var xM = Object.defineProperty; var vM = (m, a, d) => a in m ? xM(m, a, { enumerable: !0, configurable: !0, writable: !0, value: d }) : m[a] = d; var Yt = (m, a, d) => (vM(m, typeof a != "symbol" ? a + "" : a, d), d); /*! * @kurkle/color v0.3.4 * https://github.com/kurkle/color#readme * (c) 2024 Jukka Kurkela * Released under the MIT License */ function Gf(m) { return m + 0.5 | 0; } const Ic = (m, a, d) => Math.max(Math.min(m, d), a); function wf(m) { return Ic(Gf(m * 2.55), 0, 255); } function kc(m) { return Ic(Gf(m * 255), 0, 255); } function Fl(m) { return Ic(Gf(m / 2.55) / 100, 0, 1); } function $v(m) { return Ic(Gf(m * 100), 0, 100); } const sa = { 0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15 }, Gg = [..."0123456789ABCDEF"], bM = (m) => Gg[m & 15], wM = (m) => Gg[(m & 240) >> 4] + Gg[m & 15], um = (m) => (m & 240) >> 4 === (m & 15), TM = (m) => um(m.r) && um(m.g) && um(m.b) && um(m.a); function MM(m) { var a = m.length, d; return m[0] === "#" && (a === 4 || a === 5 ? d = { r: 255 & sa[m[1]] * 17, g: 255 & sa[m[2]] * 17, b: 255 & sa[m[3]] * 17, a: a === 5 ? sa[m[4]] * 17 : 255 } : (a === 7 || a === 9) && (d = { r: sa[m[1]] << 4 | sa[m[2]], g: sa[m[3]] << 4 | sa[m[4]], b: sa[m[5]] << 4 | sa[m[6]], a: a === 9 ? sa[m[7]] << 4 | sa[m[8]] : 255 })), d; } const SM = (m, a) => m < 255 ? a(m) : ""; function EM(m) { var a = TM(m) ? bM : wM; return m ? "#" + a(m.r) + a(m.g) + a(m.b) + SM(m.a, a) : void 0; } const PM = /^(hsla?|hwb|hsv)\(\s*([-+.e\d]+)(?:deg)?[\s,]+([-+.e\d]+)%[\s,]+([-+.e\d]+)%(?:[\s,]+([-+.e\d]+)(%)?)?\s*\)$/; function bb(m, a, d) { const g = a * Math.min(d, 1 - d), w = (b, E = (b + m / 30) % 12) => d - g * Math.max(Math.min(E - 3, 9 - E, 1), -1); return [w(0), w(8), w(4)]; } function AM(m, a, d) { const g = (w, b = (w + m / 60) % 6) => d - d * a * Math.max(Math.min(b, 4 - b, 1), 0); return [g(5), g(3), g(1)]; } function CM(m, a, d) { const g = bb(m, 1, 0.5); let w; for (a + d > 1 && (w = 1 / (a + d), a *= w, d *= w), w = 0; w < 3; w++) g[w] *= 1 - a - d, g[w] += a; return g; } function IM(m, a, d, g, w) { return m === w ? (a - d) / g + (a < d ? 6 : 0) : a === w ? (d - m) / g + 2 : (m - a) / g + 4; } function ay(m) { const d = m.r / 255, g = m.g / 255, w = m.b / 255, b = Math.max(d, g, w), E = Math.min(d, g, w), i = (b + E) / 2; let O, j, Y; return b !== E && (Y = b - E, j = i > 0.5 ? Y / (2 - b - E) : Y / (b + E), O = IM(d, g, w, Y, b), O = O * 60 + 0.5), [O | 0, j || 0, i]; } function ly(m, a, d, g) { return (Array.isArray(a) ? m(a[0], a[1], a[2]) : m(a, d, g)).map(kc); } function cy(m, a, d) { return ly(bb, m, a, d); } function LM(m, a, d) { return ly(CM, m, a, d); } function zM(m, a, d) { return ly(AM, m, a, d); } function wb(m) { return (m % 360 + 360) % 360; } function DM(m) { const a = PM.exec(m); let d = 255, g; if (!a) return; a[5] !== g && (d = a[6] ? wf(+a[5]) : kc(+a[5])); const w = wb(+a[2]), b = +a[3] / 100, E = +a[4] / 100; return a[1] === "hwb" ? g = LM(w, b, E) : a[1] === "hsv" ? g = zM(w, b, E) : g = cy(w, b, E), { r: g[0], g: g[1], b: g[2], a: d }; } function kM(m, a) { var d = ay(m); d[0] = wb(d[0] + a), d = cy(d), m.r = d[0], m.g = d[1], m.b = d[2]; } function RM(m) { if (!m) return; const a = ay(m), d = a[0], g = $v(a[1]), w = $v(a[2]); return m.a < 255 ? `hsla(${d}, ${g}%, ${w}%, ${Fl(m.a)})` : `hsl(${d}, ${g}%, ${w}%)`; } const Xv = { x: "dark", Z: "light", Y: "re", X: "blu", W: "gr", V: "medium", U: "slate", A: "ee", T: "ol", S: "or", B: "ra", C: "lateg", D: "ights", R: "in", Q: "turquois", E: "hi", P: "ro", O: "al", N: "le", M: "de", L: "yello", F: "en", K: "ch", G: "arks", H: "ea", I: "ightg", J: "wh" }, Yv = { OiceXe: "f0f8ff", antiquewEte: "faebd7", aqua: "ffff", aquamarRe: "7fffd4", azuY: "f0ffff", beige: "f5f5dc", bisque: "ffe4c4", black: "0", blanKedOmond: "ffebcd", Xe: "ff", XeviTet: "8a2be2", bPwn: "a52a2a", burlywood: "deb887", caMtXe: "5f9ea0", KartYuse: "7fff00", KocTate: "d2691e", cSO: "ff7f50", cSnflowerXe: "6495ed", cSnsilk: "fff8dc", crimson: "dc143c", cyan: "ffff", xXe: "8b", xcyan: "8b8b", xgTMnPd: "b8860b", xWay: "a9a9a9", xgYF: "6400", xgYy: "a9a9a9", xkhaki: "bdb76b", xmagFta: "8b008b", xTivegYF: "556b2f", xSange: "ff8c00", xScEd: "9932cc", xYd: "8b0000", xsOmon: "e9967a", xsHgYF: "8fbc8f", xUXe: "483d8b", xUWay: "2f4f4f", xUgYy: "2f4f4f", xQe: "ced1", xviTet: "9400d3", dAppRk: "ff1493", dApskyXe: "bfff", dimWay: "696969", dimgYy: "696969", dodgerXe: "1e90ff", fiYbrick: "b22222", flSOwEte: "fffaf0", foYstWAn: "228b22", fuKsia: "ff00ff", gaRsbSo: "dcdcdc", ghostwEte: "f8f8ff", gTd: "ffd700", gTMnPd: "daa520", Way: "808080", gYF: "8000", gYFLw: "adff2f", gYy: "808080", honeyMw: "f0fff0", hotpRk: "ff69b4", RdianYd: "cd5c5c", Rdigo: "4b0082", ivSy: "fffff0", khaki: "f0e68c", lavFMr: "e6e6fa", lavFMrXsh: "fff0f5", lawngYF: "7cfc00", NmoncEffon: "fffacd", ZXe: "add8e6", ZcSO: "f08080", Zcyan: "e0ffff", ZgTMnPdLw: "fafad2", ZWay: "d3d3d3", ZgYF: "90ee90", ZgYy: "d3d3d3", ZpRk: "ffb6c1", ZsOmon: "ffa07a", ZsHgYF: "20b2aa", ZskyXe: "87cefa", ZUWay: "778899", ZUgYy: "778899", ZstAlXe: "b0c4de", ZLw: "ffffe0", lime: "ff00", limegYF: "32cd32", lRF: "faf0e6", magFta: "ff00ff", maPon: "800000", VaquamarRe: "66cdaa", VXe: "cd", VScEd: "ba55d3", VpurpN: "9370db", VsHgYF: "3cb371", VUXe: "7b68ee", VsprRggYF: "fa9a", VQe: "48d1cc", VviTetYd: "c71585", midnightXe: "191970", mRtcYam: "f5fffa", mistyPse: "ffe4e1", moccasR: "ffe4b5", navajowEte: "ffdead", navy: "80", Tdlace: "fdf5e6", Tive: "808000", TivedBb: "6b8e23", Sange: "ffa500", SangeYd: "ff4500", ScEd: "da70d6", pOegTMnPd: "eee8aa", pOegYF: "98fb98", pOeQe: "afeeee", pOeviTetYd: "db7093", papayawEp: "ffefd5", pHKpuff: "ffdab9", peru: "cd853f", pRk: "ffc0cb", plum: "dda0dd", powMrXe: "b0e0e6", purpN: "800080", YbeccapurpN: "663399", Yd: "ff0000", Psybrown: "bc8f8f", PyOXe: "4169e1", saddNbPwn: "8b4513", sOmon: "fa8072", sandybPwn: "f4a460", sHgYF: "2e8b57", sHshell: "fff5ee", siFna: "a0522d", silver: "c0c0c0", skyXe: "87ceeb", UXe: "6a5acd", UWay: "708090", UgYy: "708090", snow: "fffafa", sprRggYF: "ff7f", stAlXe: "4682b4", tan: "d2b48c", teO: "8080", tEstN: "d8bfd8", tomato: "ff6347", Qe: "40e0d0", viTet: "ee82ee", JHt: "f5deb3", wEte: "ffffff", wEtesmoke: "f5f5f5", Lw: "ffff00", LwgYF: "9acd32" }; function OM() { const m = {}, a = Object.keys(Yv), d = Object.keys(Xv); let g, w, b, E, i; for (g = 0; g < a.length; g++) { for (E = i = a[g], w = 0; w < d.length; w++) b = d[w], i = i.replace(b, Xv[b]); b = parseInt(Yv[E], 16), m[i] = [b >> 16 & 255, b >> 8 & 255, b & 255]; } return m; } let dm; function FM(m) { dm || (dm = OM(), dm.transparent = [0, 0, 0, 0]); const a = dm[m.toLowerCase()]; return a && { r: a[0], g: a[1], b: a[2], a: a.length === 4 ? a[3] : 255 }; } const BM = /^rgba?\(\s*([-+.\d]+)(%)?[\s,]+([-+.e\d]+)(%)?[\s,]+([-+.e\d]+)(%)?(?:[\s,/]+([-+.e\d]+)(%)?)?\s*\)$/; function NM(m) { const a = BM.exec(m); let d = 255, g, w, b; if (a) { if (a[7] !== g) { const E = +a[7]; d = a[8] ? wf(E) : Ic(E * 255, 0, 255); } return g = +a[1], w = +a[3], b = +a[5], g = 255 & (a[2] ? wf(g) : Ic(g, 0, 255)), w = 255 & (a[4] ? wf(w) : Ic(w, 0, 255)), b = 255 & (a[6] ? wf(b) : Ic(b, 0, 255)), { r: g, g: w, b, a: d }; } } function VM(m) { return m && (m.a < 255 ? `rgba(${m.r}, ${m.g}, ${m.b}, ${Fl(m.a)})` : `rgb(${m.r}, ${m.g}, ${m.b})`); } const Ig = (m) => m <= 31308e-7 ? m * 12.92 : Math.pow(m, 1 / 2.4) * 1.055 - 0.055, qu = (m) => m <= 0.04045 ? m / 12.92 : Math.pow((m + 0.055) / 1.055, 2.4); function UM(m, a, d) { const g = qu(Fl(m.r)), w = qu(Fl(m.g)), b = qu(Fl(m.b)); return { r: kc(Ig(g + d * (qu(Fl(a.r)) - g))), g: kc(Ig(w + d * (qu(Fl(a.g)) - w))), b: kc(Ig(b + d * (qu(Fl(a.b)) - b))), a: m.a + d * (a.a - m.a) }; } function fm(m, a, d) { if (m) { let g = ay(m); g[a] = Math.max(0, Math.min(g[a] + g[a] * d, a === 0 ? 360 : 1)), g = cy(g), m.r = g[0], m.g = g[1], m.b = g[2]; } } function Tb(m, a) { return m && Object.assign(a || {}, m); } function Kv(m) { var a = { r: 0, g: 0, b: 0, a: 255 }; return Array.isArray(m) ? m.length >= 3 && (a = { r: m[0], g: m[1], b: m[2], a: 255 }, m.length > 3 && (a.a = kc(m[3]))) : (a = Tb(m, { r: 0, g: 0, b: 0, a: 1 }), a.a = kc(a.a)), a; } function jM(m) { return m.charAt(0) === "r" ? NM(m) : DM(m); } class kf { constructor(a) { if (a instanceof kf) return a; const d = typeof a; let g; d === "object" ? g = Kv(a) : d === "string" && (g = MM(a) || FM(a) || jM(a)), this._rgb = g, this._valid = !!g; } get valid() { return this._valid; } get rgb() { var a = Tb(this._rgb); return a && (a.a = Fl(a.a)), a; } set rgb(a) { this._rgb = Kv(a); } rgbString() { return this._valid ? VM(this._rgb) : void 0; } hexString() { return this._valid ? EM(this._rgb) : void 0; } hslString() { return this._valid ? RM(this._rgb) : void 0; } mix(a, d) { if (a) { const g = this.rgb, w = a.rgb; let b; const E = d === b ? 0.5 : d, i = 2 * E - 1, O = g.a - w.a, j = ((i * O === -1 ? i : (i + O) / (1 + i * O)) + 1) / 2; b = 1 - j, g.r = 255 & j * g.r + b * w.r + 0.5, g.g = 255 & j * g.g + b * w.g + 0.5, g.b = 255 & j * g.b + b * w.b + 0.5, g.a = E * g.a + (1 - E) * w.a, this.rgb = g; } return this; } interpolate(a, d) { return a && (this._rgb = UM(this._rgb, a._rgb, d)), this; } clone() { return new kf(this.rgb); } alpha(a) { return this._rgb.a = kc(a), this; } clearer(a) { const d = this._rgb; return d.a *= 1 - a, this; } greyscale() { const a = this._rgb, d = Gf(a.r * 0.3 + a.g * 0.59 + a.b * 0.11); return a.r = a.g = a.b = d, this; } opaquer(a) { const d = this._rgb; return d.a *= 1 + a, this; } negate() { const a = this._rgb; return a.r = 255 - a.r, a.g = 255 - a.g, a.b = 255 - a.b, this; } lighten(a) { return fm(this._rgb, 2, a), this; } darken(a) { return fm(this._rgb, 2, -a), this; } saturate(a) { return fm(this._rgb, 1, a), this; } desaturate(a) { return fm(this._rgb, 1, -a), this; } rotate(a) { return kM(this._rgb, a), this; } } /*! * Chart.js v4.4.7 * https://www.chartjs.org * (c) 2024 Chart.js Contributors * Released under the MIT License */ function kl() { } const GM = (() => { let m = 0; return () => m++; })(); function En(m) { return m == null; } function hs(m) { if (Array.isArray && Array.isArray(m)) return !0; const a = Object.prototype.toString.call(m); return a.slice(0, 7) === "[object" && a.slice(-6) === "Array]"; } function yn(m) { return m !== null && Object.prototype.toString.call(m) === "[object Object]"; } function As(m) { return (typeof m == "number" || m instanceof Number) && isFinite(+m); } function Bo(m, a) { return As(m) ? m : a; } function en(m, a) { return typeof m > "u" ? a : m; } const ZM = (m, a) => typeof m == "string" && m.endsWith("%") ? parseFloat(m) / 100 : +m / a, Mb = (m, a) => typeof m == "string" && m.endsWith("%") ? parseFloat(m) / 100 * a : +m; function is(m, a, d) { if (m && typeof m.call == "function") return m.apply(d, a); } function Zn(m, a, d, g) { let w, b, E; if (hs(m)) if (b = m.length, g) for (w = b - 1; w >= 0; w--) a.call(d, m[w], w); else for (w = 0; w < b; w++) a.call(d, m[w], w); else if (yn(m)) for (E = Object.keys(m), b = E.length, w = 0; w < b; w++) a.call(d, m[E[w]], E[w]); } function Om(m, a) { let d, g, w, b; if (!m || !a || m.length !== a.length) return !1; for (d = 0, g = m.length; d < g; ++d) if (w = m[d], b = a[d], w.datasetIndex !== b.datasetIndex || w.index !== b.index) return !1; return !0; } function Fm(m) { if (hs(m)) return m.map(Fm); if (yn(m)) { const a = /* @__PURE__ */ Object.create(null), d = Object.keys(m), g = d.length; let w = 0; for (; w < g; ++w) a[d[w]] = Fm(m[d[w]]); return a; } return m; } function Sb(m) { return [ "__proto__", "prototype", "constructor" ].indexOf(m) === -1; } function HM(m, a, d, g) { if (!Sb(m)) return; const w = a[m], b = d[m]; yn(w) && yn(b) ? Rf(w, b, g) : a[m] = Fm(b); } function Rf(m, a, d) { const g = hs(a) ? a : [ a ], w = g.length; if (!yn(m)) return m; d = d || {}; const b = d.merger || HM; let E; for (let i = 0; i < w; ++i) { if (E = g[i], !yn(E)) continue; const O = Object.keys(E); for (let j = 0, Y = O.length; j < Y; ++j) b(O[j], m, E, d); } return m; } function Cf(m, a) { return Rf(m, a, { merger: qM }); } function qM(m, a, d) { if (!Sb(m)) return; const g = a[m], w = d[m]; yn(g) && yn(w) ? Cf(g, w) : Object.prototype.hasOwnProperty.call(a, m) || (a[m] = Fm(w)); } const Jv = { // Chart.helpers.core resolveObjectKey should resolve empty key to root object "": (m) => m, // default resolvers x: (m) => m.x, y: (m) => m.y }; function WM(m) { const a = m.split("."), d = []; let g = ""; for (const w of a) g += w, g.endsWith("\\") ? g = g.slice(0, -1) + "." : (d.push(g), g = ""); return d; } function $M(m) { const a = WM(m); return (d) => { for (const g of a) { if (g === "") break; d = d && d[g]; } return d; }; } function Rc(m, a) { return (Jv[a] || (Jv[a] = $M(a)))(m); } function hy(m) { return m.charAt(0).toUpperCase() + m.slice(1); } const Of = (m) => typeof m < "u", Oc = (m) => typeof m == "function", Qv = (m, a) => { if (m.size !== a.size) return !1; for (const d of m) if (!a.has(d)) return !1; return !0; }; function XM(m) { return m.type === "mouseup" || m.type === "click" || m.type === "contextmenu"; } const ds = Math.PI, us = 2 * ds, YM = us + ds, Bm = Number.POSITIVE_INFINITY, KM = ds / 180, Ns = ds / 2, Ph = ds / 4, e1 = ds * 2 / 3, Lc = Math.log10, ll = Math.sign; function If(m, a, d) { return Math.abs(m - a) < d; } function t1(m) { const a = Math.round(m); m = If(m, a, m / 1e3) ? a : m; const d = Math.pow(10, Math.floor(Lc(m))), g = m / d; return (g <= 1 ? 1 : g <= 2 ? 2 : g <= 5 ? 5 : 10) * d; } function JM(m) { const a = [], d = Math.sqrt(m); let g; for (g = 1; g < d; g++) m % g === 0 && (a.push(g), a.push(m / g)); return d === (d | 0) && a.push(d), a.sort((w, b) => w - b).pop(), a; } function Xu(m) { return !isNaN(parseFloat(m)) && isFinite(m); } function QM(m, a) { const d = Math.round(m); return d - a <= m && d + a >= m; } function Eb(m, a, d) { let g, w, b; for (g = 0, w = m.length; g < w; g++) b = m[g][d], isNaN(b) || (a.min = Math.min(a.min, b), a.max = Math.max(a.max, b)); } function Ia(m) { return m * (ds / 180); } function uy(m) { return m * (180 / ds); } function i1(m) { if (!As(m)) return; let a = 1, d = 0; for (; Math.round(m * a) / a !== m; ) a *= 10, d++; return d; } function Pb(m, a) { const d = a.x - m.x, g = a.y - m.y, w = Math.sqrt(d * d + g * g); let b = Math.atan2(g, d); return b < -0.5 * ds && (b += us), { angle: b, distance: w }; } function Zg(m, a) { return Math.sqrt(Math.pow(a.x - m.x, 2) + Math.pow(a.y - m.y, 2)); } function eS(m, a) { return (m - a + YM) % us - ds; } function No(m) { return (m % us + us) % us; } function Ff(m, a, d, g) { const w = No(m), b = No(a), E = No(d), i = No(b - w), O = No(E - w), j = No(w - b), Y = No(w - E); return w === b || w === E || g && b === E || i > O && j < Y; } function gr(m, a, d) { return Math.max(a, Math.min(d, m)); } function tS(m) { return gr(m, -32768, 32767); } function Nl(m, a, d, g = 1e-6) { return m >= Math.min(a, d) - g && m <= Math.max(a, d) + g; } function dy(m, a, d) { d = d || ((E) => m[E] < a); let g = m.length - 1, w = 0, b; for (; g - w > 1; ) b = w + g >> 1, d(b) ? w = b : g = b; return { lo: w, hi: g }; } const Vl = (m, a, d, g) => dy(m, d, g ? (w) => { const b = m[w][a]; return b < d || b === d && m[w + 1][a] === d; } : (w) => m[w][a] < d), iS = (m, a, d) => dy(m, d, (g) => m[g][a] >= d); function nS(m, a, d) { let g = 0, w = m.length; for (; g < w && m[g] < a; ) g++; for (; w > g && m[w - 1] > d; ) w--; return g > 0 || w < m.length ? m.slice(g, w) : m; } const Ab = [ "push", "pop", "shift", "splice", "unshift" ]; function sS(m, a) { if (m._chartjs) { m._chartjs.listeners.push(a); return; } Object.defineProperty(m, "_chartjs", { configurable: !0, enumerable: !1, value: { listeners: [ a ] } }), Ab.forEach((d) => { const g = "_onData" + hy(d), w = m[d]; Object.defineProperty(m, d, { configurable: !0, enumerable: !1, value(...b) { const E = w.apply(this, b); return m._chartjs.listeners.forEach((i) => { typeof i[g] == "function" && i[g](...b); }), E; } }); }); } function n1(m, a) { const d = m._chartjs; if (!d) return; const g = d.listeners, w = g.indexOf(a); w !== -1 && g.splice(w, 1), !(g.length > 0) && (Ab.forEach((b) => { delete m[b]; }), delete m._chartjs); } function Cb(m) { const a = new Set(m); return a.size === m.length ? m : Array.from(a); } const Ib = function() { return typeof window > "u" ? function(m) { return m(); } : window.requestAnimationFrame; }(); function Lb(m, a) { let d = [], g = !1; return function(...w) { d = w, g || (g = !0, Ib.call(window, () => { g = !1, m.apply(a, d); })); }; } function rS(m, a) { let d; return function(...g) { return a ? (clearTimeout(d), d = setTimeout(m, a, g)) : m.apply(this, g), a; }; } const fy = (m) => m === "start" ? "left" : m === "end" ? "right" : "center", Ur = (m, a, d) => m === "start" ? a : m === "end" ? d : (a + d) / 2, oS = (m, a, d, g) => m === (g ? "left" : "right") ? d : m === "center" ? (a + d) / 2 : a; function zb(m, a, d) { const g = a.length; let w = 0, b = g; if (m._sorted) { const { iScale: E, _parsed: i } = m, O = E.axis, { min: j, max: Y, minDefined: J, maxDefined: ae } = E.getUserBounds(); J && (w = gr(Math.min( // @ts-expect-error Need to type _parsed Vl(i, O, j).lo, // @ts-expect-error Need to fix types on _lookupByKey d ? g : Vl(a, O, E.getPixelForValue(j)).lo ), 0, g - 1)), ae ? b = gr(Math.max( // @ts-expect-error Need to type _parsed Vl(i, E.axis, Y, !0).hi + 1, // @ts-expect-error Need to fix types on _lookupByKey d ? 0 : Vl(a, O, E.getPixelForValue(Y), !0).hi + 1 ), w, g) - w : b = g - w; } return { start: w, count: b }; } function Db(m) { const { xScale: a, yScale: d, _scaleRanges: g } = m, w = { xmin: a.min, xmax: a.max, ymin: d.min, ymax: d.max }; if (!g) return m._scaleRanges = w, !0; const b = g.xmin !== a.min || g.xmax !== a.max || g.ymin !== d.min || g.ymax !== d.max; return Object.assign(g, w), b; } const pm = (m) => m === 0 || m === 1, s1 = (m, a, d) => -(Math.pow(2, 10 * (m -= 1)) * Math.sin((m - a) * us / d)), r1 = (m, a, d) => Math.pow(2, -10 * m) * Math.sin((m - a) * us / d) + 1, Lf = { linear: (m) => m, easeInQuad: (m) => m * m, easeOutQuad: (m) => -m * (m - 2), easeInOutQuad: (m) => (m /= 0.5) < 1 ? 0.5 * m * m : -0.5 * (--m * (m - 2) - 1), easeInCubic: (m) => m * m * m, easeOutCubic: (m) => (m -= 1) * m * m + 1, easeInOutCubic: (m) => (m /= 0.5) < 1 ? 0.5 * m * m * m : 0.5 * ((m -= 2) * m * m + 2), easeInQuart: (m) => m * m * m * m, easeOutQuart: (m) => -((m -= 1) * m * m * m - 1), easeInOutQuart: (m) => (m /= 0.5) < 1 ? 0.5 * m * m * m * m : -0.5 * ((m -= 2) * m * m * m - 2), easeInQuint: (m) => m * m * m * m * m, easeOutQuint: (m) => (m -= 1) * m * m * m * m + 1, easeInOutQuint: (m) => (m /= 0.5) < 1 ? 0.5 * m * m * m * m * m : 0.5 * ((m -= 2) * m * m * m * m + 2), easeInSine: (m) => -Math.cos(m * Ns) + 1, easeOutSine: (m) => Math.sin(m * Ns), easeInOutSine: (m) => -0.5 * (Math.cos(ds * m) - 1), easeInExpo: (m) => m === 0 ? 0 : Math.pow(2, 10 * (m - 1)), easeOutExpo: (m) => m === 1 ? 1 : -Math.pow(2, -10 * m) + 1, easeInOutExpo: (m) => pm(m) ? m : m < 0.5 ? 0.5 * Math.pow(2, 10 * (m * 2 - 1)) : 0.5 * (-Math.pow(2, -10 * (m * 2 - 1)) + 2), easeInCirc: (m) => m >= 1 ? m : -(Math.sqrt(1 - m * m) - 1), easeOutCirc: (m) => Math.sqrt(1 - (m -= 1) * m), easeInOutCirc: (m) => (m /= 0.5) < 1 ? -0.5 * (Math.sqrt(1 - m * m) - 1) : 0.5 * (Math.sqrt(1 - (m -= 2) * m) + 1), easeInElastic: (m) => pm(m) ? m : s1(m, 0.075, 0.3), easeOutElastic: (m) => pm(m) ? m : r1(m, 0.075, 0.3), easeInOutElastic(m) { return pm(m) ? m : m < 0.5 ? 0.5 * s1(m * 2, 0.1125, 0.45) : 0.5 + 0.5 * r1(m * 2 - 1, 0.1125, 0.45); }, easeInBack(m) { return m * m * ((1.70158 + 1) * m - 1.70158); }, easeOutBack(m) { return (m -= 1) * m * ((1.70158 + 1) * m + 1.70158) + 1; }, easeInOutBack(m) { let a = 1.70158; return (m /= 0.5) < 1 ? 0.5 * (m * m * (((a *= 1.525) + 1) * m - a)) : 0.5 * ((m -= 2) * m * (((a *= 1.525) + 1) * m + a) + 2); }, easeInBounce: (m) => 1 - Lf.easeOutBounce(1 - m), easeOutBounce(m) { return m < 1 / 2.75 ? 7.5625 * m * m : m < 2 / 2.75 ? 7.5625 * (m -= 1.5 / 2.75) * m + 0.75 : m < 2.5 / 2.75 ? 7.5625 * (m -= 2.25 / 2.75) * m + 0.9375 : 7.5625 * (m -= 2.625 / 2.75) * m + 0.984375; }, easeInOutBounce: (m) => m < 0.5 ? Lf.easeInBounce(m * 2) * 0.5 : Lf.easeOutBounce(m * 2 - 1) * 0.5 + 0.5 }; function py(m) { if (m && typeof m == "object") { const a = m.toString(); return a === "[object CanvasPattern]" || a === "[object CanvasGradient]"; } return !1; } function o1(m) { return py(m) ? m : new kf(m); } function Lg(m) { return py(m) ? m : new kf(m).saturate(0.5).darken(0.1).hexString(); } const aS = [ "x", "y", "borderWidth", "radius", "tension" ], lS = [ "color", "borderColor", "backgroundColor" ]; function cS(m) { m.set("animation", { delay: void 0, duration: 1e3, easing: "easeOutQuart", fn: void 0, from: void 0, loop: void 0, to: void 0, type: void 0 }), m.describe("animation", { _fallback: !1, _indexable: !1, _scriptable: (a) => a !== "onProgress" && a !== "onComplete" && a !== "fn" }), m.set("animations", { colors: { type: "color", properties: lS }, numbers: { type: "number", properties: aS } }), m.describe("animations", { _fallback: "animation" }), m.set("transitions", { active: { animation: { duration: 400 } }, resize: { animation: { duration: 0 } }, show: { animations: { colors: { from: "transparent" }, visible: { type: "boolean", duration: 0 } } }, hide: { animations: { colors: { to: "transparent" }, visible: { type: "boolean", easing: "linear", fn: (a) => a | 0 } } } }); } function hS(m) { m.set("layout", { autoPadding: !0, padding: { top: 0, right: 0, bottom: 0, left: 0 } }); } const a1 = /* @__PURE__ */ new Map(); function uS(m, a) { a = a || {}; const d = m + JSON.stringify(a); let g = a1.get(d); return g || (g = new Intl.NumberFormat(m, a), a1.set(d, g)), g; } function Zf(m, a, d) { return uS(a, d).format(m); } const kb = { values(m) { return hs(m) ? m : "" + m; }, numeric(m, a, d) { if (m === 0) return "0"; const g = this.chart.options.locale; let w, b = m; if (d.length > 1) { const j = Math.max(Math.abs(d[0].value), Math.abs(d[d.length - 1].value)); (j < 1e-4 || j > 1e15) && (w = "scientific"), b = dS(m, d); } const E = Lc(Math.abs(b)), i = isNaN(E) ? 1 : Math.max(Math.min(-1 * Math.floor(E), 20), 0), O = { notation: w, minimumFractionDigits: i, maximumFractionDigits: i }; return Object.assign(O, this.options.ticks.format), Zf(m, g, O); }, logarithmic(m, a, d) { if (m === 0) return "0"; const g = d[a].significand || m / Math.pow(10, Math.floor(Lc(m))); return [ 1, 2, 3, 5, 10, 15 ].includes(g) || a > 0.8 * d.length ? kb.numeric.call(this, m, a, d) : ""; } }; function dS(m, a) { let d = a.length > 3 ? a[2].value - a[1].value : a[1].value - a[0].value; return Math.abs(d) >= 1 && m !== Math.floor(m) && (d = m - Math.floor(m)), d; } var qm = { formatters: kb }; function fS(m) { m.set("scale", { display: !0, offset: !1, reverse: !1, beginAtZero: !1, bounds: "ticks", clip: !0, grace: 0, grid: { display: !0, lineWidth: 1, drawOnChartArea: !0, drawTicks: !0, tickLength: 8, tickWidth: (a, d) => d.lineWidth, tickColor: (a, d) => d.color, offset: !1 }, border: { display: !0, dash: [], dashOffset: 0, width: 1 }, title: { display: !1, text: "", padding: { top: 4, bottom: 4 } }, ticks: { minRotation: 0, maxRotation: 50, mirror: !1, textStrokeWidth: 0, textStrokeColor: "", padding: 3, display: !0, autoSkip: !0, autoSkipPadding: 3, labelOffset: 0, callback: qm.formatters.values, minor: {}, major: {}, align: "center", crossAlign: "near", showLabelBackdrop: !1, backdropColor: "rgba(255, 255, 255, 0.75)", backdropPadding: 2 } }), m.route("scale.ticks", "color", "", "color"), m.route("scale.grid", "color", "", "borderColor"), m.route("scale.border", "color", "", "borderColor"), m.route("scale.title", "color", "", "color"), m.describe("scale", { _fallback: !1, _scriptable: (a) => !a.startsWith("before") && !a.startsWith("after") && a !== "callback" && a !== "parser", _indexable: (a) => a !== "borderDash" && a !== "tickBorderDash" && a !== "dash" }), m.describe("scales", { _fallback: "scale" }), m.describe("scale.ticks", { _scriptable: (a) => a !== "backdropPadding" && a !== "callback", _indexable: (a) => a !== "backdropPadding" }); } const Oh = /* @__PURE__ */ Object.create(null), Hg = /* @__PURE__ */ Object.create(null); function zf(m, a) { if (!a) return m; const d = a.split("."); for (let g = 0, w = d.length; g < w; ++g) { const b = d[g]; m = m[b] || (m[b] = /* @__PURE__ */ Object.create(null)); } return m; } function zg(m, a, d) { return typeof a == "string" ? Rf(zf(m, a), d) : Rf(zf(m, ""), a); } class pS { constructor(a, d) { this.animation = void 0, this.backgroundColor = "rgba(0,0,0,0.1)", this.borderColor = "rgba(0,0,0,0.1)", this.color = "#666", this.datasets = {}, this.devicePixelRatio = (g) => g.chart.platform.getDevicePixelRatio(), this.elements = {}, this.events = [ "mousemove", "mouseout", "click", "touchstart", "touchmove" ], this.font = { family: "'Helvetica Neue', 'Helvetica', 'Arial', sans-serif", size: 12, style: "normal", lineHeight: 1.2, weight: null }, this.hover = {}, this.hoverBackgroundColor = (g, w) => Lg(w.backgroundColor), this.hoverBorderColor = (g, w) => Lg(w.borderColor), this.hoverColor = (g, w) => Lg(w.color), this.indexAxis = "x", this.interaction = { mode: "nearest", intersect: !0, includeInvisible: !1 }, this.maintainAspectRatio = !0, this.onHover = null, this.onClick = null, this.parsing = !0, this.plugins = {}, this.responsive = !0, this.scale = void 0, this.scales = {}, this.showLine = !0, this.drawActiveElementsOnTop = !0, this.describe(a), this.apply(d); } set(a, d) { return zg(this, a, d); } get(a) { return zf(this, a); } describe(a, d) { return zg(Hg, a, d); } override(a, d) { return zg(Oh, a, d); } route(a, d, g, w) { const b = zf(this, a), E = zf(this, g), i = "_" + d; Object.defineProperties(b, { [i]: { value: b[d], writable: !0 }, [d]: { enumerable: !0, get() { const O = this[i], j = E[w]; return yn(O) ? Object.assign({}, j, O) : en(O, j); }, set(O) { this[i] = O; } } }); } apply(a) { a.forEach((d) => d(this)); } } var ys = /* @__PURE__ */ new pS({ _scriptable: (m) => !m.startsWith("on"), _indexable: (m) => m !== "events", hover: { _fallback: "interaction" }, interaction: { _scriptable: !1, _indexable: !1 } }, [ cS, hS, fS ]); function mS(m) { return !m || En(m.size) || En(m.family) ? null : (m.style ? m.style + " " : "") + (m.weight ? m.weight + " " : "") + m.size + "px " + m.family; } function Nm(m, a, d, g, w) { let b = a[w]; return b || (b = a[w] = m.measureText(w).width, d.push(w)), b > g && (g = b), g; } function _S(m, a, d, g) { g = g || {}; let w = g.data = g.data || {}, b = g.garbageCollect = g.garbageCollect || []; g.font !== a && (w = g.data = {}, b = g.garbageCollect = [], g.font = a), m.save(), m.font = a; let E = 0; const i = d.length; let O, j, Y, J, ae; for (O = 0; O < i; O++) if (J = d[O], J != null && !hs(J)) E = Nm(m, w, b, E, J); else if (hs(J)) for (j = 0, Y = J.length; j < Y; j++) ae = J[j], ae != null && !hs(ae) && (E = Nm(m, w, b, E, ae)); m.restore(); const ce = b.length / 2; if (ce > d.length) { for (O = 0; O < ce; O++) delete w[b[O]]; b.splice(0, ce); } return E; } function Ah(m, a, d) { const g = m.currentDevicePixelRatio, w = d !== 0 ? Math.max(d / 2, 0.5) : 0; return Math.round((a - w) * g) / g + w; } function l1(m, a) { !a && !m || (a = a || m.getContext("2d"), a.save(), a.resetTransform(), a.clearRect(0, 0, m.width, m.height), a.restore()); } function qg(m, a, d, g) { Rb(m, a, d, g, null); } function Rb(m, a, d, g, w) { let b, E, i, O, j, Y, J, ae; const ce = a.pointStyle, Te = a.rotation, be = a.radius; let Ze = (Te || 0) * KM; if (ce && typeof ce == "object" && (b = ce.toString(), b === "[object HTMLImageElement]" || b === "[object HTMLCanvasElement]")) { m.save(), m.translate(d, g), m.rotate(Ze), m.drawImage(ce, -ce.width / 2, -ce.height / 2, ce.width, ce.height), m.restore(); return; } if (!(isNaN(be) || be <= 0)) { switch (m.beginPath(), ce) { default: w ? m.ellipse(d, g, w / 2, be, 0, 0, us) : m.arc(d, g, be, 0, us), m.closePath(); break; case "triangle": Y = w ? w / 2 : be, m.moveTo(d + Math.sin(Ze) * Y, g - Math.cos(Ze) * be), Ze += e1, m.lineTo(d + Math.sin(Ze) * Y, g - Math.cos(Ze) * be), Ze += e1, m.lineTo(d + Math.sin(Ze) * Y, g - Math.cos(Ze) * be), m.closePath(); break; case "rectRounded": j = be * 0.516, O = be - j, E = Math.cos(Ze + Ph) * O, J = Math.cos(Ze + Ph) * (w ? w / 2 - j : O), i = Math.sin(Ze + Ph) * O, ae = Math.sin(Ze + Ph) * (w ? w / 2 - j : O), m.arc(d - J, g - i, j, Ze - ds, Ze - Ns), m.arc(d + ae, g - E, j, Ze - Ns, Ze), m.arc(d + J, g + i, j, Ze, Ze + Ns), m.arc(d - ae, g + E, j, Ze + Ns, Ze + ds), m.closePath(); break; case "rect": if (!Te) { O = Math.SQRT1_2 * be, Y = w ? w / 2 : O, m.rect(d - Y, g - O, 2 * Y, 2 * O); break; } Ze += Ph; case "rectRot": J = Math.cos(Ze) * (w ? w / 2 : be), E = Math.cos(Ze) * be, i = Math.sin(Ze) * be, ae = Math.sin(Ze) * (w ? w / 2 : be), m.moveTo(d - J, g - i), m.lineTo(d + ae, g - E), m.lineTo(d + J, g + i), m.lineTo(d - ae, g + E), m.closePath(); break; case "crossRot": Ze += Ph; case "cross": J = Math.cos(Ze) * (w ? w / 2 : be), E = Math.cos(Ze) * be, i = Math.sin(Ze) * be, ae = Math.sin(Ze) * (w ? w / 2 : be), m.moveTo(d - J, g - i), m.lineTo(d + J, g + i), m.moveTo(d + ae, g - E), m.lineTo(d - ae, g + E); break; case "star": J = Math.cos(Ze) * (w ? w / 2 : be), E = Math.cos(Ze) * be, i = Math.sin(Ze) * be, ae = Math.sin(Ze) * (w ? w / 2 : be), m.moveTo(d - J, g - i), m.lineTo(d + J, g + i), m.moveTo(d + ae, g - E), m.lineTo(d - ae, g + E), Ze += Ph, J = Math.cos(Ze) * (w ? w / 2 : be), E = Math.cos(Ze) * be, i = Math.sin(Ze) * be, ae = Math.sin(Ze) * (w ? w / 2 : be), m.moveTo(d - J, g - i), m.lineTo(d + J, g + i), m.moveTo(d + ae, g - E), m.lineTo(d - ae, g + E); break; case "line": E = w ? w / 2 : Math.cos(Ze) * be, i = Math.sin(Ze) * be, m.moveTo(d - E, g - i), m.lineTo(d + E, g + i); break; case "dash": m.moveTo(d, g), m.lineTo(d + Math.cos(Ze) * (w ? w / 2 : be), g + Math.sin(Ze) * be); break; case !1: m.closePath(); break; } m.fill(), a.borderWidth > 0 && m.stroke(); } } function Ul(m, a, d) { return d = d || 0.5, !a || m && m.x > a.left - d && m.x < a.right + d && m.y > a.top - d && m.y < a.bottom + d; } function Wm(m, a) { m.save(), m.beginPath(), m.rect(a.left, a.top, a.right - a.left, a.bottom - a.top), m.clip(); } function $m(m) { m.restore(); } function gS(m, a, d, g, w) { if (!a) return m.lineTo(d.x, d.y); if (w === "middle") { const b = (a.x + d.x) / 2; m.lineTo(b, a.y), m.lineTo(b, d.y); } else w === "after" != !!g ? m.lineTo(a.x, d.y) : m.lineTo(d.x, a.y); m.lineTo(d.x, d.y); } function yS(m, a, d, g) { if (!a) return m.lineTo(d.x, d.y); m.bezierCurveTo(g ? a.cp1x : a.cp2x, g ? a.cp1y : a.cp2y, g ? d.cp2x : d.cp1x, g ? d.cp2y : d.cp1y, d.x, d.y); } function xS(m, a) { a.translation && m.translate(a.translation[0], a.translation[1]), En(a.rotation) || m.rotate(a.rotation), a.color && (m.fillStyle = a.color), a.textAlign && (m.textAlign = a.textAlign), a.textBaseline && (m.textBaseline = a.textBaseline); } function vS(m, a, d, g, w) { if (w.strikethrough || w.underline) { const b = m.measureText(g), E = a - b.actualBoundingBoxLeft, i = a + b.actualBoundingBoxRight, O = d - b.actualBoundingBoxAscent, j = d + b.actualBoundingBoxDescent, Y = w.strikethrough ? (O + j) / 2 : j; m.strokeStyle = m.fillStyle, m.beginPath(), m.lineWidth = w.decorationWidth || 2, m.moveTo(E, Y), m.lineTo(i, Y), m.stroke(); } } function bS(m, a) { const d = m.fillStyle; m.fillStyle = a.color, m.fillRect(a.left, a.top, a.width, a.height), m.fillStyle = d; } function Fh(m, a, d, g, w, b = {}) { const E = hs(a) ? a : [ a ], i = b.strokeWidth > 0 && b.strokeColor !== ""; let O, j; for (m.save(), m.font = w.string, xS(m, b), O = 0; O < E.length; ++O) j = E[O], b.backdrop && bS(m, b.backdrop), i && (b.strokeColor && (m.strokeStyle = b.strokeColor), En(b.strokeWidth) || (m.lineWidth = b.strokeWidth), m.strokeText(j, d, g, b.maxWidth)), m.fillText(j, d, g, b.maxWidth), vS(m, d, g, j, b), g += Number(w.lineHeight); m.restore(); } function Bf(m, a) { const { x: d, y: g, w, h: b, radius: E } = a; m.arc(d + E.topLeft, g + E.topLeft, E.topLeft, 1.5 * ds, ds, !0), m.lineTo(d, g + b - E.bottomLeft), m.arc(d + E.bottomLeft, g + b - E.bottomLeft, E.bottomLeft, ds, Ns, !0), m.lineTo(d + w - E.bottomRight, g + b), m.arc(d + w - E.bottomRight, g + b - E.bottomRight, E.bottomRight, Ns, 0, !0), m.lineTo(d + w, g + E.topRight), m.arc(d + w - E.topRight, g + E.topRight, E.topRight, 0, -Ns, !0), m.lineTo(d + E.topLeft, g); } const wS = /^(normal|(\d+(?:\.\d+)?)(px|em|%)?)$/, TS = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/; function MS(m, a) { const d = ("" + m).match(wS); if (!d || d[1] === "normal") return a * 1.2; switch (m = +d[2], d[3]) { case "px": return m; case "%": m /= 100; break; } return a * m; } const SS = (m) => +m || 0; function my(m, a) { const d = {}, g = yn(a), w = g ? Object.keys(a) : a, b = yn(m) ? g ? (E) => en(m[E], m[a[E]]) : (E) => m[E] : () => m; for (const E of w) d[E] = SS(b(E)); return d; } function Ob(m) { return my(m, { top: "y", right: "x", bottom: "y", left: "x" }); } function kh(m) { return my(m, [ "topLeft", "topRight", "bottomLeft", "bottomRight" ]); } function Gr(m) { const a = Ob(m); return a.width = a.left + a.right, a.height = a.top + a.bottom, a; } function ir(m, a) { m = m || {}, a = a || ys.font; let d = en(m.size, a.size); typeof d == "string" && (d = parseInt(d, 10)); let g = en(m.style, a.style); g && !("" + g).match(TS) && (console.warn('Invalid font style specified: "' + g + '"'), g = void 0); const w = { family: en(m.family, a.family), lineHeight: MS(en(m.lineHeight, a.lineHeight), d), size: d, style: g, weight: en(m.weight, a.weight), string: "" }; return w.string = mS(w), w; } function Tf(m, a, d, g) { let w = !0, b, E, i; for (b = 0, E = m.length; b < E; ++b) if (i = m[b], i !== void 0 && (a !== void 0 && typeof i == "function" && (i = i(a), w = !1), d !== void 0 && hs(i) && (i = i[d % i.length], w = !1), i !== void 0)) return g && !w && (g.cacheable = !1), i; } function ES(m, a, d) { const { min: g, max: w } = m, b = Mb(a, (w - g) / 2), E = (i, O) => d && i === 0 ? 0 : i + O; return { min: E(g, -Math.abs(b)), max: E(w, b) }; } function Fc(m, a) { return Object.assign(Object.create(m), a); } function _y(m, a = [ "" ], d, g, w = () => m[0]) { const b = d || m; typeof g > "u" && (g = Vb("_fallback", m)); const E = { [Symbol.toStringTag]: "Object", _cacheable: !0, _scopes: m, _rootScopes: b, _fallback: g, _getTarget: w, override: (i) => _y([ i, ...m ], a, b, g) }; return new Proxy(E, { /** * A trap for the delete operator. */ deleteProperty(i, O) { return delete i[O], delete i._keys, delete m[0][O], !0; }, /** * A trap for getting property values. */ get(i, O) { return Bb(i, O, () => kS(O, a, m, i)); }, /** * A trap for Object.getOwnPropertyDescriptor. * Also used by Object.hasOwnProperty. */ getOwnPropertyDescriptor(i, O) { return Reflect.getOwnPropertyDescriptor(i._scopes[0], O); }, /** * A trap for Object.getPrototypeOf. */ getPrototypeOf() { return Reflect.getPrototypeOf(m[0]); }, /** * A trap for the in operator. */ has(i, O) { return h1(i).includes(O); }, /** * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols. */ ownKeys(i) { return h1(i); }, /** * A trap for setting property values. */ set(i, O, j) { const Y = i._storage || (i._storage = w()); return i[O] = Y[O] = j, delete i._keys, !0; } }); } function Yu(m, a, d, g) { const w = { _cacheable: !1, _proxy: m, _context: a, _subProxy: d, _stack: /* @__PURE__ */ new Set(), _descriptors: Fb(m, g), setContext: (b) => Yu(m, b, d, g), override: (b) => Yu(m.override(b), a, d, g) }; return new Proxy(w, { /** * A trap for the delete operator. */ deleteProperty(b, E) { return delete b[E], delete m[E], !0; }, /** * A trap for getting property values. */ get(b, E, i) { return Bb(b, E, () => AS(b, E, i)); }, /** * A trap for Object.getOwnPropertyDescriptor. * Also used by Object.hasOwnProperty. */ getOwnPropertyDescriptor(b, E) { return b._descriptors.allKeys ? Reflect.has(m, E) ? { enumerable: !0, configurable: !0 } : void 0 : Reflect.getOwnPropertyDescriptor(m, E); }, /** * A trap for Object.getPrototypeOf. */ getPrototypeOf() { return Reflect.getPrototypeOf(m); }, /** * A trap for the in operator. */ has(b, E) { return Reflect.has(m, E); }, /** * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols. */ ownKeys() { return Reflect.ownKeys(m); }, /** * A trap for setting property values. */ set(b, E, i) { return m[E] = i, delete b[E], !0; } }); } function Fb(m, a = { scriptable: !0, indexable: !0 }) { const { _scriptable: d = a.scriptable, _indexable: g = a.indexable, _allKeys: w = a.allKeys } = m; return { allKeys: w, scriptable: d, indexable: g, isScriptable: Oc(d) ? d : () => d, isIndexable: Oc(g) ? g : () => g }; } const PS = (m, a) => m ? m + hy(a) : a, gy = (m, a) => yn(a) && m !== "adapters" && (Object.getPrototypeOf(a) === null || a.constructor === Object); function Bb(m, a, d) { if (Object.prototype.hasOwnProperty.call(m, a) || a === "constructor") return m[a]; const g = d(); return m[a] = g, g; } function AS(m, a, d) { const { _proxy: g, _context: w, _subProxy: b, _descriptors: E } = m; let i = g[a]; return Oc(i) && E.isScriptable(a) && (i = CS(a, i, m, d)), hs(i) && i.length && (i = IS(a, i, m, E.isIndexable)), gy(a, i) && (i = Yu(i, w, b && b[a], E)), i; } function CS(m, a, d, g) { const { _proxy: w, _context: b, _subProxy: E, _stack: i } = d; if (i.has(m)) throw new Error("Recursion detected: " + Array.from(i).join("->") + "->" + m); i.add(m); let O = a(b, E || g); return i.delete(m), gy(m, O) && (O = yy(w._scopes, w, m, O)), O; } function IS(m, a, d, g) { const { _proxy: w, _context: b, _subProxy: E, _descriptors: i } = d; if (typeof b.index < "u" && g(m)) return a[b.index % a.length]; if (yn(a[0])) { const O = a, j = w._scopes.filter((Y) => Y !== O); a = []; for (const Y of O) { const J = yy(j, w, m, Y); a.push(Yu(J, b, E && E[m], i)); } } return a; } function Nb(m, a, d) { return Oc(m) ? m(a, d) : m; } const LS = (m, a) => m === !0 ? a : typeof m == "string" ? Rc(a, m) : void 0; function zS(m, a, d, g, w) { for (const b of a) { const E = LS(d, b); if (E) { m.add(E); const i = Nb(E._fallback, d, w); if (typeof i < "u" && i !== d && i !== g) return i; } else if (E === !1 && typeof g < "u" && d !== g) return null; } return !1; } function yy(m, a, d, g) { const w = a._rootScopes, b = Nb(a._fallback, d, g), E = [ ...m, ...w ], i = /* @__PURE__ */ new Set(); i.add(g); let O = c1(i, E, d, b || d, g); return O === null || typeof b < "u" && b !== d && (O = c1(i, E, b, O, g), O === null) ? !1 : _y(Array.from(i), [ "" ], w, b, () => DS(a, d, g)); } function c1(m, a, d, g, w) { for (; d; ) d = zS(m, a, d, g, w); return d; } function DS(m, a, d) { const g = m._getTarget(); a in g || (g[a] = {}); const w = g[a]; return hs(w) && yn(d) ? d : w || {}; } function kS(m, a, d, g) { let w; for (const b of a) if (w = Vb(PS(b, m), d), typeof w < "u") return gy(m, w) ? yy(d, g, m, w) : w; } function Vb(m, a) { for (const d of a) { if (!d) continue; const g = d[m]; if (typeof g < "u") return g; } } function h1(m) { let a = m._keys; return a || (a = m._keys = RS(m._scopes)), a; } function RS(m) { const a = /* @__PURE__ */ new Set(); for (const d of m) for (const g of Object.keys(d).filter((w) => !w.startsWith("_"))) a.add(g); return Array.from(a); } function Ub(m, a, d, g) { const { iScale: w } = m, { key: b = "r" } = this._parsing, E = new Array(g); let i, O, j, Y; for (i = 0, O = g; i < O; ++i) j = i + d, Y = a[j], E[i] = { r: w.parse(Rc(Y, b), j) }; return E; } const OS = Number.EPSILON || 1e-14, Ku = (m, a) => a < m.length && !m[a].skip && m[a], jb = (m) => m === "x" ? "y" : "x"; function FS(m, a, d, g) { const w = m.skip ? a : m, b = a, E = d.skip ? a : d, i = Zg(b, w), O = Zg(E, b); let j = i / (i + O), Y = O / (i + O); j = isNaN(j) ? 0 : j, Y = isNaN(Y) ? 0 : Y; const J = g * j, ae = g * Y; return { previous: { x: b.x - J * (E.x - w.x), y: b.y - J * (E.y - w.y) }, next: { x: b.x + ae * (E.x - w.x), y: b.y + ae * (E.y - w.y) } }; } function BS(m, a, d) { const g = m.length; let w, b, E, i, O, j = Ku(m, 0); for (let Y = 0; Y < g - 1; ++Y) if (O = j, j = Ku(m, Y + 1), !(!O || !j)) { if (If(a[Y], 0, OS)) { d[Y] = d[Y + 1] = 0; continue; } w = d[Y] / a[Y], b = d[Y + 1] / a[Y], i = Math.pow(w, 2) + Math.pow(b, 2), !(i <= 9) && (E = 3 / Math.sqrt(i), d[Y] = w * E * a[Y], d[Y + 1] = b * E * a[Y]); } } function NS(m, a, d = "x") { const g = jb(d), w = m.length; let b, E, i, O = Ku(m, 0); for (let j = 0; j < w; ++j) { if (E = i, i = O, O = Ku(m, j + 1), !i) continue; const Y = i[d], J = i[g]; E && (b = (Y - E[d]) / 3, i[`cp1${d}`] = Y - b, i[`cp1${g}`] = J - b * a[j]), O && (b = (O[d] - Y) / 3, i[`cp2${d}`] = Y + b, i[`cp2${g}`] = J + b * a[j]); } } function VS(m, a = "x") { const d = jb(a), g = m.length, w = Array(g).fill(0), b = Array(g); let E, i, O, j = Ku(m, 0); for (E = 0; E < g; ++E) if (i = O, O = j, j = Ku(m, E + 1), !!O) { if (j) { const Y = j[a] - O[a]; w[E] = Y !== 0 ? (j[d] - O[d]) / Y : 0; } b[E] = i ? j ? ll(w[E - 1]) !== ll(w[E]) ? 0 : (w[E - 1] + w[E]) / 2 : w[E - 1] : w[E]; } BS(m, w, b), NS(m, b, a); } function mm(m, a, d) { return Math.max(Math.min(m, d), a); } function US(m, a) { let d, g, w, b, E, i = Ul(m[0], a); for (d = 0, g = m.length; d < g; ++d) E = b, b = i, i = d < g - 1 && Ul(m[d + 1], a), b && (w = m[d], E && (w.cp1x = mm(w.cp1x, a.left, a.right), w.cp1y = mm(w.cp1y, a.top, a.bottom)), i && (w.cp2x = mm(w.cp2x, a.left, a.right), w.cp2y = mm(w.cp2y, a.top, a.bottom))); } function jS(m, a, d, g, w) { let b, E, i, O; if (a.spanGaps && (m = m.filter((j) => !j.skip)), a.cubicInterpolationMode === "monotone") VS(m, w); else { let j = g ? m[m.length - 1] : m[0]; for (b = 0, E = m.length; b < E; ++b) i = m[b], O = FS(j, i, m[Math.min(b + 1, E - (g ? 0 : 1)) % E], a.tension), i.cp1x = O.previous.x, i.cp1y = O.previous.y, i.cp2x = O.next.x, i.cp2y = O.next.y, j = i; } a.capBezierPoints && US(m, d); } function xy() { return typeof window < "u" && typeof document < "u"; } function vy(m) { let a = m.parentNode; return a && a.toString() === "[object ShadowRoot]" && (a = a.host), a; } function Vm(m, a, d) { let g; return typeof m == "string" ? (g = parseInt(m, 10), m.indexOf("%") !== -1 && (g = g / 100 * a.parentNode[d])) : g = m, g; } const Xm = (m) => m.ownerDocument.defaultView.getComputedStyle(m, null); function GS(m, a) { return Xm(m).getPropertyValue(a); } const ZS = [ "top", "right", "bottom", "left" ]; function Rh(m, a, d) { const g = {}; d = d ? "-" + d : ""; for (let w = 0; w < 4; w++) { const b = ZS[w]; g[b] = parseFloat(m[a + "-" + b + d]) || 0; } return g.width = g.left + g.right, g.height = g.top + g.bottom, g; } const HS = (m, a, d) => (m > 0 || a > 0) && (!d || !d.shadowRoot); function qS(m, a) { const d = m.touches, g = d && d.length ? d[0] : m, { offsetX: w, offsetY: b } = g; let E = !1, i, O; if (HS(w, b, m.target)) i = w, O = b; else { const j = a.getBoundingClientRect(); i = g.clientX - j.left, O = g.clientY - j.top, E = !0; } return { x: i, y: O, box: E }; } function Lh(m, a) { if ("native" in m) return m; const { canvas: d, currentDevicePixelRatio: g } = a, w = Xm(d), b = w.boxSizing === "border-box", E = Rh(w, "padding"), i = Rh(w, "border", "width"), { x: O, y: j, box: Y } = qS(m, d), J = E.left + (Y && i.left), ae = E.top + (Y && i.top); let { width: ce, height: Te } = a; return b && (ce -= E.width + i.width, Te -= E.height + i.height), { x: Math.round((O - J) / ce * d.width / g), y: Math.round((j - ae) / Te * d.height / g) }; } function WS(m, a, d) { let g, w; if (a === void 0 || d === void 0) { const b = m && vy(m); if (!b) a = m.clientWidth, d = m.clientHeight; else { const E = b.getBoundingClientRect(), i = Xm(b), O = Rh(i, "border", "width"), j = Rh(i, "padding"); a = E.width - j.width - O.width, d = E.height - j.height - O.height, g = Vm(i.maxWidth, b, "clientWidth"), w = Vm(i.maxHeight, b, "clientHeight"); } } return { width: a, height: d, maxWidth: g || Bm, maxHeight: w || Bm }; } const _m = (m) => Math.round(m * 10) / 10; function $S(m, a, d, g) { const w = Xm(m), b = Rh(w, "margin"), E = Vm(w.maxWidth, m, "clientWidth") || Bm, i = Vm(w.maxHeight, m, "clientHeight") || Bm, O = WS(m, a, d); let { width: j, height: Y } = O; if (w.boxSizing === "content-box") { const ae = Rh(w, "border", "width"), ce = Rh(w, "padding"); j -= ce.width + ae.width, Y -= ce.height + ae.height; } return j = Math.max(0, j - b.width), Y = Math.max(0, g ? j / g : Y - b.height), j = _m(Math.min(j, E, O.maxWidth)), Y = _m(Math.min(Y, i, O.maxHeight)), j && !Y && (Y = _m(j / 2)), (a !== void 0 || d !== void 0) && g && O.height && Y > O.height && (Y = O.height, j = _m(Math.floor(Y * g))), { width: j, height: Y }; } function u1(m, a, d) { const g = a || 1, w = Math.floor(m.height * g), b = Math.floor(m.width * g); m.height = Math.floor(m.height), m.width = Math.floor(m.width); const E = m.canvas; return E.style && (d || !E.style.height && !E.style.width) && (E.style.height = `${m.height}px`, E.style.width = `${m.width}px`), m.currentDevicePixelRatio !== g || E.height !== w || E.width !== b ? (m.currentDevicePixelRatio = g, E.height = w, E.width = b, m.ctx.setTransform(g, 0, 0, g, 0, 0), !0) : !1; } const XS = function() { let m = !1; try { const a = { get passive() { return m = !0, !1; } }; xy() && (window.addEventListener("test", null, a), window.removeEventListener("test", null, a)); } catch { } return m; }(); function d1(m, a) { const d = GS(m, a), g = d && d.match(/^(\d+)(\.\d+)?px$/); return g ? +g[1] : void 0; } function zh(m, a, d, g) { return { x: m.x + d * (a.x - m.x), y: m.y + d * (a.y - m.y) }; } function YS(m, a, d, g) { return { x: m.x + d * (a.x - m.x), y: g === "middle" ? d < 0.5 ? m.y : a.y : g === "after" ? d < 1 ? m.y : a.y : d > 0 ? a.y : m.y }; } function KS(m, a, d, g) { const w = { x: m.cp2x, y: m.cp2y }, b = { x: a.cp1x, y: a.cp1y }, E = zh(m, w, d), i = zh(w, b, d), O = zh(b, a, d), j = zh(E, i, d), Y = zh(i, O, d); return zh(j, Y, d); } const JS = function(m, a) { return { x(d) { return m + m + a - d; }, setWidth(d) { a = d; }, textAlign(d) { return d === "center" ? d : d === "right" ? "left" : "right"; }, xPlus(d, g) { return d - g; }, leftForLtr(d, g) { return d - g; } }; }, QS = function() { return { x(m) { return m; }, setWidth(m) { }, textAlign(m) { return m; }, xPlus(m, a) { return m + a; }, leftForLtr(m, a) { return m; } }; }; function $u(m, a, d) { return m ? JS(a, d) : QS(); } function Gb(m, a) { let d, g; (a === "ltr" || a === "rtl") && (d = m.canvas.style, g = [ d.getPropertyValue("direction"), d.getPropertyPriority("direction") ], d.setProperty("direction", a, "important"), m.prevTextDirection = g); } function Zb(m, a) { a !== void 0 && (delete m.prevTextDirection, m.canvas.style.setProperty("direction", a[0], a[1])); } function Hb(m) { return m === "angle" ? { between: Ff, compare: eS, normalize: No } : { between: Nl, compare: (a, d) => a - d, normalize: (a) => a }; } function f1({ start: m, end: a, count: d, loop: g, style: w }) { return { start: m % d, end: a % d, loop: g && (a - m + 1) % d === 0, style: w }; } function eE(m, a, d) { const { property: g, start: w, end: b } = d, { between: E, normalize: i } = Hb(g), O = a.length; let { start: j, end: Y, loop: J } = m, ae, ce; if (J) { for (j += O, Y += O, ae = 0, ce = O; ae < ce && E(i(a[j % O][g]), w, b); ++ae) j--, Y--; j %= O, Y %= O; } return Y < j && (Y += O), { start: j, end: Y, loop: J, style: m.style }; } function qb(m, a, d) { if (!d) return [ m ]; const { property: g, start: w, end: b } = d, E = a.length, { compare: i, between: O, normalize: j } = Hb(g), { start: Y, end: J, loop: ae, style: ce } = eE(m, a, d), Te = []; let be = !1, Ze = null, je, ot, vt; const ht = () => O(w, vt, je) && i(w, vt) !== 0, gt = () => i(b, je) === 0 || O(b, vt, je), Vt = () => be || ht(), pt = () => !be || gt(); for (let Gt = Y, ui = Y; Gt <= J; ++Gt) ot = a[Gt % E], !ot.skip && (je = j(ot[g]), je !== vt && (be = O(je, w, b), Ze === null && Vt() && (Ze = i(je, w) === 0 ? Gt : ui), Ze !== null && pt() && (Te.push(f1({ start: Ze, end: Gt, loop: ae, count: E, style: ce })), Ze = null), ui = Gt, vt = je)); return Ze !== null && Te.push(f1({ start: Ze, end: J, loop: ae, count: E, style: ce })), Te; } function Wb(m, a) { const d = [], g = m.segments; for (let w = 0; w < g.length; w++) { const b = qb(g[w], m.points, a); b.length && d.push(...b); } return d; } function tE(m, a, d, g) { let w = 0, b = a - 1; if (d && !g) for (; w < a && !m[w].skip; ) w++; for (; w < a && m[w].skip; ) w++; for (w %= a, d && (b += w); b > w && m[b % a].skip; ) b--; return b %= a, { start: w, end: b }; } function iE(m, a, d, g) { const w = m.length, b = []; let E = a, i = m[a], O; for (O = a + 1; O <= d; ++O) { const j = m[O % w]; j.skip || j.stop ? i.skip || (g = !1, b.push({ start: a % w, end: (O - 1) % w, loop: g }), a = E = j.stop ? O : null) : (E = O, i.skip && (a = O)), i = j; } return E !== null && b.push({ start: a % w, end: E % w, loop: g }), b; } function nE(m, a) { const d = m.points, g = m.options.spanGaps, w = d.length; if (!w) return []; const b = !!m._loop, { start: E, end: i } = tE(d, w, b, g); if (g === !0) return p1(m, [ { start: E, end: i, loop: b } ], d, a); const O = i < E ? i + w : i, j = !!m._fullLoop && E === 0 && i === w - 1; return p1(m, iE(d, E, O, j), d, a); } function p1(m, a, d, g) { return !g || !g.setContext || !d ? a : sE(m, a, d, g); } function sE(m, a, d, g) { const w = m._chart.getContext(), b = m1(m.options), { _datasetIndex: E, options: { spanGaps: i } } = m, O = d.length, j = []; let Y = b, J = a[0].start, ae = J; function ce(Te, be, Ze, je) { const ot = i ? -1 : 1; if (Te !== be) { for (Te += O; d[Te % O].skip; ) Te -= ot; for (; d[be % O].skip; ) be += ot; Te % O !== be % O && (j.push({ start: Te % O, end: be % O, loop: Ze, style: je }), Y = je, J = be % O); } } for (const Te of a) { J = i ? J : Te.start; let be = d[J % O], Ze; for (ae = J + 1; ae <= Te.end; ae++) { const je = d[ae % O]; Ze = m1(g.setContext(Fc(w, { type: "segment", p0: be, p1: je, p0DataIndex: (ae - 1) % O, p1DataIndex: ae % O, datasetIndex: E }))), rE(Ze, Y) && ce(J, ae - 1, Te.loop, Y), be = je, Y = Ze; } J < ae - 1 && ce(J, ae - 1, Te.loop, Y); } return j; } function m1(m) { return { backgroundColor: m.backgroundColor, borderCapStyle: m.borderCapStyle, borderDash: m.borderDash, borderDashOffset: m.borderDashOffset, borderJoinStyle: m.borderJoinStyle, borderWidth: m.borderWidth, borderColor: m.borderColor }; } function rE(m, a) { if (!a) return !1; const d = [], g = function(w, b) { return py(b) ? (d.includes(b) || d.push(b), d.indexOf(b)) : b; }; return JSON.stringify(m, g) !== JSON.stringify(a, g); } /*! * Chart.js v4.4.7 * https://www.chartjs.org * (c) 2024 Chart.js Contributors * Released under the MIT License */ class oE { constructor() { this._request = null, this._charts = /* @__PURE__ */ new Map(), this._running = !1, this._lastDate = void 0; } _notify(a, d, g, w) { const b = d.listeners[w], E = d.duration; b.forEach((i) => i({ chart: a, initial: d.initial, numSteps: E, currentStep: Math.min(g - d.start, E) })); } _refresh() { this._request || (this._running = !0, this._request = Ib.call(window, () => { this._update(), this._request = null, this._running && this._refresh(); })); } _update(a = Date.now()) { let d = 0; this._charts.forEach((g, w) => { if (!g.running || !g.items.length) return; const b = g.items; let E = b.length - 1, i = !1, O; for (; E >= 0; --E) O = b[E], O._active ? (O._total > g.duration && (g.duration = O._total), O.tick(a), i = !0) : (b[E] = b[b.length - 1], b.pop()); i && (w.draw(), this._notify(w, g, a, "progress")), b.length || (g.running = !1, this._notify(w, g, a, "complete"), g.initial = !1), d += b.length; }), this._lastDate = a, d === 0 && (this._running = !1); } _getAnims(a) { const d = this._charts; let g = d.get(a); return g || (g = { running: !1, initial: !0, items: [], listeners: { complete: [], progress: [] } }, d.set(a, g)), g; } listen(a, d, g) { this._getAnims(a).listeners[d].push(g); } add(a, d) { !d || !d.length || this._getAnims(a).items.push(...d); } has(a) { return this._getAnims(a).items.length > 0; } start(a) { const d = this._charts.get(a); d && (d.running = !0, d.start = Date.now(), d.duration = d.items.reduce((g, w) => Math.max(g, w._duration), 0), this._refresh()); } running(a) { if (!this._running) return !1; const d = this._charts.get(a); return !(!d || !d.running || !d.items.length); } stop(a) { const d = this._charts.get(a); if (!d || !d.items.length) return; const g = d.items; let w = g.length - 1; for (; w >= 0; --w) g[w].cancel(); d.items = [], this._notify(a, d, Date.now(), "complete"); } remove(a) { return this._charts.delete(a); } } var Rl = /* @__PURE__ */ new oE(); const _1 = "transparent", aE = { boolean(m, a, d) { return d > 0.5 ? a : m; }, color(m, a, d) { const g = o1(m || _1), w = g.valid && o1(a || _1); return w && w.valid ? w.mix(g, d).hexString() : a; }, number(m, a, d) { return m + (a - m) * d; } }; class lE { constructor(a, d, g, w) { const b = d[g]; w = Tf([ a.to, w, b, a.from ]); const E = Tf([ a.from, b, w ]); this._active = !0, this._fn = a.fn || aE[a.type || typeof E], this._easing = Lf[a.easing] || Lf.linear, this._start = Math.floor(Date.now() + (a.delay || 0)), this._duration = this._total = Math.floor(a.duration), this._loop = !!a.loop, this._target = d, this._prop = g, this._from = E, this._to = w, this._promises = void 0; } active() { return this._active; } update(a, d, g) { if (this._active) { this._notify(!1); const w = this._target[this._prop], b = g - this._start, E = this._duration - b; this._start = g, this._duration = Math.floor(Math.max(E, a.duration)), this._total += b, this._loop = !!a.loop, this._to = Tf([ a.to, d, w, a.from ]), this._from = Tf([ a.from, w, d ]); } } cancel() { this._active && (this.tick(Date.now()), this._active = !1, this._notify(!1)); } tick(a) { const d = a - this._start, g = this._duration, w = this._prop, b = this._from, E = this._loop, i = this._to; let O; if (this._active = b !== i && (E || d < g), !this._active) { this._target[w] = i, this._notify(!0); return; } if (d < 0) { this._target[w] = b; return; } O = d / g % 2, O = E && O > 1 ? 2 - O : O, O = this._easing(Math.min(1, Math.max(0, O))), this._target[w] = this._fn(b, i, O); } wait() { const a = this._promises || (this._promises = []); return new Promise((d, g) => { a.push({ res: d, rej: g }); }); } _notify(a) { const d = a ? "res" : "rej", g = this._promises || []; for (let w = 0; w < g.length; w++) g[w][d](); } } class $b { constructor(a, d) { this._chart = a, this._properties = /* @__PURE__ */ new Map(), this.configure(d); } configure(a) { if (!yn(a)) return; const d = Object.keys(ys.animation), g = this._properties; Object.getOwnPropertyNames(a).forEach((w) => { const b = a[w]; if (!yn(b)) return; const E = {}; for (const i of d) E[i] = b[i]; (hs(b.properties) && b.properties || [ w ]).forEach((i) => { (i === w || !g.has(i)) && g.set(i, E); }); }); } _animateOptions(a, d) { const g = d.options, w = hE(a, g); if (!w) return []; const b = this._createAnimations(w, g); return g.$shared && cE(a.options.$animations, g).then(() => { a.options = g; }, () => { }), b; } _createAnimations(a, d) { const g = this._properties, w = [], b = a.$animations || (a.$animations = {}), E = Object.keys(d), i = Date.now(); let O; for (O = E.length - 1; O >= 0; --O) { const j = E[O]; if (j.charAt(0) === "$") continue; if (j === "options") { w.push(...this._animateOptions(a, d)); continue; } const Y = d[j]; let J = b[j]; const ae = g.get(j); if (J) if (ae && J.active()) { J.update(ae, Y, i); continue; } else J.cancel(); if (!ae || !ae.duration) { a[j] = Y; continue; } b[j] = J = new lE(ae, a, j, Y), w.push(J); } return w; } update(a, d) { if (this._properties.size === 0) { Object.assign(a, d); return; } const g = this._createAnimations(a, d); if (g.length) return Rl.add(this._chart, g), !0; } } function cE(m, a) { const d = [], g = Object.keys(a); for (let w = 0; w < g.length; w++) { const b = m[g[w]]; b && b.active() && d.push(b.wait()); } return Promise.all(d); } function hE(m, a) { if (!a) return; let d = m.options; if (!d) { m.options = a; return; } return d.$shared && (m.options = d = Object.assign({}, d, { $shared: !1, $animations: {} })), d; } function g1(m, a) { const d = m && m.options || {}, g = d.reverse, w = d.min === void 0 ? a : 0, b = d.max === void 0 ? a : 0; return { start: g ? b : w, end: g ? w : b }; } function uE(m, a, d) { if (d === !1) return !1; const g = g1(m, d), w = g1(a, d); return { top: w.end, right: g.end, bottom: w.start, left: g.start }; } function dE(m) { let a, d, g, w; return yn(m) ? (a = m.top, d = m.right, g = m.bottom, w = m.left) : a = d = g = w = m, { top: a, right: d, bottom: g, left: w, disabled: m === !1 }; } function Xb(m, a) { const d = [], g = m._getSortedDatasetMetas(a); let w, b; for (w = 0, b = g.length; w < b; ++w) d.push(g[w].index); return d; } function y1(m, a, d, g = {}) { const w = m.keys, b = g.mode === "single"; let E, i, O, j; if (a === null) return; let Y = !1; for (E = 0, i = w.length; E < i; ++E) { if (O = +w[E], O === d) { if (Y = !0, g.all) continue; break; } j = m.values[O], As(j) && (b || a === 0 || ll(a) === ll(j)) && (a += j); } return !Y && !g.all ? 0 : a; } function fE(m, a) { const { iScale: d, vScale: g } = a, w = d.axis === "x" ? "x" : "y", b = g.axis === "x" ? "x" : "y", E = Object.keys(m), i = new Array(E.length); let O, j, Y; for (O = 0, j = E.length; O < j; ++O) Y = E[O], i[O] = { [w]: Y, [b]: m[Y] }; return i; } function Dg(m, a) { const d = m && m.options.stacked; return d || d === void 0 && a.stack !== void 0; } function pE(m, a, d) { return `${m.id}.${a.id}.${d.stack || d.type}`; } function mE(m) { const { min: a, max: d, minDefined: g, maxDefined: w } = m.getUserBounds(); return { min: g ? a : Number.NEGATIVE_INFINITY, max: w ? d : Number.POSITIVE_INFINITY }; } function _E(m, a, d) { const g = m[a] || (m[a] = {}); return g[d] || (g[d] = {}); } function x1(m, a, d, g) { for (const w of a.getMatchingVisibleMetas(g).reverse()) { const b = m[w.index]; if (d && b > 0 || !d && b < 0) return w.index; } return null; } function v1(m, a) { const { chart: d, _cachedMeta: g } = m, w = d._stacks || (d._stacks = {}), { iScale: b, vScale: E, index: i } = g, O = b.axis, j = E.axis, Y = pE(b, E, g), J = a.length; let ae; for (let ce = 0; ce < J; ++ce) { const Te = a[ce], { [O]: be, [j]: Ze } = Te, je = Te._stacks || (Te._stacks = {}); ae = je[j] = _E(w, Y, be), ae[i] = Ze, ae._top = x1(ae, E, !0, g.type), ae._bottom = x1(ae, E, !1, g.type); const ot = ae._visualValues || (ae._visualValues = {}); ot[i] = Ze; } } function kg(m, a) { const d = m.scales; return Object.keys(d).filter((g) => d[g].axis === a).shift(); } function gE(m, a) { return Fc(m, { active: !1, dataset: void 0, datasetIndex: a, index: a, mode: "default", type: "dataset" }); } function yE(m, a, d) { return Fc(m, { active: !1, dataIndex: a, parsed: void 0, raw: void 0, element: d, index: a, mode: "default", type: "data" }); } function gf(m, a) { const d = m.controller.index, g = m.vScale && m.vScale.axis; if (g) { a = a || m._parsed; for (const w of a) { const b = w._stacks; if (!b || b[g] === void 0 || b[g][d] === void 0) return; delete b[g][d], b[g]._visualValues !== void 0 && b[g]._visualValues[d] !== void 0 && delete b[g]._visualValues[d]; } } } const Rg = (m) => m === "reset" || m === "none", b1 = (m, a) => a ? m : Object.assign({}, m), xE = (m, a, d) => m && !a.hidden && a._stacked && { keys: Xb(d, !0), values: null }; class za { constructor(a, d) { this.chart = a, this._ctx = a.ctx, this.index = d, this._cachedDataOpts = {}, this._cachedMeta = this.getMeta(), this._type = this._cachedMeta.type, this.options = void 0, this._parsing = !1, this._data = void 0, this._objectData = void 0, this._sharedOptions = void 0, this._drawStart = void 0, this._drawCount = void 0, this.enableOptionSharing = !1, this.supportsDecimation = !1, this.$context = void 0, this._syncList = [], this.datasetElementType = new.target.datasetElementType, this.dataElementType = new.target.dataElementType, this.initialize(); } initialize() { const a = this._cachedMeta; this.configure(), this.linkScales(), a._stacked = Dg(a.vScale, a), this.addElements(), this.options.fill && !this.chart.isPluginEnabled("filler") && console.warn("Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options"); } updateIndex(a) { this.index !== a && gf(this._cachedMeta), this.index = a; } linkScales() { const a = this.chart, d = this._cachedMeta, g = this.getDataset(), w = (J, ae, ce, Te) => J === "x" ? ae : J === "r" ? Te : ce, b = d.xAxisID = en(g.xAxisID, kg(a, "x")), E = d.yAxisID = en(g.yAxisID, kg(a, "y")), i = d.rAxisID = en(g.rAxisID, kg(a, "r")), O = d.indexAxis, j = d.iAxisID = w(O, b, E, i), Y = d.vAxisID = w(O, E, b, i); d.xScale = this.getScaleForId(b), d.yScale = this.getScaleForId(E), d.rScale = this.getScaleForId(i), d.iScale = this.getScaleForId(j), d.vScale = this.getScaleForId(Y); } getDataset() { return this.chart.data.datasets[this.index]; } getMeta() { return this.chart.getDatasetMeta(this.index); } getScaleForId(a) { return this.chart.scales[a]; } _getOtherScale(a) { const d = this._cachedMeta; return a === d.iScale ? d.vScale : d.iScale; } reset() { this._update("reset"); } _destroy() { const a = this._cachedMeta; this._data && n1(this._data, this), a._stacked && gf(a); } _dataCheck() { const a = this.getDataset(), d = a.data || (a.data = []), g = this._data; if (yn(d)) { const w = this._cachedMeta; this._data = fE(d, w); } else if (g !== d) { if (g) { n1(g, this); const w = this._cachedMeta; gf(w), w._parsed = []; } d && Object.isExtensible(d) && sS(d, this), this._syncList = [], this._data = d; } } addElements() { const a = this._cachedMeta; this._dataCheck(), this.datasetElementType && (a.dataset = new this.datasetElementType()); } buildOrUpdateElements(a) { const d = this._cachedMeta, g = this.getDataset(); let w = !1; this._dataCheck(); const b = d._stacked; d._stacked = Dg(d.vScale, d), d.stack !== g.stack && (w = !0, gf(d), d.stack = g.stack), this._resyncElements(a), (w || b !== d._stacked) && (v1(this, d._parsed), d._stacked = Dg(d.vScale, d)); } configure() { const a = this.chart.config, d = a.datasetScopeKeys(this._type), g = a.getOptionScopes(this.getDataset(), d, !0); this.options = a.createResolver(g, this.getContext()), this._parsing = this.options.parsing, this._cachedDataOpts = {}; } parse(a, d) { const { _cachedMeta: g, _data: w } = this, { iScale: b, _stacked: E } = g, i = b.axis; let O = a === 0 && d === w.length ? !0 : g._sorted, j = a > 0 && g._parsed[a - 1], Y, J, ae; if (this._parsing === !1) g._parsed = w, g._sorted = !0, ae = w; else { hs(w[a]) ? ae = this.parseArrayData(g, w, a, d) : yn(w[a]) ? ae = this.parseObjectData(g, w, a, d) : ae = this.parsePrimitiveData(g, w, a, d); const ce = () => J[i] === null || j && J[i] < j[i]; for (Y = 0; Y < d; ++Y) g._parsed[Y + a] = J = ae[Y], O && (ce() && (O = !1), j = J); g._sorted = O; } E && v1(this, ae); } parsePrimitiveData(a, d, g, w) { const { iScale: b, vScale: E } = a, i = b.axis, O = E.axis, j = b.getLabels(), Y = b === E, J = new Array(w); let ae, ce, Te; for (ae = 0, ce = w; ae < ce; ++ae) Te = ae + g, J[ae] = { [i]: Y || b.parse(j[Te], Te), [O]: E.parse(d[Te], Te) }; return J; } parseArrayData(a, d, g, w) { const { xScale: b, yScale: E } = a, i = new Array(w); let O, j, Y, J; for (O = 0, j = w; O < j; ++O) Y = O + g, J = d[Y], i[O] = { x: b.parse(J[0], Y), y: E.parse(J[1], Y) }; return i; } parseObjectData(a, d, g, w) { const { xScale: b, yScale: E } = a, { xAxisKey: i = "x", yAxisKey: O = "y" } = this._parsing, j = new Array(w); let Y, J, ae, ce; for (Y = 0, J = w; Y < J; ++Y) ae = Y + g, ce = d[ae], j[Y] = { x: b.parse(Rc(ce, i), ae), y: E.parse(Rc(ce, O), ae) }; return j; } getParsed(a) { return this._cachedMeta._parsed[a]; } getDataElement(a) { return this._cachedMeta.data[a]; } applyStack(a, d, g) { const w = this.chart, b = this._cachedMeta, E = d[a.axis], i = { keys: Xb(w, !0), values: d._stacks[a.axis]._visualValues }; return y1(i, E, b.index, { mode: g }); } updateRangeFromParsed(a, d, g, w) { const b = g[d.axis]; let E = b === null ? NaN : b; const i = w && g._stacks[d.axis]; w && i && (w.values = i, E = y1(w, b, this._cachedMeta.index)), a.min = Math.min(a.min, E), a.max = Math.max(a.max, E); } getMinMax(a, d) { const g = this._cachedMeta, w = g._parsed, b = g._sorted && a === g.iScale, E = w.length, i = this._getOtherScale(a), O = xE(d, g, this.chart), j = { min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY }, { min: Y, max: J } = mE(i); let ae, ce; function Te() { ce = w[ae]; const be = ce[i.axis]; return !As(ce[a.axis]) || Y > be || J < be; } for (ae = 0; ae < E && !(!Te() && (this.updateRangeFromParsed(j, a, ce, O), b)); ++ae) ; if (b) { for (ae = E - 1; ae >= 0; --ae) if (!Te()) { this.updateRangeFromParsed(j, a, ce, O); break; } } return j; } getAllParsedValues(a) { const d = this._cachedMeta._parsed, g = []; let w, b, E; for (w = 0, b = d.length; w < b; ++w) E = d[w][a.axis], As(E) && g.push(E); return g; } getMaxOverflow() { return !1; } getLabelAndValue(a) { const d = this._cachedMeta, g = d.iScale, w = d.vScale, b = this.getParsed(a); return { label: g ? "" + g.getLabelForValue(b[g.axis]) : "", value: w ? "" + w.getLabelForValue(b[w.axis]) : "" }; } _update(a) { const d = this._cachedMeta; this.update(a || "default"), d._clip = dE(en(this.options.clip, uE(d.xScale, d.yScale, this.getMaxOverflow()))); } update(a) { } draw() { const a = this._ctx, d = this.chart, g = this._cachedMeta, w = g.data || [], b = d.chartArea, E = [], i = this._drawStart || 0, O = this._drawCount || w.length - i, j = this.options.drawActiveElementsOnTop; let Y; for (g.dataset && g.dataset.draw(a, b, i, O), Y = i; Y < i + O; ++Y) { const J = w[Y]; J.hidden || (J.active && j ? E.push(J) : J.draw(a, b)); } for (Y = 0; Y < E.length; ++Y) E[Y].draw(a, b); } getStyle(a, d) { const g = d ? "active" : "default"; return a === void 0 && this._cachedMeta.dataset ? this.resolveDatasetElementOptions(g) : this.resolveDataElementOptions(a || 0, g); } getContext(a, d, g) { const w = this.getDataset(); let b; if (a >= 0 && a < this._cachedMeta.data.length) { const E = this._cachedMeta.data[a]; b = E.$context || (E.$context = yE(this.getContext(), a, E)), b.parsed = this.getParsed(a), b.raw = w.data[a], b.index = b.dataIndex = a; } else b = this.$context || (this.$context = gE(this.chart.getContext(), this.index)), b.dataset = w, b.index = b.datasetIndex = this.index; return b.active = !!d, b.mode = g, b; } resolveDatasetElementOptions(a) { return this._resolveElementOptions(this.datasetElementType.id, a); } resolveDataElementOptions(a, d) { return this._resolveElementOptions(this.dataElementType.id, d, a); } _resolveElementOptions(a, d = "default", g) { const w = d === "active", b = this._cachedDataOpts, E = a + "-" + d, i = b[E], O = this.enableOptionSharing && Of(g); if (i) return b1(i, O); const j = this.chart.config, Y = j.datasetElementScopeKeys(this._type, a), J = w ? [ `${a}Hover`, "hover", a, "" ] : [ a, "" ], ae = j.getOptionScopes(this.getDataset(), Y), ce = Object.keys(ys.elements[a]), Te = () => this.getContext(g, w, d), be = j.resolveNamedOptions(ae, ce, Te, J); return be.$shared && (be.$shared = O, b[E] = Object.freeze(b1(be, O))), be; } _resolveAnimations(a, d, g) { const w = this.chart, b = this._cachedDataOpts, E = `animation-${d}`, i = b[E]; if (i) return i; let O; if (w.options.animation !== !1) { const Y = this.chart.config, J = Y.datasetAnimationScopeKeys(this._type, d), ae = Y.getOptionScopes(this.getDataset(), J); O = Y.createResolver(ae, this.getContext(a, g, d)); } const j = new $b(w, O && O.animations); return O && O._cacheable && (b[E] = Object.freeze(j)), j; } getSharedOptions(a) { if (a.$shared) return this._sharedOptions || (this._sharedOptions = Object.assign({}, a)); } includeOptions(a, d) { return !d || Rg(a) || this.chart._animationsDisabled; } _getSharedOptions(a, d) { const g = this.resolveDataElementOptions(a, d), w = this._sharedOptions, b = this.getSharedOptions(g), E = this.includeOptions(d, b) || b !== w; return this.updateSharedOptions(b, d, g), { sharedOptions: b, includeOptions: E }; } updateElement(a, d, g, w) { Rg(w) ? Object.assign(a, g) : this._resolveAnimations(d, w).update(a, g); } updateSharedOptions(a, d, g) { a && !Rg(d) && this._resolveAnimations(void 0, d).update(a, g); } _setStyle(a, d, g, w) { a.active = w; const b = this.getStyle(d, w); this._resolveAnimations(d, g, w).update(a, { options: !w && this.getSharedOptions(b) || b }); } removeHoverStyle(a, d, g) { this._setStyle(a, g, "active", !1); } setHoverStyle(a, d, g) { this._setStyle(a, g, "active", !0); } _removeDatasetHoverStyle() { const a = this._cachedMeta.dataset; a && this._setStyle(a, void 0, "active", !1); } _setDatasetHoverStyle() { const a = this._cachedMeta.dataset; a && this._setStyle(a, void 0, "active", !0); } _resyncElements(a) { const d = this._data, g = this._cachedMeta.data; for (const [i, O, j] of this._syncList) this[i](O, j); this._syncList = []; const w = g.length, b = d.length, E = Math.min(b, w); E && this.parse(0, E), b > w ? this._insertElements(w, b - w, a) : b < w && this._removeElements(b, w - b); } _insertElements(a, d, g = !0) { const w = this._cachedMeta, b = w.data, E = a + d; let i; const O = (j) => { for (j.length += d, i = j.length - 1; i >= E; i--) j[i] = j[i - d]; }; for (O(b), i = a; i < E; ++i) b[i] = new this.dataElementType(); this._parsing && O(w._parsed), this.parse(a, d), g && this.updateElements(b, a, d, "reset"); } updateElements(a, d, g, w) { } _removeElements(a, d) { const g = this._cachedMeta; if (this._parsing) { const w = g._parsed.splice(a, d); g._stacked && gf(g, w); } g.data.splice(a, d); } _sync(a) { if (this._parsing) this._syncList.push(a); else { const [d, g, w] = a; this[d](g, w); } this.chart._dataChanges.push([ this.index, ...a ]); } _onDataPush() { const a = arguments.length; this._sync([ "_insertElements", this.getDataset().data.length - a, a ]); } _onDataPop() { this._sync([ "_removeElements", this._cachedMeta.data.length - 1, 1 ]); } _onDataShift() { this._sync([ "_removeElements", 0, 1 ]); } _onDataSplice(a, d) { d && this._sync([ "_removeElements", a, d ]); const g = arguments.length - 2; g && this._sync([ "_insertElements", a, g ]); } _onDataUnshift() { this._sync([ "_insertElements", 0, arguments.length ]); } } Yt(za, "defaults", {}), Yt(za, "datasetElementType", null), Yt(za, "dataElementType", null); function vE(m, a) { if (!m._cache.$bar) { const d = m.getMatchingVisibleMetas(a); let g = []; for (let w = 0, b = d.length; w < b; w++) g = g.concat(d[w].controller.getAllParsedValues(m)); m._cache.$bar = Cb(g.sort((w, b) => w - b)); } return m._cache.$bar; } function bE(m) { const a = m.iScale, d = vE(a, m.type); let g = a._length, w, b, E, i; const O = () => { E === 32767 || E === -32768 || (Of(i) && (g = Math.min(g, Math.abs(E - i) || g)), i = E); }; for (w = 0, b = d.length; w < b; ++w) E = a.getPixelForValue(d[w]), O(); for (i = void 0, w = 0, b = a.ticks.length; w < b; ++w) E = a.getPixelForTick(w), O(); return g; } function wE(m, a, d, g) { const w = d.barThickness; let b, E; return En(w) ? (b = a.min * d.categoryPercentage, E = d.barPercentage) : (b = w * g, E = 1), { chunk: b / g, ratio: E, start: a.pixels[m] - b / 2 }; } function TE(m, a, d, g) { const w = a.pixels, b = w[m]; let E = m > 0 ? w[m - 1] : null, i = m < w.length - 1 ? w[m + 1] : null; const O = d.categoryPercentage; E === null && (E = b - (i === null ? a.end - a.start : i - b)), i === null && (i = b + b - E); const j = b - (b - Math.min(E, i)) / 2 * O; return { chunk: Math.abs(i - E) / 2 * O / g, ratio: d.barPercentage, start: j }; } function ME(m, a, d, g) { const w = d.parse(m[0], g), b = d.parse(m[1], g), E = Math.min(w, b), i = Math.max(w, b); let O = E, j = i; Math.abs(E) > Math.abs(i) && (O = i, j = E), a[d.axis] = j, a._custom = { barStart: O, barEnd: j, start: w, end: b, min: E, max: i }; } function Yb(m, a, d, g) { return hs(m) ? ME(m, a, d, g) : a[d.axis] = d.parse(m, g), a; } function w1(m, a, d, g) { const w = m.iScale, b = m.vScale, E = w.getLabels(), i = w === b, O = []; let j, Y, J, ae; for (j = d, Y = d + g; j < Y; ++j) ae = a[j], J = {}, J[w.axis] = i || w.parse(E[j], j), O.push(Yb(ae, J, b, j)); return O; } function Og(m) { return m && m.barStart !== void 0 && m.barEnd !== void 0; } function SE(m, a, d) { return m !== 0 ? ll(m) : (a.isHorizontal() ? 1 : -1) * (a.min >= d ? 1 : -1); } function EE(m) { let a, d, g, w, b; return m.horizontal ? (a = m.base > m.x, d = "left", g = "right") : (a = m.base < m.y, d = "bottom", g = "top"), a ? (w = "end", b = "start") : (w = "start", b = "end"), { start: d, end: g, reverse: a, top: w, bottom: b }; } function PE(m, a, d, g) { let w = a.borderSkipped; const b = {}; if (!w) { m.borderSkipped = b; return; } if (w === !0) { m.borderSkipped = { top: !0, right: !0, bottom: !0, left: !0 }; return; } const { start: E, end: i, reverse: O, top: j, bottom: Y } = EE(m); w === "middle" && d && (m.enableBorderRadius = !0, (d._top || 0) === g ? w = j : (d._bottom || 0) === g ? w = Y : (b[T1(Y, E, i, O)] = !0, w = j)), b[T1(w, E, i, O)] = !0, m.borderSkipped = b; } function T1(m, a, d, g) { return g ? (m = AE(m, a, d), m = M1(m, d, a)) : m = M1(m, a, d), m; } function AE(m, a, d) { return m === a ? d : m === d ? a : m; } function M1(m, a, d) { return m === "start" ? a : m === "end" ? d : m; } function CE(m, { inflateAmount: a }, d) { m.inflateAmount = a === "auto" ? d === 1 ? 0.33 : 0 : a; } class Pm extends za { parsePrimitiveData(a, d, g, w) { return w1(a, d, g, w); } parseArrayData(a, d, g, w) { return w1(a, d, g, w); } parseObjectData(a, d, g, w) { const { iScale: b, vScale: E } = a, { xAxisKey: i = "x", yAxisKey: O = "y" } = this._parsing, j = b.axis === "x" ? i : O, Y = E.axis === "x" ? i : O, J = []; let ae, ce, Te, be; for (ae = g, ce = g + w; ae < ce; ++ae) be = d[ae], Te = {}, Te[b.axis] = b.parse(Rc(be, j), ae), J.push(Yb(Rc(be, Y), Te, E, ae)); return J; } updateRangeFromParsed(a, d, g, w) { super.updateRangeFromParsed(a, d, g, w); const b = g._custom; b && d === this._cachedMeta.vScale && (a.min = Math.min(a.min, b.min), a.max = Math.max(a.max, b.max)); } getMaxOverflow() { return 0; } getLabelAndValue(a) { const d = this._cachedMeta, { iScale: g, vScale: w } = d, b = this.getParsed(a), E = b._custom, i = Og(E) ? "[" + E.start + ", " + E.end + "]" : "" + w.getLabelForValue(b[w.axis]); return { label: "" + g.getLabelForValue(b[g.axis]), value: i }; } initialize() { this.enableOptionSharing = !0, super.initialize(); const a = this._cachedMeta; a.stack = this.getDataset().stack; } update(a) { const d = this._cachedMeta; this.updateElements(d.data, 0, d.data.length, a); } updateElements(a, d, g, w) { const b = w === "reset", { index: E, _cachedMeta: { vScale: i } } = this, O = i.getBasePixel(), j = i.isHorizontal(), Y = this._getRuler(), { sharedOptions: J, includeOptions: ae } = this._getSharedOptions(d, w); for (let ce = d; ce < d + g; ce++) { const Te = this.getParsed(ce), be = b || En(Te[i.axis]) ? { base: O, head: O } : this._calculateBarValuePixels(ce), Ze = this._calculateBarIndexPixels(ce, Y), je = (Te._stacks || {})[i.axis], ot = { horizontal: j, base: be.base, enableBorderRadius: !je || Og(Te._custom) || E === je._top || E === je._bottom, x: j ? be.head : Ze.center, y: j ? Ze.center : be.head, height: j ? Ze.size : Math.abs(be.size), width: j ? Math.abs(be.size) : Ze.size }; ae && (ot.options = J || this.resolveDataElementOptions(ce, a[ce].active ? "active" : w)); const vt = ot.options || a[ce].options; PE(ot, vt, je, E), CE(ot, vt, Y.ratio), this.updateElement(a[ce], ce, ot, w); } } _getStacks(a, d) { const { iScale: g } = this._cachedMeta, w = g.getMatchingVisibleMetas(this._type).filter((Y) => Y.controller.options.grouped), b = g.options.stacked, E = [], i = this._cachedMeta.controller.getParsed(d), O = i && i[g.axis], j = (Y) => { const J = Y._parsed.find((ce) => ce[g.axis] === O), ae = J && J[Y.vScale.axis]; if (En(ae) || isNaN(ae)) return !0; }; for (const Y of w) if (!(d !== void 0 && j(Y)) && ((b === !1 || E.indexOf(Y.stack) === -1 || b === void 0 && Y.stack === void 0) && E.push(Y.stack), Y.index === a)) break; return E.length || E.push(void 0), E; } _getStackCount(a) { return this._getStacks(void 0, a).length; } _getStackIndex(a, d, g) { const w = this._getStacks(a, g), b = d !== void 0 ? w.indexOf(d) : -1; return b === -1 ? w.length - 1 : b; } _getRuler() { const a = this.options, d = this._cachedMeta, g = d.iScale, w = []; let b, E; for (b = 0, E = d.data.length; b < E; ++b) w.push(g.getPixelForValue(this.getParsed(b)[g.axis], b)); const i = a.barThickness; return { min: i || bE(d), pixels: w, start: g._startPixel, end: g._endPixel, stackCount: this._getStackCount(), scale: g, grouped: a.grouped, ratio: i ? 1 : a.categoryPercentage * a.barPercentage }; } _calculateBarValuePixels(a) { const { _cachedMeta: { vScale: d, _stacked: g, index: w }, options: { base: b, minBarLength: E } } = this, i = b || 0, O = this.getParsed(a), j = O._custom, Y = Og(j); let J = O[d.axis], ae = 0, ce = g ? this.applyStack(d, O, g) : J, Te, be; ce !== J && (ae = ce - J, ce = J), Y && (J = j.barStart, ce = j.barEnd - j.barStart, J !== 0 && ll(J) !== ll(j.barEnd) && (ae = 0), ae += J); const Ze = !En(b) && !Y ? b : ae; let je = d.getPixelForValue(Ze); if (this.chart.getDataVisibility(a) ? Te = d.getPixelForValue(ae + ce) : Te = je, be = Te - je, Math.abs(be) < E) { be = SE(be, d, i) * E, J === i && (je -= be / 2); const ot = d.getPixelForDecimal(0), vt = d.getPixelForDecimal(1), ht = Math.min(ot, vt), gt = Math.max(ot, vt); je = Math.max(Math.min(je, gt), ht), Te = je + be, g && !Y && (O._stacks[d.axis]._visualValues[w] = d.getValueForPixel(Te) - d.getValueForPixel(je)); } if (je === d.getPixelForValue(i)) { const ot = ll(be) * d.getLineWidthForValue(i) / 2; je += ot, be -= ot; } return { size: be, base: je, head: Te, center: Te + be / 2 }; } _calculateBarIndexPixels(a, d) { const g = d.scale, w = this.options, b = w.skipNull, E = en(w.maxBarThickness, 1 / 0); let i, O; if (d.grouped) { const j = b ? this._getStackCount(a) : d.stackCount, Y = w.barThickness === "flex" ? TE(a, d, w, j) : wE(a, d, w, j), J = this._getStackIndex(this.index, this._cachedMeta.stack, b ? a : void 0); i = Y.start + Y.chunk * J + Y.chunk / 2, O = Math.min(E, Y.chunk * Y.ratio); } else i = g.getPixelForValue(this.getParsed(a)[g.axis], a), O = Math.min(E, d.min * d.ratio); return { base: i - O / 2, head: i + O / 2, center: i, size: O }; } draw() { const a = this._cachedMeta, d = a.vScale, g = a.data, w = g.length; let b = 0; for (; b < w; ++b) this.getParsed(b)[d.axis] !== null && !g[b].hidden && g[b].draw(this._ctx); } } Yt(Pm, "id", "bar"), Yt(Pm, "defaults", { datasetElementType: !1, dataElementType: "bar", categoryPercentage: 0.8, barPercentage: 0.9, grouped: !0, animations: { numbers: { type: "number", properties: [ "x", "y", "base", "width", "height" ] } } }), Yt(Pm, "overrides", { scales: { _index_: { type: "category", offset: !0, grid: { offset: !0 } }, _value_: { type: "linear", beginAtZero: !0 } } }); class Am extends za { initialize() { this.enableOptionSharing = !0, super.initialize(); } parsePrimitiveData(a, d, g, w) { const b = super.parsePrimitiveData(a, d, g, w); for (let E = 0; E < b.length; E++) b[E]._custom = this.resolveDataElementOptions(E + g).radius; return b; } parseArrayData(a, d, g, w) { const b = super.parseArrayData(a, d, g, w); for (let E = 0; E < b.length; E++) { const i = d[g + E]; b[E]._custom = en(i[2], this.resolveDataElementOptions(E + g).radius); } return b; } parseObjectData(a, d, g, w) { const b = super.parseObjectData(a, d, g, w); for (let E = 0; E < b.length; E++) { const i = d[g + E]; b[E]._custom = en(i && i.r && +i.r, this.resolveDataElementOptions(E + g).radius); } return b; } getMaxOverflow() { const a = this._cachedMeta.data; let d = 0; for (let g = a.length - 1; g >= 0; --g) d = Math.max(d, a[g].size(this.resolveDataElementOptions(g)) / 2); return d > 0 && d; } getLabelAndValue(a) { const d = this._cachedMeta, g = this.chart.data.labels || [], { xScale: w, yScale: b } = d, E = this.getParsed(a), i = w.getLabelForValue(E.x), O = b.getLabelForValue(E.y), j = E._custom; return { label: g[a] || "", value: "(" + i + ", " + O + (j ? ", " + j : "") + ")" }; } update(a) { const d = this._cachedMeta.data; this.updateElements(d, 0, d.length, a); } updateElements(a, d, g, w) { const b = w === "reset", { iScale: E, vScale: i } = this._cachedMeta, { sharedOptions: O, includeOptions: j } = this._getSharedOptions(d, w), Y = E.axis, J = i.axis; for (let ae = d; ae < d + g; ae++) { const ce = a[ae], Te = !b && this.getParsed(ae), be = {}, Ze = be[Y] = b ? E.getPixelForDecimal(0.5) : E.getPixelForValue(Te[Y]), je = be[J] = b ? i.getBasePixel() : i.getPixelForValue(Te[J]); be.skip = isNaN(Ze) || isNaN(je), j && (be.options = O || this.resolveDataElementOptions(ae, ce.active ? "active" : w), b && (be.options.radius = 0)), this.updateElement(ce, ae, be, w); } } resolveDataElementOptions(a, d) { const g = this.getParsed(a); let w = super.resolveDataElementOptions(a, d); w.$shared && (w = Object.assign({}, w, { $shared: !1 })); const b = w.radius; return d !== "active" && (w.radius = 0), w.radius += en(g && g._custom, b), w; } } Yt(Am, "id", "bubble"), Yt(Am, "defaults", { datasetElementType: !1, dataElementType: "point", animations: { numbers: { type: "number", properties: [ "x", "y", "borderWidth", "radius" ] } } }), Yt(Am, "overrides", { scales: { x: { type: "linear" }, y: { type: "linear" } } }); function IE(m, a, d) { let g = 1, w = 1, b = 0, E = 0; if (a < us) { const i = m, O = i + a, j = Math.cos(i), Y = Math.sin(i), J = Math.cos(O), ae = Math.sin(O), ce = (vt, ht, gt) => Ff(vt, i, O, !0) ? 1 : Math.max(ht, ht * d, gt, gt * d), Te = (vt, ht, gt) => Ff(vt, i, O, !0) ? -1 : Math.min(ht, ht * d, gt, gt * d), be = ce(0, j, J), Ze = ce(Ns, Y, ae), je = Te(ds, j, J), ot = Te(ds + Ns, Y, ae); g = (be - je) / 2, w = (Ze - ot) / 2, b = -(be + je) / 2, E = -(Ze + ot) / 2; } return { ratioX: g, ratioY: w, offsetX: b, offsetY: E }; } class Dh extends za { constructor(a, d) { super(a, d), this.enableOptionSharing = !0, this.innerRadius = void 0, this.outerRadius = void 0, this.offsetX = void 0, this.offsetY = void 0; } linkScales() { } parse(a, d) { const g = this.getDataset().data, w = this._cachedMeta; if (this._parsing === !1) w._parsed = g; else { let b = (O) => +g[O]; if (yn(g[a])) { const { key: O = "value" } = this._parsing; b = (j) => +Rc(g[j], O); } let E, i; for (E = a, i = a + d; E < i; ++E) w._parsed[E] = b(E); } } _getRotation() { return Ia(this.options.rotation - 90); } _getCircumference() { return Ia(this.options.circumference); } _getRotationExtents() { let a = us, d = -us; for (let g = 0; g < this.chart.data.datasets.length; ++g) if (this.chart.isDatasetVisible(g) && this.chart.getDatasetMeta(g).type === this._type) { const w = this.chart.getDatasetMeta(g).controller, b = w._getRotation(), E = w._getCircumference(); a = Math.min(a, b), d = Math.max(d, b + E); } return { rotation: a, circumference: d - a }; } update(a) { const d = this.chart, { chartArea: g } = d, w = this._cachedMeta, b = w.data, E = this.getMaxBorderWidth() + this.getMaxOffset(b) + this.options.spacing, i = Math.max((Math.min(g.width, g.height) - E) / 2, 0), O = Math.min(ZM(this.options.cutout, i), 1), j = this._getRingWeight(this.index), { circumference: Y, rotation: J } = this._getRotationExtents(), { ratioX: ae, ratioY: ce, offsetX: Te, offsetY: be } = IE(J, Y, O), Ze = (g.width - E) / ae, je = (g.height - E) / ce, ot = Math.max(Math.min(Ze, je) / 2, 0), vt = Mb(this.options.radius, ot), ht = Math.max(vt * O, 0), gt = (vt - ht) / this._getVisibleDatasetWeightTotal(); this.offsetX = Te * vt, this.offsetY = be * vt, w.total = this.calculateTotal(), this.outerRadius = vt - gt * this._getRingWeightOffset(this.index), this.innerRadius = Math.max(this.outerRadius - gt * j, 0), this.updateElements(b, 0, b.length, a); } _circumference(a, d) { const g = this.options, w = this._cachedMeta, b = this._getCircumference(); return d && g.animation.animateRotate || !this.chart.getDataVisibility(a) || w._parsed[a] === null || w.data[a].hidden ? 0 : this.calculateCircumference(w._parsed[a] * b / us); } updateElements(a, d, g, w) { const b = w === "reset", E = this.chart, i = E.chartArea, j = E.options.animation, Y = (i.left + i.right) / 2, J = (i.top + i.bottom) / 2, ae = b && j.animateScale, ce = ae ? 0 : this.innerRadius, Te = ae ? 0 : this.outerRadius, { sharedOptions: be, includeOptions: Ze } = this._getSharedOptions(d, w); let je = this._getRotation(), ot; for (ot = 0; ot < d; ++ot) je += this._circumference(ot, b); for (ot = d; ot < d + g; ++ot) { const vt = this._circumference(ot, b), ht = a[ot], gt = { x: Y + this.offsetX, y: J + this.offsetY, startAngle: je, endAngle: je + vt, circumference: vt, outerRadius: Te, innerRadius: ce }; Ze && (gt.options = be || this.resolveDataElementOptions(ot, ht.active ? "active" : w)), je += vt, this.updateElement(ht, ot, gt, w); } } calculateTotal() { const a = this._cachedMeta, d = a.data; let g = 0, w; for (w = 0; w < d.length; w++) { const b = a._parsed[w]; b !== null && !isNaN(b) && this.chart.getDataVisibility(w) && !d[w].hidden && (g += Math.abs(b)); } return g; } calculateCircumference(a) { const d = this._cachedMeta.total; return d > 0 && !isNaN(a) ? us * (Math.abs(a) / d) : 0; } getLabelAndValue(a) { const d = this._cachedMeta, g = this.chart, w = g.data.labels || [], b = Zf(d._parsed[a], g.options.locale); return { label: w[a] || "", value: b }; } getMaxBorderWidth(a) { let d = 0; const g = this.chart; let w, b, E, i, O; if (!a) { for (w = 0, b = g.data.datasets.length; w < b; ++w) if (g.isDatasetVisible(w)) { E = g.getDatasetMeta(w), a = E.data, i = E.controller; break; } } if (!a) return 0; for (w = 0, b = a.length; w < b; ++w) O = i.resolveDataElementOptions(w), O.borderAlign !== "inner" && (d = Math.max(d, O.borderWidth || 0, O.hoverBorderWidth || 0)); return d; } getMaxOffset(a) { let d = 0; for (let g = 0, w = a.length; g < w; ++g) { const b = this.resolveDataElementOptions(g); d = Math.max(d, b.offset || 0, b.hoverOffset || 0); } return d; } _getRingWeightOffset(a) { let d = 0; for (let g = 0; g < a; ++g) this.chart.isDatasetVisible(g) && (d += this._getRingWeight(g)); return d; } _getRingWeight(a) { return Math.max(en(this.chart.data.datasets[a].weight, 1), 0); } _getVisibleDatasetWeightTotal() { return this._getRingWeightOffset(this.chart.data.datasets.length) || 1; } } Yt(Dh, "id", "doughnut"), Yt(Dh, "defaults", { datasetElementType: !1, dataElementType: "arc", animation: { animateRotate: !0, animateScale: !1 }, animations: { numbers: { type: "number", properties: [ "circumference", "endAngle", "innerRadius", "outerRadius", "startAngle", "x", "y", "offset", "borderWidth", "spacing" ] } }, cutout: "50%", rotation: 0, circumference: 360, radius: "100%", spacing: 0, indexAxis: "r" }), Yt(Dh, "descriptors", { _scriptable: (a) => a !== "spacing", _indexable: (a) => a !== "spacing" && !a.startsWith("borderDash") && !a.startsWith("hoverBorderDash") }), Yt(Dh, "overrides", { aspectRatio: 1, plugins: { legend: { labels: { generateLabels(a) { const d = a.data; if (d.labels.length && d.datasets.length) { const { labels: { pointStyle: g, color: w } } = a.legend.options; return d.labels.map((b, E) => { const O = a.getDatasetMeta(0).controller.getStyle(E); return { text: b, fillStyle: O.backgroundColor, strokeStyle: O.borderColor, fontColor: w, lineWidth: O.borderWidth, pointStyle: g, hidden: !a.getDataVisibility(E), index: E }; }); } return []; } }, onClick(a, d, g) { g.chart.toggleDataVisibility(d.index), g.chart.update(); } } } }); class Cm extends za { initialize() { this.enableOptionSharing = !0, this.supportsDecimation = !0, super.initialize(); } update(a) { const d = this._cachedMeta, { dataset: g, data: w = [], _dataset: b } = d, E = this.chart._animationsDisabled; let { start: i, count: O } = zb(d, w, E); this._drawStart = i, this._drawCount = O, Db(d) && (i = 0, O = w.length), g._chart = this.chart, g._datasetIndex = this.index, g._decimated = !!b._decimated, g.points = w; const j = this.resolveDatasetElementOptions(a); this.options.showLine || (j.borderWidth = 0), j.segment = this.options.segment, this.updateElement(g, void 0, { animated: !E, options: j }, a), this.updateElements(w, i, O, a); } updateElements(a, d, g, w) { const b = w === "reset", { iScale: E, vScale: i, _stacked: O, _dataset: j } = this._cachedMeta, { sharedOptions: Y, includeOptions: J } = this._getSharedOptions(d, w), ae = E.axis, ce = i.axis, { spanGaps: Te, segment: be } = this.options, Ze = Xu(Te) ? Te : Number.POSITIVE_INFINITY, je = this.chart._animationsDisabled || b || w === "none", ot = d + g, vt = a.length; let ht = d > 0 && this.getParsed(d - 1); for (let gt = 0; gt < vt; ++gt) { const Vt = a[gt], pt = je ? Vt : {}; if (gt < d || gt >= ot) { pt.skip = !0; continue; } const Gt = this.getParsed(gt), ui = En(Gt[ce]), kt = pt[ae] = E.getPixelForValue(Gt[ae], gt), Pt = pt[ce] = b || ui ? i.getBasePixel() : i.getPixelForValue(O ? this.applyStack(i, Gt, O) : Gt[ce], gt); pt.skip = isNaN(kt) || isNaN(Pt) || ui, pt.stop = gt > 0 && Math.abs(Gt[ae] - ht[ae]) > Ze, be && (pt.parsed = Gt, pt.raw = j.data[gt]), J && (pt.options = Y || this.resolveDataElementOptions(gt, Vt.active ? "active" : w)), je || this.updateElement(Vt, gt, pt, w), ht = Gt; } } getMaxOverflow() { const a = this._cachedMeta, d = a.dataset, g = d.options && d.options.borderWidth || 0, w = a.data || []; if (!w.length) return g; const b = w[0].size(this.resolveDataElementOptions(0)), E = w[w.length - 1].size(this.resolveDataElementOptions(w.length - 1)); return Math.max(g, b, E) / 2; } draw() { const a = this._cachedMeta; a.dataset.updateControlPoints(this.chart.chartArea, a.iScale.axis), super.draw(); } } Yt(Cm, "id", "line"), Yt(Cm, "defaults", { datasetElementType: "line", dataElementType: "point", showLine: !0, spanGaps: !1 }), Yt(Cm, "overrides", { scales: { _index_: { type: "category" }, _value_: { type: "linear" } } }); class Df extends za { constructor(a, d) { super(a, d), this.innerRadius = void 0, this.outerRadius = void 0; } getLabelAndValue(a) { const d = this._cachedMeta, g = this.chart, w = g.data.labels || [], b = Zf(d._parsed[a].r, g.options.locale); return { label: w[a] || "", value: b }; } parseObjectData(a, d, g, w) { return Ub.bind(this)(a, d, g, w); } update(a) { const d = this._cachedMeta.data; this._updateRadius(), this.updateElements(d, 0, d.length, a); } getMinMax() { const a = this._cachedMeta, d = { min: Number.POSITIVE_INFINITY, max: Number.NEGATIVE_INFINITY }; return a.data.forEach((g, w) => { const b = this.getParsed(w).r; !isNaN(b) && this.chart.getDataVisibility(w) && (b < d.min && (d.min = b), b > d.max && (d.max = b)); }), d; } _updateRadius() { const a = this.chart, d = a.chartArea, g = a.options, w = Math.min(d.right - d.left, d.bottom - d.top), b = Math.max(w / 2, 0), E = Math.max(g.cutoutPercentage ? b / 100 * g.cutoutPercentage : 1, 0), i = (b - E) / a.getVisibleDatasetCount(); this.outerRadius = b - i * this.index, this.innerRadius = this.outerRadius - i; } updateElements(a, d, g, w) { const b = w === "reset", E = this.chart, O = E.options.animation, j = this._cachedMeta.rScale, Y = j.xCenter, J = j.yCenter, ae = j.getIndexAngle(0) - 0.5 * ds; let ce = ae, Te; const be = 360 / this.countVisibleElements(); for (Te = 0; Te < d; ++Te) ce += this._computeAngle(Te, w, be); for (Te = d; Te < d + g; Te++) { const Ze = a[Te]; let je = ce, ot = ce + this._computeAngle(Te, w, be), vt = E.getDataVisibility(Te) ? j.getDistanceFromCenterForValue(this.getParsed(Te).r) : 0; ce = ot, b && (O.animateScale && (vt = 0), O.animateRotate && (je = ot = ae)); const ht = { x: Y, y: J, innerRadius: 0, outerRadius: vt, startAngle: je, endAngle: ot, options: this.resolveDataElementOptions(Te, Ze.active ? "active" : w) }; this.updateElement(Ze, Te, ht, w); } } countVisibleElements() { const a = this._cachedMeta; let d = 0; return a.data.forEach((g, w) => { !isNaN(this.getParsed(w).r) && this.chart.getDataVisibility(w) && d++; }), d; } _computeAngle(a, d, g) { return this.chart.getDataVisibility(a) ? Ia(this.resolveDataElementOptions(a, d).angle || g) : 0; } } Yt(Df, "id", "polarArea"), Yt(Df, "defaults", { dataElementType: "arc", animation: { animateRotate: !0, animateScale: !0 }, animations: { numbers: { type: "number", properties: [ "x", "y", "startAngle", "endAngle", "innerRadius", "outerRadius" ] } }, indexAxis: "r", startAngle: 0 }), Yt(Df, "overrides", { aspectRatio: 1, plugins: { legend: { labels: { generateLabels(a) { const d = a.data; if (d.labels.length && d.datasets.length) { const { labels: { pointStyle: g, color: w } } = a.legend.options; return d.labels.map((b, E) => { const O = a.getDatasetMeta(0).controller.getStyle(E); return { text: b, fillStyle: O.backgroundColor, strokeStyle: O.borderColor, fontColor: w, lineWidth: O.borderWidth, pointStyle: g, hidden: !a.getDataVisibility(E), index: E }; }); } return []; } }, onClick(a, d, g) { g.chart.toggleDataVisibility(d.index), g.chart.update(); } } }, scales: { r: { type: "radialLinear", angleLines: { display: !1 }, beginAtZero: !0, grid: { circular: !0 }, pointLabels: { display: !1 }, startAngle: 0 } } }); class Wg extends Dh { } Yt(Wg, "id", "pie"), Yt(Wg, "defaults", { cutout: 0, rotation: 0, circumference: 360, radius: "100%" }); class Im extends za { getLabelAndValue(a) { const d = this._cachedMeta.vScale, g = this.getParsed(a); return { label: d.getLabels()[a], value: "" + d.getLabelForValue(g[d.axis]) }; } parseObjectData(a, d, g, w) { return Ub.bind(this)(a, d, g, w); } update(a) { const d = this._cachedMeta, g = d.dataset, w = d.data || [], b = d.iScale.getLabels(); if (g.points = w, a !== "resize") { const E = this.resolveDatasetElementOptions(a); this.options.showLine || (E.borderWidth = 0); const i = { _loop: !0, _fullLoop: b.length === w.length, options: E }; this.updateElement(g, void 0, i, a); } this.updateElements(w, 0, w.length, a); } updateElements(a, d, g, w) { const b = this._cachedMeta.rScale, E = w === "reset"; for (let i = d; i < d + g; i++) { const O = a[i], j = this.resolveDataElementOptions(i, O.active ? "active" : w), Y = b.getPointPositionForValue(i, this.getParsed(i).r), J = E ? b.xCenter : Y.x, ae = E ? b.yCenter : Y.y, ce = { x: J, y: ae, angle: Y.angle, skip: isNaN(J) || isNaN(ae), options: j }; this.updateElement(O, i, ce, w); } } } Yt(Im, "id", "radar"), Yt(Im, "defaults", { datasetElementType: "line", dataElementType: "point", indexAxis: "r", showLine: !0, elements: { line: { fill: "start" } } }), Yt(Im, "overrides", { aspectRatio: 1, scales: { r: { type: "radialLinear" } } }); class Lm extends za { getLabelAndValue(a) { const d = this._cachedMeta, g = this.chart.data.labels || [], { xScale: w, yScale: b } = d, E = this.getParsed(a), i = w.getLabelForValue(E.x), O = b.getLabelForValue(E.y); return { label: g[a] || "", value: "(" + i + ", " + O + ")" }; } update(a) { const d = this._cachedMeta, { data: g = [] } = d, w = this.chart._animationsDisabled; let { start: b, count: E } = zb(d, g, w); if (this._drawStart = b, this._drawCount = E, Db(d) && (b = 0, E = g.length), this.options.showLine) { this.datasetElementType || this.addElements(); const { dataset: i, _dataset: O } = d; i._chart = this.chart, i._datasetIndex = this.index, i._decimated = !!O._decimated, i.points = g; const j = this.resolveDatasetElementOptions(a); j.segment = this.options.segment, this.updateElement(i, void 0, { animated: !w, options: j }, a); } else this.datasetElementType && (delete d.dataset, this.datasetElementType = !1); this.updateElements(g, b, E, a); } addElements() { const { showLine: a } = this.options; !this.datasetElementType && a && (this.datasetElementType = this.chart.registry.getElement("line")), super.addElements(); } updateElements(a, d, g, w) { const b = w === "reset", { iScale: E, vScale: i, _stacked: O, _dataset: j } = this._cachedMeta, Y = this.resolveDataElementOptions(d, w), J = this.getSharedOptions(Y), ae = this.includeOptions(w, J), ce = E.axis, Te = i.axis, { spanGaps: be, segment: Ze } = this.options, je = Xu(be) ? be : Number.POSITIVE_INFINITY, ot = this.chart._animationsDisabled || b || w === "none"; let vt = d > 0 && this.getParsed(d - 1); for (let ht = d; ht < d + g; ++ht) { const gt = a[ht], Vt = this.getParsed(ht), pt = ot ? gt : {}, Gt = En(Vt[Te]), ui = pt[ce] = E.getPixelForValue(Vt[ce], ht), kt = pt[Te] = b || Gt ? i.getBasePixel() : i.getPixelForValue(O ? this.applyStack(i, Vt, O) : Vt[Te], ht); pt.skip = isNaN(ui) || isNaN(kt) || Gt, pt.stop = ht > 0 && Math.abs(Vt[ce] - vt[ce]) > je, Ze && (pt.parsed = Vt, pt.raw = j.data[ht]), ae && (pt.options = J || this.resolveDataElementOptions(ht, gt.active ? "active" : w)), ot || this.updateElement(gt, ht, pt, w), vt = Vt; } this.updateSharedOptions(J, w, Y); } getMaxOverflow() { const a = this._cachedMeta, d = a.data || []; if (!this.options.showLine) { let i = 0; for (let O = d.length - 1; O >= 0; --O) i = Math.max(i, d[O].size(this.resolveDataElementOptions(O)) / 2); return i > 0 && i; } const g = a.dataset, w = g.options && g.options.borderWidth || 0; if (!d.length) return w; const b = d[0].size(this.resolveDataElementOptions(0)), E = d[d.length - 1].size(this.resolveDataElementOptions(d.length - 1)); return Math.max(w, b, E) / 2; } } Yt(Lm, "id", "scatter"), Yt(Lm, "defaults", { datasetElementType: !1, dataElementType: "point", showLine: !1, fill: !1 }), Yt(Lm, "overrides", { interaction: { mode: "point" }, scales: { x: { type: "linear" }, y: { type: "linear" } } }); var LE = /* @__PURE__ */ Object.freeze({ __proto__: null, BarController: Pm, BubbleController: Am, DoughnutController: Dh, LineController: Cm, PieController: Wg, PolarAreaController: Df, RadarController: Im, ScatterController: Lm }); function Ch() { throw new Error("This method is not implemented: Check that a complete date adapter is provided."); } class by { constructor(a) { Yt(this, "options"); this.options = a || {}; } /** * Override default date adapter methods. * Accepts type parameter to define options type. * @example * Chart._adapters._date.override<{myAdapterOption: string}>({ * init() { * console.log(this.options.myAdapterOption); * } * }) */ static override(a) { Object.assign(by.prototype, a); } // eslint-disable-next-line @typescript-eslint/no-empty-function init() { } formats() { return Ch(); } parse() { return Ch(); } format() { return Ch(); } add() { return Ch(); } diff() { return Ch(); } startOf() { return Ch(); } endOf() { return Ch(); } } var zE = { _date: by }; function DE(m, a, d, g) { const { controller: w, data: b, _sorted: E } = m, i = w._cachedMeta.iScale; if (i && a === i.axis && a !== "r" && E && b.length) { const O = i._reversePixels ? iS : Vl; if (g) { if (w._sharedOptions) { const j = b[0], Y = typeof j.getRange == "function" && j.getRange(a); if (Y) { const J = O(b, a, d - Y), ae = O(b, a, d + Y); return { lo: J.lo, hi: ae.hi }; } } } else return O(b, a, d); } return { lo: 0, hi: b.length - 1 }; } function Hf(m, a, d, g, w) { const b = m.getSortedVisibleDatasetMetas(), E = d[a]; for (let i = 0, O = b.length; i < O; ++i) { const { index: j, data: Y } = b[i], { lo: J, hi: ae } = DE(b[i], a, E, w); for (let ce = J; ce <= ae; ++ce) { const Te = Y[ce]; Te.skip || g(Te, j, ce); } } } function kE(m) { const a = m.indexOf("x") !== -1, d = m.indexOf("y") !== -1; return function(g, w) { const b = a ? Math.abs(g.x - w.x) : 0, E = d ? Math.abs(g.y - w.y) : 0; return Math.sqrt(Math.pow(b, 2) + Math.pow(E, 2)); }; } function Fg(m, a, d, g, w) { const b = []; return !w && !m.isPointInArea(a) || Hf(m, d, a, function(i, O, j) { !w && !Ul(i, m.chartArea, 0) || i.inRange(a.x, a.y, g) && b.push({ element: i, datasetIndex: O, index: j }); }, !0), b; } function RE(m, a, d, g) { let w = []; function b(E, i, O) { const { startAngle: j, endAngle: Y } = E.getProps([ "startAngle", "endAngle" ], g), { angle: J } = Pb(E, { x: a.x, y: a.y }); Ff(J, j, Y) && w.push({ element: E, datasetIndex: i, index: O }); } return Hf(m, d, a, b), w; } function OE(m, a, d, g, w, b) { let E = []; const i = kE(d); let O = Number.POSITIVE_INFINITY; function j(Y, J, ae) { const ce = Y.inRange(a.x, a.y, w); if (g && !ce) return; const Te = Y.getCenterPoint(w); if (!(!!b || m.isPointInArea(Te)) && !ce) return; const Ze = i(a, Te); Ze < O ? (E = [ { element: Y, datasetIndex: J, index: ae } ], O = Ze) : Ze === O && E.push({ element: Y, datasetIndex: J, index: ae }); } return Hf(m, d, a, j), E; } function Bg(m, a, d, g, w, b) { return !b && !m.isPointInArea(a) ? [] : d === "r" && !g ? RE(m, a, d, w) : OE(m, a, d, g, w, b); } function S1(m, a, d, g, w) { const b = [], E = d === "x" ? "inXRange" : "inYRange"; let i = !1; return Hf(m, d, a, (O, j, Y) => { O[E] && O[E](a[d], w) && (b.push({ element: O, datasetIndex: j, index: Y }), i = i || O.inRange(a.x, a.y, w)); }), g && !i ? [] : b; } var FE = { evaluateInteractionItems: Hf, modes: { index(m, a, d, g) { const w = Lh(a, m), b = d.axis || "x", E = d.includeInvisible || !1, i = d.intersect ? Fg(m, w, b, g, E) : Bg(m, w, b, !1, g, E), O = []; return i.length ? (m.getSortedVisibleDatasetMetas().forEach((j) => { const Y = i[0].index, J = j.data[Y]; J && !J.skip && O.push({ element: J, datasetIndex: j.index, index: Y }); }), O) : []; }, dataset(m, a, d, g) { const w = Lh(a, m), b = d.axis || "xy", E = d.includeInvisible || !1; let i = d.intersect ? Fg(m, w, b, g, E) : Bg(m, w, b, !1, g, E); if (i.length > 0) { const O = i[0].datasetIndex, j = m.getDatasetMeta(O).data; i = []; for (let Y = 0; Y < j.length; ++Y) i.push({ element: j[Y], datasetIndex: O, index: Y }); } return i; }, point(m, a, d, g) { const w = Lh(a, m), b = d.axis || "xy", E = d.includeInvisible || !1; return Fg(m, w, b, g, E); }, nearest(m, a, d, g) { const w = Lh(a, m), b = d.axis || "xy", E = d.includeInvisible || !1; return Bg(m, w, b, d.intersect, g, E); }, x(m, a, d, g) { const w = Lh(a, m); return S1(m, w, "x", d.intersect, g); }, y(m, a, d, g) { const w = Lh(a, m); return S1(m, w, "y", d.intersect, g); } } }; const Kb = [ "left", "top", "right", "bottom" ]; function yf(m, a) { return m.filter((d) => d.pos === a); } function E1(m, a) { return m.filter((d) => Kb.indexOf(d.pos) === -1 && d.box.axis === a); } function xf(m, a) { return m.sort((d, g) => { const w = a ? g : d, b = a ? d : g; return w.weight === b.weight ? w.index - b.index : w.weight - b.weight; }); } function BE(m) { const a = []; let d, g, w, b, E, i; for (d = 0, g = (m || []).length; d < g; ++d) w = m[d], { position: b, options: { stack: E, stackWeight: i = 1 } } = w, a.push({ index: d, box: w, pos: b, horizontal: w.isHorizontal(), weight: w.weight, stack: E && b + E, stackWeight: i }); return a; } function NE(m) { const a = {}; for (const d of m) { const { stack: g, pos: w, stackWeight: b } = d; if (!g || !Kb.includes(w)) continue; const E = a[g] || (a[g] = { count: 0, placed: 0, weight: 0, size: 0 }); E.count++, E.weight += b; } return a; } function VE(m, a) { const d = NE(m), { vBoxMaxWidth: g, hBoxMaxHeight: w } = a; let b, E, i; for (b = 0, E = m.length; b < E; ++b) { i = m[b]; const { fullSize: O } = i.box, j = d[i.stack], Y = j && i.stackWeight / j.weight; i.horizontal ? (i.width = Y ? Y * g : O && a.availableWidth, i.height = w) : (i.width = g, i.height = Y ? Y * w : O && a.availableHeight); } return d; } function UE(m) { const a = BE(m), d = xf(a.filter((j) => j.box.fullSize), !0), g = xf(yf(a, "left"), !0), w = xf(yf(a, "right")), b = xf(yf(a, "top"), !0), E = xf(yf(a, "bottom")), i = E1(a, "x"), O = E1(a, "y"); return { fullSize: d, leftAndTop: g.concat(b), rightAndBottom: w.concat(O).concat(E).concat(i), chartArea: yf(a, "chartArea"), vertical: g.concat(w).concat(O), horizontal: b.concat(E).concat(i) }; } function P1(m, a, d, g) { return Math.max(m[d], a[d]) + Math.max(m[g], a[g]); } function Jb(m, a) { m.top = Math.max(m.top, a.top), m.left = Math.max(m.left, a.left), m.bottom = Math.max(m.bottom, a.bottom), m.right = Math.max(m.right, a.right); } function jE(m, a, d, g) { const { pos: w, box: b } = d, E = m.maxPadding; if (!yn(w)) { d.size && (m[w] -= d.size); const J = g[d.stack] || { size: 0, count: 1 }; J.size = Math.max(J.size, d.horizontal ? b.height : b.width), d.size = J.size / J.count, m[w] += d.size; } b.getPadding && Jb(E, b.getPadding()); const i = Math.max(0, a.outerWidth - P1(E, m, "left", "right")), O = Math.max(0, a.outerHeight - P1(E, m, "top", "bottom")), j = i !== m.w, Y = O !== m.h; return m.w = i, m.h = O, d.horizontal ? { same: j, other: Y } : { same: Y, other: j }; } function GE(m) { const a = m.maxPadding; function d(g) { const w = Math.max(a[g] - m[g], 0); return m[g] += w, w; } m.y += d("top"), m.x += d("left"), d("right"), d("bottom"); } function ZE(m, a) { const d = a.maxPadding; function g(w) { const b = { left: 0, top: 0, right: 0, bottom: 0 }; return w.forEach((E) => { b[E] = Math.max(a[E], d[E]); }), b; } return g(m ? [ "left", "right" ] : [ "top", "bottom" ]); } function Mf(m, a, d, g) { const w = []; let b, E, i, O, j, Y; for (b = 0, E = m.length, j = 0; b < E; ++b) { i = m[b], O = i.box, O.update(i.width || a.w, i.height || a.h, ZE(i.horizontal, a)); const { same: J, other: ae } = jE(a, d, i, g); j |= J && w.length, Y = Y || ae, O.fullSize || w.push(i); } return j && Mf(w, a, d, g) || Y; } function gm(m, a, d, g, w) { m.top = d, m.left = a, m.right = a + g, m.bottom = d + w, m.width = g, m.height = w; } function A1(m, a, d, g) { const w = d.padding; let { x: b, y: E } = a; for (const i of m) { const O = i.box, j = g[i.stack] || { count: 1, placed: 0, weight: 1 }, Y = i.stackWeight / j.weight || 1; if (i.horizontal) { const J = a.w * Y, ae = j.size || O.height; Of(j.start) && (E = j.start), O.fullSize ? gm(O, w.left, E, d.outerWidth - w.right - w.left, ae) : gm(O, a.left + j.placed, E, J, ae), j.start = E, j.placed += J, E = O.bottom; } else { const J = a.h * Y, ae = j.size || O.width; Of(j.start) && (b = j.start), O.fullSize ? gm(O, b, w.top, ae, d.outerHeight - w.bottom - w.top) : gm(O, b, a.top + j.placed, ae, J), j.start = b, j.placed += J, b = O.right; } } a.x = b, a.y = E; } var jr = { addBox(m, a) { m.boxes || (m.boxes = []), a.fullSize = a.fullSize || !1, a.position = a.position || "top", a.weight = a.weight || 0, a._layers = a._layers || function() { return [ { z: 0, draw(d) { a.draw(d); } } ]; }, m.boxes.push(a); }, removeBox(m, a) { const d = m.boxes ? m.boxes.indexOf(a) : -1; d !== -1 && m.boxes.splice(d, 1); }, configure(m, a, d) { a.fullSize = d.fullSize, a.position = d.position, a.weight = d.weight; }, update(m, a, d, g) { if (!m) return; const w = Gr(m.options.layout.padding), b = Math.max(a - w.width, 0), E = Math.max(d - w.height, 0), i = UE(m.boxes), O = i.vertical, j = i.horizontal; Zn(m.boxes, (be) => { typeof be.beforeLayout == "function" && be.beforeLayout(); }); const Y = O.reduce((be, Ze) => Ze.box.options && Ze.box.options.display === !1 ? be : be + 1, 0) || 1, J = Object.freeze({ outerWidth: a, outerHeight: d, padding: w, availableWidth: b, availableHeight: E, vBoxMaxWidth: b / 2 / Y, hBoxMaxHeight: E / 2 }), ae = Object.assign({}, w); Jb(ae, Gr(g)); const ce = Object.assign({ maxPadding: ae, w: b, h: E, x: w.left, y: w.top }, w), Te = VE(O.concat(j), J); Mf(i.fullSize, ce, J, Te), Mf(O, ce, J, Te), Mf(j, ce, J, Te) && Mf(O, ce, J, Te), GE(ce), A1(i.leftAndTop, ce, J, Te), ce.x += ce.w, ce.y += ce.h, A1(i.rightAndBottom, ce, J, Te), m.chartArea = { left: ce.left, top: ce.top, right: ce.left + ce.w, bottom: ce.top + ce.h, height: ce.h, width: ce.w }, Zn(i.chartArea, (be) => { const Ze = be.box; Object.assign(Ze, m.chartArea), Ze.update(ce.w, ce.h, { left: 0, top: 0, right: 0, bottom: 0 }); }); } }; class Qb { acquireContext(a, d) { } releaseContext(a) { return !1; } addEventListener(a, d, g) { } removeEventListener(a, d, g) { } getDevicePixelRatio() { return 1; } getMaximumSize(a, d, g, w) { return d = Math.max(0, d || a.width), g = g || a.height, { width: d, height: Math.max(0, w ? Math.floor(d / w) : g) }; } isAttached(a) { return !0; } updateConfig(a) { } } class HE extends Qb { acquireContext(a) { return a && a.getContext && a.getContext("2d") || null; } updateConfig(a) { a.options.animation = !1; } } const zm = "$chartjs", qE = { touchstart: "mousedown", touchmove: "mousemove", touchend: "mouseup", pointerenter: "mouseenter", pointerdown: "mousedown", pointermove: "mousemove", pointerup: "mouseup", pointerleave: "mouseout", pointerout: "mouseout" }, C1 = (m) => m === null || m === ""; function WE(m, a) { const d = m.style, g = m.getAttribute("height"), w = m.getAttribute("width"); if (m[zm] = { initial: { height: g, width: w, style: { display: d.display, height: d.height, width: d.width } } }, d.display = d.display || "block", d.boxSizing = d.boxSizing || "border-box", C1(w)) { const b = d1(m, "width"); b !== void 0 && (m.width = b); } if (C1(g)) if (m.style.height === "") m.height = m.width / (a || 2); else { const b = d1(m, "height"); b !== void 0 && (m.height = b); } return m; } const ew = XS ? { passive: !0 } : !1; function $E(m, a, d) { m && m.addEventListener(a, d, ew); } function XE(m, a, d) { m && m.canvas && m.canvas.removeEventListener(a, d, ew); } function YE(m, a) { const d = qE[m.type] || m.type, { x: g, y: w } = Lh(m, a); return { type: d, chart: a, native: m, x: g !== void 0 ? g : null, y: w !== void 0 ? w : null }; } function Um(m, a) { for (const d of m) if (d === a || d.contains(a)) return !0; } function KE(m, a, d) { const g = m.canvas, w = new MutationObserver((b) => { let E = !1; for (const i of b) E = E || Um(i.addedNodes, g), E = E && !Um(i.removedNodes, g); E && d(); }); return w.observe(document, { childList: !0, subtree: !0 }), w; } function JE(m, a, d) { const g = m.canvas, w = new MutationObserver((b) => { let E = !1; for (const i of b) E = E || Um(i.removedNodes, g), E = E && !Um(i.addedNodes, g); E && d(); }); return w.observe(document, { childList: !0, subtree: !0 }), w; } const Nf = /* @__PURE__ */ new Map(); let I1 = 0; function tw() { const m = window.devicePixelRatio; m !== I1 && (I1 = m, Nf.forEach((a, d) => { d.currentDevicePixelRatio !== m && a(); })); } function QE(m, a) { Nf.size || window.addEventListener("resize", tw), Nf.set(m, a); } function eP(m) { Nf.delete(m), Nf.size || window.removeEventListener("resize", tw); } function tP(m, a, d) { const g = m.canvas, w = g && vy(g); if (!w) return; const b = Lb((i, O) => { const j = w.clientWidth; d(i, O), j < w.clientWidth && d(); }, window), E = new ResizeObserver((i) => { const O = i[0], j = O.contentRect.width, Y = O.contentRect.height; j === 0 && Y === 0 || b(j, Y); }); return E.observe(w), QE(m, b), E; } function Ng(m, a, d) { d && d.disconnect(), a === "resize" && eP(m); } function iP(m, a, d) { const g = m.canvas, w = Lb((b) => { m.ctx !== null && d(YE(b, m)); }, m); return $E(g, a, w), w; } class nP extends Qb { acquireContext(a, d) { const g = a && a.getContext && a.getContext("2d"); return g && g.canvas === a ? (WE(a, d), g) : null; } releaseContext(a) { const d = a.canvas; if (!d[zm]) return !1; const g = d[zm].initial; [ "height", "width" ].forEach((b) => { const E = g[b]; En(E) ? d.removeAttribute(b) : d.setAttribute(b, E); }); const w = g.style || {}; return Object.keys(w).forEach((b) => { d.style[b] = w[b]; }), d.width = d.width, delete d[zm], !0; } addEventListener(a, d, g) { this.removeEventListener(a, d); const w = a.$proxies || (a.$proxies = {}), E = { attach: KE, detach: JE, resize: tP }[d] || iP; w[d] = E(a, d, g); } removeEventListener(a, d) { const g = a.$proxies || (a.$proxies = {}), w = g[d]; if (!w) return; ({ attach: Ng, detach: Ng, resize: Ng }[d] || XE)(a, d, w), g[d] = void 0; } getDevicePixelRatio() { return window.devicePixelRatio; } getMaximumSize(a, d, g, w) { return $S(a, d, g, w); } isAttached(a) { const d = a && vy(a); return !!(d && d.isConnected); } } function sP(m) { return !xy() || typeof OffscreenCanvas < "u" && m instanceof OffscreenCanvas ? HE : nP; } var Em; let jl = (Em = class { constructor() { Yt(this, "x"); Yt(this, "y"); Yt(this, "active", !1); Yt(this, "options"); Yt(this, "$animations"); } tooltipPosition(a) { const { x: d, y: g } = this.getProps([ "x", "y" ], a); return { x: d, y: g }; } hasValue() { return Xu(this.x) && Xu(this.y); } getProps(a, d) { const g = this.$animations; if (!d || !g) return this; const w = {}; return a.forEach((b) => { w[b] = g[b] && g[b].active() ? g[b]._to : this[b]; }), w; } }, Yt(Em, "defaults", {}), Yt(Em, "defaultRoutes"), Em); function rP(m, a) { const d = m.options.ticks, g = oP(m), w = Math.min(d.maxTicksLimit || g, g), b = d.major.enabled ? lP(a) : [], E = b.length, i = b[0], O = b[E - 1], j = []; if (E > w) return cP(a, j, b, E / w), j; const Y = aP(b, a, w); if (E > 0) { let J, ae; const ce = E > 1 ? Math.round((O - i) / (E - 1)) : null; for (ym(a, j, Y, En(ce) ? 0 : i - ce, i), J = 0, ae = E - 1; J < ae; J++) ym(a, j, Y, b[J], b[J + 1]); return ym(a, j, Y, O, En(ce) ? a.length : O + ce), j; } return ym(a, j, Y), j; } function oP(m) { const a = m.options.offset, d = m._tickSize(), g = m._length / d + (a ? 0 : 1), w = m._maxLength / d; return Math.floor(Math.min(g, w)); } function aP(m, a, d) { const g = hP(m), w = a.length / d; if (!g) return Math.max(w, 1); const b = JM(g); for (let E = 0, i = b.length - 1; E < i; E++) { const O = b[E]; if (O > w) return O; } return Math.max(w, 1); } function lP(m) { const a = []; let d, g; for (d = 0, g = m.length; d < g; d++) m[d].major && a.push(d); return a; } function cP(m, a, d, g) { let w = 0, b = d[0], E; for (g = Math.ceil(g), E = 0; E < m.length; E++) E === b && (a.push(m[E]), w++, b = d[w * g]); } function ym(m, a, d, g, w) { const b = en(g, 0), E = Math.min(en(w, m.length), m.length); let i = 0, O, j, Y; for (d = Math.ceil(d), w && (O = w - g, d = O / Math.floor(O / d)), Y = b; Y < 0; ) i++, Y = Math.round(b + i * d); for (j = Math.max(b, 0); j < E; j++) j === Y && (a.push(m[j]), i++, Y = Math.round(b + i * d)); } function hP(m) { const a = m.length; let d, g; if (a < 2) return !1; for (g = m[0], d = 1; d < a; ++d) if (m[d] - m[d - 1] !== g) return !1; return g; } const uP = (m) => m === "left" ? "right" : m === "right" ? "left" : m, L1 = (m, a, d) => a === "top" || a === "left" ? m[a] + d : m[a] - d, z1 = (m, a) => Math.min(a || m, m); function D1(m, a) { const d = [], g = m.length / a, w = m.length; let b = 0; for (; b < w; b += g) d.push(m[Math.floor(b)]); return d; } function dP(m, a, d) { const g = m.ticks.length, w = Math.min(a, g - 1), b = m._startPixel, E = m._endPixel, i = 1e-6; let O = m.getPixelForTick(w), j; if (!(d && (g === 1 ? j = Math.max(O - b, E - O) : a === 0 ? j = (m.getPixelForTick(1) - O) / 2 : j = (O - m.getPixelForTick(w - 1)) / 2, O += w < a ? j : -j, O < b - i || O > E + i))) return O; } function fP(m, a) { Zn(m, (d) => { const g = d.gc, w = g.length / 2; let b; if (w > a) { for (b = 0; b < w; ++b) delete d.data[g[b]]; g.splice(0, w); } }); } function vf(m) { return m.drawTicks ? m.tickLength : 0; } function k1(m, a) { if (!m.display) return 0; const d = ir(m.font, a), g = Gr(m.padding); return (hs(m.text) ? m.text.length : 1) * d.lineHeight + g.height; } function pP(m, a) { return Fc(m, { scale: a, type: "scale" }); } function mP(m, a, d) { return Fc(m, { tick: d, index: a, type: "tick" }); } function _P(m, a, d) { let g = fy(m); return (d && a !== "right" || !d && a === "right") && (g = uP(g)), g; } function gP(m, a, d, g) { const { top: w, left: b, bottom: E, right: i, chart: O } = m, { chartArea: j, scales: Y } = O; let J = 0, ae, ce, Te; const be = E - w, Ze = i - b; if (m.isHorizontal()) { if (ce = Ur(g, b, i), yn(d)) { const je = Object.keys(d)[0], ot = d[je]; Te = Y[je].getPixelForValue(ot) + be - a; } else d === "center" ? Te = (j.bottom + j.top) / 2 + be - a : Te = L1(m, d, a); ae = i - b; } else { if (yn(d)) { const je = Object.keys(d)[0], ot = d[je]; ce = Y[je].getPixelForValue(ot) - Ze + a; } else d === "center" ? ce = (j.left + j.right) / 2 - Ze + a : ce = L1(m, d, a); Te = Ur(g, E, w), J = d === "left" ? -Ns : Ns; } return { titleX: ce, titleY: Te, maxWidth: ae, rotation: J }; } class Bh extends jl { constructor(a) { super(), this.id = a.id, this.type = a.type, this.options = void 0, this.ctx = a.ctx, this.chart = a.chart, this.top = void 0, this.bottom = void 0, this.left = void 0, this.right = void 0, this.width = void 0, this.height = void 0, this._margins = { left: 0, right: 0, top: 0, bottom: 0 }, this.maxWidth = void 0, this.maxHeight = void 0, this.paddingTop = void 0, this.paddingBottom = void 0, this.paddingLeft = void 0, this.paddingRight = void 0, this.axis = void 0, this.labelRotation = void 0, this.min = void 0, this.max = void 0, this._range = void 0, this.ticks = [], this._gridLineItems = null, this._labelItems = null, this._labelSizes = null, this._length = 0, this._maxLength = 0, this._longestTextCache = {}, this._startPixel = void 0, this._endPixel = void 0, this._reversePixels = !1, this._userMax = void 0, this._userMin = void 0, this._suggestedMax = void 0, this._suggestedMin = void 0, this._ticksLength = 0, this._borderValue = 0, this._cache = {}, this._dataLimitsCached = !1, this.$context = void 0; } init(a) { this.options = a.setContext(this.getContext()), this.axis = a.axis, this._userMin = this.parse(a.min), this._userMax = this.parse(a.max), this._suggestedMin = this.parse(a.suggestedMin), this._suggestedMax = this.parse(a.suggestedMax); } parse(a, d) { return a; } getUserBounds() { let { _userMin: a, _userMax: d, _suggestedMin: g, _suggestedMax: w } = this; return a = Bo(a, Number.POSITIVE_INFINITY), d = Bo(d, Number.NEGATIVE_INFINITY), g = Bo(g, Number.POSITIVE_INFINITY), w = Bo(w, Number.NEGATIVE_INFINITY), { min: Bo(a, g), max: Bo(d, w), minDefined: As(a), maxDefined: As(d) }; } getMinMax(a) { let { min: d, max: g, minDefined: w, maxDefined: b } = this.getUserBounds(), E; if (w && b) return { min: d, max: g }; const i = this.getMatchingVisibleMetas(); for (let O = 0, j = i.length; O < j; ++O) E = i[O].controller.getMinMax(this, a), w || (d = Math.min(d, E.min)), b || (g = Math.max(g, E.max)); return d = b && d > g ? g : d, g = w && d > g ? d : g, { min: Bo(d, Bo(g, d)), max: Bo(g, Bo(d, g)) }; } getPadding() { return { left: this.paddingLeft || 0, top: this.paddingTop || 0, right: this.paddingRight || 0, bottom: this.paddingBottom || 0 }; } getTicks() { return this.ticks; } getLabels() { const a = this.chart.data; return this.options.labels || (this.isHorizontal() ? a.xLabels : a.yLabels) || a.labels || []; } getLabelItems(a = this.chart.chartArea) { return this._labelItems || (this._labelItems = this._computeLabelItems(a)); } beforeLayout() { this._cache = {}, this._dataLimitsCached = !1; } beforeUpdate() { is(this.options.beforeUpdate, [ this ]); } update(a, d, g) { const { beginAtZero: w, grace: b, ticks: E } = this.options, i = E.sampleSize; this.beforeUpdate(), this.maxWidth = a, this.maxHeight = d, this._margins = g = Object.assign({ left: 0, right: 0, top: 0, bottom: 0 }, g), this.ticks = null, this._labelSizes = null, this._gridLineItems = null, this._labelItems = null, this.beforeSetDimensions(), this.setDimensions(), this.afterSetDimensions(), this._maxLength = this.isHorizontal() ? this.width + g.left + g.right : this.height + g.top + g.bottom, this._dataLimitsCached || (this.beforeDataLimits(), this.determineDataLimits(), this.afterDataLimits(), this._range = ES(this, b, w), this._dataLimitsCached = !0), this.beforeBuildTicks(), this.ticks = this.buildTicks() || [], this.afterBuildTicks(); const O = i < this.ticks.length; this._convertTicksToLabels(O ? D1(this.ticks, i) : this.ticks), this.configure(), this.beforeCalculateLabelRotation(), this.calculateLabelRotation(), this.afterCalculateLabelRotation(), E.display && (E.autoSkip || E.source === "auto") && (this.ticks = rP(this, this.ticks), this._labelSizes = null, this.afterAutoSkip()), O && this._convertTicksToLabels(this.ticks), this.beforeFit(), this.fit(), this.afterFit(), this.afterUpdate(); } configure() { let a = this.options.reverse, d, g; this.isHorizontal() ? (d = this.left, g = this.right) : (d = this.top, g = this.bottom, a = !a), this._startPixel = d, this._endPixel = g, this._reversePixels = a, this._length = g - d, this._alignToPixels = this.options.alignToPixels; } afterUpdate() { is(this.options.afterUpdate, [ this ]); } beforeSetDimensions() { is(this.options.beforeSetDimensions, [ this ]); } setDimensions() { this.isHorizontal() ? (this.width = this.maxWidth, this.left = 0, this.right = this.width) : (this.height = this.maxHeight, this.top = 0, this.bottom = this.height), this.paddingLeft = 0, this.paddingTop = 0, this.paddingRight = 0, this.paddingBottom = 0; } afterSetDimensions() { is(this.options.afterSetDimensions, [ this ]); } _callHooks(a) { this.chart.notifyPlugins(a, this.getContext()), is(this.options[a], [ this ]); } beforeDataLimits() { this._callHooks("beforeDataLimits"); } determineDataLimits() { } afterDataLimits() { this._callHooks("afterDataLimits"); } beforeBuildTicks() { this._callHooks("beforeBuildTicks"); } buildTicks() { return []; } afterBuildTicks() { this._callHooks("afterBuildTicks"); } beforeTickToLabelConversion() { is(this.options.beforeTickToLabelConversion, [ this ]); } generateTickLabels(a) { const d = this.options.ticks; let g, w, b; for (g = 0, w = a.length; g < w; g++) b = a[g], b.label = is(d.callback, [ b.value, g, a ], this); } afterTickToLabelConversion() { is(this.options.afterTickToLabelConversion, [ this ]); } beforeCalculateLabelRotation() { is(this.options.beforeCalculateLabelRotation, [ this ]); } calculateLabelRotation() { const a = this.options, d = a.ticks, g = z1(this.ticks.length, a.ticks.maxTicksLimit), w = d.minRotation || 0, b = d.maxRotation; let E = w, i, O, j; if (!this._isVisible() || !d.display || w >= b || g <= 1 || !this.isHorizontal()) { this.labelRotation = w; return; } const Y = this._getLabelSizes(), J = Y.widest.width, ae = Y.highest.height, ce = gr(this.chart.width - J, 0, this.maxWidth); i = a.offset ? this.maxWidth / g : ce / (g - 1), J + 6 > i && (i = ce / (g - (a.offset ? 0.5 : 1)), O = this.maxHeight - vf(a.grid) - d.padding - k1(a.title, this.chart.options.font), j = Math.sqrt(J * J + ae * ae), E = uy(Math.min(Math.asin(gr((Y.highest.height + 6) / i, -1, 1)), Math.asin(gr(O / j, -1, 1)) - Math.asin(gr(ae / j, -1, 1)))), E = Math.max(w, Math.min(b, E))), this.labelRotation = E; } afterCalculateLabelRotation() { is(this.options.afterCalculateLabelRotation, [ this ]); } afterAutoSkip() { } beforeFit() { is(this.options.beforeFit, [ this ]); } fit() { const a = { width: 0, height: 0 }, { chart: d, options: { ticks: g, title: w, grid: b } } = this, E = this._isVisible(), i = this.isHorizontal(); if (E) { const O = k1(w, d.options.font); if (i ? (a.width = this.maxWidth, a.height = vf(b) + O) : (a.height = this.maxHeight, a.width = vf(b) + O), g.display && this.ticks.length) { const { first: j, last: Y, widest: J, highest: ae } = this._getLabelSizes(), ce = g.padding * 2, Te = Ia(this.labelRotation), be = Math.cos(Te), Ze = Math.sin(Te); if (i) { const je = g.mirror ? 0 : Ze * J.width + be * ae.height; a.height = Math.min(this.maxHeight, a.height + je + ce); } else { const je = g.mirror ? 0 : be * J.width + Ze * ae.height; a.width = Math.min(this.maxWidth, a.width + je + ce); } this._calculatePadding(j, Y, Ze, be); } } this._handleMargins(), i ? (this.width = this._length = d.width - this._margins.left - this._margins.right, this.height = a.height) : (this.width = a.width, this.height = this._length = d.height - this._margins.top - this._margins.bottom); } _calculatePadding(a, d, g, w) { const { ticks: { align: b, padding: E }, position: i } = this.options, O = this.labelRotation !== 0, j = i !== "top" && this.axis === "x"; if (this.isHorizontal()) { const Y = this.getPixelForTick(0) - this.left, J = this.right - this.getPixelForTick(this.ticks.length - 1); let ae = 0, ce = 0; O ? j ? (ae = w * a.width, ce = g * d.height) : (ae = g * a.height, ce = w * d.width) : b === "start" ? ce = d.width : b === "end" ? ae = a.width : b !== "inner" && (ae = a.width / 2, ce = d.width / 2), this.paddingLeft = Math.max((ae - Y + E) * this.width / (this.width - Y), 0), this.paddingRight = Math.max((ce - J + E) * this.width / (this.width - J), 0); } else { let Y = d.height / 2, J = a.height / 2; b === "start" ? (Y = 0, J = a.height) : b === "end" && (Y = d.height, J = 0), this.paddingTop = Y + E, this.paddingBottom = J + E; } } _handleMargins() { this._margins && (this._margins.left = Math.max(this.paddingLeft, this._margins.left), this._margins.top = Math.max(this.paddingTop, this._margins.top), this._margins.right = Math.max(this.paddingRight, this._margins.right), this._margins.bottom = Math.max(this.paddingBottom, this._margins.bottom)); } afterFit() { is(this.options.afterFit, [ this ]); } isHorizontal() { const { axis: a, position: d } = this.options; return d === "top" || d === "bottom" || a === "x"; } isFullSize() { return this.options.fullSize; } _convertTicksToLabels(a) { this.beforeTickToLabelConversion(), this.generateTickLabels(a); let d, g; for (d = 0, g = a.length; d < g; d++) En(a[d].label) && (a.splice(d, 1), g--, d--); this.afterTickToLabelConversion(); } _getLabelSizes() { let a = this._labelSizes; if (!a) { const d = this.options.ticks.sampleSize; let g = this.ticks; d < g.length && (g = D1(g, d)), this._labelSizes = a = this._computeLabelSizes(g, g.length, this.options.ticks.maxTicksLimit); } return a; } _computeLabelSizes(a, d, g) { const { ctx: w, _longestTextCache: b } = this, E = [], i = [], O = Math.floor(d / z1(d, g)); let j = 0, Y = 0, J, ae, ce, Te, be, Ze, je, ot, vt, ht, gt; for (J = 0; J < d; J += O) { if (Te = a[J].label, be = this._resolveTickFontOptions(J), w.font = Ze = be.string, je = b[Ze] = b[Ze] || { data: {}, gc: [] }, ot = be.lineHeight, vt = ht = 0, !En(Te) && !hs(Te)) vt = Nm(w, je.data, je.gc, vt, Te), ht = ot; else if (hs(Te)) for (ae = 0, ce = Te.length; ae < ce; ++ae) gt = Te[ae], !En(gt) && !hs(gt) && (vt = Nm(w, je.data, je.gc, vt, gt), ht += ot); E.push(vt), i.push(ht), j = Math.max(vt, j), Y = Math.max(ht, Y); } fP(b, d); const Vt = E.indexOf(j), pt = i.indexOf(Y), Gt = (ui) => ({ width: E[ui] || 0, height: i[ui] || 0 }); return { first: Gt(0), last: Gt(d - 1), widest: Gt(Vt), highest: Gt(pt), widths: E, heights: i }; } getLabelForValue(a) { return a; } getPixelForValue(a, d) { return NaN; } getValueForPixel(a) { } getPixelForTick(a) { const d = this.ticks; return a < 0 || a > d.length - 1 ? null : this.getPixelForValue(d[a].value); } getPixelForDecimal(a) { this._reversePixels && (a = 1 - a); const d = this._startPixel + a * this._length; return tS(this._alignToPixels ? Ah(this.chart, d, 0) : d); } getDecimalForPixel(a) { const d = (a - this._startPixel) / this._length; return this._reversePixels ? 1 - d : d; } getBasePixel() { return this.getPixelForValue(this.getBaseValue()); } getBaseValue() { const { min: a, max: d } = this; return a < 0 && d < 0 ? d : a > 0 && d > 0 ? a : 0; } getContext(a) { const d = this.ticks || []; if (a >= 0 && a < d.length) { const g = d[a]; return g.$context || (g.$context = mP(this.getContext(), a, g)); } return this.$context || (this.$context = pP(this.chart.getContext(), this)); } _tickSize() { const a = this.options.ticks, d = Ia(this.labelRotation), g = Math.abs(Math.cos(d)), w = Math.abs(Math.sin(d)), b = this._getLabelSizes(), E = a.autoSkipPadding || 0, i = b ? b.widest.width + E : 0, O = b ? b.highest.height + E : 0; return this.isHorizontal() ? O * g > i * w ? i / g : O / w : O * w < i * g ? O / g : i / w; } _isVisible() { const a = this.options.display; return a !== "auto" ? !!a : this.getMatchingVisibleMetas().length > 0; } _computeGridLineItems(a) { const d = this.axis, g = this.chart, w = this.options, { grid: b, position: E, border: i } = w, O = b.offset, j = this.isHorizontal(), J = this.ticks.length + (O ? 1 : 0), ae = vf(b), ce = [], Te = i.setContext(this.getContext()), be = Te.display ? Te.width : 0, Ze = be / 2, je = function(Si) { return Ah(g, Si, be); }; let ot, vt, ht, gt, Vt, pt, Gt, ui, kt, Pt, Mi, Pn; if (E === "top") ot = je(this.bottom), pt = this.bottom - ae, ui = ot - Ze, Pt = je(a.top) + Ze, Pn = a.bottom; else if (E === "bottom") ot = je(this.top), Pt = a.top, Pn = je(a.bottom) - Ze, pt = ot + Ze, ui = this.top + ae; else if (E === "left") ot = je(this.right), Vt = this.right - ae, Gt = ot - Ze, kt = je(a.left) + Ze, Mi = a.right; else if (E === "right") ot = je(this.left), kt = a.left, Mi = je(a.right) - Ze, Vt = ot + Ze, Gt = this.left + ae; else if (d === "x") { if (E === "center") ot = je((a.top + a.bottom) / 2 + 0.5); else if (yn(E)) { const Si = Object.keys(E)[0], Ji = E[Si]; ot = je(this.chart.scales[Si].getPixelForValue(Ji)); } Pt = a.top, Pn = a.bottom, pt = ot + Ze, ui = pt + ae; } else if (d === "y") { if (E === "center") ot = je((a.left + a.right) / 2); else if (yn(E)) { const Si = Object.keys(E)[0], Ji = E[Si]; ot = je(this.chart.scales[Si].getPixelForValue(Ji)); } Vt = ot - Ze, Gt = Vt - ae, kt = a.left, Mi = a.right; } const hn = en(w.ticks.maxTicksLimit, J), Ht = Math.max(1, Math.ceil(J / hn)); for (vt = 0; vt < J; vt += Ht) { const Si = this.getContext(vt), Ji = b.setContext(Si), fi = i.setContext(Si), jt = Ji.lineWidth, ni = Ji.color, Gi = fi.dash || [], an = fi.dashOffset, qt = Ji.tickWidth, ln = Ji.tickColor, Di = Ji.tickBorderDash || [], xi = Ji.tickBorderDashOffset; ht = dP(this, vt, O), ht !== void 0 && (gt = Ah(g, ht, jt), j ? Vt = Gt = kt = Mi = gt : pt = ui = Pt = Pn = gt, ce.push({ tx1: Vt, ty1: pt, tx2: Gt, ty2: ui, x1: kt, y1: Pt, x2: Mi, y2: Pn, width: jt, color: ni, borderDash: Gi, borderDashOffset: an, tickWidth: qt, tickColor: ln, tickBorderDash: Di, tickBorderDashOffset: xi })); } return this._ticksLength = J, this._borderValue = ot, ce; } _computeLabelItems(a) { const d = this.axis, g = this.options, { position: w, ticks: b } = g, E = this.isHorizontal(), i = this.ticks, { align: O, crossAlign: j, padding: Y, mirror: J } = b, ae = vf(g.grid), ce = ae + Y, Te = J ? -Y : ce, be = -Ia(this.labelRotation), Ze = []; let je, ot, vt, ht, gt, Vt, pt, Gt, ui, kt, Pt, Mi, Pn = "middle"; if (w === "top") Vt = this.bottom - Te, pt = this._getXAxisLabelAlignment(); else if (w === "bottom") Vt = this.top + Te, pt = this._getXAxisLabelAlignment(); else if (w === "left") { const Ht = this._getYAxisLabelAlignment(ae); pt = Ht.textAlign, gt = Ht.x; } else if (w === "right") { const Ht = this._getYAxisLabelAlignment(ae); pt = Ht.textAlign, gt = Ht.x; } else if (d === "x") { if (w === "center") Vt = (a.top + a.bottom) / 2 + ce; else if (yn(w)) { const Ht = Object.keys(w)[0], Si = w[Ht]; Vt = this.chart.scales[Ht].getPixelForValue(Si) + ce; } pt = this._getXAxisLabelAlignment(); } else if (d === "y") { if (w === "center") gt = (a.left + a.right) / 2 - ce; else if (yn(w)) { const Ht = Object.keys(w)[0], Si = w[Ht]; gt = this.chart.scales[Ht].getPixelForValue(Si); } pt = this._getYAxisLabelAlignment(ae).textAlign; } d === "y" && (O === "start" ? Pn = "top" : O === "end" && (Pn = "bottom")); const hn = this._getLabelSizes(); for (je = 0, ot = i.length; je < ot; ++je) { vt = i[je], ht = vt.label; const Ht = b.setContext(this.getContext(je)); Gt = this.getPixelForTick(je) + b.labelOffset, ui = this._resolveTickFontOptions(je), kt = ui.lineHeight, Pt = hs(ht) ? ht.length : 1; const Si = Pt / 2, Ji = Ht.color, fi = Ht.textStrokeColor, jt = Ht.textStrokeWidth; let ni = pt; E ? (gt = Gt, pt === "inner" && (je === ot - 1 ? ni = this.options.reverse ? "left" : "right" : je === 0 ? ni = this.options.reverse ? "right" : "left" : ni = "center"), w === "top" ? j === "near" || be !== 0 ? Mi = -Pt * kt + kt / 2 : j === "center" ? Mi = -hn.highest.height / 2 - Si * kt + kt : Mi = -hn.highest.height + kt / 2 : j === "near" || be !== 0 ? Mi = kt / 2 : j === "center" ? Mi = hn.highest.height / 2 - Si * kt : Mi = hn.highest.height - Pt * kt, J && (Mi *= -1), be !== 0 && !Ht.showLabelBackdrop && (gt += kt / 2 * Math.sin(be))) : (Vt = Gt, Mi = (1 - Pt) * kt / 2); let Gi; if (Ht.showLabelBackdrop) { const an = Gr(Ht.backdropPadding), qt = hn.heights[je], ln = hn.widths[je]; let Di = Mi - an.top, xi = 0 - an.left; switch (Pn) { case "middle": Di -= qt / 2; break; case "bottom": Di -= qt; break; } switch (pt) { case "center": xi -= ln / 2; break; case "right": xi -= ln; break; case "inner": je === ot - 1 ? xi -= ln : je > 0 && (xi -= ln / 2); break; } Gi = { left: xi, top: Di, width: ln + an.width, height: qt + an.height, color: Ht.backdropColor }; } Ze.push({ label: ht, font: ui, textOffset: Mi, options: { rotation: be, color: Ji, strokeColor: fi, strokeWidth: jt, textAlign: ni, textBaseline: Pn, translation: [ gt, Vt ], backdrop: Gi } }); } return Ze; } _getXAxisLabelAlignment() { const { position: a, ticks: d } = this.options; if (-Ia(this.labelRotation)) return a === "top" ? "left" : "right"; let w = "center"; return d.align === "start" ? w = "left" : d.align === "end" ? w = "right" : d.align === "inner" && (w = "inner"), w; } _getYAxisLabelAlignment(a) { const { position: d, ticks: { crossAlign: g, mirror: w, padding: b } } = this.options, E = this._getLabelSizes(), i = a + b, O = E.widest.width; let j, Y; return d === "left" ? w ? (Y = this.right + b, g === "near" ? j = "left" : g === "center" ? (j = "center", Y += O / 2) : (j = "right", Y += O)) : (Y = this.right - i, g === "near" ? j = "right" : g === "center" ? (j = "center", Y -= O / 2) : (j = "left", Y = this.left)) : d === "right" ? w ? (Y = this.left + b, g === "near" ? j = "right" : g === "center" ? (j = "center", Y -= O / 2) : (j = "left", Y -= O)) : (Y = this.left + i, g === "near" ? j = "left" : g === "center" ? (j = "center", Y += O / 2) : (j = "right", Y = this.right)) : j = "right", { textAlign: j, x: Y }; } _computeLabelArea() { if (this.options.ticks.mirror) return; const a = this.chart, d = this.options.position; if (d === "left" || d === "right") return { top: 0, left: this.left, bottom: a.height, right: this.right }; if (d === "top" || d === "bottom") return { top: this.top, left: 0, bottom: this.bottom, right: a.width }; } drawBackground() { const { ctx: a, options: { backgroundColor: d }, left: g, top: w, width: b, height: E } = this; d && (a.save(), a.fillStyle = d, a.fillRect(g, w, b, E), a.restore()); } getLineWidthForValue(a) { const d = this.options.grid; if (!this._isVisible() || !d.display) return 0; const w = this.ticks.findIndex((b) => b.value === a); return w >= 0 ? d.setContext(this.getContext(w)).lineWidth : 0; } drawGrid(a) { const d = this.options.grid, g = this.ctx, w = this._gridLineItems || (this._gridLineItems = this._computeGridLineItems(a)); let b, E; const i = (O, j, Y) => { !Y.width || !Y.color || (g.save(), g.lineWidth = Y.width, g.strokeStyle = Y.color, g.setLineDash(Y.borderDash || []), g.lineDashOffset = Y.borderDashOffset, g.beginPath(), g.moveTo(O.x, O.y), g.lineTo(j.x, j.y), g.stroke(), g.restore()); }; if (d.display) for (b = 0, E = w.length; b < E; ++b) { const O = w[b]; d.drawOnChartArea && i({ x: O.x1, y: O.y1 }, { x: O.x2, y: O.y2 }, O), d.drawTicks && i({ x: O.tx1, y: O.ty1 }, { x: O.tx2, y: O.ty2 }, { color: O.tickColor, width: O.tickWidth, borderDash: O.tickBorderDash, borderDashOffset: O.tickBorderDashOffset }); } } drawBorder() { const { chart: a, ctx: d, options: { border: g, grid: w } } = this, b = g.setContext(this.getContext()), E = g.display ? b.width : 0; if (!E) return; const i = w.setContext(this.getContext(0)).lineWidth, O = this._borderValue; let j, Y, J, ae; this.isHorizontal() ? (j = Ah(a, this.left, E) - E / 2, Y = Ah(a, this.right, i) + i / 2, J = ae = O) : (J = Ah(a, this.top, E) - E / 2, ae = Ah(a, this.bottom, i) + i / 2, j = Y = O), d.save(), d.lineWidth = b.width, d.strokeStyle = b.color, d.beginPath(), d.moveTo(j, J), d.lineTo(Y, ae), d.stroke(), d.restore(); } drawLabels(a) { if (!this.options.ticks.display) return; const g = this.ctx, w = this._computeLabelArea(); w && Wm(g, w); const b = this.getLabelItems(a); for (const E of b) { const i = E.options, O = E.font, j = E.label, Y = E.textOffset; Fh(g, j, 0, Y, O, i); } w && $m(g); } drawTitle() { const { ctx: a, options: { position: d, title: g, reverse: w } } = this; if (!g.display) return; const b = ir(g.font), E = Gr(g.padding), i = g.align; let O = b.lineHeight / 2; d === "bottom" || d === "center" || yn(d) ? (O += E.bottom, hs(g.text) && (O += b.lineHeight * (g.text.length - 1))) : O += E.top; const { titleX: j, titleY: Y, maxWidth: J, rotation: ae } = gP(this, O, d, i); Fh(a, g.text, 0, 0, b, { color: g.color, maxWidth: J, rotation: ae, textAlign: _P(i, d, w), textBaseline: "middle", translation: [ j, Y ] }); } draw(a) { this._isVisible() && (this.drawBackground(), this.drawGrid(a), this.drawBorder(), this.drawTitle(), this.drawLabels(a)); } _layers() { const a = this.options, d = a.ticks && a.ticks.z || 0, g = en(a.grid && a.grid.z, -1), w = en(a.border && a.border.z, 0); return !this._isVisible() || this.draw !== Bh.prototype.draw ? [ { z: d, draw: (b) => { this.draw(b); } } ] : [ { z: g, draw: (b) => { this.drawBackground(), this.drawGrid(b), this.drawTitle(); } }, { z: w, draw: () => { this.drawBorder(); } }, { z: d, draw: (b) => { this.drawLabels(b); } } ]; } getMatchingVisibleMetas(a) { const d = this.chart.getSortedVisibleDatasetMetas(), g = this.axis + "AxisID", w = []; let b, E; for (b = 0, E = d.length; b < E; ++b) { const i = d[b]; i[g] === this.id && (!a || i.type === a) && w.push(i); } return w; } _resolveTickFontOptions(a) { const d = this.options.ticks.setContext(this.getContext(a)); return ir(d.font); } _maxDigits() { const a = this._resolveTickFontOptions(0).lineHeight; return (this.isHorizontal() ? this.width : this.height) / a; } } class xm { constructor(a, d, g) { this.type = a, this.scope = d, this.override = g, this.items = /* @__PURE__ */ Object.create(null); } isForType(a) { return Object.prototype.isPrototypeOf.call(this.type.prototype, a.prototype); } register(a) { const d = Object.getPrototypeOf(a); let g; vP(d) && (g = this.register(d)); const w = this.items, b = a.id, E = this.scope + "." + b; if (!b) throw new Error("class does not have id: " + a); return b in w || (w[b] = a, yP(a, E, g), this.override && ys.override(a.id, a.overrides)), E; } get(a) { return this.items[a]; } unregister(a) { const d = this.items, g = a.id, w = this.scope; g in d && delete d[g], w && g in ys[w] && (delete ys[w][g], this.override && delete Oh[g]); } } function yP(m, a, d) { const g = Rf(/* @__PURE__ */ Object.create(null), [ d ? ys.get(d) : {}, ys.get(a), m.defaults ]); ys.set(a, g), m.defaultRoutes && xP(a, m.defaultRoutes), m.descriptors && ys.describe(a, m.descriptors); } function xP(m, a) { Object.keys(a).forEach((d) => { const g = d.split("."), w = g.pop(), b = [ m ].concat(g).join("."), E = a[d].split("."), i = E.pop(), O = E.join("."); ys.route(b, w, O, i); }); } function vP(m) { return "id" in m && "defaults" in m; } class bP { constructor() { this.controllers = new xm(za, "datasets", !0), this.elements = new xm(jl, "elements"), this.plugins = new xm(Object, "plugins"), this.scales = new xm(Bh, "scales"), this._typedRegistries = [ this.controllers, this.scales, this.elements ]; } add(...a) { this._each("register", a); } remove(...a) { this._each("unregister", a); } addControllers(...a) { this._each("register", a, this.controllers); } addElements(...a) { this._each("register", a, this.elements); } addPlugins(...a) { this._each("register", a, this.plugins); } addScales(...a) { this._each("register", a, this.scales); } getController(a) { return this._get(a, this.controllers, "controller"); } getElement(a) { return this._get(a, this.elements, "element"); } getPlugin(a) { return this._get(a, this.plugins, "plugin"); } getScale(a) { return this._get(a, this.scales, "scale"); } removeControllers(...a) { this._each("unregister", a, this.controllers); } removeElements(...a) { this._each("unregister", a, this.elements); } removePlugins(...a) { this._each("unregister", a, this.plugins); } removeScales(...a) { this._each("unregister", a, this.scales); } _each(a, d, g) { [ ...d ].forEach((w) => { const b = g || this._getRegistryForType(w); g || b.isForType(w) || b === this.plugins && w.id ? this._exec(a, b, w) : Zn(w, (E) => { const i = g || this._getRegistryForType(E); this._exec(a, i, E); }); }); } _exec(a, d, g) { const w = hy(a); is(g["before" + w], [], g), d[a](g), is(g["after" + w], [], g); } _getRegistryForType(a) { for (let d = 0; d < this._typedRegistries.length; d++) { const g = this._typedRegistries[d]; if (g.isForType(a)) return g; } return this.plugins; } _get(a, d, g) { const w = d.get(a); if (w === void 0) throw new Error('"' + a + '" is not a registered ' + g + "."); return w; } } var al = /* @__PURE__ */ new bP(); class wP { constructor() { this._init = []; } notify(a, d, g, w) { d === "beforeInit" && (this._init = this._createDescriptors(a, !0), this._notify(this._init, a, "install")); const b = w ? this._descriptors(a).filter(w) : this._descriptors(a), E = this._notify(b, a, d, g); return d === "afterDestroy" && (this._notify(b, a, "stop"), this._notify(this._init, a, "uninstall")), E; } _notify(a, d, g, w) { w = w || {}; for (const b of a) { const E = b.plugin, i = E[g], O = [ d, w, b.options ]; if (is(i, O, E) === !1 && w.cancelable) return !1; } return !0; } invalidate() { En(this._cache) || (this._oldCache = this._cache, this._cache = void 0); } _descriptors(a) { if (this._cache) return this._cache; const d = this._cache = this._createDescriptors(a); return this._notifyStateChanges(a), d; } _createDescriptors(a, d) { const g = a && a.config, w = en(g.options && g.options.plugins, {}), b = TP(g); return w === !1 && !d ? [] : SP(a, b, w, d); } _notifyStateChanges(a) { const d = this._oldCache || [], g = this._cache, w = (b, E) => b.filter((i) => !E.some((O) => i.plugin.id === O.plugin.id)); this._notify(w(d, g), a, "stop"), this._notify(w(g, d), a, "start"); } } function TP(m) { const a = {}, d = [], g = Object.keys(al.plugins.items); for (let b = 0; b < g.length; b++) d.push(al.getPlugin(g[b])); const w = m.plugins || []; for (let b = 0; b < w.length; b++) { const E = w[b]; d.indexOf(E) === -1 && (d.push(E), a[E.id] = !0); } return { plugins: d, localIds: a }; } function MP(m, a) { return !a && m === !1 ? null : m === !0 ? {} : m; } function SP(m, { plugins: a, localIds: d }, g, w) { const b = [], E = m.getContext(); for (const i of a) { const O = i.id, j = MP(g[O], w); j !== null && b.push({ plugin: i, options: EP(m.config, { plugin: i, local: d[O] }, j, E) }); } return b; } function EP(m, { plugin: a, local: d }, g, w) { const b = m.pluginScopeKeys(a), E = m.getOptionScopes(g, b); return d && a.defaults && E.push(a.defaults), m.createResolver(E, w, [ "" ], { scriptable: !1, indexable: !1, allKeys: !0 }); } function $g(m, a) { const d = ys.datasets[m] || {}; return ((a.datasets || {})[m] || {}).indexAxis || a.indexAxis || d.indexAxis || "x"; } function PP(m, a) { let d = m; return m === "_index_" ? d = a : m === "_value_" && (d = a === "x" ? "y" : "x"), d; } function AP(m, a) { return m === a ? "_index_" : "_value_"; } function R1(m) { if (m === "x" || m === "y" || m === "r") return m; } function CP(m) { if (m === "top" || m === "bottom") return "x"; if (m === "left" || m === "right") return "y"; } function Xg(m, ...a) { if (R1(m)) return m; for (const d of a) { const g = d.axis || CP(d.position) || m.length > 1 && R1(m[0].toLowerCase()); if (g) return g; } throw new Error(`Cannot determine type of '${m}' axis. Please provide 'axis' or 'position' option.`); } function O1(m, a, d) { if (d[a + "AxisID"] === m) return { axis: a }; } function IP(m, a) { if (a.data && a.data.datasets) { const d = a.data.datasets.filter((g) => g.xAxisID === m || g.yAxisID === m); if (d.length) return O1(m, "x", d[0]) || O1(m, "y", d[0]); } return {}; } function LP(m, a) { const d = Oh[m.type] || { scales: {} }, g = a.scales || {}, w = $g(m.type, a), b = /* @__PURE__ */ Object.create(null); return Object.keys(g).forEach((E) => { const i = g[E]; if (!yn(i)) return console.error(`Invalid scale configuration for scale: ${E}`); if (i._proxy) return console.warn(`Ignoring resolver passed as options for scale: ${E}`); const O = Xg(E, i, IP(E, m), ys.scales[i.type]), j = AP(O, w), Y = d.scales || {}; b[E] = Cf(/* @__PURE__ */ Object.create(null), [ { axis: O }, i, Y[O], Y[j] ]); }), m.data.datasets.forEach((E) => { const i = E.type || m.type, O = E.indexAxis || $g(i, a), Y = (Oh[i] || {}).scales || {}; Object.keys(Y).forEach((J) => { const ae = PP(J, O), ce = E[ae + "AxisID"] || ae; b[ce] = b[ce] || /* @__PURE__ */ Object.create(null), Cf(b[ce], [ { axis: ae }, g[ce], Y[J] ]); }); }), Object.keys(b).forEach((E) => { const i = b[E]; Cf(i, [ ys.scales[i.type], ys.scale ]); }), b; } function iw(m) { const a = m.options || (m.options = {}); a.plugins = en(a.plugins, {}), a.scales = LP(m, a); } function nw(m) { return m = m || {}, m.datasets = m.datasets || [], m.labels = m.labels || [], m; } function zP(m) { return m = m || {}, m.data = nw(m.data), iw(m), m; } const F1 = /* @__PURE__ */ new Map(), sw = /* @__PURE__ */ new Set(); function vm(m, a) { let d = F1.get(m); return d || (d = a(), F1.set(m, d), sw.add(d)), d; } const bf = (m, a, d) => { const g = Rc(a, d); g !== void 0 && m.add(g); }; class DP { constructor(a) { this._config = zP(a), this._scopeCache = /* @__PURE__ */ new Map(), this._resolverCache = /* @__PURE__ */ new Map(); } get platform() { return this._config.platform; } get type() { return this._config.type; } set type(a) { this._config.type = a; } get data() { return this._config.data; } set data(a) { this._config.data = nw(a); } get options() { return this._config.options; } set options(a) { this._config.options = a; } get plugins() { return this._config.plugins; } update() { const a = this._config; this.clearCache(), iw(a); } clearCache() { this._scopeCache.clear(), this._resolverCache.clear(); } datasetScopeKeys(a) { return vm(a, () => [ [ `datasets.${a}`, "" ] ]); } datasetAnimationScopeKeys(a, d) { return vm(`${a}.transition.${d}`, () => [ [ `datasets.${a}.transitions.${d}`, `transitions.${d}` ], [ `datasets.${a}`, "" ] ]); } datasetElementScopeKeys(a, d) { return vm(`${a}-${d}`, () => [ [ `datasets.${a}.elements.${d}`, `datasets.${a}`, `elements.${d}`, "" ] ]); } pluginScopeKeys(a) { const d = a.id, g = this.type; return vm(`${g}-plugin-${d}`, () => [ [ `plugins.${d}`, ...a.additionalOptionScopes || [] ] ]); } _cachedScopes(a, d) { const g = this._scopeCache; let w = g.get(a); return (!w || d) && (w = /* @__PURE__ */ new Map(), g.set(a, w)), w; } getOptionScopes(a, d, g) { const { options: w, type: b } = this, E = this._cachedScopes(a, g), i = E.get(d); if (i) return i; const O = /* @__PURE__ */ new Set(); d.forEach((Y) => { a && (O.add(a), Y.forEach((J) => bf(O, a, J))), Y.forEach((J) => bf(O, w, J)), Y.forEach((J) => bf(O, Oh[b] || {}, J)), Y.forEach((J) => bf(O, ys, J)), Y.forEach((J) => bf(O, Hg, J)); }); const j = Array.from(O); return j.length === 0 && j.push(/* @__PURE__ */ Object.create(null)), sw.has(d) && E.set(d, j), j; } chartOptionScopes() { const { options: a, type: d } = this; return [ a, Oh[d] || {}, ys.datasets[d] || {}, { type: d }, ys, Hg ]; } resolveNamedOptions(a, d, g, w = [ "" ]) { const b = { $shared: !0 }, { resolver: E, subPrefixes: i } = B1(this._resolverCache, a, w); let O = E; if (RP(E, d)) { b.$shared = !1, g = Oc(g) ? g() : g; const j = this.createResolver(a, g, i); O = Yu(E, g, j); } for (const j of d) b[j] = O[j]; return b; } createResolver(a, d, g = [ "" ], w) { const { resolver: b } = B1(this._resolverCache, a, g); return yn(d) ? Yu(b, d, void 0, w) : b; } } function B1(m, a, d) { let g = m.get(a); g || (g = /* @__PURE__ */ new Map(), m.set(a, g)); const w = d.join(); let b = g.get(w); return b || (b = { resolver: _y(a, d), subPrefixes: d.filter((i) => !i.toLowerCase().includes("hover")) }, g.set(w, b)), b; } const kP = (m) => yn(m) && Object.getOwnPropertyNames(m).some((a) => Oc(m[a])); function RP(m, a) { const { isScriptable: d, isIndexable: g } = Fb(m); for (const w of a) { const b = d(w), E = g(w), i = (E || b) && m[w]; if (b && (Oc(i) || kP(i)) || E && hs(i)) return !0; } return !1; } var OP = "4.4.7"; const FP = [ "top", "bottom", "left", "right", "chartArea" ]; function N1(m, a) { return m === "top" || m === "bottom" || FP.indexOf(m) === -1 && a === "x"; } function V1(m, a) { return function(d, g) { return d[m] === g[m] ? d[a] - g[a] : d[m] - g[m]; }; } function U1(m) { const a = m.chart, d = a.options.animation; a.notifyPlugins("afterRender"), is(d && d.onComplete, [ m ], a); } function BP(m) { const a = m.chart, d = a.options.animation; is(d && d.onProgress, [ m ], a); } function rw(m) { return xy() && typeof m == "string" ? m = document.getElementById(m) : m && m.length && (m = m[0]), m && m.canvas && (m = m.canvas), m; } const Dm = {}, j1 = (m) => { const a = rw(m); return Object.values(Dm).filter((d) => d.canvas === a).pop(); }; function NP(m, a, d) { const g = Object.keys(m); for (const w of g) { const b = +w; if (b >= a) { const E = m[w]; delete m[w], (d > 0 || b > a) && (m[b + d] = E); } } } function VP(m, a, d, g) { return !d || m.type === "mouseout" ? null : g ? a : m; } function bm(m, a, d) { return m.options.clip ? m[d] : a[d]; } function UP(m, a) { const { xScale: d, yScale: g } = m; return d && g ? { left: bm(d, a, "left"), right: bm(d, a, "right"), top: bm(g, a, "top"), bottom: bm(g, a, "bottom") } : a; } class Bl { static register(...a) { al.add(...a), G1(); } static unregister(...a) { al.remove(...a), G1(); } constructor(a, d) { const g = this.config = new DP(d), w = rw(a), b = j1(w); if (b) throw new Error("Canvas is already in use. Chart with ID '" + b.id + "' must be destroyed before the canvas with ID '" + b.canvas.id + "' can be reused."); const E = g.createResolver(g.chartOptionScopes(), this.getContext()); this.platform = new (g.platform || sP(w))(), this.platform.updateConfig(g); const i = this.platform.acquireContext(w, E.aspectRatio), O = i && i.canvas, j = O && O.height, Y = O && O.width; if (this.id = GM(), this.ctx = i, this.canvas = O, this.width = Y, this.height = j, this._options = E, this._aspectRatio = this.aspectRatio, this._layers = [], this._metasets = [], this._stacks = void 0, this.boxes = [], this.currentDevicePixelRatio = void 0, this.chartArea = void 0, this._active = [], this._lastEvent = void 0, this._listeners = {}, this._responsiveListeners = void 0, this._sortedMetasets = [], this.scales = {}, this._plugins = new wP(), this.$proxies = {}, this._hiddenIndices = {}, this.attached = !1, this._animationsDisabled = void 0, this.$context = void 0, this._doResize = rS((J) => this.update(J), E.resizeDelay || 0), this._dataChanges = [], Dm[this.id] = this, !i || !O) { console.error("Failed to create chart: can't acquire context from the given item"); return; } Rl.listen(this, "complete", U1), Rl.listen(this, "progress", BP), this._initialize(), this.attached && this.update(); } get aspectRatio() { const { options: { aspectRatio: a, maintainAspectRatio: d }, width: g, height: w, _aspectRatio: b } = this; return En(a) ? d && b ? b : w ? g / w : null : a; } get data() { return this.config.data; } set data(a) { this.config.data = a; } get options() { return this._options; } set options(a) { this.config.options = a; } get registry() { return al; } _initialize() { return this.notifyPlugins("beforeInit"), this.options.responsive ? this.resize() : u1(this, this.options.devicePixelRatio), this.bindEvents(), this.notifyPlugins("afterInit"), this; } clear() { return l1(this.canvas, this.ctx), this; } stop() { return Rl.stop(this), this; } resize(a, d) { Rl.running(this) ? this._resizeBeforeDraw = { width: a, height: d } : this._resize(a, d); } _resize(a, d) { const g = this.options, w = this.canvas, b = g.maintainAspectRatio && this.aspectRatio, E = this.platform.getMaximumSize(w, a, d, b), i = g.devicePixelRatio || this.platform.getDevicePixelRatio(), O = this.width ? "resize" : "attach"; this.width = E.width, this.height = E.height, this._aspectRatio = this.aspectRatio, u1(this, i, !0) && (this.notifyPlugins("resize", { size: E }), is(g.onResize, [ this, E ], this), this.attached && this._doResize(O) && this.render()); } ensureScalesHaveIDs() { const d = this.options.scales || {}; Zn(d, (g, w) => { g.id = w; }); } buildOrUpdateScales() { const a = this.options, d = a.scales, g = this.scales, w = Object.keys(g).reduce((E, i) => (E[i] = !1, E), {}); let b = []; d && (b = b.concat(Object.keys(d).map((E) => { const i = d[E], O = Xg(E, i), j = O === "r", Y = O === "x"; return { options: i, dposition: j ? "chartArea" : Y ? "bottom" : "left", dtype: j ? "radialLinear" : Y ? "category" : "linear" }; }))), Zn(b, (E) => { const i = E.options, O = i.id, j = Xg(O, i), Y = en(i.type, E.dtype); (i.position === void 0 || N1(i.position, j) !== N1(E.dposition)) && (i.position = E.dposition), w[O] = !0; let J = null; if (O in g && g[O].type === Y) J = g[O]; else { const ae = al.getScale(Y); J = new ae({ id: O, type: Y, ctx: this.ctx, chart: this }), g[J.id] = J; } J.init(i, a); }), Zn(w, (E, i) => { E || delete g[i]; }), Zn(g, (E) => { jr.configure(this, E, E.options), jr.addBox(this, E); }); } _updateMetasets() { const a = this._metasets, d = this.data.datasets.length, g = a.length; if (a.sort((w, b) => w.index - b.index), g > d) { for (let w = d; w < g; ++w) this._destroyDatasetMeta(w); a.splice(d, g - d); } this._sortedMetasets = a.slice(0).sort(V1("order", "index")); } _removeUnreferencedMetasets() { const { _metasets: a, data: { datasets: d } } = this; a.length > d.length && delete this._stacks, a.forEach((g, w) => { d.filter((b) => b === g._dataset).length === 0 && this._destroyDatasetMeta(w); }); } buildOrUpdateControllers() { const a = [], d = this.data.datasets; let g, w; for (this._removeUnreferencedMetasets(), g = 0, w = d.length; g < w; g++) { const b = d[g]; let E = this.getDatasetMeta(g); const i = b.type || this.config.type; if (E.type && E.type !== i && (this._destroyDatasetMeta(g), E = this.getDatasetMeta(g)), E.type = i, E.indexAxis = b.indexAxis || $g(i, this.options), E.order = b.order || 0, E.index = g, E.label = "" + b.label, E.visible = this.isDatasetVisible(g), E.controller) E.controller.updateIndex(g), E.controller.linkScales(); else { const O = al.getController(i), { datasetElementType: j, dataElementType: Y } = ys.datasets[i]; Object.assign(O, { dataElementType: al.getElement(Y), datasetElementType: j && al.getElement(j) }), E.controller = new O(this, g), a.push(E.controller); } } return this._updateMetasets(), a; } _resetElements() { Zn(this.data.datasets, (a, d) => { this.getDatasetMeta(d).controller.reset(); }, this); } reset() { this._resetElements(), this.notifyPlugins("reset"); } update(a) { const d = this.config; d.update(); const g = this._options = d.createResolver(d.chartOptionScopes(), this.getContext()), w = this._animationsDisabled = !g.animation; if (this._updateScales(), this._checkEventBindings(), this._updateHiddenIndices(), this._plugins.invalidate(), this.notifyPlugins("beforeUpdate", { mode: a, cancelable: !0 }) === !1) return; const b = this.buildOrUpdateControllers(); this.notifyPlugins("beforeElementsUpdate"); let E = 0; for (let j = 0, Y = this.data.datasets.length; j < Y; j++) { const { controller: J } = this.getDatasetMeta(j), ae = !w && b.indexOf(J) === -1; J.buildOrUpdateElements(ae), E = Math.max(+J.getMaxOverflow(), E); } E = this._minPadding = g.layout.autoPadding ? E : 0, this._updateLayout(E), w || Zn(b, (j) => { j.reset(); }), this._updateDatasets(a), this.notifyPlugins("afterUpdate", { mode: a }), this._layers.sort(V1("z", "_idx")); const { _active: i, _lastEvent: O } = this; O ? this._eventHandler(O, !0) : i.length && this._updateHoverStyles(i, i, !0), this.render(); } _updateScales() { Zn(this.scales, (a) => { jr.removeBox(this, a); }), this.ensureScalesHaveIDs(), this.buildOrUpdateScales(); } _checkEventBindings() { const a = this.options, d = new Set(Object.keys(this._listeners)), g = new Set(a.events); (!Qv(d, g) || !!this._responsiveListeners !== a.responsive) && (this.unbindEvents(), this.bindEvents()); } _updateHiddenIndices() { const { _hiddenIndices: a } = this, d = this._getUniformDataChanges() || []; for (const { method: g, start: w, count: b } of d) { const E = g === "_removeElements" ? -b : b; NP(a, w, E); } } _getUniformDataChanges() { const a = this._dataChanges; if (!a || !a.length) return; this._dataChanges = []; const d = this.data.datasets.length, g = (b) => new Set(a.filter((E) => E[0] === b).map((E, i) => i + "," + E.splice(1).join(","))), w = g(0); for (let b = 1; b < d; b++) if (!Qv(w, g(b))) return; return Array.from(w).map((b) => b.split(",")).map((b) => ({ method: b[1], start: +b[2], count: +b[3] })); } _updateLayout(a) { if (this.notifyPlugins("beforeLayout", { cancelable: !0 }) === !1) return; jr.update(this, this.width, this.height, a); const d = this.chartArea, g = d.width <= 0 || d.height <= 0; this._layers = [], Zn(this.boxes, (w) => { g && w.position === "chartArea" || (w.configure && w.configure(), this._layers.push(...w._layers())); }, this), this._layers.forEach((w, b) => { w._idx = b; }), this.notifyPlugins("afterLayout"); } _updateDatasets(a) { if (this.notifyPlugins("beforeDatasetsUpdate", { mode: a, cancelable: !0 }) !== !1) { for (let d = 0, g = this.data.datasets.length; d < g; ++d) this.getDatasetMeta(d).controller.configure(); for (let d = 0, g = this.data.datasets.length; d < g; ++d) this._updateDataset(d, Oc(a) ? a({ datasetIndex: d }) : a); this.notifyPlugins("afterDatasetsUpdate", { mode: a }); } } _updateDataset(a, d) { const g = this.getDatasetMeta(a), w = { meta: g, index: a, mode: d, cancelable: !0 }; this.notifyPlugins("beforeDatasetUpdate", w) !== !1 && (g.controller._update(d), w.cancelable = !1, this.notifyPlugins("afterDatasetUpdate", w)); } render() { this.notifyPlugins("beforeRender", { cancelable: !0 }) !== !1 && (Rl.has(this) ? this.attached && !Rl.running(this) && Rl.start(this) : (this.draw(), U1({ chart: this }))); } draw() { let a; if (this._resizeBeforeDraw) { const { width: g, height: w } = this._resizeBeforeDraw; this._resizeBeforeDraw = null, this._resize(g, w); } if (this.clear(), this.width <= 0 || this.height <= 0 || this.notifyPlugins("beforeDraw", { cancelable: !0 }) === !1) return; const d = this._layers; for (a = 0; a < d.length && d[a].z <= 0; ++a) d[a].draw(this.chartArea); for (this._drawDatasets(); a < d.length; ++a) d[a].draw(this.chartArea); this.notifyPlugins("afterDraw"); } _getSortedDatasetMetas(a) { const d = this._sortedMetasets, g = []; let w, b; for (w = 0, b = d.length; w < b; ++w) { const E = d[w]; (!a || E.visible) && g.push(E); } return g; } getSortedVisibleDatasetMetas() { return this._getSortedDatasetMetas(!0); } _drawDatasets() { if (this.notifyPlugins("beforeDatasetsDraw", { cancelable: !0 }) === !1) return; const a = this.getSortedVisibleDatasetMetas(); for (let d = a.length - 1; d >= 0; --d) this._drawDataset(a[d]); this.notifyPlugins("afterDatasetsDraw"); } _drawDataset(a) { const d = this.ctx, g = a._clip, w = !g.disabled, b = UP(a, this.chartArea), E = { meta: a, index: a.index, cancelable: !0 }; this.notifyPlugins("beforeDatasetDraw", E) !== !1 && (w && Wm(d, { left: g.left === !1 ? 0 : b.left - g.left, right: g.right === !1 ? this.width : b.right + g.right, top: g.top === !1 ? 0 : b.top - g.top, bottom: g.bottom === !1 ? this.height : b.bottom + g.bottom }), a.controller.draw(), w && $m(d), E.cancelable = !1, this.notifyPlugins("afterDatasetDraw", E)); } isPointInArea(a) { return Ul(a, this.chartArea, this._minPadding); } getElementsAtEventForMode(a, d, g, w) { const b = FE.modes[d]; return typeof b == "function" ? b(this, a, g, w) : []; } getDatasetMeta(a) { const d = this.data.datasets[a], g = this._metasets; let w = g.filter((b) => b && b._dataset === d).pop(); return w || (w = { type: null, data: [], dataset: null, controller: null, hidden: null, xAxisID: null, yAxisID: null, order: d && d.order || 0, index: a, _dataset: d, _parsed: [], _sorted: !1 }, g.push(w)), w; } getContext() { return this.$context || (this.$context = Fc(null, { chart: this, type: "chart" })); } getVisibleDatasetCount() { return this.getSortedVisibleDatasetMetas().length; } isDatasetVisible(a) { const d = this.data.datasets[a]; if (!d) return !1; const g = this.getDatasetMeta(a); return typeof g.hidden == "boolean" ? !g.hidden : !d.hidden; } setDatasetVisibility(a, d) { const g = this.getDatasetMeta(a); g.hidden = !d; } toggleDataVisibility(a) { this._hiddenIndices[a] = !this._hiddenIndices[a]; } getDataVisibility(a) { return !this._hiddenIndices[a]; } _updateVisibility(a, d, g) { const w = g ? "show" : "hide", b = this.getDatasetMeta(a), E = b.controller._resolveAnimations(void 0, w); Of(d) ? (b.data[d].hidden = !g, this.update()) : (this.setDatasetVisibility(a, g), E.update(b, { visible: g }), this.update((i) => i.datasetIndex === a ? w : void 0)); } hide(a, d) { this._updateVisibility(a, d, !1); } show(a, d) { this._updateVisibility(a, d, !0); } _destroyDatasetMeta(a) { const d = this._metasets[a]; d && d.controller && d.controller._destroy(), delete this._metasets[a]; } _stop() { let a, d; for (this.stop(), Rl.remove(this), a = 0, d = this.data.datasets.length; a < d; ++a) this._destroyDatasetMeta(a); } destroy() { this.notifyPlugins("beforeDestroy"); const { canvas: a, ctx: d } = this; this._stop(), this.config.clearCache(), a && (this.unbindEvents(), l1(a, d), this.platform.releaseContext(d), this.canvas = null, this.ctx = null), delete Dm[this.id], this.notifyPlugins("afterDestroy"); } toBase64Image(...a) { return this.canvas.toDataURL(...a); } bindEvents() { this.bindUserEvents(), this.options.responsive ? this.bindResponsiveEvents() : this.attached = !0; } bindUserEvents() { const a = this._listeners, d = this.platform, g = (b, E) => { d.addEventListener(this, b, E), a[b] = E; }, w = (b, E, i) => { b.offsetX = E, b.offsetY = i, this._eventHandler(b); }; Zn(this.options.events, (b) => g(b, w)); } bindResponsiveEvents() { this._responsiveListeners || (this._responsiveListeners = {}); const a = this._responsiveListeners, d = this.platform, g = (O, j) => { d.addEventListener(this, O, j), a[O] = j; }, w = (O, j) => { a[O] && (d.removeEventListener(this, O, j), delete a[O]); }, b = (O, j) => { this.canvas && this.resize(O, j); }; let E; const i = () => { w("attach", i), this.attached = !0, this.resize(), g("resize", b), g("detach", E); }; E = () => { this.attached = !1, w("resize", b), this._stop(), this._resize(0, 0), g("attach", i); }, d.isAttached(this.canvas) ? i() : E(); } unbindEvents() { Zn(this._listeners, (a, d) => { this.platform.removeEventListener(this, d, a); }), this._listeners = {}, Zn(this._responsiveListeners, (a, d) => { this.platform.removeEventListener(this, d, a); }), this._responsiveListeners = void 0; } updateHoverStyle(a, d, g) { const w = g ? "set" : "remove"; let b, E, i, O; for (d === "dataset" && (b = this.getDatasetMeta(a[0].datasetIndex), b.controller["_" + w + "DatasetHoverStyle"]()), i = 0, O = a.length; i < O; ++i) { E = a[i]; const j = E && this.getDatasetMeta(E.datasetIndex).controller; j && j[w + "HoverStyle"](E.element, E.datasetIndex, E.index); } } getActiveElements() { return this._active || []; } setActiveElements(a) { const d = this._active || [], g = a.map(({ datasetIndex: b, index: E }) => { const i = this.getDatasetMeta(b); if (!i) throw new Error("No dataset found at index " + b); return { datasetIndex: b, element: i.data[E], index: E }; }); !Om(g, d) && (this._active = g, this._lastEvent = null, this._updateHoverStyles(g, d)); } notifyPlugins(a, d, g) { return this._plugins.notify(this, a, d, g); } isPluginEnabled(a) { return this._plugins._cache.filter((d) => d.plugin.id === a).length === 1; } _updateHoverStyles(a, d, g) { const w = this.options.hover, b = (O, j) => O.filter((Y) => !j.some((J) => Y.datasetIndex === J.datasetIndex && Y.index === J.index)), E = b(d, a), i = g ? a : b(a, d); E.length && this.updateHoverStyle(E, w.mode, !1), i.length && w.mode && this.updateHoverStyle(i, w.mode, !0); } _eventHandler(a, d) { const g = { event: a, replay: d, cancelable: !0, inChartArea: this.isPointInArea(a) }, w = (E) => (E.options.events || this.options.events).includes(a.native.type); if (this.notifyPlugins("beforeEvent", g, w) === !1) return; const b = this._handleEvent(a, d, g.inChartArea); return g.cancelable = !1, this.notifyPlugins("afterEvent", g, w), (b || g.changed) && this.render(), this; } _handleEvent(a, d, g) { const { _active: w = [], options: b } = this, E = d, i = this._getActiveElements(a, w, g, E), O = XM(a), j = VP(a, this._lastEvent, g, O); g && (this._lastEvent = null, is(b.onHover, [ a, i, this ], this), O && is(b.onClick, [ a, i, this ], this)); const Y = !Om(i, w); return (Y || d) && (this._active = i, this._updateHoverStyles(i, w, d)), this._lastEvent = j, Y; } _getActiveElements(a, d, g, w) { if (a.type === "mouseout") return []; if (!g) return d; const b = this.options.hover; return this.getElementsAtEventForMode(a, b.mode, b, w); } } Yt(Bl, "defaults", ys), Yt(Bl, "instances", Dm), Yt(Bl, "overrides", Oh), Yt(Bl, "registry", al), Yt(Bl, "version", OP), Yt(Bl, "getChart", j1); function G1() { return Zn(Bl.instances, (m) => m._plugins.invalidate()); } function jP(m, a, d) { const { startAngle: g, pixelMargin: w, x: b, y: E, outerRadius: i, innerRadius: O } = a; let j = w / i; m.beginPath(), m.arc(b, E, i, g - j, d + j), O > w ? (j = w / O, m.arc(b, E, O, d + j, g - j, !0)) : m.arc(b, E, w, d + Ns, g - Ns), m.closePath(), m.clip(); } function GP(m) { return my(m, [ "outerStart", "outerEnd", "innerStart", "innerEnd" ]); } function ZP(m, a, d, g) { const w = GP(m.options.borderRadius), b = (d - a) / 2, E = Math.min(b, g * a / 2), i = (O) => { const j = (d - Math.min(b, O)) * g / 2; return gr(O, 0, Math.min(b, j)); }; return { outerStart: i(w.outerStart), outerEnd: i(w.outerEnd), innerStart: gr(w.innerStart, 0, E), innerEnd: gr(w.innerEnd, 0, E) }; } function Wu(m, a, d, g) { return { x: d + m * Math.cos(a), y: g + m * Math.sin(a) }; } function jm(m, a, d, g, w, b) { const { x: E, y: i, startAngle: O, pixelMargin: j, innerRadius: Y } = a, J = Math.max(a.outerRadius + g + d - j, 0), ae = Y > 0 ? Y + g + d + j : 0; let ce = 0; const Te = w - O; if (g) { const Ht = Y > 0 ? Y - g : 0, Si = J > 0 ? J - g : 0, Ji = (Ht + Si) / 2, fi = Ji !== 0 ? Te * Ji / (Ji + g) : Te; ce = (Te - fi) / 2; } const be = Math.max(1e-3, Te * J - d / ds) / J, Ze = (Te - be) / 2, je = O + Ze + ce, ot = w - Ze - ce, { outerStart: vt, outerEnd: ht, innerStart: gt, innerEnd: Vt } = ZP(a, ae, J, ot - je), pt = J - vt, Gt = J - ht, ui = je + vt / pt, kt = ot - ht / Gt, Pt = ae + gt, Mi = ae + Vt, Pn = je + gt / Pt, hn = ot - Vt / Mi; if (m.beginPath(), b) { const Ht = (ui + kt) / 2; if (m.arc(E, i, J, ui, Ht), m.arc(E, i, J, Ht, kt), ht > 0) { const jt = Wu(Gt, kt, E, i); m.arc(jt.x, jt.y, ht, kt, ot + Ns); } const Si = Wu(Mi, ot, E, i); if (m.lineTo(Si.x, Si.y), Vt > 0) { const jt = Wu(Mi, hn, E, i); m.arc(jt.x, jt.y, Vt, ot + Ns, hn + Math.PI); } const Ji = (ot - Vt / ae + (je + gt / ae)) / 2; if (m.arc(E, i, ae, ot - Vt / ae, Ji, !0), m.arc(E, i, ae, Ji, je + gt / ae, !0), gt > 0) { const jt = Wu(Pt, Pn, E, i); m.arc(jt.x, jt.y, gt, Pn + Math.PI, je - Ns); } const fi = Wu(pt, je, E, i); if (m.lineTo(fi.x, fi.y), vt > 0) { const jt = Wu(pt, ui, E, i); m.arc(jt.x, jt.y, vt, je - Ns, ui); } } else { m.moveTo(E, i); const Ht = Math.cos(ui) * J + E, Si = Math.sin(ui) * J + i; m.lineTo(Ht, Si); const Ji = Math.cos(kt) * J + E, fi = Math.sin(kt) * J + i; m.lineTo(Ji, fi); } m.closePath(); } function HP(m, a, d, g, w) { const { fullCircles: b, startAngle: E, circumference: i } = a; let O = a.endAngle; if (b) { jm(m, a, d, g, O, w); for (let j = 0; j < b; ++j) m.fill(); isNaN(i) || (O = E + (i % us || us)); } return jm(m, a, d, g, O, w), m.fill(), O; } function qP(m, a, d, g, w) { const { fullCircles: b, startAngle: E, circumference: i, options: O } = a, { borderWidth: j, borderJoinStyle: Y, borderDash: J, borderDashOffset: ae } = O, ce = O.borderAlign === "inner"; if (!j) return; m.setLineDash(J || []), m.lineDashOffset = ae, ce ? (m.lineWidth = j * 2, m.lineJoin = Y || "round") : (m.lineWidth = j, m.lineJoin = Y || "bevel"); let Te = a.endAngle; if (b) { jm(m, a, d, g, Te, w); for (let be = 0; be < b; ++be) m.stroke(); isNaN(i) || (Te = E + (i % us || us)); } ce && jP(m, a, Te), b || (jm(m, a, d, g, Te, w), m.stroke()); } class Sf extends jl { constructor(d) { super(); Yt(this, "circumference"); Yt(this, "endAngle"); Yt(this, "fullCircles"); Yt(this, "innerRadius"); Yt(this, "outerRadius"); Yt(this, "pixelMargin"); Yt(this, "startAngle"); this.options = void 0, this.circumference = void 0, this.startAngle = void 0, this.endAngle = void 0, this.innerRadius = void 0, this.outerRadius = void 0, this.pixelMargin = 0, this.fullCircles = 0, d && Object.assign(this, d); } inRange(d, g, w) { const b = this.getProps([ "x", "y" ], w), { angle: E, distance: i } = Pb(b, { x: d, y: g }), { startAngle: O, endAngle: j, innerRadius: Y, outerRadius: J, circumference: ae } = this.getProps([ "startAngle", "endAngle", "innerRadius", "outerRadius", "circumference" ], w), ce = (this.options.spacing + this.options.borderWidth) / 2, Te = en(ae, j - O), be = Ff(E, O, j) && O !== j, Ze = Te >= us || be, je = Nl(i, Y + ce, J + ce); return Ze && je; } getCenterPoint(d) { const { x: g, y: w, startAngle: b, endAngle: E, innerRadius: i, outerRadius: O } = this.getProps([ "x", "y", "startAngle", "endAngle", "innerRadius", "outerRadius" ], d), { offset: j, spacing: Y } = this.options, J = (b + E) / 2, ae = (i + O + Y + j) / 2; return { x: g + Math.cos(J) * ae, y: w + Math.sin(J) * ae }; } tooltipPosition(d) { return this.getCenterPoint(d); } draw(d) { const { options: g, circumference: w } = this, b = (g.offset || 0) / 4, E = (g.spacing || 0) / 2, i = g.circular; if (this.pixelMargin = g.borderAlign === "inner" ? 0.33 : 0, this.fullCircles = w > us ? Math.floor(w / us) : 0, w === 0 || this.innerRadius < 0 || this.outerRadius < 0) return; d.save(); const O = (this.startAngle + this.endAngle) / 2; d.translate(Math.cos(O) * b, Math.sin(O) * b); const j = 1 - Math.sin(Math.min(ds, w || 0)), Y = b * j; d.fillStyle = g.backgroundColor, d.strokeStyle = g.borderColor, HP(d, this, Y, E, i), qP(d, this, Y, E, i), d.restore(); } } Yt(Sf, "id", "arc"), Yt(Sf, "defaults", { borderAlign: "center", borderColor: "#fff", borderDash: [], borderDashOffset: 0, borderJoinStyle: void 0, borderRadius: 0, borderWidth: 2, offset: 0, spacing: 0, angle: void 0, circular: !0 }), Yt(Sf, "defaultRoutes", { backgroundColor: "backgroundColor" }), Yt(Sf, "descriptors", { _scriptable: !0, _indexable: (d) => d !== "borderDash" }); function ow(m, a, d = a) { m.lineCap = en(d.borderCapStyle, a.borderCapStyle), m.setLineDash(en(d.borderDash, a.borderDash)), m.lineDashOffset = en(d.borderDashOffset, a.borderDashOffset), m.lineJoin = en(d.borderJoinStyle, a.borderJoinStyle), m.lineWidth = en(d.borderWidth, a.borderWidth), m.strokeStyle = en(d.borderColor, a.borderColor); } function WP(m, a, d) { m.lineTo(d.x, d.y); } function $P(m) { return m.stepped ? gS : m.tension || m.cubicInterpolationMode === "monotone" ? yS : WP; } function aw(m, a, d = {}) { const g = m.length, { start: w = 0, end: b = g - 1 } = d, { start: E, end: i } = a, O = Math.max(w, E), j = Math.min(b, i), Y = w < E && b < E || w > i && b > i; return { count: g, start: O, loop: a.loop, ilen: j < O && !Y ? g + j - O : j - O }; } function XP(m, a, d, g) { const { points: w, options: b } = a, { count: E, start: i, loop: O, ilen: j } = aw(w, d, g), Y = $P(b); let { move: J = !0, reverse: ae } = g || {}, ce, Te, be; for (ce = 0; ce <= j; ++ce) Te = w[(i + (ae ? j - ce : ce)) % E], !Te.skip && (J ? (m.moveTo(Te.x, Te.y), J = !1) : Y(m, be, Te, ae, b.stepped), be = Te); return O && (Te = w[(i + (ae ? j : 0)) % E], Y(m, be, Te, ae, b.stepped)), !!O; } function YP(m, a, d, g) { const w = a.points, { count: b, start: E, ilen: i } = aw(w, d, g), { move: O = !0, reverse: j } = g || {}; let Y = 0, J = 0, ae, ce, Te, be, Ze, je; const ot = (ht) => (E + (j ? i - ht : ht)) % b, vt = () => { be !== Ze && (m.lineTo(Y, Ze), m.lineTo(Y, be), m.lineTo(Y, je)); }; for (O && (ce = w[ot(0)], m.moveTo(ce.x, ce.y)), ae = 0; ae <= i; ++ae) { if (ce = w[ot(ae)], ce.skip) continue; const ht = ce.x, gt = ce.y, Vt = ht | 0; Vt === Te ? (gt < be ? be = gt : gt > Ze && (Ze = gt), Y = (J * Y + ht) / ++J) : (vt(), m.lineTo(ht, gt), Te = Vt, J = 0, be = Ze = gt), je = gt; } vt(); } function Yg(m) { const a = m.options, d = a.borderDash && a.borderDash.length; return !m._decimated && !m._loop && !a.tension && a.cubicInterpolationMode !== "monotone" && !a.stepped && !d ? YP : XP; } function KP(m) { return m.stepped ? YS : m.tension || m.cubicInterpolationMode === "monotone" ? KS : zh; } function JP(m, a, d, g) { let w = a._path; w || (w = a._path = new Path2D(), a.path(w, d, g) && w.closePath()), ow(m, a.options), m.stroke(w); } function QP(m, a, d, g) { const { segments: w, options: b } = a, E = Yg(a); for (const i of w) ow(m, b, i.style), m.beginPath(), E(m, a, i, { start: d, end: d + g - 1 }) && m.closePath(), m.stroke(); } const eA = typeof Path2D == "function"; function tA(m, a, d, g) { eA && !a.options.segment ? JP(m, a, d, g) : QP(m, a, d, g); } class zc extends jl { constructor(a) { super(), this.animated = !0, this.options = void 0, this._chart = void 0, this._loop = void 0, this._fullLoop = void 0, this._path = void 0, this._points = void 0, this._segments = void 0, this._decimated = !1, this._pointsUpdated = !1, this._datasetIndex = void 0, a && Object.assign(this, a); } updateControlPoints(a, d) { const g = this.options; if ((g.tension || g.cubicInterpolationMode === "monotone") && !g.stepped && !this._pointsUpdated) { const w = g.spanGaps ? this._loop : this._fullLoop; jS(this._points, g, a, w, d), this._pointsUpdated = !0; } } set points(a) { this._points = a, delete this._segments, delete this._path, this._pointsUpdated = !1; } get points() { return this._points; } get segments() { return this._segments || (this._segments = nE(this, this.options.segment)); } first() { const a = this.segments, d = this.points; return a.length && d[a[0].start]; } last() { const a = this.segments, d = this.points, g = a.length; return g && d[a[g - 1].end]; } interpolate(a, d) { const g = this.options, w = a[d], b = this.points, E = Wb(this, { property: d, start: w, end: w }); if (!E.length) return; const i = [], O = KP(g); let j, Y; for (j = 0, Y = E.length; j < Y; ++j) { const { start: J, end: ae } = E[j], ce = b[J], Te = b[ae]; if (ce === Te) { i.push(ce); continue; } const be = Math.abs((w - ce[d]) / (Te[d] - ce[d])), Ze = O(ce, Te, be, g.stepped); Ze[d] = a[d], i.push(Ze); } return i.length === 1 ? i[0] : i; } pathSegment(a, d, g) { return Yg(this)(a, this, d, g); } path(a, d, g) { const w = this.segments, b = Yg(this); let E = this._loop; d = d || 0, g = g || this.points.length - d; for (const i of w) E &= b(a, this, i, { start: d, end: d + g - 1 }); return !!E; } draw(a, d, g, w) { const b = this.options || {}; (this.points || []).length && b.borderWidth && (a.save(), tA(a, this, g, w), a.restore()), this.animated && (this._pointsUpdated = !1, this._path = void 0); } } Yt(zc, "id", "line"), Yt(zc, "defaults", { borderCapStyle: "butt", borderDash: [], borderDashOffset: 0, borderJoinStyle: "miter", borderWidth: 3, capBezierPoints: !0, cubicInterpolationMode: "default", fill: !1, spanGaps: !1, stepped: !1, tension: 0 }), Yt(zc, "defaultRoutes", { backgroundColor: "backgroundColor", borderColor: "borderColor" }), Yt(zc, "descriptors", { _scriptable: !0, _indexable: (a) => a !== "borderDash" && a !== "fill" }); function Z1(m, a, d, g) { const w = m.options, { [d]: b } = m.getProps([ d ], g); return Math.abs(a - b) < w.radius + w.hitRadius; } class km extends jl { constructor(d) { super(); Yt(this, "parsed"); Yt(this, "skip"); Yt(this, "stop"); this.options = void 0, this.parsed = void 0, this.skip = void 0, this.stop = void 0, d && Object.assign(this, d); } inRange(d, g, w) { const b = this.options, { x: E, y: i } = this.getProps([ "x", "y" ], w); return Math.pow(d - E, 2) + Math.pow(g - i, 2) < Math.pow(b.hitRadius + b.radius, 2); } inXRange(d, g) { return Z1(this, d, "x", g); } inYRange(d, g) { return Z1(this, d, "y", g); } getCenterPoint(d) { const { x: g, y: w } = this.getProps([ "x", "y" ], d); return { x: g, y: w }; } size(d) { d = d || this.options || {}; let g = d.radius || 0; g = Math.max(g, g && d.hoverRadius || 0); const w = g && d.borderWidth || 0; return (g + w) * 2; } draw(d, g) { const w = this.options; this.skip || w.radius < 0.1 || !Ul(this, g, this.size(w) / 2) || (d.strokeStyle = w.borderColor, d.lineWidth = w.borderWidth, d.fillStyle = w.backgroundColor, qg(d, w, this.x, this.y)); } getRange() { const d = this.options || {}; return d.radius + d.hitRadius; } } Yt(km, "id", "point"), /** * @type {any} */ Yt(km, "defaults", { borderWidth: 1, hitRadius: 1, hoverBorderWidth: 1, hoverRadius: 4, pointStyle: "circle", radius: 3, rotation: 0 }), /** * @type {any} */ Yt(km, "defaultRoutes", { backgroundColor: "backgroundColor", borderColor: "borderColor" }); function lw(m, a) { const { x: d, y: g, base: w, width: b, height: E } = m.getProps([ "x", "y", "base", "width", "height" ], a); let i, O, j, Y, J; return m.horizontal ? (J = E / 2, i = Math.min(d, w), O = Math.max(d, w), j = g - J, Y = g + J) : (J = b / 2, i = d - J, O = d + J, j = Math.min(g, w), Y = Math.max(g, w)), { left: i, top: j, right: O, bottom: Y }; } function Dc(m, a, d, g) { return m ? 0 : gr(a, d, g); } function iA(m, a, d) { const g = m.options.borderWidth, w = m.borderSkipped, b = Ob(g); return { t: Dc(w.top, b.top, 0, d), r: Dc(w.right, b.right, 0, a), b: Dc(w.bottom, b.bottom, 0, d), l: Dc(w.left, b.left, 0, a) }; } function nA(m, a, d) { const { enableBorderRadius: g } = m.getProps([ "enableBorderRadius" ]), w = m.options.borderRadius, b = kh(w), E = Math.min(a, d), i = m.borderSkipped, O = g || yn(w); return { topLeft: Dc(!O || i.top || i.left, b.topLeft, 0, E), topRight: Dc(!O || i.top || i.right, b.topRight, 0, E), bottomLeft: Dc(!O || i.bottom || i.left, b.bottomLeft, 0, E), bottomRight: Dc(!O || i.bottom || i.right, b.bottomRight, 0, E) }; } function sA(m) { const a = lw(m), d = a.right - a.left, g = a.bottom - a.top, w = iA(m, d / 2, g / 2), b = nA(m, d / 2, g / 2); return { outer: { x: a.left, y: a.top, w: d, h: g, radius: b }, inner: { x: a.left + w.l, y: a.top + w.t, w: d - w.l - w.r, h: g - w.t - w.b, radius: { topLeft: Math.max(0, b.topLeft - Math.max(w.t, w.l)), topRight: Math.max(0, b.topRight - Math.max(w.t, w.r)), bottomLeft: Math.max(0, b.bottomLeft - Math.max(w.b, w.l)), bottomRight: Math.max(0, b.bottomRight - Math.max(w.b, w.r)) } } }; } function Vg(m, a, d, g) { const w = a === null, b = d === null, i = m && !(w && b) && lw(m, g); return i && (w || Nl(a, i.left, i.right)) && (b || Nl(d, i.top, i.bottom)); } function rA(m) { return m.topLeft || m.topRight || m.bottomLeft || m.bottomRight; } function oA(m, a) { m.rect(a.x, a.y, a.w, a.h); } function Ug(m, a, d = {}) { const g = m.x !== d.x ? -a : 0, w = m.y !== d.y ? -a : 0, b = (m.x + m.w !== d.x + d.w ? a : 0) - g, E = (m.y + m.h !== d.y + d.h ? a : 0) - w; return { x: m.x + g, y: m.y + w, w: m.w + b, h: m.h + E, radius: m.radius }; } class Rm extends jl { constructor(a) { super(), this.options = void 0, this.horizontal = void 0, this.base = void 0, this.width = void 0, this.height = void 0, this.inflateAmount = void 0, a && Object.assign(this, a); } draw(a) { const { inflateAmount: d, options: { borderColor: g, backgroundColor: w } } = this, { inner: b, outer: E } = sA(this), i = rA(E.radius) ? Bf : oA; a.save(), (E.w !== b.w || E.h !== b.h) && (a.beginPath(), i(a, Ug(E, d, b)), a.clip(), i(a, Ug(b, -d, E)), a.fillStyle = g, a.fill("evenodd")), a.beginPath(), i(a, Ug(b, d)), a.fillStyle = w, a.fill(), a.restore(); } inRange(a, d, g) { return Vg(this, a, d, g); } inXRange(a, d) { return Vg(this, a, null, d); } inYRange(a, d) { return Vg(this, null, a, d); } getCenterPoint(a) { const { x: d, y: g, base: w, horizontal: b } = this.getProps([ "x", "y", "base", "horizontal" ], a); return { x: b ? (d + w) / 2 : d, y: b ? g : (g + w) / 2 }; } getRange(a) { return a === "x" ? this.width / 2 : this.height / 2; } } Yt(Rm, "id", "bar"), Yt(Rm, "defaults", { borderSkipped: "start", borderWidth: 0, borderRadius: 0, inflateAmount: "auto", pointStyle: void 0 }), Yt(Rm, "defaultRoutes", { backgroundColor: "backgroundColor", borderColor: "borderColor" }); var aA = /* @__PURE__ */ Object.freeze({ __proto__: null, ArcElement: Sf, BarElement: Rm, LineElement: zc, PointElement: km }); const Kg = [ "rgb(54, 162, 235)", "rgb(255, 99, 132)", "rgb(255, 159, 64)", "rgb(255, 205, 86)", "rgb(75, 192, 192)", "rgb(153, 102, 255)", "rgb(201, 203, 207)" // grey ], H1 = /* @__PURE__ */ Kg.map((m) => m.replace("rgb(", "rgba(").replace(")", ", 0.5)")); function cw(m) { return Kg[m % Kg.length]; } function hw(m) { return H1[m % H1.length]; } function lA(m, a) { return m.borderColor = cw(a), m.backgroundColor = hw(a), ++a; } function cA(m, a) { return m.backgroundColor = m.data.map(() => cw(a++)), a; } function hA(m, a) { return m.backgroundColor = m.data.map(() => hw(a++)), a; } function uA(m) { let a = 0; return (d, g) => { const w = m.getDatasetMeta(g).controller; w instanceof Dh ? a = cA(d, a) : w instanceof Df ? a = hA(d, a) : w && (a = lA(d, a)); }; } function q1(m) { let a; for (a in m) if (m[a].borderColor || m[a].backgroundColor) return !0; return !1; } function dA(m) { return m && (m.borderColor || m.backgroundColor); } function fA() { return ys.borderColor !== "rgba(0,0,0,0.1)" || ys.backgroundColor !== "rgba(0,0,0,0.1)"; } var pA = { id: "colors", defaults: { enabled: !0, forceOverride: !1 }, beforeLayout(m, a, d) { if (!d.enabled) return; const { data: { datasets: g }, options: w } = m.config, { elements: b } = w, E = q1(g) || dA(w) || b && q1(b) || fA(); if (!d.forceOverride && E) return; const i = uA(m); g.forEach(i); } }; function mA(m, a, d, g, w) { const b = w.samples || g; if (b >= d) return m.slice(a, a + d); const E = [], i = (d - 2) / (b - 2); let O = 0; const j = a + d - 1; let Y = a, J, ae, ce, Te, be; for (E[O++] = m[Y], J = 0; J < b - 2; J++) { let Ze = 0, je = 0, ot; const vt = Math.floor((J + 1) * i) + 1 + a, ht = Math.min(Math.floor((J + 2) * i) + 1, d) + a, gt = ht - vt; for (ot = vt; ot < ht; ot++) Ze += m[ot].x, je += m[ot].y; Ze /= gt, je /= gt; const Vt = Math.floor(J * i) + 1 + a, pt = Math.min(Math.floor((J + 1) * i) + 1, d) + a, { x: Gt, y: ui } = m[Y]; for (ce = Te = -1, ot = Vt; ot < pt; ot++) Te = 0.5 * Math.abs((Gt - Ze) * (m[ot].y - ui) - (Gt - m[ot].x) * (je - ui)), Te > ce && (ce = Te, ae = m[ot], be = ot); E[O++] = ae, Y = be; } return E[O++] = m[j], E; } function _A(m, a, d, g) { let w = 0, b = 0, E, i, O, j, Y, J, ae, ce, Te, be; const Ze = [], je = a + d - 1, ot = m[a].x, ht = m[je].x - ot; for (E = a; E < a + d; ++E) { i = m[E], O = (i.x - ot) / ht * g, j = i.y; const gt = O | 0; if (gt === Y) j < Te ? (Te = j, J = E) : j > be && (be = j, ae = E), w = (b * w + i.x) / ++b; else { const Vt = E - 1; if (!En(J) && !En(ae)) { const pt = Math.min(J, ae), Gt = Math.max(J, ae); pt !== ce && pt !== Vt && Ze.push({ ...m[pt], x: w }), Gt !== ce && Gt !== Vt && Ze.push({ ...m[Gt], x: w }); } E > 0 && Vt !== ce && Ze.push(m[Vt]), Ze.push(i), Y = gt, b = 0, Te = be = j, J = ae = ce = E; } } return Ze; } function uw(m) { if (m._decimated) { const a = m._data; delete m._decimated, delete m._data, Object.defineProperty(m, "data", { configurable: !0, enumerable: !0, writable: !0, value: a }); } } function W1(m) { m.data.datasets.forEach((a) => { uw(a); }); } function gA(m, a) { const d = a.length; let g = 0, w; const { iScale: b } = m, { min: E, max: i, minDefined: O, maxDefined: j } = b.getUserBounds(); return O && (g = gr(Vl(a, b.axis, E).lo, 0, d - 1)), j ? w = gr(Vl(a, b.axis, i).hi + 1, g, d) - g : w = d - g, { start: g, count: w }; } var yA = { id: "decimation", defaults: { algorithm: "min-max", enabled: !1 }, beforeElementsUpdate: (m, a, d) => { if (!d.enabled) { W1(m); return; } const g = m.width; m.data.datasets.forEach((w, b) => { const { _data: E, indexAxis: i } = w, O = m.getDatasetMeta(b), j = E || w.data; if (Tf([ i, m.options.indexAxis ]) === "y" || !O.controller.supportsDecimation) return; const Y = m.scales[O.xAxisID]; if (Y.type !== "linear" && Y.type !== "time" || m.options.parsing) return; let { start: J, count: ae } = gA(O, j); const ce = d.threshold || 4 * g; if (ae <= ce) { uw(w); return; } En(E) && (w._data = j, delete w.data, Object.defineProperty(w, "data", { configurable: !0, enumerable: !0, get: function() { return this._decimated; }, set: function(be) { this._data = be; } })); let Te; switch (d.algorithm) { case "lttb": Te = mA(j, J, ae, g, d); break; case "min-max": Te = _A(j, J, ae, g); break; default: throw new Error(`Unsupported decimation algorithm '${d.algorithm}'`); } w._decimated = Te; }); }, destroy(m) { W1(m); } }; function xA(m, a, d) { const g = m.segments, w = m.points, b = a.points, E = []; for (const i of g) { let { start: O, end: j } = i; j = wy(O, j, w); const Y = Jg(d, w[O], w[j], i.loop); if (!a.segments) { E.push({ source: i, target: Y, start: w[O], end: w[j] }); continue; } const J = Wb(a, Y); for (const ae of J) { const ce = Jg(d, b[ae.start], b[ae.end], ae.loop), Te = qb(i, w, ce); for (const be of Te) E.push({ source: be, target: ae, start: { [d]: $1(Y, ce, "start", Math.max) }, end: { [d]: $1(Y, ce, "end", Math.min) } }); } } return E; } function Jg(m, a, d, g) { if (g) return; let w = a[m], b = d[m]; return m === "angle" && (w = No(w), b = No(b)), { property: m, start: w, end: b }; } function vA(m, a) { const { x: d = null, y: g = null } = m || {}, w = a.points, b = []; return a.segments.forEach(({ start: E, end: i }) => { i = wy(E, i, w); const O = w[E], j = w[i]; g !== null ? (b.push({ x: O.x, y: g }), b.push({ x: j.x, y: g })) : d !== null && (b.push({ x: d, y: O.y }), b.push({ x: d, y: j.y })); }), b; } function wy(m, a, d) { for (; a > m; a--) { const g = d[a]; if (!isNaN(g.x) && !isNaN(g.y)) break; } return a; } function $1(m, a, d, g) { return m && a ? g(m[d], a[d]) : m ? m[d] : a ? a[d] : 0; } function dw(m, a) { let d = [], g = !1; return hs(m) ? (g = !0, d = m) : d = vA(m, a), d.length ? new zc({ points: d, options: { tension: 0 }, _loop: g, _fullLoop: g }) : null; } function X1(m) { return m && m.fill !== !1; } function bA(m, a, d) { let w = m[a].fill; const b = [ a ]; let E; if (!d) return w; for (; w !== !1 && b.indexOf(w) === -1; ) { if (!As(w)) return w; if (E = m[w], !E) return !1; if (E.visible) return w; b.push(w), w = E.fill; } return !1; } function wA(m, a, d) { const g = EA(m); if (yn(g)) return isNaN(g.value) ? !1 : g; let w = parseFloat(g); return As(w) && Math.floor(w) === w ? TA(g[0], a, w, d) : [ "origin", "start", "end", "stack", "shape" ].indexOf(g) >= 0 && g; } function TA(m, a, d, g) { return (m === "-" || m === "+") && (d = a + d), d === a || d < 0 || d >= g ? !1 : d; } function MA(m, a) { let d = null; return m === "start" ? d = a.bottom : m === "end" ? d = a.top : yn(m) ? d = a.getPixelForValue(m.value) : a.getBasePixel && (d = a.getBasePixel()), d; } function SA(m, a, d) { let g; return m === "start" ? g = d : m === "end" ? g = a.options.reverse ? a.min : a.max : yn(m) ? g = m.value : g = a.getBaseValue(), g; } function EA(m) { const a = m.options, d = a.fill; let g = en(d && d.target, d); return g === void 0 && (g = !!a.backgroundColor), g === !1 || g === null ? !1 : g === !0 ? "origin" : g; } function PA(m) { const { scale: a, index: d, line: g } = m, w = [], b = g.segments, E = g.points, i = AA(a, d); i.push(dw({ x: null, y: a.bottom }, g)); for (let O = 0; O < b.length; O++) { const j = b[O]; for (let Y = j.start; Y <= j.end; Y++) CA(w, E[Y], i); } return new zc({ points: w, options: {} }); } function AA(m, a) { const d = [], g = m.getMatchingVisibleMetas("line"); for (let w = 0; w < g.length; w++) { const b = g[w]; if (b.index === a) break; b.hidden || d.unshift(b.dataset); } return d; } function CA(m, a, d) { const g = []; for (let w = 0; w < d.length; w++) { const b = d[w], { first: E, last: i, point: O } = IA(b, a, "x"); if (!(!O || E && i)) { if (E) g.unshift(O); else if (m.push(O), !i) break; } } m.push(...g); } function IA(m, a, d) { const g = m.interpolate(a, d); if (!g) return {}; const w = g[d], b = m.segments, E = m.points; let i = !1, O = !1; for (let j = 0; j < b.length; j++) { const Y = b[j], J = E[Y.start][d], ae = E[Y.end][d]; if (Nl(w, J, ae)) { i = w === J, O = w === ae; break; } } return { first: i, last: O, point: g }; } class fw { constructor(a) { this.x = a.x, this.y = a.y, this.radius = a.radius; } pathSegment(a, d, g) { const { x: w, y: b, radius: E } = this; return d = d || { start: 0, end: us }, a.arc(w, b, E, d.end, d.start, !0), !g.bounds; } interpolate(a) { const { x: d, y: g, radius: w } = this, b = a.angle; return { x: d + Math.cos(b) * w, y: g + Math.sin(b) * w, angle: b }; } } function LA(m) { const { chart: a, fill: d, line: g } = m; if (As(d)) return zA(a, d); if (d === "stack") return PA(m); if (d === "shape") return !0; const w = DA(m); return w instanceof fw ? w : dw(w, g); } function zA(m, a) { const d = m.getDatasetMeta(a); return d && m.isDatasetVisible(a) ? d.dataset : null; } function DA(m) { return (m.scale || {}).getPointPositionForValue ? RA(m) : kA(m); } function kA(m) { const { scale: a = {}, fill: d } = m, g = MA(d, a); if (As(g)) { const w = a.isHorizontal(); return { x: w ? g : null, y: w ? null : g }; } return null; } function RA(m) { const { scale: a, fill: d } = m, g = a.options, w = a.getLabels().length, b = g.reverse ? a.max : a.min, E = SA(d, a, b), i = []; if (g.grid.circular) { const O = a.getPointPositionForValue(0, b); return new fw({ x: O.x, y: O.y, radius: a.getDistanceFromCenterForValue(E) }); } for (let O = 0; O < w; ++O) i.push(a.getPointPositionForValue(O, E)); return i; } function jg(m, a, d) { const g = LA(a), { line: w, scale: b, axis: E } = a, i = w.options, O = i.fill, j = i.backgroundColor, { above: Y = j, below: J = j } = O || {}; g && w.points.length && (Wm(m, d), OA(m, { line: w, target: g, above: Y, below: J, area: d, scale: b, axis: E }), $m(m)); } function OA(m, a) { const { line: d, target: g, above: w, below: b, area: E, scale: i } = a, O = d._loop ? "angle" : a.axis; m.save(), O === "x" && b !== w && (Y1(m, g, E.top), K1(m, { line: d, target: g, color: w, scale: i, property: O }), m.restore(), m.save(), Y1(m, g, E.bottom)), K1(m, { line: d, target: g, color: b, scale: i, property: O }), m.restore(); } function Y1(m, a, d) { const { segments: g, points: w } = a; let b = !0, E = !1; m.beginPath(); for (const i of g) { const { start: O, end: j } = i, Y = w[O], J = w[wy(O, j, w)]; b ? (m.moveTo(Y.x, Y.y), b = !1) : (m.lineTo(Y.x, d), m.lineTo(Y.x, Y.y)), E = !!a.pathSegment(m, i, { move: E }), E ? m.closePath() : m.lineTo(J.x, d); } m.lineTo(a.first().x, d), m.closePath(), m.clip(); } function K1(m, a) { const { line: d, target: g, property: w, color: b, scale: E } = a, i = xA(d, g, w); for (const { source: O, target: j, start: Y, end: J } of i) { const { style: { backgroundColor: ae = b } = {} } = O, ce = g !== !0; m.save(), m.fillStyle = ae, FA(m, E, ce && Jg(w, Y, J)), m.beginPath(); const Te = !!d.pathSegment(m, O); let be; if (ce) { Te ? m.closePath() : J1(m, g, J, w); const Ze = !!g.pathSegment(m, j, { move: Te, reverse: !0 }); be = Te && Ze, be || J1(m, g, Y, w); } m.closePath(), m.fill(be ? "evenodd" : "nonzero"), m.restore(); } } function FA(m, a, d) { const { top: g, bottom: w } = a.chart.chartArea, { property: b, start: E, end: i } = d || {}; b === "x" && (m.beginPath(), m.rect(E, g, i - E, w - g), m.clip()); } function J1(m, a, d, g) { const w = a.interpolate(d, g); w && m.lineTo(w.x, w.y); } var BA = { id: "filler", afterDatasetsUpdate(m, a, d) { const g = (m.data.datasets || []).length, w = []; let b, E, i, O; for (E = 0; E < g; ++E) b = m.getDatasetMeta(E), i = b.dataset, O = null, i && i.options && i instanceof zc && (O = { visible: m.isDatasetVisible(E), index: E, fill: wA(i, E, g), chart: m, axis: b.controller.options.indexAxis, scale: b.vScale, line: i }), b.$filler = O, w.push(O); for (E = 0; E < g; ++E) O = w[E], !(!O || O.fill === !1) && (O.fill = bA(w, E, d.propagate)); }, beforeDraw(m, a, d) { const g = d.drawTime === "beforeDraw", w = m.getSortedVisibleDatasetMetas(), b = m.chartArea; for (let E = w.length - 1; E >= 0; --E) { const i = w[E].$filler; i && (i.line.updateControlPoints(b, i.axis), g && i.fill && jg(m.ctx, i, b)); } }, beforeDatasetsDraw(m, a, d) { if (d.drawTime !== "beforeDatasetsDraw") return; const g = m.getSortedVisibleDatasetMetas(); for (let w = g.length - 1; w >= 0; --w) { const b = g[w].$filler; X1(b) && jg(m.ctx, b, m.chartArea); } }, beforeDatasetDraw(m, a, d) { const g = a.meta.$filler; !X1(g) || d.drawTime !== "beforeDatasetDraw" || jg(m.ctx, g, m.chartArea); }, defaults: { propagate: !0, drawTime: "beforeDatasetDraw" } }; const Q1 = (m, a) => { let { boxHeight: d = a, boxWidth: g = a } = m; return m.usePointStyle && (d = Math.min(d, a), g = m.pointStyleWidth || Math.min(g, a)), { boxWidth: g, boxHeight: d, itemHeight: Math.max(a, d) }; }, NA = (m, a) => m !== null && a !== null && m.datasetIndex === a.datasetIndex && m.index === a.index; class eb extends jl { constructor(a) { super(), this._added = !1, this.legendHitBoxes = [], this._hoveredItem = null, this.doughnutMode = !1, this.chart = a.chart, this.options = a.options, this.ctx = a.ctx, this.legendItems = void 0, this.columnSizes = void 0, this.lineWidths = void 0, this.maxHeight = void 0, this.maxWidth = void 0, this.top = void 0, this.bottom = void 0, this.left = void 0, this.right = void 0, this.height = void 0, this.width = void 0, this._margins = void 0, this.position = void 0, this.weight = void 0, this.fullSize = void 0; } update(a, d, g) { this.maxWidth = a, this.maxHeight = d, this._margins = g, this.setDimensions(), this.buildLabels(), this.fit(); } setDimensions() { this.isHorizontal() ? (this.width = this.maxWidth, this.left = this._margins.left, this.right = this.width) : (this.height = this.maxHeight, this.top = this._margins.top, this.bottom = this.height); } buildLabels() { const a = this.options.labels || {}; let d = is(a.generateLabels, [ this.chart ], this) || []; a.filter && (d = d.filter((g) => a.filter(g, this.chart.data))), a.sort && (d = d.sort((g, w) => a.sort(g, w, this.chart.data))), this.options.reverse && d.reverse(), this.legendItems = d; } fit() { const { options: a, ctx: d } = this; if (!a.display) { this.width = this.height = 0; return; } const g = a.labels, w = ir(g.font), b = w.size, E = this._computeTitleHeight(), { boxWidth: i, itemHeight: O } = Q1(g, b); let j, Y; d.font = w.string, this.isHorizontal() ? (j = this.maxWidth, Y = this._fitRows(E, b, i, O) + 10) : (Y = this.maxHeight, j = this._fitCols(E, w, i, O) + 10), this.width = Math.min(j, a.maxWidth || this.maxWidth), this.height = Math.min(Y, a.maxHeight || this.maxHeight); } _fitRows(a, d, g, w) { const { ctx: b, maxWidth: E, options: { labels: { padding: i } } } = this, O = this.legendHitBoxes = [], j = this.lineWidths = [ 0 ], Y = w + i; let J = a; b.textAlign = "left", b.textBaseline = "middle"; let ae = -1, ce = -Y; return this.legendItems.forEach((Te, be) => { const Ze = g + d / 2 + b.measureText(Te.text).width; (be === 0 || j[j.length - 1] + Ze + 2 * i > E) && (J += Y, j[j.length - (be > 0 ? 0 : 1)] = 0, ce += Y, ae++), O[be] = { left: 0, top: ce, row: ae, width: Ze, height: w }, j[j.length - 1] += Ze + i; }), J; } _fitCols(a, d, g, w) { const { ctx: b, maxHeight: E, options: { labels: { padding: i } } } = this, O = this.legendHitBoxes = [], j = this.columnSizes = [], Y = E - a; let J = i, ae = 0, ce = 0, Te = 0, be = 0; return this.legendItems.forEach((Ze, je) => { const { itemWidth: ot, itemHeight: vt } = VA(g, d, b, Ze, w); je > 0 && ce + vt + 2 * i > Y && (J += ae + i, j.push({ width: ae, height: ce }), Te += ae + i, be++, ae = ce = 0), O[je] = { left: Te, top: ce, col: be, width: ot, height: vt }, ae = Math.max(ae, ot), ce += vt + i; }), J += ae, j.push({ width: ae, height: ce }), J; } adjustHitBoxes() { if (!this.options.display) return; const a = this._computeTitleHeight(), { legendHitBoxes: d, options: { align: g, labels: { padding: w }, rtl: b } } = this, E = $u(b, this.left, this.width); if (this.isHorizontal()) { let i = 0, O = Ur(g, this.left + w, this.right - this.lineWidths[i]); for (const j of d) i !== j.row && (i = j.row, O = Ur(g, this.left + w, this.right - this.lineWidths[i])), j.top += this.top + a + w, j.left = E.leftForLtr(E.x(O), j.width), O += j.width + w; } else { let i = 0, O = Ur(g, this.top + a + w, this.bottom - this.columnSizes[i].height); for (const j of d) j.col !== i && (i = j.col, O = Ur(g, this.top + a + w, this.bottom - this.columnSizes[i].height)), j.top = O, j.left += this.left + w, j.left = E.leftForLtr(E.x(j.left), j.width), O += j.height + w; } } isHorizontal() { return this.options.position === "top" || this.options.position === "bottom"; } draw() { if (this.options.display) { const a = this.ctx; Wm(a, this), this._draw(), $m(a); } } _draw() { const { options: a, columnSizes: d, lineWidths: g, ctx: w } = this, { align: b, labels: E } = a, i = ys.color, O = $u(a.rtl, this.left, this.width), j = ir(E.font), { padding: Y } = E, J = j.size, ae = J / 2; let ce; this.drawTitle(), w.textAlign = O.textAlign("left"), w.textBaseline = "middle", w.lineWidth = 0.5, w.font = j.string; const { boxWidth: Te, boxHeight: be, itemHeight: Ze } = Q1(E, J), je = function(Vt, pt, Gt) { if (isNaN(Te) || Te <= 0 || isNaN(be) || be < 0) return; w.save(); const ui = en(Gt.lineWidth, 1); if (w.fillStyle = en(Gt.fillStyle, i), w.lineCap = en(Gt.lineCap, "butt"), w.lineDashOffset = en(Gt.lineDashOffset, 0), w.lineJoin = en(Gt.lineJoin, "miter"), w.lineWidth = ui, w.strokeStyle = en(Gt.strokeStyle, i), w.setLineDash(en(Gt.lineDash, [])), E.usePointStyle) { const kt = { radius: be * Math.SQRT2 / 2, pointStyle: Gt.pointStyle, rotation: Gt.rotation, borderWidth: ui }, Pt = O.xPlus(Vt, Te / 2), Mi = pt + ae; Rb(w, kt, Pt, Mi, E.pointStyleWidth && Te); } else { const kt = pt + Math.max((J - be) / 2, 0), Pt = O.leftForLtr(Vt, Te), Mi = kh(Gt.borderRadius); w.beginPath(), Object.values(Mi).some((Pn) => Pn !== 0) ? Bf(w, { x: Pt, y: kt, w: Te, h: be, radius: Mi }) : w.rect(Pt, kt, Te, be), w.fill(), ui !== 0 && w.stroke(); } w.restore(); }, ot = function(Vt, pt, Gt) { Fh(w, Gt.text, Vt, pt + Ze / 2, j, { strikethrough: Gt.hidden, textAlign: O.textAlign(Gt.textAlign) }); }, vt = this.isHorizontal(), ht = this._computeTitleHeight(); vt ? ce = { x: Ur(b, this.left + Y, this.right - g[0]), y: this.top + Y + ht, line: 0 } : ce = { x: this.left + Y, y: Ur(b, this.top + ht + Y, this.bottom - d[0].height), line: 0 }, Gb(this.ctx, a.textDirection); const gt = Ze + Y; this.legendItems.forEach((Vt, pt) => { w.strokeStyle = Vt.fontColor, w.fillStyle = Vt.fontColor; const Gt = w.measureText(Vt.text).width, ui = O.textAlign(Vt.textAlign || (Vt.textAlign = E.textAlign)), kt = Te + ae + Gt; let Pt = ce.x, Mi = ce.y; O.setWidth(this.width), vt ? pt > 0 && Pt + kt + Y > this.right && (Mi = ce.y += gt, ce.line++, Pt = ce.x = Ur(b, this.left + Y, this.right - g[ce.line])) : pt > 0 && Mi + gt > this.bottom && (Pt = ce.x = Pt + d[ce.line].width + Y, ce.line++, Mi = ce.y = Ur(b, this.top + ht + Y, this.bottom - d[ce.line].height)); const Pn = O.x(Pt); if (je(Pn, Mi, Vt), Pt = oS(ui, Pt + Te + ae, vt ? Pt + kt : this.right, a.rtl), ot(O.x(Pt), Mi, Vt), vt) ce.x += kt + Y; else if (typeof Vt.text != "string") { const hn = j.lineHeight; ce.y += pw(Vt, hn) + Y; } else ce.y += gt; }), Zb(this.ctx, a.textDirection); } drawTitle() { const a = this.options, d = a.title, g = ir(d.font), w = Gr(d.padding); if (!d.display) return; const b = $u(a.rtl, this.left, this.width), E = this.ctx, i = d.position, O = g.size / 2, j = w.top + O; let Y, J = this.left, ae = this.width; if (this.isHorizontal()) ae = Math.max(...this.lineWidths), Y = this.top + j, J = Ur(a.align, J, this.right - ae); else { const Te = this.columnSizes.reduce((be, Ze) => Math.max(be, Ze.height), 0); Y = j + Ur(a.align, this.top, this.bottom - Te - a.labels.padding - this._computeTitleHeight()); } const ce = Ur(i, J, J + ae); E.textAlign = b.textAlign(fy(i)), E.textBaseline = "middle", E.strokeStyle = d.color, E.fillStyle = d.color, E.font = g.string, Fh(E, d.text, ce, Y, g); } _computeTitleHeight() { const a = this.options.title, d = ir(a.font), g = Gr(a.padding); return a.display ? d.lineHeight + g.height : 0; } _getLegendItemAt(a, d) { let g, w, b; if (Nl(a, this.left, this.right) && Nl(d, this.top, this.bottom)) { for (b = this.legendHitBoxes, g = 0; g < b.length; ++g) if (w = b[g], Nl(a, w.left, w.left + w.width) && Nl(d, w.top, w.top + w.height)) return this.legendItems[g]; } return null; } handleEvent(a) { const d = this.options; if (!GA(a.type, d)) return; const g = this._getLegendItemAt(a.x, a.y); if (a.type === "mousemove" || a.type === "mouseout") { const w = this._hoveredItem, b = NA(w, g); w && !b && is(d.onLeave, [ a, w, this ], this), this._hoveredItem = g, g && !b && is(d.onHover, [ a, g, this ], this); } else g && is(d.onClick, [ a, g, this ], this); } } function VA(m, a, d, g, w) { const b = UA(g, m, a, d), E = jA(w, g, a.lineHeight); return { itemWidth: b, itemHeight: E }; } function UA(m, a, d, g) { let w = m.text; return w && typeof w != "string" && (w = w.reduce((b, E) => b.length > E.length ? b : E)), a + d.size / 2 + g.measureText(w).width; } function jA(m, a, d) { let g = m; return typeof a.text != "string" && (g = pw(a, d)), g; } function pw(m, a) { const d = m.text ? m.text.length : 0; return a * d; } function GA(m, a) { return !!((m === "mousemove" || m === "mouseout") && (a.onHover || a.onLeave) || a.onClick && (m === "click" || m === "mouseup")); } var ZA = { id: "legend", _element: eb, start(m, a, d) { const g = m.legend = new eb({ ctx: m.ctx, options: d, chart: m }); jr.configure(m, g, d), jr.addBox(m, g); }, stop(m) { jr.removeBox(m, m.legend), delete m.legend; }, beforeUpdate(m, a, d) { const g = m.legend; jr.configure(m, g, d), g.options = d; }, afterUpdate(m) { const a = m.legend; a.buildLabels(), a.adjustHitBoxes(); }, afterEvent(m, a) { a.replay || m.legend.handleEvent(a.event); }, defaults: { display: !0, position: "top", align: "center", fullSize: !0, reverse: !1, weight: 1e3, onClick(m, a, d) { const g = a.datasetIndex, w = d.chart; w.isDatasetVisible(g) ? (w.hide(g), a.hidden = !0) : (w.show(g), a.hidden = !1); }, onHover: null, onLeave: null, labels: { color: (m) => m.chart.options.color, boxWidth: 40, padding: 10, generateLabels(m) { const a = m.data.datasets, { labels: { usePointStyle: d, pointStyle: g, textAlign: w, color: b, useBorderRadius: E, borderRadius: i } } = m.legend.options; return m._getSortedDatasetMetas().map((O) => { const j = O.controller.getStyle(d ? 0 : void 0), Y = Gr(j.borderWidth); return { text: a[O.index].label, fillStyle: j.backgroundColor, fontColor: b, hidden: !O.visible, lineCap: j.borderCapStyle, lineDash: j.borderDash, lineDashOffset: j.borderDashOffset, lineJoin: j.borderJoinStyle, lineWidth: (Y.width + Y.height) / 4, strokeStyle: j.borderColor, pointStyle: g || j.pointStyle, rotation: j.rotation, textAlign: w || j.textAlign, borderRadius: E && (i || j.borderRadius), datasetIndex: O.index }; }, this); } }, title: { color: (m) => m.chart.options.color, display: !1, position: "center", text: "" } }, descriptors: { _scriptable: (m) => !m.startsWith("on"), labels: { _scriptable: (m) => ![ "generateLabels", "filter", "sort" ].includes(m) } } }; class Ty extends jl { constructor(a) { super(), this.chart = a.chart, this.options = a.options, this.ctx = a.ctx, this._padding = void 0, this.top = void 0, this.bottom = void 0, this.left = void 0, this.right = void 0, this.width = void 0, this.height = void 0, this.position = void 0, this.weight = void 0, this.fullSize = void 0; } update(a, d) { const g = this.options; if (this.left = 0, this.top = 0, !g.display) { this.width = this.height = this.right = this.bottom = 0; return; } this.width = this.right = a, this.height = this.bottom = d; const w = hs(g.text) ? g.text.length : 1; this._padding = Gr(g.padding); const b = w * ir(g.font).lineHeight + this._padding.height; this.isHorizontal() ? this.height = b : this.width = b; } isHorizontal() { const a = this.options.position; return a === "top" || a === "bottom"; } _drawArgs(a) { const { top: d, left: g, bottom: w, right: b, options: E } = this, i = E.align; let O = 0, j, Y, J; return this.isHorizontal() ? (Y = Ur(i, g, b), J = d + a, j = b - g) : (E.position === "left" ? (Y = g + a, J = Ur(i, w, d), O = ds * -0.5) : (Y = b - a, J = Ur(i, d, w), O = ds * 0.5), j = w - d), { titleX: Y, titleY: J, maxWidth: j, rotation: O }; } draw() { const a = this.ctx, d = this.options; if (!d.display) return; const g = ir(d.font), b = g.lineHeight / 2 + this._padding.top, { titleX: E, titleY: i, maxWidth: O, rotation: j } = this._drawArgs(b); Fh(a, d.text, 0, 0, g, { color: d.color, maxWidth: O, rotation: j, textAlign: fy(d.align), textBaseline: "middle", translation: [ E, i ] }); } } function HA(m, a) { const d = new Ty({ ctx: m.ctx, options: a, chart: m }); jr.configure(m, d, a), jr.addBox(m, d), m.titleBlock = d; } var qA = { id: "title", _element: Ty, start(m, a, d) { HA(m, d); }, stop(m) { const a = m.titleBlock; jr.removeBox(m, a), delete m.titleBlock; }, beforeUpdate(m, a, d) { const g = m.titleBlock; jr.configure(m, g, d), g.options = d; }, defaults: { align: "center", display: !1, font: { weight: "bold" }, fullSize: !0, padding: 10, position: "top", text: "", weight: 2e3 }, defaultRoutes: { color: "color" }, descriptors: { _scriptable: !0, _indexable: !1 } }; const wm = /* @__PURE__ */ new WeakMap(); var WA = { id: "subtitle", start(m, a, d) { const g = new Ty({ ctx: m.ctx, options: d, chart: m }); jr.configure(m, g, d), jr.addBox(m, g), wm.set(m, g); }, stop(m) { jr.removeBox(m, wm.get(m)), wm.delete(m); }, beforeUpdate(m, a, d) { const g = wm.get(m); jr.configure(m, g, d), g.options = d; }, defaults: { align: "center", display: !1, font: { weight: "normal" }, fullSize: !0, padding: 0, position: "top", text: "", weight: 1500 }, defaultRoutes: { color: "color" }, descriptors: { _scriptable: !0, _indexable: !1 } }; const Ef = { average(m) { if (!m.length) return !1; let a, d, g = /* @__PURE__ */ new Set(), w = 0, b = 0; for (a = 0, d = m.length; a < d; ++a) { const i = m[a].element; if (i && i.hasValue()) { const O = i.tooltipPosition(); g.add(O.x), w += O.y, ++b; } } return b === 0 || g.size === 0 ? !1 : { x: [ ...g ].reduce((i, O) => i + O) / g.size, y: w / b }; }, nearest(m, a) { if (!m.length) return !1; let d = a.x, g = a.y, w = Number.POSITIVE_INFINITY, b, E, i; for (b = 0, E = m.length; b < E; ++b) { const O = m[b].element; if (O && O.hasValue()) { const j = O.getCenterPoint(), Y = Zg(a, j); Y < w && (w = Y, i = O); } } if (i) { const O = i.tooltipPosition(); d = O.x, g = O.y; } return { x: d, y: g }; } }; function ol(m, a) { return a && (hs(a) ? Array.prototype.push.apply(m, a) : m.push(a)), m; } function Ol(m) { return (typeof m == "string" || m instanceof String) && m.indexOf(` `) > -1 ? m.split(` `) : m; } function $A(m, a) { const { element: d, datasetIndex: g, index: w } = a, b = m.getDatasetMeta(g).controller, { label: E, value: i } = b.getLabelAndValue(w); return { chart: m, label: E, parsed: b.getParsed(w), raw: m.data.datasets[g].data[w], formattedValue: i, dataset: b.getDataset(), dataIndex: w, datasetIndex: g, element: d }; } function tb(m, a) { const d = m.chart.ctx, { body: g, footer: w, title: b } = m, { boxWidth: E, boxHeight: i } = a, O = ir(a.bodyFont), j = ir(a.titleFont), Y = ir(a.footerFont), J = b.length, ae = w.length, ce = g.length, Te = Gr(a.padding); let be = Te.height, Ze = 0, je = g.reduce((ht, gt) => ht + gt.before.length + gt.lines.length + gt.after.length, 0); if (je += m.beforeBody.length + m.afterBody.length, J && (be += J * j.lineHeight + (J - 1) * a.titleSpacing + a.titleMarginBottom), je) { const ht = a.displayColors ? Math.max(i, O.lineHeight) : O.lineHeight; be += ce * ht + (je - ce) * O.lineHeight + (je - 1) * a.bodySpacing; } ae && (be += a.footerMarginTop + ae * Y.lineHeight + (ae - 1) * a.footerSpacing); let ot = 0; const vt = function(ht) { Ze = Math.max(Ze, d.measureText(ht).width + ot); }; return d.save(), d.font = j.string, Zn(m.title, vt), d.font = O.string, Zn(m.beforeBody.concat(m.afterBody), vt), ot = a.displayColors ? E + 2 + a.boxPadding : 0, Zn(g, (ht) => { Zn(ht.before, vt), Zn(ht.lines, vt), Zn(ht.after, vt); }), ot = 0, d.font = Y.string, Zn(m.footer, vt), d.restore(), Ze += Te.width, { width: Ze, height: be }; } function XA(m, a) { const { y: d, height: g } = a; return d < g / 2 ? "top" : d > m.height - g / 2 ? "bottom" : "center"; } function YA(m, a, d, g) { const { x: w, width: b } = g, E = d.caretSize + d.caretPadding; if (m === "left" && w + b + E > a.width || m === "right" && w - b - E < 0) return !0; } function KA(m, a, d, g) { const { x: w, width: b } = d, { width: E, chartArea: { left: i, right: O } } = m; let j = "center"; return g === "center" ? j = w <= (i + O) / 2 ? "left" : "right" : w <= b / 2 ? j = "left" : w >= E - b / 2 && (j = "right"), YA(j, m, a, d) && (j = "center"), j; } function ib(m, a, d) { const g = d.yAlign || a.yAlign || XA(m, d); return { xAlign: d.xAlign || a.xAlign || KA(m, a, d, g), yAlign: g }; } function JA(m, a) { let { x: d, width: g } = m; return a === "right" ? d -= g : a === "center" && (d -= g / 2), d; } function QA(m, a, d) { let { y: g, height: w } = m; return a === "top" ? g += d : a === "bottom" ? g -= w + d : g -= w / 2, g; } function nb(m, a, d, g) { const { caretSize: w, caretPadding: b, cornerRadius: E } = m, { xAlign: i, yAlign: O } = d, j = w + b, { topLeft: Y, topRight: J, bottomLeft: ae, bottomRight: ce } = kh(E); let Te = JA(a, i); const be = QA(a, O, j); return O === "center" ? i === "left" ? Te += j : i === "right" && (Te -= j) : i === "left" ? Te -= Math.max(Y, ae) + w : i === "right" && (Te += Math.max(J, ce) + w), { x: gr(Te, 0, g.width - a.width), y: gr(be, 0, g.height - a.height) }; } function Tm(m, a, d) { const g = Gr(d.padding); return a === "center" ? m.x + m.width / 2 : a === "right" ? m.x + m.width - g.right : m.x + g.left; } function sb(m) { return ol([], Ol(m)); } function eC(m, a, d) { return Fc(m, { tooltip: a, tooltipItems: d, type: "tooltip" }); } function rb(m, a) { const d = a && a.dataset && a.dataset.tooltip && a.dataset.tooltip.callbacks; return d ? m.override(d) : m; } const mw = { beforeTitle: kl, title(m) { if (m.length > 0) { const a = m[0], d = a.chart.data.labels, g = d ? d.length : 0; if (this && this.options && this.options.mode === "dataset") return a.dataset.label || ""; if (a.label) return a.label; if (g > 0 && a.dataIndex < g) return d[a.dataIndex]; } return ""; }, afterTitle: kl, beforeBody: kl, beforeLabel: kl, label(m) { if (this && this.options && this.options.mode === "dataset") return m.label + ": " + m.formattedValue || m.formattedValue; let a = m.dataset.label || ""; a && (a += ": "); const d = m.formattedValue; return En(d) || (a += d), a; }, labelColor(m) { const d = m.chart.getDatasetMeta(m.datasetIndex).controller.getStyle(m.dataIndex); return { borderColor: d.borderColor, backgroundColor: d.backgroundColor, borderWidth: d.borderWidth, borderDash: d.borderDash, borderDashOffset: d.borderDashOffset, borderRadius: 0 }; }, labelTextColor() { return this.options.bodyColor; }, labelPointStyle(m) { const d = m.chart.getDatasetMeta(m.datasetIndex).controller.getStyle(m.dataIndex); return { pointStyle: d.pointStyle, rotation: d.rotation }; }, afterLabel: kl, afterBody: kl, beforeFooter: kl, footer: kl, afterFooter: kl }; function mo(m, a, d, g) { const w = m[a].call(d, g); return typeof w > "u" ? mw[a].call(d, g) : w; } class Qg extends jl { constructor(a) { super(), this.opacity = 0, this._active = [], this._eventPosition = void 0, this._size = void 0, this._cachedAnimations = void 0, this._tooltipItems = [], this.$animations = void 0, this.$context = void 0, this.chart = a.chart, this.options = a.options, this.dataPoints = void 0, this.title = void 0, this.beforeBody = void 0, this.body = void 0, this.afterBody = void 0, this.footer = void 0, this.xAlign = void 0, this.yAlign = void 0, this.x = void 0, this.y = void 0, this.height = void 0, this.width = void 0, this.caretX = void 0, this.caretY = void 0, this.labelColors = void 0, this.labelPointStyles = void 0, this.labelTextColors = void 0; } initialize(a) { this.options = a, this._cachedAnimations = void 0, this.$context = void 0; } _resolveAnimations() { const a = this._cachedAnimations; if (a) return a; const d = this.chart, g = this.options.setContext(this.getContext()), w = g.enabled && d.options.animation && g.animations, b = new $b(this.chart, w); return w._cacheable && (this._cachedAnimations = Object.freeze(b)), b; } getContext() { return this.$context || (this.$context = eC(this.chart.getContext(), this, this._tooltipItems)); } getTitle(a, d) { const { callbacks: g } = d, w = mo(g, "beforeTitle", this, a), b = mo(g, "title", this, a), E = mo(g, "afterTitle", this, a); let i = []; return i = ol(i, Ol(w)), i = ol(i, Ol(b)), i = ol(i, Ol(E)), i; } getBeforeBody(a, d) { return sb(mo(d.callbacks, "beforeBody", this, a)); } getBody(a, d) { const { callbacks: g } = d, w = []; return Zn(a, (b) => { const E = { before: [], lines: [], after: [] }, i = rb(g, b); ol(E.before, Ol(mo(i, "beforeLabel", this, b))), ol(E.lines, mo(i, "label", this, b)), ol(E.after, Ol(mo(i, "afterLabel", this, b))), w.push(E); }), w; } getAfterBody(a, d) { return sb(mo(d.callbacks, "afterBody", this, a)); } getFooter(a, d) { const { callbacks: g } = d, w = mo(g, "beforeFooter", this, a), b = mo(g, "footer", this, a), E = mo(g, "afterFooter", this, a); let i = []; return i = ol(i, Ol(w)), i = ol(i, Ol(b)), i = ol(i, Ol(E)), i; } _createItems(a) { const d = this._active, g = this.chart.data, w = [], b = [], E = []; let i = [], O, j; for (O = 0, j = d.length; O < j; ++O) i.push($A(this.chart, d[O])); return a.filter && (i = i.filter((Y, J, ae) => a.filter(Y, J, ae, g))), a.itemSort && (i = i.sort((Y, J) => a.itemSort(Y, J, g))), Zn(i, (Y) => { const J = rb(a.callbacks, Y); w.push(mo(J, "labelColor", this, Y)), b.push(mo(J, "labelPointStyle", this, Y)), E.push(mo(J, "labelTextColor", this, Y)); }), this.labelColors = w, this.labelPointStyles = b, this.labelTextColors = E, this.dataPoints = i, i; } update(a, d) { const g = this.options.setContext(this.getContext()), w = this._active; let b, E = []; if (!w.length) this.opacity !== 0 && (b = { opacity: 0 }); else { const i = Ef[g.position].call(this, w, this._eventPosition); E = this._createItems(g), this.title = this.getTitle(E, g), this.beforeBody = this.getBeforeBody(E, g), this.body = this.getBody(E, g), this.afterBody = this.getAfterBody(E, g), this.footer = this.getFooter(E, g); const O = this._size = tb(this, g), j = Object.assign({}, i, O), Y = ib(this.chart, g, j), J = nb(g, j, Y, this.chart); this.xAlign = Y.xAlign, this.yAlign = Y.yAlign, b = { opacity: 1, x: J.x, y: J.y, width: O.width, height: O.height, caretX: i.x, caretY: i.y }; } this._tooltipItems = E, this.$context = void 0, b && this._resolveAnimations().update(this, b), a && g.external && g.external.call(this, { chart: this.chart, tooltip: this, replay: d }); } drawCaret(a, d, g, w) { const b = this.getCaretPosition(a, g, w); d.lineTo(b.x1, b.y1), d.lineTo(b.x2, b.y2), d.lineTo(b.x3, b.y3); } getCaretPosition(a, d, g) { const { xAlign: w, yAlign: b } = this, { caretSize: E, cornerRadius: i } = g, { topLeft: O, topRight: j, bottomLeft: Y, bottomRight: J } = kh(i), { x: ae, y: ce } = a, { width: Te, height: be } = d; let Ze, je, ot, vt, ht, gt; return b === "center" ? (ht = ce + be / 2, w === "left" ? (Ze = ae, je = Ze - E, vt = ht + E, gt = ht - E) : (Ze = ae + Te, je = Ze + E, vt = ht - E, gt = ht + E), ot = Ze) : (w === "left" ? je = ae + Math.max(O, Y) + E : w === "right" ? je = ae + Te - Math.max(j, J) - E : je = this.caretX, b === "top" ? (vt = ce, ht = vt - E, Ze = je - E, ot = je + E) : (vt = ce + be, ht = vt + E, Ze = je + E, ot = je - E), gt = vt), { x1: Ze, x2: je, x3: ot, y1: vt, y2: ht, y3: gt }; } drawTitle(a, d, g) { const w = this.title, b = w.length; let E, i, O; if (b) { const j = $u(g.rtl, this.x, this.width); for (a.x = Tm(this, g.titleAlign, g), d.textAlign = j.textAlign(g.titleAlign), d.textBaseline = "middle", E = ir(g.titleFont), i = g.titleSpacing, d.fillStyle = g.titleColor, d.font = E.string, O = 0; O < b; ++O) d.fillText(w[O], j.x(a.x), a.y + E.lineHeight / 2), a.y += E.lineHeight + i, O + 1 === b && (a.y += g.titleMarginBottom - i); } } _drawColorBox(a, d, g, w, b) { const E = this.labelColors[g], i = this.labelPointStyles[g], { boxHeight: O, boxWidth: j } = b, Y = ir(b.bodyFont), J = Tm(this, "left", b), ae = w.x(J), ce = O < Y.lineHeight ? (Y.lineHeight - O) / 2 : 0, Te = d.y + ce; if (b.usePointStyle) { const be = { radius: Math.min(j, O) / 2, pointStyle: i.pointStyle, rotation: i.rotation, borderWidth: 1 }, Ze = w.leftForLtr(ae, j) + j / 2, je = Te + O / 2; a.strokeStyle = b.multiKeyBackground, a.fillStyle = b.multiKeyBackground, qg(a, be, Ze, je), a.strokeStyle = E.borderColor, a.fillStyle = E.backgroundColor, qg(a, be, Ze, je); } else { a.lineWidth = yn(E.borderWidth) ? Math.max(...Object.values(E.borderWidth)) : E.borderWidth || 1, a.strokeStyle = E.borderColor, a.setLineDash(E.borderDash || []), a.lineDashOffset = E.borderDashOffset || 0; const be = w.leftForLtr(ae, j), Ze = w.leftForLtr(w.xPlus(ae, 1), j - 2), je = kh(E.borderRadius); Object.values(je).some((ot) => ot !== 0) ? (a.beginPath(), a.fillStyle = b.multiKeyBackground, Bf(a, { x: be, y: Te, w: j, h: O, radius: je }), a.fill(), a.stroke(), a.fillStyle = E.backgroundColor, a.beginPath(), Bf(a, { x: Ze, y: Te + 1, w: j - 2, h: O - 2, radius: je }), a.fill()) : (a.fillStyle = b.multiKeyBackground, a.fillRect(be, Te, j, O), a.strokeRect(be, Te, j, O), a.fillStyle = E.backgroundColor, a.fillRect(Ze, Te + 1, j - 2, O - 2)); } a.fillStyle = this.labelTextColors[g]; } drawBody(a, d, g) { const { body: w } = this, { bodySpacing: b, bodyAlign: E, displayColors: i, boxHeight: O, boxWidth: j, boxPadding: Y } = g, J = ir(g.bodyFont); let ae = J.lineHeight, ce = 0; const Te = $u(g.rtl, this.x, this.width), be = function(Gt) { d.fillText(Gt, Te.x(a.x + ce), a.y + ae / 2), a.y += ae + b; }, Ze = Te.textAlign(E); let je, ot, vt, ht, gt, Vt, pt; for (d.textAlign = E, d.textBaseline = "middle", d.font = J.string, a.x = Tm(this, Ze, g), d.fillStyle = g.bodyColor, Zn(this.beforeBody, be), ce = i && Ze !== "right" ? E === "center" ? j / 2 + Y : j + 2 + Y : 0, ht = 0, Vt = w.length; ht < Vt; ++ht) { for (je = w[ht], ot = this.labelTextColors[ht], d.fillStyle = ot, Zn(je.before, be), vt = je.lines, i && vt.length && (this._drawColorBox(d, a, ht, Te, g), ae = Math.max(J.lineHeight, O)), gt = 0, pt = vt.length; gt < pt; ++gt) be(vt[gt]), ae = J.lineHeight; Zn(je.after, be); } ce = 0, ae = J.lineHeight, Zn(this.afterBody, be), a.y -= b; } drawFooter(a, d, g) { const w = this.footer, b = w.length; let E, i; if (b) { const O = $u(g.rtl, this.x, this.width); for (a.x = Tm(this, g.footerAlign, g), a.y += g.footerMarginTop, d.textAlign = O.textAlign(g.footerAlign), d.textBaseline = "middle", E = ir(g.footerFont), d.fillStyle = g.footerColor, d.font = E.string, i = 0; i < b; ++i) d.fillText(w[i], O.x(a.x), a.y + E.lineHeight / 2), a.y += E.lineHeight + g.footerSpacing; } } drawBackground(a, d, g, w) { const { xAlign: b, yAlign: E } = this, { x: i, y: O } = a, { width: j, height: Y } = g, { topLeft: J, topRight: ae, bottomLeft: ce, bottomRight: Te } = kh(w.cornerRadius); d.fillStyle = w.backgroundColor, d.strokeStyle = w.borderColor, d.lineWidth = w.borderWidth, d.beginPath(), d.moveTo(i + J, O), E === "top" && this.drawCaret(a, d, g, w), d.lineTo(i + j - ae, O), d.quadraticCurveTo(i + j, O, i + j, O + ae), E === "center" && b === "right" && this.drawCaret(a, d, g, w), d.lineTo(i + j, O + Y - Te), d.quadraticCurveTo(i + j, O + Y, i + j - Te, O + Y), E === "bottom" && this.drawCaret(a, d, g, w), d.lineTo(i + ce, O + Y), d.quadraticCurveTo(i, O + Y, i, O + Y - ce), E === "center" && b === "left" && this.drawCaret(a, d, g, w), d.lineTo(i, O + J), d.quadraticCurveTo(i, O, i + J, O), d.closePath(), d.fill(), w.borderWidth > 0 && d.stroke(); } _updateAnimationTarget(a) { const d = this.chart, g = this.$animations, w = g && g.x, b = g && g.y; if (w || b) { const E = Ef[a.position].call(this, this._active, this._eventPosition); if (!E) return; const i = this._size = tb(this, a), O = Object.assign({}, E, this._size), j = ib(d, a, O), Y = nb(a, O, j, d); (w._to !== Y.x || b._to !== Y.y) && (this.xAlign = j.xAlign, this.yAlign = j.yAlign, this.width = i.width, this.height = i.height, this.caretX = E.x, this.caretY = E.y, this._resolveAnimations().update(this, Y)); } } _willRender() { return !!this.opacity; } draw(a) { const d = this.options.setContext(this.getContext()); let g = this.opacity; if (!g) return; this._updateAnimationTarget(d); const w = { width: this.width, height: this.height }, b = { x: this.x, y: this.y }; g = Math.abs(g) < 1e-3 ? 0 : g; const E = Gr(d.padding), i = this.title.length || this.beforeBody.length || this.body.length || this.afterBody.length || this.footer.length; d.enabled && i && (a.save(), a.globalAlpha = g, this.drawBackground(b, a, w, d), Gb(a, d.textDirection), b.y += E.top, this.drawTitle(b, a, d), this.drawBody(b, a, d), this.drawFooter(b, a, d), Zb(a, d.textDirection), a.restore()); } getActiveElements() { return this._active || []; } setActiveElements(a, d) { const g = this._active, w = a.map(({ datasetIndex: i, index: O }) => { const j = this.chart.getDatasetMeta(i); if (!j) throw new Error("Cannot find a dataset at index " + i); return { datasetIndex: i, element: j.data[O], index: O }; }), b = !Om(g, w), E = this._positionChanged(w, d); (b || E) && (this._active = w, this._eventPosition = d, this._ignoreReplayEvents = !0, this.update(!0)); } handleEvent(a, d, g = !0) { if (d && this._ignoreReplayEvents) return !1; this._ignoreReplayEvents = !1; const w = this.options, b = this._active || [], E = this._getActiveElements(a, b, d, g), i = this._positionChanged(E, a), O = d || !Om(E, b) || i; return O && (this._active = E, (w.enabled || w.external) && (this._eventPosition = { x: a.x, y: a.y }, this.update(!0, d))), O; } _getActiveElements(a, d, g, w) { const b = this.options; if (a.type === "mouseout") return []; if (!w) return d.filter((i) => this.chart.data.datasets[i.datasetIndex] && this.chart.getDatasetMeta(i.datasetIndex).controller.getParsed(i.index) !== void 0); const E = this.chart.getElementsAtEventForMode(a, b.mode, b, g); return b.reverse && E.reverse(), E; } _positionChanged(a, d) { const { caretX: g, caretY: w, options: b } = this, E = Ef[b.position].call(this, a, d); return E !== !1 && (g !== E.x || w !== E.y); } } Yt(Qg, "positioners", Ef); var tC = { id: "tooltip", _element: Qg, positioners: Ef, afterInit(m, a, d) { d && (m.tooltip = new Qg({ chart: m, options: d })); }, beforeUpdate(m, a, d) { m.tooltip && m.tooltip.initialize(d); }, reset(m, a, d) { m.tooltip && m.tooltip.initialize(d); }, afterDraw(m) { const a = m.tooltip; if (a && a._willRender()) { const d = { tooltip: a }; if (m.notifyPlugins("beforeTooltipDraw", { ...d, cancelable: !0 }) === !1) return; a.draw(m.ctx), m.notifyPlugins("afterTooltipDraw", d); } }, afterEvent(m, a) { if (m.tooltip) { const d = a.replay; m.tooltip.handleEvent(a.event, d, a.inChartArea) && (a.changed = !0); } }, defaults: { enabled: !0, external: null, position: "average", backgroundColor: "rgba(0,0,0,0.8)", titleColor: "#fff", titleFont: { weight: "bold" }, titleSpacing: 2, titleMarginBottom: 6, titleAlign: "left", bodyColor: "#fff", bodySpacing: 2, bodyFont: {}, bodyAlign: "left", footerColor: "#fff", footerSpacing: 2, footerMarginTop: 6, footerFont: { weight: "bold" }, footerAlign: "left", padding: 6, caretPadding: 2, caretSize: 5, cornerRadius: 6, boxHeight: (m, a) => a.bodyFont.size, boxWidth: (m, a) => a.bodyFont.size, multiKeyBackground: "#fff", displayColors: !0, boxPadding: 0, borderColor: "rgba(0,0,0,0)", borderWidth: 0, animation: { duration: 400, easing: "easeOutQuart" }, animations: { numbers: { type: "number", properties: [ "x", "y", "width", "height", "caretX", "caretY" ] }, opacity: { easing: "linear", duration: 200 } }, callbacks: mw }, defaultRoutes: { bodyFont: "font", footerFont: "font", titleFont: "font" }, descriptors: { _scriptable: (m) => m !== "filter" && m !== "itemSort" && m !== "external", _indexable: !1, callbacks: { _scriptable: !1, _indexable: !1 }, animation: { _fallback: !1 }, animations: { _fallback: "animation" } }, additionalOptionScopes: [ "interaction" ] }, iC = /* @__PURE__ */ Object.freeze({ __proto__: null, Colors: pA, Decimation: yA, Filler: BA, Legend: ZA, SubTitle: WA, Title: qA, Tooltip: tC }); const nC = (m, a, d, g) => (typeof a == "string" ? (d = m.push(a) - 1, g.unshift({ index: d, label: a })) : isNaN(a) && (d = null), d); function sC(m, a, d, g) { const w = m.indexOf(a); if (w === -1) return nC(m, a, d, g); const b = m.lastIndexOf(a); return w !== b ? d : w; } const rC = (m, a) => m === null ? null : gr(Math.round(m), 0, a); function ob(m) { const a = this.getLabels(); return m >= 0 && m < a.length ? a[m] : m; } class ey extends Bh { constructor(a) { super(a), this._startValue = void 0, this._valueRange = 0, this._addedLabels = []; } init(a) { const d = this._addedLabels; if (d.length) { const g = this.getLabels(); for (const { index: w, label: b } of d) g[w] === b && g.splice(w, 1); this._addedLabels = []; } super.init(a); } parse(a, d) { if (En(a)) return null; const g = this.getLabels(); return d = isFinite(d) && g[d] === a ? d : sC(g, a, en(d, a), this._addedLabels), rC(d, g.length - 1); } determineDataLimits() { const { minDefined: a, maxDefined: d } = this.getUserBounds(); let { min: g, max: w } = this.getMinMax(!0); this.options.bounds === "ticks" && (a || (g = 0), d || (w = this.getLabels().length - 1)), this.min = g, this.max = w; } buildTicks() { const a = this.min, d = this.max, g = this.options.offset, w = []; let b = this.getLabels(); b = a === 0 && d === b.length - 1 ? b : b.slice(a, d + 1), this._valueRange = Math.max(b.length - (g ? 0 : 1), 1), this._startValue = this.min - (g ? 0.5 : 0); for (let E = a; E <= d; E++) w.push({ value: E }); return w; } getLabelForValue(a) { return ob.call(this, a); } configure() { super.configure(), this.isHorizontal() || (this._reversePixels = !this._reversePixels); } getPixelForValue(a) { return typeof a != "number" && (a = this.parse(a)), a === null ? NaN : this.getPixelForDecimal((a - this._startValue) / this._valueRange); } getPixelForTick(a) { const d = this.ticks; return a < 0 || a > d.length - 1 ? null : this.getPixelForValue(d[a].value); } getValueForPixel(a) { return Math.round(this._startValue + this.getDecimalForPixel(a) * this._valueRange); } getBasePixel() { return this.bottom; } } Yt(ey, "id", "category"), Yt(ey, "defaults", { ticks: { callback: ob } }); function oC(m, a) { const d = [], { bounds: w, step: b, min: E, max: i, precision: O, count: j, maxTicks: Y, maxDigits: J, includeBounds: ae } = m, ce = b || 1, Te = Y - 1, { min: be, max: Ze } = a, je = !En(E), ot = !En(i), vt = !En(j), ht = (Ze - be) / (J + 1); let gt = t1((Ze - be) / Te / ce) * ce, Vt, pt, Gt, ui; if (gt < 1e-14 && !je && !ot) return [ { value: be }, { value: Ze } ]; ui = Math.ceil(Ze / gt) - Math.floor(be / gt), ui > Te && (gt = t1(ui * gt / Te / ce) * ce), En(O) || (Vt = Math.pow(10, O), gt = Math.ceil(gt * Vt) / Vt), w === "ticks" ? (pt = Math.floor(be / gt) * gt, Gt = Math.ceil(Ze / gt) * gt) : (pt = be, Gt = Ze), je && ot && b && QM((i - E) / b, gt / 1e3) ? (ui = Math.round(Math.min((i - E) / gt, Y)), gt = (i - E) / ui, pt = E, Gt = i) : vt ? (pt = je ? E : pt, Gt = ot ? i : Gt, ui = j - 1, gt = (Gt - pt) / ui) : (ui = (Gt - pt) / gt, If(ui, Math.round(ui), gt / 1e3) ? ui = Math.round(ui) : ui = Math.ceil(ui)); const kt = Math.max(i1(gt), i1(pt)); Vt = Math.pow(10, En(O) ? kt : O), pt = Math.round(pt * Vt) / Vt, Gt = Math.round(Gt * Vt) / Vt; let Pt = 0; for (je && (ae && pt !== E ? (d.push({ value: E }), pt < E && Pt++, If(Math.round((pt + Pt * gt) * Vt) / Vt, E, ab(E, ht, m)) && Pt++) : pt < E && Pt++); Pt < ui; ++Pt) { const Mi = Math.round((pt + Pt * gt) * Vt) / Vt; if (ot && Mi > i) break; d.push({ value: Mi }); } return ot && ae && Gt !== i ? d.length && If(d[d.length - 1].value, i, ab(i, ht, m)) ? d[d.length - 1].value = i : d.push({ value: i }) : (!ot || Gt === i) && d.push({ value: Gt }), d; } function ab(m, a, { horizontal: d, minRotation: g }) { const w = Ia(g), b = (d ? Math.sin(w) : Math.cos(w)) || 1e-3, E = 0.75 * a * ("" + m).length; return Math.min(a / b, E); } class Gm extends Bh { constructor(a) { super(a), this.start = void 0, this.end = void 0, this._startValue = void 0, this._endValue = void 0, this._valueRange = 0; } parse(a, d) { return En(a) || (typeof a == "number" || a instanceof Number) && !isFinite(+a) ? null : +a; } handleTickRangeOptions() { const { beginAtZero: a } = this.options, { minDefined: d, maxDefined: g } = this.getUserBounds(); let { min: w, max: b } = this; const E = (O) => w = d ? w : O, i = (O) => b = g ? b : O; if (a) { const O = ll(w), j = ll(b); O < 0 && j < 0 ? i(0) : O > 0 && j > 0 && E(0); } if (w === b) { let O = b === 0 ? 1 : Math.abs(b * 0.05); i(b + O), a || E(w - O); } this.min = w, this.max = b; } getTickLimit() { const a = this.options.ticks; let { maxTicksLimit: d, stepSize: g } = a, w; return g ? (w = Math.ceil(this.max / g) - Math.floor(this.min / g) + 1, w > 1e3 && (console.warn(`scales.${this.id}.ticks.stepSize: ${g} would result generating up to ${w} ticks. Limiting to 1000.`), w = 1e3)) : (w = this.computeTickLimit(), d = d || 11), d && (w = Math.min(d, w)), w; } computeTickLimit() { return Number.POSITIVE_INFINITY; } buildTicks() { const a = this.options, d = a.ticks; let g = this.getTickLimit(); g = Math.max(2, g); const w = { maxTicks: g, bounds: a.bounds, min: a.min, max: a.max, precision: d.precision, step: d.stepSize, count: d.count, maxDigits: this._maxDigits(), horizontal: this.isHorizontal(), minRotation: d.minRotation || 0, includeBounds: d.includeBounds !== !1 }, b = this._range || this, E = oC(w, b); return a.bounds === "ticks" && Eb(E, this, "value"), a.reverse ? (E.reverse(), this.start = this.max, this.end = this.min) : (this.start = this.min, this.end = this.max), E; } configure() { const a = this.ticks; let d = this.min, g = this.max; if (super.configure(), this.options.offset && a.length) { const w = (g - d) / Math.max(a.length - 1, 1) / 2; d -= w, g += w; } this._startValue = d, this._endValue = g, this._valueRange = g - d; } getLabelForValue(a) { return Zf(a, this.chart.options.locale, this.options.ticks.format); } } class ty extends Gm { determineDataLimits() { const { min: a, max: d } = this.getMinMax(!0); this.min = As(a) ? a : 0, this.max = As(d) ? d : 1, this.handleTickRangeOptions(); } computeTickLimit() { const a = this.isHorizontal(), d = a ? this.width : this.height, g = Ia(this.options.ticks.minRotation), w = (a ? Math.sin(g) : Math.cos(g)) || 1e-3, b = this._resolveTickFontOptions(0); return Math.ceil(d / Math.min(40, b.lineHeight / w)); } getPixelForValue(a) { return a === null ? NaN : this.getPixelForDecimal((a - this._startValue) / this._valueRange); } getValueForPixel(a) { return this._startValue + this.getDecimalForPixel(a) * this._valueRange; } } Yt(ty, "id", "linear"), Yt(ty, "defaults", { ticks: { callback: qm.formatters.numeric } }); const Vf = (m) => Math.floor(Lc(m)), Ih = (m, a) => Math.pow(10, Vf(m) + a); function lb(m) { return m / Math.pow(10, Vf(m)) === 1; } function cb(m, a, d) { const g = Math.pow(10, d), w = Math.floor(m / g); return Math.ceil(a / g) - w; } function aC(m, a) { const d = a - m; let g = Vf(d); for (; cb(m, a, g) > 10; ) g++; for (; cb(m, a, g) < 10; ) g--; return Math.min(g, Vf(m)); } function lC(m, { min: a, max: d }) { a = Bo(m.min, a); const g = [], w = Vf(a); let b = aC(a, d), E = b < 0 ? Math.pow(10, Math.abs(b)) : 1; const i = Math.pow(10, b), O = w > b ? Math.pow(10, w) : 0, j = Math.round((a - O) * E) / E, Y = Math.floor((a - O) / i / 10) * i * 10; let J = Math.floor((j - Y) / Math.pow(10, b)), ae = Bo(m.min, Math.round((O + Y + J * Math.pow(10, b)) * E) / E); for (; ae < d; ) g.push({ value: ae, major: lb(ae), significand: J }), J >= 10 ? J = J < 15 ? 15 : 20 : J++, J >= 20 && (b++, J = 2, E = b >= 0 ? 1 : E), ae = Math.round((O + Y + J * Math.pow(10, b)) * E) / E; const ce = Bo(m.max, ae); return g.push({ value: ce, major: lb(ce), significand: J }), g; } class iy extends Bh { constructor(a) { super(a), this.start = void 0, this.end = void 0, this._startValue = void 0, this._valueRange = 0; } parse(a, d) { const g = Gm.prototype.parse.apply(this, [ a, d ]); if (g === 0) { this._zero = !0; return; } return As(g) && g > 0 ? g : null; } determineDataLimits() { const { min: a, max: d } = this.getMinMax(!0); this.min = As(a) ? Math.max(0, a) : null, this.max = As(d) ? Math.max(0, d) : null, this.options.beginAtZero && (this._zero = !0), this._zero && this.min !== this._suggestedMin && !As(this._userMin) && (this.min = a === Ih(this.min, 0) ? Ih(this.min, -1) : Ih(this.min, 0)), this.handleTickRangeOptions(); } handleTickRangeOptions() { const { minDefined: a, maxDefined: d } = this.getUserBounds(); let g = this.min, w = this.max; const b = (i) => g = a ? g : i, E = (i) => w = d ? w : i; g === w && (g <= 0 ? (b(1), E(10)) : (b(Ih(g, -1)), E(Ih(w, 1)))), g <= 0 && b(Ih(w, -1)), w <= 0 && E(Ih(g, 1)), this.min = g, this.max = w; } buildTicks() { const a = this.options, d = { min: this._userMin, max: this._userMax }, g = lC(d, this); return a.bounds === "ticks" && Eb(g, this, "value"), a.reverse ? (g.reverse(), this.start = this.max, this.end = this.min) : (this.start = this.min, this.end = this.max), g; } getLabelForValue(a) { return a === void 0 ? "0" : Zf(a, this.chart.options.locale, this.options.ticks.format); } configure() { const a = this.min; super.configure(), this._startValue = Lc(a), this._valueRange = Lc(this.max) - Lc(a); } getPixelForValue(a) { return (a === void 0 || a === 0) && (a = this.min), a === null || isNaN(a) ? NaN : this.getPixelForDecimal(a === this.min ? 0 : (Lc(a) - this._startValue) / this._valueRange); } getValueForPixel(a) { const d = this.getDecimalForPixel(a); return Math.pow(10, this._startValue + d * this._valueRange); } } Yt(iy, "id", "logarithmic"), Yt(iy, "defaults", { ticks: { callback: qm.formatters.logarithmic, major: { enabled: !0 } } }); function ny(m) { const a = m.ticks; if (a.display && m.display) { const d = Gr(a.backdropPadding); return en(a.font && a.font.size, ys.font.size) + d.height; } return 0; } function cC(m, a, d) { return d = hs(d) ? d : [ d ], { w: _S(m, a.string, d), h: d.length * a.lineHeight }; } function hb(m, a, d, g, w) { return m === g || m === w ? { start: a - d / 2, end: a + d / 2 } : m < g || m > w ? { start: a - d, end: a } : { start: a, end: a + d }; } function hC(m) { const a = { l: m.left + m._padding.left, r: m.right - m._padding.right, t: m.top + m._padding.top, b: m.bottom - m._padding.bottom }, d = Object.assign({}, a), g = [], w = [], b = m._pointLabels.length, E = m.options.pointLabels, i = E.centerPointLabels ? ds / b : 0; for (let O = 0; O < b; O++) { const j = E.setContext(m.getPointLabelContext(O)); w[O] = j.padding; const Y = m.getPointPosition(O, m.drawingArea + w[O], i), J = ir(j.font), ae = cC(m.ctx, J, m._pointLabels[O]); g[O] = ae; const ce = No(m.getIndexAngle(O) + i), Te = Math.round(uy(ce)), be = hb(Te, Y.x, ae.w, 0, 180), Ze = hb(Te, Y.y, ae.h, 90, 270); uC(d, a, ce, be, Ze); } m.setCenterPoint(a.l - d.l, d.r - a.r, a.t - d.t, d.b - a.b), m._pointLabelItems = pC(m, g, w); } function uC(m, a, d, g, w) { const b = Math.abs(Math.sin(d)), E = Math.abs(Math.cos(d)); let i = 0, O = 0; g.start < a.l ? (i = (a.l - g.start) / b, m.l = Math.min(m.l, a.l - i)) : g.end > a.r && (i = (g.end - a.r) / b, m.r = Math.max(m.r, a.r + i)), w.start < a.t ? (O = (a.t - w.start) / E, m.t = Math.min(m.t, a.t - O)) : w.end > a.b && (O = (w.end - a.b) / E, m.b = Math.max(m.b, a.b + O)); } function dC(m, a, d) { const g = m.drawingArea, { extra: w, additionalAngle: b, padding: E, size: i } = d, O = m.getPointPosition(a, g + w + E, b), j = Math.round(uy(No(O.angle + Ns))), Y = gC(O.y, i.h, j), J = mC(j), ae = _C(O.x, i.w, J); return { visible: !0, x: O.x, y: Y, textAlign: J, left: ae, top: Y, right: ae + i.w, bottom: Y + i.h }; } function fC(m, a) { if (!a) return !0; const { left: d, top: g, right: w, bottom: b } = m; return !(Ul({ x: d, y: g }, a) || Ul({ x: d, y: b }, a) || Ul({ x: w, y: g }, a) || Ul({ x: w, y: b }, a)); } function pC(m, a, d) { const g = [], w = m._pointLabels.length, b = m.options, { centerPointLabels: E, display: i } = b.pointLabels, O = { extra: ny(b) / 2, additionalAngle: E ? ds / w : 0 }; let j; for (let Y = 0; Y < w; Y++) { O.padding = d[Y], O.size = a[Y]; const J = dC(m, Y, O); g.push(J), i === "auto" && (J.visible = fC(J, j), J.visible && (j = J)); } return g; } function mC(m) { return m === 0 || m === 180 ? "center" : m < 180 ? "left" : "right"; } function _C(m, a, d) { return d === "right" ? m -= a : d === "center" && (m -= a / 2), m; } function gC(m, a, d) { return d === 90 || d === 270 ? m -= a / 2 : (d > 270 || d < 90) && (m -= a), m; } function yC(m, a, d) { const { left: g, top: w, right: b, bottom: E } = d, { backdropColor: i } = a; if (!En(i)) { const O = kh(a.borderRadius), j = Gr(a.backdropPadding); m.fillStyle = i; const Y = g - j.left, J = w - j.top, ae = b - g + j.width, ce = E - w + j.height; Object.values(O).some((Te) => Te !== 0) ? (m.beginPath(), Bf(m, { x: Y, y: J, w: ae, h: ce, radius: O }), m.fill()) : m.fillRect(Y, J, ae, ce); } } function xC(m, a) { const { ctx: d, options: { pointLabels: g } } = m; for (let w = a - 1; w >= 0; w--) { const b = m._pointLabelItems[w]; if (!b.visible) continue; const E = g.setContext(m.getPointLabelContext(w)); yC(d, E, b); const i = ir(E.font), { x: O, y: j, textAlign: Y } = b; Fh(d, m._pointLabels[w], O, j + i.lineHeight / 2, i, { color: E.color, textAlign: Y, textBaseline: "middle" }); } } function _w(m, a, d, g) { const { ctx: w } = m; if (d) w.arc(m.xCenter, m.yCenter, a, 0, us); else { let b = m.getPointPosition(0, a); w.moveTo(b.x, b.y); for (let E = 1; E < g; E++) b = m.getPointPosition(E, a), w.lineTo(b.x, b.y); } } function vC(m, a, d, g, w) { const b = m.ctx, E = a.circular, { color: i, lineWidth: O } = a; !E && !g || !i || !O || d < 0 || (b.save(), b.strokeStyle = i, b.lineWidth = O, b.setLineDash(w.dash || []), b.lineDashOffset = w.dashOffset, b.beginPath(), _w(m, d, E, g), b.closePath(), b.stroke(), b.restore()); } function bC(m, a, d) { return Fc(m, { label: d, index: a, type: "pointLabel" }); } class Pf extends Gm { constructor(a) { super(a), this.xCenter = void 0, this.yCenter = void 0, this.drawingArea = void 0, this._pointLabels = [], this._pointLabelItems = []; } setDimensions() { const a = this._padding = Gr(ny(this.options) / 2), d = this.width = this.maxWidth - a.width, g = this.height = this.maxHeight - a.height; this.xCenter = Math.floor(this.left + d / 2 + a.left), this.yCenter = Math.floor(this.top + g / 2 + a.top), this.drawingArea = Math.floor(Math.min(d, g) / 2); } determineDataLimits() { const { min: a, max: d } = this.getMinMax(!1); this.min = As(a) && !isNaN(a) ? a : 0, this.max = As(d) && !isNaN(d) ? d : 0, this.handleTickRangeOptions(); } computeTickLimit() { return Math.ceil(this.drawingArea / ny(this.options)); } generateTickLabels(a) { Gm.prototype.generateTickLabels.call(this, a), this._pointLabels = this.getLabels().map((d, g) => { const w = is(this.options.pointLabels.callback, [ d, g ], this); return w || w === 0 ? w : ""; }).filter((d, g) => this.chart.getDataVisibility(g)); } fit() { const a = this.options; a.display && a.pointLabels.display ? hC(this) : this.setCenterPoint(0, 0, 0, 0); } setCenterPoint(a, d, g, w) { this.xCenter += Math.floor((a - d) / 2), this.yCenter += Math.floor((g - w) / 2), this.drawingArea -= Math.min(this.drawingArea / 2, Math.max(a, d, g, w)); } getIndexAngle(a) { const d = us / (this._pointLabels.length || 1), g = this.options.startAngle || 0; return No(a * d + Ia(g)); } getDistanceFromCenterForValue(a) { if (En(a)) return NaN; const d = this.drawingArea / (this.max - this.min); return this.options.reverse ? (this.max - a) * d : (a - this.min) * d; } getValueForDistanceFromCenter(a) { if (En(a)) return NaN; const d = a / (this.drawingArea / (this.max - this.min)); return this.options.reverse ? this.max - d : this.min + d; } getPointLabelContext(a) { const d = this._pointLabels || []; if (a >= 0 && a < d.length) { const g = d[a]; return bC(this.getContext(), a, g); } } getPointPosition(a, d, g = 0) { const w = this.getIndexAngle(a) - Ns + g; return { x: Math.cos(w) * d + this.xCenter, y: Math.sin(w) * d + this.yCenter, angle: w }; } getPointPositionForValue(a, d) { return this.getPointPosition(a, this.getDistanceFromCenterForValue(d)); } getBasePosition(a) { return this.getPointPositionForValue(a || 0, this.getBaseValue()); } getPointLabelPosition(a) { const { left: d, top: g, right: w, bottom: b } = this._pointLabelItems[a]; return { left: d, top: g, right: w, bottom: b }; } drawBackground() { const { backgroundColor: a, grid: { circular: d } } = this.options; if (a) { const g = this.ctx; g.save(), g.beginPath(), _w(this, this.getDistanceFromCenterForValue(this._endValue), d, this._pointLabels.length), g.closePath(), g.fillStyle = a, g.fill(), g.restore(); } } drawGrid() { const a = this.ctx, d = this.options, { angleLines: g, grid: w, border: b } = d, E = this._pointLabels.length; let i, O, j; if (d.pointLabels.display && xC(this, E), w.display && this.ticks.forEach((Y, J) => { if (J !== 0 || J === 0 && this.min < 0) { O = this.getDistanceFromCenterForValue(Y.value); const ae = this.getContext(J), ce = w.setContext(ae), Te = b.setContext(ae); vC(this, ce, O, E, Te); } }), g.display) { for (a.save(), i = E - 1; i >= 0; i--) { const Y = g.setContext(this.getPointLabelContext(i)), { color: J, lineWidth: ae } = Y; !ae || !J || (a.lineWidth = ae, a.strokeStyle = J, a.setLineDash(Y.borderDash), a.lineDashOffset = Y.borderDashOffset, O = this.getDistanceFromCenterForValue(d.reverse ? this.min : this.max), j = this.getPointPosition(i, O), a.beginPath(), a.moveTo(this.xCenter, this.yCenter), a.lineTo(j.x, j.y), a.stroke()); } a.restore(); } } drawBorder() { } drawLabels() { const a = this.ctx, d = this.options, g = d.ticks; if (!g.display) return; const w = this.getIndexAngle(0); let b, E; a.save(), a.translate(this.xCenter, this.yCenter), a.rotate(w), a.textAlign = "center", a.textBaseline = "middle", this.ticks.forEach((i, O) => { if (O === 0 && this.min >= 0 && !d.reverse) return; const j = g.setContext(this.getContext(O)), Y = ir(j.font); if (b = this.getDistanceFromCenterForValue(this.ticks[O].value), j.showLabelBackdrop) { a.font = Y.string, E = a.measureText(i.label).width, a.fillStyle = j.backdropColor; const J = Gr(j.backdropPadding); a.fillRect(-E / 2 - J.left, -b - Y.size / 2 - J.top, E + J.width, Y.size + J.height); } Fh(a, i.label, 0, -b, Y, { color: j.color, strokeColor: j.textStrokeColor, strokeWidth: j.textStrokeWidth }); }), a.restore(); } drawTitle() { } } Yt(Pf, "id", "radialLinear"), Yt(Pf, "defaults", { display: !0, animate: !0, position: "chartArea", angleLines: { display: !0, lineWidth: 1, borderDash: [], borderDashOffset: 0 }, grid: { circular: !1 }, startAngle: 0, ticks: { showLabelBackdrop: !0, callback: qm.formatters.numeric }, pointLabels: { backdropColor: void 0, backdropPadding: 2, display: !0, font: { size: 10 }, callback(a) { return a; }, padding: 5, centerPointLabels: !1 } }), Yt(Pf, "defaultRoutes", { "angleLines.color": "borderColor", "pointLabels.color": "color", "ticks.color": "color" }), Yt(Pf, "descriptors", { angleLines: { _fallback: "grid" } }); const Ym = { millisecond: { common: !0, size: 1, steps: 1e3 }, second: { common: !0, size: 1e3, steps: 60 }, minute: { common: !0, size: 6e4, steps: 60 }, hour: { common: !0, size: 36e5, steps: 24 }, day: { common: !0, size: 864e5, steps: 30 }, week: { common: !1, size: 6048e5, steps: 4 }, month: { common: !0, size: 2628e6, steps: 12 }, quarter: { common: !1, size: 7884e6, steps: 4 }, year: { common: !0, size: 3154e7 } }, go = /* @__PURE__ */ Object.keys(Ym); function ub(m, a) { return m - a; } function db(m, a) { if (En(a)) return null; const d = m._adapter, { parser: g, round: w, isoWeekday: b } = m._parseOpts; let E = a; return typeof g == "function" && (E = g(E)), As(E) || (E = typeof g == "string" ? d.parse(E, g) : d.parse(E)), E === null ? null : (w && (E = w === "week" && (Xu(b) || b === !0) ? d.startOf(E, "isoWeek", b) : d.startOf(E, w)), +E); } function fb(m, a, d, g) { const w = go.length; for (let b = go.indexOf(m); b < w - 1; ++b) { const E = Ym[go[b]], i = E.steps ? E.steps : Number.MAX_SAFE_INTEGER; if (E.common && Math.ceil((d - a) / (i * E.size)) <= g) return go[b]; } return go[w - 1]; } function wC(m, a, d, g, w) { for (let b = go.length - 1; b >= go.indexOf(d); b--) { const E = go[b]; if (Ym[E].common && m._adapter.diff(w, g, E) >= a - 1) return E; } return go[d ? go.indexOf(d) : 0]; } function TC(m) { for (let a = go.indexOf(m) + 1, d = go.length; a < d; ++a) if (Ym[go[a]].common) return go[a]; } function pb(m, a, d) { if (!d) m[a] = !0; else if (d.length) { const { lo: g, hi: w } = dy(d, a), b = d[g] >= a ? d[g] : d[w]; m[b] = !0; } } function MC(m, a, d, g) { const w = m._adapter, b = +w.startOf(a[0].value, g), E = a[a.length - 1].value; let i, O; for (i = b; i <= E; i = +w.add(i, 1, g)) O = d[i], O >= 0 && (a[O].major = !0); return a; } function mb(m, a, d) { const g = [], w = {}, b = a.length; let E, i; for (E = 0; E < b; ++E) i = a[E], w[i] = E, g.push({ value: i, major: !1 }); return b === 0 || !d ? g : MC(m, g, w, d); } class Uf extends Bh { constructor(a) { super(a), this._cache = { data: [], labels: [], all: [] }, this._unit = "day", this._majorUnit = void 0, this._offsets = {}, this._normalized = !1, this._parseOpts = void 0; } init(a, d = {}) { const g = a.time || (a.time = {}), w = this._adapter = new zE._date(a.adapters.date); w.init(d), Cf(g.displayFormats, w.formats()), this._parseOpts = { parser: g.parser, round: g.round, isoWeekday: g.isoWeekday }, super.init(a), this._normalized = d.normalized; } parse(a, d) { return a === void 0 ? null : db(this, a); } beforeLayout() { super.beforeLayout(), this._cache = { data: [], labels: [], all: [] }; } determineDataLimits() { const a = this.options, d = this._adapter, g = a.time.unit || "day"; let { min: w, max: b, minDefined: E, maxDefined: i } = this.getUserBounds(); function O(j) { !E && !isNaN(j.min) && (w = Math.min(w, j.min)), !i && !isNaN(j.max) && (b = Math.max(b, j.max)); } (!E || !i) && (O(this._getLabelBounds()), (a.bounds !== "ticks" || a.ticks.source !== "labels") && O(this.getMinMax(!1))), w = As(w) && !isNaN(w) ? w : +d.startOf(Date.now(), g), b = As(b) && !isNaN(b) ? b : +d.endOf(Date.now(), g) + 1, this.min = Math.min(w, b - 1), this.max = Math.max(w + 1, b); } _getLabelBounds() { const a = this.getLabelTimestamps(); let d = Number.POSITIVE_INFINITY, g = Number.NEGATIVE_INFINITY; return a.length && (d = a[0], g = a[a.length - 1]), { min: d, max: g }; } buildTicks() { const a = this.options, d = a.time, g = a.ticks, w = g.source === "labels" ? this.getLabelTimestamps() : this._generate(); a.bounds === "ticks" && w.length && (this.min = this._userMin || w[0], this.max = this._userMax || w[w.length - 1]); const b = this.min, E = this.max, i = nS(w, b, E); return this._unit = d.unit || (g.autoSkip ? fb(d.minUnit, this.min, this.max, this._getLabelCapacity(b)) : wC(this, i.length, d.minUnit, this.min, this.max)), this._majorUnit = !g.major.enabled || this._unit === "year" ? void 0 : TC(this._unit), this.initOffsets(w), a.reverse && i.reverse(), mb(this, i, this._majorUnit); } afterAutoSkip() { this.options.offsetAfterAutoskip && this.initOffsets(this.ticks.map((a) => +a.value)); } initOffsets(a = []) { let d = 0, g = 0, w, b; this.options.offset && a.length && (w = this.getDecimalForValue(a[0]), a.length === 1 ? d = 1 - w : d = (this.getDecimalForValue(a[1]) - w) / 2, b = this.getDecimalForValue(a[a.length - 1]), a.length === 1 ? g = b : g = (b - this.getDecimalForValue(a[a.length - 2])) / 2); const E = a.length < 3 ? 0.5 : 0.25; d = gr(d, 0, E), g = gr(g, 0, E), this._offsets = { start: d, end: g, factor: 1 / (d + 1 + g) }; } _generate() { const a = this._adapter, d = this.min, g = this.max, w = this.options, b = w.time, E = b.unit || fb(b.minUnit, d, g, this._getLabelCapacity(d)), i = en(w.ticks.stepSize, 1), O = E === "week" ? b.isoWeekday : !1, j = Xu(O) || O === !0, Y = {}; let J = d, ae, ce; if (j && (J = +a.startOf(J, "isoWeek", O)), J = +a.startOf(J, j ? "day" : E), a.diff(g, d, E) > 1e5 * i) throw new Error(d + " and " + g + " are too far apart with stepSize of " + i + " " + E); const Te = w.ticks.source === "data" && this.getDataTimestamps(); for (ae = J, ce = 0; ae < g; ae = +a.add(ae, i, E), ce++) pb(Y, ae, Te); return (ae === g || w.bounds === "ticks" || ce === 1) && pb(Y, ae, Te), Object.keys(Y).sort(ub).map((be) => +be); } getLabelForValue(a) { const d = this._adapter, g = this.options.time; return g.tooltipFormat ? d.format(a, g.tooltipFormat) : d.format(a, g.displayFormats.datetime); } format(a, d) { const w = this.options.time.displayFormats, b = this._unit, E = d || w[b]; return this._adapter.format(a, E); } _tickFormatFunction(a, d, g, w) { const b = this.options, E = b.ticks.callback; if (E) return is(E, [ a, d, g ], this); const i = b.time.displayFormats, O = this._unit, j = this._majorUnit, Y = O && i[O], J = j && i[j], ae = g[d], ce = j && J && ae && ae.major; return this._adapter.format(a, w || (ce ? J : Y)); } generateTickLabels(a) { let d, g, w; for (d = 0, g = a.length; d < g; ++d) w = a[d], w.label = this._tickFormatFunction(w.value, d, a); } getDecimalForValue(a) { return a === null ? NaN : (a - this.min) / (this.max - this.min); } getPixelForValue(a) { const d = this._offsets, g = this.getDecimalForValue(a); return this.getPixelForDecimal((d.start + g) * d.factor); } getValueForPixel(a) { const d = this._offsets, g = this.getDecimalForPixel(a) / d.factor - d.end; return this.min + g * (this.max - this.min); } _getLabelSize(a) { const d = this.options.ticks, g = this.ctx.measureText(a).width, w = Ia(this.isHorizontal() ? d.maxRotation : d.minRotation), b = Math.cos(w), E = Math.sin(w), i = this._resolveTickFontOptions(0).size; return { w: g * b + i * E, h: g * E + i * b }; } _getLabelCapacity(a) { const d = this.options.time, g = d.displayFormats, w = g[d.unit] || g.millisecond, b = this._tickFormatFunction(a, 0, mb(this, [ a ], this._majorUnit), w), E = this._getLabelSize(b), i = Math.floor(this.isHorizontal() ? this.width / E.w : this.height / E.h) - 1; return i > 0 ? i : 1; } getDataTimestamps() { let a = this._cache.data || [], d, g; if (a.length) return a; const w = this.getMatchingVisibleMetas(); if (this._normalized && w.length) return this._cache.data = w[0].controller.getAllParsedValues(this); for (d = 0, g = w.length; d < g; ++d) a = a.concat(w[d].controller.getAllParsedValues(this)); return this._cache.data = this.normalize(a); } getLabelTimestamps() { const a = this._cache.labels || []; let d, g; if (a.length) return a; const w = this.getLabels(); for (d = 0, g = w.length; d < g; ++d) a.push(db(this, w[d])); return this._cache.labels = this._normalized ? a : this.normalize(a); } normalize(a) { return Cb(a.sort(ub)); } } Yt(Uf, "id", "time"), Yt(Uf, "defaults", { bounds: "data", adapters: {}, time: { parser: !1, unit: !1, round: !1, isoWeekday: !1, minUnit: "millisecond", displayFormats: {} }, ticks: { source: "auto", callback: !1, major: { enabled: !1 } } }); function Mm(m, a, d) { let g = 0, w = m.length - 1, b, E, i, O; d ? (a >= m[g].pos && a <= m[w].pos && ({ lo: g, hi: w } = Vl(m, "pos", a)), { pos: b, time: i } = m[g], { pos: E, time: O } = m[w]) : (a >= m[g].time && a <= m[w].time && ({ lo: g, hi: w } = Vl(m, "time", a)), { time: b, pos: i } = m[g], { time: E, pos: O } = m[w]); const j = E - b; return j ? i + (O - i) * (a - b) / j : i; } class sy extends Uf { constructor(a) { super(a), this._table = [], this._minPos = void 0, this._tableRange = void 0; } initOffsets() { const a = this._getTimestampsForTable(), d = this._table = this.buildLookupTable(a); this._minPos = Mm(d, this.min), this._tableRange = Mm(d, this.max) - this._minPos, super.initOffsets(a); } buildLookupTable(a) { const { min: d, max: g } = this, w = [], b = []; let E, i, O, j, Y; for (E = 0, i = a.length; E < i; ++E) j = a[E], j >= d && j <= g && w.push(j); if (w.length < 2) return [ { time: d, pos: 0 }, { time: g, pos: 1 } ]; for (E = 0, i = w.length; E < i; ++E) Y = w[E + 1], O = w[E - 1], j = w[E], Math.round((Y + O) / 2) !== j && b.push({ time: j, pos: E / (i - 1) }); return b; } _generate() { const a = this.min, d = this.max; let g = super.getDataTimestamps(); return (!g.includes(a) || !g.length) && g.splice(0, 0, a), (!g.includes(d) || g.length === 1) && g.push(d), g.sort((w, b) => w - b); } _getTimestampsForTable() { let a = this._cache.all || []; if (a.length) return a; const d = this.getDataTimestamps(), g = this.getLabelTimestamps(); return d.length && g.length ? a = this.normalize(d.concat(g)) : a = d.length ? d : g, a = this._cache.all = a, a; } getDecimalForValue(a) { return (Mm(this._table, a) - this._minPos) / this._tableRange; } getValueForPixel(a) { const d = this._offsets, g = this.getDecimalForPixel(a) / d.factor - d.end; return Mm(this._table, g * this._tableRange + this._minPos, !0); } } Yt(sy, "id", "timeseries"), Yt(sy, "defaults", Uf.defaults); var SC = /* @__PURE__ */ Object.freeze({ __proto__: null, CategoryScale: ey, LinearScale: ty, LogarithmicScale: iy, RadialLinearScale: Pf, TimeScale: Uf, TimeSeriesScale: sy }); const EC = [ LE, aA, iC, SC ], Zm = { Utils: { DividePolylinesPoints(m) { let a = 0; const d = [], g = m.length; for (let w = 0; w < g; w++) m[w] === null && (d.push(m.slice(a === 0 ? 0 : a + 1, w)), a = w); return g - 1 !== a && d.push(m.slice(a)), d; }, GetItemFromArray(m, a) { try { return m[a]; } catch { return [0, 0]; } } } }; var Km = typeof globalThis < "u" ? globalThis : typeof window < "u" ? window : typeof global < "u" ? global : typeof self < "u" ? self : {}; function gw(m) { return m && m.__esModule && Object.prototype.hasOwnProperty.call(m, "default") ? m.default : m; } var Sm = { exports: {} }; /* @preserve * Leaflet 1.9.4, a JS library for interactive maps. https://leafletjs.com * (c) 2010-2023 Vladimir Agafonkin, (c) 2010-2011 CloudMade */ var _b; function yw() { return _b || (_b = 1, function(m, a) { (function(d, g) { g(a); })(Km, function(d) { var g = "1.9.4"; function w(p) { var A, B, X, ne; for (B = 1, X = arguments.length; B < X; B++) { ne = arguments[B]; for (A in ne) p[A] = ne[A]; } return p; } var b = Object.create || function() { function p() { } return function(A) { return p.prototype = A, new p(); }; }(); function E(p, A) { var B = Array.prototype.slice; if (p.bind) return p.bind.apply(p, B.call(arguments, 1)); var X = B.call(arguments, 2); return function() { return p.apply(A, X.length ? X.concat(B.call(arguments)) : arguments); }; } var i = 0; function O(p) { return "_leaflet_id" in p || (p._leaflet_id = ++i), p._leaflet_id; } function j(p, A, B) { var X, ne, ye, We; return We = function() { X = !1, ne && (ye.apply(B, ne), ne = !1); }, ye = function() { X ? ne = arguments : (p.apply(B, arguments), setTimeout(We, A), X = !0); }, ye; } function Y(p, A, B) { var X = A[1], ne = A[0], ye = X - ne; return p === X && B ? p : ((p - ne) % ye + ye) % ye + ne; } function J() { return !1; } function ae(p, A) { if (A === !1) return p; var B = Math.pow(10, A === void 0 ? 6 : A); return Math.round(p * B) / B; } function ce(p) { return p.trim ? p.trim() : p.replace(/^\s+|\s+$/g, ""); } function Te(p) { return ce(p).split(/\s+/); } function be(p, A) { Object.prototype.hasOwnProperty.call(p, "options") || (p.options = p.options ? b(p.options) : {}); for (var B in A) p.options[B] = A[B]; return p.options; } function Ze(p, A, B) { var X = []; for (var ne in p) X.push(encodeURIComponent(B ? ne.toUpperCase() : ne) + "=" + encodeURIComponent(p[ne])); return (!A || A.indexOf("?") === -1 ? "?" : "&") + X.join("&"); } var je = /\{ *([\w_ -]+) *\}/g; function ot(p, A) { return p.replace(je, function(B, X) { var ne = A[X]; if (ne === void 0) throw new Error("No value provided for variable " + B); return typeof ne == "function" && (ne = ne(A)), ne; }); } var vt = Array.isArray || function(p) { return Object.prototype.toString.call(p) === "[object Array]"; }; function ht(p, A) { for (var B = 0; B < p.length; B++) if (p[B] === A) return B; return -1; } var gt = ""; function Vt(p) { return window["webkit" + p] || window["moz" + p] || window["ms" + p]; } var pt = 0; function Gt(p) { var A = +/* @__PURE__ */ new Date(), B = Math.max(0, 16 - (A - pt)); return pt = A + B, window.setTimeout(p, B); } var ui = window.requestAnimationFrame || Vt("RequestAnimationFrame") || Gt, kt = window.cancelAnimationFrame || Vt("CancelAnimationFrame") || Vt("CancelRequestAnimationFrame") || function(p) { window.clearTimeout(p); }; function Pt(p, A, B) { if (B && ui === Gt) p.call(A); else return ui.call(window, E(p, A)); } function Mi(p) { p && kt.call(window, p); } var Pn = { __proto__: null, extend: w, create: b, bind: E, get lastId() { return i; }, stamp: O, throttle: j, wrapNum: Y, falseFn: J, formatNum: ae, trim: ce, splitWords: Te, setOptions: be, getParamString: Ze, template: ot, isArray: vt, indexOf: ht, emptyImageUrl: gt, requestFn: ui, cancelFn: kt, requestAnimFrame: Pt, cancelAnimFrame: Mi }; function hn() { } hn.extend = function(p) { var A = function() { be(this), this.initialize && this.initialize.apply(this, arguments), this.callInitHooks(); }, B = A.__super__ = this.prototype, X = b(B); X.constructor = A, A.prototype = X; for (var ne in this) Object.prototype.hasOwnProperty.call(this, ne) && ne !== "prototype" && ne !== "__super__" && (A[ne] = this[ne]); return p.statics && w(A, p.statics), p.includes && (Ht(p.includes), w.apply(null, [X].concat(p.includes))), w(X, p), delete X.statics, delete X.includes, X.options && (X.options = B.options ? b(B.options) : {}, w(X.options, p.options)), X._initHooks = [], X.callInitHooks = function() { if (!this._initHooksCalled) { B.callInitHooks && B.callInitHooks.call(this), this._initHooksCalled = !0; for (var ye = 0, We = X._initHooks.length; ye < We; ye++) X._initHooks[ye].call(this); } }, A; }, hn.include = function(p) { var A = this.prototype.options; return w(this.prototype, p), p.options && (this.prototype.options = A, this.mergeOptions(p.options)), this; }, hn.mergeOptions = function(p) { return w(this.prototype.options, p), this; }, hn.addInitHook = function(p) { var A = Array.prototype.slice.call(arguments, 1), B = typeof p == "function" ? p : function() { this[p].apply(this, A); }; return this.prototype._initHooks = this.prototype._initHooks || [], this.prototype._initHooks.push(B), this; }; function Ht(p) { if (!(typeof L > "u" || !L || !L.Mixin)) { p = vt(p) ? p : [p]; for (var A = 0; A < p.length; A++) p[A] === L.Mixin.Events && console.warn("Deprecated include of L.Mixin.Events: this property will be removed in future releases, please inherit from L.Evented instead.", new Error().stack); } } var Si = { /* @method on(type: String, fn: Function, context?: Object): this * Adds a listener function (`fn`) to a particular event type of the object. You can optionally specify the context of the listener (object the this keyword will point to). You can also pass several space-separated types (e.g. `'click dblclick'`). * * @alternative * @method on(eventMap: Object): this * Adds a set of type/listener pairs, e.g. `{click: onClick, mousemove: onMouseMove}` */ on: function(p, A, B) { if (typeof p == "object") for (var X in p) this._on(X, p[X], A); else { p = Te(p); for (var ne = 0, ye = p.length; ne < ye; ne++) this._on(p[ne], A, B); } return this; }, /* @method off(type: String, fn?: Function, context?: Object): this * Removes a previously added listener function. If no function is specified, it will remove all the listeners of that particular event from the object. Note that if you passed a custom context to `on`, you must pass the same context to `off` in order to remove the listener. * * @alternative * @method off(eventMap: Object): this * Removes a set of type/listener pairs. * * @alternative * @method off: this * Removes all listeners to all events on the object. This includes implicitly attached events. */ off: function(p, A, B) { if (!arguments.length) delete this._events; else if (typeof p == "object") for (var X in p) this._off(X, p[X], A); else { p = Te(p); for (var ne = arguments.length === 1, ye = 0, We = p.length; ye < We; ye++) ne ? this._off(p[ye]) : this._off(p[ye], A, B); } return this; }, // attach listener (without syntactic sugar now) _on: function(p, A, B, X) { if (typeof A != "function") { console.warn("wrong listener type: " + typeof A); return; } if (this._listens(p, A, B) === !1) { B === this && (B = void 0); var ne = { fn: A, ctx: B }; X && (ne.once = !0), this._events = this._events || {}, this._events[p] = this._events[p] || [], this._events[p].push(ne); } }, _off: function(p, A, B) { var X, ne, ye; if (this._events && (X = this._events[p], !!X)) { if (arguments.length === 1) { if (this._firingCount) for (ne = 0, ye = X.length; ne < ye; ne++) X[ne].fn = J; delete this._events[p]; return; } if (typeof A != "function") { console.warn("wrong listener type: " + typeof A); return; } var We = this._listens(p, A, B); if (We !== !1) { var at = X[We]; this._firingCount && (at.fn = J, this._events[p] = X = X.slice()), X.splice(We, 1); } } }, // @method fire(type: String, data?: Object, propagate?: Boolean): this // Fires an event of the specified type. You can optionally provide a data // object — the first argument of the listener function will contain its // properties. The event can optionally be propagated to event parents. fire: function(p, A, B) { if (!this.listens(p, B)) return this; var X = w({}, A, { type: p, target: this, sourceTarget: A && A.sourceTarget || this }); if (this._events) { var ne = this._events[p]; if (ne) { this._firingCount = this._firingCount + 1 || 1; for (var ye = 0, We = ne.length; ye < We; ye++) { var at = ne[ye], ft = at.fn; at.once && this.off(p, ft, at.ctx), ft.call(at.ctx || this, X); } this._firingCount--; } } return B && this._propagateEvent(X), this; }, // @method listens(type: String, propagate?: Boolean): Boolean // @method listens(type: String, fn: Function, context?: Object, propagate?: Boolean): Boolean // Returns `true` if a particular event type has any listeners attached to it. // The verification can optionally be propagated, it will return `true` if parents have the listener attached to it. listens: function(p, A, B, X) { typeof p != "string" && console.warn('"string" type argument expected'); var ne = A; typeof A != "function" && (X = !!A, ne = void 0, B = void 0); var ye = this._events && this._events[p]; if (ye && ye.length && this._listens(p, ne, B) !== !1) return !0; if (X) { for (var We in this._eventParents) if (this._eventParents[We].listens(p, A, B, X)) return !0; } return !1; }, // returns the index (number) or false _listens: function(p, A, B) { if (!this._events) return !1; var X = this._events[p] || []; if (!A) return !!X.length; B === this && (B = void 0); for (var ne = 0, ye = X.length; ne < ye; ne++) if (X[ne].fn === A && X[ne].ctx === B) return ne; return !1; }, // @method once(…): this // Behaves as [`on(…)`](#evented-on), except the listener will only get fired once and then removed. once: function(p, A, B) { if (typeof p == "object") for (var X in p) this._on(X, p[X], A, !0); else { p = Te(p); for (var ne = 0, ye = p.length; ne < ye; ne++) this._on(p[ne], A, B, !0); } return this; }, // @method addEventParent(obj: Evented): this // Adds an event parent - an `Evented` that will receive propagated events addEventParent: function(p) { return this._eventParents = this._eventParents || {}, this._eventParents[O(p)] = p, this; }, // @method removeEventParent(obj: Evented): this // Removes an event parent, so it will stop receiving propagated events removeEventParent: function(p) { return this._eventParents && delete this._eventParents[O(p)], this; }, _propagateEvent: function(p) { for (var A in this._eventParents) this._eventParents[A].fire(p.type, w({ layer: p.target, propagatedFrom: p.target }, p), !0); } }; Si.addEventListener = Si.on, Si.removeEventListener = Si.clearAllEventListeners = Si.off, Si.addOneTimeEventListener = Si.once, Si.fireEvent = Si.fire, Si.hasEventListeners = Si.listens; var Ji = hn.extend(Si); function fi(p, A, B) { this.x = B ? Math.round(p) : p, this.y = B ? Math.round(A) : A; } var jt = Math.trunc || function(p) { return p > 0 ? Math.floor(p) : Math.ceil(p); }; fi.prototype = { // @method clone(): Point // Returns a copy of the current point. clone: function() { return new fi(this.x, this.y); }, // @method add(otherPoint: Point): Point // Returns the result of addition of the current and the given points. add: function(p) { return this.clone()._add(ni(p)); }, _add: function(p) { return this.x += p.x, this.y += p.y, this; }, // @method subtract(otherPoint: Point): Point // Returns the result of subtraction of the given point from the current. subtract: function(p) { return this.clone()._subtract(ni(p)); }, _subtract: function(p) { return this.x -= p.x, this.y -= p.y, this; }, // @method divideBy(num: Number): Point // Returns the result of division of the current point by the given number. divideBy: function(p) { return this.clone()._divideBy(p); }, _divideBy: function(p) { return this.x /= p, this.y /= p, this; }, // @method multiplyBy(num: Number): Point // Returns the result of multiplication of the current point by the given number. multiplyBy: function(p) { return this.clone()._multiplyBy(p); }, _multiplyBy: function(p) { return this.x *= p, this.y *= p, this; }, // @method scaleBy(scale: Point): Point // Multiply each coordinate of the current point by each coordinate of // `scale`. In linear algebra terms, multiply the point by the // [scaling matrix](https://en.wikipedia.org/wiki/Scaling_%28geometry%29#Matrix_representation) // defined by `scale`. scaleBy: function(p) { return new fi(this.x * p.x, this.y * p.y); }, // @method unscaleBy(scale: Point): Point // Inverse of `scaleBy`. Divide each coordinate of the current point by // each coordinate of `scale`. unscaleBy: function(p) { return new fi(this.x / p.x, this.y / p.y); }, // @method round(): Point // Returns a copy of the current point with rounded coordinates. round: function() { return this.clone()._round(); }, _round: function() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this; }, // @method floor(): Point // Returns a copy of the current point with floored coordinates (rounded down). floor: function() { return this.clone()._floor(); }, _floor: function() { return this.x = Math.floor(this.x), this.y = Math.floor(this.y), this; }, // @method ceil(): Point // Returns a copy of the current point with ceiled coordinates (rounded up). ceil: function() { return this.clone()._ceil(); }, _ceil: function() { return this.x = Math.ceil(this.x), this.y = Math.ceil(this.y), this; }, // @method trunc(): Point // Returns a copy of the current point with truncated coordinates (rounded towards zero). trunc: function() { return this.clone()._trunc(); }, _trunc: function() { return this.x = jt(this.x), this.y = jt(this.y), this; }, // @method distanceTo(otherPoint: Point): Number // Returns the cartesian distance between the current and the given points. distanceTo: function(p) { p = ni(p); var A = p.x - this.x, B = p.y - this.y; return Math.sqrt(A * A + B * B); }, // @method equals(otherPoint: Point): Boolean // Returns `true` if the given point has the same coordinates. equals: function(p) { return p = ni(p), p.x === this.x && p.y === this.y; }, // @method contains(otherPoint: Point): Boolean // Returns `true` if both coordinates of the given point are less than the corresponding current point coordinates (in absolute values). contains: function(p) { return p = ni(p), Math.abs(p.x) <= Math.abs(this.x) && Math.abs(p.y) <= Math.abs(this.y); }, // @method toString(): String // Returns a string representation of the point for debugging purposes. toString: function() { return "Point(" + ae(this.x) + ", " + ae(this.y) + ")"; } }; function ni(p, A, B) { return p instanceof fi ? p : vt(p) ? new fi(p[0], p[1]) : p == null ? p : typeof p == "object" && "x" in p && "y" in p ? new fi(p.x, p.y) : new fi(p, A, B); } function Gi(p, A) { if (p) for (var B = A ? [p, A] : p, X = 0, ne = B.length; X < ne; X++) this.extend(B[X]); } Gi.prototype = { // @method extend(point: Point): this // Extends the bounds to contain the given point. // @alternative // @method extend(otherBounds: Bounds): this // Extend the bounds to contain the given bounds extend: function(p) { var A, B; if (!p) return this; if (p instanceof fi || typeof p[0] == "number" || "x" in p) A = B = ni(p); else if (p = an(p), A = p.min, B = p.max, !A || !B) return this; return !this.min && !this.max ? (this.min = A.clone(), this.max = B.clone()) : (this.min.x = Math.min(A.x, this.min.x), this.max.x = Math.max(B.x, this.max.x), this.min.y = Math.min(A.y, this.min.y), this.max.y = Math.max(B.y, this.max.y)), this; }, // @method getCenter(round?: Boolean): Point // Returns the center point of the bounds. getCenter: function(p) { return ni( (this.min.x + this.max.x) / 2, (this.min.y + this.max.y) / 2, p ); }, // @method getBottomLeft(): Point // Returns the bottom-left point of the bounds. getBottomLeft: function() { return ni(this.min.x, this.max.y); }, // @method getTopRight(): Point // Returns the top-right point of the bounds. getTopRight: function() { return ni(this.max.x, this.min.y); }, // @method getTopLeft(): Point // Returns the top-left point of the bounds (i.e. [`this.min`](#bounds-min)). getTopLeft: function() { return this.min; }, // @method getBottomRight(): Point // Returns the bottom-right point of the bounds (i.e. [`this.max`](#bounds-max)). getBottomRight: function() { return this.max; }, // @method getSize(): Point // Returns the size of the given bounds getSize: function() { return this.max.subtract(this.min); }, // @method contains(otherBounds: Bounds): Boolean // Returns `true` if the rectangle contains the given one. // @alternative // @method contains(point: Point): Boolean // Returns `true` if the rectangle contains the given point. contains: function(p) { var A, B; return typeof p[0] == "number" || p instanceof fi ? p = ni(p) : p = an(p), p instanceof Gi ? (A = p.min, B = p.max) : A = B = p, A.x >= this.min.x && B.x <= this.max.x && A.y >= this.min.y && B.y <= this.max.y; }, // @method intersects(otherBounds: Bounds): Boolean // Returns `true` if the rectangle intersects the given bounds. Two bounds // intersect if they have at least one point in common. intersects: function(p) { p = an(p); var A = this.min, B = this.max, X = p.min, ne = p.max, ye = ne.x >= A.x && X.x <= B.x, We = ne.y >= A.y && X.y <= B.y; return ye && We; }, // @method overlaps(otherBounds: Bounds): Boolean // Returns `true` if the rectangle overlaps the given bounds. Two bounds // overlap if their intersection is an area. overlaps: function(p) { p = an(p); var A = this.min, B = this.max, X = p.min, ne = p.max, ye = ne.x > A.x && X.x < B.x, We = ne.y > A.y && X.y < B.y; return ye && We; }, // @method isValid(): Boolean // Returns `true` if the bounds are properly initialized. isValid: function() { return !!(this.min && this.max); }, // @method pad(bufferRatio: Number): Bounds // Returns bounds created by extending or retracting the current bounds by a given ratio in each direction. // For example, a ratio of 0.5 extends the bounds by 50% in each direction. // Negative values will retract the bounds. pad: function(p) { var A = this.min, B = this.max, X = Math.abs(A.x - B.x) * p, ne = Math.abs(A.y - B.y) * p; return an( ni(A.x - X, A.y - ne), ni(B.x + X, B.y + ne) ); }, // @method equals(otherBounds: Bounds): Boolean // Returns `true` if the rectangle is equivalent to the given bounds. equals: function(p) { return p ? (p = an(p), this.min.equals(p.getTopLeft()) && this.max.equals(p.getBottomRight())) : !1; } }; function an(p, A) { return !p || p instanceof Gi ? p : new Gi(p, A); } function qt(p, A) { if (p) for (var B = A ? [p, A] : p, X = 0, ne = B.length; X < ne; X++) this.extend(B[X]); } qt.prototype = { // @method extend(latlng: LatLng): this // Extend the bounds to contain the given point // @alternative // @method extend(otherBounds: LatLngBounds): this // Extend the bounds to contain the given bounds extend: function(p) { var A = this._southWest, B = this._northEast, X, ne; if (p instanceof Di) X = p, ne = p; else if (p instanceof qt) { if (X = p._southWest, ne = p._northEast, !X || !ne) return this; } else return p ? this.extend(xi(p) || ln(p)) : this; return !A && !B ? (this._southWest = new Di(X.lat, X.lng), this._northEast = new Di(ne.lat, ne.lng)) : (A.lat = Math.min(X.lat, A.lat), A.lng = Math.min(X.lng, A.lng), B.lat = Math.max(ne.lat, B.lat), B.lng = Math.max(ne.lng, B.lng)), this; }, // @method pad(bufferRatio: Number): LatLngBounds // Returns bounds created by extending or retracting the current bounds by a given ratio in each direction. // For example, a ratio of 0.5 extends the bounds by 50% in each direction. // Negative values will retract the bounds. pad: function(p) { var A = this._southWest, B = this._northEast, X = Math.abs(A.lat - B.lat) * p, ne = Math.abs(A.lng - B.lng) * p; return new qt( new Di(A.lat - X, A.lng - ne), new Di(B.lat + X, B.lng + ne) ); }, // @method getCenter(): LatLng // Returns the center point of the bounds. getCenter: function() { return new Di( (this._southWest.lat + this._northEast.lat) / 2, (this._southWest.lng + this._northEast.lng) / 2 ); }, // @method getSouthWest(): LatLng // Returns the south-west point of the bounds. getSouthWest: function() { return this._southWest; }, // @method getNorthEast(): LatLng // Returns the north-east point of the bounds. getNorthEast: function() { return this._northEast; }, // @method getNorthWest(): LatLng // Returns the north-west point of the bounds. getNorthWest: function() { return new Di(this.getNorth(), this.getWest()); }, // @method getSouthEast(): LatLng // Returns the south-east point of the bounds. getSouthEast: function() { return new Di(this.getSouth(), this.getEast()); }, // @method getWest(): Number // Returns the west longitude of the bounds getWest: function() { return this._southWest.lng; }, // @method getSouth(): Number // Returns the south latitude of the bounds getSouth: function() { return this._southWest.lat; }, // @method getEast(): Number // Returns the east longitude of the bounds getEast: function() { return this._northEast.lng; }, // @method getNorth(): Number // Returns the north latitude of the bounds getNorth: function() { return this._northEast.lat; }, // @method contains(otherBounds: LatLngBounds): Boolean // Returns `true` if the rectangle contains the given one. // @alternative // @method contains (latlng: LatLng): Boolean // Returns `true` if the rectangle contains the given point. contains: function(p) { typeof p[0] == "number" || p instanceof Di || "lat" in p ? p = xi(p) : p = ln(p); var A = this._southWest, B = this._northEast, X, ne; return p instanceof qt ? (X = p.getSouthWest(), ne = p.getNorthEast()) : X = ne = p, X.lat >= A.lat && ne.lat <= B.lat && X.lng >= A.lng && ne.lng <= B.lng; }, // @method intersects(otherBounds: LatLngBounds): Boolean // Returns `true` if the rectangle intersects the given bounds. Two bounds intersect if they have at least one point in common. intersects: function(p) { p = ln(p); var A = this._southWest, B = this._northEast, X = p.getSouthWest(), ne = p.getNorthEast(), ye = ne.lat >= A.lat && X.lat <= B.lat, We = ne.lng >= A.lng && X.lng <= B.lng; return ye && We; }, // @method overlaps(otherBounds: LatLngBounds): Boolean // Returns `true` if the rectangle overlaps the given bounds. Two bounds overlap if their intersection is an area. overlaps: function(p) { p = ln(p); var A = this._southWest, B = this._northEast, X = p.getSouthWest(), ne = p.getNorthEast(), ye = ne.lat > A.lat && X.lat < B.lat, We = ne.lng > A.lng && X.lng < B.lng; return ye && We; }, // @method toBBoxString(): String // Returns a string with bounding box coordinates in a 'southwest_lng,southwest_lat,northeast_lng,northeast_lat' format. Useful for sending requests to web services that return geo data. toBBoxString: function() { return [this.getWest(), this.getSouth(), this.getEast(), this.getNorth()].join(","); }, // @method equals(otherBounds: LatLngBounds, maxMargin?: Number): Boolean // Returns `true` if the rectangle is equivalent (within a small margin of error) to the given bounds. The margin of error can be overridden by setting `maxMargin` to a small number. equals: function(p, A) { return p ? (p = ln(p), this._southWest.equals(p.getSouthWest(), A) && this._northEast.equals(p.getNorthEast(), A)) : !1; }, // @method isValid(): Boolean // Returns `true` if the bounds are properly initialized. isValid: function() { return !!(this._southWest && this._northEast); } }; function ln(p, A) { return p instanceof qt ? p : new qt(p, A); } function Di(p, A, B) { if (isNaN(p) || isNaN(A)) throw new Error("Invalid LatLng object: (" + p + ", " + A + ")"); this.lat = +p, this.lng = +A, B !== void 0 && (this.alt = +B); } Di.prototype = { // @method equals(otherLatLng: LatLng, maxMargin?: Number): Boolean // Returns `true` if the given `LatLng` point is at the same position (within a small margin of error). The margin of error can be overridden by setting `maxMargin` to a small number. equals: function(p, A) { if (!p) return !1; p = xi(p); var B = Math.max( Math.abs(this.lat - p.lat), Math.abs(this.lng - p.lng) ); return B <= (A === void 0 ? 1e-9 : A); }, // @method toString(): String // Returns a string representation of the point (for debugging purposes). toString: function(p) { return "LatLng(" + ae(this.lat, p) + ", " + ae(this.lng, p) + ")"; }, // @method distanceTo(otherLatLng: LatLng): Number // Returns the distance (in meters) to the given `LatLng` calculated using the [Spherical Law of Cosines](https://en.wikipedia.org/wiki/Spherical_law_of_cosines). distanceTo: function(p) { return xs.distance(this, xi(p)); }, // @method wrap(): LatLng // Returns a new `LatLng` object with the longitude wrapped so it's always between -180 and +180 degrees. wrap: function() { return xs.wrapLatLng(this); }, // @method toBounds(sizeInMeters: Number): LatLngBounds // Returns a new `LatLngBounds` object in which each boundary is `sizeInMeters/2` meters apart from the `LatLng`. toBounds: function(p) { var A = 180 * p / 40075017, B = A / Math.cos(Math.PI / 180 * this.lat); return ln( [this.lat - A, this.lng - B], [this.lat + A, this.lng + B] ); }, clone: function() { return new Di(this.lat, this.lng, this.alt); } }; function xi(p, A, B) { return p instanceof Di ? p : vt(p) && typeof p[0] != "object" ? p.length === 3 ? new Di(p[0], p[1], p[2]) : p.length === 2 ? new Di(p[0], p[1]) : null : p == null ? p : typeof p == "object" && "lat" in p ? new Di(p.lat, "lng" in p ? p.lng : p.lon, p.alt) : A === void 0 ? null : new Di(p, A, B); } var Cs = { // @method latLngToPoint(latlng: LatLng, zoom: Number): Point // Projects geographical coordinates into pixel coordinates for a given zoom. latLngToPoint: function(p, A) { var B = this.projection.project(p), X = this.scale(A); return this.transformation._transform(B, X); }, // @method pointToLatLng(point: Point, zoom: Number): LatLng // The inverse of `latLngToPoint`. Projects pixel coordinates on a given // zoom into geographical coordinates. pointToLatLng: function(p, A) { var B = this.scale(A), X = this.transformation.untransform(p, B); return this.projection.unproject(X); }, // @method project(latlng: LatLng): Point // Projects geographical coordinates into coordinates in units accepted for // this CRS (e.g. meters for EPSG:3857, for passing it to WMS services). project: function(p) { return this.projection.project(p); }, // @method unproject(point: Point): LatLng // Given a projected coordinate returns the corresponding LatLng. // The inverse of `project`. unproject: function(p) { return this.projection.unproject(p); }, // @method scale(zoom: Number): Number // Returns the scale used when transforming projected coordinates into // pixel coordinates for a particular zoom. For example, it returns // `256 * 2^zoom` for Mercator-based CRS. scale: function(p) { return 256 * Math.pow(2, p); }, // @method zoom(scale: Number): Number // Inverse of `scale()`, returns the zoom level corresponding to a scale // factor of `scale`. zoom: function(p) { return Math.log(p / 256) / Math.LN2; }, // @method getProjectedBounds(zoom: Number): Bounds // Returns the projection's bounds scaled and transformed for the provided `zoom`. getProjectedBounds: function(p) { if (this.infinite) return null; var A = this.projection.bounds, B = this.scale(p), X = this.transformation.transform(A.min, B), ne = this.transformation.transform(A.max, B); return new Gi(X, ne); }, // @method distance(latlng1: LatLng, latlng2: LatLng): Number // Returns the distance between two geographical coordinates. // @property code: String // Standard code name of the CRS passed into WMS services (e.g. `'EPSG:3857'`) // // @property wrapLng: Number[] // An array of two numbers defining whether the longitude (horizontal) coordinate // axis wraps around a given range and how. Defaults to `[-180, 180]` in most // geographical CRSs. If `undefined`, the longitude axis does not wrap around. // // @property wrapLat: Number[] // Like `wrapLng`, but for the latitude (vertical) axis. // wrapLng: [min, max], // wrapLat: [min, max], // @property infinite: Boolean // If true, the coordinate space will be unbounded (infinite in both axes) infinite: !1, // @method wrapLatLng(latlng: LatLng): LatLng // Returns a `LatLng` where lat and lng has been wrapped according to the // CRS's `wrapLat` and `wrapLng` properties, if they are outside the CRS's bounds. wrapLatLng: function(p) { var A = this.wrapLng ? Y(p.lng, this.wrapLng, !0) : p.lng, B = this.wrapLat ? Y(p.lat, this.wrapLat, !0) : p.lat, X = p.alt; return new Di(B, A, X); }, // @method wrapLatLngBounds(bounds: LatLngBounds): LatLngBounds // Returns a `LatLngBounds` with the same size as the given one, ensuring // that its center is within the CRS's bounds. // Only accepts actual `L.LatLngBounds` instances, not arrays. wrapLatLngBounds: function(p) { var A = p.getCenter(), B = this.wrapLatLng(A), X = A.lat - B.lat, ne = A.lng - B.lng; if (X === 0 && ne === 0) return p; var ye = p.getSouthWest(), We = p.getNorthEast(), at = new Di(ye.lat - X, ye.lng - ne), ft = new Di(We.lat - X, We.lng - ne); return new qt(at, ft); } }, xs = w({}, Cs, { wrapLng: [-180, 180], // Mean Earth Radius, as recommended for use by // the International Union of Geodesy and Geophysics, // see https://rosettacode.org/wiki/Haversine_formula R: 6371e3, // distance between two geographical points using spherical law of cosines approximation distance: function(p, A) { var B = Math.PI / 180, X = p.lat * B, ne = A.lat * B, ye = Math.sin((A.lat - p.lat) * B / 2), We = Math.sin((A.lng - p.lng) * B / 2), at = ye * ye + Math.cos(X) * Math.cos(ne) * We * We, ft = 2 * Math.atan2(Math.sqrt(at), Math.sqrt(1 - at)); return this.R * ft; } }), Is = 6378137, De = { R: Is, MAX_LATITUDE: 85.0511287798, project: function(p) { var A = Math.PI / 180, B = this.MAX_LATITUDE, X = Math.max(Math.min(B, p.lat), -B), ne = Math.sin(X * A); return new fi( this.R * p.lng * A, this.R * Math.log((1 + ne) / (1 - ne)) / 2 ); }, unproject: function(p) { var A = 180 / Math.PI; return new Di( (2 * Math.atan(Math.exp(p.y / this.R)) - Math.PI / 2) * A, p.x * A / this.R ); }, bounds: function() { var p = Is * Math.PI; return new Gi([-p, -p], [p, p]); }() }; function Vs(p, A, B, X) { if (vt(p)) { this._a = p[0], this._b = p[1], this._c = p[2], this._d = p[3]; return; } this._a = p, this._b = A, this._c = B, this._d = X; } Vs.prototype = { // @method transform(point: Point, scale?: Number): Point // Returns a transformed point, optionally multiplied by the given scale. // Only accepts actual `L.Point` instances, not arrays. transform: function(p, A) { return this._transform(p.clone(), A); }, // destructive transform (faster) _transform: function(p, A) { return A = A || 1, p.x = A * (this._a * p.x + this._b), p.y = A * (this._c * p.y + this._d), p; }, // @method untransform(point: Point, scale?: Number): Point // Returns the reverse transformation of the given point, optionally divided // by the given scale. Only accepts actual `L.Point` instances, not arrays. untransform: function(p, A) { return A = A || 1, new fi( (p.x / A - this._b) / this._a, (p.y / A - this._d) / this._c ); } }; function Us(p, A, B, X) { return new Vs(p, A, B, X); } var Zr = w({}, xs, { code: "EPSG:3857", projection: De, transformation: function() { var p = 0.5 / (Math.PI * De.R); return Us(p, 0.5, -p, 0.5); }() }), Et = w({}, Zr, { code: "EPSG:900913" }); function Ws(p) { return document.createElementNS("http://www.w3.org/2000/svg", p); } function $n(p, A) { var B = "", X, ne, ye, We, at, ft; for (X = 0, ye = p.length; X < ye; X++) { for (at = p[X], ne = 0, We = at.length; ne < We; ne++) ft = at[ne], B += (ne ? "L" : "M") + ft.x + " " + ft.y; B += A ? Pe.svg ? "z" : "x" : ""; } return B || "M0 0"; } var $s = document.documentElement.style, vi = "ActiveXObject" in window, kn = vi && !document.addEventListener, Xs = "msLaunchUri" in navigator && !("documentMode" in document), Hr = qe("webkit"), qr = qe("android"), Wr = qe("android 2") || qe("android 3"), si = parseInt(/WebKit\/([0-9]+)|$/.exec(navigator.userAgent)[1], 10), fs = qr && qe("Google") && si < 537 && !("AudioNode" in window), zn = !!window.opera, Rn = !Xs && qe("chrome"), An = qe("gecko") && !Hr && !zn && !vi, js = !Rn && qe("safari"), yo = qe("phantom"), xo = "OTransition" in $s, vo = navigator.platform.indexOf("Win") === 0, yr = vi && "transition" in $s, Mr = "WebKitCSSMatrix" in window && "m11" in new window.WebKitCSSMatrix() && !Wr, io = "MozPerspective" in $s, Ys = !window.L_DISABLE_3D && (yr || Mr || io) && !xo && !yo, Sr = typeof orientation < "u" || qe("mobile"), mi = Sr && Hr, On = Sr && Mr, Vn = !window.PointerEvent && window.MSPointerEvent, Zi = !!(window.PointerEvent || Vn), Jn = "ontouchstart" in window || !!window.TouchEvent, Fn = !window.L_NO_TOUCH && (Jn || Zi), Ls = Sr && zn, zs = Sr && An, Vo = (window.devicePixelRatio || window.screen.deviceXDPI / window.screen.logicalXDPI) > 1, Ke = function() { var p = !1; try { var A = Object.defineProperty({}, "passive", { get: function() { p = !0; } }); window.addEventListener("testPassiveEventSupport", J, A), window.removeEventListener("testPassiveEventSupport", J, A); } catch { } return p; }(), re = function() { return !!document.createElement("canvas").getContext; }(), le = !!(document.createElementNS && Ws("svg").createSVGRect), ge = !!le && function() { var p = document.createElement("div"); return p.innerHTML = "", (p.firstChild && p.firstChild.namespaceURI) === "http://www.w3.org/2000/svg"; }(), Le = !le && function() { try { var p = document.createElement("div"); p.innerHTML = ''; var A = p.firstChild; return A.style.behavior = "url(#default#VML)", A && typeof A.adj == "object"; } catch { return !1; } }(), Ce = navigator.platform.indexOf("Mac") === 0, Be = navigator.platform.indexOf("Linux") === 0; function qe(p) { return navigator.userAgent.toLowerCase().indexOf(p) >= 0; } var Pe = { ie: vi, ielt9: kn, edge: Xs, webkit: Hr, android: qr, android23: Wr, androidStock: fs, opera: zn, chrome: Rn, gecko: An, safari: js, phantom: yo, opera12: xo, win: vo, ie3d: yr, webkit3d: Mr, gecko3d: io, any3d: Ys, mobile: Sr, mobileWebkit: mi, mobileWebkit3d: On, msPointer: Vn, pointer: Zi, touch: Fn, touchNative: Jn, mobileOpera: Ls, mobileGecko: zs, retina: Vo, passiveEvents: Ke, canvas: re, svg: le, vml: Le, inlineSvg: ge, mac: Ce, linux: Be }, Ye = Pe.msPointer ? "MSPointerDown" : "pointerdown", Qe = Pe.msPointer ? "MSPointerMove" : "pointermove", it = Pe.msPointer ? "MSPointerUp" : "pointerup", mt = Pe.msPointer ? "MSPointerCancel" : "pointercancel", Ct = { touchstart: Ye, touchmove: Qe, touchend: it, touchcancel: mt }, It = { touchstart: Xn, touchmove: Hi, touchend: Hi, touchcancel: Hi }, Kt = {}, di = !1; function li(p, A, B) { return A === "touchstart" && $i(), It[A] ? (B = It[A].bind(this, B), p.addEventListener(Ct[A], B, !1), B) : (console.warn("wrong event specified:", A), J); } function ri(p, A, B) { if (!Ct[A]) { console.warn("wrong event specified:", A); return; } p.removeEventListener(Ct[A], B, !1); } function Ki(p) { Kt[p.pointerId] = p; } function Ni(p) { Kt[p.pointerId] && (Kt[p.pointerId] = p); } function Ei(p) { delete Kt[p.pointerId]; } function $i() { di || (document.addEventListener(Ye, Ki, !0), document.addEventListener(Qe, Ni, !0), document.addEventListener(it, Ei, !0), document.addEventListener(mt, Ei, !0), di = !0); } function Hi(p, A) { if (A.pointerType !== (A.MSPOINTER_TYPE_MOUSE || "mouse")) { A.touches = []; for (var B in Kt) A.touches.push(Kt[B]); A.changedTouches = [A], p(A); } } function Xn(p, A) { A.MSPOINTER_TYPE_TOUCH && A.pointerType === A.MSPOINTER_TYPE_TOUCH && _s(A), Hi(p, A); } function Gs(p) { var A = {}, B, X; for (X in p) B = p[X], A[X] = B && B.bind ? B.bind(p) : B; return p = A, A.type = "dblclick", A.detail = 2, A.isTrusted = !1, A._simulated = !0, A; } var ps = 200; function vs(p, A) { p.addEventListener("dblclick", A); var B = 0, X; function ne(ye) { if (ye.detail !== 1) { X = ye.detail; return; } if (!(ye.pointerType === "mouse" || ye.sourceCapabilities && !ye.sourceCapabilities.firesTouchEvents)) { var We = Ho(ye); if (!(We.some(function(ft) { return ft instanceof HTMLLabelElement && ft.attributes.for; }) && !We.some(function(ft) { return ft instanceof HTMLInputElement || ft instanceof HTMLSelectElement; }))) { var at = Date.now(); at - B <= ps ? (X++, X === 2 && A(Gs(ye))) : X = 1, B = at; } } } return p.addEventListener("click", ne), { dblclick: A, simDblclick: ne }; } function ra(p, A) { p.removeEventListener("dblclick", A.dblclick), p.removeEventListener("click", A.simDblclick); } var Er = nr( ["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"] ), oa = nr( ["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"] ), cl = oa === "webkitTransition" || oa === "OTransition" ? oa + "End" : "transitionend"; function Uo(p) { return typeof p == "string" ? document.getElementById(p) : p; } function jo(p, A) { var B = p.style[A] || p.currentStyle && p.currentStyle[A]; if ((!B || B === "auto") && document.defaultView) { var X = document.defaultView.getComputedStyle(p, null); B = X ? X[A] : null; } return B === "auto" ? null : B; } function tn(p, A, B) { var X = document.createElement(p); return X.className = A || "", B && B.appendChild(X), X; } function xn(p) { var A = p.parentNode; A && A.removeChild(p); } function no(p) { for (; p.firstChild; ) p.removeChild(p.firstChild); } function Go(p) { var A = p.parentNode; A && A.lastChild !== p && A.appendChild(p); } function aa(p) { var A = p.parentNode; A && A.firstChild !== p && A.insertBefore(p, A.firstChild); } function Da(p, A) { if (p.classList !== void 0) return p.classList.contains(A); var B = Zs(p); return B.length > 0 && new RegExp("(^|\\s)" + A + "(\\s|$)").test(B); } function Vi(p, A) { if (p.classList !== void 0) for (var B = Te(A), X = 0, ne = B.length; X < ne; X++) p.classList.add(B[X]); else if (!Da(p, A)) { var ye = Zs(p); hl(p, (ye ? ye + " " : "") + A); } } function Hn(p, A) { p.classList !== void 0 ? p.classList.remove(A) : hl(p, ce((" " + Zs(p) + " ").replace(" " + A + " ", " "))); } function hl(p, A) { p.className.baseVal === void 0 ? p.className = A : p.className.baseVal = A; } function Zs(p) { return p.correspondingElement && (p = p.correspondingElement), p.className.baseVal === void 0 ? p.className : p.className.baseVal; } function Qn(p, A) { "opacity" in p.style ? p.style.opacity = A : "filter" in p.style && Pr(p, A); } function Pr(p, A) { var B = !1, X = "DXImageTransform.Microsoft.Alpha"; try { B = p.filters.item(X); } catch { if (A === 1) return; } A = Math.round(A * 100), B ? (B.Enabled = A !== 100, B.Opacity = A) : p.style.filter += " progid:" + X + "(opacity=" + A + ")"; } function nr(p) { for (var A = document.documentElement.style, B = 0; B < p.length; B++) if (p[B] in A) return p[B]; return !1; } function Ks(p, A, B) { var X = A || new fi(0, 0); p.style[Er] = (Pe.ie3d ? "translate(" + X.x + "px," + X.y + "px)" : "translate3d(" + X.x + "px," + X.y + "px,0)") + (B ? " scale(" + B + ")" : ""); } function Yn(p, A) { p._leaflet_pos = A, Pe.any3d ? Ks(p, A) : (p.style.left = A.x + "px", p.style.top = A.y + "px"); } function $r(p) { return p._leaflet_pos || new fi(0, 0); } var Ar, Cr, ka; if ("onselectstart" in document) Ar = function() { Bi(window, "selectstart", _s); }, Cr = function() { Cn(window, "selectstart", _s); }; else { var la = nr( ["userSelect", "WebkitUserSelect", "OUserSelect", "MozUserSelect", "msUserSelect"] ); Ar = function() { if (la) { var p = document.documentElement.style; ka = p[la], p[la] = "none"; } }, Cr = function() { la && (document.documentElement.style[la] = ka, ka = void 0); }; } function Zo() { Bi(window, "dragstart", _s); } function sr() { Cn(window, "dragstart", _s); } var ca, Ra; function ki(p) { for (; p.tabIndex === -1; ) p = p.parentNode; p.style && (Gl(), ca = p, Ra = p.style.outlineStyle, p.style.outlineStyle = "none", Bi(window, "keydown", Gl)); } function Gl() { ca && (ca.style.outlineStyle = Ra, ca = void 0, Ra = void 0, Cn(window, "keydown", Gl)); } function ei(p) { do p = p.parentNode; while ((!p.offsetWidth || !p.offsetHeight) && p !== document.body); return p; } function ul(p) { var A = p.getBoundingClientRect(); return { x: A.width / p.offsetWidth || 1, y: A.height / p.offsetHeight || 1, boundingClientRect: A }; } var Oi = { __proto__: null, TRANSFORM: Er, TRANSITION: oa, TRANSITION_END: cl, get: Uo, getStyle: jo, create: tn, remove: xn, empty: no, toFront: Go, toBack: aa, hasClass: Da, addClass: Vi, removeClass: Hn, setClass: hl, getClass: Zs, setOpacity: Qn, testProp: nr, setTransform: Ks, setPosition: Yn, getPosition: $r, get disableTextSelection() { return Ar; }, get enableTextSelection() { return Cr; }, disableImageDrag: Zo, enableImageDrag: sr, preventOutline: ki, restoreOutline: Gl, getSizedParentNode: ei, getScale: ul }; function Bi(p, A, B, X) { if (A && typeof A == "object") for (var ne in A) Fi(p, ne, A[ne], B); else { A = Te(A); for (var ye = 0, We = A.length; ye < We; ye++) Fi(p, A[ye], B, X); } return this; } var ns = "_leaflet_events"; function Cn(p, A, B, X) { if (arguments.length === 1) ha(p), delete p[ns]; else if (A && typeof A == "object") for (var ne in A) Li(p, ne, A[ne], B); else if (A = Te(A), arguments.length === 2) ha(p, function(at) { return ht(A, at) !== -1; }); else for (var ye = 0, We = A.length; ye < We; ye++) Li(p, A[ye], B, X); return this; } function ha(p, A) { for (var B in p[ns]) { var X = B.split(/\d/)[0]; (!A || A(X)) && Li(p, X, null, null, B); } } var Ot = { mouseenter: "mouseover", mouseleave: "mouseout", wheel: !("onwheel" in window) && "mousewheel" }; function Fi(p, A, B, X) { var ne = A + O(B) + (X ? "_" + O(X) : ""); if (p[ns] && p[ns][ne]) return this; var ye = function(at) { return B.call(X || p, at || window.event); }, We = ye; !Pe.touchNative && Pe.pointer && A.indexOf("touch") === 0 ? ye = li(p, A, ye) : Pe.touch && A === "dblclick" ? ye = vs(p, ye) : "addEventListener" in p ? A === "touchstart" || A === "touchmove" || A === "wheel" || A === "mousewheel" ? p.addEventListener(Ot[A] || A, ye, Pe.passiveEvents ? { passive: !1 } : !1) : A === "mouseenter" || A === "mouseleave" ? (ye = function(at) { at = at || window.event, ua(p, at) && We(at); }, p.addEventListener(Ot[A], ye, !1)) : p.addEventListener(A, We, !1) : p.attachEvent("on" + A, ye), p[ns] = p[ns] || {}, p[ns][ne] = ye; } function Li(p, A, B, X, ne) { ne = ne || A + O(B) + (X ? "_" + O(X) : ""); var ye = p[ns] && p[ns][ne]; if (!ye) return this; !Pe.touchNative && Pe.pointer && A.indexOf("touch") === 0 ? ri(p, A, ye) : Pe.touch && A === "dblclick" ? ra(p, ye) : "removeEventListener" in p ? p.removeEventListener(Ot[A] || A, ye, !1) : p.detachEvent("on" + A, ye), p[ns][ne] = null; } function ms(p) { return p.stopPropagation ? p.stopPropagation() : p.originalEvent ? p.originalEvent._stopped = !0 : p.cancelBubble = !0, this; } function bo(p) { return Fi(p, "wheel", ms), this; } function Pi(p) { return Bi(p, "mousedown touchstart dblclick contextmenu", ms), p._leaflet_disable_click = !0, this; } function _s(p) { return p.preventDefault ? p.preventDefault() : p.returnValue = !1, this; } function Js(p) { return _s(p), ms(p), this; } function Ho(p) { if (p.composedPath) return p.composedPath(); for (var A = [], B = p.target; B; ) A.push(B), B = B.parentNode; return A; } function Ss(p, A) { if (!A) return new fi(p.clientX, p.clientY); var B = ul(A), X = B.boundingClientRect; return new fi( // offset.left/top values are in page scale (like clientX/Y), // whereas clientLeft/Top (border width) values are the original values (before CSS scale applies). (p.clientX - X.left) / B.x - A.clientLeft, (p.clientY - X.top) / B.y - A.clientTop ); } var un = Pe.linux && Pe.chrome ? window.devicePixelRatio : Pe.mac ? window.devicePixelRatio * 3 : window.devicePixelRatio > 0 ? 2 * window.devicePixelRatio : 1; function Bc(p) { return Pe.edge ? p.wheelDeltaY / 2 : ( // Don't trust window-geometry-based delta p.deltaY && p.deltaMode === 0 ? -p.deltaY / un : ( // Pixels p.deltaY && p.deltaMode === 1 ? -p.deltaY * 20 : ( // Lines p.deltaY && p.deltaMode === 2 ? -p.deltaY * 60 : ( // Pages p.deltaX || p.deltaZ ? 0 : ( // Skip horizontal/depth wheel events p.wheelDelta ? (p.wheelDeltaY || p.wheelDelta) / 2 : ( // Legacy IE pixels p.detail && Math.abs(p.detail) < 32765 ? -p.detail * 20 : ( // Legacy Moz lines p.detail ? p.detail / -32765 * 60 : ( // Legacy Moz pages 0 ) ) ) ) ) ) ) ); } function ua(p, A) { var B = A.relatedTarget; if (!B) return !0; try { for (; B && B !== p; ) B = B.parentNode; } catch { return !1; } return B !== p; } var Zl = { __proto__: null, on: Bi, off: Cn, stopPropagation: ms, disableScrollPropagation: bo, disableClickPropagation: Pi, preventDefault: _s, stop: Js, getPropagationPath: Ho, getMousePosition: Ss, getWheelDelta: Bc, isExternalTarget: ua, addListener: Bi, removeListener: Cn }, da = Ji.extend({ // @method run(el: HTMLElement, newPos: Point, duration?: Number, easeLinearity?: Number) // Run an animation of a given element to a new position, optionally setting // duration in seconds (`0.25` by default) and easing linearity factor (3rd // argument of the [cubic bezier curve](https://cubic-bezier.com/#0,0,.5,1), // `0.5` by default). run: function(p, A, B, X) { this.stop(), this._el = p, this._inProgress = !0, this._duration = B || 0.25, this._easeOutPower = 1 / Math.max(X || 0.5, 0.2), this._startPos = $r(p), this._offset = A.subtract(this._startPos), this._startTime = +/* @__PURE__ */ new Date(), this.fire("start"), this._animate(); }, // @method stop() // Stops the animation (if currently running). stop: function() { this._inProgress && (this._step(!0), this._complete()); }, _animate: function() { this._animId = Pt(this._animate, this), this._step(); }, _step: function(p) { var A = +/* @__PURE__ */ new Date() - this._startTime, B = this._duration * 1e3; A < B ? this._runFrame(this._easeOut(A / B), p) : (this._runFrame(1), this._complete()); }, _runFrame: function(p, A) { var B = this._startPos.add(this._offset.multiplyBy(p)); A && B._round(), Yn(this._el, B), this.fire("step"); }, _complete: function() { Mi(this._animId), this._inProgress = !1, this.fire("end"); }, _easeOut: function(p) { return 1 - Math.pow(1 - p, this._easeOutPower); } }), nn = Ji.extend({ options: { // @section Map State Options // @option crs: CRS = L.CRS.EPSG3857 // The [Coordinate Reference System](#crs) to use. Don't change this if you're not // sure what it means. crs: Zr, // @option center: LatLng = undefined // Initial geographic center of the map center: void 0, // @option zoom: Number = undefined // Initial map zoom level zoom: void 0, // @option minZoom: Number = * // Minimum zoom level of the map. // If not specified and at least one `GridLayer` or `TileLayer` is in the map, // the lowest of their `minZoom` options will be used instead. minZoom: void 0, // @option maxZoom: Number = * // Maximum zoom level of the map. // If not specified and at least one `GridLayer` or `TileLayer` is in the map, // the highest of their `maxZoom` options will be used instead. maxZoom: void 0, // @option layers: Layer[] = [] // Array of layers that will be added to the map initially layers: [], // @option maxBounds: LatLngBounds = null // When this option is set, the map restricts the view to the given // geographical bounds, bouncing the user back if the user tries to pan // outside the view. To set the restriction dynamically, use // [`setMaxBounds`](#map-setmaxbounds) method. maxBounds: void 0, // @option renderer: Renderer = * // The default method for drawing vector layers on the map. `L.SVG` // or `L.Canvas` by default depending on browser support. renderer: void 0, // @section Animation Options // @option zoomAnimation: Boolean = true // Whether the map zoom animation is enabled. By default it's enabled // in all browsers that support CSS3 Transitions except Android. zoomAnimation: !0, // @option zoomAnimationThreshold: Number = 4 // Won't animate zoom if the zoom difference exceeds this value. zoomAnimationThreshold: 4, // @option fadeAnimation: Boolean = true // Whether the tile fade animation is enabled. By default it's enabled // in all browsers that support CSS3 Transitions except Android. fadeAnimation: !0, // @option markerZoomAnimation: Boolean = true // Whether markers animate their zoom with the zoom animation, if disabled // they will disappear for the length of the animation. By default it's // enabled in all browsers that support CSS3 Transitions except Android. markerZoomAnimation: !0, // @option transform3DLimit: Number = 2^23 // Defines the maximum size of a CSS translation transform. The default // value should not be changed unless a web browser positions layers in // the wrong place after doing a large `panBy`. transform3DLimit: 8388608, // Precision limit of a 32-bit float // @section Interaction Options // @option zoomSnap: Number = 1 // Forces the map's zoom level to always be a multiple of this, particularly // right after a [`fitBounds()`](#map-fitbounds) or a pinch-zoom. // By default, the zoom level snaps to the nearest integer; lower values // (e.g. `0.5` or `0.1`) allow for greater granularity. A value of `0` // means the zoom level will not be snapped after `fitBounds` or a pinch-zoom. zoomSnap: 1, // @option zoomDelta: Number = 1 // Controls how much the map's zoom level will change after a // [`zoomIn()`](#map-zoomin), [`zoomOut()`](#map-zoomout), pressing `+` // or `-` on the keyboard, or using the [zoom controls](#control-zoom). // Values smaller than `1` (e.g. `0.5`) allow for greater granularity. zoomDelta: 1, // @option trackResize: Boolean = true // Whether the map automatically handles browser window resize to update itself. trackResize: !0 }, initialize: function(p, A) { A = be(this, A), this._handlers = [], this._layers = {}, this._zoomBoundLayers = {}, this._sizeChanged = !0, this._initContainer(p), this._initLayout(), this._onResize = E(this._onResize, this), this._initEvents(), A.maxBounds && this.setMaxBounds(A.maxBounds), A.zoom !== void 0 && (this._zoom = this._limitZoom(A.zoom)), A.center && A.zoom !== void 0 && this.setView(xi(A.center), A.zoom, { reset: !0 }), this.callInitHooks(), this._zoomAnimated = oa && Pe.any3d && !Pe.mobileOpera && this.options.zoomAnimation, this._zoomAnimated && (this._createAnimProxy(), Bi(this._proxy, cl, this._catchTransitionEnd, this)), this._addLayers(this.options.layers); }, // @section Methods for modifying map state // @method setView(center: LatLng, zoom: Number, options?: Zoom/pan options): this // Sets the view of the map (geographical center and zoom) with the given // animation options. setView: function(p, A, B) { if (A = A === void 0 ? this._zoom : this._limitZoom(A), p = this._limitCenter(xi(p), A, this.options.maxBounds), B = B || {}, this._stop(), this._loaded && !B.reset && B !== !0) { B.animate !== void 0 && (B.zoom = w({ animate: B.animate }, B.zoom), B.pan = w({ animate: B.animate, duration: B.duration }, B.pan)); var X = this._zoom !== A ? this._tryAnimatedZoom && this._tryAnimatedZoom(p, A, B.zoom) : this._tryAnimatedPan(p, B.pan); if (X) return clearTimeout(this._sizeTimer), this; } return this._resetView(p, A, B.pan && B.pan.noMoveStart), this; }, // @method setZoom(zoom: Number, options?: Zoom/pan options): this // Sets the zoom of the map. setZoom: function(p, A) { return this._loaded ? this.setView(this.getCenter(), p, { zoom: A }) : (this._zoom = p, this); }, // @method zoomIn(delta?: Number, options?: Zoom options): this // Increases the zoom of the map by `delta` ([`zoomDelta`](#map-zoomdelta) by default). zoomIn: function(p, A) { return p = p || (Pe.any3d ? this.options.zoomDelta : 1), this.setZoom(this._zoom + p, A); }, // @method zoomOut(delta?: Number, options?: Zoom options): this // Decreases the zoom of the map by `delta` ([`zoomDelta`](#map-zoomdelta) by default). zoomOut: function(p, A) { return p = p || (Pe.any3d ? this.options.zoomDelta : 1), this.setZoom(this._zoom - p, A); }, // @method setZoomAround(latlng: LatLng, zoom: Number, options: Zoom options): this // Zooms the map while keeping a specified geographical point on the map // stationary (e.g. used internally for scroll zoom and double-click zoom). // @alternative // @method setZoomAround(offset: Point, zoom: Number, options: Zoom options): this // Zooms the map while keeping a specified pixel on the map (relative to the top-left corner) stationary. setZoomAround: function(p, A, B) { var X = this.getZoomScale(A), ne = this.getSize().divideBy(2), ye = p instanceof fi ? p : this.latLngToContainerPoint(p), We = ye.subtract(ne).multiplyBy(1 - 1 / X), at = this.containerPointToLatLng(ne.add(We)); return this.setView(at, A, { zoom: B }); }, _getBoundsCenterZoom: function(p, A) { A = A || {}, p = p.getBounds ? p.getBounds() : ln(p); var B = ni(A.paddingTopLeft || A.padding || [0, 0]), X = ni(A.paddingBottomRight || A.padding || [0, 0]), ne = this.getBoundsZoom(p, !1, B.add(X)); if (ne = typeof A.maxZoom == "number" ? Math.min(A.maxZoom, ne) : ne, ne === 1 / 0) return { center: p.getCenter(), zoom: ne }; var ye = X.subtract(B).divideBy(2), We = this.project(p.getSouthWest(), ne), at = this.project(p.getNorthEast(), ne), ft = this.unproject(We.add(at).divideBy(2).add(ye), ne); return { center: ft, zoom: ne }; }, // @method fitBounds(bounds: LatLngBounds, options?: fitBounds options): this // Sets a map view that contains the given geographical bounds with the // maximum zoom level possible. fitBounds: function(p, A) { if (p = ln(p), !p.isValid()) throw new Error("Bounds are not valid."); var B = this._getBoundsCenterZoom(p, A); return this.setView(B.center, B.zoom, A); }, // @method fitWorld(options?: fitBounds options): this // Sets a map view that mostly contains the whole world with the maximum // zoom level possible. fitWorld: function(p) { return this.fitBounds([[-90, -180], [90, 180]], p); }, // @method panTo(latlng: LatLng, options?: Pan options): this // Pans the map to a given center. panTo: function(p, A) { return this.setView(p, this._zoom, { pan: A }); }, // @method panBy(offset: Point, options?: Pan options): this // Pans the map by a given number of pixels (animated). panBy: function(p, A) { if (p = ni(p).round(), A = A || {}, !p.x && !p.y) return this.fire("moveend"); if (A.animate !== !0 && !this.getSize().contains(p)) return this._resetView(this.unproject(this.project(this.getCenter()).add(p)), this.getZoom()), this; if (this._panAnim || (this._panAnim = new da(), this._panAnim.on({ step: this._onPanTransitionStep, end: this._onPanTransitionEnd }, this)), A.noMoveStart || this.fire("movestart"), A.animate !== !1) { Vi(this._mapPane, "leaflet-pan-anim"); var B = this._getMapPanePos().subtract(p).round(); this._panAnim.run(this._mapPane, B, A.duration || 0.25, A.easeLinearity); } else this._rawPanBy(p), this.fire("move").fire("moveend"); return this; }, // @method flyTo(latlng: LatLng, zoom?: Number, options?: Zoom/pan options): this // Sets the view of the map (geographical center and zoom) performing a smooth // pan-zoom animation. flyTo: function(p, A, B) { if (B = B || {}, B.animate === !1 || !Pe.any3d) return this.setView(p, A, B); this._stop(); var X = this.project(this.getCenter()), ne = this.project(p), ye = this.getSize(), We = this._zoom; p = xi(p), A = A === void 0 ? We : A; var at = Math.max(ye.x, ye.y), ft = at * this.getZoomScale(We, A), Rt = ne.distanceTo(X) || 1, ii = 1.42, Ci = ii * ii; function Wi(es) { var Ao = es ? -1 : 1, Yh = es ? ft : at, Kh = ft * ft - at * at + Ao * Ci * Ci * Rt * Rt, Yc = 2 * Yh * Ci * Rt, Ha = Kh / Yc, vr = Math.sqrt(Ha * Ha + 1) - Ha, Kc = vr < 1e-9 ? -18 : Math.log(vr); return Kc; } function Hs(es) { return (Math.exp(es) - Math.exp(-es)) / 2; } function ws(es) { return (Math.exp(es) + Math.exp(-es)) / 2; } function Rs(es) { return Hs(es) / ws(es); } var ur = Wi(0); function Za(es) { return at * (ws(ur) / ws(ur + ii * es)); } function nd(es) { return at * (ws(ur) * Rs(ur + ii * es) - Hs(ur)) / Ci; } function sd(es) { return 1 - Math.pow(1 - es, 1.5); } var rd = Date.now(), Xh = (Wi(1) - ur) / ii, wl = B.duration ? 1e3 * B.duration : 1e3 * Xh * 0.8; function ic() { var es = (Date.now() - rd) / wl, Ao = sd(es) * Xh; es <= 1 ? (this._flyToFrame = Pt(ic, this), this._move( this.unproject(X.add(ne.subtract(X).multiplyBy(nd(Ao) / Rt)), We), this.getScaleZoom(at / Za(Ao), We), { flyTo: !0 } )) : this._move(p, A)._moveEnd(!0); } return this._moveStart(!0, B.noMoveStart), ic.call(this), this; }, // @method flyToBounds(bounds: LatLngBounds, options?: fitBounds options): this // Sets the view of the map with a smooth animation like [`flyTo`](#map-flyto), // but takes a bounds parameter like [`fitBounds`](#map-fitbounds). flyToBounds: function(p, A) { var B = this._getBoundsCenterZoom(p, A); return this.flyTo(B.center, B.zoom, A); }, // @method setMaxBounds(bounds: LatLngBounds): this // Restricts the map view to the given bounds (see the [maxBounds](#map-maxbounds) option). setMaxBounds: function(p) { return p = ln(p), this.listens("moveend", this._panInsideMaxBounds) && this.off("moveend", this._panInsideMaxBounds), p.isValid() ? (this.options.maxBounds = p, this._loaded && this._panInsideMaxBounds(), this.on("moveend", this._panInsideMaxBounds)) : (this.options.maxBounds = null, this); }, // @method setMinZoom(zoom: Number): this // Sets the lower limit for the available zoom levels (see the [minZoom](#map-minzoom) option). setMinZoom: function(p) { var A = this.options.minZoom; return this.options.minZoom = p, this._loaded && A !== p && (this.fire("zoomlevelschange"), this.getZoom() < this.options.minZoom) ? this.setZoom(p) : this; }, // @method setMaxZoom(zoom: Number): this // Sets the upper limit for the available zoom levels (see the [maxZoom](#map-maxzoom) option). setMaxZoom: function(p) { var A = this.options.maxZoom; return this.options.maxZoom = p, this._loaded && A !== p && (this.fire("zoomlevelschange"), this.getZoom() > this.options.maxZoom) ? this.setZoom(p) : this; }, // @method panInsideBounds(bounds: LatLngBounds, options?: Pan options): this // Pans the map to the closest view that would lie inside the given bounds (if it's not already), controlling the animation using the options specific, if any. panInsideBounds: function(p, A) { this._enforcingBounds = !0; var B = this.getCenter(), X = this._limitCenter(B, this._zoom, ln(p)); return B.equals(X) || this.panTo(X, A), this._enforcingBounds = !1, this; }, // @method panInside(latlng: LatLng, options?: padding options): this // Pans the map the minimum amount to make the `latlng` visible. Use // padding options to fit the display to more restricted bounds. // If `latlng` is already within the (optionally padded) display bounds, // the map will not be panned. panInside: function(p, A) { A = A || {}; var B = ni(A.paddingTopLeft || A.padding || [0, 0]), X = ni(A.paddingBottomRight || A.padding || [0, 0]), ne = this.project(this.getCenter()), ye = this.project(p), We = this.getPixelBounds(), at = an([We.min.add(B), We.max.subtract(X)]), ft = at.getSize(); if (!at.contains(ye)) { this._enforcingBounds = !0; var Rt = ye.subtract(at.getCenter()), ii = at.extend(ye).getSize().subtract(ft); ne.x += Rt.x < 0 ? -ii.x : ii.x, ne.y += Rt.y < 0 ? -ii.y : ii.y, this.panTo(this.unproject(ne), A), this._enforcingBounds = !1; } return this; }, // @method invalidateSize(options: Zoom/pan options): this // Checks if the map container size changed and updates the map if so — // call it after you've changed the map size dynamically, also animating // pan by default. If `options.pan` is `false`, panning will not occur. // If `options.debounceMoveend` is `true`, it will delay `moveend` event so // that it doesn't happen often even if the method is called many // times in a row. // @alternative // @method invalidateSize(animate: Boolean): this // Checks if the map container size changed and updates the map if so — // call it after you've changed the map size dynamically, also animating // pan by default. invalidateSize: function(p) { if (!this._loaded) return this; p = w({ animate: !1, pan: !0 }, p === !0 ? { animate: !0 } : p); var A = this.getSize(); this._sizeChanged = !0, this._lastCenter = null; var B = this.getSize(), X = A.divideBy(2).round(), ne = B.divideBy(2).round(), ye = X.subtract(ne); return !ye.x && !ye.y ? this : (p.animate && p.pan ? this.panBy(ye) : (p.pan && this._rawPanBy(ye), this.fire("move"), p.debounceMoveend ? (clearTimeout(this._sizeTimer), this._sizeTimer = setTimeout(E(this.fire, this, "moveend"), 200)) : this.fire("moveend")), this.fire("resize", { oldSize: A, newSize: B })); }, // @section Methods for modifying map state // @method stop(): this // Stops the currently running `panTo` or `flyTo` animation, if any. stop: function() { return this.setZoom(this._limitZoom(this._zoom)), this.options.zoomSnap || this.fire("viewreset"), this._stop(); }, // @section Geolocation methods // @method locate(options?: Locate options): this // Tries to locate the user using the Geolocation API, firing a [`locationfound`](#map-locationfound) // event with location data on success or a [`locationerror`](#map-locationerror) event on failure, // and optionally sets the map view to the user's location with respect to // detection accuracy (or to the world view if geolocation failed). // Note that, if your page doesn't use HTTPS, this method will fail in // modern browsers ([Chrome 50 and newer](https://sites.google.com/a/chromium.org/dev/Home/chromium-security/deprecating-powerful-features-on-insecure-origins)) // See `Locate options` for more details. locate: function(p) { if (p = this._locateOptions = w({ timeout: 1e4, watch: !1 // setView: false // maxZoom: // maximumAge: 0 // enableHighAccuracy: false }, p), !("geolocation" in navigator)) return this._handleGeolocationError({ code: 0, message: "Geolocation not supported." }), this; var A = E(this._handleGeolocationResponse, this), B = E(this._handleGeolocationError, this); return p.watch ? this._locationWatchId = navigator.geolocation.watchPosition(A, B, p) : navigator.geolocation.getCurrentPosition(A, B, p), this; }, // @method stopLocate(): this // Stops watching location previously initiated by `map.locate({watch: true})` // and aborts resetting the map view if map.locate was called with // `{setView: true}`. stopLocate: function() { return navigator.geolocation && navigator.geolocation.clearWatch && navigator.geolocation.clearWatch(this._locationWatchId), this._locateOptions && (this._locateOptions.setView = !1), this; }, _handleGeolocationError: function(p) { if (this._container._leaflet_id) { var A = p.code, B = p.message || (A === 1 ? "permission denied" : A === 2 ? "position unavailable" : "timeout"); this._locateOptions.setView && !this._loaded && this.fitWorld(), this.fire("locationerror", { code: A, message: "Geolocation error: " + B + "." }); } }, _handleGeolocationResponse: function(p) { if (this._container._leaflet_id) { var A = p.coords.latitude, B = p.coords.longitude, X = new Di(A, B), ne = X.toBounds(p.coords.accuracy * 2), ye = this._locateOptions; if (ye.setView) { var We = this.getBoundsZoom(ne); this.setView(X, ye.maxZoom ? Math.min(We, ye.maxZoom) : We); } var at = { latlng: X, bounds: ne, timestamp: p.timestamp }; for (var ft in p.coords) typeof p.coords[ft] == "number" && (at[ft] = p.coords[ft]); this.fire("locationfound", at); } }, // TODO Appropriate docs section? // @section Other Methods // @method addHandler(name: String, HandlerClass: Function): this // Adds a new `Handler` to the map, given its name and constructor function. addHandler: function(p, A) { if (!A) return this; var B = this[p] = new A(this); return this._handlers.push(B), this.options[p] && B.enable(), this; }, // @method remove(): this // Destroys the map and clears all related event listeners. remove: function() { if (this._initEvents(!0), this.options.maxBounds && this.off("moveend", this._panInsideMaxBounds), this._containerId !== this._container._leaflet_id) throw new Error("Map container is being reused by another instance"); try { delete this._container._leaflet_id, delete this._containerId; } catch { this._container._leaflet_id = void 0, this._containerId = void 0; } this._locationWatchId !== void 0 && this.stopLocate(), this._stop(), xn(this._mapPane), this._clearControlPos && this._clearControlPos(), this._resizeRequest && (Mi(this._resizeRequest), this._resizeRequest = null), this._clearHandlers(), this._loaded && this.fire("unload"); var p; for (p in this._layers) this._layers[p].remove(); for (p in this._panes) xn(this._panes[p]); return this._layers = [], this._panes = [], delete this._mapPane, delete this._renderer, this; }, // @section Other Methods // @method createPane(name: String, container?: HTMLElement): HTMLElement // Creates a new [map pane](#map-pane) with the given name if it doesn't exist already, // then returns it. The pane is created as a child of `container`, or // as a child of the main map pane if not set. createPane: function(p, A) { var B = "leaflet-pane" + (p ? " leaflet-" + p.replace("Pane", "") + "-pane" : ""), X = tn("div", B, A || this._mapPane); return p && (this._panes[p] = X), X; }, // @section Methods for Getting Map State // @method getCenter(): LatLng // Returns the geographical center of the map view getCenter: function() { return this._checkIfLoaded(), this._lastCenter && !this._moved() ? this._lastCenter.clone() : this.layerPointToLatLng(this._getCenterLayerPoint()); }, // @method getZoom(): Number // Returns the current zoom level of the map view getZoom: function() { return this._zoom; }, // @method getBounds(): LatLngBounds // Returns the geographical bounds visible in the current map view getBounds: function() { var p = this.getPixelBounds(), A = this.unproject(p.getBottomLeft()), B = this.unproject(p.getTopRight()); return new qt(A, B); }, // @method getMinZoom(): Number // Returns the minimum zoom level of the map (if set in the `minZoom` option of the map or of any layers), or `0` by default. getMinZoom: function() { return this.options.minZoom === void 0 ? this._layersMinZoom || 0 : this.options.minZoom; }, // @method getMaxZoom(): Number // Returns the maximum zoom level of the map (if set in the `maxZoom` option of the map or of any layers). getMaxZoom: function() { return this.options.maxZoom === void 0 ? this._layersMaxZoom === void 0 ? 1 / 0 : this._layersMaxZoom : this.options.maxZoom; }, // @method getBoundsZoom(bounds: LatLngBounds, inside?: Boolean, padding?: Point): Number // Returns the maximum zoom level on which the given bounds fit to the map // view in its entirety. If `inside` (optional) is set to `true`, the method // instead returns the minimum zoom level on which the map view fits into // the given bounds in its entirety. getBoundsZoom: function(p, A, B) { p = ln(p), B = ni(B || [0, 0]); var X = this.getZoom() || 0, ne = this.getMinZoom(), ye = this.getMaxZoom(), We = p.getNorthWest(), at = p.getSouthEast(), ft = this.getSize().subtract(B), Rt = an(this.project(at, X), this.project(We, X)).getSize(), ii = Pe.any3d ? this.options.zoomSnap : 1, Ci = ft.x / Rt.x, Wi = ft.y / Rt.y, Hs = A ? Math.max(Ci, Wi) : Math.min(Ci, Wi); return X = this.getScaleZoom(Hs, X), ii && (X = Math.round(X / (ii / 100)) * (ii / 100), X = A ? Math.ceil(X / ii) * ii : Math.floor(X / ii) * ii), Math.max(ne, Math.min(ye, X)); }, // @method getSize(): Point // Returns the current size of the map container (in pixels). getSize: function() { return (!this._size || this._sizeChanged) && (this._size = new fi( this._container.clientWidth || 0, this._container.clientHeight || 0 ), this._sizeChanged = !1), this._size.clone(); }, // @method getPixelBounds(): Bounds // Returns the bounds of the current map view in projected pixel // coordinates (sometimes useful in layer and overlay implementations). getPixelBounds: function(p, A) { var B = this._getTopLeftPoint(p, A); return new Gi(B, B.add(this.getSize())); }, // TODO: Check semantics - isn't the pixel origin the 0,0 coord relative to // the map pane? "left point of the map layer" can be confusing, specially // since there can be negative offsets. // @method getPixelOrigin(): Point // Returns the projected pixel coordinates of the top left point of // the map layer (useful in custom layer and overlay implementations). getPixelOrigin: function() { return this._checkIfLoaded(), this._pixelOrigin; }, // @method getPixelWorldBounds(zoom?: Number): Bounds // Returns the world's bounds in pixel coordinates for zoom level `zoom`. // If `zoom` is omitted, the map's current zoom level is used. getPixelWorldBounds: function(p) { return this.options.crs.getProjectedBounds(p === void 0 ? this.getZoom() : p); }, // @section Other Methods // @method getPane(pane: String|HTMLElement): HTMLElement // Returns a [map pane](#map-pane), given its name or its HTML element (its identity). getPane: function(p) { return typeof p == "string" ? this._panes[p] : p; }, // @method getPanes(): Object // Returns a plain object containing the names of all [panes](#map-pane) as keys and // the panes as values. getPanes: function() { return this._panes; }, // @method getContainer: HTMLElement // Returns the HTML element that contains the map. getContainer: function() { return this._container; }, // @section Conversion Methods // @method getZoomScale(toZoom: Number, fromZoom: Number): Number // Returns the scale factor to be applied to a map transition from zoom level // `fromZoom` to `toZoom`. Used internally to help with zoom animations. getZoomScale: function(p, A) { var B = this.options.crs; return A = A === void 0 ? this._zoom : A, B.scale(p) / B.scale(A); }, // @method getScaleZoom(scale: Number, fromZoom: Number): Number // Returns the zoom level that the map would end up at, if it is at `fromZoom` // level and everything is scaled by a factor of `scale`. Inverse of // [`getZoomScale`](#map-getZoomScale). getScaleZoom: function(p, A) { var B = this.options.crs; A = A === void 0 ? this._zoom : A; var X = B.zoom(p * B.scale(A)); return isNaN(X) ? 1 / 0 : X; }, // @method project(latlng: LatLng, zoom: Number): Point // Projects a geographical coordinate `LatLng` according to the projection // of the map's CRS, then scales it according to `zoom` and the CRS's // `Transformation`. The result is pixel coordinate relative to // the CRS origin. project: function(p, A) { return A = A === void 0 ? this._zoom : A, this.options.crs.latLngToPoint(xi(p), A); }, // @method unproject(point: Point, zoom: Number): LatLng // Inverse of [`project`](#map-project). unproject: function(p, A) { return A = A === void 0 ? this._zoom : A, this.options.crs.pointToLatLng(ni(p), A); }, // @method layerPointToLatLng(point: Point): LatLng // Given a pixel coordinate relative to the [origin pixel](#map-getpixelorigin), // returns the corresponding geographical coordinate (for the current zoom level). layerPointToLatLng: function(p) { var A = ni(p).add(this.getPixelOrigin()); return this.unproject(A); }, // @method latLngToLayerPoint(latlng: LatLng): Point // Given a geographical coordinate, returns the corresponding pixel coordinate // relative to the [origin pixel](#map-getpixelorigin). latLngToLayerPoint: function(p) { var A = this.project(xi(p))._round(); return A._subtract(this.getPixelOrigin()); }, // @method wrapLatLng(latlng: LatLng): LatLng // Returns a `LatLng` where `lat` and `lng` has been wrapped according to the // map's CRS's `wrapLat` and `wrapLng` properties, if they are outside the // CRS's bounds. // By default this means longitude is wrapped around the dateline so its // value is between -180 and +180 degrees. wrapLatLng: function(p) { return this.options.crs.wrapLatLng(xi(p)); }, // @method wrapLatLngBounds(bounds: LatLngBounds): LatLngBounds // Returns a `LatLngBounds` with the same size as the given one, ensuring that // its center is within the CRS's bounds. // By default this means the center longitude is wrapped around the dateline so its // value is between -180 and +180 degrees, and the majority of the bounds // overlaps the CRS's bounds. wrapLatLngBounds: function(p) { return this.options.crs.wrapLatLngBounds(ln(p)); }, // @method distance(latlng1: LatLng, latlng2: LatLng): Number // Returns the distance between two geographical coordinates according to // the map's CRS. By default this measures distance in meters. distance: function(p, A) { return this.options.crs.distance(xi(p), xi(A)); }, // @method containerPointToLayerPoint(point: Point): Point // Given a pixel coordinate relative to the map container, returns the corresponding // pixel coordinate relative to the [origin pixel](#map-getpixelorigin). containerPointToLayerPoint: function(p) { return ni(p).subtract(this._getMapPanePos()); }, // @method layerPointToContainerPoint(point: Point): Point // Given a pixel coordinate relative to the [origin pixel](#map-getpixelorigin), // returns the corresponding pixel coordinate relative to the map container. layerPointToContainerPoint: function(p) { return ni(p).add(this._getMapPanePos()); }, // @method containerPointToLatLng(point: Point): LatLng // Given a pixel coordinate relative to the map container, returns // the corresponding geographical coordinate (for the current zoom level). containerPointToLatLng: function(p) { var A = this.containerPointToLayerPoint(ni(p)); return this.layerPointToLatLng(A); }, // @method latLngToContainerPoint(latlng: LatLng): Point // Given a geographical coordinate, returns the corresponding pixel coordinate // relative to the map container. latLngToContainerPoint: function(p) { return this.layerPointToContainerPoint(this.latLngToLayerPoint(xi(p))); }, // @method mouseEventToContainerPoint(ev: MouseEvent): Point // Given a MouseEvent object, returns the pixel coordinate relative to the // map container where the event took place. mouseEventToContainerPoint: function(p) { return Ss(p, this._container); }, // @method mouseEventToLayerPoint(ev: MouseEvent): Point // Given a MouseEvent object, returns the pixel coordinate relative to // the [origin pixel](#map-getpixelorigin) where the event took place. mouseEventToLayerPoint: function(p) { return this.containerPointToLayerPoint(this.mouseEventToContainerPoint(p)); }, // @method mouseEventToLatLng(ev: MouseEvent): LatLng // Given a MouseEvent object, returns geographical coordinate where the // event took place. mouseEventToLatLng: function(p) { return this.layerPointToLatLng(this.mouseEventToLayerPoint(p)); }, // map initialization methods _initContainer: function(p) { var A = this._container = Uo(p); if (A) { if (A._leaflet_id) throw new Error("Map container is already initialized."); } else throw new Error("Map container not found."); Bi(A, "scroll", this._onScroll, this), this._containerId = O(A); }, _initLayout: function() { var p = this._container; this._fadeAnimated = this.options.fadeAnimation && Pe.any3d, Vi(p, "leaflet-container" + (Pe.touch ? " leaflet-touch" : "") + (Pe.retina ? " leaflet-retina" : "") + (Pe.ielt9 ? " leaflet-oldie" : "") + (Pe.safari ? " leaflet-safari" : "") + (this._fadeAnimated ? " leaflet-fade-anim" : "")); var A = jo(p, "position"); A !== "absolute" && A !== "relative" && A !== "fixed" && A !== "sticky" && (p.style.position = "relative"), this._initPanes(), this._initControlPos && this._initControlPos(); }, _initPanes: function() { var p = this._panes = {}; this._paneRenderers = {}, this._mapPane = this.createPane("mapPane", this._container), Yn(this._mapPane, new fi(0, 0)), this.createPane("tilePane"), this.createPane("overlayPane"), this.createPane("shadowPane"), this.createPane("markerPane"), this.createPane("tooltipPane"), this.createPane("popupPane"), this.options.markerZoomAnimation || (Vi(p.markerPane, "leaflet-zoom-hide"), Vi(p.shadowPane, "leaflet-zoom-hide")); }, // private methods that modify map state // @section Map state change events _resetView: function(p, A, B) { Yn(this._mapPane, new fi(0, 0)); var X = !this._loaded; this._loaded = !0, A = this._limitZoom(A), this.fire("viewprereset"); var ne = this._zoom !== A; this._moveStart(ne, B)._move(p, A)._moveEnd(ne), this.fire("viewreset"), X && this.fire("load"); }, _moveStart: function(p, A) { return p && this.fire("zoomstart"), A || this.fire("movestart"), this; }, _move: function(p, A, B, X) { A === void 0 && (A = this._zoom); var ne = this._zoom !== A; return this._zoom = A, this._lastCenter = p, this._pixelOrigin = this._getNewPixelOrigin(p), X ? B && B.pinch && this.fire("zoom", B) : ((ne || B && B.pinch) && this.fire("zoom", B), this.fire("move", B)), this; }, _moveEnd: function(p) { return p && this.fire("zoomend"), this.fire("moveend"); }, _stop: function() { return Mi(this._flyToFrame), this._panAnim && this._panAnim.stop(), this; }, _rawPanBy: function(p) { Yn(this._mapPane, this._getMapPanePos().subtract(p)); }, _getZoomSpan: function() { return this.getMaxZoom() - this.getMinZoom(); }, _panInsideMaxBounds: function() { this._enforcingBounds || this.panInsideBounds(this.options.maxBounds); }, _checkIfLoaded: function() { if (!this._loaded) throw new Error("Set map center and zoom first."); }, // DOM event handling // @section Interaction events _initEvents: function(p) { this._targets = {}, this._targets[O(this._container)] = this; var A = p ? Cn : Bi; A(this._container, "click dblclick mousedown mouseup mouseover mouseout mousemove contextmenu keypress keydown keyup", this._handleDOMEvent, this), this.options.trackResize && A(window, "resize", this._onResize, this), Pe.any3d && this.options.transform3DLimit && (p ? this.off : this.on).call(this, "moveend", this._onMoveEnd); }, _onResize: function() { Mi(this._resizeRequest), this._resizeRequest = Pt( function() { this.invalidateSize({ debounceMoveend: !0 }); }, this ); }, _onScroll: function() { this._container.scrollTop = 0, this._container.scrollLeft = 0; }, _onMoveEnd: function() { var p = this._getMapPanePos(); Math.max(Math.abs(p.x), Math.abs(p.y)) >= this.options.transform3DLimit && this._resetView(this.getCenter(), this.getZoom()); }, _findEventTargets: function(p, A) { for (var B = [], X, ne = A === "mouseout" || A === "mouseover", ye = p.target || p.srcElement, We = !1; ye; ) { if (X = this._targets[O(ye)], X && (A === "click" || A === "preclick") && this._draggableMoved(X)) { We = !0; break; } if (X && X.listens(A, !0) && (ne && !ua(ye, p) || (B.push(X), ne)) || ye === this._container) break; ye = ye.parentNode; } return !B.length && !We && !ne && this.listens(A, !0) && (B = [this]), B; }, _isClickDisabled: function(p) { for (; p && p !== this._container; ) { if (p._leaflet_disable_click) return !0; p = p.parentNode; } }, _handleDOMEvent: function(p) { var A = p.target || p.srcElement; if (!(!this._loaded || A._leaflet_disable_events || p.type === "click" && this._isClickDisabled(A))) { var B = p.type; B === "mousedown" && ki(A), this._fireDOMEvent(p, B); } }, _mouseEvents: ["click", "dblclick", "mouseover", "mouseout", "contextmenu"], _fireDOMEvent: function(p, A, B) { if (p.type === "click") { var X = w({}, p); X.type = "preclick", this._fireDOMEvent(X, X.type, B); } var ne = this._findEventTargets(p, A); if (B) { for (var ye = [], We = 0; We < B.length; We++) B[We].listens(A, !0) && ye.push(B[We]); ne = ye.concat(ne); } if (ne.length) { A === "contextmenu" && _s(p); var at = ne[0], ft = { originalEvent: p }; if (p.type !== "keypress" && p.type !== "keydown" && p.type !== "keyup") { var Rt = at.getLatLng && (!at._radius || at._radius <= 10); ft.containerPoint = Rt ? this.latLngToContainerPoint(at.getLatLng()) : this.mouseEventToContainerPoint(p), ft.layerPoint = this.containerPointToLayerPoint(ft.containerPoint), ft.latlng = Rt ? at.getLatLng() : this.layerPointToLatLng(ft.layerPoint); } for (We = 0; We < ne.length; We++) if (ne[We].fire(A, ft, !0), ft.originalEvent._stopped || ne[We].options.bubblingMouseEvents === !1 && ht(this._mouseEvents, A) !== -1) return; } }, _draggableMoved: function(p) { return p = p.dragging && p.dragging.enabled() ? p : this, p.dragging && p.dragging.moved() || this.boxZoom && this.boxZoom.moved(); }, _clearHandlers: function() { for (var p = 0, A = this._handlers.length; p < A; p++) this._handlers[p].disable(); }, // @section Other Methods // @method whenReady(fn: Function, context?: Object): this // Runs the given function `fn` when the map gets initialized with // a view (center and zoom) and at least one layer, or immediately // if it's already initialized, optionally passing a function context. whenReady: function(p, A) { return this._loaded ? p.call(A || this, { target: this }) : this.on("load", p, A), this; }, // private methods for getting map state _getMapPanePos: function() { return $r(this._mapPane) || new fi(0, 0); }, _moved: function() { var p = this._getMapPanePos(); return p && !p.equals([0, 0]); }, _getTopLeftPoint: function(p, A) { var B = p && A !== void 0 ? this._getNewPixelOrigin(p, A) : this.getPixelOrigin(); return B.subtract(this._getMapPanePos()); }, _getNewPixelOrigin: function(p, A) { var B = this.getSize()._divideBy(2); return this.project(p, A)._subtract(B)._add(this._getMapPanePos())._round(); }, _latLngToNewLayerPoint: function(p, A, B) { var X = this._getNewPixelOrigin(B, A); return this.project(p, A)._subtract(X); }, _latLngBoundsToNewLayerBounds: function(p, A, B) { var X = this._getNewPixelOrigin(B, A); return an([ this.project(p.getSouthWest(), A)._subtract(X), this.project(p.getNorthWest(), A)._subtract(X), this.project(p.getSouthEast(), A)._subtract(X), this.project(p.getNorthEast(), A)._subtract(X) ]); }, // layer point of the current center _getCenterLayerPoint: function() { return this.containerPointToLayerPoint(this.getSize()._divideBy(2)); }, // offset of the specified place to the current center in pixels _getCenterOffset: function(p) { return this.latLngToLayerPoint(p).subtract(this._getCenterLayerPoint()); }, // adjust center for view to get inside bounds _limitCenter: function(p, A, B) { if (!B) return p; var X = this.project(p, A), ne = this.getSize().divideBy(2), ye = new Gi(X.subtract(ne), X.add(ne)), We = this._getBoundsOffset(ye, B, A); return Math.abs(We.x) <= 1 && Math.abs(We.y) <= 1 ? p : this.unproject(X.add(We), A); }, // adjust offset for view to get inside bounds _limitOffset: function(p, A) { if (!A) return p; var B = this.getPixelBounds(), X = new Gi(B.min.add(p), B.max.add(p)); return p.add(this._getBoundsOffset(X, A)); }, // returns offset needed for pxBounds to get inside maxBounds at a specified zoom _getBoundsOffset: function(p, A, B) { var X = an( this.project(A.getNorthEast(), B), this.project(A.getSouthWest(), B) ), ne = X.min.subtract(p.min), ye = X.max.subtract(p.max), We = this._rebound(ne.x, -ye.x), at = this._rebound(ne.y, -ye.y); return new fi(We, at); }, _rebound: function(p, A) { return p + A > 0 ? Math.round(p - A) / 2 : Math.max(0, Math.ceil(p)) - Math.max(0, Math.floor(A)); }, _limitZoom: function(p) { var A = this.getMinZoom(), B = this.getMaxZoom(), X = Pe.any3d ? this.options.zoomSnap : 1; return X && (p = Math.round(p / X) * X), Math.max(A, Math.min(B, p)); }, _onPanTransitionStep: function() { this.fire("move"); }, _onPanTransitionEnd: function() { Hn(this._mapPane, "leaflet-pan-anim"), this.fire("moveend"); }, _tryAnimatedPan: function(p, A) { var B = this._getCenterOffset(p)._trunc(); return (A && A.animate) !== !0 && !this.getSize().contains(B) ? !1 : (this.panBy(B, A), !0); }, _createAnimProxy: function() { var p = this._proxy = tn("div", "leaflet-proxy leaflet-zoom-animated"); this._panes.mapPane.appendChild(p), this.on("zoomanim", function(A) { var B = Er, X = this._proxy.style[B]; Ks(this._proxy, this.project(A.center, A.zoom), this.getZoomScale(A.zoom, 1)), X === this._proxy.style[B] && this._animatingZoom && this._onZoomTransitionEnd(); }, this), this.on("load moveend", this._animMoveEnd, this), this._on("unload", this._destroyAnimProxy, this); }, _destroyAnimProxy: function() { xn(this._proxy), this.off("load moveend", this._animMoveEnd, this), delete this._proxy; }, _animMoveEnd: function() { var p = this.getCenter(), A = this.getZoom(); Ks(this._proxy, this.project(p, A), this.getZoomScale(A, 1)); }, _catchTransitionEnd: function(p) { this._animatingZoom && p.propertyName.indexOf("transform") >= 0 && this._onZoomTransitionEnd(); }, _nothingToAnimate: function() { return !this._container.getElementsByClassName("leaflet-zoom-animated").length; }, _tryAnimatedZoom: function(p, A, B) { if (this._animatingZoom) return !0; if (B = B || {}, !this._zoomAnimated || B.animate === !1 || this._nothingToAnimate() || Math.abs(A - this._zoom) > this.options.zoomAnimationThreshold) return !1; var X = this.getZoomScale(A), ne = this._getCenterOffset(p)._divideBy(1 - 1 / X); return B.animate !== !0 && !this.getSize().contains(ne) ? !1 : (Pt(function() { this._moveStart(!0, B.noMoveStart || !1)._animateZoom(p, A, !0); }, this), !0); }, _animateZoom: function(p, A, B, X) { this._mapPane && (B && (this._animatingZoom = !0, this._animateToCenter = p, this._animateToZoom = A, Vi(this._mapPane, "leaflet-zoom-anim")), this.fire("zoomanim", { center: p, zoom: A, noUpdate: X }), this._tempFireZoomEvent || (this._tempFireZoomEvent = this._zoom !== this._animateToZoom), this._move(this._animateToCenter, this._animateToZoom, void 0, !0), setTimeout(E(this._onZoomTransitionEnd, this), 250)); }, _onZoomTransitionEnd: function() { this._animatingZoom && (this._mapPane && Hn(this._mapPane, "leaflet-zoom-anim"), this._animatingZoom = !1, this._move(this._animateToCenter, this._animateToZoom, void 0, !0), this._tempFireZoomEvent && this.fire("zoom"), delete this._tempFireZoomEvent, this.fire("move"), this._moveEnd(!0)); } }); function dl(p, A) { return new nn(p, A); } var Dn = hn.extend({ // @section // @aka Control Options options: { // @option position: String = 'topright' // The position of the control (one of the map corners). Possible values are `'topleft'`, // `'topright'`, `'bottomleft'` or `'bottomright'` position: "topright" }, initialize: function(p) { be(this, p); }, /* @section * Classes extending L.Control will inherit the following methods: * * @method getPosition: string * Returns the position of the control. */ getPosition: function() { return this.options.position; }, // @method setPosition(position: string): this // Sets the position of the control. setPosition: function(p) { var A = this._map; return A && A.removeControl(this), this.options.position = p, A && A.addControl(this), this; }, // @method getContainer: HTMLElement // Returns the HTMLElement that contains the control. getContainer: function() { return this._container; }, // @method addTo(map: Map): this // Adds the control to the given map. addTo: function(p) { this.remove(), this._map = p; var A = this._container = this.onAdd(p), B = this.getPosition(), X = p._controlCorners[B]; return Vi(A, "leaflet-control"), B.indexOf("bottom") !== -1 ? X.insertBefore(A, X.firstChild) : X.appendChild(A), this._map.on("unload", this.remove, this), this; }, // @method remove: this // Removes the control from the map it is currently active on. remove: function() { return this._map ? (xn(this._container), this.onRemove && this.onRemove(this._map), this._map.off("unload", this.remove, this), this._map = null, this) : this; }, _refocusOnMap: function(p) { this._map && p && p.screenX > 0 && p.screenY > 0 && this._map.getContainer().focus(); } }), rr = function(p) { return new Dn(p); }; nn.include({ // @method addControl(control: Control): this // Adds the given control to the map addControl: function(p) { return p.addTo(this), this; }, // @method removeControl(control: Control): this // Removes the given control from the map removeControl: function(p) { return p.remove(), this; }, _initControlPos: function() { var p = this._controlCorners = {}, A = "leaflet-", B = this._controlContainer = tn("div", A + "control-container", this._container); function X(ne, ye) { var We = A + ne + " " + A + ye; p[ne + ye] = tn("div", We, B); } X("top", "left"), X("top", "right"), X("bottom", "left"), X("bottom", "right"); }, _clearControlPos: function() { for (var p in this._controlCorners) xn(this._controlCorners[p]); xn(this._controlContainer), delete this._controlCorners, delete this._controlContainer; } }); var ss = Dn.extend({ // @section // @aka Control.Layers options options: { // @option collapsed: Boolean = true // If `true`, the control will be collapsed into an icon and expanded on mouse hover, touch, or keyboard activation. collapsed: !0, position: "topright", // @option autoZIndex: Boolean = true // If `true`, the control will assign zIndexes in increasing order to all of its layers so that the order is preserved when switching them on/off. autoZIndex: !0, // @option hideSingleBase: Boolean = false // If `true`, the base layers in the control will be hidden when there is only one. hideSingleBase: !1, // @option sortLayers: Boolean = false // Whether to sort the layers. When `false`, layers will keep the order // in which they were added to the control. sortLayers: !1, // @option sortFunction: Function = * // A [compare function](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) // that will be used for sorting the layers, when `sortLayers` is `true`. // The function receives both the `L.Layer` instances and their names, as in // `sortFunction(layerA, layerB, nameA, nameB)`. // By default, it sorts layers alphabetically by their name. sortFunction: function(p, A, B, X) { return B < X ? -1 : X < B ? 1 : 0; } }, initialize: function(p, A, B) { be(this, B), this._layerControlInputs = [], this._layers = [], this._lastZIndex = 0, this._handlingClick = !1, this._preventClick = !1; for (var X in p) this._addLayer(p[X], X); for (X in A) this._addLayer(A[X], X, !0); }, onAdd: function(p) { this._initLayout(), this._update(), this._map = p, p.on("zoomend", this._checkDisabledLayers, this); for (var A = 0; A < this._layers.length; A++) this._layers[A].layer.on("add remove", this._onLayerChange, this); return this._container; }, addTo: function(p) { return Dn.prototype.addTo.call(this, p), this._expandIfNotCollapsed(); }, onRemove: function() { this._map.off("zoomend", this._checkDisabledLayers, this); for (var p = 0; p < this._layers.length; p++) this._layers[p].layer.off("add remove", this._onLayerChange, this); }, // @method addBaseLayer(layer: Layer, name: String): this // Adds a base layer (radio button entry) with the given name to the control. addBaseLayer: function(p, A) { return this._addLayer(p, A), this._map ? this._update() : this; }, // @method addOverlay(layer: Layer, name: String): this // Adds an overlay (checkbox entry) with the given name to the control. addOverlay: function(p, A) { return this._addLayer(p, A, !0), this._map ? this._update() : this; }, // @method removeLayer(layer: Layer): this // Remove the given layer from the control. removeLayer: function(p) { p.off("add remove", this._onLayerChange, this); var A = this._getLayer(O(p)); return A && this._layers.splice(this._layers.indexOf(A), 1), this._map ? this._update() : this; }, // @method expand(): this // Expand the control container if collapsed. expand: function() { Vi(this._container, "leaflet-control-layers-expanded"), this._section.style.height = null; var p = this._map.getSize().y - (this._container.offsetTop + 50); return p < this._section.clientHeight ? (Vi(this._section, "leaflet-control-layers-scrollbar"), this._section.style.height = p + "px") : Hn(this._section, "leaflet-control-layers-scrollbar"), this._checkDisabledLayers(), this; }, // @method collapse(): this // Collapse the control container if expanded. collapse: function() { return Hn(this._container, "leaflet-control-layers-expanded"), this; }, _initLayout: function() { var p = "leaflet-control-layers", A = this._container = tn("div", p), B = this.options.collapsed; A.setAttribute("aria-haspopup", !0), Pi(A), bo(A); var X = this._section = tn("section", p + "-list"); B && (this._map.on("click", this.collapse, this), Bi(A, { mouseenter: this._expandSafely, mouseleave: this.collapse }, this)); var ne = this._layersLink = tn("a", p + "-toggle", A); ne.href = "#", ne.title = "Layers", ne.setAttribute("role", "button"), Bi(ne, { keydown: function(ye) { ye.keyCode === 13 && this._expandSafely(); }, // Certain screen readers intercept the key event and instead send a click event click: function(ye) { _s(ye), this._expandSafely(); } }, this), B || this.expand(), this._baseLayersList = tn("div", p + "-base", X), this._separator = tn("div", p + "-separator", X), this._overlaysList = tn("div", p + "-overlays", X), A.appendChild(X); }, _getLayer: function(p) { for (var A = 0; A < this._layers.length; A++) if (this._layers[A] && O(this._layers[A].layer) === p) return this._layers[A]; }, _addLayer: function(p, A, B) { this._map && p.on("add remove", this._onLayerChange, this), this._layers.push({ layer: p, name: A, overlay: B }), this.options.sortLayers && this._layers.sort(E(function(X, ne) { return this.options.sortFunction(X.layer, ne.layer, X.name, ne.name); }, this)), this.options.autoZIndex && p.setZIndex && (this._lastZIndex++, p.setZIndex(this._lastZIndex)), this._expandIfNotCollapsed(); }, _update: function() { if (!this._container) return this; no(this._baseLayersList), no(this._overlaysList), this._layerControlInputs = []; var p, A, B, X, ne = 0; for (B = 0; B < this._layers.length; B++) X = this._layers[B], this._addItem(X), A = A || X.overlay, p = p || !X.overlay, ne += X.overlay ? 0 : 1; return this.options.hideSingleBase && (p = p && ne > 1, this._baseLayersList.style.display = p ? "" : "none"), this._separator.style.display = A && p ? "" : "none", this; }, _onLayerChange: function(p) { this._handlingClick || this._update(); var A = this._getLayer(O(p.target)), B = A.overlay ? p.type === "add" ? "overlayadd" : "overlayremove" : p.type === "add" ? "baselayerchange" : null; B && this._map.fire(B, A); }, // IE7 bugs out if you create a radio dynamically, so you have to do it this hacky way (see https://stackoverflow.com/a/119079) _createRadioElement: function(p, A) { var B = '", X = document.createElement("div"); return X.innerHTML = B, X.firstChild; }, _addItem: function(p) { var A = document.createElement("label"), B = this._map.hasLayer(p.layer), X; p.overlay ? (X = document.createElement("input"), X.type = "checkbox", X.className = "leaflet-control-layers-selector", X.defaultChecked = B) : X = this._createRadioElement("leaflet-base-layers_" + O(this), B), this._layerControlInputs.push(X), X.layerId = O(p.layer), Bi(X, "click", this._onInputClick, this); var ne = document.createElement("span"); ne.innerHTML = " " + p.name; var ye = document.createElement("span"); A.appendChild(ye), ye.appendChild(X), ye.appendChild(ne); var We = p.overlay ? this._overlaysList : this._baseLayersList; return We.appendChild(A), this._checkDisabledLayers(), A; }, _onInputClick: function() { if (!this._preventClick) { var p = this._layerControlInputs, A, B, X = [], ne = []; this._handlingClick = !0; for (var ye = p.length - 1; ye >= 0; ye--) A = p[ye], B = this._getLayer(A.layerId).layer, A.checked ? X.push(B) : A.checked || ne.push(B); for (ye = 0; ye < ne.length; ye++) this._map.hasLayer(ne[ye]) && this._map.removeLayer(ne[ye]); for (ye = 0; ye < X.length; ye++) this._map.hasLayer(X[ye]) || this._map.addLayer(X[ye]); this._handlingClick = !1, this._refocusOnMap(); } }, _checkDisabledLayers: function() { for (var p = this._layerControlInputs, A, B, X = this._map.getZoom(), ne = p.length - 1; ne >= 0; ne--) A = p[ne], B = this._getLayer(A.layerId).layer, A.disabled = B.options.minZoom !== void 0 && X < B.options.minZoom || B.options.maxZoom !== void 0 && X > B.options.maxZoom; }, _expandIfNotCollapsed: function() { return this._map && !this.options.collapsed && this.expand(), this; }, _expandSafely: function() { var p = this._section; this._preventClick = !0, Bi(p, "click", _s), this.expand(); var A = this; setTimeout(function() { Cn(p, "click", _s), A._preventClick = !1; }); } }), fa = function(p, A, B) { return new ss(p, A, B); }, wo = Dn.extend({ // @section // @aka Control.Zoom options options: { position: "topleft", // @option zoomInText: String = '' // The text set on the 'zoom in' button. zoomInText: '', // @option zoomInTitle: String = 'Zoom in' // The title set on the 'zoom in' button. zoomInTitle: "Zoom in", // @option zoomOutText: String = '' // The text set on the 'zoom out' button. zoomOutText: '', // @option zoomOutTitle: String = 'Zoom out' // The title set on the 'zoom out' button. zoomOutTitle: "Zoom out" }, onAdd: function(p) { var A = "leaflet-control-zoom", B = tn("div", A + " leaflet-bar"), X = this.options; return this._zoomInButton = this._createButton( X.zoomInText, X.zoomInTitle, A + "-in", B, this._zoomIn ), this._zoomOutButton = this._createButton( X.zoomOutText, X.zoomOutTitle, A + "-out", B, this._zoomOut ), this._updateDisabled(), p.on("zoomend zoomlevelschange", this._updateDisabled, this), B; }, onRemove: function(p) { p.off("zoomend zoomlevelschange", this._updateDisabled, this); }, disable: function() { return this._disabled = !0, this._updateDisabled(), this; }, enable: function() { return this._disabled = !1, this._updateDisabled(), this; }, _zoomIn: function(p) { !this._disabled && this._map._zoom < this._map.getMaxZoom() && this._map.zoomIn(this._map.options.zoomDelta * (p.shiftKey ? 3 : 1)); }, _zoomOut: function(p) { !this._disabled && this._map._zoom > this._map.getMinZoom() && this._map.zoomOut(this._map.options.zoomDelta * (p.shiftKey ? 3 : 1)); }, _createButton: function(p, A, B, X, ne) { var ye = tn("a", B, X); return ye.innerHTML = p, ye.href = "#", ye.title = A, ye.setAttribute("role", "button"), ye.setAttribute("aria-label", A), Pi(ye), Bi(ye, "click", Js), Bi(ye, "click", ne, this), Bi(ye, "click", this._refocusOnMap, this), ye; }, _updateDisabled: function() { var p = this._map, A = "leaflet-disabled"; Hn(this._zoomInButton, A), Hn(this._zoomOutButton, A), this._zoomInButton.setAttribute("aria-disabled", "false"), this._zoomOutButton.setAttribute("aria-disabled", "false"), (this._disabled || p._zoom === p.getMinZoom()) && (Vi(this._zoomOutButton, A), this._zoomOutButton.setAttribute("aria-disabled", "true")), (this._disabled || p._zoom === p.getMaxZoom()) && (Vi(this._zoomInButton, A), this._zoomInButton.setAttribute("aria-disabled", "true")); } }); nn.mergeOptions({ zoomControl: !0 }), nn.addInitHook(function() { this.options.zoomControl && (this.zoomControl = new wo(), this.addControl(this.zoomControl)); }); var vn = function(p) { return new wo(p); }, Ir = Dn.extend({ // @section // @aka Control.Scale options options: { position: "bottomleft", // @option maxWidth: Number = 100 // Maximum width of the control in pixels. The width is set dynamically to show round values (e.g. 100, 200, 500). maxWidth: 100, // @option metric: Boolean = True // Whether to show the metric scale line (m/km). metric: !0, // @option imperial: Boolean = True // Whether to show the imperial scale line (mi/ft). imperial: !0 // @option updateWhenIdle: Boolean = false // If `true`, the control is updated on [`moveend`](#map-moveend), otherwise it's always up-to-date (updated on [`move`](#map-move)). }, onAdd: function(p) { var A = "leaflet-control-scale", B = tn("div", A), X = this.options; return this._addScales(X, A + "-line", B), p.on(X.updateWhenIdle ? "moveend" : "move", this._update, this), p.whenReady(this._update, this), B; }, onRemove: function(p) { p.off(this.options.updateWhenIdle ? "moveend" : "move", this._update, this); }, _addScales: function(p, A, B) { p.metric && (this._mScale = tn("div", A, B)), p.imperial && (this._iScale = tn("div", A, B)); }, _update: function() { var p = this._map, A = p.getSize().y / 2, B = p.distance( p.containerPointToLatLng([0, A]), p.containerPointToLatLng([this.options.maxWidth, A]) ); this._updateScales(B); }, _updateScales: function(p) { this.options.metric && p && this._updateMetric(p), this.options.imperial && p && this._updateImperial(p); }, _updateMetric: function(p) { var A = this._getRoundNum(p), B = A < 1e3 ? A + " m" : A / 1e3 + " km"; this._updateScale(this._mScale, B, A / p); }, _updateImperial: function(p) { var A = p * 3.2808399, B, X, ne; A > 5280 ? (B = A / 5280, X = this._getRoundNum(B), this._updateScale(this._iScale, X + " mi", X / B)) : (ne = this._getRoundNum(A), this._updateScale(this._iScale, ne + " ft", ne / A)); }, _updateScale: function(p, A, B) { p.style.width = Math.round(this.options.maxWidth * B) + "px", p.innerHTML = A; }, _getRoundNum: function(p) { var A = Math.pow(10, (Math.floor(p) + "").length - 1), B = p / A; return B = B >= 10 ? 10 : B >= 5 ? 5 : B >= 3 ? 3 : B >= 2 ? 2 : 1, A * B; } }), Lr = function(p) { return new Ir(p); }, qn = '', pa = Dn.extend({ // @section // @aka Control.Attribution options options: { position: "bottomright", // @option prefix: String|false = 'Leaflet' // The HTML text shown before the attributions. Pass `false` to disable. prefix: '' + (Pe.inlineSvg ? qn + " " : "") + "Leaflet" }, initialize: function(p) { be(this, p), this._attributions = {}; }, onAdd: function(p) { p.attributionControl = this, this._container = tn("div", "leaflet-control-attribution"), Pi(this._container); for (var A in p._layers) p._layers[A].getAttribution && this.addAttribution(p._layers[A].getAttribution()); return this._update(), p.on("layeradd", this._addAttribution, this), this._container; }, onRemove: function(p) { p.off("layeradd", this._addAttribution, this); }, _addAttribution: function(p) { p.layer.getAttribution && (this.addAttribution(p.layer.getAttribution()), p.layer.once("remove", function() { this.removeAttribution(p.layer.getAttribution()); }, this)); }, // @method setPrefix(prefix: String|false): this // The HTML text shown before the attributions. Pass `false` to disable. setPrefix: function(p) { return this.options.prefix = p, this._update(), this; }, // @method addAttribution(text: String): this // Adds an attribution text (e.g. `'© OpenStreetMap contributors'`). addAttribution: function(p) { return p ? (this._attributions[p] || (this._attributions[p] = 0), this._attributions[p]++, this._update(), this) : this; }, // @method removeAttribution(text: String): this // Removes an attribution text. removeAttribution: function(p) { return p ? (this._attributions[p] && (this._attributions[p]--, this._update()), this) : this; }, _update: function() { if (this._map) { var p = []; for (var A in this._attributions) this._attributions[A] && p.push(A); var B = []; this.options.prefix && B.push(this.options.prefix), p.length && B.push(p.join(", ")), this._container.innerHTML = B.join(' '); } } }); nn.mergeOptions({ attributionControl: !0 }), nn.addInitHook(function() { this.options.attributionControl && new pa().addTo(this); }); var zr = function(p) { return new pa(p); }; Dn.Layers = ss, Dn.Zoom = wo, Dn.Scale = Ir, Dn.Attribution = pa, rr.layers = fa, rr.zoom = vn, rr.scale = Lr, rr.attribution = zr; var Es = hn.extend({ initialize: function(p) { this._map = p; }, // @method enable(): this // Enables the handler enable: function() { return this._enabled ? this : (this._enabled = !0, this.addHooks(), this); }, // @method disable(): this // Disables the handler disable: function() { return this._enabled ? (this._enabled = !1, this.removeHooks(), this) : this; }, // @method enabled(): Boolean // Returns `true` if the handler is enabled enabled: function() { return !!this._enabled; } // @section Extension methods // Classes inheriting from `Handler` must implement the two following methods: // @method addHooks() // Called when the handler is enabled, should add event hooks. // @method removeHooks() // Called when the handler is disabled, should remove the event hooks added previously. }); Es.addTo = function(p, A) { return p.addHandler(A, this), this; }; var Oa = { Events: Si }, qo = Pe.touch ? "touchstart mousedown" : "mousedown", Wo = Ji.extend({ options: { // @section // @aka Draggable options // @option clickTolerance: Number = 3 // The max number of pixels a user can shift the mouse pointer during a click // for it to be considered a valid click (as opposed to a mouse drag). clickTolerance: 3 }, // @constructor L.Draggable(el: HTMLElement, dragHandle?: HTMLElement, preventOutline?: Boolean, options?: Draggable options) // Creates a `Draggable` object for moving `el` when you start dragging the `dragHandle` element (equals `el` itself by default). initialize: function(p, A, B, X) { be(this, X), this._element = p, this._dragStartTarget = A || p, this._preventOutline = B; }, // @method enable() // Enables the dragging ability enable: function() { this._enabled || (Bi(this._dragStartTarget, qo, this._onDown, this), this._enabled = !0); }, // @method disable() // Disables the dragging ability disable: function() { this._enabled && (Wo._dragging === this && this.finishDrag(!0), Cn(this._dragStartTarget, qo, this._onDown, this), this._enabled = !1, this._moved = !1); }, _onDown: function(p) { if (this._enabled && (this._moved = !1, !Da(this._element, "leaflet-zoom-anim"))) { if (p.touches && p.touches.length !== 1) { Wo._dragging === this && this.finishDrag(); return; } if (!(Wo._dragging || p.shiftKey || p.which !== 1 && p.button !== 1 && !p.touches) && (Wo._dragging = this, this._preventOutline && ki(this._element), Zo(), Ar(), !this._moving)) { this.fire("down"); var A = p.touches ? p.touches[0] : p, B = ei(this._element); this._startPoint = new fi(A.clientX, A.clientY), this._startPos = $r(this._element), this._parentScale = ul(B); var X = p.type === "mousedown"; Bi(document, X ? "mousemove" : "touchmove", this._onMove, this), Bi(document, X ? "mouseup" : "touchend touchcancel", this._onUp, this); } } }, _onMove: function(p) { if (this._enabled) { if (p.touches && p.touches.length > 1) { this._moved = !0; return; } var A = p.touches && p.touches.length === 1 ? p.touches[0] : p, B = new fi(A.clientX, A.clientY)._subtract(this._startPoint); !B.x && !B.y || Math.abs(B.x) + Math.abs(B.y) < this.options.clickTolerance || (B.x /= this._parentScale.x, B.y /= this._parentScale.y, _s(p), this._moved || (this.fire("dragstart"), this._moved = !0, Vi(document.body, "leaflet-dragging"), this._lastTarget = p.target || p.srcElement, window.SVGElementInstance && this._lastTarget instanceof window.SVGElementInstance && (this._lastTarget = this._lastTarget.correspondingUseElement), Vi(this._lastTarget, "leaflet-drag-target")), this._newPos = this._startPos.add(B), this._moving = !0, this._lastEvent = p, this._updatePosition()); } }, _updatePosition: function() { var p = { originalEvent: this._lastEvent }; this.fire("predrag", p), Yn(this._element, this._newPos), this.fire("drag", p); }, _onUp: function() { this._enabled && this.finishDrag(); }, finishDrag: function(p) { Hn(document.body, "leaflet-dragging"), this._lastTarget && (Hn(this._lastTarget, "leaflet-drag-target"), this._lastTarget = null), Cn(document, "mousemove touchmove", this._onMove, this), Cn(document, "mouseup touchend touchcancel", this._onUp, this), sr(), Cr(); var A = this._moved && this._moving; this._moving = !1, Wo._dragging = !1, A && this.fire("dragend", { noInertia: p, distance: this._newPos.distanceTo(this._startPos) }); } }); function so(p, A, B) { var X, ne = [1, 4, 2, 8], ye, We, at, ft, Rt, ii, Ci, Wi; for (ye = 0, ii = p.length; ye < ii; ye++) p[ye]._code = Ds(p[ye], A); for (at = 0; at < 4; at++) { for (Ci = ne[at], X = [], ye = 0, ii = p.length, We = ii - 1; ye < ii; We = ye++) ft = p[ye], Rt = p[We], ft._code & Ci ? Rt._code & Ci || (Wi = _l(Rt, ft, Ci, A, B), Wi._code = Ds(Wi, A), X.push(Wi)) : (Rt._code & Ci && (Wi = _l(Rt, ft, Ci, A, B), Wi._code = Ds(Wi, A), X.push(Wi)), X.push(ft)); p = X; } return p; } function Nc(p, A) { var B, X, ne, ye, We, at, ft, Rt, ii; if (!p || p.length === 0) throw new Error("latlngs not passed"); rs(p) || (console.warn("latlngs are not flat! Only the first ring will be used"), p = p[0]); var Ci = xi([0, 0]), Wi = ln(p), Hs = Wi.getNorthWest().distanceTo(Wi.getSouthWest()) * Wi.getNorthEast().distanceTo(Wi.getNorthWest()); Hs < 1700 && (Ci = Fa(p)); var ws = p.length, Rs = []; for (B = 0; B < ws; B++) { var ur = xi(p[B]); Rs.push(A.project(xi([ur.lat - Ci.lat, ur.lng - Ci.lng]))); } for (at = ft = Rt = 0, B = 0, X = ws - 1; B < ws; X = B++) ne = Rs[B], ye = Rs[X], We = ne.y * ye.x - ye.y * ne.x, ft += (ne.x + ye.x) * We, Rt += (ne.y + ye.y) * We, at += We * 3; at === 0 ? ii = Rs[0] : ii = [ft / at, Rt / at]; var Za = A.unproject(ni(ii)); return xi([Za.lat + Ci.lat, Za.lng + Ci.lng]); } function Fa(p) { for (var A = 0, B = 0, X = 0, ne = 0; ne < p.length; ne++) { var ye = xi(p[ne]); A += ye.lat, B += ye.lng, X++; } return xi([A / X, B / X]); } var or = { __proto__: null, clipPolygon: so, polygonCenter: Nc, centroid: Fa }; function fl(p, A) { if (!A || !p.length) return p.slice(); var B = A * A; return p = Qu(p, B), p = ml(p, B), p; } function pl(p, A, B) { return Math.sqrt($o(p, A, B, !0)); } function Nh(p, A, B) { return $o(p, A, B); } function ml(p, A) { var B = p.length, X = typeof Uint8Array != void 0 + "" ? Uint8Array : Array, ne = new X(B); ne[0] = ne[B - 1] = 1, Vc(p, ne, A, 0, B - 1); var ye, We = []; for (ye = 0; ye < B; ye++) ne[ye] && We.push(p[ye]); return We; } function Vc(p, A, B, X, ne) { var ye = 0, We, at, ft; for (at = X + 1; at <= ne - 1; at++) ft = $o(p[at], p[X], p[ne], !0), ft > ye && (We = at, ye = ft); ye > B && (A[We] = 1, Vc(p, A, B, X, We), Vc(p, A, B, We, ne)); } function Qu(p, A) { for (var B = [p[0]], X = 1, ne = 0, ye = p.length; X < ye; X++) Vh(p[X], p[ne]) > A && (B.push(p[X]), ne = X); return ne < ye - 1 && B.push(p[ye - 1]), B; } var Ba; function Na(p, A, B, X, ne) { var ye = X ? Ba : Ds(p, B), We = Ds(A, B), at, ft, Rt; for (Ba = We; ; ) { if (!(ye | We)) return [p, A]; if (ye & We) return !1; at = ye || We, ft = _l(p, A, at, B, ne), Rt = Ds(ft, B), at === ye ? (p = ft, ye = Rt) : (A = ft, We = Rt); } } function _l(p, A, B, X, ne) { var ye = A.x - p.x, We = A.y - p.y, at = X.min, ft = X.max, Rt, ii; return B & 8 ? (Rt = p.x + ye * (ft.y - p.y) / We, ii = ft.y) : B & 4 ? (Rt = p.x + ye * (at.y - p.y) / We, ii = at.y) : B & 2 ? (Rt = ft.x, ii = p.y + We * (ft.x - p.x) / ye) : B & 1 && (Rt = at.x, ii = p.y + We * (at.x - p.x) / ye), new fi(Rt, ii, ne); } function Ds(p, A) { var B = 0; return p.x < A.min.x ? B |= 1 : p.x > A.max.x && (B |= 2), p.y < A.min.y ? B |= 4 : p.y > A.max.y && (B |= 8), B; } function Vh(p, A) { var B = A.x - p.x, X = A.y - p.y; return B * B + X * X; } function $o(p, A, B, X) { var ne = A.x, ye = A.y, We = B.x - ne, at = B.y - ye, ft = We * We + at * at, Rt; return ft > 0 && (Rt = ((p.x - ne) * We + (p.y - ye) * at) / ft, Rt > 1 ? (ne = B.x, ye = B.y) : Rt > 0 && (ne += We * Rt, ye += at * Rt)), We = p.x - ne, at = p.y - ye, X ? We * We + at * at : new fi(ne, ye); } function rs(p) { return !vt(p[0]) || typeof p[0][0] != "object" && typeof p[0][0] < "u"; } function Uh(p) { return console.warn("Deprecated use of _flat, please use L.LineUtil.isFlat instead."), rs(p); } function jh(p, A) { var B, X, ne, ye, We, at, ft, Rt; if (!p || p.length === 0) throw new Error("latlngs not passed"); rs(p) || (console.warn("latlngs are not flat! Only the first ring will be used"), p = p[0]); var ii = xi([0, 0]), Ci = ln(p), Wi = Ci.getNorthWest().distanceTo(Ci.getSouthWest()) * Ci.getNorthEast().distanceTo(Ci.getNorthWest()); Wi < 1700 && (ii = Fa(p)); var Hs = p.length, ws = []; for (B = 0; B < Hs; B++) { var Rs = xi(p[B]); ws.push(A.project(xi([Rs.lat - ii.lat, Rs.lng - ii.lng]))); } for (B = 0, X = 0; B < Hs - 1; B++) X += ws[B].distanceTo(ws[B + 1]) / 2; if (X === 0) Rt = ws[0]; else for (B = 0, ye = 0; B < Hs - 1; B++) if (We = ws[B], at = ws[B + 1], ne = We.distanceTo(at), ye += ne, ye > X) { ft = (ye - X) / ne, Rt = [ at.x - ft * (at.x - We.x), at.y - ft * (at.y - We.y) ]; break; } var ur = A.unproject(ni(Rt)); return xi([ur.lat + ii.lat, ur.lng + ii.lng]); } var ed = { __proto__: null, simplify: fl, pointToSegmentDistance: pl, closestPointOnSegment: Nh, clipSegment: Na, _getEdgeIntersection: _l, _getBitCode: Ds, _sqClosestPointOnSegment: $o, isFlat: rs, _flat: Uh, polylineCenter: jh }, Hl = { project: function(p) { return new fi(p.lng, p.lat); }, unproject: function(p) { return new Di(p.y, p.x); }, bounds: new Gi([-180, -90], [180, 90]) }, Xo = { R: 6378137, R_MINOR: 6356752314245179e-9, bounds: new Gi([-2003750834279e-5, -1549657073972e-5], [2003750834279e-5, 1876465623138e-5]), project: function(p) { var A = Math.PI / 180, B = this.R, X = p.lat * A, ne = this.R_MINOR / B, ye = Math.sqrt(1 - ne * ne), We = ye * Math.sin(X), at = Math.tan(Math.PI / 4 - X / 2) / Math.pow((1 - We) / (1 + We), ye / 2); return X = -B * Math.log(Math.max(at, 1e-10)), new fi(p.lng * A * B, X); }, unproject: function(p) { for (var A = 180 / Math.PI, B = this.R, X = this.R_MINOR / B, ne = Math.sqrt(1 - X * X), ye = Math.exp(-p.y / B), We = Math.PI / 2 - 2 * Math.atan(ye), at = 0, ft = 0.1, Rt; at < 15 && Math.abs(ft) > 1e-7; at++) Rt = ne * Math.sin(We), Rt = Math.pow((1 - Rt) / (1 + Rt), ne / 2), ft = Math.PI / 2 - 2 * Math.atan(ye * Rt) - We, We += ft; return new Di(We * A, p.x * A / B); } }, bi = { __proto__: null, LonLat: Hl, Mercator: Xo, SphericalMercator: De }, Wt = w({}, xs, { code: "EPSG:3395", projection: Xo, transformation: function() { var p = 0.5 / (Math.PI * Xo.R); return Us(p, 0.5, -p, 0.5); }() }), gl = w({}, xs, { code: "EPSG:4326", projection: Hl, transformation: Us(1 / 180, 1, -1 / 180, 0.5) }), ci = w({}, Cs, { projection: Hl, transformation: Us(1, 0, -1, 0), scale: function(p) { return Math.pow(2, p); }, zoom: function(p) { return Math.log(p) / Math.LN2; }, distance: function(p, A) { var B = A.lng - p.lng, X = A.lat - p.lat; return Math.sqrt(B * B + X * X); }, infinite: !0 }); Cs.Earth = xs, Cs.EPSG3395 = Wt, Cs.EPSG3857 = Zr, Cs.EPSG900913 = Et, Cs.EPSG4326 = gl, Cs.Simple = ci; var ar = Ji.extend({ // Classes extending `L.Layer` will inherit the following options: options: { // @option pane: String = 'overlayPane' // By default the layer will be added to the map's [overlay pane](#map-overlaypane). Overriding this option will cause the layer to be placed on another pane by default. pane: "overlayPane", // @option attribution: String = null // String to be shown in the attribution control, e.g. "© OpenStreetMap contributors". It describes the layer data and is often a legal obligation towards copyright holders and tile providers. attribution: null, bubblingMouseEvents: !0 }, /* @section * Classes extending `L.Layer` will inherit the following methods: * * @method addTo(map: Map|LayerGroup): this * Adds the layer to the given map or layer group. */ addTo: function(p) { return p.addLayer(this), this; }, // @method remove: this // Removes the layer from the map it is currently active on. remove: function() { return this.removeFrom(this._map || this._mapToAdd); }, // @method removeFrom(map: Map): this // Removes the layer from the given map // // @alternative // @method removeFrom(group: LayerGroup): this // Removes the layer from the given `LayerGroup` removeFrom: function(p) { return p && p.removeLayer(this), this; }, // @method getPane(name? : String): HTMLElement // Returns the `HTMLElement` representing the named pane on the map. If `name` is omitted, returns the pane for this layer. getPane: function(p) { return this._map.getPane(p ? this.options[p] || p : this.options.pane); }, addInteractiveTarget: function(p) { return this._map._targets[O(p)] = this, this; }, removeInteractiveTarget: function(p) { return delete this._map._targets[O(p)], this; }, // @method getAttribution: String // Used by the `attribution control`, returns the [attribution option](#gridlayer-attribution). getAttribution: function() { return this.options.attribution; }, _layerAdd: function(p) { var A = p.target; if (A.hasLayer(this)) { if (this._map = A, this._zoomAnimated = A._zoomAnimated, this.getEvents) { var B = this.getEvents(); A.on(B, this), this.once("remove", function() { A.off(B, this); }, this); } this.onAdd(A), this.fire("add"), A.fire("layeradd", { layer: this }); } } }); nn.include({ // @method addLayer(layer: Layer): this // Adds the given layer to the map addLayer: function(p) { if (!p._layerAdd) throw new Error("The provided object is not a Layer."); var A = O(p); return this._layers[A] ? this : (this._layers[A] = p, p._mapToAdd = this, p.beforeAdd && p.beforeAdd(this), this.whenReady(p._layerAdd, p), this); }, // @method removeLayer(layer: Layer): this // Removes the given layer from the map. removeLayer: function(p) { var A = O(p); return this._layers[A] ? (this._loaded && p.onRemove(this), delete this._layers[A], this._loaded && (this.fire("layerremove", { layer: p }), p.fire("remove")), p._map = p._mapToAdd = null, this) : this; }, // @method hasLayer(layer: Layer): Boolean // Returns `true` if the given layer is currently added to the map hasLayer: function(p) { return O(p) in this._layers; }, /* @method eachLayer(fn: Function, context?: Object): this * Iterates over the layers of the map, optionally specifying context of the iterator function. * ``` * map.eachLayer(function(layer){ * layer.bindPopup('Hello'); * }); * ``` */ eachLayer: function(p, A) { for (var B in this._layers) p.call(A, this._layers[B]); return this; }, _addLayers: function(p) { p = p ? vt(p) ? p : [p] : []; for (var A = 0, B = p.length; A < B; A++) this.addLayer(p[A]); }, _addZoomLimit: function(p) { (!isNaN(p.options.maxZoom) || !isNaN(p.options.minZoom)) && (this._zoomBoundLayers[O(p)] = p, this._updateZoomLevels()); }, _removeZoomLimit: function(p) { var A = O(p); this._zoomBoundLayers[A] && (delete this._zoomBoundLayers[A], this._updateZoomLevels()); }, _updateZoomLevels: function() { var p = 1 / 0, A = -1 / 0, B = this._getZoomSpan(); for (var X in this._zoomBoundLayers) { var ne = this._zoomBoundLayers[X].options; p = ne.minZoom === void 0 ? p : Math.min(p, ne.minZoom), A = ne.maxZoom === void 0 ? A : Math.max(A, ne.maxZoom); } this._layersMaxZoom = A === -1 / 0 ? void 0 : A, this._layersMinZoom = p === 1 / 0 ? void 0 : p, B !== this._getZoomSpan() && this.fire("zoomlevelschange"), this.options.maxZoom === void 0 && this._layersMaxZoom && this.getZoom() > this._layersMaxZoom && this.setZoom(this._layersMaxZoom), this.options.minZoom === void 0 && this._layersMinZoom && this.getZoom() < this._layersMinZoom && this.setZoom(this._layersMinZoom); } }); var lr = ar.extend({ initialize: function(p, A) { be(this, A), this._layers = {}; var B, X; if (p) for (B = 0, X = p.length; B < X; B++) this.addLayer(p[B]); }, // @method addLayer(layer: Layer): this // Adds the given layer to the group. addLayer: function(p) { var A = this.getLayerId(p); return this._layers[A] = p, this._map && this._map.addLayer(p), this; }, // @method removeLayer(layer: Layer): this // Removes the given layer from the group. // @alternative // @method removeLayer(id: Number): this // Removes the layer with the given internal ID from the group. removeLayer: function(p) { var A = p in this._layers ? p : this.getLayerId(p); return this._map && this._layers[A] && this._map.removeLayer(this._layers[A]), delete this._layers[A], this; }, // @method hasLayer(layer: Layer): Boolean // Returns `true` if the given layer is currently added to the group. // @alternative // @method hasLayer(id: Number): Boolean // Returns `true` if the given internal ID is currently added to the group. hasLayer: function(p) { var A = typeof p == "number" ? p : this.getLayerId(p); return A in this._layers; }, // @method clearLayers(): this // Removes all the layers from the group. clearLayers: function() { return this.eachLayer(this.removeLayer, this); }, // @method invoke(methodName: String, …): this // Calls `methodName` on every layer contained in this group, passing any // additional parameters. Has no effect if the layers contained do not // implement `methodName`. invoke: function(p) { var A = Array.prototype.slice.call(arguments, 1), B, X; for (B in this._layers) X = this._layers[B], X[p] && X[p].apply(X, A); return this; }, onAdd: function(p) { this.eachLayer(p.addLayer, p); }, onRemove: function(p) { this.eachLayer(p.removeLayer, p); }, // @method eachLayer(fn: Function, context?: Object): this // Iterates over the layers of the group, optionally specifying context of the iterator function. // ```js // group.eachLayer(function (layer) { // layer.bindPopup('Hello'); // }); // ``` eachLayer: function(p, A) { for (var B in this._layers) p.call(A, this._layers[B]); return this; }, // @method getLayer(id: Number): Layer // Returns the layer with the given internal ID. getLayer: function(p) { return this._layers[p]; }, // @method getLayers(): Layer[] // Returns an array of all the layers added to the group. getLayers: function() { var p = []; return this.eachLayer(p.push, p), p; }, // @method setZIndex(zIndex: Number): this // Calls `setZIndex` on every layer contained in this group, passing the z-index. setZIndex: function(p) { return this.invoke("setZIndex", p); }, // @method getLayerId(layer: Layer): Number // Returns the internal ID for a layer getLayerId: function(p) { return O(p); } }), ti = function(p, A) { return new lr(p, A); }, Xr = lr.extend({ addLayer: function(p) { return this.hasLayer(p) ? this : (p.addEventParent(this), lr.prototype.addLayer.call(this, p), this.fire("layeradd", { layer: p })); }, removeLayer: function(p) { return this.hasLayer(p) ? (p in this._layers && (p = this._layers[p]), p.removeEventParent(this), lr.prototype.removeLayer.call(this, p), this.fire("layerremove", { layer: p })) : this; }, // @method setStyle(style: Path options): this // Sets the given path options to each layer of the group that has a `setStyle` method. setStyle: function(p) { return this.invoke("setStyle", p); }, // @method bringToFront(): this // Brings the layer group to the top of all other layers bringToFront: function() { return this.invoke("bringToFront"); }, // @method bringToBack(): this // Brings the layer group to the back of all other layers bringToBack: function() { return this.invoke("bringToBack"); }, // @method getBounds(): LatLngBounds // Returns the LatLngBounds of the Feature Group (created from bounds and coordinates of its children). getBounds: function() { var p = new qt(); for (var A in this._layers) { var B = this._layers[A]; p.extend(B.getBounds ? B.getBounds() : B.getLatLng()); } return p; } }), ql = function(p, A) { return new Xr(p, A); }, Yr = hn.extend({ /* @section * @aka Icon options * * @option iconUrl: String = null * **(required)** The URL to the icon image (absolute or relative to your script path). * * @option iconRetinaUrl: String = null * The URL to a retina sized version of the icon image (absolute or relative to your * script path). Used for Retina screen devices. * * @option iconSize: Point = null * Size of the icon image in pixels. * * @option iconAnchor: Point = null * The coordinates of the "tip" of the icon (relative to its top left corner). The icon * will be aligned so that this point is at the marker's geographical location. Centered * by default if size is specified, also can be set in CSS with negative margins. * * @option popupAnchor: Point = [0, 0] * The coordinates of the point from which popups will "open", relative to the icon anchor. * * @option tooltipAnchor: Point = [0, 0] * The coordinates of the point from which tooltips will "open", relative to the icon anchor. * * @option shadowUrl: String = null * The URL to the icon shadow image. If not specified, no shadow image will be created. * * @option shadowRetinaUrl: String = null * * @option shadowSize: Point = null * Size of the shadow image in pixels. * * @option shadowAnchor: Point = null * The coordinates of the "tip" of the shadow (relative to its top left corner) (the same * as iconAnchor if not specified). * * @option className: String = '' * A custom class name to assign to both icon and shadow images. Empty by default. */ options: { popupAnchor: [0, 0], tooltipAnchor: [0, 0], // @option crossOrigin: Boolean|String = false // Whether the crossOrigin attribute will be added to the tiles. // If a String is provided, all tiles will have their crossOrigin attribute set to the String provided. This is needed if you want to access tile pixel data. // Refer to [CORS Settings](https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_settings_attributes) for valid String values. crossOrigin: !1 }, initialize: function(p) { be(this, p); }, // @method createIcon(oldIcon?: HTMLElement): HTMLElement // Called internally when the icon has to be shown, returns a `` HTML element // styled according to the options. createIcon: function(p) { return this._createIcon("icon", p); }, // @method createShadow(oldIcon?: HTMLElement): HTMLElement // As `createIcon`, but for the shadow beneath it. createShadow: function(p) { return this._createIcon("shadow", p); }, _createIcon: function(p, A) { var B = this._getIconUrl(p); if (!B) { if (p === "icon") throw new Error("iconUrl not set in Icon options (see the docs)."); return null; } var X = this._createImg(B, A && A.tagName === "IMG" ? A : null); return this._setIconStyles(X, p), (this.options.crossOrigin || this.options.crossOrigin === "") && (X.crossOrigin = this.options.crossOrigin === !0 ? "" : this.options.crossOrigin), X; }, _setIconStyles: function(p, A) { var B = this.options, X = B[A + "Size"]; typeof X == "number" && (X = [X, X]); var ne = ni(X), ye = ni(A === "shadow" && B.shadowAnchor || B.iconAnchor || ne && ne.divideBy(2, !0)); p.className = "leaflet-marker-" + A + " " + (B.className || ""), ye && (p.style.marginLeft = -ye.x + "px", p.style.marginTop = -ye.y + "px"), ne && (p.style.width = ne.x + "px", p.style.height = ne.y + "px"); }, _createImg: function(p, A) { return A = A || document.createElement("img"), A.src = p, A; }, _getIconUrl: function(p) { return Pe.retina && this.options[p + "RetinaUrl"] || this.options[p + "Url"]; } }); function Va(p) { return new Yr(p); } var To = Yr.extend({ options: { iconUrl: "marker-icon.png", iconRetinaUrl: "marker-icon-2x.png", shadowUrl: "marker-shadow.png", iconSize: [25, 41], iconAnchor: [12, 41], popupAnchor: [1, -34], tooltipAnchor: [16, -28], shadowSize: [41, 41] }, _getIconUrl: function(p) { return typeof To.imagePath != "string" && (To.imagePath = this._detectIconPath()), (this.options.imagePath || To.imagePath) + Yr.prototype._getIconUrl.call(this, p); }, _stripUrl: function(p) { var A = function(B, X, ne) { var ye = X.exec(B); return ye && ye[ne]; }; return p = A(p, /^url\((['"])?(.+)\1\)$/, 2), p && A(p, /^(.*)marker-icon\.png$/, 1); }, _detectIconPath: function() { var p = tn("div", "leaflet-default-icon-path", document.body), A = jo(p, "background-image") || jo(p, "backgroundImage"); if (document.body.removeChild(p), A = this._stripUrl(A), A) return A; var B = document.querySelector('link[href$="leaflet.css"]'); return B ? B.href.substring(0, B.href.length - 11 - 1) : ""; } }), bs = Es.extend({ initialize: function(p) { this._marker = p; }, addHooks: function() { var p = this._marker._icon; this._draggable || (this._draggable = new Wo(p, p, !0)), this._draggable.on({ dragstart: this._onDragStart, predrag: this._onPreDrag, drag: this._onDrag, dragend: this._onDragEnd }, this).enable(), Vi(p, "leaflet-marker-draggable"); }, removeHooks: function() { this._draggable.off({ dragstart: this._onDragStart, predrag: this._onPreDrag, drag: this._onDrag, dragend: this._onDragEnd }, this).disable(), this._marker._icon && Hn(this._marker._icon, "leaflet-marker-draggable"); }, moved: function() { return this._draggable && this._draggable._moved; }, _adjustPan: function(p) { var A = this._marker, B = A._map, X = this._marker.options.autoPanSpeed, ne = this._marker.options.autoPanPadding, ye = $r(A._icon), We = B.getPixelBounds(), at = B.getPixelOrigin(), ft = an( We.min._subtract(at).add(ne), We.max._subtract(at).subtract(ne) ); if (!ft.contains(ye)) { var Rt = ni( (Math.max(ft.max.x, ye.x) - ft.max.x) / (We.max.x - ft.max.x) - (Math.min(ft.min.x, ye.x) - ft.min.x) / (We.min.x - ft.min.x), (Math.max(ft.max.y, ye.y) - ft.max.y) / (We.max.y - ft.max.y) - (Math.min(ft.min.y, ye.y) - ft.min.y) / (We.min.y - ft.min.y) ).multiplyBy(X); B.panBy(Rt, { animate: !1 }), this._draggable._newPos._add(Rt), this._draggable._startPos._add(Rt), Yn(A._icon, this._draggable._newPos), this._onDrag(p), this._panRequest = Pt(this._adjustPan.bind(this, p)); } }, _onDragStart: function() { this._oldLatLng = this._marker.getLatLng(), this._marker.closePopup && this._marker.closePopup(), this._marker.fire("movestart").fire("dragstart"); }, _onPreDrag: function(p) { this._marker.options.autoPan && (Mi(this._panRequest), this._panRequest = Pt(this._adjustPan.bind(this, p))); }, _onDrag: function(p) { var A = this._marker, B = A._shadow, X = $r(A._icon), ne = A._map.layerPointToLatLng(X); B && Yn(B, X), A._latlng = ne, p.latlng = ne, p.oldLatLng = this._oldLatLng, A.fire("move", p).fire("drag", p); }, _onDragEnd: function(p) { Mi(this._panRequest), delete this._oldLatLng, this._marker.fire("moveend").fire("dragend", p); } }), ks = ar.extend({ // @section // @aka Marker options options: { // @option icon: Icon = * // Icon instance to use for rendering the marker. // See [Icon documentation](#L.Icon) for details on how to customize the marker icon. // If not specified, a common instance of `L.Icon.Default` is used. icon: new To(), // Option inherited from "Interactive layer" abstract class interactive: !0, // @option keyboard: Boolean = true // Whether the marker can be tabbed to with a keyboard and clicked by pressing enter. keyboard: !0, // @option title: String = '' // Text for the browser tooltip that appear on marker hover (no tooltip by default). // [Useful for accessibility](https://leafletjs.com/examples/accessibility/#markers-must-be-labelled). title: "", // @option alt: String = 'Marker' // Text for the `alt` attribute of the icon image. // [Useful for accessibility](https://leafletjs.com/examples/accessibility/#markers-must-be-labelled). alt: "Marker", // @option zIndexOffset: Number = 0 // By default, marker images zIndex is set automatically based on its latitude. Use this option if you want to put the marker on top of all others (or below), specifying a high value like `1000` (or high negative value, respectively). zIndexOffset: 0, // @option opacity: Number = 1.0 // The opacity of the marker. opacity: 1, // @option riseOnHover: Boolean = false // If `true`, the marker will get on top of others when you hover the mouse over it. riseOnHover: !1, // @option riseOffset: Number = 250 // The z-index offset used for the `riseOnHover` feature. riseOffset: 250, // @option pane: String = 'markerPane' // `Map pane` where the markers icon will be added. pane: "markerPane", // @option shadowPane: String = 'shadowPane' // `Map pane` where the markers shadow will be added. shadowPane: "shadowPane", // @option bubblingMouseEvents: Boolean = false // When `true`, a mouse event on this marker will trigger the same event on the map // (unless [`L.DomEvent.stopPropagation`](#domevent-stoppropagation) is used). bubblingMouseEvents: !1, // @option autoPanOnFocus: Boolean = true // When `true`, the map will pan whenever the marker is focused (via // e.g. pressing `tab` on the keyboard) to ensure the marker is // visible within the map's bounds autoPanOnFocus: !0, // @section Draggable marker options // @option draggable: Boolean = false // Whether the marker is draggable with mouse/touch or not. draggable: !1, // @option autoPan: Boolean = false // Whether to pan the map when dragging this marker near its edge or not. autoPan: !1, // @option autoPanPadding: Point = Point(50, 50) // Distance (in pixels to the left/right and to the top/bottom) of the // map edge to start panning the map. autoPanPadding: [50, 50], // @option autoPanSpeed: Number = 10 // Number of pixels the map should pan by. autoPanSpeed: 10 }, /* @section * * In addition to [shared layer methods](#Layer) like `addTo()` and `remove()` and [popup methods](#Popup) like bindPopup() you can also use the following methods: */ initialize: function(p, A) { be(this, A), this._latlng = xi(p); }, onAdd: function(p) { this._zoomAnimated = this._zoomAnimated && p.options.markerZoomAnimation, this._zoomAnimated && p.on("zoomanim", this._animateZoom, this), this._initIcon(), this.update(); }, onRemove: function(p) { this.dragging && this.dragging.enabled() && (this.options.draggable = !0, this.dragging.removeHooks()), delete this.dragging, this._zoomAnimated && p.off("zoomanim", this._animateZoom, this), this._removeIcon(), this._removeShadow(); }, getEvents: function() { return { zoom: this.update, viewreset: this.update }; }, // @method getLatLng: LatLng // Returns the current geographical position of the marker. getLatLng: function() { return this._latlng; }, // @method setLatLng(latlng: LatLng): this // Changes the marker position to the given point. setLatLng: function(p) { var A = this._latlng; return this._latlng = xi(p), this.update(), this.fire("move", { oldLatLng: A, latlng: this._latlng }); }, // @method setZIndexOffset(offset: Number): this // Changes the [zIndex offset](#marker-zindexoffset) of the marker. setZIndexOffset: function(p) { return this.options.zIndexOffset = p, this.update(); }, // @method getIcon: Icon // Returns the current icon used by the marker getIcon: function() { return this.options.icon; }, // @method setIcon(icon: Icon): this // Changes the marker icon. setIcon: function(p) { return this.options.icon = p, this._map && (this._initIcon(), this.update()), this._popup && this.bindPopup(this._popup, this._popup.options), this; }, getElement: function() { return this._icon; }, update: function() { if (this._icon && this._map) { var p = this._map.latLngToLayerPoint(this._latlng).round(); this._setPos(p); } return this; }, _initIcon: function() { var p = this.options, A = "leaflet-zoom-" + (this._zoomAnimated ? "animated" : "hide"), B = p.icon.createIcon(this._icon), X = !1; B !== this._icon && (this._icon && this._removeIcon(), X = !0, p.title && (B.title = p.title), B.tagName === "IMG" && (B.alt = p.alt || "")), Vi(B, A), p.keyboard && (B.tabIndex = "0", B.setAttribute("role", "button")), this._icon = B, p.riseOnHover && this.on({ mouseover: this._bringToFront, mouseout: this._resetZIndex }), this.options.autoPanOnFocus && Bi(B, "focus", this._panOnFocus, this); var ne = p.icon.createShadow(this._shadow), ye = !1; ne !== this._shadow && (this._removeShadow(), ye = !0), ne && (Vi(ne, A), ne.alt = ""), this._shadow = ne, p.opacity < 1 && this._updateOpacity(), X && this.getPane().appendChild(this._icon), this._initInteraction(), ne && ye && this.getPane(p.shadowPane).appendChild(this._shadow); }, _removeIcon: function() { this.options.riseOnHover && this.off({ mouseover: this._bringToFront, mouseout: this._resetZIndex }), this.options.autoPanOnFocus && Cn(this._icon, "focus", this._panOnFocus, this), xn(this._icon), this.removeInteractiveTarget(this._icon), this._icon = null; }, _removeShadow: function() { this._shadow && xn(this._shadow), this._shadow = null; }, _setPos: function(p) { this._icon && Yn(this._icon, p), this._shadow && Yn(this._shadow, p), this._zIndex = p.y + this.options.zIndexOffset, this._resetZIndex(); }, _updateZIndex: function(p) { this._icon && (this._icon.style.zIndex = this._zIndex + p); }, _animateZoom: function(p) { var A = this._map._latLngToNewLayerPoint(this._latlng, p.zoom, p.center).round(); this._setPos(A); }, _initInteraction: function() { if (this.options.interactive && (Vi(this._icon, "leaflet-interactive"), this.addInteractiveTarget(this._icon), bs)) { var p = this.options.draggable; this.dragging && (p = this.dragging.enabled(), this.dragging.disable()), this.dragging = new bs(this), p && this.dragging.enable(); } }, // @method setOpacity(opacity: Number): this // Changes the opacity of the marker. setOpacity: function(p) { return this.options.opacity = p, this._map && this._updateOpacity(), this; }, _updateOpacity: function() { var p = this.options.opacity; this._icon && Qn(this._icon, p), this._shadow && Qn(this._shadow, p); }, _bringToFront: function() { this._updateZIndex(this.options.riseOffset); }, _resetZIndex: function() { this._updateZIndex(0); }, _panOnFocus: function() { var p = this._map; if (p) { var A = this.options.icon.options, B = A.iconSize ? ni(A.iconSize) : ni(0, 0), X = A.iconAnchor ? ni(A.iconAnchor) : ni(0, 0); p.panInside(this._latlng, { paddingTopLeft: X, paddingBottomRight: B.subtract(X) }); } }, _getPopupAnchor: function() { return this.options.icon.options.popupAnchor; }, _getTooltipAnchor: function() { return this.options.icon.options.tooltipAnchor; } }); function Wl(p, A) { return new ks(p, A); } var Tt = ar.extend({ // @section // @aka Path options options: { // @option stroke: Boolean = true // Whether to draw stroke along the path. Set it to `false` to disable borders on polygons or circles. stroke: !0, // @option color: String = '#3388ff' // Stroke color color: "#3388ff", // @option weight: Number = 3 // Stroke width in pixels weight: 3, // @option opacity: Number = 1.0 // Stroke opacity opacity: 1, // @option lineCap: String= 'round' // A string that defines [shape to be used at the end](https://developer.mozilla.org/docs/Web/SVG/Attribute/stroke-linecap) of the stroke. lineCap: "round", // @option lineJoin: String = 'round' // A string that defines [shape to be used at the corners](https://developer.mozilla.org/docs/Web/SVG/Attribute/stroke-linejoin) of the stroke. lineJoin: "round", // @option dashArray: String = null // A string that defines the stroke [dash pattern](https://developer.mozilla.org/docs/Web/SVG/Attribute/stroke-dasharray). Doesn't work on `Canvas`-powered layers in [some old browsers](https://developer.mozilla.org/docs/Web/API/CanvasRenderingContext2D/setLineDash#Browser_compatibility). dashArray: null, // @option dashOffset: String = null // A string that defines the [distance into the dash pattern to start the dash](https://developer.mozilla.org/docs/Web/SVG/Attribute/stroke-dashoffset). Doesn't work on `Canvas`-powered layers in [some old browsers](https://developer.mozilla.org/docs/Web/API/CanvasRenderingContext2D/setLineDash#Browser_compatibility). dashOffset: null, // @option fill: Boolean = depends // Whether to fill the path with color. Set it to `false` to disable filling on polygons or circles. fill: !1, // @option fillColor: String = * // Fill color. Defaults to the value of the [`color`](#path-color) option fillColor: null, // @option fillOpacity: Number = 0.2 // Fill opacity. fillOpacity: 0.2, // @option fillRule: String = 'evenodd' // A string that defines [how the inside of a shape](https://developer.mozilla.org/docs/Web/SVG/Attribute/fill-rule) is determined. fillRule: "evenodd", // className: '', // Option inherited from "Interactive layer" abstract class interactive: !0, // @option bubblingMouseEvents: Boolean = true // When `true`, a mouse event on this path will trigger the same event on the map // (unless [`L.DomEvent.stopPropagation`](#domevent-stoppropagation) is used). bubblingMouseEvents: !0 }, beforeAdd: function(p) { this._renderer = p.getRenderer(this); }, onAdd: function() { this._renderer._initPath(this), this._reset(), this._renderer._addPath(this); }, onRemove: function() { this._renderer._removePath(this); }, // @method redraw(): this // Redraws the layer. Sometimes useful after you changed the coordinates that the path uses. redraw: function() { return this._map && this._renderer._updatePath(this), this; }, // @method setStyle(style: Path options): this // Changes the appearance of a Path based on the options in the `Path options` object. setStyle: function(p) { return be(this, p), this._renderer && (this._renderer._updateStyle(this), this.options.stroke && p && Object.prototype.hasOwnProperty.call(p, "weight") && this._updateBounds()), this; }, // @method bringToFront(): this // Brings the layer to the top of all path layers. bringToFront: function() { return this._renderer && this._renderer._bringToFront(this), this; }, // @method bringToBack(): this // Brings the layer to the bottom of all path layers. bringToBack: function() { return this._renderer && this._renderer._bringToBack(this), this; }, getElement: function() { return this._path; }, _reset: function() { this._project(), this._update(); }, _clickTolerance: function() { return (this.options.stroke ? this.options.weight / 2 : 0) + (this._renderer.options.tolerance || 0); } }), ma = Tt.extend({ // @section // @aka CircleMarker options options: { fill: !0, // @option radius: Number = 10 // Radius of the circle marker, in pixels radius: 10 }, initialize: function(p, A) { be(this, A), this._latlng = xi(p), this._radius = this.options.radius; }, // @method setLatLng(latLng: LatLng): this // Sets the position of a circle marker to a new location. setLatLng: function(p) { var A = this._latlng; return this._latlng = xi(p), this.redraw(), this.fire("move", { oldLatLng: A, latlng: this._latlng }); }, // @method getLatLng(): LatLng // Returns the current geographical position of the circle marker getLatLng: function() { return this._latlng; }, // @method setRadius(radius: Number): this // Sets the radius of a circle marker. Units are in pixels. setRadius: function(p) { return this.options.radius = this._radius = p, this.redraw(); }, // @method getRadius(): Number // Returns the current radius of the circle getRadius: function() { return this._radius; }, setStyle: function(p) { var A = p && p.radius || this._radius; return Tt.prototype.setStyle.call(this, p), this.setRadius(A), this; }, _project: function() { this._point = this._map.latLngToLayerPoint(this._latlng), this._updateBounds(); }, _updateBounds: function() { var p = this._radius, A = this._radiusY || p, B = this._clickTolerance(), X = [p + B, A + B]; this._pxBounds = new Gi(this._point.subtract(X), this._point.add(X)); }, _update: function() { this._map && this._updatePath(); }, _updatePath: function() { this._renderer._updateCircle(this); }, _empty: function() { return this._radius && !this._renderer._bounds.intersects(this._pxBounds); }, // Needed by the `Canvas` renderer for interactivity _containsPoint: function(p) { return p.distanceTo(this._point) <= this._radius + this._clickTolerance(); } }); function Mo(p, A) { return new ma(p, A); } var gs = ma.extend({ initialize: function(p, A, B) { if (typeof A == "number" && (A = w({}, B, { radius: A })), be(this, A), this._latlng = xi(p), isNaN(this.options.radius)) throw new Error("Circle radius cannot be NaN"); this._mRadius = this.options.radius; }, // @method setRadius(radius: Number): this // Sets the radius of a circle. Units are in meters. setRadius: function(p) { return this._mRadius = p, this.redraw(); }, // @method getRadius(): Number // Returns the current radius of a circle. Units are in meters. getRadius: function() { return this._mRadius; }, // @method getBounds(): LatLngBounds // Returns the `LatLngBounds` of the path. getBounds: function() { var p = [this._radius, this._radiusY || this._radius]; return new qt( this._map.layerPointToLatLng(this._point.subtract(p)), this._map.layerPointToLatLng(this._point.add(p)) ); }, setStyle: Tt.prototype.setStyle, _project: function() { var p = this._latlng.lng, A = this._latlng.lat, B = this._map, X = B.options.crs; if (X.distance === xs.distance) { var ne = Math.PI / 180, ye = this._mRadius / xs.R / ne, We = B.project([A + ye, p]), at = B.project([A - ye, p]), ft = We.add(at).divideBy(2), Rt = B.unproject(ft).lat, ii = Math.acos((Math.cos(ye * ne) - Math.sin(A * ne) * Math.sin(Rt * ne)) / (Math.cos(A * ne) * Math.cos(Rt * ne))) / ne; (isNaN(ii) || ii === 0) && (ii = ye / Math.cos(Math.PI / 180 * A)), this._point = ft.subtract(B.getPixelOrigin()), this._radius = isNaN(ii) ? 0 : ft.x - B.project([Rt, p - ii]).x, this._radiusY = ft.y - We.y; } else { var Ci = X.unproject(X.project(this._latlng).subtract([this._mRadius, 0])); this._point = B.latLngToLayerPoint(this._latlng), this._radius = this._point.x - B.latLngToLayerPoint(Ci).x; } this._updateBounds(); } }); function Gh(p, A, B) { return new gs(p, A, B); } var Dr = Tt.extend({ // @section // @aka Polyline options options: { // @option smoothFactor: Number = 1.0 // How much to simplify the polyline on each zoom level. More means // better performance and smoother look, and less means more accurate representation. smoothFactor: 1, // @option noClip: Boolean = false // Disable polyline clipping. noClip: !1 }, initialize: function(p, A) { be(this, A), this._setLatLngs(p); }, // @method getLatLngs(): LatLng[] // Returns an array of the points in the path, or nested arrays of points in case of multi-polyline. getLatLngs: function() { return this._latlngs; }, // @method setLatLngs(latlngs: LatLng[]): this // Replaces all the points in the polyline with the given array of geographical points. setLatLngs: function(p) { return this._setLatLngs(p), this.redraw(); }, // @method isEmpty(): Boolean // Returns `true` if the Polyline has no LatLngs. isEmpty: function() { return !this._latlngs.length; }, // @method closestLayerPoint(p: Point): Point // Returns the point closest to `p` on the Polyline. closestLayerPoint: function(p) { for (var A = 1 / 0, B = null, X = $o, ne, ye, We = 0, at = this._parts.length; We < at; We++) for (var ft = this._parts[We], Rt = 1, ii = ft.length; Rt < ii; Rt++) { ne = ft[Rt - 1], ye = ft[Rt]; var Ci = X(p, ne, ye, !0); Ci < A && (A = Ci, B = X(p, ne, ye)); } return B && (B.distance = Math.sqrt(A)), B; }, // @method getCenter(): LatLng // Returns the center ([centroid](https://en.wikipedia.org/wiki/Centroid)) of the polyline. getCenter: function() { if (!this._map) throw new Error("Must add layer to map before using getCenter()"); return jh(this._defaultShape(), this._map.options.crs); }, // @method getBounds(): LatLngBounds // Returns the `LatLngBounds` of the path. getBounds: function() { return this._bounds; }, // @method addLatLng(latlng: LatLng, latlngs?: LatLng[]): this // Adds a given point to the polyline. By default, adds to the first ring of // the polyline in case of a multi-polyline, but can be overridden by passing // a specific ring as a LatLng array (that you can earlier access with [`getLatLngs`](#polyline-getlatlngs)). addLatLng: function(p, A) { return A = A || this._defaultShape(), p = xi(p), A.push(p), this._bounds.extend(p), this.redraw(); }, _setLatLngs: function(p) { this._bounds = new qt(), this._latlngs = this._convertLatLngs(p); }, _defaultShape: function() { return rs(this._latlngs) ? this._latlngs : this._latlngs[0]; }, // recursively convert latlngs input into actual LatLng instances; calculate bounds along the way _convertLatLngs: function(p) { for (var A = [], B = rs(p), X = 0, ne = p.length; X < ne; X++) B ? (A[X] = xi(p[X]), this._bounds.extend(A[X])) : A[X] = this._convertLatLngs(p[X]); return A; }, _project: function() { var p = new Gi(); this._rings = [], this._projectLatlngs(this._latlngs, this._rings, p), this._bounds.isValid() && p.isValid() && (this._rawPxBounds = p, this._updateBounds()); }, _updateBounds: function() { var p = this._clickTolerance(), A = new fi(p, p); this._rawPxBounds && (this._pxBounds = new Gi([ this._rawPxBounds.min.subtract(A), this._rawPxBounds.max.add(A) ])); }, // recursively turns latlngs into a set of rings with projected coordinates _projectLatlngs: function(p, A, B) { var X = p[0] instanceof Di, ne = p.length, ye, We; if (X) { for (We = [], ye = 0; ye < ne; ye++) We[ye] = this._map.latLngToLayerPoint(p[ye]), B.extend(We[ye]); A.push(We); } else for (ye = 0; ye < ne; ye++) this._projectLatlngs(p[ye], A, B); }, // clip polyline by renderer bounds so that we have less to render for performance _clipPoints: function() { var p = this._renderer._bounds; if (this._parts = [], !(!this._pxBounds || !this._pxBounds.intersects(p))) { if (this.options.noClip) { this._parts = this._rings; return; } var A = this._parts, B, X, ne, ye, We, at, ft; for (B = 0, ne = 0, ye = this._rings.length; B < ye; B++) for (ft = this._rings[B], X = 0, We = ft.length; X < We - 1; X++) at = Na(ft[X], ft[X + 1], p, X, !0), at && (A[ne] = A[ne] || [], A[ne].push(at[0]), (at[1] !== ft[X + 1] || X === We - 2) && (A[ne].push(at[1]), ne++)); } }, // simplify each clipped part of the polyline for performance _simplifyPoints: function() { for (var p = this._parts, A = this.options.smoothFactor, B = 0, X = p.length; B < X; B++) p[B] = fl(p[B], A); }, _update: function() { this._map && (this._clipPoints(), this._simplifyPoints(), this._updatePath()); }, _updatePath: function() { this._renderer._updatePoly(this); }, // Needed by the `Canvas` renderer for interactivity _containsPoint: function(p, A) { var B, X, ne, ye, We, at, ft = this._clickTolerance(); if (!this._pxBounds || !this._pxBounds.contains(p)) return !1; for (B = 0, ye = this._parts.length; B < ye; B++) for (at = this._parts[B], X = 0, We = at.length, ne = We - 1; X < We; ne = X++) if (!(!A && X === 0) && pl(p, at[ne], at[X]) <= ft) return !0; return !1; } }); function So(p, A) { return new Dr(p, A); } Dr._flat = Uh; var Kr = Dr.extend({ options: { fill: !0 }, isEmpty: function() { return !this._latlngs.length || !this._latlngs[0].length; }, // @method getCenter(): LatLng // Returns the center ([centroid](http://en.wikipedia.org/wiki/Centroid)) of the Polygon. getCenter: function() { if (!this._map) throw new Error("Must add layer to map before using getCenter()"); return Nc(this._defaultShape(), this._map.options.crs); }, _convertLatLngs: function(p) { var A = Dr.prototype._convertLatLngs.call(this, p), B = A.length; return B >= 2 && A[0] instanceof Di && A[0].equals(A[B - 1]) && A.pop(), A; }, _setLatLngs: function(p) { Dr.prototype._setLatLngs.call(this, p), rs(this._latlngs) && (this._latlngs = [this._latlngs]); }, _defaultShape: function() { return rs(this._latlngs[0]) ? this._latlngs[0] : this._latlngs[0][0]; }, _clipPoints: function() { var p = this._renderer._bounds, A = this.options.weight, B = new fi(A, A); if (p = new Gi(p.min.subtract(B), p.max.add(B)), this._parts = [], !(!this._pxBounds || !this._pxBounds.intersects(p))) { if (this.options.noClip) { this._parts = this._rings; return; } for (var X = 0, ne = this._rings.length, ye; X < ne; X++) ye = so(this._rings[X], p, !0), ye.length && this._parts.push(ye); } }, _updatePath: function() { this._renderer._updatePoly(this, !0); }, // Needed by the `Canvas` renderer for interactivity _containsPoint: function(p) { var A = !1, B, X, ne, ye, We, at, ft, Rt; if (!this._pxBounds || !this._pxBounds.contains(p)) return !1; for (ye = 0, ft = this._parts.length; ye < ft; ye++) for (B = this._parts[ye], We = 0, Rt = B.length, at = Rt - 1; We < Rt; at = We++) X = B[We], ne = B[at], X.y > p.y != ne.y > p.y && p.x < (ne.x - X.x) * (p.y - X.y) / (ne.y - X.y) + X.x && (A = !A); return A || Dr.prototype._containsPoint.call(this, p, !0); } }); function Yo(p, A) { return new Kr(p, A); } var cr = Xr.extend({ /* @section * @aka GeoJSON options * * @option pointToLayer: Function = * * A `Function` defining how GeoJSON points spawn Leaflet layers. It is internally * called when data is added, passing the GeoJSON point feature and its `LatLng`. * The default is to spawn a default `Marker`: * ```js * function(geoJsonPoint, latlng) { * return L.marker(latlng); * } * ``` * * @option style: Function = * * A `Function` defining the `Path options` for styling GeoJSON lines and polygons, * called internally when data is added. * The default value is to not override any defaults: * ```js * function (geoJsonFeature) { * return {} * } * ``` * * @option onEachFeature: Function = * * A `Function` that will be called once for each created `Feature`, after it has * been created and styled. Useful for attaching events and popups to features. * The default is to do nothing with the newly created layers: * ```js * function (feature, layer) {} * ``` * * @option filter: Function = * * A `Function` that will be used to decide whether to include a feature or not. * The default is to include all features: * ```js * function (geoJsonFeature) { * return true; * } * ``` * Note: dynamically changing the `filter` option will have effect only on newly * added data. It will _not_ re-evaluate already included features. * * @option coordsToLatLng: Function = * * A `Function` that will be used for converting GeoJSON coordinates to `LatLng`s. * The default is the `coordsToLatLng` static method. * * @option markersInheritOptions: Boolean = false * Whether default Markers for "Point" type Features inherit from group options. */ initialize: function(p, A) { be(this, A), this._layers = {}, p && this.addData(p); }, // @method addData( data ): this // Adds a GeoJSON object to the layer. addData: function(p) { var A = vt(p) ? p : p.features, B, X, ne; if (A) { for (B = 0, X = A.length; B < X; B++) ne = A[B], (ne.geometries || ne.geometry || ne.features || ne.coordinates) && this.addData(ne); return this; } var ye = this.options; if (ye.filter && !ye.filter(p)) return this; var We = Eo(p, ye); return We ? (We.feature = ga(p), We.defaultOptions = We.options, this.resetStyle(We), ye.onEachFeature && ye.onEachFeature(p, We), this.addLayer(We)) : this; }, // @method resetStyle( layer? ): this // Resets the given vector layer's style to the original GeoJSON style, useful for resetting style after hover events. // If `layer` is omitted, the style of all features in the current layer is reset. resetStyle: function(p) { return p === void 0 ? this.eachLayer(this.resetStyle, this) : (p.options = w({}, p.defaultOptions), this._setLayerStyle(p, this.options.style), this); }, // @method setStyle( style ): this // Changes styles of GeoJSON vector layers with the given style function. setStyle: function(p) { return this.eachLayer(function(A) { this._setLayerStyle(A, p); }, this); }, _setLayerStyle: function(p, A) { p.setStyle && (typeof A == "function" && (A = A(p.feature)), p.setStyle(A)); } }); function Eo(p, A) { var B = p.type === "Feature" ? p.geometry : p, X = B ? B.coordinates : null, ne = [], ye = A && A.pointToLayer, We = A && A.coordsToLatLng || Uc, at, ft, Rt, ii; if (!X && !B) return null; switch (B.type) { case "Point": return at = We(X), Zh(ye, p, at, A); case "MultiPoint": for (Rt = 0, ii = X.length; Rt < ii; Rt++) at = We(X[Rt]), ne.push(Zh(ye, p, at, A)); return new Xr(ne); case "LineString": case "MultiLineString": return ft = Ua(X, B.type === "LineString" ? 0 : 1, We), new Dr(ft, A); case "Polygon": case "MultiPolygon": return ft = Ua(X, B.type === "Polygon" ? 1 : 2, We), new Kr(ft, A); case "GeometryCollection": for (Rt = 0, ii = B.geometries.length; Rt < ii; Rt++) { var Ci = Eo({ geometry: B.geometries[Rt], type: "Feature", properties: p.properties }, A); Ci && ne.push(Ci); } return new Xr(ne); case "FeatureCollection": for (Rt = 0, ii = B.features.length; Rt < ii; Rt++) { var Wi = Eo(B.features[Rt], A); Wi && ne.push(Wi); } return new Xr(ne); default: throw new Error("Invalid GeoJSON object."); } } function Zh(p, A, B, X) { return p ? p(A, B) : new ks(B, X && X.markersInheritOptions && X); } function Uc(p) { return new Di(p[1], p[0], p[2]); } function Ua(p, A, B) { for (var X = [], ne = 0, ye = p.length, We; ne < ye; ne++) We = A ? Ua(p[ne], A - 1, B) : (B || Uc)(p[ne]), X.push(We); return X; } function $l(p, A) { return p = xi(p), p.alt !== void 0 ? [ae(p.lng, A), ae(p.lat, A), ae(p.alt, A)] : [ae(p.lng, A), ae(p.lat, A)]; } function yl(p, A, B, X) { for (var ne = [], ye = 0, We = p.length; ye < We; ye++) ne.push(A ? yl(p[ye], rs(p[ye]) ? 0 : A - 1, B, X) : $l(p[ye], X)); return !A && B && ne.length > 0 && ne.push(ne[0].slice()), ne; } function _a(p, A) { return p.feature ? w({}, p.feature, { geometry: A }) : ga(A); } function ga(p) { return p.type === "Feature" || p.type === "FeatureCollection" ? p : { type: "Feature", properties: {}, geometry: p }; } var Po = { toGeoJSON: function(p) { return _a(this, { type: "Point", coordinates: $l(this.getLatLng(), p) }); } }; ks.include(Po), gs.include(Po), ma.include(Po), Dr.include({ toGeoJSON: function(p) { var A = !rs(this._latlngs), B = yl(this._latlngs, A ? 1 : 0, !1, p); return _a(this, { type: (A ? "Multi" : "") + "LineString", coordinates: B }); } }), Kr.include({ toGeoJSON: function(p) { var A = !rs(this._latlngs), B = A && !rs(this._latlngs[0]), X = yl(this._latlngs, B ? 2 : A ? 1 : 0, !0, p); return A || (X = [X]), _a(this, { type: (B ? "Multi" : "") + "Polygon", coordinates: X }); } }), lr.include({ toMultiPoint: function(p) { var A = []; return this.eachLayer(function(B) { A.push(B.toGeoJSON(p).geometry.coordinates); }), _a(this, { type: "MultiPoint", coordinates: A }); }, // @method toGeoJSON(precision?: Number|false): Object // Coordinates values are rounded with [`formatNum`](#util-formatnum) function with given `precision`. // Returns a [`GeoJSON`](https://en.wikipedia.org/wiki/GeoJSON) representation of the layer group (as a GeoJSON `FeatureCollection`, `GeometryCollection`, or `MultiPoint`). toGeoJSON: function(p) { var A = this.feature && this.feature.geometry && this.feature.geometry.type; if (A === "MultiPoint") return this.toMultiPoint(p); var B = A === "GeometryCollection", X = []; return this.eachLayer(function(ne) { if (ne.toGeoJSON) { var ye = ne.toGeoJSON(p); if (B) X.push(ye.geometry); else { var We = ga(ye); We.type === "FeatureCollection" ? X.push.apply(X, We.features) : X.push(We); } } }), B ? _a(this, { geometries: X, type: "GeometryCollection" }) : { type: "FeatureCollection", features: X }; } }); function Hh(p, A) { return new cr(p, A); } var td = Hh, ja = ar.extend({ // @section // @aka ImageOverlay options options: { // @option opacity: Number = 1.0 // The opacity of the image overlay. opacity: 1, // @option alt: String = '' // Text for the `alt` attribute of the image (useful for accessibility). alt: "", // @option interactive: Boolean = false // If `true`, the image overlay will emit [mouse events](#interactive-layer) when clicked or hovered. interactive: !1, // @option crossOrigin: Boolean|String = false // Whether the crossOrigin attribute will be added to the image. // If a String is provided, the image will have its crossOrigin attribute set to the String provided. This is needed if you want to access image pixel data. // Refer to [CORS Settings](https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_settings_attributes) for valid String values. crossOrigin: !1, // @option errorOverlayUrl: String = '' // URL to the overlay image to show in place of the overlay that failed to load. errorOverlayUrl: "", // @option zIndex: Number = 1 // The explicit [zIndex](https://developer.mozilla.org/docs/Web/CSS/CSS_Positioning/Understanding_z_index) of the overlay layer. zIndex: 1, // @option className: String = '' // A custom class name to assign to the image. Empty by default. className: "" }, initialize: function(p, A, B) { this._url = p, this._bounds = ln(A), be(this, B); }, onAdd: function() { this._image || (this._initImage(), this.options.opacity < 1 && this._updateOpacity()), this.options.interactive && (Vi(this._image, "leaflet-interactive"), this.addInteractiveTarget(this._image)), this.getPane().appendChild(this._image), this._reset(); }, onRemove: function() { xn(this._image), this.options.interactive && this.removeInteractiveTarget(this._image); }, // @method setOpacity(opacity: Number): this // Sets the opacity of the overlay. setOpacity: function(p) { return this.options.opacity = p, this._image && this._updateOpacity(), this; }, setStyle: function(p) { return p.opacity && this.setOpacity(p.opacity), this; }, // @method bringToFront(): this // Brings the layer to the top of all overlays. bringToFront: function() { return this._map && Go(this._image), this; }, // @method bringToBack(): this // Brings the layer to the bottom of all overlays. bringToBack: function() { return this._map && aa(this._image), this; }, // @method setUrl(url: String): this // Changes the URL of the image. setUrl: function(p) { return this._url = p, this._image && (this._image.src = p), this; }, // @method setBounds(bounds: LatLngBounds): this // Update the bounds that this ImageOverlay covers setBounds: function(p) { return this._bounds = ln(p), this._map && this._reset(), this; }, getEvents: function() { var p = { zoom: this._reset, viewreset: this._reset }; return this._zoomAnimated && (p.zoomanim = this._animateZoom), p; }, // @method setZIndex(value: Number): this // Changes the [zIndex](#imageoverlay-zindex) of the image overlay. setZIndex: function(p) { return this.options.zIndex = p, this._updateZIndex(), this; }, // @method getBounds(): LatLngBounds // Get the bounds that this ImageOverlay covers getBounds: function() { return this._bounds; }, // @method getElement(): HTMLElement // Returns the instance of [`HTMLImageElement`](https://developer.mozilla.org/docs/Web/API/HTMLImageElement) // used by this overlay. getElement: function() { return this._image; }, _initImage: function() { var p = this._url.tagName === "IMG", A = this._image = p ? this._url : tn("img"); if (Vi(A, "leaflet-image-layer"), this._zoomAnimated && Vi(A, "leaflet-zoom-animated"), this.options.className && Vi(A, this.options.className), A.onselectstart = J, A.onmousemove = J, A.onload = E(this.fire, this, "load"), A.onerror = E(this._overlayOnError, this, "error"), (this.options.crossOrigin || this.options.crossOrigin === "") && (A.crossOrigin = this.options.crossOrigin === !0 ? "" : this.options.crossOrigin), this.options.zIndex && this._updateZIndex(), p) { this._url = A.src; return; } A.src = this._url, A.alt = this.options.alt; }, _animateZoom: function(p) { var A = this._map.getZoomScale(p.zoom), B = this._map._latLngBoundsToNewLayerBounds(this._bounds, p.zoom, p.center).min; Ks(this._image, B, A); }, _reset: function() { var p = this._image, A = new Gi( this._map.latLngToLayerPoint(this._bounds.getNorthWest()), this._map.latLngToLayerPoint(this._bounds.getSouthEast()) ), B = A.getSize(); Yn(p, A.min), p.style.width = B.x + "px", p.style.height = B.y + "px"; }, _updateOpacity: function() { Qn(this._image, this.options.opacity); }, _updateZIndex: function() { this._image && this.options.zIndex !== void 0 && this.options.zIndex !== null && (this._image.style.zIndex = this.options.zIndex); }, _overlayOnError: function() { this.fire("error"); var p = this.options.errorOverlayUrl; p && this._url !== p && (this._url = p, this._image.src = p); }, // @method getCenter(): LatLng // Returns the center of the ImageOverlay. getCenter: function() { return this._bounds.getCenter(); } }), jc = function(p, A, B) { return new ja(p, A, B); }, Gc = ja.extend({ // @section // @aka VideoOverlay options options: { // @option autoplay: Boolean = true // Whether the video starts playing automatically when loaded. // On some browsers autoplay will only work with `muted: true` autoplay: !0, // @option loop: Boolean = true // Whether the video will loop back to the beginning when played. loop: !0, // @option keepAspectRatio: Boolean = true // Whether the video will save aspect ratio after the projection. // Relevant for supported browsers. See [browser compatibility](https://developer.mozilla.org/en-US/docs/Web/CSS/object-fit) keepAspectRatio: !0, // @option muted: Boolean = false // Whether the video starts on mute when loaded. muted: !1, // @option playsInline: Boolean = true // Mobile browsers will play the video right where it is instead of open it up in fullscreen mode. playsInline: !0 }, _initImage: function() { var p = this._url.tagName === "VIDEO", A = this._image = p ? this._url : tn("video"); if (Vi(A, "leaflet-image-layer"), this._zoomAnimated && Vi(A, "leaflet-zoom-animated"), this.options.className && Vi(A, this.options.className), A.onselectstart = J, A.onmousemove = J, A.onloadeddata = E(this.fire, this, "load"), p) { for (var B = A.getElementsByTagName("source"), X = [], ne = 0; ne < B.length; ne++) X.push(B[ne].src); this._url = B.length > 0 ? X : [A.src]; return; } vt(this._url) || (this._url = [this._url]), !this.options.keepAspectRatio && Object.prototype.hasOwnProperty.call(A.style, "objectFit") && (A.style.objectFit = "fill"), A.autoplay = !!this.options.autoplay, A.loop = !!this.options.loop, A.muted = !!this.options.muted, A.playsInline = !!this.options.playsInline; for (var ye = 0; ye < this._url.length; ye++) { var We = tn("source"); We.src = this._url[ye], A.appendChild(We); } } // @method getElement(): HTMLVideoElement // Returns the instance of [`HTMLVideoElement`](https://developer.mozilla.org/docs/Web/API/HTMLVideoElement) // used by this overlay. }); function hr(p, A, B) { return new Gc(p, A, B); } var Zc = ja.extend({ _initImage: function() { var p = this._image = this._url; Vi(p, "leaflet-image-layer"), this._zoomAnimated && Vi(p, "leaflet-zoom-animated"), this.options.className && Vi(p, this.options.className), p.onselectstart = J, p.onmousemove = J; } // @method getElement(): SVGElement // Returns the instance of [`SVGElement`](https://developer.mozilla.org/docs/Web/API/SVGElement) // used by this overlay. }); function Hc(p, A, B) { return new Zc(p, A, B); } var xr = ar.extend({ // @section // @aka DivOverlay options options: { // @option interactive: Boolean = false // If true, the popup/tooltip will listen to the mouse events. interactive: !1, // @option offset: Point = Point(0, 0) // The offset of the overlay position. offset: [0, 0], // @option className: String = '' // A custom CSS class name to assign to the overlay. className: "", // @option pane: String = undefined // `Map pane` where the overlay will be added. pane: void 0, // @option content: String|HTMLElement|Function = '' // Sets the HTML content of the overlay while initializing. If a function is passed the source layer will be // passed to the function. The function should return a `String` or `HTMLElement` to be used in the overlay. content: "" }, initialize: function(p, A) { p && (p instanceof Di || vt(p)) ? (this._latlng = xi(p), be(this, A)) : (be(this, p), this._source = A), this.options.content && (this._content = this.options.content); }, // @method openOn(map: Map): this // Adds the overlay to the map. // Alternative to `map.openPopup(popup)`/`.openTooltip(tooltip)`. openOn: function(p) { return p = arguments.length ? p : this._source._map, p.hasLayer(this) || p.addLayer(this), this; }, // @method close(): this // Closes the overlay. // Alternative to `map.closePopup(popup)`/`.closeTooltip(tooltip)` // and `layer.closePopup()`/`.closeTooltip()`. close: function() { return this._map && this._map.removeLayer(this), this; }, // @method toggle(layer?: Layer): this // Opens or closes the overlay bound to layer depending on its current state. // Argument may be omitted only for overlay bound to layer. // Alternative to `layer.togglePopup()`/`.toggleTooltip()`. toggle: function(p) { return this._map ? this.close() : (arguments.length ? this._source = p : p = this._source, this._prepareOpen(), this.openOn(p._map)), this; }, onAdd: function(p) { this._zoomAnimated = p._zoomAnimated, this._container || this._initLayout(), p._fadeAnimated && Qn(this._container, 0), clearTimeout(this._removeTimeout), this.getPane().appendChild(this._container), this.update(), p._fadeAnimated && Qn(this._container, 1), this.bringToFront(), this.options.interactive && (Vi(this._container, "leaflet-interactive"), this.addInteractiveTarget(this._container)); }, onRemove: function(p) { p._fadeAnimated ? (Qn(this._container, 0), this._removeTimeout = setTimeout(E(xn, void 0, this._container), 200)) : xn(this._container), this.options.interactive && (Hn(this._container, "leaflet-interactive"), this.removeInteractiveTarget(this._container)); }, // @namespace DivOverlay // @method getLatLng: LatLng // Returns the geographical point of the overlay. getLatLng: function() { return this._latlng; }, // @method setLatLng(latlng: LatLng): this // Sets the geographical point where the overlay will open. setLatLng: function(p) { return this._latlng = xi(p), this._map && (this._updatePosition(), this._adjustPan()), this; }, // @method getContent: String|HTMLElement // Returns the content of the overlay. getContent: function() { return this._content; }, // @method setContent(htmlContent: String|HTMLElement|Function): this // Sets the HTML content of the overlay. If a function is passed the source layer will be passed to the function. // The function should return a `String` or `HTMLElement` to be used in the overlay. setContent: function(p) { return this._content = p, this.update(), this; }, // @method getElement: String|HTMLElement // Returns the HTML container of the overlay. getElement: function() { return this._container; }, // @method update: null // Updates the overlay content, layout and position. Useful for updating the overlay after something inside changed, e.g. image loaded. update: function() { this._map && (this._container.style.visibility = "hidden", this._updateContent(), this._updateLayout(), this._updatePosition(), this._container.style.visibility = "", this._adjustPan()); }, getEvents: function() { var p = { zoom: this._updatePosition, viewreset: this._updatePosition }; return this._zoomAnimated && (p.zoomanim = this._animateZoom), p; }, // @method isOpen: Boolean // Returns `true` when the overlay is visible on the map. isOpen: function() { return !!this._map && this._map.hasLayer(this); }, // @method bringToFront: this // Brings this overlay in front of other overlays (in the same map pane). bringToFront: function() { return this._map && Go(this._container), this; }, // @method bringToBack: this // Brings this overlay to the back of other overlays (in the same map pane). bringToBack: function() { return this._map && aa(this._container), this; }, // prepare bound overlay to open: update latlng pos / content source (for FeatureGroup) _prepareOpen: function(p) { var A = this._source; if (!A._map) return !1; if (A instanceof Xr) { A = null; var B = this._source._layers; for (var X in B) if (B[X]._map) { A = B[X]; break; } if (!A) return !1; this._source = A; } if (!p) if (A.getCenter) p = A.getCenter(); else if (A.getLatLng) p = A.getLatLng(); else if (A.getBounds) p = A.getBounds().getCenter(); else throw new Error("Unable to get source layer LatLng."); return this.setLatLng(p), this._map && this.update(), !0; }, _updateContent: function() { if (this._content) { var p = this._contentNode, A = typeof this._content == "function" ? this._content(this._source || this) : this._content; if (typeof A == "string") p.innerHTML = A; else { for (; p.hasChildNodes(); ) p.removeChild(p.firstChild); p.appendChild(A); } this.fire("contentupdate"); } }, _updatePosition: function() { if (this._map) { var p = this._map.latLngToLayerPoint(this._latlng), A = ni(this.options.offset), B = this._getAnchor(); this._zoomAnimated ? Yn(this._container, p.add(B)) : A = A.add(p).add(B); var X = this._containerBottom = -A.y, ne = this._containerLeft = -Math.round(this._containerWidth / 2) + A.x; this._container.style.bottom = X + "px", this._container.style.left = ne + "px"; } }, _getAnchor: function() { return [0, 0]; } }); nn.include({ _initOverlay: function(p, A, B, X) { var ne = A; return ne instanceof p || (ne = new p(X).setContent(A)), B && ne.setLatLng(B), ne; } }), ar.include({ _initOverlay: function(p, A, B, X) { var ne = B; return ne instanceof p ? (be(ne, X), ne._source = this) : (ne = A && !X ? A : new p(X, this), ne.setContent(B)), ne; } }); var Ko = xr.extend({ // @section // @aka Popup options options: { // @option pane: String = 'popupPane' // `Map pane` where the popup will be added. pane: "popupPane", // @option offset: Point = Point(0, 7) // The offset of the popup position. offset: [0, 7], // @option maxWidth: Number = 300 // Max width of the popup, in pixels. maxWidth: 300, // @option minWidth: Number = 50 // Min width of the popup, in pixels. minWidth: 50, // @option maxHeight: Number = null // If set, creates a scrollable container of the given height // inside a popup if its content exceeds it. // The scrollable container can be styled using the // `leaflet-popup-scrolled` CSS class selector. maxHeight: null, // @option autoPan: Boolean = true // Set it to `false` if you don't want the map to do panning animation // to fit the opened popup. autoPan: !0, // @option autoPanPaddingTopLeft: Point = null // The margin between the popup and the top left corner of the map // view after autopanning was performed. autoPanPaddingTopLeft: null, // @option autoPanPaddingBottomRight: Point = null // The margin between the popup and the bottom right corner of the map // view after autopanning was performed. autoPanPaddingBottomRight: null, // @option autoPanPadding: Point = Point(5, 5) // Equivalent of setting both top left and bottom right autopan padding to the same value. autoPanPadding: [5, 5], // @option keepInView: Boolean = false // Set it to `true` if you want to prevent users from panning the popup // off of the screen while it is open. keepInView: !1, // @option closeButton: Boolean = true // Controls the presence of a close button in the popup. closeButton: !0, // @option autoClose: Boolean = true // Set it to `false` if you want to override the default behavior of // the popup closing when another popup is opened. autoClose: !0, // @option closeOnEscapeKey: Boolean = true // Set it to `false` if you want to override the default behavior of // the ESC key for closing of the popup. closeOnEscapeKey: !0, // @option closeOnClick: Boolean = * // Set it if you want to override the default behavior of the popup closing when user clicks // on the map. Defaults to the map's [`closePopupOnClick`](#map-closepopuponclick) option. // @option className: String = '' // A custom CSS class name to assign to the popup. className: "" }, // @namespace Popup // @method openOn(map: Map): this // Alternative to `map.openPopup(popup)`. // Adds the popup to the map and closes the previous one. openOn: function(p) { return p = arguments.length ? p : this._source._map, !p.hasLayer(this) && p._popup && p._popup.options.autoClose && p.removeLayer(p._popup), p._popup = this, xr.prototype.openOn.call(this, p); }, onAdd: function(p) { xr.prototype.onAdd.call(this, p), p.fire("popupopen", { popup: this }), this._source && (this._source.fire("popupopen", { popup: this }, !0), this._source instanceof Tt || this._source.on("preclick", ms)); }, onRemove: function(p) { xr.prototype.onRemove.call(this, p), p.fire("popupclose", { popup: this }), this._source && (this._source.fire("popupclose", { popup: this }, !0), this._source instanceof Tt || this._source.off("preclick", ms)); }, getEvents: function() { var p = xr.prototype.getEvents.call(this); return (this.options.closeOnClick !== void 0 ? this.options.closeOnClick : this._map.options.closePopupOnClick) && (p.preclick = this.close), this.options.keepInView && (p.moveend = this._adjustPan), p; }, _initLayout: function() { var p = "leaflet-popup", A = this._container = tn( "div", p + " " + (this.options.className || "") + " leaflet-zoom-animated" ), B = this._wrapper = tn("div", p + "-content-wrapper", A); if (this._contentNode = tn("div", p + "-content", B), Pi(A), bo(this._contentNode), Bi(A, "contextmenu", ms), this._tipContainer = tn("div", p + "-tip-container", A), this._tip = tn("div", p + "-tip", this._tipContainer), this.options.closeButton) { var X = this._closeButton = tn("a", p + "-close-button", A); X.setAttribute("role", "button"), X.setAttribute("aria-label", "Close popup"), X.href = "#close", X.innerHTML = '', Bi(X, "click", function(ne) { _s(ne), this.close(); }, this); } }, _updateLayout: function() { var p = this._contentNode, A = p.style; A.width = "", A.whiteSpace = "nowrap"; var B = p.offsetWidth; B = Math.min(B, this.options.maxWidth), B = Math.max(B, this.options.minWidth), A.width = B + 1 + "px", A.whiteSpace = "", A.height = ""; var X = p.offsetHeight, ne = this.options.maxHeight, ye = "leaflet-popup-scrolled"; ne && X > ne ? (A.height = ne + "px", Vi(p, ye)) : Hn(p, ye), this._containerWidth = this._container.offsetWidth; }, _animateZoom: function(p) { var A = this._map._latLngToNewLayerPoint(this._latlng, p.zoom, p.center), B = this._getAnchor(); Yn(this._container, A.add(B)); }, _adjustPan: function() { if (this.options.autoPan) { if (this._map._panAnim && this._map._panAnim.stop(), this._autopanning) { this._autopanning = !1; return; } var p = this._map, A = parseInt(jo(this._container, "marginBottom"), 10) || 0, B = this._container.offsetHeight + A, X = this._containerWidth, ne = new fi(this._containerLeft, -B - this._containerBottom); ne._add($r(this._container)); var ye = p.layerPointToContainerPoint(ne), We = ni(this.options.autoPanPadding), at = ni(this.options.autoPanPaddingTopLeft || We), ft = ni(this.options.autoPanPaddingBottomRight || We), Rt = p.getSize(), ii = 0, Ci = 0; ye.x + X + ft.x > Rt.x && (ii = ye.x + X - Rt.x + ft.x), ye.x - ii - at.x < 0 && (ii = ye.x - at.x), ye.y + B + ft.y > Rt.y && (Ci = ye.y + B - Rt.y + ft.y), ye.y - Ci - at.y < 0 && (Ci = ye.y - at.y), (ii || Ci) && (this.options.keepInView && (this._autopanning = !0), p.fire("autopanstart").panBy([ii, Ci])); } }, _getAnchor: function() { return ni(this._source && this._source._getPopupAnchor ? this._source._getPopupAnchor() : [0, 0]); } }), Xl = function(p, A) { return new Ko(p, A); }; nn.mergeOptions({ closePopupOnClick: !0 }), nn.include({ // @method openPopup(popup: Popup): this // Opens the specified popup while closing the previously opened (to make sure only one is opened at one time for usability). // @alternative // @method openPopup(content: String|HTMLElement, latlng: LatLng, options?: Popup options): this // Creates a popup with the specified content and options and opens it in the given point on a map. openPopup: function(p, A, B) { return this._initOverlay(Ko, p, A, B).openOn(this), this; }, // @method closePopup(popup?: Popup): this // Closes the popup previously opened with [openPopup](#map-openpopup) (or the given one). closePopup: function(p) { return p = arguments.length ? p : this._popup, p && p.close(), this; } }), ar.include({ // @method bindPopup(content: String|HTMLElement|Function|Popup, options?: Popup options): this // Binds a popup to the layer with the passed `content` and sets up the // necessary event listeners. If a `Function` is passed it will receive // the layer as the first argument and should return a `String` or `HTMLElement`. bindPopup: function(p, A) { return this._popup = this._initOverlay(Ko, this._popup, p, A), this._popupHandlersAdded || (this.on({ click: this._openPopup, keypress: this._onKeyPress, remove: this.closePopup, move: this._movePopup }), this._popupHandlersAdded = !0), this; }, // @method unbindPopup(): this // Removes the popup previously bound with `bindPopup`. unbindPopup: function() { return this._popup && (this.off({ click: this._openPopup, keypress: this._onKeyPress, remove: this.closePopup, move: this._movePopup }), this._popupHandlersAdded = !1, this._popup = null), this; }, // @method openPopup(latlng?: LatLng): this // Opens the bound popup at the specified `latlng` or at the default popup anchor if no `latlng` is passed. openPopup: function(p) { return this._popup && (this instanceof Xr || (this._popup._source = this), this._popup._prepareOpen(p || this._latlng) && this._popup.openOn(this._map)), this; }, // @method closePopup(): this // Closes the popup bound to this layer if it is open. closePopup: function() { return this._popup && this._popup.close(), this; }, // @method togglePopup(): this // Opens or closes the popup bound to this layer depending on its current state. togglePopup: function() { return this._popup && this._popup.toggle(this), this; }, // @method isPopupOpen(): boolean // Returns `true` if the popup bound to this layer is currently open. isPopupOpen: function() { return this._popup ? this._popup.isOpen() : !1; }, // @method setPopupContent(content: String|HTMLElement|Popup): this // Sets the content of the popup bound to this layer. setPopupContent: function(p) { return this._popup && this._popup.setContent(p), this; }, // @method getPopup(): Popup // Returns the popup bound to this layer. getPopup: function() { return this._popup; }, _openPopup: function(p) { if (!(!this._popup || !this._map)) { Js(p); var A = p.layer || p.target; if (this._popup._source === A && !(A instanceof Tt)) { this._map.hasLayer(this._popup) ? this.closePopup() : this.openPopup(p.latlng); return; } this._popup._source = A, this.openPopup(p.latlng); } }, _movePopup: function(p) { this._popup.setLatLng(p.latlng); }, _onKeyPress: function(p) { p.originalEvent.keyCode === 13 && this._openPopup(p); } }); var Jr = xr.extend({ // @section // @aka Tooltip options options: { // @option pane: String = 'tooltipPane' // `Map pane` where the tooltip will be added. pane: "tooltipPane", // @option offset: Point = Point(0, 0) // Optional offset of the tooltip position. offset: [0, 0], // @option direction: String = 'auto' // Direction where to open the tooltip. Possible values are: `right`, `left`, // `top`, `bottom`, `center`, `auto`. // `auto` will dynamically switch between `right` and `left` according to the tooltip // position on the map. direction: "auto", // @option permanent: Boolean = false // Whether to open the tooltip permanently or only on mouseover. permanent: !1, // @option sticky: Boolean = false // If true, the tooltip will follow the mouse instead of being fixed at the feature center. sticky: !1, // @option opacity: Number = 0.9 // Tooltip container opacity. opacity: 0.9 }, onAdd: function(p) { xr.prototype.onAdd.call(this, p), this.setOpacity(this.options.opacity), p.fire("tooltipopen", { tooltip: this }), this._source && (this.addEventParent(this._source), this._source.fire("tooltipopen", { tooltip: this }, !0)); }, onRemove: function(p) { xr.prototype.onRemove.call(this, p), p.fire("tooltipclose", { tooltip: this }), this._source && (this.removeEventParent(this._source), this._source.fire("tooltipclose", { tooltip: this }, !0)); }, getEvents: function() { var p = xr.prototype.getEvents.call(this); return this.options.permanent || (p.preclick = this.close), p; }, _initLayout: function() { var p = "leaflet-tooltip", A = p + " " + (this.options.className || "") + " leaflet-zoom-" + (this._zoomAnimated ? "animated" : "hide"); this._contentNode = this._container = tn("div", A), this._container.setAttribute("role", "tooltip"), this._container.setAttribute("id", "leaflet-tooltip-" + O(this)); }, _updateLayout: function() { }, _adjustPan: function() { }, _setPosition: function(p) { var A, B, X = this._map, ne = this._container, ye = X.latLngToContainerPoint(X.getCenter()), We = X.layerPointToContainerPoint(p), at = this.options.direction, ft = ne.offsetWidth, Rt = ne.offsetHeight, ii = ni(this.options.offset), Ci = this._getAnchor(); at === "top" ? (A = ft / 2, B = Rt) : at === "bottom" ? (A = ft / 2, B = 0) : at === "center" ? (A = ft / 2, B = Rt / 2) : at === "right" ? (A = 0, B = Rt / 2) : at === "left" ? (A = ft, B = Rt / 2) : We.x < ye.x ? (at = "right", A = 0, B = Rt / 2) : (at = "left", A = ft + (ii.x + Ci.x) * 2, B = Rt / 2), p = p.subtract(ni(A, B, !0)).add(ii).add(Ci), Hn(ne, "leaflet-tooltip-right"), Hn(ne, "leaflet-tooltip-left"), Hn(ne, "leaflet-tooltip-top"), Hn(ne, "leaflet-tooltip-bottom"), Vi(ne, "leaflet-tooltip-" + at), Yn(ne, p); }, _updatePosition: function() { var p = this._map.latLngToLayerPoint(this._latlng); this._setPosition(p); }, setOpacity: function(p) { this.options.opacity = p, this._container && Qn(this._container, p); }, _animateZoom: function(p) { var A = this._map._latLngToNewLayerPoint(this._latlng, p.zoom, p.center); this._setPosition(A); }, _getAnchor: function() { return ni(this._source && this._source._getTooltipAnchor && !this.options.sticky ? this._source._getTooltipAnchor() : [0, 0]); } }), Yl = function(p, A) { return new Jr(p, A); }; nn.include({ // @method openTooltip(tooltip: Tooltip): this // Opens the specified tooltip. // @alternative // @method openTooltip(content: String|HTMLElement, latlng: LatLng, options?: Tooltip options): this // Creates a tooltip with the specified content and options and open it. openTooltip: function(p, A, B) { return this._initOverlay(Jr, p, A, B).openOn(this), this; }, // @method closeTooltip(tooltip: Tooltip): this // Closes the tooltip given as parameter. closeTooltip: function(p) { return p.close(), this; } }), ar.include({ // @method bindTooltip(content: String|HTMLElement|Function|Tooltip, options?: Tooltip options): this // Binds a tooltip to the layer with the passed `content` and sets up the // necessary event listeners. If a `Function` is passed it will receive // the layer as the first argument and should return a `String` or `HTMLElement`. bindTooltip: function(p, A) { return this._tooltip && this.isTooltipOpen() && this.unbindTooltip(), this._tooltip = this._initOverlay(Jr, this._tooltip, p, A), this._initTooltipInteractions(), this._tooltip.options.permanent && this._map && this._map.hasLayer(this) && this.openTooltip(), this; }, // @method unbindTooltip(): this // Removes the tooltip previously bound with `bindTooltip`. unbindTooltip: function() { return this._tooltip && (this._initTooltipInteractions(!0), this.closeTooltip(), this._tooltip = null), this; }, _initTooltipInteractions: function(p) { if (!(!p && this._tooltipHandlersAdded)) { var A = p ? "off" : "on", B = { remove: this.closeTooltip, move: this._moveTooltip }; this._tooltip.options.permanent ? B.add = this._openTooltip : (B.mouseover = this._openTooltip, B.mouseout = this.closeTooltip, B.click = this._openTooltip, this._map ? this._addFocusListeners() : B.add = this._addFocusListeners), this._tooltip.options.sticky && (B.mousemove = this._moveTooltip), this[A](B), this._tooltipHandlersAdded = !p; } }, // @method openTooltip(latlng?: LatLng): this // Opens the bound tooltip at the specified `latlng` or at the default tooltip anchor if no `latlng` is passed. openTooltip: function(p) { return this._tooltip && (this instanceof Xr || (this._tooltip._source = this), this._tooltip._prepareOpen(p) && (this._tooltip.openOn(this._map), this.getElement ? this._setAriaDescribedByOnLayer(this) : this.eachLayer && this.eachLayer(this._setAriaDescribedByOnLayer, this))), this; }, // @method closeTooltip(): this // Closes the tooltip bound to this layer if it is open. closeTooltip: function() { if (this._tooltip) return this._tooltip.close(); }, // @method toggleTooltip(): this // Opens or closes the tooltip bound to this layer depending on its current state. toggleTooltip: function() { return this._tooltip && this._tooltip.toggle(this), this; }, // @method isTooltipOpen(): boolean // Returns `true` if the tooltip bound to this layer is currently open. isTooltipOpen: function() { return this._tooltip.isOpen(); }, // @method setTooltipContent(content: String|HTMLElement|Tooltip): this // Sets the content of the tooltip bound to this layer. setTooltipContent: function(p) { return this._tooltip && this._tooltip.setContent(p), this; }, // @method getTooltip(): Tooltip // Returns the tooltip bound to this layer. getTooltip: function() { return this._tooltip; }, _addFocusListeners: function() { this.getElement ? this._addFocusListenersOnLayer(this) : this.eachLayer && this.eachLayer(this._addFocusListenersOnLayer, this); }, _addFocusListenersOnLayer: function(p) { var A = typeof p.getElement == "function" && p.getElement(); A && (Bi(A, "focus", function() { this._tooltip._source = p, this.openTooltip(); }, this), Bi(A, "blur", this.closeTooltip, this)); }, _setAriaDescribedByOnLayer: function(p) { var A = typeof p.getElement == "function" && p.getElement(); A && A.setAttribute("aria-describedby", this._tooltip._container.id); }, _openTooltip: function(p) { if (!(!this._tooltip || !this._map)) { if (this._map.dragging && this._map.dragging.moving() && !this._openOnceFlag) { this._openOnceFlag = !0; var A = this; this._map.once("moveend", function() { A._openOnceFlag = !1, A._openTooltip(p); }); return; } this._tooltip._source = p.layer || p.target, this.openTooltip(this._tooltip.options.sticky ? p.latlng : void 0); } }, _moveTooltip: function(p) { var A = p.latlng, B, X; this._tooltip.options.sticky && p.originalEvent && (B = this._map.mouseEventToContainerPoint(p.originalEvent), X = this._map.containerPointToLayerPoint(B), A = this._map.layerPointToLatLng(X)), this._tooltip.setLatLng(A); } }); var Kl = Yr.extend({ options: { // @section // @aka DivIcon options iconSize: [12, 12], // also can be set through CSS // iconAnchor: (Point), // popupAnchor: (Point), // @option html: String|HTMLElement = '' // Custom HTML code to put inside the div element, empty by default. Alternatively, // an instance of `HTMLElement`. html: !1, // @option bgPos: Point = [0, 0] // Optional relative position of the background, in pixels bgPos: null, className: "leaflet-div-icon" }, createIcon: function(p) { var A = p && p.tagName === "DIV" ? p : document.createElement("div"), B = this.options; if (B.html instanceof Element ? (no(A), A.appendChild(B.html)) : A.innerHTML = B.html !== !1 ? B.html : "", B.bgPos) { var X = ni(B.bgPos); A.style.backgroundPosition = -X.x + "px " + -X.y + "px"; } return this._setIconStyles(A, "icon"), A; }, createShadow: function() { return null; } }); function ya(p) { return new Kl(p); } Yr.Default = To; var ro = ar.extend({ // @section // @aka GridLayer options options: { // @option tileSize: Number|Point = 256 // Width and height of tiles in the grid. Use a number if width and height are equal, or `L.point(width, height)` otherwise. tileSize: 256, // @option opacity: Number = 1.0 // Opacity of the tiles. Can be used in the `createTile()` function. opacity: 1, // @option updateWhenIdle: Boolean = (depends) // Load new tiles only when panning ends. // `true` by default on mobile browsers, in order to avoid too many requests and keep smooth navigation. // `false` otherwise in order to display new tiles _during_ panning, since it is easy to pan outside the // [`keepBuffer`](#gridlayer-keepbuffer) option in desktop browsers. updateWhenIdle: Pe.mobile, // @option updateWhenZooming: Boolean = true // By default, a smooth zoom animation (during a [touch zoom](#map-touchzoom) or a [`flyTo()`](#map-flyto)) will update grid layers every integer zoom level. Setting this option to `false` will update the grid layer only when the smooth animation ends. updateWhenZooming: !0, // @option updateInterval: Number = 200 // Tiles will not update more than once every `updateInterval` milliseconds when panning. updateInterval: 200, // @option zIndex: Number = 1 // The explicit zIndex of the tile layer. zIndex: 1, // @option bounds: LatLngBounds = undefined // If set, tiles will only be loaded inside the set `LatLngBounds`. bounds: null, // @option minZoom: Number = 0 // The minimum zoom level down to which this layer will be displayed (inclusive). minZoom: 0, // @option maxZoom: Number = undefined // The maximum zoom level up to which this layer will be displayed (inclusive). maxZoom: void 0, // @option maxNativeZoom: Number = undefined // Maximum zoom number the tile source has available. If it is specified, // the tiles on all zoom levels higher than `maxNativeZoom` will be loaded // from `maxNativeZoom` level and auto-scaled. maxNativeZoom: void 0, // @option minNativeZoom: Number = undefined // Minimum zoom number the tile source has available. If it is specified, // the tiles on all zoom levels lower than `minNativeZoom` will be loaded // from `minNativeZoom` level and auto-scaled. minNativeZoom: void 0, // @option noWrap: Boolean = false // Whether the layer is wrapped around the antimeridian. If `true`, the // GridLayer will only be displayed once at low zoom levels. Has no // effect when the [map CRS](#map-crs) doesn't wrap around. Can be used // in combination with [`bounds`](#gridlayer-bounds) to prevent requesting // tiles outside the CRS limits. noWrap: !1, // @option pane: String = 'tilePane' // `Map pane` where the grid layer will be added. pane: "tilePane", // @option className: String = '' // A custom class name to assign to the tile layer. Empty by default. className: "", // @option keepBuffer: Number = 2 // When panning the map, keep this many rows and columns of tiles before unloading them. keepBuffer: 2 }, initialize: function(p) { be(this, p); }, onAdd: function() { this._initContainer(), this._levels = {}, this._tiles = {}, this._resetView(); }, beforeAdd: function(p) { p._addZoomLimit(this); }, onRemove: function(p) { this._removeAllTiles(), xn(this._container), p._removeZoomLimit(this), this._container = null, this._tileZoom = void 0; }, // @method bringToFront: this // Brings the tile layer to the top of all tile layers. bringToFront: function() { return this._map && (Go(this._container), this._setAutoZIndex(Math.max)), this; }, // @method bringToBack: this // Brings the tile layer to the bottom of all tile layers. bringToBack: function() { return this._map && (aa(this._container), this._setAutoZIndex(Math.min)), this; }, // @method getContainer: HTMLElement // Returns the HTML element that contains the tiles for this layer. getContainer: function() { return this._container; }, // @method setOpacity(opacity: Number): this // Changes the [opacity](#gridlayer-opacity) of the grid layer. setOpacity: function(p) { return this.options.opacity = p, this._updateOpacity(), this; }, // @method setZIndex(zIndex: Number): this // Changes the [zIndex](#gridlayer-zindex) of the grid layer. setZIndex: function(p) { return this.options.zIndex = p, this._updateZIndex(), this; }, // @method isLoading: Boolean // Returns `true` if any tile in the grid layer has not finished loading. isLoading: function() { return this._loading; }, // @method redraw: this // Causes the layer to clear all the tiles and request them again. redraw: function() { if (this._map) { this._removeAllTiles(); var p = this._clampZoom(this._map.getZoom()); p !== this._tileZoom && (this._tileZoom = p, this._updateLevels()), this._update(); } return this; }, getEvents: function() { var p = { viewprereset: this._invalidateAll, viewreset: this._resetView, zoom: this._resetView, moveend: this._onMoveEnd }; return this.options.updateWhenIdle || (this._onMove || (this._onMove = j(this._onMoveEnd, this.options.updateInterval, this)), p.move = this._onMove), this._zoomAnimated && (p.zoomanim = this._animateZoom), p; }, // @section Extension methods // Layers extending `GridLayer` shall reimplement the following method. // @method createTile(coords: Object, done?: Function): HTMLElement // Called only internally, must be overridden by classes extending `GridLayer`. // Returns the `HTMLElement` corresponding to the given `coords`. If the `done` callback // is specified, it must be called when the tile has finished loading and drawing. createTile: function() { return document.createElement("div"); }, // @section // @method getTileSize: Point // Normalizes the [tileSize option](#gridlayer-tilesize) into a point. Used by the `createTile()` method. getTileSize: function() { var p = this.options.tileSize; return p instanceof fi ? p : new fi(p, p); }, _updateZIndex: function() { this._container && this.options.zIndex !== void 0 && this.options.zIndex !== null && (this._container.style.zIndex = this.options.zIndex); }, _setAutoZIndex: function(p) { for (var A = this.getPane().children, B = -p(-1 / 0, 1 / 0), X = 0, ne = A.length, ye; X < ne; X++) ye = A[X].style.zIndex, A[X] !== this._container && ye && (B = p(B, +ye)); isFinite(B) && (this.options.zIndex = B + p(-1, 1), this._updateZIndex()); }, _updateOpacity: function() { if (this._map && !Pe.ielt9) { Qn(this._container, this.options.opacity); var p = +/* @__PURE__ */ new Date(), A = !1, B = !1; for (var X in this._tiles) { var ne = this._tiles[X]; if (!(!ne.current || !ne.loaded)) { var ye = Math.min(1, (p - ne.loaded) / 200); Qn(ne.el, ye), ye < 1 ? A = !0 : (ne.active ? B = !0 : this._onOpaqueTile(ne), ne.active = !0); } } B && !this._noPrune && this._pruneTiles(), A && (Mi(this._fadeFrame), this._fadeFrame = Pt(this._updateOpacity, this)); } }, _onOpaqueTile: J, _initContainer: function() { this._container || (this._container = tn("div", "leaflet-layer " + (this.options.className || "")), this._updateZIndex(), this.options.opacity < 1 && this._updateOpacity(), this.getPane().appendChild(this._container)); }, _updateLevels: function() { var p = this._tileZoom, A = this.options.maxZoom; if (p !== void 0) { for (var B in this._levels) B = Number(B), this._levels[B].el.children.length || B === p ? (this._levels[B].el.style.zIndex = A - Math.abs(p - B), this._onUpdateLevel(B)) : (xn(this._levels[B].el), this._removeTilesAtZoom(B), this._onRemoveLevel(B), delete this._levels[B]); var X = this._levels[p], ne = this._map; return X || (X = this._levels[p] = {}, X.el = tn("div", "leaflet-tile-container leaflet-zoom-animated", this._container), X.el.style.zIndex = A, X.origin = ne.project(ne.unproject(ne.getPixelOrigin()), p).round(), X.zoom = p, this._setZoomTransform(X, ne.getCenter(), ne.getZoom()), J(X.el.offsetWidth), this._onCreateLevel(X)), this._level = X, X; } }, _onUpdateLevel: J, _onRemoveLevel: J, _onCreateLevel: J, _pruneTiles: function() { if (this._map) { var p, A, B = this._map.getZoom(); if (B > this.options.maxZoom || B < this.options.minZoom) { this._removeAllTiles(); return; } for (p in this._tiles) A = this._tiles[p], A.retain = A.current; for (p in this._tiles) if (A = this._tiles[p], A.current && !A.active) { var X = A.coords; this._retainParent(X.x, X.y, X.z, X.z - 5) || this._retainChildren(X.x, X.y, X.z, X.z + 2); } for (p in this._tiles) this._tiles[p].retain || this._removeTile(p); } }, _removeTilesAtZoom: function(p) { for (var A in this._tiles) this._tiles[A].coords.z === p && this._removeTile(A); }, _removeAllTiles: function() { for (var p in this._tiles) this._removeTile(p); }, _invalidateAll: function() { for (var p in this._levels) xn(this._levels[p].el), this._onRemoveLevel(Number(p)), delete this._levels[p]; this._removeAllTiles(), this._tileZoom = void 0; }, _retainParent: function(p, A, B, X) { var ne = Math.floor(p / 2), ye = Math.floor(A / 2), We = B - 1, at = new fi(+ne, +ye); at.z = +We; var ft = this._tileCoordsToKey(at), Rt = this._tiles[ft]; return Rt && Rt.active ? (Rt.retain = !0, !0) : (Rt && Rt.loaded && (Rt.retain = !0), We > X ? this._retainParent(ne, ye, We, X) : !1); }, _retainChildren: function(p, A, B, X) { for (var ne = 2 * p; ne < 2 * p + 2; ne++) for (var ye = 2 * A; ye < 2 * A + 2; ye++) { var We = new fi(ne, ye); We.z = B + 1; var at = this._tileCoordsToKey(We), ft = this._tiles[at]; if (ft && ft.active) { ft.retain = !0; continue; } else ft && ft.loaded && (ft.retain = !0); B + 1 < X && this._retainChildren(ne, ye, B + 1, X); } }, _resetView: function(p) { var A = p && (p.pinch || p.flyTo); this._setView(this._map.getCenter(), this._map.getZoom(), A, A); }, _animateZoom: function(p) { this._setView(p.center, p.zoom, !0, p.noUpdate); }, _clampZoom: function(p) { var A = this.options; return A.minNativeZoom !== void 0 && p < A.minNativeZoom ? A.minNativeZoom : A.maxNativeZoom !== void 0 && A.maxNativeZoom < p ? A.maxNativeZoom : p; }, _setView: function(p, A, B, X) { var ne = Math.round(A); this.options.maxZoom !== void 0 && ne > this.options.maxZoom || this.options.minZoom !== void 0 && ne < this.options.minZoom ? ne = void 0 : ne = this._clampZoom(ne); var ye = this.options.updateWhenZooming && ne !== this._tileZoom; (!X || ye) && (this._tileZoom = ne, this._abortLoading && this._abortLoading(), this._updateLevels(), this._resetGrid(), ne !== void 0 && this._update(p), B || this._pruneTiles(), this._noPrune = !!B), this._setZoomTransforms(p, A); }, _setZoomTransforms: function(p, A) { for (var B in this._levels) this._setZoomTransform(this._levels[B], p, A); }, _setZoomTransform: function(p, A, B) { var X = this._map.getZoomScale(B, p.zoom), ne = p.origin.multiplyBy(X).subtract(this._map._getNewPixelOrigin(A, B)).round(); Pe.any3d ? Ks(p.el, ne, X) : Yn(p.el, ne); }, _resetGrid: function() { var p = this._map, A = p.options.crs, B = this._tileSize = this.getTileSize(), X = this._tileZoom, ne = this._map.getPixelWorldBounds(this._tileZoom); ne && (this._globalTileRange = this._pxBoundsToTileRange(ne)), this._wrapX = A.wrapLng && !this.options.noWrap && [ Math.floor(p.project([0, A.wrapLng[0]], X).x / B.x), Math.ceil(p.project([0, A.wrapLng[1]], X).x / B.y) ], this._wrapY = A.wrapLat && !this.options.noWrap && [ Math.floor(p.project([A.wrapLat[0], 0], X).y / B.x), Math.ceil(p.project([A.wrapLat[1], 0], X).y / B.y) ]; }, _onMoveEnd: function() { !this._map || this._map._animatingZoom || this._update(); }, _getTiledPixelBounds: function(p) { var A = this._map, B = A._animatingZoom ? Math.max(A._animateToZoom, A.getZoom()) : A.getZoom(), X = A.getZoomScale(B, this._tileZoom), ne = A.project(p, this._tileZoom).floor(), ye = A.getSize().divideBy(X * 2); return new Gi(ne.subtract(ye), ne.add(ye)); }, // Private method to load tiles in the grid's active zoom level according to map bounds _update: function(p) { var A = this._map; if (A) { var B = this._clampZoom(A.getZoom()); if (p === void 0 && (p = A.getCenter()), this._tileZoom !== void 0) { var X = this._getTiledPixelBounds(p), ne = this._pxBoundsToTileRange(X), ye = ne.getCenter(), We = [], at = this.options.keepBuffer, ft = new Gi( ne.getBottomLeft().subtract([at, -at]), ne.getTopRight().add([at, -at]) ); if (!(isFinite(ne.min.x) && isFinite(ne.min.y) && isFinite(ne.max.x) && isFinite(ne.max.y))) throw new Error("Attempted to load an infinite number of tiles"); for (var Rt in this._tiles) { var ii = this._tiles[Rt].coords; (ii.z !== this._tileZoom || !ft.contains(new fi(ii.x, ii.y))) && (this._tiles[Rt].current = !1); } if (Math.abs(B - this._tileZoom) > 1) { this._setView(p, B); return; } for (var Ci = ne.min.y; Ci <= ne.max.y; Ci++) for (var Wi = ne.min.x; Wi <= ne.max.x; Wi++) { var Hs = new fi(Wi, Ci); if (Hs.z = this._tileZoom, !!this._isValidTile(Hs)) { var ws = this._tiles[this._tileCoordsToKey(Hs)]; ws ? ws.current = !0 : We.push(Hs); } } if (We.sort(function(ur, Za) { return ur.distanceTo(ye) - Za.distanceTo(ye); }), We.length !== 0) { this._loading || (this._loading = !0, this.fire("loading")); var Rs = document.createDocumentFragment(); for (Wi = 0; Wi < We.length; Wi++) this._addTile(We[Wi], Rs); this._level.el.appendChild(Rs); } } } }, _isValidTile: function(p) { var A = this._map.options.crs; if (!A.infinite) { var B = this._globalTileRange; if (!A.wrapLng && (p.x < B.min.x || p.x > B.max.x) || !A.wrapLat && (p.y < B.min.y || p.y > B.max.y)) return !1; } if (!this.options.bounds) return !0; var X = this._tileCoordsToBounds(p); return ln(this.options.bounds).overlaps(X); }, _keyToBounds: function(p) { return this._tileCoordsToBounds(this._keyToTileCoords(p)); }, _tileCoordsToNwSe: function(p) { var A = this._map, B = this.getTileSize(), X = p.scaleBy(B), ne = X.add(B), ye = A.unproject(X, p.z), We = A.unproject(ne, p.z); return [ye, We]; }, // converts tile coordinates to its geographical bounds _tileCoordsToBounds: function(p) { var A = this._tileCoordsToNwSe(p), B = new qt(A[0], A[1]); return this.options.noWrap || (B = this._map.wrapLatLngBounds(B)), B; }, // converts tile coordinates to key for the tile cache _tileCoordsToKey: function(p) { return p.x + ":" + p.y + ":" + p.z; }, // converts tile cache key to coordinates _keyToTileCoords: function(p) { var A = p.split(":"), B = new fi(+A[0], +A[1]); return B.z = +A[2], B; }, _removeTile: function(p) { var A = this._tiles[p]; A && (xn(A.el), delete this._tiles[p], this.fire("tileunload", { tile: A.el, coords: this._keyToTileCoords(p) })); }, _initTile: function(p) { Vi(p, "leaflet-tile"); var A = this.getTileSize(); p.style.width = A.x + "px", p.style.height = A.y + "px", p.onselectstart = J, p.onmousemove = J, Pe.ielt9 && this.options.opacity < 1 && Qn(p, this.options.opacity); }, _addTile: function(p, A) { var B = this._getTilePos(p), X = this._tileCoordsToKey(p), ne = this.createTile(this._wrapCoords(p), E(this._tileReady, this, p)); this._initTile(ne), this.createTile.length < 2 && Pt(E(this._tileReady, this, p, null, ne)), Yn(ne, B), this._tiles[X] = { el: ne, coords: p, current: !0 }, A.appendChild(ne), this.fire("tileloadstart", { tile: ne, coords: p }); }, _tileReady: function(p, A, B) { A && this.fire("tileerror", { error: A, tile: B, coords: p }); var X = this._tileCoordsToKey(p); B = this._tiles[X], B && (B.loaded = +/* @__PURE__ */ new Date(), this._map._fadeAnimated ? (Qn(B.el, 0), Mi(this._fadeFrame), this._fadeFrame = Pt(this._updateOpacity, this)) : (B.active = !0, this._pruneTiles()), A || (Vi(B.el, "leaflet-tile-loaded"), this.fire("tileload", { tile: B.el, coords: p })), this._noTilesToLoad() && (this._loading = !1, this.fire("load"), Pe.ielt9 || !this._map._fadeAnimated ? Pt(this._pruneTiles, this) : setTimeout(E(this._pruneTiles, this), 250))); }, _getTilePos: function(p) { return p.scaleBy(this.getTileSize()).subtract(this._level.origin); }, _wrapCoords: function(p) { var A = new fi( this._wrapX ? Y(p.x, this._wrapX) : p.x, this._wrapY ? Y(p.y, this._wrapY) : p.y ); return A.z = p.z, A; }, _pxBoundsToTileRange: function(p) { var A = this.getTileSize(); return new Gi( p.min.unscaleBy(A).floor(), p.max.unscaleBy(A).ceil().subtract([1, 1]) ); }, _noTilesToLoad: function() { for (var p in this._tiles) if (!this._tiles[p].loaded) return !1; return !0; } }); function xl(p) { return new ro(p); } var kr = ro.extend({ // @section // @aka TileLayer options options: { // @option minZoom: Number = 0 // The minimum zoom level down to which this layer will be displayed (inclusive). minZoom: 0, // @option maxZoom: Number = 18 // The maximum zoom level up to which this layer will be displayed (inclusive). maxZoom: 18, // @option subdomains: String|String[] = 'abc' // Subdomains of the tile service. Can be passed in the form of one string (where each letter is a subdomain name) or an array of strings. subdomains: "abc", // @option errorTileUrl: String = '' // URL to the tile image to show in place of the tile that failed to load. errorTileUrl: "", // @option zoomOffset: Number = 0 // The zoom number used in tile URLs will be offset with this value. zoomOffset: 0, // @option tms: Boolean = false // If `true`, inverses Y axis numbering for tiles (turn this on for [TMS](https://en.wikipedia.org/wiki/Tile_Map_Service) services). tms: !1, // @option zoomReverse: Boolean = false // If set to true, the zoom number used in tile URLs will be reversed (`maxZoom - zoom` instead of `zoom`) zoomReverse: !1, // @option detectRetina: Boolean = false // If `true` and user is on a retina display, it will request four tiles of half the specified size and a bigger zoom level in place of one to utilize the high resolution. detectRetina: !1, // @option crossOrigin: Boolean|String = false // Whether the crossOrigin attribute will be added to the tiles. // If a String is provided, all tiles will have their crossOrigin attribute set to the String provided. This is needed if you want to access tile pixel data. // Refer to [CORS Settings](https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_settings_attributes) for valid String values. crossOrigin: !1, // @option referrerPolicy: Boolean|String = false // Whether the referrerPolicy attribute will be added to the tiles. // If a String is provided, all tiles will have their referrerPolicy attribute set to the String provided. // This may be needed if your map's rendering context has a strict default but your tile provider expects a valid referrer // (e.g. to validate an API token). // Refer to [HTMLImageElement.referrerPolicy](https://developer.mozilla.org/en-US/docs/Web/API/HTMLImageElement/referrerPolicy) for valid String values. referrerPolicy: !1 }, initialize: function(p, A) { this._url = p, A = be(this, A), A.detectRetina && Pe.retina && A.maxZoom > 0 ? (A.tileSize = Math.floor(A.tileSize / 2), A.zoomReverse ? (A.zoomOffset--, A.minZoom = Math.min(A.maxZoom, A.minZoom + 1)) : (A.zoomOffset++, A.maxZoom = Math.max(A.minZoom, A.maxZoom - 1)), A.minZoom = Math.max(0, A.minZoom)) : A.zoomReverse ? A.minZoom = Math.min(A.maxZoom, A.minZoom) : A.maxZoom = Math.max(A.minZoom, A.maxZoom), typeof A.subdomains == "string" && (A.subdomains = A.subdomains.split("")), this.on("tileunload", this._onTileRemove); }, // @method setUrl(url: String, noRedraw?: Boolean): this // Updates the layer's URL template and redraws it (unless `noRedraw` is set to `true`). // If the URL does not change, the layer will not be redrawn unless // the noRedraw parameter is set to false. setUrl: function(p, A) { return this._url === p && A === void 0 && (A = !0), this._url = p, A || this.redraw(), this; }, // @method createTile(coords: Object, done?: Function): HTMLElement // Called only internally, overrides GridLayer's [`createTile()`](#gridlayer-createtile) // to return an `` HTML element with the appropriate image URL given `coords`. The `done` // callback is called when the tile has been loaded. createTile: function(p, A) { var B = document.createElement("img"); return Bi(B, "load", E(this._tileOnLoad, this, A, B)), Bi(B, "error", E(this._tileOnError, this, A, B)), (this.options.crossOrigin || this.options.crossOrigin === "") && (B.crossOrigin = this.options.crossOrigin === !0 ? "" : this.options.crossOrigin), typeof this.options.referrerPolicy == "string" && (B.referrerPolicy = this.options.referrerPolicy), B.alt = "", B.src = this.getTileUrl(p), B; }, // @section Extension methods // @uninheritable // Layers extending `TileLayer` might reimplement the following method. // @method getTileUrl(coords: Object): String // Called only internally, returns the URL for a tile given its coordinates. // Classes extending `TileLayer` can override this function to provide custom tile URL naming schemes. getTileUrl: function(p) { var A = { r: Pe.retina ? "@2x" : "", s: this._getSubdomain(p), x: p.x, y: p.y, z: this._getZoomForUrl() }; if (this._map && !this._map.options.crs.infinite) { var B = this._globalTileRange.max.y - p.y; this.options.tms && (A.y = B), A["-y"] = B; } return ot(this._url, w(A, this.options)); }, _tileOnLoad: function(p, A) { Pe.ielt9 ? setTimeout(E(p, this, null, A), 0) : p(null, A); }, _tileOnError: function(p, A, B) { var X = this.options.errorTileUrl; X && A.getAttribute("src") !== X && (A.src = X), p(B, A); }, _onTileRemove: function(p) { p.tile.onload = null; }, _getZoomForUrl: function() { var p = this._tileZoom, A = this.options.maxZoom, B = this.options.zoomReverse, X = this.options.zoomOffset; return B && (p = A - p), p + X; }, _getSubdomain: function(p) { var A = Math.abs(p.x + p.y) % this.options.subdomains.length; return this.options.subdomains[A]; }, // stops loading all tiles in the background layer _abortLoading: function() { var p, A; for (p in this._tiles) if (this._tiles[p].coords.z !== this._tileZoom && (A = this._tiles[p].el, A.onload = J, A.onerror = J, !A.complete)) { A.src = gt; var B = this._tiles[p].coords; xn(A), delete this._tiles[p], this.fire("tileabort", { tile: A, coords: B }); } }, _removeTile: function(p) { var A = this._tiles[p]; if (A) return A.el.setAttribute("src", gt), ro.prototype._removeTile.call(this, p); }, _tileReady: function(p, A, B) { if (!(!this._map || B && B.getAttribute("src") === gt)) return ro.prototype._tileReady.call(this, p, A, B); } }); function oo(p, A) { return new kr(p, A); } var Jo = kr.extend({ // @section // @aka TileLayer.WMS options // If any custom options not documented here are used, they will be sent to the // WMS server as extra parameters in each request URL. This can be useful for // [non-standard vendor WMS parameters](https://docs.geoserver.org/stable/en/user/services/wms/vendor.html). defaultWmsParams: { service: "WMS", request: "GetMap", // @option layers: String = '' // **(required)** Comma-separated list of WMS layers to show. layers: "", // @option styles: String = '' // Comma-separated list of WMS styles. styles: "", // @option format: String = 'image/jpeg' // WMS image format (use `'image/png'` for layers with transparency). format: "image/jpeg", // @option transparent: Boolean = false // If `true`, the WMS service will return images with transparency. transparent: !1, // @option version: String = '1.1.1' // Version of the WMS service to use version: "1.1.1" }, options: { // @option crs: CRS = null // Coordinate Reference System to use for the WMS requests, defaults to // map CRS. Don't change this if you're not sure what it means. crs: null, // @option uppercase: Boolean = false // If `true`, WMS request parameter keys will be uppercase. uppercase: !1 }, initialize: function(p, A) { this._url = p; var B = w({}, this.defaultWmsParams); for (var X in A) X in this.options || (B[X] = A[X]); A = be(this, A); var ne = A.detectRetina && Pe.retina ? 2 : 1, ye = this.getTileSize(); B.width = ye.x * ne, B.height = ye.y * ne, this.wmsParams = B; }, onAdd: function(p) { this._crs = this.options.crs || p.options.crs, this._wmsVersion = parseFloat(this.wmsParams.version); var A = this._wmsVersion >= 1.3 ? "crs" : "srs"; this.wmsParams[A] = this._crs.code, kr.prototype.onAdd.call(this, p); }, getTileUrl: function(p) { var A = this._tileCoordsToNwSe(p), B = this._crs, X = an(B.project(A[0]), B.project(A[1])), ne = X.min, ye = X.max, We = (this._wmsVersion >= 1.3 && this._crs === gl ? [ne.y, ne.x, ye.y, ye.x] : [ne.x, ne.y, ye.x, ye.y]).join(","), at = kr.prototype.getTileUrl.call(this, p); return at + Ze(this.wmsParams, at, this.options.uppercase) + (this.options.uppercase ? "&BBOX=" : "&bbox=") + We; }, // @method setParams(params: Object, noRedraw?: Boolean): this // Merges an object with the new parameters and re-requests tiles on the current screen (unless `noRedraw` was set to true). setParams: function(p, A) { return w(this.wmsParams, p), A || this.redraw(), this; } }); function Jl(p, A) { return new Jo(p, A); } kr.WMS = Jo, oo.wms = Jl; var Qr = ar.extend({ // @section // @aka Renderer options options: { // @option padding: Number = 0.1 // How much to extend the clip area around the map view (relative to its size) // e.g. 0.1 would be 10% of map view in each direction padding: 0.1 }, initialize: function(p) { be(this, p), O(this), this._layers = this._layers || {}; }, onAdd: function() { this._container || (this._initContainer(), Vi(this._container, "leaflet-zoom-animated")), this.getPane().appendChild(this._container), this._update(), this.on("update", this._updatePaths, this); }, onRemove: function() { this.off("update", this._updatePaths, this), this._destroyContainer(); }, getEvents: function() { var p = { viewreset: this._reset, zoom: this._onZoom, moveend: this._update, zoomend: this._onZoomEnd }; return this._zoomAnimated && (p.zoomanim = this._onAnimZoom), p; }, _onAnimZoom: function(p) { this._updateTransform(p.center, p.zoom); }, _onZoom: function() { this._updateTransform(this._map.getCenter(), this._map.getZoom()); }, _updateTransform: function(p, A) { var B = this._map.getZoomScale(A, this._zoom), X = this._map.getSize().multiplyBy(0.5 + this.options.padding), ne = this._map.project(this._center, A), ye = X.multiplyBy(-B).add(ne).subtract(this._map._getNewPixelOrigin(p, A)); Pe.any3d ? Ks(this._container, ye, B) : Yn(this._container, ye); }, _reset: function() { this._update(), this._updateTransform(this._center, this._zoom); for (var p in this._layers) this._layers[p]._reset(); }, _onZoomEnd: function() { for (var p in this._layers) this._layers[p]._project(); }, _updatePaths: function() { for (var p in this._layers) this._layers[p]._update(); }, _update: function() { var p = this.options.padding, A = this._map.getSize(), B = this._map.containerPointToLayerPoint(A.multiplyBy(-p)).round(); this._bounds = new Gi(B, B.add(A.multiplyBy(1 + p * 2)).round()), this._center = this._map.getCenter(), this._zoom = this._map.getZoom(); } }), vl = Qr.extend({ // @section // @aka Canvas options options: { // @option tolerance: Number = 0 // How much to extend the click tolerance around a path/object on the map. tolerance: 0 }, getEvents: function() { var p = Qr.prototype.getEvents.call(this); return p.viewprereset = this._onViewPreReset, p; }, _onViewPreReset: function() { this._postponeUpdatePaths = !0; }, onAdd: function() { Qr.prototype.onAdd.call(this), this._draw(); }, _initContainer: function() { var p = this._container = document.createElement("canvas"); Bi(p, "mousemove", this._onMouseMove, this), Bi(p, "click dblclick mousedown mouseup contextmenu", this._onClick, this), Bi(p, "mouseout", this._handleMouseOut, this), p._leaflet_disable_events = !0, this._ctx = p.getContext("2d"); }, _destroyContainer: function() { Mi(this._redrawRequest), delete this._ctx, xn(this._container), Cn(this._container), delete this._container; }, _updatePaths: function() { if (!this._postponeUpdatePaths) { var p; this._redrawBounds = null; for (var A in this._layers) p = this._layers[A], p._update(); this._redraw(); } }, _update: function() { if (!(this._map._animatingZoom && this._bounds)) { Qr.prototype._update.call(this); var p = this._bounds, A = this._container, B = p.getSize(), X = Pe.retina ? 2 : 1; Yn(A, p.min), A.width = X * B.x, A.height = X * B.y, A.style.width = B.x + "px", A.style.height = B.y + "px", Pe.retina && this._ctx.scale(2, 2), this._ctx.translate(-p.min.x, -p.min.y), this.fire("update"); } }, _reset: function() { Qr.prototype._reset.call(this), this._postponeUpdatePaths && (this._postponeUpdatePaths = !1, this._updatePaths()); }, _initPath: function(p) { this._updateDashArray(p), this._layers[O(p)] = p; var A = p._order = { layer: p, prev: this._drawLast, next: null }; this._drawLast && (this._drawLast.next = A), this._drawLast = A, this._drawFirst = this._drawFirst || this._drawLast; }, _addPath: function(p) { this._requestRedraw(p); }, _removePath: function(p) { var A = p._order, B = A.next, X = A.prev; B ? B.prev = X : this._drawLast = X, X ? X.next = B : this._drawFirst = B, delete p._order, delete this._layers[O(p)], this._requestRedraw(p); }, _updatePath: function(p) { this._extendRedrawBounds(p), p._project(), p._update(), this._requestRedraw(p); }, _updateStyle: function(p) { this._updateDashArray(p), this._requestRedraw(p); }, _updateDashArray: function(p) { if (typeof p.options.dashArray == "string") { var A = p.options.dashArray.split(/[, ]+/), B = [], X, ne; for (ne = 0; ne < A.length; ne++) { if (X = Number(A[ne]), isNaN(X)) return; B.push(X); } p.options._dashArray = B; } else p.options._dashArray = p.options.dashArray; }, _requestRedraw: function(p) { this._map && (this._extendRedrawBounds(p), this._redrawRequest = this._redrawRequest || Pt(this._redraw, this)); }, _extendRedrawBounds: function(p) { if (p._pxBounds) { var A = (p.options.weight || 0) + 1; this._redrawBounds = this._redrawBounds || new Gi(), this._redrawBounds.extend(p._pxBounds.min.subtract([A, A])), this._redrawBounds.extend(p._pxBounds.max.add([A, A])); } }, _redraw: function() { this._redrawRequest = null, this._redrawBounds && (this._redrawBounds.min._floor(), this._redrawBounds.max._ceil()), this._clear(), this._draw(), this._redrawBounds = null; }, _clear: function() { var p = this._redrawBounds; if (p) { var A = p.getSize(); this._ctx.clearRect(p.min.x, p.min.y, A.x, A.y); } else this._ctx.save(), this._ctx.setTransform(1, 0, 0, 1, 0, 0), this._ctx.clearRect(0, 0, this._container.width, this._container.height), this._ctx.restore(); }, _draw: function() { var p, A = this._redrawBounds; if (this._ctx.save(), A) { var B = A.getSize(); this._ctx.beginPath(), this._ctx.rect(A.min.x, A.min.y, B.x, B.y), this._ctx.clip(); } this._drawing = !0; for (var X = this._drawFirst; X; X = X.next) p = X.layer, (!A || p._pxBounds && p._pxBounds.intersects(A)) && p._updatePath(); this._drawing = !1, this._ctx.restore(); }, _updatePoly: function(p, A) { if (this._drawing) { var B, X, ne, ye, We = p._parts, at = We.length, ft = this._ctx; if (at) { for (ft.beginPath(), B = 0; B < at; B++) { for (X = 0, ne = We[B].length; X < ne; X++) ye = We[B][X], ft[X ? "lineTo" : "moveTo"](ye.x, ye.y); A && ft.closePath(); } this._fillStroke(ft, p); } } }, _updateCircle: function(p) { if (!(!this._drawing || p._empty())) { var A = p._point, B = this._ctx, X = Math.max(Math.round(p._radius), 1), ne = (Math.max(Math.round(p._radiusY), 1) || X) / X; ne !== 1 && (B.save(), B.scale(1, ne)), B.beginPath(), B.arc(A.x, A.y / ne, X, 0, Math.PI * 2, !1), ne !== 1 && B.restore(), this._fillStroke(B, p); } }, _fillStroke: function(p, A) { var B = A.options; B.fill && (p.globalAlpha = B.fillOpacity, p.fillStyle = B.fillColor || B.color, p.fill(B.fillRule || "evenodd")), B.stroke && B.weight !== 0 && (p.setLineDash && p.setLineDash(A.options && A.options._dashArray || []), p.globalAlpha = B.opacity, p.lineWidth = B.weight, p.strokeStyle = B.color, p.lineCap = B.lineCap, p.lineJoin = B.lineJoin, p.stroke()); }, // Canvas obviously doesn't have mouse events for individual drawn objects, // so we emulate that by calculating what's under the mouse on mousemove/click manually _onClick: function(p) { for (var A = this._map.mouseEventToLayerPoint(p), B, X, ne = this._drawFirst; ne; ne = ne.next) B = ne.layer, B.options.interactive && B._containsPoint(A) && (!(p.type === "click" || p.type === "preclick") || !this._map._draggableMoved(B)) && (X = B); this._fireEvent(X ? [X] : !1, p); }, _onMouseMove: function(p) { if (!(!this._map || this._map.dragging.moving() || this._map._animatingZoom)) { var A = this._map.mouseEventToLayerPoint(p); this._handleMouseHover(p, A); } }, _handleMouseOut: function(p) { var A = this._hoveredLayer; A && (Hn(this._container, "leaflet-interactive"), this._fireEvent([A], p, "mouseout"), this._hoveredLayer = null, this._mouseHoverThrottled = !1); }, _handleMouseHover: function(p, A) { if (!this._mouseHoverThrottled) { for (var B, X, ne = this._drawFirst; ne; ne = ne.next) B = ne.layer, B.options.interactive && B._containsPoint(A) && (X = B); X !== this._hoveredLayer && (this._handleMouseOut(p), X && (Vi(this._container, "leaflet-interactive"), this._fireEvent([X], p, "mouseover"), this._hoveredLayer = X)), this._fireEvent(this._hoveredLayer ? [this._hoveredLayer] : !1, p), this._mouseHoverThrottled = !0, setTimeout(E(function() { this._mouseHoverThrottled = !1; }, this), 32); } }, _fireEvent: function(p, A, B) { this._map._fireDOMEvent(A, B || A.type, p); }, _bringToFront: function(p) { var A = p._order; if (A) { var B = A.next, X = A.prev; if (B) B.prev = X; else return; X ? X.next = B : B && (this._drawFirst = B), A.prev = this._drawLast, this._drawLast.next = A, A.next = null, this._drawLast = A, this._requestRedraw(p); } }, _bringToBack: function(p) { var A = p._order; if (A) { var B = A.next, X = A.prev; if (X) X.next = B; else return; B ? B.prev = X : X && (this._drawLast = X), A.prev = null, A.next = this._drawFirst, this._drawFirst.prev = A, this._drawFirst = A, this._requestRedraw(p); } } }); function ao(p) { return Pe.canvas ? new vl(p) : null; } var Ti = function() { try { return document.namespaces.add("lvml", "urn:schemas-microsoft-com:vml"), function(p) { return document.createElement("'); }; } catch { } return function(p) { return document.createElement("<" + p + ' xmlns="urn:schemas-microsoft.com:vml" class="lvml">'); }; }(), qh = { _initContainer: function() { this._container = tn("div", "leaflet-vml-container"); }, _update: function() { this._map._animatingZoom || (Qr.prototype._update.call(this), this.fire("update")); }, _initPath: function(p) { var A = p._container = Ti("shape"); Vi(A, "leaflet-vml-shape " + (this.options.className || "")), A.coordsize = "1 1", p._path = Ti("path"), A.appendChild(p._path), this._updateStyle(p), this._layers[O(p)] = p; }, _addPath: function(p) { var A = p._container; this._container.appendChild(A), p.options.interactive && p.addInteractiveTarget(A); }, _removePath: function(p) { var A = p._container; xn(A), p.removeInteractiveTarget(A), delete this._layers[O(p)]; }, _updateStyle: function(p) { var A = p._stroke, B = p._fill, X = p.options, ne = p._container; ne.stroked = !!X.stroke, ne.filled = !!X.fill, X.stroke ? (A || (A = p._stroke = Ti("stroke")), ne.appendChild(A), A.weight = X.weight + "px", A.color = X.color, A.opacity = X.opacity, X.dashArray ? A.dashStyle = vt(X.dashArray) ? X.dashArray.join(" ") : X.dashArray.replace(/( *, *)/g, " ") : A.dashStyle = "", A.endcap = X.lineCap.replace("butt", "flat"), A.joinstyle = X.lineJoin) : A && (ne.removeChild(A), p._stroke = null), X.fill ? (B || (B = p._fill = Ti("fill")), ne.appendChild(B), B.color = X.fillColor || X.color, B.opacity = X.fillOpacity) : B && (ne.removeChild(B), p._fill = null); }, _updateCircle: function(p) { var A = p._point.round(), B = Math.round(p._radius), X = Math.round(p._radiusY || B); this._setPath(p, p._empty() ? "M0 0" : "AL " + A.x + "," + A.y + " " + B + "," + X + " 0," + 65535 * 360); }, _setPath: function(p, A) { p._path.v = A; }, _bringToFront: function(p) { Go(p._container); }, _bringToBack: function(p) { aa(p._container); } }, bl = Pe.vml ? Ti : Ws, Ga = Qr.extend({ _initContainer: function() { this._container = bl("svg"), this._container.setAttribute("pointer-events", "none"), this._rootGroup = bl("g"), this._container.appendChild(this._rootGroup); }, _destroyContainer: function() { xn(this._container), Cn(this._container), delete this._container, delete this._rootGroup, delete this._svgSize; }, _update: function() { if (!(this._map._animatingZoom && this._bounds)) { Qr.prototype._update.call(this); var p = this._bounds, A = p.getSize(), B = this._container; (!this._svgSize || !this._svgSize.equals(A)) && (this._svgSize = A, B.setAttribute("width", A.x), B.setAttribute("height", A.y)), Yn(B, p.min), B.setAttribute("viewBox", [p.min.x, p.min.y, A.x, A.y].join(" ")), this.fire("update"); } }, // methods below are called by vector layers implementations _initPath: function(p) { var A = p._path = bl("path"); p.options.className && Vi(A, p.options.className), p.options.interactive && Vi(A, "leaflet-interactive"), this._updateStyle(p), this._layers[O(p)] = p; }, _addPath: function(p) { this._rootGroup || this._initContainer(), this._rootGroup.appendChild(p._path), p.addInteractiveTarget(p._path); }, _removePath: function(p) { xn(p._path), p.removeInteractiveTarget(p._path), delete this._layers[O(p)]; }, _updatePath: function(p) { p._project(), p._update(); }, _updateStyle: function(p) { var A = p._path, B = p.options; A && (B.stroke ? (A.setAttribute("stroke", B.color), A.setAttribute("stroke-opacity", B.opacity), A.setAttribute("stroke-width", B.weight), A.setAttribute("stroke-linecap", B.lineCap), A.setAttribute("stroke-linejoin", B.lineJoin), B.dashArray ? A.setAttribute("stroke-dasharray", B.dashArray) : A.removeAttribute("stroke-dasharray"), B.dashOffset ? A.setAttribute("stroke-dashoffset", B.dashOffset) : A.removeAttribute("stroke-dashoffset")) : A.setAttribute("stroke", "none"), B.fill ? (A.setAttribute("fill", B.fillColor || B.color), A.setAttribute("fill-opacity", B.fillOpacity), A.setAttribute("fill-rule", B.fillRule || "evenodd")) : A.setAttribute("fill", "none")); }, _updatePoly: function(p, A) { this._setPath(p, $n(p._parts, A)); }, _updateCircle: function(p) { var A = p._point, B = Math.max(Math.round(p._radius), 1), X = Math.max(Math.round(p._radiusY), 1) || B, ne = "a" + B + "," + X + " 0 1,0 ", ye = p._empty() ? "M0 0" : "M" + (A.x - B) + "," + A.y + ne + B * 2 + ",0 " + ne + -B * 2 + ",0 "; this._setPath(p, ye); }, _setPath: function(p, A) { p._path.setAttribute("d", A); }, // SVG does not have the concept of zIndex so we resort to changing the DOM order of elements _bringToFront: function(p) { Go(p._path); }, _bringToBack: function(p) { aa(p._path); } }); Pe.vml && Ga.include(qh); function Qo(p) { return Pe.svg || Pe.vml ? new Ga(p) : null; } nn.include({ // @namespace Map; @method getRenderer(layer: Path): Renderer // Returns the instance of `Renderer` that should be used to render the given // `Path`. It will ensure that the `renderer` options of the map and paths // are respected, and that the renderers do exist on the map. getRenderer: function(p) { var A = p.options.renderer || this._getPaneRenderer(p.options.pane) || this.options.renderer || this._renderer; return A || (A = this._renderer = this._createRenderer()), this.hasLayer(A) || this.addLayer(A), A; }, _getPaneRenderer: function(p) { if (p === "overlayPane" || p === void 0) return !1; var A = this._paneRenderers[p]; return A === void 0 && (A = this._createRenderer({ pane: p }), this._paneRenderers[p] = A), A; }, _createRenderer: function(p) { return this.options.preferCanvas && ao(p) || Qo(p); } }); var qc = Kr.extend({ initialize: function(p, A) { Kr.prototype.initialize.call(this, this._boundsToLatLngs(p), A); }, // @method setBounds(latLngBounds: LatLngBounds): this // Redraws the rectangle with the passed bounds. setBounds: function(p) { return this.setLatLngs(this._boundsToLatLngs(p)); }, _boundsToLatLngs: function(p) { return p = ln(p), [ p.getSouthWest(), p.getNorthWest(), p.getNorthEast(), p.getSouthEast() ]; } }); function gn(p, A) { return new qc(p, A); } Ga.create = bl, Ga.pointsToPath = $n, cr.geometryToLayer = Eo, cr.coordsToLatLng = Uc, cr.coordsToLatLngs = Ua, cr.latLngToCoords = $l, cr.latLngsToCoords = yl, cr.getFeature = _a, cr.asFeature = ga, nn.mergeOptions({ // @option boxZoom: Boolean = true // Whether the map can be zoomed to a rectangular area specified by // dragging the mouse while pressing the shift key. boxZoom: !0 }); var Wh = Es.extend({ initialize: function(p) { this._map = p, this._container = p._container, this._pane = p._panes.overlayPane, this._resetStateTimeout = 0, p.on("unload", this._destroy, this); }, addHooks: function() { Bi(this._container, "mousedown", this._onMouseDown, this); }, removeHooks: function() { Cn(this._container, "mousedown", this._onMouseDown, this); }, moved: function() { return this._moved; }, _destroy: function() { xn(this._pane), delete this._pane; }, _resetState: function() { this._resetStateTimeout = 0, this._moved = !1; }, _clearDeferredResetState: function() { this._resetStateTimeout !== 0 && (clearTimeout(this._resetStateTimeout), this._resetStateTimeout = 0); }, _onMouseDown: function(p) { if (!p.shiftKey || p.which !== 1 && p.button !== 1) return !1; this._clearDeferredResetState(), this._resetState(), Ar(), Zo(), this._startPoint = this._map.mouseEventToContainerPoint(p), Bi(document, { contextmenu: Js, mousemove: this._onMouseMove, mouseup: this._onMouseUp, keydown: this._onKeyDown }, this); }, _onMouseMove: function(p) { this._moved || (this._moved = !0, this._box = tn("div", "leaflet-zoom-box", this._container), Vi(this._container, "leaflet-crosshair"), this._map.fire("boxzoomstart")), this._point = this._map.mouseEventToContainerPoint(p); var A = new Gi(this._point, this._startPoint), B = A.getSize(); Yn(this._box, A.min), this._box.style.width = B.x + "px", this._box.style.height = B.y + "px"; }, _finish: function() { this._moved && (xn(this._box), Hn(this._container, "leaflet-crosshair")), Cr(), sr(), Cn(document, { contextmenu: Js, mousemove: this._onMouseMove, mouseup: this._onMouseUp, keydown: this._onKeyDown }, this); }, _onMouseUp: function(p) { if (!(p.which !== 1 && p.button !== 1) && (this._finish(), !!this._moved)) { this._clearDeferredResetState(), this._resetStateTimeout = setTimeout(E(this._resetState, this), 0); var A = new qt( this._map.containerPointToLatLng(this._startPoint), this._map.containerPointToLatLng(this._point) ); this._map.fitBounds(A).fire("boxzoomend", { boxZoomBounds: A }); } }, _onKeyDown: function(p) { p.keyCode === 27 && (this._finish(), this._clearDeferredResetState(), this._resetState()); } }); nn.addInitHook("addHandler", "boxZoom", Wh), nn.mergeOptions({ // @option doubleClickZoom: Boolean|String = true // Whether the map can be zoomed in by double clicking on it and // zoomed out by double clicking while holding shift. If passed // `'center'`, double-click zoom will zoom to the center of the // view regardless of where the mouse was. doubleClickZoom: !0 }); var $h = Es.extend({ addHooks: function() { this._map.on("dblclick", this._onDoubleClick, this); }, removeHooks: function() { this._map.off("dblclick", this._onDoubleClick, this); }, _onDoubleClick: function(p) { var A = this._map, B = A.getZoom(), X = A.options.zoomDelta, ne = p.originalEvent.shiftKey ? B - X : B + X; A.options.doubleClickZoom === "center" ? A.setZoom(ne) : A.setZoomAround(p.containerPoint, ne); } }); nn.addInitHook("addHandler", "doubleClickZoom", $h), nn.mergeOptions({ // @option dragging: Boolean = true // Whether the map is draggable with mouse/touch or not. dragging: !0, // @section Panning Inertia Options // @option inertia: Boolean = * // If enabled, panning of the map will have an inertia effect where // the map builds momentum while dragging and continues moving in // the same direction for some time. Feels especially nice on touch // devices. Enabled by default. inertia: !0, // @option inertiaDeceleration: Number = 3000 // The rate with which the inertial movement slows down, in pixels/second². inertiaDeceleration: 3400, // px/s^2 // @option inertiaMaxSpeed: Number = Infinity // Max speed of the inertial movement, in pixels/second. inertiaMaxSpeed: 1 / 0, // px/s // @option easeLinearity: Number = 0.2 easeLinearity: 0.2, // TODO refactor, move to CRS // @option worldCopyJump: Boolean = false // With this option enabled, the map tracks when you pan to another "copy" // of the world and seamlessly jumps to the original one so that all overlays // like markers and vector layers are still visible. worldCopyJump: !1, // @option maxBoundsViscosity: Number = 0.0 // If `maxBounds` is set, this option will control how solid the bounds // are when dragging the map around. The default value of `0.0` allows the // user to drag outside the bounds at normal speed, higher values will // slow down map dragging outside bounds, and `1.0` makes the bounds fully // solid, preventing the user from dragging outside the bounds. maxBoundsViscosity: 0 }); var Ql = Es.extend({ addHooks: function() { if (!this._draggable) { var p = this._map; this._draggable = new Wo(p._mapPane, p._container), this._draggable.on({ dragstart: this._onDragStart, drag: this._onDrag, dragend: this._onDragEnd }, this), this._draggable.on("predrag", this._onPreDragLimit, this), p.options.worldCopyJump && (this._draggable.on("predrag", this._onPreDragWrap, this), p.on("zoomend", this._onZoomEnd, this), p.whenReady(this._onZoomEnd, this)); } Vi(this._map._container, "leaflet-grab leaflet-touch-drag"), this._draggable.enable(), this._positions = [], this._times = []; }, removeHooks: function() { Hn(this._map._container, "leaflet-grab"), Hn(this._map._container, "leaflet-touch-drag"), this._draggable.disable(); }, moved: function() { return this._draggable && this._draggable._moved; }, moving: function() { return this._draggable && this._draggable._moving; }, _onDragStart: function() { var p = this._map; if (p._stop(), this._map.options.maxBounds && this._map.options.maxBoundsViscosity) { var A = ln(this._map.options.maxBounds); this._offsetLimit = an( this._map.latLngToContainerPoint(A.getNorthWest()).multiplyBy(-1), this._map.latLngToContainerPoint(A.getSouthEast()).multiplyBy(-1).add(this._map.getSize()) ), this._viscosity = Math.min(1, Math.max(0, this._map.options.maxBoundsViscosity)); } else this._offsetLimit = null; p.fire("movestart").fire("dragstart"), p.options.inertia && (this._positions = [], this._times = []); }, _onDrag: function(p) { if (this._map.options.inertia) { var A = this._lastTime = +/* @__PURE__ */ new Date(), B = this._lastPos = this._draggable._absPos || this._draggable._newPos; this._positions.push(B), this._times.push(A), this._prunePositions(A); } this._map.fire("move", p).fire("drag", p); }, _prunePositions: function(p) { for (; this._positions.length > 1 && p - this._times[0] > 50; ) this._positions.shift(), this._times.shift(); }, _onZoomEnd: function() { var p = this._map.getSize().divideBy(2), A = this._map.latLngToLayerPoint([0, 0]); this._initialWorldOffset = A.subtract(p).x, this._worldWidth = this._map.getPixelWorldBounds().getSize().x; }, _viscousLimit: function(p, A) { return p - (p - A) * this._viscosity; }, _onPreDragLimit: function() { if (!(!this._viscosity || !this._offsetLimit)) { var p = this._draggable._newPos.subtract(this._draggable._startPos), A = this._offsetLimit; p.x < A.min.x && (p.x = this._viscousLimit(p.x, A.min.x)), p.y < A.min.y && (p.y = this._viscousLimit(p.y, A.min.y)), p.x > A.max.x && (p.x = this._viscousLimit(p.x, A.max.x)), p.y > A.max.y && (p.y = this._viscousLimit(p.y, A.max.y)), this._draggable._newPos = this._draggable._startPos.add(p); } }, _onPreDragWrap: function() { var p = this._worldWidth, A = Math.round(p / 2), B = this._initialWorldOffset, X = this._draggable._newPos.x, ne = (X - A + B) % p + A - B, ye = (X + A + B) % p - A - B, We = Math.abs(ne + B) < Math.abs(ye + B) ? ne : ye; this._draggable._absPos = this._draggable._newPos.clone(), this._draggable._newPos.x = We; }, _onDragEnd: function(p) { var A = this._map, B = A.options, X = !B.inertia || p.noInertia || this._times.length < 2; if (A.fire("dragend", p), X) A.fire("moveend"); else { this._prunePositions(+/* @__PURE__ */ new Date()); var ne = this._lastPos.subtract(this._positions[0]), ye = (this._lastTime - this._times[0]) / 1e3, We = B.easeLinearity, at = ne.multiplyBy(We / ye), ft = at.distanceTo([0, 0]), Rt = Math.min(B.inertiaMaxSpeed, ft), ii = at.multiplyBy(Rt / ft), Ci = Rt / (B.inertiaDeceleration * We), Wi = ii.multiplyBy(-Ci / 2).round(); !Wi.x && !Wi.y ? A.fire("moveend") : (Wi = A._limitOffset(Wi, A.options.maxBounds), Pt(function() { A.panBy(Wi, { duration: Ci, easeLinearity: We, noMoveStart: !0, animate: !0 }); })); } } }); nn.addInitHook("addHandler", "dragging", Ql), nn.mergeOptions({ // @option keyboard: Boolean = true // Makes the map focusable and allows users to navigate the map with keyboard // arrows and `+`/`-` keys. keyboard: !0, // @option keyboardPanDelta: Number = 80 // Amount of pixels to pan when pressing an arrow key. keyboardPanDelta: 80 }); var ec = Es.extend({ keyCodes: { left: [37], right: [39], down: [40], up: [38], zoomIn: [187, 107, 61, 171], zoomOut: [189, 109, 54, 173] }, initialize: function(p) { this._map = p, this._setPanDelta(p.options.keyboardPanDelta), this._setZoomDelta(p.options.zoomDelta); }, addHooks: function() { var p = this._map._container; p.tabIndex <= 0 && (p.tabIndex = "0"), Bi(p, { focus: this._onFocus, blur: this._onBlur, mousedown: this._onMouseDown }, this), this._map.on({ focus: this._addHooks, blur: this._removeHooks }, this); }, removeHooks: function() { this._removeHooks(), Cn(this._map._container, { focus: this._onFocus, blur: this._onBlur, mousedown: this._onMouseDown }, this), this._map.off({ focus: this._addHooks, blur: this._removeHooks }, this); }, _onMouseDown: function() { if (!this._focused) { var p = document.body, A = document.documentElement, B = p.scrollTop || A.scrollTop, X = p.scrollLeft || A.scrollLeft; this._map._container.focus(), window.scrollTo(X, B); } }, _onFocus: function() { this._focused = !0, this._map.fire("focus"); }, _onBlur: function() { this._focused = !1, this._map.fire("blur"); }, _setPanDelta: function(p) { var A = this._panKeys = {}, B = this.keyCodes, X, ne; for (X = 0, ne = B.left.length; X < ne; X++) A[B.left[X]] = [-1 * p, 0]; for (X = 0, ne = B.right.length; X < ne; X++) A[B.right[X]] = [p, 0]; for (X = 0, ne = B.down.length; X < ne; X++) A[B.down[X]] = [0, p]; for (X = 0, ne = B.up.length; X < ne; X++) A[B.up[X]] = [0, -1 * p]; }, _setZoomDelta: function(p) { var A = this._zoomKeys = {}, B = this.keyCodes, X, ne; for (X = 0, ne = B.zoomIn.length; X < ne; X++) A[B.zoomIn[X]] = p; for (X = 0, ne = B.zoomOut.length; X < ne; X++) A[B.zoomOut[X]] = -p; }, _addHooks: function() { Bi(document, "keydown", this._onKeyDown, this); }, _removeHooks: function() { Cn(document, "keydown", this._onKeyDown, this); }, _onKeyDown: function(p) { if (!(p.altKey || p.ctrlKey || p.metaKey)) { var A = p.keyCode, B = this._map, X; if (A in this._panKeys) { if (!B._panAnim || !B._panAnim._inProgress) if (X = this._panKeys[A], p.shiftKey && (X = ni(X).multiplyBy(3)), B.options.maxBounds && (X = B._limitOffset(ni(X), B.options.maxBounds)), B.options.worldCopyJump) { var ne = B.wrapLatLng(B.unproject(B.project(B.getCenter()).add(X))); B.panTo(ne); } else B.panBy(X); } else if (A in this._zoomKeys) B.setZoom(B.getZoom() + (p.shiftKey ? 3 : 1) * this._zoomKeys[A]); else if (A === 27 && B._popup && B._popup.options.closeOnEscapeKey) B.closePopup(); else return; Js(p); } } }); nn.addInitHook("addHandler", "keyboard", ec), nn.mergeOptions({ // @section Mouse wheel options // @option scrollWheelZoom: Boolean|String = true // Whether the map can be zoomed by using the mouse wheel. If passed `'center'`, // it will zoom to the center of the view regardless of where the mouse was. scrollWheelZoom: !0, // @option wheelDebounceTime: Number = 40 // Limits the rate at which a wheel can fire (in milliseconds). By default // user can't zoom via wheel more often than once per 40 ms. wheelDebounceTime: 40, // @option wheelPxPerZoomLevel: Number = 60 // How many scroll pixels (as reported by [L.DomEvent.getWheelDelta](#domevent-getwheeldelta)) // mean a change of one full zoom level. Smaller values will make wheel-zooming // faster (and vice versa). wheelPxPerZoomLevel: 60 }); var tc = Es.extend({ addHooks: function() { Bi(this._map._container, "wheel", this._onWheelScroll, this), this._delta = 0; }, removeHooks: function() { Cn(this._map._container, "wheel", this._onWheelScroll, this); }, _onWheelScroll: function(p) { var A = Bc(p), B = this._map.options.wheelDebounceTime; this._delta += A, this._lastMousePos = this._map.mouseEventToContainerPoint(p), this._startTime || (this._startTime = +/* @__PURE__ */ new Date()); var X = Math.max(B - (+/* @__PURE__ */ new Date() - this._startTime), 0); clearTimeout(this._timer), this._timer = setTimeout(E(this._performZoom, this), X), Js(p); }, _performZoom: function() { var p = this._map, A = p.getZoom(), B = this._map.options.zoomSnap || 0; p._stop(); var X = this._delta / (this._map.options.wheelPxPerZoomLevel * 4), ne = 4 * Math.log(2 / (1 + Math.exp(-Math.abs(X)))) / Math.LN2, ye = B ? Math.ceil(ne / B) * B : ne, We = p._limitZoom(A + (this._delta > 0 ? ye : -ye)) - A; this._delta = 0, this._startTime = null, We && (p.options.scrollWheelZoom === "center" ? p.setZoom(A + We) : p.setZoomAround(this._lastMousePos, A + We)); } }); nn.addInitHook("addHandler", "scrollWheelZoom", tc); var Wc = 600; nn.mergeOptions({ // @section Touch interaction options // @option tapHold: Boolean // Enables simulation of `contextmenu` event, default is `true` for mobile Safari. tapHold: Pe.touchNative && Pe.safari && Pe.mobile, // @option tapTolerance: Number = 15 // The max number of pixels a user can shift his finger during touch // for it to be considered a valid tap. tapTolerance: 15 }); var $c = Es.extend({ addHooks: function() { Bi(this._map._container, "touchstart", this._onDown, this); }, removeHooks: function() { Cn(this._map._container, "touchstart", this._onDown, this); }, _onDown: function(p) { if (clearTimeout(this._holdTimeout), p.touches.length === 1) { var A = p.touches[0]; this._startPos = this._newPos = new fi(A.clientX, A.clientY), this._holdTimeout = setTimeout(E(function() { this._cancel(), this._isTapValid() && (Bi(document, "touchend", _s), Bi(document, "touchend touchcancel", this._cancelClickPrevent), this._simulateEvent("contextmenu", A)); }, this), Wc), Bi(document, "touchend touchcancel contextmenu", this._cancel, this), Bi(document, "touchmove", this._onMove, this); } }, _cancelClickPrevent: function p() { Cn(document, "touchend", _s), Cn(document, "touchend touchcancel", p); }, _cancel: function() { clearTimeout(this._holdTimeout), Cn(document, "touchend touchcancel contextmenu", this._cancel, this), Cn(document, "touchmove", this._onMove, this); }, _onMove: function(p) { var A = p.touches[0]; this._newPos = new fi(A.clientX, A.clientY); }, _isTapValid: function() { return this._newPos.distanceTo(this._startPos) <= this._map.options.tapTolerance; }, _simulateEvent: function(p, A) { var B = new MouseEvent(p, { bubbles: !0, cancelable: !0, view: window, // detail: 1, screenX: A.screenX, screenY: A.screenY, clientX: A.clientX, clientY: A.clientY // button: 2, // buttons: 2 }); B._simulated = !0, A.target.dispatchEvent(B); } }); nn.addInitHook("addHandler", "tapHold", $c), nn.mergeOptions({ // @section Touch interaction options // @option touchZoom: Boolean|String = * // Whether the map can be zoomed by touch-dragging with two fingers. If // passed `'center'`, it will zoom to the center of the view regardless of // where the touch events (fingers) were. Enabled for touch-capable web // browsers. touchZoom: Pe.touch, // @option bounceAtZoomLimits: Boolean = true // Set it to false if you don't want the map to zoom beyond min/max zoom // and then bounce back when pinch-zooming. bounceAtZoomLimits: !0 }); var Xc = Es.extend({ addHooks: function() { Vi(this._map._container, "leaflet-touch-zoom"), Bi(this._map._container, "touchstart", this._onTouchStart, this); }, removeHooks: function() { Hn(this._map._container, "leaflet-touch-zoom"), Cn(this._map._container, "touchstart", this._onTouchStart, this); }, _onTouchStart: function(p) { var A = this._map; if (!(!p.touches || p.touches.length !== 2 || A._animatingZoom || this._zooming)) { var B = A.mouseEventToContainerPoint(p.touches[0]), X = A.mouseEventToContainerPoint(p.touches[1]); this._centerPoint = A.getSize()._divideBy(2), this._startLatLng = A.containerPointToLatLng(this._centerPoint), A.options.touchZoom !== "center" && (this._pinchStartLatLng = A.containerPointToLatLng(B.add(X)._divideBy(2))), this._startDist = B.distanceTo(X), this._startZoom = A.getZoom(), this._moved = !1, this._zooming = !0, A._stop(), Bi(document, "touchmove", this._onTouchMove, this), Bi(document, "touchend touchcancel", this._onTouchEnd, this), _s(p); } }, _onTouchMove: function(p) { if (!(!p.touches || p.touches.length !== 2 || !this._zooming)) { var A = this._map, B = A.mouseEventToContainerPoint(p.touches[0]), X = A.mouseEventToContainerPoint(p.touches[1]), ne = B.distanceTo(X) / this._startDist; if (this._zoom = A.getScaleZoom(ne, this._startZoom), !A.options.bounceAtZoomLimits && (this._zoom < A.getMinZoom() && ne < 1 || this._zoom > A.getMaxZoom() && ne > 1) && (this._zoom = A._limitZoom(this._zoom)), A.options.touchZoom === "center") { if (this._center = this._startLatLng, ne === 1) return; } else { var ye = B._add(X)._divideBy(2)._subtract(this._centerPoint); if (ne === 1 && ye.x === 0 && ye.y === 0) return; this._center = A.unproject(A.project(this._pinchStartLatLng, this._zoom).subtract(ye), this._zoom); } this._moved || (A._moveStart(!0, !1), this._moved = !0), Mi(this._animRequest); var We = E(A._move, A, this._center, this._zoom, { pinch: !0, round: !1 }, void 0); this._animRequest = Pt(We, this, !0), _s(p); } }, _onTouchEnd: function() { if (!this._moved || !this._zooming) { this._zooming = !1; return; } this._zooming = !1, Mi(this._animRequest), Cn(document, "touchmove", this._onTouchMove, this), Cn(document, "touchend touchcancel", this._onTouchEnd, this), this._map.options.zoomAnimation ? this._map._animateZoom(this._center, this._map._limitZoom(this._zoom), !0, this._map.options.zoomSnap) : this._map._resetView(this._center, this._map._limitZoom(this._zoom)); } }); nn.addInitHook("addHandler", "touchZoom", Xc), nn.BoxZoom = Wh, nn.DoubleClickZoom = $h, nn.Drag = Ql, nn.Keyboard = ec, nn.ScrollWheelZoom = tc, nn.TapHold = $c, nn.TouchZoom = Xc, d.Bounds = Gi, d.Browser = Pe, d.CRS = Cs, d.Canvas = vl, d.Circle = gs, d.CircleMarker = ma, d.Class = hn, d.Control = Dn, d.DivIcon = Kl, d.DivOverlay = xr, d.DomEvent = Zl, d.DomUtil = Oi, d.Draggable = Wo, d.Evented = Ji, d.FeatureGroup = Xr, d.GeoJSON = cr, d.GridLayer = ro, d.Handler = Es, d.Icon = Yr, d.ImageOverlay = ja, d.LatLng = Di, d.LatLngBounds = qt, d.Layer = ar, d.LayerGroup = lr, d.LineUtil = ed, d.Map = nn, d.Marker = ks, d.Mixin = Oa, d.Path = Tt, d.Point = fi, d.PolyUtil = or, d.Polygon = Kr, d.Polyline = Dr, d.Popup = Ko, d.PosAnimation = da, d.Projection = bi, d.Rectangle = qc, d.Renderer = Qr, d.SVG = Ga, d.SVGOverlay = Zc, d.TileLayer = kr, d.Tooltip = Jr, d.Transformation = Vs, d.Util = Pn, d.VideoOverlay = Gc, d.bind = E, d.bounds = an, d.canvas = ao, d.circle = Gh, d.circleMarker = Mo, d.control = rr, d.divIcon = ya, d.extend = w, d.featureGroup = ql, d.geoJSON = Hh, d.geoJson = td, d.gridLayer = xl, d.icon = Va, d.imageOverlay = jc, d.latLng = xi, d.latLngBounds = ln, d.layerGroup = ti, d.map = dl, d.marker = Wl, d.point = ni, d.polygon = Yo, d.polyline = So, d.popup = Xl, d.rectangle = gn, d.setOptions = be, d.stamp = O, d.svg = Qo, d.svgOverlay = Hc, d.tileLayer = oo, d.tooltip = Yl, d.transformation = Us, d.version = g, d.videoOverlay = hr; var id = window.L; d.noConflict = function() { return window.L = id, this; }, window.L = d; }); }(Sm, Sm.exports)), Sm.exports; } var PC = yw(); const wn = /* @__PURE__ */ gw(PC); var AC = { exports: {} }; (function(m) { (function(a, d) { m.exports ? m.exports = d(yw()) : d(a.L); })(typeof self < "u" ? self : Km, (a) => { if (typeof document > "u") return console.warn('"window.document" is undefined; leaflet.fullscreen requires this object to access the DOM'), !1; const d = (() => { const b = [ // Standard [ "requestFullscreen", "exitFullscreen", "fullscreenElement", "fullscreenEnabled", "fullscreenchange", "fullscreenerror" ], // New WebKit [ "webkitRequestFullscreen", "webkitExitFullscreen", "webkitFullscreenElement", "webkitFullscreenEnabled", "webkitfullscreenchange", "webkitfullscreenerror" ] ], E = b[0], i = {}; for (const O of b) if (O[1] in document) { for (let j = 0; j < O.length; j++) i[E[j]] = O[j]; return i; } return !1; })(), g = { change: d.fullscreenchange, error: d.fullscreenerror }, w = { request(b, E) { return new Promise((i, O) => { const j = (function() { this.off("change", j), i(); }).bind(this); this.on("change", j), b = b || document.documentElement; const Y = b[d.requestFullscreen](E); Y instanceof Promise && Y.then(j).catch(O); }); }, exit() { return new Promise((b, E) => { if (!this.isFullscreen) { b(); return; } const i = (function() { this.off("change", i), b(); }).bind(this); this.on("change", i); const O = document[d.exitFullscreen](); O instanceof Promise && O.then(i).catch(E); }); }, on(b, E) { const i = g[b]; i && document.addEventListener(i, E, !1); }, off(b, E) { const i = g[b]; i && document.removeEventListener(i, E, !1); }, nativeAPI: d }; return Object.defineProperties(w, { isFullscreen: { get() { return !!document[d.fullscreenElement]; } }, isEnabled: { enumerable: !0, get() { return !!document[d.fullscreenEnabled]; } } }), a.Control.FullScreen = a.Control.extend({ options: { position: "topleft", title: "Full Screen", titleCancel: "Exit Full Screen", forceSeparateButton: !1, forcePseudoFullscreen: !1, fullscreenElement: !1 }, _screenfull: w, onAdd(b) { let E = "leaflet-control-zoom-fullscreen", i, O = ""; return b.zoomControl && !this.options.forceSeparateButton ? i = b.zoomControl._container : i = a.DomUtil.create("div", "leaflet-bar"), this.options.content ? O = this.options.content : E += " fullscreen-icon", this._createButton(this.options.title, E, O, i, this.toggleFullScreen, this), this._map.fullscreenControl = this, this._map.on("enterFullscreen exitFullscreen", this._toggleState, this), i; }, onRemove() { a.DomEvent.off(this.link, "click", a.DomEvent.stop).off(this.link, "click", this.toggleFullScreen, this), this._screenfull.isEnabled && (a.DomEvent.off(this._container, this._screenfull.nativeAPI.fullscreenchange, a.DomEvent.stop).off(this._container, this._screenfull.nativeAPI.fullscreenchange, this._handleFullscreenChange, this), a.DomEvent.off(document, this._screenfull.nativeAPI.fullscreenchange, a.DomEvent.stop).off(document, this._screenfull.nativeAPI.fullscreenchange, this._handleFullscreenChange, this)); }, _createButton(b, E, i, O, j, Y) { return this.link = a.DomUtil.create("a", E, O), this.link.href = "#", this.link.title = b, this.link.innerHTML = i, this.link.setAttribute("role", "button"), this.link.setAttribute("aria-label", b), L.DomEvent.disableClickPropagation(O), a.DomEvent.on(this.link, "click", a.DomEvent.stop).on(this.link, "click", j, Y), this._screenfull.isEnabled && (a.DomEvent.on(O, this._screenfull.nativeAPI.fullscreenchange, a.DomEvent.stop).on(O, this._screenfull.nativeAPI.fullscreenchange, this._handleFullscreenChange, Y), a.DomEvent.on(document, this._screenfull.nativeAPI.fullscreenchange, a.DomEvent.stop).on(document, this._screenfull.nativeAPI.fullscreenchange, this._handleFullscreenChange, Y)), this.link; }, toggleFullScreen() { const b = this._map; b._exitFired = !1, b._isFullscreen ? (this._screenfull.isEnabled && !this.options.forcePseudoFullscreen ? this._screenfull.exit().then(() => b.invalidateSize()) : (a.DomUtil.removeClass(this.options.fullscreenElement ? this.options.fullscreenElement : b._container, "leaflet-pseudo-fullscreen"), b.invalidateSize()), b.fire("exitFullscreen"), b._exitFired = !0, b._isFullscreen = !1) : (this._screenfull.isEnabled && !this.options.forcePseudoFullscreen ? this._screenfull.request(this.options.fullscreenElement ? this.options.fullscreenElement : b._container).then(() => b.invalidateSize()) : (a.DomUtil.addClass(this.options.fullscreenElement ? this.options.fullscreenElement : b._container, "leaflet-pseudo-fullscreen"), b.invalidateSize()), b.fire("enterFullscreen"), b._isFullscreen = !0); }, _toggleState() { this.link.title = this._map._isFullscreen ? this.options.title : this.options.titleCancel, this._map._isFullscreen ? L.DomUtil.removeClass(this.link, "leaflet-fullscreen-on") : L.DomUtil.addClass(this.link, "leaflet-fullscreen-on"); }, _handleFullscreenChange(b) { const E = this._map; b.target === E.getContainer() && !this._screenfull.isFullscreen && !E._exitFired && (this._screenfull.exit().then(() => E.invalidateSize()), E.fire("exitFullscreen"), E._exitFired = !0, E._isFullscreen = !1); } }), a.Map.include({ toggleFullscreen() { this.fullscreenControl.toggleFullScreen(); } }), a.Map.addInitHook(function() { this.options.fullscreenControl && this.addControl(a.control.fullscreen(this.options.fullscreenControlOptions)); }), a.control.fullscreen = function(b) { return new a.Control.FullScreen(b); }, { leaflet: a }; }); })(AC); var gb = { exports: {} }; (function(m, a) { (function(d, g) { g(a); })(Km, function(d) { var g = L.MarkerClusterGroup = L.FeatureGroup.extend({ options: { maxClusterRadius: 80, //A cluster will cover at most this many pixels from its center iconCreateFunction: null, clusterPane: L.Marker.prototype.options.pane, spiderfyOnEveryZoom: !1, spiderfyOnMaxZoom: !0, showCoverageOnHover: !0, zoomToBoundsOnClick: !0, singleMarkerMode: !1, disableClusteringAtZoom: null, // Setting this to false prevents the removal of any clusters outside of the viewpoint, which // is the default behaviour for performance reasons. removeOutsideVisibleBounds: !0, // Set to false to disable all animations (zoom and spiderfy). // If false, option animateAddingMarkers below has no effect. // If L.DomUtil.TRANSITION is falsy, this option has no effect. animate: !0, //Whether to animate adding markers after adding the MarkerClusterGroup to the map // If you are adding individual markers set to true, if adding bulk markers leave false for massive performance gains. animateAddingMarkers: !1, // Make it possible to provide custom function to calculate spiderfy shape positions spiderfyShapePositions: null, //Increase to increase the distance away that spiderfied markers appear from the center spiderfyDistanceMultiplier: 1, // Make it possible to specify a polyline options on a spider leg spiderLegPolylineOptions: { weight: 1.5, color: "#222", opacity: 0.5 }, // When bulk adding layers, adds markers in chunks. Means addLayers may not add all the layers in the call, others will be loaded during setTimeouts chunkedLoading: !1, chunkInterval: 200, // process markers for a maximum of ~ n milliseconds (then trigger the chunkProgress callback) chunkDelay: 50, // at the end of each interval, give n milliseconds back to system/browser chunkProgress: null, // progress callback: function(processed, total, elapsed) (e.g. for a progress indicator) //Options to pass to the L.Polygon constructor polygonOptions: {} }, initialize: function(b) { L.Util.setOptions(this, b), this.options.iconCreateFunction || (this.options.iconCreateFunction = this._defaultIconCreateFunction), this._featureGroup = L.featureGroup(), this._featureGroup.addEventParent(this), this._nonPointGroup = L.featureGroup(), this._nonPointGroup.addEventParent(this), this._inZoomAnimation = 0, this._needsClustering = [], this._needsRemoving = [], this._currentShownBounds = null, this._queue = [], this._childMarkerEventHandlers = { dragstart: this._childMarkerDragStart, move: this._childMarkerMoved, dragend: this._childMarkerDragEnd }; var E = L.DomUtil.TRANSITION && this.options.animate; L.extend(this, E ? this._withAnimation : this._noAnimation), this._markerCluster = E ? L.MarkerCluster : L.MarkerClusterNonAnimated; }, addLayer: function(b) { if (b instanceof L.LayerGroup) return this.addLayers([b]); if (!b.getLatLng) return this._nonPointGroup.addLayer(b), this.fire("layeradd", { layer: b }), this; if (!this._map) return this._needsClustering.push(b), this.fire("layeradd", { layer: b }), this; if (this.hasLayer(b)) return this; this._unspiderfy && this._unspiderfy(), this._addLayer(b, this._maxZoom), this.fire("layeradd", { layer: b }), this._topClusterLevel._recalculateBounds(), this._refreshClustersIcons(); var E = b, i = this._zoom; if (b.__parent) for (; E.__parent._zoom >= i; ) E = E.__parent; return this._currentShownBounds.contains(E.getLatLng()) && (this.options.animateAddingMarkers ? this._animationAddLayer(b, E) : this._animationAddLayerNonAnimated(b, E)), this; }, removeLayer: function(b) { return b instanceof L.LayerGroup ? this.removeLayers([b]) : b.getLatLng ? this._map ? b.__parent ? (this._unspiderfy && (this._unspiderfy(), this._unspiderfyLayer(b)), this._removeLayer(b, !0), this.fire("layerremove", { layer: b }), this._topClusterLevel._recalculateBounds(), this._refreshClustersIcons(), b.off(this._childMarkerEventHandlers, this), this._featureGroup.hasLayer(b) && (this._featureGroup.removeLayer(b), b.clusterShow && b.clusterShow()), this) : this : (!this._arraySplice(this._needsClustering, b) && this.hasLayer(b) && this._needsRemoving.push({ layer: b, latlng: b._latlng }), this.fire("layerremove", { layer: b }), this) : (this._nonPointGroup.removeLayer(b), this.fire("layerremove", { layer: b }), this); }, //Takes an array of markers and adds them in bulk addLayers: function(b, E) { if (!L.Util.isArray(b)) return this.addLayer(b); var i = this._featureGroup, O = this._nonPointGroup, j = this.options.chunkedLoading, Y = this.options.chunkInterval, J = this.options.chunkProgress, ae = b.length, ce = 0, Te = !0, be; if (this._map) { var Ze = (/* @__PURE__ */ new Date()).getTime(), je = L.bind(function() { var vt = (/* @__PURE__ */ new Date()).getTime(); for (this._map && this._unspiderfy && this._unspiderfy(); ce < ae; ce++) { if (j && ce % 200 === 0) { var ht = (/* @__PURE__ */ new Date()).getTime() - vt; if (ht > Y) break; } if (be = b[ce], be instanceof L.LayerGroup) { Te && (b = b.slice(), Te = !1), this._extractNonGroupLayers(be, b), ae = b.length; continue; } if (!be.getLatLng) { O.addLayer(be), E || this.fire("layeradd", { layer: be }); continue; } if (!this.hasLayer(be) && (this._addLayer(be, this._maxZoom), E || this.fire("layeradd", { layer: be }), be.__parent && be.__parent.getChildCount() === 2)) { var gt = be.__parent.getAllChildMarkers(), Vt = gt[0] === be ? gt[1] : gt[0]; i.removeLayer(Vt); } } J && J(ce, ae, (/* @__PURE__ */ new Date()).getTime() - Ze), ce === ae ? (this._topClusterLevel._recalculateBounds(), this._refreshClustersIcons(), this._topClusterLevel._recursivelyAddChildrenToMap(null, this._zoom, this._currentShownBounds)) : setTimeout(je, this.options.chunkDelay); }, this); je(); } else for (var ot = this._needsClustering; ce < ae; ce++) { if (be = b[ce], be instanceof L.LayerGroup) { Te && (b = b.slice(), Te = !1), this._extractNonGroupLayers(be, b), ae = b.length; continue; } if (!be.getLatLng) { O.addLayer(be); continue; } this.hasLayer(be) || ot.push(be); } return this; }, //Takes an array of markers and removes them in bulk removeLayers: function(b) { var E, i, O = b.length, j = this._featureGroup, Y = this._nonPointGroup, J = !0; if (!this._map) { for (E = 0; E < O; E++) { if (i = b[E], i instanceof L.LayerGroup) { J && (b = b.slice(), J = !1), this._extractNonGroupLayers(i, b), O = b.length; continue; } this._arraySplice(this._needsClustering, i), Y.removeLayer(i), this.hasLayer(i) && this._needsRemoving.push({ layer: i, latlng: i._latlng }), this.fire("layerremove", { layer: i }); } return this; } if (this._unspiderfy) { this._unspiderfy(); var ae = b.slice(), ce = O; for (E = 0; E < ce; E++) { if (i = ae[E], i instanceof L.LayerGroup) { this._extractNonGroupLayers(i, ae), ce = ae.length; continue; } this._unspiderfyLayer(i); } } for (E = 0; E < O; E++) { if (i = b[E], i instanceof L.LayerGroup) { J && (b = b.slice(), J = !1), this._extractNonGroupLayers(i, b), O = b.length; continue; } if (!i.__parent) { Y.removeLayer(i), this.fire("layerremove", { layer: i }); continue; } this._removeLayer(i, !0, !0), this.fire("layerremove", { layer: i }), j.hasLayer(i) && (j.removeLayer(i), i.clusterShow && i.clusterShow()); } return this._topClusterLevel._recalculateBounds(), this._refreshClustersIcons(), this._topClusterLevel._recursivelyAddChildrenToMap(null, this._zoom, this._currentShownBounds), this; }, //Removes all layers from the MarkerClusterGroup clearLayers: function() { return this._map || (this._needsClustering = [], this._needsRemoving = [], delete this._gridClusters, delete this._gridUnclustered), this._noanimationUnspiderfy && this._noanimationUnspiderfy(), this._featureGroup.clearLayers(), this._nonPointGroup.clearLayers(), this.eachLayer(function(b) { b.off(this._childMarkerEventHandlers, this), delete b.__parent; }, this), this._map && this._generateInitialClusters(), this; }, //Override FeatureGroup.getBounds as it doesn't work getBounds: function() { var b = new L.LatLngBounds(); this._topClusterLevel && b.extend(this._topClusterLevel._bounds); for (var E = this._needsClustering.length - 1; E >= 0; E--) b.extend(this._needsClustering[E].getLatLng()); return b.extend(this._nonPointGroup.getBounds()), b; }, //Overrides LayerGroup.eachLayer eachLayer: function(b, E) { var i = this._needsClustering.slice(), O = this._needsRemoving, j, Y, J; for (this._topClusterLevel && this._topClusterLevel.getAllChildMarkers(i), Y = i.length - 1; Y >= 0; Y--) { for (j = !0, J = O.length - 1; J >= 0; J--) if (O[J].layer === i[Y]) { j = !1; break; } j && b.call(E, i[Y]); } this._nonPointGroup.eachLayer(b, E); }, //Overrides LayerGroup.getLayers getLayers: function() { var b = []; return this.eachLayer(function(E) { b.push(E); }), b; }, //Overrides LayerGroup.getLayer, WARNING: Really bad performance getLayer: function(b) { var E = null; return b = parseInt(b, 10), this.eachLayer(function(i) { L.stamp(i) === b && (E = i); }), E; }, //Returns true if the given layer is in this MarkerClusterGroup hasLayer: function(b) { if (!b) return !1; var E, i = this._needsClustering; for (E = i.length - 1; E >= 0; E--) if (i[E] === b) return !0; for (i = this._needsRemoving, E = i.length - 1; E >= 0; E--) if (i[E].layer === b) return !1; return !!(b.__parent && b.__parent._group === this) || this._nonPointGroup.hasLayer(b); }, //Zoom down to show the given layer (spiderfying if necessary) then calls the callback zoomToShowLayer: function(b, E) { var i = this._map; typeof E != "function" && (E = function() { }); var O = function() { (i.hasLayer(b) || i.hasLayer(b.__parent)) && !this._inZoomAnimation && (this._map.off("moveend", O, this), this.off("animationend", O, this), i.hasLayer(b) ? E() : b.__parent._icon && (this.once("spiderfied", E, this), b.__parent.spiderfy())); }; b._icon && this._map.getBounds().contains(b.getLatLng()) ? E() : b.__parent._zoom < Math.round(this._map._zoom) ? (this._map.on("moveend", O, this), this._map.panTo(b.getLatLng())) : (this._map.on("moveend", O, this), this.on("animationend", O, this), b.__parent.zoomToBounds()); }, //Overrides FeatureGroup.onAdd onAdd: function(b) { this._map = b; var E, i, O; if (!isFinite(this._map.getMaxZoom())) throw "Map has no maxZoom specified"; for (this._featureGroup.addTo(b), this._nonPointGroup.addTo(b), this._gridClusters || this._generateInitialClusters(), this._maxLat = b.options.crs.projection.MAX_LATITUDE, E = 0, i = this._needsRemoving.length; E < i; E++) O = this._needsRemoving[E], O.newlatlng = O.layer._latlng, O.layer._latlng = O.latlng; for (E = 0, i = this._needsRemoving.length; E < i; E++) O = this._needsRemoving[E], this._removeLayer(O.layer, !0), O.layer._latlng = O.newlatlng; this._needsRemoving = [], this._zoom = Math.round(this._map._zoom), this._currentShownBounds = this._getExpandedVisibleBounds(), this._map.on("zoomend", this._zoomEnd, this), this._map.on("moveend", this._moveEnd, this), this._spiderfierOnAdd && this._spiderfierOnAdd(), this._bindEvents(), i = this._needsClustering, this._needsClustering = [], this.addLayers(i, !0); }, //Overrides FeatureGroup.onRemove onRemove: function(b) { b.off("zoomend", this._zoomEnd, this), b.off("moveend", this._moveEnd, this), this._unbindEvents(), this._map._mapPane.className = this._map._mapPane.className.replace(" leaflet-cluster-anim", ""), this._spiderfierOnRemove && this._spiderfierOnRemove(), delete this._maxLat, this._hideCoverage(), this._featureGroup.remove(), this._nonPointGroup.remove(), this._featureGroup.clearLayers(), this._map = null; }, getVisibleParent: function(b) { for (var E = b; E && !E._icon; ) E = E.__parent; return E || null; }, //Remove the given object from the given array _arraySplice: function(b, E) { for (var i = b.length - 1; i >= 0; i--) if (b[i] === E) return b.splice(i, 1), !0; }, /** * Removes a marker from all _gridUnclustered zoom levels, starting at the supplied zoom. * @param marker to be removed from _gridUnclustered. * @param z integer bottom start zoom level (included) * @private */ _removeFromGridUnclustered: function(b, E) { for (var i = this._map, O = this._gridUnclustered, j = Math.floor(this._map.getMinZoom()); E >= j && O[E].removeObject(b, i.project(b.getLatLng(), E)); E--) ; }, _childMarkerDragStart: function(b) { b.target.__dragStart = b.target._latlng; }, _childMarkerMoved: function(b) { if (!this._ignoreMove && !b.target.__dragStart) { var E = b.target._popup && b.target._popup.isOpen(); this._moveChild(b.target, b.oldLatLng, b.latlng), E && b.target.openPopup(); } }, _moveChild: function(b, E, i) { b._latlng = E, this.removeLayer(b), b._latlng = i, this.addLayer(b); }, _childMarkerDragEnd: function(b) { var E = b.target.__dragStart; delete b.target.__dragStart, E && this._moveChild(b.target, E, b.target._latlng); }, //Internal function for removing a marker from everything. //dontUpdateMap: set to true if you will handle updating the map manually (for bulk functions) _removeLayer: function(b, E, i) { var O = this._gridClusters, j = this._gridUnclustered, Y = this._featureGroup, J = this._map, ae = Math.floor(this._map.getMinZoom()); E && this._removeFromGridUnclustered(b, this._maxZoom); var ce = b.__parent, Te = ce._markers, be; for (this._arraySplice(Te, b); ce && (ce._childCount--, ce._boundsNeedUpdate = !0, !(ce._zoom < ae)); ) E && ce._childCount <= 1 ? (be = ce._markers[0] === b ? ce._markers[1] : ce._markers[0], O[ce._zoom].removeObject(ce, J.project(ce._cLatLng, ce._zoom)), j[ce._zoom].addObject(be, J.project(be.getLatLng(), ce._zoom)), this._arraySplice(ce.__parent._childClusters, ce), ce.__parent._markers.push(be), be.__parent = ce.__parent, ce._icon && (Y.removeLayer(ce), i || Y.addLayer(be))) : ce._iconNeedsUpdate = !0, ce = ce.__parent; delete b.__parent; }, _isOrIsParent: function(b, E) { for (; E; ) { if (b === E) return !0; E = E.parentNode; } return !1; }, //Override L.Evented.fire fire: function(b, E, i) { if (E && E.layer instanceof L.MarkerCluster) { if (E.originalEvent && this._isOrIsParent(E.layer._icon, E.originalEvent.relatedTarget)) return; b = "cluster" + b; } L.FeatureGroup.prototype.fire.call(this, b, E, i); }, //Override L.Evented.listens listens: function(b, E) { return L.FeatureGroup.prototype.listens.call(this, b, E) || L.FeatureGroup.prototype.listens.call(this, "cluster" + b, E); }, //Default functionality _defaultIconCreateFunction: function(b) { var E = b.getChildCount(), i = " marker-cluster-"; return E < 10 ? i += "small" : E < 100 ? i += "medium" : i += "large", new L.DivIcon({ html: "
" + E + "
", className: "marker-cluster" + i, iconSize: new L.Point(40, 40) }); }, _bindEvents: function() { var b = this._map, E = this.options.spiderfyOnMaxZoom, i = this.options.showCoverageOnHover, O = this.options.zoomToBoundsOnClick, j = this.options.spiderfyOnEveryZoom; (E || O || j) && this.on("clusterclick clusterkeypress", this._zoomOrSpiderfy, this), i && (this.on("clustermouseover", this._showCoverage, this), this.on("clustermouseout", this._hideCoverage, this), b.on("zoomend", this._hideCoverage, this)); }, _zoomOrSpiderfy: function(b) { var E = b.layer, i = E; if (!(b.type === "clusterkeypress" && b.originalEvent && b.originalEvent.keyCode !== 13)) { for (; i._childClusters.length === 1; ) i = i._childClusters[0]; i._zoom === this._maxZoom && i._childCount === E._childCount && this.options.spiderfyOnMaxZoom ? E.spiderfy() : this.options.zoomToBoundsOnClick && E.zoomToBounds(), this.options.spiderfyOnEveryZoom && E.spiderfy(), b.originalEvent && b.originalEvent.keyCode === 13 && this._map._container.focus(); } }, _showCoverage: function(b) { var E = this._map; this._inZoomAnimation || (this._shownPolygon && E.removeLayer(this._shownPolygon), b.layer.getChildCount() > 2 && b.layer !== this._spiderfied && (this._shownPolygon = new L.Polygon(b.layer.getConvexHull(), this.options.polygonOptions), E.addLayer(this._shownPolygon))); }, _hideCoverage: function() { this._shownPolygon && (this._map.removeLayer(this._shownPolygon), this._shownPolygon = null); }, _unbindEvents: function() { var b = this.options.spiderfyOnMaxZoom, E = this.options.showCoverageOnHover, i = this.options.zoomToBoundsOnClick, O = this.options.spiderfyOnEveryZoom, j = this._map; (b || i || O) && this.off("clusterclick clusterkeypress", this._zoomOrSpiderfy, this), E && (this.off("clustermouseover", this._showCoverage, this), this.off("clustermouseout", this._hideCoverage, this), j.off("zoomend", this._hideCoverage, this)); }, _zoomEnd: function() { this._map && (this._mergeSplitClusters(), this._zoom = Math.round(this._map._zoom), this._currentShownBounds = this._getExpandedVisibleBounds()); }, _moveEnd: function() { if (!this._inZoomAnimation) { var b = this._getExpandedVisibleBounds(); this._topClusterLevel._recursivelyRemoveChildrenFromMap(this._currentShownBounds, Math.floor(this._map.getMinZoom()), this._zoom, b), this._topClusterLevel._recursivelyAddChildrenToMap(null, Math.round(this._map._zoom), b), this._currentShownBounds = b; } }, _generateInitialClusters: function() { var b = Math.ceil(this._map.getMaxZoom()), E = Math.floor(this._map.getMinZoom()), i = this.options.maxClusterRadius, O = i; typeof i != "function" && (O = function() { return i; }), this.options.disableClusteringAtZoom !== null && (b = this.options.disableClusteringAtZoom - 1), this._maxZoom = b, this._gridClusters = {}, this._gridUnclustered = {}; for (var j = b; j >= E; j--) this._gridClusters[j] = new L.DistanceGrid(O(j)), this._gridUnclustered[j] = new L.DistanceGrid(O(j)); this._topClusterLevel = new this._markerCluster(this, E - 1); }, //Zoom: Zoom to start adding at (Pass this._maxZoom to start at the bottom) _addLayer: function(b, E) { var i = this._gridClusters, O = this._gridUnclustered, j = Math.floor(this._map.getMinZoom()), Y, J; for (this.options.singleMarkerMode && this._overrideMarkerIcon(b), b.on(this._childMarkerEventHandlers, this); E >= j; E--) { Y = this._map.project(b.getLatLng(), E); var ae = i[E].getNearObject(Y); if (ae) { ae._addChild(b), b.__parent = ae; return; } if (ae = O[E].getNearObject(Y), ae) { var ce = ae.__parent; ce && this._removeLayer(ae, !1); var Te = new this._markerCluster(this, E, ae, b); i[E].addObject(Te, this._map.project(Te._cLatLng, E)), ae.__parent = Te, b.__parent = Te; var be = Te; for (J = E - 1; J > ce._zoom; J--) be = new this._markerCluster(this, J, be), i[J].addObject(be, this._map.project(ae.getLatLng(), J)); ce._addChild(be), this._removeFromGridUnclustered(ae, E); return; } O[E].addObject(b, Y); } this._topClusterLevel._addChild(b), b.__parent = this._topClusterLevel; }, /** * Refreshes the icon of all "dirty" visible clusters. * Non-visible "dirty" clusters will be updated when they are added to the map. * @private */ _refreshClustersIcons: function() { this._featureGroup.eachLayer(function(b) { b instanceof L.MarkerCluster && b._iconNeedsUpdate && b._updateIcon(); }); }, //Enqueue code to fire after the marker expand/contract has happened _enqueue: function(b) { this._queue.push(b), this._queueTimeout || (this._queueTimeout = setTimeout(L.bind(this._processQueue, this), 300)); }, _processQueue: function() { for (var b = 0; b < this._queue.length; b++) this._queue[b].call(this); this._queue.length = 0, clearTimeout(this._queueTimeout), this._queueTimeout = null; }, //Merge and split any existing clusters that are too big or small _mergeSplitClusters: function() { var b = Math.round(this._map._zoom); this._processQueue(), this._zoom < b && this._currentShownBounds.intersects(this._getExpandedVisibleBounds()) ? (this._animationStart(), this._topClusterLevel._recursivelyRemoveChildrenFromMap(this._currentShownBounds, Math.floor(this._map.getMinZoom()), this._zoom, this._getExpandedVisibleBounds()), this._animationZoomIn(this._zoom, b)) : this._zoom > b ? (this._animationStart(), this._animationZoomOut(this._zoom, b)) : this._moveEnd(); }, //Gets the maps visible bounds expanded in each direction by the size of the screen (so the user cannot see an area we do not cover in one pan) _getExpandedVisibleBounds: function() { if (this.options.removeOutsideVisibleBounds) { if (L.Browser.mobile) return this._checkBoundsMaxLat(this._map.getBounds()); } else return this._mapBoundsInfinite; return this._checkBoundsMaxLat(this._map.getBounds().pad(1)); }, /** * Expands the latitude to Infinity (or -Infinity) if the input bounds reach the map projection maximum defined latitude * (in the case of Web/Spherical Mercator, it is 85.0511287798 / see https://en.wikipedia.org/wiki/Web_Mercator#Formulas). * Otherwise, the removeOutsideVisibleBounds option will remove markers beyond that limit, whereas the same markers without * this option (or outside MCG) will have their position floored (ceiled) by the projection and rendered at that limit, * making the user think that MCG "eats" them and never displays them again. * @param bounds L.LatLngBounds * @returns {L.LatLngBounds} * @private */ _checkBoundsMaxLat: function(b) { var E = this._maxLat; return E !== void 0 && (b.getNorth() >= E && (b._northEast.lat = 1 / 0), b.getSouth() <= -E && (b._southWest.lat = -1 / 0)), b; }, //Shared animation code _animationAddLayerNonAnimated: function(b, E) { if (E === b) this._featureGroup.addLayer(b); else if (E._childCount === 2) { E._addToMap(); var i = E.getAllChildMarkers(); this._featureGroup.removeLayer(i[0]), this._featureGroup.removeLayer(i[1]); } else E._updateIcon(); }, /** * Extracts individual (i.e. non-group) layers from a Layer Group. * @param group to extract layers from. * @param output {Array} in which to store the extracted layers. * @returns {*|Array} * @private */ _extractNonGroupLayers: function(b, E) { var i = b.getLayers(), O = 0, j; for (E = E || []; O < i.length; O++) { if (j = i[O], j instanceof L.LayerGroup) { this._extractNonGroupLayers(j, E); continue; } E.push(j); } return E; }, /** * Implements the singleMarkerMode option. * @param layer Marker to re-style using the Clusters iconCreateFunction. * @returns {L.Icon} The newly created icon. * @private */ _overrideMarkerIcon: function(b) { var E = b.options.icon = this.options.iconCreateFunction({ getChildCount: function() { return 1; }, getAllChildMarkers: function() { return [b]; } }); return E; } }); L.MarkerClusterGroup.include({ _mapBoundsInfinite: new L.LatLngBounds(new L.LatLng(-1 / 0, -1 / 0), new L.LatLng(1 / 0, 1 / 0)) }), L.MarkerClusterGroup.include({ _noAnimation: { //Non Animated versions of everything _animationStart: function() { }, _animationZoomIn: function(b, E) { this._topClusterLevel._recursivelyRemoveChildrenFromMap(this._currentShownBounds, Math.floor(this._map.getMinZoom()), b), this._topClusterLevel._recursivelyAddChildrenToMap(null, E, this._getExpandedVisibleBounds()), this.fire("animationend"); }, _animationZoomOut: function(b, E) { this._topClusterLevel._recursivelyRemoveChildrenFromMap(this._currentShownBounds, Math.floor(this._map.getMinZoom()), b), this._topClusterLevel._recursivelyAddChildrenToMap(null, E, this._getExpandedVisibleBounds()), this.fire("animationend"); }, _animationAddLayer: function(b, E) { this._animationAddLayerNonAnimated(b, E); } }, _withAnimation: { //Animated versions here _animationStart: function() { this._map._mapPane.className += " leaflet-cluster-anim", this._inZoomAnimation++; }, _animationZoomIn: function(b, E) { var i = this._getExpandedVisibleBounds(), O = this._featureGroup, j = Math.floor(this._map.getMinZoom()), Y; this._ignoreMove = !0, this._topClusterLevel._recursively(i, b, j, function(J) { var ae = J._latlng, ce = J._markers, Te; for (i.contains(ae) || (ae = null), J._isSingleParent() && b + 1 === E ? (O.removeLayer(J), J._recursivelyAddChildrenToMap(null, E, i)) : (J.clusterHide(), J._recursivelyAddChildrenToMap(ae, E, i)), Y = ce.length - 1; Y >= 0; Y--) Te = ce[Y], i.contains(Te._latlng) || O.removeLayer(Te); }), this._forceLayout(), this._topClusterLevel._recursivelyBecomeVisible(i, E), O.eachLayer(function(J) { !(J instanceof L.MarkerCluster) && J._icon && J.clusterShow(); }), this._topClusterLevel._recursively(i, b, E, function(J) { J._recursivelyRestoreChildPositions(E); }), this._ignoreMove = !1, this._enqueue(function() { this._topClusterLevel._recursively(i, b, j, function(J) { O.removeLayer(J), J.clusterShow(); }), this._animationEnd(); }); }, _animationZoomOut: function(b, E) { this._animationZoomOutSingle(this._topClusterLevel, b - 1, E), this._topClusterLevel._recursivelyAddChildrenToMap(null, E, this._getExpandedVisibleBounds()), this._topClusterLevel._recursivelyRemoveChildrenFromMap(this._currentShownBounds, Math.floor(this._map.getMinZoom()), b, this._getExpandedVisibleBounds()); }, _animationAddLayer: function(b, E) { var i = this, O = this._featureGroup; O.addLayer(b), E !== b && (E._childCount > 2 ? (E._updateIcon(), this._forceLayout(), this._animationStart(), b._setPos(this._map.latLngToLayerPoint(E.getLatLng())), b.clusterHide(), this._enqueue(function() { O.removeLayer(b), b.clusterShow(), i._animationEnd(); })) : (this._forceLayout(), i._animationStart(), i._animationZoomOutSingle(E, this._map.getMaxZoom(), this._zoom))); } }, // Private methods for animated versions. _animationZoomOutSingle: function(b, E, i) { var O = this._getExpandedVisibleBounds(), j = Math.floor(this._map.getMinZoom()); b._recursivelyAnimateChildrenInAndAddSelfToMap(O, j, E + 1, i); var Y = this; this._forceLayout(), b._recursivelyBecomeVisible(O, i), this._enqueue(function() { if (b._childCount === 1) { var J = b._markers[0]; this._ignoreMove = !0, J.setLatLng(J.getLatLng()), this._ignoreMove = !1, J.clusterShow && J.clusterShow(); } else b._recursively(O, i, j, function(ae) { ae._recursivelyRemoveChildrenFromMap(O, j, E + 1); }); Y._animationEnd(); }); }, _animationEnd: function() { this._map && (this._map._mapPane.className = this._map._mapPane.className.replace(" leaflet-cluster-anim", "")), this._inZoomAnimation--, this.fire("animationend"); }, //Force a browser layout of stuff in the map // Should apply the current opacity and location to all elements so we can update them again for an animation _forceLayout: function() { L.Util.falseFn(document.body.offsetWidth); } }), L.markerClusterGroup = function(b) { return new L.MarkerClusterGroup(b); }; var w = L.MarkerCluster = L.Marker.extend({ options: L.Icon.prototype.options, initialize: function(b, E, i, O) { L.Marker.prototype.initialize.call( this, i ? i._cLatLng || i.getLatLng() : new L.LatLng(0, 0), { icon: this, pane: b.options.clusterPane } ), this._group = b, this._zoom = E, this._markers = [], this._childClusters = [], this._childCount = 0, this._iconNeedsUpdate = !0, this._boundsNeedUpdate = !0, this._bounds = new L.LatLngBounds(), i && this._addChild(i), O && this._addChild(O); }, //Recursively retrieve all child markers of this cluster getAllChildMarkers: function(b, E) { b = b || []; for (var i = this._childClusters.length - 1; i >= 0; i--) this._childClusters[i].getAllChildMarkers(b, E); for (var O = this._markers.length - 1; O >= 0; O--) E && this._markers[O].__dragStart || b.push(this._markers[O]); return b; }, //Returns the count of how many child markers we have getChildCount: function() { return this._childCount; }, //Zoom to the minimum of showing all of the child markers, or the extents of this cluster zoomToBounds: function(b) { for (var E = this._childClusters.slice(), i = this._group._map, O = i.getBoundsZoom(this._bounds), j = this._zoom + 1, Y = i.getZoom(), J; E.length > 0 && O > j; ) { j++; var ae = []; for (J = 0; J < E.length; J++) ae = ae.concat(E[J]._childClusters); E = ae; } O > j ? this._group._map.setView(this._latlng, j) : O <= Y ? this._group._map.setView(this._latlng, Y + 1) : this._group._map.fitBounds(this._bounds, b); }, getBounds: function() { var b = new L.LatLngBounds(); return b.extend(this._bounds), b; }, _updateIcon: function() { this._iconNeedsUpdate = !0, this._icon && this.setIcon(this); }, //Cludge for Icon, we pretend to be an icon for performance createIcon: function() { return this._iconNeedsUpdate && (this._iconObj = this._group.options.iconCreateFunction(this), this._iconNeedsUpdate = !1), this._iconObj.createIcon(); }, createShadow: function() { return this._iconObj.createShadow(); }, _addChild: function(b, E) { this._iconNeedsUpdate = !0, this._boundsNeedUpdate = !0, this._setClusterCenter(b), b instanceof L.MarkerCluster ? (E || (this._childClusters.push(b), b.__parent = this), this._childCount += b._childCount) : (E || this._markers.push(b), this._childCount++), this.__parent && this.__parent._addChild(b, !0); }, /** * Makes sure the cluster center is set. If not, uses the child center if it is a cluster, or the marker position. * @param child L.MarkerCluster|L.Marker that will be used as cluster center if not defined yet. * @private */ _setClusterCenter: function(b) { this._cLatLng || (this._cLatLng = b._cLatLng || b._latlng); }, /** * Assigns impossible bounding values so that the next extend entirely determines the new bounds. * This method avoids having to trash the previous L.LatLngBounds object and to create a new one, which is much slower for this class. * As long as the bounds are not extended, most other methods would probably fail, as they would with bounds initialized but not extended. * @private */ _resetBounds: function() { var b = this._bounds; b._southWest && (b._southWest.lat = 1 / 0, b._southWest.lng = 1 / 0), b._northEast && (b._northEast.lat = -1 / 0, b._northEast.lng = -1 / 0); }, _recalculateBounds: function() { var b = this._markers, E = this._childClusters, i = 0, O = 0, j = this._childCount, Y, J, ae, ce; if (j !== 0) { for (this._resetBounds(), Y = 0; Y < b.length; Y++) ae = b[Y]._latlng, this._bounds.extend(ae), i += ae.lat, O += ae.lng; for (Y = 0; Y < E.length; Y++) J = E[Y], J._boundsNeedUpdate && J._recalculateBounds(), this._bounds.extend(J._bounds), ae = J._wLatLng, ce = J._childCount, i += ae.lat * ce, O += ae.lng * ce; this._latlng = this._wLatLng = new L.LatLng(i / j, O / j), this._boundsNeedUpdate = !1; } }, //Set our markers position as given and add it to the map _addToMap: function(b) { b && (this._backupLatlng = this._latlng, this.setLatLng(b)), this._group._featureGroup.addLayer(this); }, _recursivelyAnimateChildrenIn: function(b, E, i) { this._recursively( b, this._group._map.getMinZoom(), i - 1, function(O) { var j = O._markers, Y, J; for (Y = j.length - 1; Y >= 0; Y--) J = j[Y], J._icon && (J._setPos(E), J.clusterHide()); }, function(O) { var j = O._childClusters, Y, J; for (Y = j.length - 1; Y >= 0; Y--) J = j[Y], J._icon && (J._setPos(E), J.clusterHide()); } ); }, _recursivelyAnimateChildrenInAndAddSelfToMap: function(b, E, i, O) { this._recursively( b, O, E, function(j) { j._recursivelyAnimateChildrenIn(b, j._group._map.latLngToLayerPoint(j.getLatLng()).round(), i), j._isSingleParent() && i - 1 === O ? (j.clusterShow(), j._recursivelyRemoveChildrenFromMap(b, E, i)) : j.clusterHide(), j._addToMap(); } ); }, _recursivelyBecomeVisible: function(b, E) { this._recursively(b, this._group._map.getMinZoom(), E, null, function(i) { i.clusterShow(); }); }, _recursivelyAddChildrenToMap: function(b, E, i) { this._recursively( i, this._group._map.getMinZoom() - 1, E, function(O) { if (E !== O._zoom) for (var j = O._markers.length - 1; j >= 0; j--) { var Y = O._markers[j]; i.contains(Y._latlng) && (b && (Y._backupLatlng = Y.getLatLng(), Y.setLatLng(b), Y.clusterHide && Y.clusterHide()), O._group._featureGroup.addLayer(Y)); } }, function(O) { O._addToMap(b); } ); }, _recursivelyRestoreChildPositions: function(b) { for (var E = this._markers.length - 1; E >= 0; E--) { var i = this._markers[E]; i._backupLatlng && (i.setLatLng(i._backupLatlng), delete i._backupLatlng); } if (b - 1 === this._zoom) for (var O = this._childClusters.length - 1; O >= 0; O--) this._childClusters[O]._restorePosition(); else for (var j = this._childClusters.length - 1; j >= 0; j--) this._childClusters[j]._recursivelyRestoreChildPositions(b); }, _restorePosition: function() { this._backupLatlng && (this.setLatLng(this._backupLatlng), delete this._backupLatlng); }, //exceptBounds: If set, don't remove any markers/clusters in it _recursivelyRemoveChildrenFromMap: function(b, E, i, O) { var j, Y; this._recursively( b, E - 1, i - 1, function(J) { for (Y = J._markers.length - 1; Y >= 0; Y--) j = J._markers[Y], (!O || !O.contains(j._latlng)) && (J._group._featureGroup.removeLayer(j), j.clusterShow && j.clusterShow()); }, function(J) { for (Y = J._childClusters.length - 1; Y >= 0; Y--) j = J._childClusters[Y], (!O || !O.contains(j._latlng)) && (J._group._featureGroup.removeLayer(j), j.clusterShow && j.clusterShow()); } ); }, //Run the given functions recursively to this and child clusters // boundsToApplyTo: a L.LatLngBounds representing the bounds of what clusters to recurse in to // zoomLevelToStart: zoom level to start running functions (inclusive) // zoomLevelToStop: zoom level to stop running functions (inclusive) // runAtEveryLevel: function that takes an L.MarkerCluster as an argument that should be applied on every level // runAtBottomLevel: function that takes an L.MarkerCluster as an argument that should be applied at only the bottom level _recursively: function(b, E, i, O, j) { var Y = this._childClusters, J = this._zoom, ae, ce; if (E <= J && (O && O(this), j && J === i && j(this)), J < E || J < i) for (ae = Y.length - 1; ae >= 0; ae--) ce = Y[ae], ce._boundsNeedUpdate && ce._recalculateBounds(), b.intersects(ce._bounds) && ce._recursively(b, E, i, O, j); }, //Returns true if we are the parent of only one cluster and that cluster is the same as us _isSingleParent: function() { return this._childClusters.length > 0 && this._childClusters[0]._childCount === this._childCount; } }); L.Marker.include({ clusterHide: function() { var b = this.options.opacity; return this.setOpacity(0), this.options.opacity = b, this; }, clusterShow: function() { return this.setOpacity(this.options.opacity); } }), L.DistanceGrid = function(b) { this._cellSize = b, this._sqCellSize = b * b, this._grid = {}, this._objectPoint = {}; }, L.DistanceGrid.prototype = { addObject: function(b, E) { var i = this._getCoord(E.x), O = this._getCoord(E.y), j = this._grid, Y = j[O] = j[O] || {}, J = Y[i] = Y[i] || [], ae = L.Util.stamp(b); this._objectPoint[ae] = E, J.push(b); }, updateObject: function(b, E) { this.removeObject(b), this.addObject(b, E); }, //Returns true if the object was found removeObject: function(b, E) { var i = this._getCoord(E.x), O = this._getCoord(E.y), j = this._grid, Y = j[O] = j[O] || {}, J = Y[i] = Y[i] || [], ae, ce; for (delete this._objectPoint[L.Util.stamp(b)], ae = 0, ce = J.length; ae < ce; ae++) if (J[ae] === b) return J.splice(ae, 1), ce === 1 && delete Y[i], !0; }, eachObject: function(b, E) { var i, O, j, Y, J, ae, ce, Te = this._grid; for (i in Te) { J = Te[i]; for (O in J) for (ae = J[O], j = 0, Y = ae.length; j < Y; j++) ce = b.call(E, ae[j]), ce && (j--, Y--); } }, getNearObject: function(b) { var E = this._getCoord(b.x), i = this._getCoord(b.y), O, j, Y, J, ae, ce, Te, be, Ze = this._objectPoint, je = this._sqCellSize, ot = null; for (O = i - 1; O <= i + 1; O++) if (J = this._grid[O], J) { for (j = E - 1; j <= E + 1; j++) if (ae = J[j], ae) for (Y = 0, ce = ae.length; Y < ce; Y++) Te = ae[Y], be = this._sqDist(Ze[L.Util.stamp(Te)], b), (be < je || be <= je && ot === null) && (je = be, ot = Te); } return ot; }, _getCoord: function(b) { var E = Math.floor(b / this._cellSize); return isFinite(E) ? E : b; }, _sqDist: function(b, E) { var i = E.x - b.x, O = E.y - b.y; return i * i + O * O; } }, function() { L.QuickHull = { /* * @param {Object} cpt a point to be measured from the baseline * @param {Array} bl the baseline, as represented by a two-element * array of latlng objects. * @returns {Number} an approximate distance measure */ getDistant: function(b, E) { var i = E[1].lat - E[0].lat, O = E[0].lng - E[1].lng; return O * (b.lat - E[0].lat) + i * (b.lng - E[0].lng); }, /* * @param {Array} baseLine a two-element array of latlng objects * representing the baseline to project from * @param {Array} latLngs an array of latlng objects * @returns {Object} the maximum point and all new points to stay * in consideration for the hull. */ findMostDistantPointFromBaseLine: function(b, E) { var i = 0, O = null, j = [], Y, J, ae; for (Y = E.length - 1; Y >= 0; Y--) { if (J = E[Y], ae = this.getDistant(J, b), ae > 0) j.push(J); else continue; ae > i && (i = ae, O = J); } return { maxPoint: O, newPoints: j }; }, /* * Given a baseline, compute the convex hull of latLngs as an array * of latLngs. * * @param {Array} latLngs * @returns {Array} */ buildConvexHull: function(b, E) { var i = [], O = this.findMostDistantPointFromBaseLine(b, E); return O.maxPoint ? (i = i.concat( this.buildConvexHull([b[0], O.maxPoint], O.newPoints) ), i = i.concat( this.buildConvexHull([O.maxPoint, b[1]], O.newPoints) ), i) : [b[0]]; }, /* * Given an array of latlngs, compute a convex hull as an array * of latlngs * * @param {Array} latLngs * @returns {Array} */ getConvexHull: function(b) { var E = !1, i = !1, O = !1, j = !1, Y = null, J = null, ae = null, ce = null, Te = null, be = null, Ze; for (Ze = b.length - 1; Ze >= 0; Ze--) { var je = b[Ze]; (E === !1 || je.lat > E) && (Y = je, E = je.lat), (i === !1 || je.lat < i) && (J = je, i = je.lat), (O === !1 || je.lng > O) && (ae = je, O = je.lng), (j === !1 || je.lng < j) && (ce = je, j = je.lng); } i !== E ? (be = J, Te = Y) : (be = ce, Te = ae); var ot = [].concat( this.buildConvexHull([be, Te], b), this.buildConvexHull([Te, be], b) ); return ot; } }; }(), L.MarkerCluster.include({ getConvexHull: function() { var b = this.getAllChildMarkers(), E = [], i, O; for (O = b.length - 1; O >= 0; O--) i = b[O].getLatLng(), E.push(i); return L.QuickHull.getConvexHull(E); } }), L.MarkerCluster.include({ _2PI: Math.PI * 2, _circleFootSeparation: 25, //related to circumference of circle _circleStartAngle: 0, _spiralFootSeparation: 28, //related to size of spiral (experiment!) _spiralLengthStart: 11, _spiralLengthFactor: 5, _circleSpiralSwitchover: 9, //show spiral instead of circle from this marker count upwards. // 0 -> always spiral; Infinity -> always circle spiderfy: function() { if (!(this._group._spiderfied === this || this._group._inZoomAnimation)) { var b = this.getAllChildMarkers(null, !0), E = this._group, i = E._map, O = i.latLngToLayerPoint(this._latlng), j; this._group._unspiderfy(), this._group._spiderfied = this, this._group.options.spiderfyShapePositions ? j = this._group.options.spiderfyShapePositions(b.length, O) : b.length >= this._circleSpiralSwitchover ? j = this._generatePointsSpiral(b.length, O) : (O.y += 10, j = this._generatePointsCircle(b.length, O)), this._animationSpiderfy(b, j); } }, unspiderfy: function(b) { this._group._inZoomAnimation || (this._animationUnspiderfy(b), this._group._spiderfied = null); }, _generatePointsCircle: function(b, E) { var i = this._group.options.spiderfyDistanceMultiplier * this._circleFootSeparation * (2 + b), O = i / this._2PI, j = this._2PI / b, Y = [], J, ae; for (O = Math.max(O, 35), Y.length = b, J = 0; J < b; J++) ae = this._circleStartAngle + J * j, Y[J] = new L.Point(E.x + O * Math.cos(ae), E.y + O * Math.sin(ae))._round(); return Y; }, _generatePointsSpiral: function(b, E) { var i = this._group.options.spiderfyDistanceMultiplier, O = i * this._spiralLengthStart, j = i * this._spiralFootSeparation, Y = i * this._spiralLengthFactor * this._2PI, J = 0, ae = [], ce; for (ae.length = b, ce = b; ce >= 0; ce--) ce < b && (ae[ce] = new L.Point(E.x + O * Math.cos(J), E.y + O * Math.sin(J))._round()), J += j / O + ce * 5e-4, O += Y / J; return ae; }, _noanimationUnspiderfy: function() { var b = this._group, E = b._map, i = b._featureGroup, O = this.getAllChildMarkers(null, !0), j, Y; for (b._ignoreMove = !0, this.setOpacity(1), Y = O.length - 1; Y >= 0; Y--) j = O[Y], i.removeLayer(j), j._preSpiderfyLatlng && (j.setLatLng(j._preSpiderfyLatlng), delete j._preSpiderfyLatlng), j.setZIndexOffset && j.setZIndexOffset(0), j._spiderLeg && (E.removeLayer(j._spiderLeg), delete j._spiderLeg); b.fire("unspiderfied", { cluster: this, markers: O }), b._ignoreMove = !1, b._spiderfied = null; } }), L.MarkerClusterNonAnimated = L.MarkerCluster.extend({ _animationSpiderfy: function(b, E) { var i = this._group, O = i._map, j = i._featureGroup, Y = this._group.options.spiderLegPolylineOptions, J, ae, ce, Te; for (i._ignoreMove = !0, J = 0; J < b.length; J++) Te = O.layerPointToLatLng(E[J]), ae = b[J], ce = new L.Polyline([this._latlng, Te], Y), O.addLayer(ce), ae._spiderLeg = ce, ae._preSpiderfyLatlng = ae._latlng, ae.setLatLng(Te), ae.setZIndexOffset && ae.setZIndexOffset(1e6), j.addLayer(ae); this.setOpacity(0.3), i._ignoreMove = !1, i.fire("spiderfied", { cluster: this, markers: b }); }, _animationUnspiderfy: function() { this._noanimationUnspiderfy(); } }), L.MarkerCluster.include({ _animationSpiderfy: function(b, E) { var i = this, O = this._group, j = O._map, Y = O._featureGroup, J = this._latlng, ae = j.latLngToLayerPoint(J), ce = L.Path.SVG, Te = L.extend({}, this._group.options.spiderLegPolylineOptions), be = Te.opacity, Ze, je, ot, vt, ht, gt; for (be === void 0 && (be = L.MarkerClusterGroup.prototype.options.spiderLegPolylineOptions.opacity), ce ? (Te.opacity = 0, Te.className = (Te.className || "") + " leaflet-cluster-spider-leg") : Te.opacity = be, O._ignoreMove = !0, Ze = 0; Ze < b.length; Ze++) je = b[Ze], gt = j.layerPointToLatLng(E[Ze]), ot = new L.Polyline([J, gt], Te), j.addLayer(ot), je._spiderLeg = ot, ce && (vt = ot._path, ht = vt.getTotalLength() + 0.1, vt.style.strokeDasharray = ht, vt.style.strokeDashoffset = ht), je.setZIndexOffset && je.setZIndexOffset(1e6), je.clusterHide && je.clusterHide(), Y.addLayer(je), je._setPos && je._setPos(ae); for (O._forceLayout(), O._animationStart(), Ze = b.length - 1; Ze >= 0; Ze--) gt = j.layerPointToLatLng(E[Ze]), je = b[Ze], je._preSpiderfyLatlng = je._latlng, je.setLatLng(gt), je.clusterShow && je.clusterShow(), ce && (ot = je._spiderLeg, vt = ot._path, vt.style.strokeDashoffset = 0, ot.setStyle({ opacity: be })); this.setOpacity(0.3), O._ignoreMove = !1, setTimeout(function() { O._animationEnd(), O.fire("spiderfied", { cluster: i, markers: b }); }, 200); }, _animationUnspiderfy: function(b) { var E = this, i = this._group, O = i._map, j = i._featureGroup, Y = b ? O._latLngToNewLayerPoint(this._latlng, b.zoom, b.center) : O.latLngToLayerPoint(this._latlng), J = this.getAllChildMarkers(null, !0), ae = L.Path.SVG, ce, Te, be, Ze, je, ot; for (i._ignoreMove = !0, i._animationStart(), this.setOpacity(1), Te = J.length - 1; Te >= 0; Te--) ce = J[Te], ce._preSpiderfyLatlng && (ce.closePopup(), ce.setLatLng(ce._preSpiderfyLatlng), delete ce._preSpiderfyLatlng, ot = !0, ce._setPos && (ce._setPos(Y), ot = !1), ce.clusterHide && (ce.clusterHide(), ot = !1), ot && j.removeLayer(ce), ae && (be = ce._spiderLeg, Ze = be._path, je = Ze.getTotalLength() + 0.1, Ze.style.strokeDashoffset = je, be.setStyle({ opacity: 0 }))); i._ignoreMove = !1, setTimeout(function() { var vt = 0; for (Te = J.length - 1; Te >= 0; Te--) ce = J[Te], ce._spiderLeg && vt++; for (Te = J.length - 1; Te >= 0; Te--) ce = J[Te], ce._spiderLeg && (ce.clusterShow && ce.clusterShow(), ce.setZIndexOffset && ce.setZIndexOffset(0), vt > 1 && j.removeLayer(ce), O.removeLayer(ce._spiderLeg), delete ce._spiderLeg); i._animationEnd(), i.fire("unspiderfied", { cluster: E, markers: J }); }, 200); } }), L.MarkerClusterGroup.include({ //The MarkerCluster currently spiderfied (if any) _spiderfied: null, unspiderfy: function() { this._unspiderfy.apply(this, arguments); }, _spiderfierOnAdd: function() { this._map.on("click", this._unspiderfyWrapper, this), this._map.options.zoomAnimation && this._map.on("zoomstart", this._unspiderfyZoomStart, this), this._map.on("zoomend", this._noanimationUnspiderfy, this), L.Browser.touch || this._map.getRenderer(this); }, _spiderfierOnRemove: function() { this._map.off("click", this._unspiderfyWrapper, this), this._map.off("zoomstart", this._unspiderfyZoomStart, this), this._map.off("zoomanim", this._unspiderfyZoomAnim, this), this._map.off("zoomend", this._noanimationUnspiderfy, this), this._noanimationUnspiderfy(); }, //On zoom start we add a zoomanim handler so that we are guaranteed to be last (after markers are animated) //This means we can define the animation they do rather than Markers doing an animation to their actual location _unspiderfyZoomStart: function() { this._map && this._map.on("zoomanim", this._unspiderfyZoomAnim, this); }, _unspiderfyZoomAnim: function(b) { L.DomUtil.hasClass(this._map._mapPane, "leaflet-touching") || (this._map.off("zoomanim", this._unspiderfyZoomAnim, this), this._unspiderfy(b)); }, _unspiderfyWrapper: function() { this._unspiderfy(); }, _unspiderfy: function(b) { this._spiderfied && this._spiderfied.unspiderfy(b); }, _noanimationUnspiderfy: function() { this._spiderfied && this._spiderfied._noanimationUnspiderfy(); }, //If the given layer is currently being spiderfied then we unspiderfy it so it isn't on the map anymore etc _unspiderfyLayer: function(b) { b._spiderLeg && (this._featureGroup.removeLayer(b), b.clusterShow && b.clusterShow(), b.setZIndexOffset && b.setZIndexOffset(0), this._map.removeLayer(b._spiderLeg), delete b._spiderLeg); } }), L.MarkerClusterGroup.include({ /** * Updates the icon of all clusters which are parents of the given marker(s). * In singleMarkerMode, also updates the given marker(s) icon. * @param layers L.MarkerClusterGroup|L.LayerGroup|Array(L.Marker)|Map(L.Marker)| * L.MarkerCluster|L.Marker (optional) list of markers (or single marker) whose parent * clusters need to be updated. If not provided, retrieves all child markers of this. * @returns {L.MarkerClusterGroup} */ refreshClusters: function(b) { return b ? b instanceof L.MarkerClusterGroup ? b = b._topClusterLevel.getAllChildMarkers() : b instanceof L.LayerGroup ? b = b._layers : b instanceof L.MarkerCluster ? b = b.getAllChildMarkers() : b instanceof L.Marker && (b = [b]) : b = this._topClusterLevel.getAllChildMarkers(), this._flagParentsIconsNeedUpdate(b), this._refreshClustersIcons(), this.options.singleMarkerMode && this._refreshSingleMarkerModeMarkers(b), this; }, /** * Simply flags all parent clusters of the given markers as having a "dirty" icon. * @param layers Array(L.Marker)|Map(L.Marker) list of markers. * @private */ _flagParentsIconsNeedUpdate: function(b) { var E, i; for (E in b) for (i = b[E].__parent; i; ) i._iconNeedsUpdate = !0, i = i.__parent; }, /** * Re-draws the icon of the supplied markers. * To be used in singleMarkerMode only. * @param layers Array(L.Marker)|Map(L.Marker) list of markers. * @private */ _refreshSingleMarkerModeMarkers: function(b) { var E, i; for (E in b) i = b[E], this.hasLayer(i) && i.setIcon(this._overrideMarkerIcon(i)); } }), L.Marker.include({ /** * Updates the given options in the marker's icon and refreshes the marker. * @param options map object of icon options. * @param directlyRefreshClusters boolean (optional) true to trigger * MCG.refreshClustersOf() right away with this single marker. * @returns {L.Marker} */ refreshIconOptions: function(b, E) { var i = this.options.icon; return L.setOptions(i, b), this.setIcon(i), E && this.__parent && this.__parent._group.refreshClusters(this), this; } }), d.MarkerClusterGroup = g, d.MarkerCluster = w, Object.defineProperty(d, "__esModule", { value: !0 }); }); })(gb, gb.exports); class CC { constructor() { this.Bounds = [], this.lng = null, this.map = null, this.EventSelectChart = null, this.Polylines = [], this.CurrentPositionMarker = null, this.CurrentGPSPositionMarker = null; } init(a, d, g, w, b) { this.map = wn.map( a, { scrollWheelZoom: g } ); var E = new wn.Control.FullScreen(); this.map.addControl(E), wn.tileLayer("https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png", { attribution: 'Data © OpenStreetMap contributors' }).addTo(this.map); var i = (w + "").length > 0, O = {}, j = {}; switch (i ? O["Thunderforest - Cycle"] = wn.tileLayer("https://a.tile.thunderforest.com/cycle/{z}/{x}/{y}.png?apikey=" + w, { maxZoom: 18, attribution: 'Maps © Thunderforest contributors, CC-BY-SA, Imagery © Mapbox' }) : O["Open Cycle Map"] = wn.tileLayer("http://a.tile.opencyclemap.org/cycle/{z}/{x}/{y}.png", { maxZoom: 18, attribution: 'Maps © Thunderforest contributors, CC-BY-SA, Imagery © Mapbox' }), O["Thunderforest - Outdoors"] = wn.tileLayer("https://a.tile.thunderforest.com/outddors/{z}/{x}/{y}.png?apikey=" + w, { maxZoom: 18, attribution: 'Maps © Thunderforest contributors, CC-BY-SA, Imagery © Mapbox' }), O["Thunderforest - Transport"] = wn.tileLayer("https://a.tile.thunderforest.com/transport/{z}/{x}/{y}.png?apikey=" + w, { maxZoom: 18, attribution: 'Maps © Thunderforest contributors, CC-BY-SA, Imagery © Mapbox' }), O["Thunderforest - Landscape"] = wn.tileLayer("https://a.tile.thunderforest.com/landscape/{z}/{x}/{y}.png?apikey=" + w, { maxZoom: 18, attribution: 'Maps © Thunderforest contributors, CC-BY-SA, Imagery © Mapbox' }), O["Open Street Map"] = wn.tileLayer("https://tile.openstreetmap.org/{z}/{x}/{y}.png", { maxZoom: 18, attribution: 'Maps © OpenStreetMap contributors, CC-BY-SA, Imagery © Mapbox' }), O["Humanitarian Map Style"] = wn.tileLayer("https://a.tile.openstreetmap.fr/hot/{z}/{x}/{y}.png", { maxZoom: 18, attribution: 'Maps © OpenStreetMap contributors, CC-BY-SA, Imagery © Mapbox' }), O["Hike & Bike"] = wn.tileLayer("http://toolserver.org/tiles/hikebike/{z}/{x}/{y}.png", { maxZoom: 18, attribution: 'Maps © Hike & Bike Map contributors, CC-BY-SA, Imagery © Mapbox' }), O["Open Sea Map"] = wn.tileLayer("http://tiles.openseamap.org/seamark/{z}/{x}/{y}.png", { maxZoom: 18, attribution: 'Maps © OpenSeaMap contributors, CC-BY-SA, Imagery © Mapbox' }), O["GSI Map (Japan)"] = wn.tileLayer("https://cyberjapandata.gsi.go.jp/xyz/std/{z}/{x}/{y}.png", { maxZoom: 18, attribution: '© 国土地理院, Imagery © Mapbox' }), d) { case "OSM1": { O["Open Street Map"].addTo(this.map); break; } case "OSM2": { O["Thunderforest - Cycle"].addTo(this.map); break; } case "OSM3": { O["Thunderforest - Outdoors"].addTo(this.map); break; } case "OSM4": { O["Thunderforest - Transport"].addTo(this.map); break; } case "OSM5": { O["Thunderforest - Landscape"].addTo(this.map); break; } case "OSM7": { O["Humanitarian Map Style"].addTo(this.map); break; } case "OSM9": { O["Hike & Bike"].addTo(this.map); break; } case "OSM10": { O["Open Sea Map"].addTo(this.map); break; } case "OSM11": { O["GSI Map (Japan)"].addTo(this.map); break; } default: O["Open Street Map"].addTo(this.map); } wn.control.layers(O, j).addTo(this.map); } AppPolylines(a, d, g, w, b) { var Y; if (this.map != null) { var E = Zm.Utils.GetItemFromArray(a, 0); if (E != null) { (g == "" || g == null) && (g = "https://maps.google.com/mapfiles/kml/pal4/icon25.png"); var i = wn.marker(wn.latLng(E), { icon: wn.icon({ iconUrl: g, iconSize: [32, 32], // Size of the icon. iconAnchor: [16, 16] // Point of the icon which will correspond to marker's location. }), title: (Y = this.lng) == null ? void 0 : Y.currentPosition }); i.addTo(this.map), this.CurrentPositionMarker = i; var O = Zm.Utils.DividePolylinesPoints(a); this.lng, this.EventSelectChart, this.Bounds = a.filter((J) => J != null), this.CenterMap(); for (let J = 0; J < O.length; J++) { let ae = ""; J < d.length ? ae = d[J] : ae = d[d.length - 1]; try { let ce = wn.polyline(O[J], { color: ae }).addTo(this.map); this.Polylines.push(ce); let Te = this; this.Polylines[J].on("mousemove", function(be) { Te.MoveMarkerToPosition([be.latlng.lat, be.latlng.lng], !0); }); } catch { } } if (w != "") { let J = a[0]; J != null && wn.marker(wn.latLng(J), { icon: wn.icon({ iconUrl: w + "", iconSize: [32, 32], // Size of the icon. iconAnchor: [16, 16] // Point of the icon which will correspond to marker's location. }), title: "Start" }).addTo(this.map); } if (b != "" && a[a.length - 1] != null) { let J = a[a.length - 1]; if (J != null) { var j = wn.marker(wn.latLng(J), { icon: wn.icon({ iconUrl: b + "", iconSize: [32, 32], // size of the icon iconAnchor: [16, 16] // point of the icon which will correspond to marker's location }), title: "End" }); j.addTo(this.map); } } } } } SetCurrentGPSPosition(a, d, g) { this.CurrentGPSPositionMarker == null ? (d == "" && (d = "https://maps.google.com/mapfiles/kml/pal4/icon25.png"), this.map != null && (this.CurrentGPSPositionMarker = wn.marker(a, { icon: wn.icon({ iconUrl: d, iconSize: [32, 32], // Size of the icon. iconAnchor: [16, 16] // Point of the icon which will correspond to marker's location. }) }).addTo(this.map).bindPopup(g.currentPosition).openPopup())) : this.CurrentGPSPositionMarker.setLatLng(a), this.Bounds.push(a), this.CenterMap(); } AddWaypoints(a, d) { var g = wn.icon({ iconUrl: "https://maps.google.com/mapfiles/ms/micons/flag.png", iconSize: [32, 32], // Size of the icon. iconAnchor: [16, 16] // Point of the icon which will correspond to marker's location. }); d != "" && (g = wn.icon({ iconUrl: "waypointIcon", iconSize: [32, 32], // Size of the icon. iconAnchor: [16, 16] // Point of the icon which will correspond to marker's location. })); for (let j = 0; j < a.length; j++) { var w = a[j]; this.Bounds.push([w.lat, w.lon]); var b = w.lat, E = w.lon; w.sym, w.type, w.img && (g.iconUrl = w.img + ""); var i = wn.marker([b, E], { icon: g }), O = ""; w.name == "" ? O = "
" + unescape(w.desc) + "
" : O = "
" + w.name + "
" + unescape(w.desc) + "
", O += "

Itinéraire

", this.map != null && i.addTo(this.map).bindPopup(O); } this.CenterMap(); } MoveMarkerToPosition(a, d) { this.CurrentPositionMarker != null && (this.CurrentPositionMarker.setLatLng(a), this.lng && this.CurrentPositionMarker.setTooltipContent(this.lng.currentPosition), d == !0 && this.EventSelectChart && this.EventSelectChart(a)); } CenterMap() { var g; try { if (this.Bounds && this.Bounds.length > 0) { let w = { minLat: Number.POSITIVE_INFINITY, maxLat: Number.NEGATIVE_INFINITY, minLng: Number.POSITIVE_INFINITY, maxLng: Number.NEGATIVE_INFINITY }; this.Bounds.forEach((b) => { if (!Array.isArray(b) || b.length !== 2) throw new Error("Each coordinate must be an array with [latitude, longitude]."); const [E, i] = b; w.minLat = Math.min(w.minLat, E), w.maxLat = Math.max(w.maxLat, E), w.minLng = Math.min(w.minLng, i), w.maxLng = Math.max(w.maxLng, i); }); var a = new wn.LatLng(w.minLat, w.minLng), d = new wn.LatLng(w.maxLat, w.maxLng); (g = this.map) == null || g.fitBounds(new wn.LatLngBounds(a, d)); } } catch (w) { console.log(w); } } AddPhotos(a) { for (const d of a) { let g = wn.marker(d, { icon: wn.divIcon( wn.extend( { html: '
', className: "leaflet-marker-photo" }, d, { iconSize: [40, 40] } ) ), title: d.caption || "" }); g.bindPopup('

' + d.name + "

", { minWidth: 500 }), g.addTo(this.map); } } } var xw = {}; Object.defineProperty(xw, "__esModule", { value: !0 }); class Ju { constructor(a, d) { this.styles = a || Ju.DEFAULT_STYLES; const g = typeof d == "string" ? d : d ? d.defaultStyle : void 0; this.defaultStyle = g || Ju.DEFAULT_STYLE, this.onDocumentClick = this.onDocumentClick.bind(this), this.events = typeof d != "string" && d ? d.eventListeners : void 0; } getDefaultPosition() { return "top-right"; } onAdd(a) { this.map = a, this.controlContainer = document.createElement("div"), this.controlContainer.classList.add("mapboxgl-ctrl"), this.controlContainer.classList.add("mapboxgl-ctrl-group"), this.mapStyleContainer = document.createElement("div"), this.styleButton = document.createElement("button"), this.styleButton.type = "button", this.mapStyleContainer.classList.add("mapboxgl-style-list"); for (const d of this.styles) { const g = document.createElement("button"); g.type = "button", g.innerText = d.title, g.classList.add(d.title.replace(/[^a-z0-9-]/gi, "_")), g.dataset.uri = JSON.stringify(d.uri), g.addEventListener("click", (w) => { const b = w.srcElement; if (this.closeModal(), b.classList.contains("active") || this.events && this.events.onOpen && this.events.onOpen(w)) return; const E = JSON.parse(b.dataset.uri); this.map.setStyle(E); const i = this.mapStyleContainer.getElementsByClassName("active"); for (; i[0]; ) i[0].classList.remove("active"); b.classList.add("active"), this.events && this.events.onChange && this.events.onChange(w, E); }), d.title === this.defaultStyle && g.classList.add("active"), this.mapStyleContainer.appendChild(g); } return this.styleButton.classList.add("mapboxgl-ctrl-icon"), this.styleButton.classList.add("mapboxgl-style-switcher"), this.styleButton.addEventListener("click", (d) => { this.events && this.events.onSelect && this.events.onSelect(d) || this.openModal(); }), document.addEventListener("click", this.onDocumentClick), this.controlContainer.appendChild(this.styleButton), this.controlContainer.appendChild(this.mapStyleContainer), this.controlContainer; } onRemove() { !this.controlContainer || !this.controlContainer.parentNode || !this.map || !this.styleButton || (this.styleButton.removeEventListener("click", this.onDocumentClick), this.controlContainer.parentNode.removeChild(this.controlContainer), document.removeEventListener("click", this.onDocumentClick), this.map = void 0); } closeModal() { this.mapStyleContainer && this.styleButton && (this.mapStyleContainer.style.display = "none", this.styleButton.style.display = "block"); } openModal() { this.mapStyleContainer && this.styleButton && (this.mapStyleContainer.style.display = "block", this.styleButton.style.display = "none"); } onDocumentClick(a) { this.controlContainer && !this.controlContainer.contains(a.target) && this.closeModal(); } } Ju.DEFAULT_STYLE = "Streets"; Ju.DEFAULT_STYLES = [ { title: "Dark", uri: "mapbox://styles/mapbox/dark-v10" }, { title: "Light", uri: "mapbox://styles/mapbox/light-v10" }, { title: "Outdoors", uri: "mapbox://styles/mapbox/outdoors-v11" }, { title: "Satellite", uri: "mapbox://styles/mapbox/satellite-streets-v11" }, { title: "Streets", uri: "mapbox://styles/mapbox/streets-v11" } ]; var IC = xw.MapboxStyleSwitcherControl = Ju, vw = { exports: {} }; (function(m, a) { (function(d, g) { m.exports = g(); })(Km, function() { var d, g, w; function b(i, O) { if (!d) d = O; else if (!g) g = O; else { var j = "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 = {}; (" + d + ")(sharedChunk); (" + g + ")(sharedChunk); self.onerror = null;", Y = {}; d(Y), w = O(Y), typeof window < "u" && window && window.URL && window.URL.createObjectURL && (w.workerUrl = window.URL.createObjectURL(new Blob([j], { type: "text/javascript" }))); } } b(["exports"], function(i) { function O(r) { return r && r.__esModule && Object.prototype.hasOwnProperty.call(r, "default") ? r.default : r; } var j, Y = {}, J = {}; function ae() { if (j) return J; j = 1, Object.defineProperty(J, "__esModule", { value: !0 }), J.setMatrixArrayType = function(u) { J.ARRAY_TYPE = e = u; }, J.toRadian = function(u) { return u * o; }, J.equals = function(u, l) { return Math.abs(u - l) <= r * Math.max(1, Math.abs(u), Math.abs(l)); }, J.RANDOM = J.ARRAY_TYPE = J.EPSILON = void 0; var r = 1e-6; J.EPSILON = r; var e = typeof Float32Array < "u" ? Float32Array : Array; J.ARRAY_TYPE = e; var n = Math.random; J.RANDOM = n; var o = Math.PI / 180; return Math.hypot || (Math.hypot = function() { for (var u = 0, l = arguments.length; l--; ) u += arguments[l] * arguments[l]; return Math.sqrt(u); }), J; } var ce, Te = {}; function be() { if (ce) return Te; function r(l) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(f) { return typeof f; } : function(f) { return f && typeof Symbol == "function" && f.constructor === Symbol && f !== Symbol.prototype ? "symbol" : typeof f; }, r(l); } ce = 1, Object.defineProperty(Te, "__esModule", { value: !0 }), Te.create = function() { var l = new e.ARRAY_TYPE(4); return e.ARRAY_TYPE != Float32Array && (l[1] = 0, l[2] = 0), l[0] = 1, l[3] = 1, l; }, Te.clone = function(l) { var f = new e.ARRAY_TYPE(4); return f[0] = l[0], f[1] = l[1], f[2] = l[2], f[3] = l[3], f; }, Te.copy = function(l, f) { return l[0] = f[0], l[1] = f[1], l[2] = f[2], l[3] = f[3], l; }, Te.identity = function(l) { return l[0] = 1, l[1] = 0, l[2] = 0, l[3] = 1, l; }, Te.fromValues = function(l, f, v, S) { var D = new e.ARRAY_TYPE(4); return D[0] = l, D[1] = f, D[2] = v, D[3] = S, D; }, Te.set = function(l, f, v, S, D) { return l[0] = f, l[1] = v, l[2] = S, l[3] = D, l; }, Te.transpose = function(l, f) { if (l === f) { var v = f[1]; l[1] = f[2], l[2] = v; } else l[0] = f[0], l[1] = f[2], l[2] = f[1], l[3] = f[3]; return l; }, Te.invert = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = v * x - D * S; return P ? (l[0] = x * (P = 1 / P), l[1] = -S * P, l[2] = -D * P, l[3] = v * P, l) : null; }, Te.adjoint = function(l, f) { var v = f[0]; return l[0] = f[3], l[1] = -f[1], l[2] = -f[2], l[3] = v, l; }, Te.determinant = function(l) { return l[0] * l[3] - l[2] * l[1]; }, Te.multiply = o, Te.rotate = function(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = Math.sin(v), M = Math.cos(v); return l[0] = S * M + x * I, l[1] = D * M + P * I, l[2] = S * -I + x * M, l[3] = D * -I + P * M, l; }, Te.scale = function(l, f, v) { var S = f[1], D = f[2], x = f[3], P = v[0], I = v[1]; return l[0] = f[0] * P, l[1] = S * P, l[2] = D * I, l[3] = x * I, l; }, Te.fromRotation = function(l, f) { var v = Math.sin(f), S = Math.cos(f); return l[0] = S, l[1] = v, l[2] = -v, l[3] = S, l; }, Te.fromScaling = function(l, f) { return l[0] = f[0], l[1] = 0, l[2] = 0, l[3] = f[1], l; }, Te.str = function(l) { return "mat2(" + l[0] + ", " + l[1] + ", " + l[2] + ", " + l[3] + ")"; }, Te.frob = function(l) { return Math.hypot(l[0], l[1], l[2], l[3]); }, Te.LDU = function(l, f, v, S) { return l[2] = S[2] / S[0], v[0] = S[0], v[1] = S[1], v[3] = S[3] - l[2] * v[1], [l, f, v]; }, Te.add = function(l, f, v) { return l[0] = f[0] + v[0], l[1] = f[1] + v[1], l[2] = f[2] + v[2], l[3] = f[3] + v[3], l; }, Te.subtract = u, Te.exactEquals = function(l, f) { return l[0] === f[0] && l[1] === f[1] && l[2] === f[2] && l[3] === f[3]; }, Te.equals = function(l, f) { var v = l[0], S = l[1], D = l[2], x = l[3], P = f[0], I = f[1], M = f[2], C = f[3]; return Math.abs(v - P) <= e.EPSILON * Math.max(1, Math.abs(v), Math.abs(P)) && Math.abs(S - I) <= e.EPSILON * Math.max(1, Math.abs(S), Math.abs(I)) && Math.abs(D - M) <= e.EPSILON * Math.max(1, Math.abs(D), Math.abs(M)) && Math.abs(x - C) <= e.EPSILON * Math.max(1, Math.abs(x), Math.abs(C)); }, Te.multiplyScalar = function(l, f, v) { return l[0] = f[0] * v, l[1] = f[1] * v, l[2] = f[2] * v, l[3] = f[3] * v, l; }, Te.multiplyScalarAndAdd = function(l, f, v, S) { return l[0] = f[0] + v[0] * S, l[1] = f[1] + v[1] * S, l[2] = f[2] + v[2] * S, l[3] = f[3] + v[3] * S, l; }, Te.sub = Te.mul = void 0; var e = function(l, f) { if (l && l.__esModule) return l; if (l === null || r(l) !== "object" && typeof l != "function") return { default: l }; var v = n(void 0); if (v && v.has(l)) return v.get(l); var S = {}, D = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var x in l) if (x !== "default" && Object.prototype.hasOwnProperty.call(l, x)) { var P = D ? Object.getOwnPropertyDescriptor(l, x) : null; P && (P.get || P.set) ? Object.defineProperty(S, x, P) : S[x] = l[x]; } return S.default = l, v && v.set(l, S), S; }(ae()); function n(l) { if (typeof WeakMap != "function") return null; var f = /* @__PURE__ */ new WeakMap(), v = /* @__PURE__ */ new WeakMap(); return (n = function(S) { return S ? v : f; })(l); } function o(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = v[0], M = v[1], C = v[2], k = v[3]; return l[0] = S * I + x * M, l[1] = D * I + P * M, l[2] = S * C + x * k, l[3] = D * C + P * k, l; } function u(l, f, v) { return l[0] = f[0] - v[0], l[1] = f[1] - v[1], l[2] = f[2] - v[2], l[3] = f[3] - v[3], l; } return Te.mul = o, Te.sub = u, Te; } var Ze, je = {}; function ot() { if (Ze) return je; function r(l) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(f) { return typeof f; } : function(f) { return f && typeof Symbol == "function" && f.constructor === Symbol && f !== Symbol.prototype ? "symbol" : typeof f; }, r(l); } Ze = 1, Object.defineProperty(je, "__esModule", { value: !0 }), je.create = function() { var l = new e.ARRAY_TYPE(6); return e.ARRAY_TYPE != Float32Array && (l[1] = 0, l[2] = 0, l[4] = 0, l[5] = 0), l[0] = 1, l[3] = 1, l; }, je.clone = function(l) { var f = new e.ARRAY_TYPE(6); return f[0] = l[0], f[1] = l[1], f[2] = l[2], f[3] = l[3], f[4] = l[4], f[5] = l[5], f; }, je.copy = function(l, f) { return l[0] = f[0], l[1] = f[1], l[2] = f[2], l[3] = f[3], l[4] = f[4], l[5] = f[5], l; }, je.identity = function(l) { return l[0] = 1, l[1] = 0, l[2] = 0, l[3] = 1, l[4] = 0, l[5] = 0, l; }, je.fromValues = function(l, f, v, S, D, x) { var P = new e.ARRAY_TYPE(6); return P[0] = l, P[1] = f, P[2] = v, P[3] = S, P[4] = D, P[5] = x, P; }, je.set = function(l, f, v, S, D, x, P) { return l[0] = f, l[1] = v, l[2] = S, l[3] = D, l[4] = x, l[5] = P, l; }, je.invert = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = f[4], I = f[5], M = v * x - S * D; return M ? (l[0] = x * (M = 1 / M), l[1] = -S * M, l[2] = -D * M, l[3] = v * M, l[4] = (D * I - x * P) * M, l[5] = (S * P - v * I) * M, l) : null; }, je.determinant = function(l) { return l[0] * l[3] - l[1] * l[2]; }, je.multiply = o, je.rotate = function(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = Math.sin(v), k = Math.cos(v); return l[0] = S * k + x * C, l[1] = D * k + P * C, l[2] = S * -C + x * k, l[3] = D * -C + P * k, l[4] = I, l[5] = M, l; }, je.scale = function(l, f, v) { var S = f[1], D = f[2], x = f[3], P = f[4], I = f[5], M = v[0], C = v[1]; return l[0] = f[0] * M, l[1] = S * M, l[2] = D * C, l[3] = x * C, l[4] = P, l[5] = I, l; }, je.translate = function(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = v[0], k = v[1]; return l[0] = S, l[1] = D, l[2] = x, l[3] = P, l[4] = S * C + x * k + I, l[5] = D * C + P * k + M, l; }, je.fromRotation = function(l, f) { var v = Math.sin(f), S = Math.cos(f); return l[0] = S, l[1] = v, l[2] = -v, l[3] = S, l[4] = 0, l[5] = 0, l; }, je.fromScaling = function(l, f) { return l[0] = f[0], l[1] = 0, l[2] = 0, l[3] = f[1], l[4] = 0, l[5] = 0, l; }, je.fromTranslation = function(l, f) { return l[0] = 1, l[1] = 0, l[2] = 0, l[3] = 1, l[4] = f[0], l[5] = f[1], l; }, je.str = function(l) { return "mat2d(" + l[0] + ", " + l[1] + ", " + l[2] + ", " + l[3] + ", " + l[4] + ", " + l[5] + ")"; }, je.frob = function(l) { return Math.hypot(l[0], l[1], l[2], l[3], l[4], l[5], 1); }, je.add = function(l, f, v) { return l[0] = f[0] + v[0], l[1] = f[1] + v[1], l[2] = f[2] + v[2], l[3] = f[3] + v[3], l[4] = f[4] + v[4], l[5] = f[5] + v[5], l; }, je.subtract = u, je.multiplyScalar = function(l, f, v) { return l[0] = f[0] * v, l[1] = f[1] * v, l[2] = f[2] * v, l[3] = f[3] * v, l[4] = f[4] * v, l[5] = f[5] * v, l; }, je.multiplyScalarAndAdd = function(l, f, v, S) { return l[0] = f[0] + v[0] * S, l[1] = f[1] + v[1] * S, l[2] = f[2] + v[2] * S, l[3] = f[3] + v[3] * S, l[4] = f[4] + v[4] * S, l[5] = f[5] + v[5] * S, l; }, je.exactEquals = function(l, f) { return l[0] === f[0] && l[1] === f[1] && l[2] === f[2] && l[3] === f[3] && l[4] === f[4] && l[5] === f[5]; }, je.equals = function(l, f) { var v = l[0], S = l[1], D = l[2], x = l[3], P = l[4], I = l[5], M = f[0], C = f[1], k = f[2], V = f[3], U = f[4], q = f[5]; return Math.abs(v - M) <= e.EPSILON * Math.max(1, Math.abs(v), Math.abs(M)) && Math.abs(S - C) <= e.EPSILON * Math.max(1, Math.abs(S), Math.abs(C)) && Math.abs(D - k) <= e.EPSILON * Math.max(1, Math.abs(D), Math.abs(k)) && Math.abs(x - V) <= e.EPSILON * Math.max(1, Math.abs(x), Math.abs(V)) && Math.abs(P - U) <= e.EPSILON * Math.max(1, Math.abs(P), Math.abs(U)) && Math.abs(I - q) <= e.EPSILON * Math.max(1, Math.abs(I), Math.abs(q)); }, je.sub = je.mul = void 0; var e = function(l, f) { if (l && l.__esModule) return l; if (l === null || r(l) !== "object" && typeof l != "function") return { default: l }; var v = n(void 0); if (v && v.has(l)) return v.get(l); var S = {}, D = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var x in l) if (x !== "default" && Object.prototype.hasOwnProperty.call(l, x)) { var P = D ? Object.getOwnPropertyDescriptor(l, x) : null; P && (P.get || P.set) ? Object.defineProperty(S, x, P) : S[x] = l[x]; } return S.default = l, v && v.set(l, S), S; }(ae()); function n(l) { if (typeof WeakMap != "function") return null; var f = /* @__PURE__ */ new WeakMap(), v = /* @__PURE__ */ new WeakMap(); return (n = function(S) { return S ? v : f; })(l); } function o(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = v[0], k = v[1], V = v[2], U = v[3], q = v[4], $ = v[5]; return l[0] = S * C + x * k, l[1] = D * C + P * k, l[2] = S * V + x * U, l[3] = D * V + P * U, l[4] = S * q + x * $ + I, l[5] = D * q + P * $ + M, l; } function u(l, f, v) { return l[0] = f[0] - v[0], l[1] = f[1] - v[1], l[2] = f[2] - v[2], l[3] = f[3] - v[3], l[4] = f[4] - v[4], l[5] = f[5] - v[5], l; } return je.mul = o, je.sub = u, je; } var vt, ht = {}; function gt() { if (vt) return ht; function r(l) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(f) { return typeof f; } : function(f) { return f && typeof Symbol == "function" && f.constructor === Symbol && f !== Symbol.prototype ? "symbol" : typeof f; }, r(l); } vt = 1, Object.defineProperty(ht, "__esModule", { value: !0 }), ht.create = function() { var l = new e.ARRAY_TYPE(9); return e.ARRAY_TYPE != Float32Array && (l[1] = 0, l[2] = 0, l[3] = 0, l[5] = 0, l[6] = 0, l[7] = 0), l[0] = 1, l[4] = 1, l[8] = 1, l; }, ht.fromMat4 = function(l, f) { return l[0] = f[0], l[1] = f[1], l[2] = f[2], l[3] = f[4], l[4] = f[5], l[5] = f[6], l[6] = f[8], l[7] = f[9], l[8] = f[10], l; }, ht.clone = function(l) { var f = new e.ARRAY_TYPE(9); return f[0] = l[0], f[1] = l[1], f[2] = l[2], f[3] = l[3], f[4] = l[4], f[5] = l[5], f[6] = l[6], f[7] = l[7], f[8] = l[8], f; }, ht.copy = function(l, f) { return l[0] = f[0], l[1] = f[1], l[2] = f[2], l[3] = f[3], l[4] = f[4], l[5] = f[5], l[6] = f[6], l[7] = f[7], l[8] = f[8], l; }, ht.fromValues = function(l, f, v, S, D, x, P, I, M) { var C = new e.ARRAY_TYPE(9); return C[0] = l, C[1] = f, C[2] = v, C[3] = S, C[4] = D, C[5] = x, C[6] = P, C[7] = I, C[8] = M, C; }, ht.set = function(l, f, v, S, D, x, P, I, M, C) { return l[0] = f, l[1] = v, l[2] = S, l[3] = D, l[4] = x, l[5] = P, l[6] = I, l[7] = M, l[8] = C, l; }, ht.identity = function(l) { return l[0] = 1, l[1] = 0, l[2] = 0, l[3] = 0, l[4] = 1, l[5] = 0, l[6] = 0, l[7] = 0, l[8] = 1, l; }, ht.transpose = function(l, f) { if (l === f) { var v = f[1], S = f[2], D = f[5]; l[1] = f[3], l[2] = f[6], l[3] = v, l[5] = f[7], l[6] = S, l[7] = D; } else l[0] = f[0], l[1] = f[3], l[2] = f[6], l[3] = f[1], l[4] = f[4], l[5] = f[7], l[6] = f[2], l[7] = f[5], l[8] = f[8]; return l; }, ht.invert = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = f[4], I = f[5], M = f[6], C = f[7], k = f[8], V = k * P - I * C, U = -k * x + I * M, q = C * x - P * M, $ = v * V + S * U + D * q; return $ ? (l[0] = V * ($ = 1 / $), l[1] = (-k * S + D * C) * $, l[2] = (I * S - D * P) * $, l[3] = U * $, l[4] = (k * v - D * M) * $, l[5] = (-I * v + D * x) * $, l[6] = q * $, l[7] = (-C * v + S * M) * $, l[8] = (P * v - S * x) * $, l) : null; }, ht.adjoint = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = f[4], I = f[5], M = f[6], C = f[7], k = f[8]; return l[0] = P * k - I * C, l[1] = D * C - S * k, l[2] = S * I - D * P, l[3] = I * M - x * k, l[4] = v * k - D * M, l[5] = D * x - v * I, l[6] = x * C - P * M, l[7] = S * M - v * C, l[8] = v * P - S * x, l; }, ht.determinant = function(l) { var f = l[3], v = l[4], S = l[5], D = l[6], x = l[7], P = l[8]; return l[0] * (P * v - S * x) + l[1] * (-P * f + S * D) + l[2] * (x * f - v * D); }, ht.multiply = o, ht.translate = function(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = f[6], k = f[7], V = f[8], U = v[0], q = v[1]; return l[0] = S, l[1] = D, l[2] = x, l[3] = P, l[4] = I, l[5] = M, l[6] = U * S + q * P + C, l[7] = U * D + q * I + k, l[8] = U * x + q * M + V, l; }, ht.rotate = function(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = f[6], k = f[7], V = f[8], U = Math.sin(v), q = Math.cos(v); return l[0] = q * S + U * P, l[1] = q * D + U * I, l[2] = q * x + U * M, l[3] = q * P - U * S, l[4] = q * I - U * D, l[5] = q * M - U * x, l[6] = C, l[7] = k, l[8] = V, l; }, ht.scale = function(l, f, v) { var S = v[0], D = v[1]; return l[0] = S * f[0], l[1] = S * f[1], l[2] = S * f[2], l[3] = D * f[3], l[4] = D * f[4], l[5] = D * f[5], l[6] = f[6], l[7] = f[7], l[8] = f[8], l; }, ht.fromTranslation = function(l, f) { return l[0] = 1, l[1] = 0, l[2] = 0, l[3] = 0, l[4] = 1, l[5] = 0, l[6] = f[0], l[7] = f[1], l[8] = 1, l; }, ht.fromRotation = function(l, f) { var v = Math.sin(f), S = Math.cos(f); return l[0] = S, l[1] = v, l[2] = 0, l[3] = -v, l[4] = S, l[5] = 0, l[6] = 0, l[7] = 0, l[8] = 1, l; }, ht.fromScaling = function(l, f) { return l[0] = f[0], l[1] = 0, l[2] = 0, l[3] = 0, l[4] = f[1], l[5] = 0, l[6] = 0, l[7] = 0, l[8] = 1, l; }, ht.fromMat2d = function(l, f) { return l[0] = f[0], l[1] = f[1], l[2] = 0, l[3] = f[2], l[4] = f[3], l[5] = 0, l[6] = f[4], l[7] = f[5], l[8] = 1, l; }, ht.fromQuat = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = v + v, I = S + S, M = D + D, C = v * P, k = S * P, V = S * I, U = D * P, q = D * I, $ = D * M, H = x * P, K = x * I, Q = x * M; return l[0] = 1 - V - $, l[3] = k - Q, l[6] = U + K, l[1] = k + Q, l[4] = 1 - C - $, l[7] = q - H, l[2] = U - K, l[5] = q + H, l[8] = 1 - C - V, l; }, ht.normalFromMat4 = function(l, f) { var v = f[0], S = f[1], D = f[2], x = f[3], P = f[4], I = f[5], M = f[6], C = f[7], k = f[8], V = f[9], U = f[10], q = f[11], $ = f[12], H = f[13], K = f[14], Q = f[15], ie = v * I - S * P, fe = v * M - D * P, de = v * C - x * P, ue = S * M - D * I, Se = S * C - x * I, me = D * C - x * M, Ee = k * H - V * $, ze = k * K - U * $, Ie = k * Q - q * $, Re = V * K - U * H, Ve = V * Q - q * H, Ue = U * Q - q * K, Fe = ie * Ue - fe * Ve + de * Re + ue * Ie - Se * ze + me * Ee; return Fe ? (l[0] = (I * Ue - M * Ve + C * Re) * (Fe = 1 / Fe), l[1] = (M * Ie - P * Ue - C * ze) * Fe, l[2] = (P * Ve - I * Ie + C * Ee) * Fe, l[3] = (D * Ve - S * Ue - x * Re) * Fe, l[4] = (v * Ue - D * Ie + x * ze) * Fe, l[5] = (S * Ie - v * Ve - x * Ee) * Fe, l[6] = (H * me - K * Se + Q * ue) * Fe, l[7] = (K * de - $ * me - Q * fe) * Fe, l[8] = ($ * Se - H * de + Q * ie) * Fe, l) : null; }, ht.projection = function(l, f, v) { return l[0] = 2 / f, l[1] = 0, l[2] = 0, l[3] = 0, l[4] = -2 / v, l[5] = 0, l[6] = -1, l[7] = 1, l[8] = 1, l; }, ht.str = function(l) { return "mat3(" + l[0] + ", " + l[1] + ", " + l[2] + ", " + l[3] + ", " + l[4] + ", " + l[5] + ", " + l[6] + ", " + l[7] + ", " + l[8] + ")"; }, ht.frob = function(l) { return Math.hypot(l[0], l[1], l[2], l[3], l[4], l[5], l[6], l[7], l[8]); }, ht.add = function(l, f, v) { return l[0] = f[0] + v[0], l[1] = f[1] + v[1], l[2] = f[2] + v[2], l[3] = f[3] + v[3], l[4] = f[4] + v[4], l[5] = f[5] + v[5], l[6] = f[6] + v[6], l[7] = f[7] + v[7], l[8] = f[8] + v[8], l; }, ht.subtract = u, ht.multiplyScalar = function(l, f, v) { return l[0] = f[0] * v, l[1] = f[1] * v, l[2] = f[2] * v, l[3] = f[3] * v, l[4] = f[4] * v, l[5] = f[5] * v, l[6] = f[6] * v, l[7] = f[7] * v, l[8] = f[8] * v, l; }, ht.multiplyScalarAndAdd = function(l, f, v, S) { return l[0] = f[0] + v[0] * S, l[1] = f[1] + v[1] * S, l[2] = f[2] + v[2] * S, l[3] = f[3] + v[3] * S, l[4] = f[4] + v[4] * S, l[5] = f[5] + v[5] * S, l[6] = f[6] + v[6] * S, l[7] = f[7] + v[7] * S, l[8] = f[8] + v[8] * S, l; }, ht.exactEquals = function(l, f) { return l[0] === f[0] && l[1] === f[1] && l[2] === f[2] && l[3] === f[3] && l[4] === f[4] && l[5] === f[5] && l[6] === f[6] && l[7] === f[7] && l[8] === f[8]; }, ht.equals = function(l, f) { var v = l[0], S = l[1], D = l[2], x = l[3], P = l[4], I = l[5], M = l[6], C = l[7], k = l[8], V = f[0], U = f[1], q = f[2], $ = f[3], H = f[4], K = f[5], Q = f[6], ie = f[7], fe = f[8]; return Math.abs(v - V) <= e.EPSILON * Math.max(1, Math.abs(v), Math.abs(V)) && Math.abs(S - U) <= e.EPSILON * Math.max(1, Math.abs(S), Math.abs(U)) && Math.abs(D - q) <= e.EPSILON * Math.max(1, Math.abs(D), Math.abs(q)) && Math.abs(x - $) <= e.EPSILON * Math.max(1, Math.abs(x), Math.abs($)) && Math.abs(P - H) <= e.EPSILON * Math.max(1, Math.abs(P), Math.abs(H)) && Math.abs(I - K) <= e.EPSILON * Math.max(1, Math.abs(I), Math.abs(K)) && Math.abs(M - Q) <= e.EPSILON * Math.max(1, Math.abs(M), Math.abs(Q)) && Math.abs(C - ie) <= e.EPSILON * Math.max(1, Math.abs(C), Math.abs(ie)) && Math.abs(k - fe) <= e.EPSILON * Math.max(1, Math.abs(k), Math.abs(fe)); }, ht.sub = ht.mul = void 0; var e = function(l, f) { if (l && l.__esModule) return l; if (l === null || r(l) !== "object" && typeof l != "function") return { default: l }; var v = n(void 0); if (v && v.has(l)) return v.get(l); var S = {}, D = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var x in l) if (x !== "default" && Object.prototype.hasOwnProperty.call(l, x)) { var P = D ? Object.getOwnPropertyDescriptor(l, x) : null; P && (P.get || P.set) ? Object.defineProperty(S, x, P) : S[x] = l[x]; } return S.default = l, v && v.set(l, S), S; }(ae()); function n(l) { if (typeof WeakMap != "function") return null; var f = /* @__PURE__ */ new WeakMap(), v = /* @__PURE__ */ new WeakMap(); return (n = function(S) { return S ? v : f; })(l); } function o(l, f, v) { var S = f[0], D = f[1], x = f[2], P = f[3], I = f[4], M = f[5], C = f[6], k = f[7], V = f[8], U = v[0], q = v[1], $ = v[2], H = v[3], K = v[4], Q = v[5], ie = v[6], fe = v[7], de = v[8]; return l[0] = U * S + q * P + $ * C, l[1] = U * D + q * I + $ * k, l[2] = U * x + q * M + $ * V, l[3] = H * S + K * P + Q * C, l[4] = H * D + K * I + Q * k, l[5] = H * x + K * M + Q * V, l[6] = ie * S + fe * P + de * C, l[7] = ie * D + fe * I + de * k, l[8] = ie * x + fe * M + de * V, l; } function u(l, f, v) { return l[0] = f[0] - v[0], l[1] = f[1] - v[1], l[2] = f[2] - v[2], l[3] = f[3] - v[3], l[4] = f[4] - v[4], l[5] = f[5] - v[5], l[6] = f[6] - v[6], l[7] = f[7] - v[7], l[8] = f[8] - v[8], l; } return ht.mul = o, ht.sub = u, ht; } var Vt, pt = {}; function Gt() { if (Vt) return pt; function r(x) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(P) { return typeof P; } : function(P) { return P && typeof Symbol == "function" && P.constructor === Symbol && P !== Symbol.prototype ? "symbol" : typeof P; }, r(x); } Vt = 1, Object.defineProperty(pt, "__esModule", { value: !0 }), pt.create = function() { var x = new e.ARRAY_TYPE(16); return e.ARRAY_TYPE != Float32Array && (x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0), x[0] = 1, x[5] = 1, x[10] = 1, x[15] = 1, x; }, pt.clone = function(x) { var P = new e.ARRAY_TYPE(16); return P[0] = x[0], P[1] = x[1], P[2] = x[2], P[3] = x[3], P[4] = x[4], P[5] = x[5], P[6] = x[6], P[7] = x[7], P[8] = x[8], P[9] = x[9], P[10] = x[10], P[11] = x[11], P[12] = x[12], P[13] = x[13], P[14] = x[14], P[15] = x[15], P; }, pt.copy = function(x, P) { return x[0] = P[0], x[1] = P[1], x[2] = P[2], x[3] = P[3], x[4] = P[4], x[5] = P[5], x[6] = P[6], x[7] = P[7], x[8] = P[8], x[9] = P[9], x[10] = P[10], x[11] = P[11], x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15], x; }, pt.fromValues = function(x, P, I, M, C, k, V, U, q, $, H, K, Q, ie, fe, de) { var ue = new e.ARRAY_TYPE(16); return ue[0] = x, ue[1] = P, ue[2] = I, ue[3] = M, ue[4] = C, ue[5] = k, ue[6] = V, ue[7] = U, ue[8] = q, ue[9] = $, ue[10] = H, ue[11] = K, ue[12] = Q, ue[13] = ie, ue[14] = fe, ue[15] = de, ue; }, pt.set = function(x, P, I, M, C, k, V, U, q, $, H, K, Q, ie, fe, de, ue) { return x[0] = P, x[1] = I, x[2] = M, x[3] = C, x[4] = k, x[5] = V, x[6] = U, x[7] = q, x[8] = $, x[9] = H, x[10] = K, x[11] = Q, x[12] = ie, x[13] = fe, x[14] = de, x[15] = ue, x; }, pt.identity = o, pt.transpose = function(x, P) { if (x === P) { var I = P[1], M = P[2], C = P[3], k = P[6], V = P[7], U = P[11]; x[1] = P[4], x[2] = P[8], x[3] = P[12], x[4] = I, x[6] = P[9], x[7] = P[13], x[8] = M, x[9] = k, x[11] = P[14], x[12] = C, x[13] = V, x[14] = U; } else x[0] = P[0], x[1] = P[4], x[2] = P[8], x[3] = P[12], x[4] = P[1], x[5] = P[5], x[6] = P[9], x[7] = P[13], x[8] = P[2], x[9] = P[6], x[10] = P[10], x[11] = P[14], x[12] = P[3], x[13] = P[7], x[14] = P[11], x[15] = P[15]; return x; }, pt.invert = function(x, P) { var I = P[0], M = P[1], C = P[2], k = P[3], V = P[4], U = P[5], q = P[6], $ = P[7], H = P[8], K = P[9], Q = P[10], ie = P[11], fe = P[12], de = P[13], ue = P[14], Se = P[15], me = I * U - M * V, Ee = I * q - C * V, ze = I * $ - k * V, Ie = M * q - C * U, Re = M * $ - k * U, Ve = C * $ - k * q, Ue = H * de - K * fe, Fe = H * ue - Q * fe, et = H * Se - ie * fe, dt = K * ue - Q * de, tt = K * Se - ie * de, Mt = Q * Se - ie * ue, wt = me * Mt - Ee * tt + ze * dt + Ie * et - Re * Fe + Ve * Ue; return wt ? (x[0] = (U * Mt - q * tt + $ * dt) * (wt = 1 / wt), x[1] = (C * tt - M * Mt - k * dt) * wt, x[2] = (de * Ve - ue * Re + Se * Ie) * wt, x[3] = (Q * Re - K * Ve - ie * Ie) * wt, x[4] = (q * et - V * Mt - $ * Fe) * wt, x[5] = (I * Mt - C * et + k * Fe) * wt, x[6] = (ue * ze - fe * Ve - Se * Ee) * wt, x[7] = (H * Ve - Q * ze + ie * Ee) * wt, x[8] = (V * tt - U * et + $ * Ue) * wt, x[9] = (M * et - I * tt - k * Ue) * wt, x[10] = (fe * Re - de * ze + Se * me) * wt, x[11] = (K * ze - H * Re - ie * me) * wt, x[12] = (U * Fe - V * dt - q * Ue) * wt, x[13] = (I * dt - M * Fe + C * Ue) * wt, x[14] = (de * Ee - fe * Ie - ue * me) * wt, x[15] = (H * Ie - K * Ee + Q * me) * wt, x) : null; }, pt.adjoint = function(x, P) { var I = P[0], M = P[1], C = P[2], k = P[3], V = P[4], U = P[5], q = P[6], $ = P[7], H = P[8], K = P[9], Q = P[10], ie = P[11], fe = P[12], de = P[13], ue = P[14], Se = P[15]; return x[0] = U * (Q * Se - ie * ue) - K * (q * Se - $ * ue) + de * (q * ie - $ * Q), x[1] = -(M * (Q * Se - ie * ue) - K * (C * Se - k * ue) + de * (C * ie - k * Q)), x[2] = M * (q * Se - $ * ue) - U * (C * Se - k * ue) + de * (C * $ - k * q), x[3] = -(M * (q * ie - $ * Q) - U * (C * ie - k * Q) + K * (C * $ - k * q)), x[4] = -(V * (Q * Se - ie * ue) - H * (q * Se - $ * ue) + fe * (q * ie - $ * Q)), x[5] = I * (Q * Se - ie * ue) - H * (C * Se - k * ue) + fe * (C * ie - k * Q), x[6] = -(I * (q * Se - $ * ue) - V * (C * Se - k * ue) + fe * (C * $ - k * q)), x[7] = I * (q * ie - $ * Q) - V * (C * ie - k * Q) + H * (C * $ - k * q), x[8] = V * (K * Se - ie * de) - H * (U * Se - $ * de) + fe * (U * ie - $ * K), x[9] = -(I * (K * Se - ie * de) - H * (M * Se - k * de) + fe * (M * ie - k * K)), x[10] = I * (U * Se - $ * de) - V * (M * Se - k * de) + fe * (M * $ - k * U), x[11] = -(I * (U * ie - $ * K) - V * (M * ie - k * K) + H * (M * $ - k * U)), x[12] = -(V * (K * ue - Q * de) - H * (U * ue - q * de) + fe * (U * Q - q * K)), x[13] = I * (K * ue - Q * de) - H * (M * ue - C * de) + fe * (M * Q - C * K), x[14] = -(I * (U * ue - q * de) - V * (M * ue - C * de) + fe * (M * q - C * U)), x[15] = I * (U * Q - q * K) - V * (M * Q - C * K) + H * (M * q - C * U), x; }, pt.determinant = function(x) { var P = x[0], I = x[1], M = x[2], C = x[3], k = x[4], V = x[5], U = x[6], q = x[7], $ = x[8], H = x[9], K = x[10], Q = x[11], ie = x[12], fe = x[13], de = x[14], ue = x[15]; return (P * V - I * k) * (K * ue - Q * de) - (P * U - M * k) * (H * ue - Q * fe) + (P * q - C * k) * (H * de - K * fe) + (I * U - M * V) * ($ * ue - Q * ie) - (I * q - C * V) * ($ * de - K * ie) + (M * q - C * U) * ($ * fe - H * ie); }, pt.multiply = u, pt.translate = function(x, P, I) { var M, C, k, V, U, q, $, H, K, Q, ie, fe, de = I[0], ue = I[1], Se = I[2]; return P === x ? (x[12] = P[0] * de + P[4] * ue + P[8] * Se + P[12], x[13] = P[1] * de + P[5] * ue + P[9] * Se + P[13], x[14] = P[2] * de + P[6] * ue + P[10] * Se + P[14], x[15] = P[3] * de + P[7] * ue + P[11] * Se + P[15]) : (C = P[1], k = P[2], V = P[3], U = P[4], q = P[5], $ = P[6], H = P[7], K = P[8], Q = P[9], ie = P[10], fe = P[11], x[0] = M = P[0], x[1] = C, x[2] = k, x[3] = V, x[4] = U, x[5] = q, x[6] = $, x[7] = H, x[8] = K, x[9] = Q, x[10] = ie, x[11] = fe, x[12] = M * de + U * ue + K * Se + P[12], x[13] = C * de + q * ue + Q * Se + P[13], x[14] = k * de + $ * ue + ie * Se + P[14], x[15] = V * de + H * ue + fe * Se + P[15]), x; }, pt.scale = function(x, P, I) { var M = I[0], C = I[1], k = I[2]; return x[0] = P[0] * M, x[1] = P[1] * M, x[2] = P[2] * M, x[3] = P[3] * M, x[4] = P[4] * C, x[5] = P[5] * C, x[6] = P[6] * C, x[7] = P[7] * C, x[8] = P[8] * k, x[9] = P[9] * k, x[10] = P[10] * k, x[11] = P[11] * k, x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15], x; }, pt.rotate = function(x, P, I, M) { var C, k, V, U, q, $, H, K, Q, ie, fe, de, ue, Se, me, Ee, ze, Ie, Re, Ve, Ue, Fe, et, dt, tt = M[0], Mt = M[1], wt = M[2], At = Math.hypot(tt, Mt, wt); return At < e.EPSILON ? null : (tt *= At = 1 / At, Mt *= At, wt *= At, C = Math.sin(I), k = Math.cos(I), q = P[1], $ = P[2], H = P[3], Q = P[5], ie = P[6], fe = P[7], ue = P[9], Se = P[10], me = P[11], Ee = tt * tt * (V = 1 - k) + k, Re = tt * Mt * V - wt * C, Ve = Mt * Mt * V + k, Ue = wt * Mt * V + tt * C, Fe = tt * wt * V + Mt * C, et = Mt * wt * V - tt * C, dt = wt * wt * V + k, x[0] = (U = P[0]) * Ee + (K = P[4]) * (ze = Mt * tt * V + wt * C) + (de = P[8]) * (Ie = wt * tt * V - Mt * C), x[1] = q * Ee + Q * ze + ue * Ie, x[2] = $ * Ee + ie * ze + Se * Ie, x[3] = H * Ee + fe * ze + me * Ie, x[4] = U * Re + K * Ve + de * Ue, x[5] = q * Re + Q * Ve + ue * Ue, x[6] = $ * Re + ie * Ve + Se * Ue, x[7] = H * Re + fe * Ve + me * Ue, x[8] = U * Fe + K * et + de * dt, x[9] = q * Fe + Q * et + ue * dt, x[10] = $ * Fe + ie * et + Se * dt, x[11] = H * Fe + fe * et + me * dt, P !== x && (x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15]), x); }, pt.rotateX = function(x, P, I) { var M = Math.sin(I), C = Math.cos(I), k = P[4], V = P[5], U = P[6], q = P[7], $ = P[8], H = P[9], K = P[10], Q = P[11]; return P !== x && (x[0] = P[0], x[1] = P[1], x[2] = P[2], x[3] = P[3], x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15]), x[4] = k * C + $ * M, x[5] = V * C + H * M, x[6] = U * C + K * M, x[7] = q * C + Q * M, x[8] = $ * C - k * M, x[9] = H * C - V * M, x[10] = K * C - U * M, x[11] = Q * C - q * M, x; }, pt.rotateY = function(x, P, I) { var M = Math.sin(I), C = Math.cos(I), k = P[0], V = P[1], U = P[2], q = P[3], $ = P[8], H = P[9], K = P[10], Q = P[11]; return P !== x && (x[4] = P[4], x[5] = P[5], x[6] = P[6], x[7] = P[7], x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15]), x[0] = k * C - $ * M, x[1] = V * C - H * M, x[2] = U * C - K * M, x[3] = q * C - Q * M, x[8] = k * M + $ * C, x[9] = V * M + H * C, x[10] = U * M + K * C, x[11] = q * M + Q * C, x; }, pt.rotateZ = function(x, P, I) { var M = Math.sin(I), C = Math.cos(I), k = P[0], V = P[1], U = P[2], q = P[3], $ = P[4], H = P[5], K = P[6], Q = P[7]; return P !== x && (x[8] = P[8], x[9] = P[9], x[10] = P[10], x[11] = P[11], x[12] = P[12], x[13] = P[13], x[14] = P[14], x[15] = P[15]), x[0] = k * C + $ * M, x[1] = V * C + H * M, x[2] = U * C + K * M, x[3] = q * C + Q * M, x[4] = $ * C - k * M, x[5] = H * C - V * M, x[6] = K * C - U * M, x[7] = Q * C - q * M, x; }, pt.fromTranslation = function(x, P) { return x[0] = 1, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = 1, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = 1, x[11] = 0, x[12] = P[0], x[13] = P[1], x[14] = P[2], x[15] = 1, x; }, pt.fromScaling = function(x, P) { return x[0] = P[0], x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = P[1], x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = P[2], x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; }, pt.fromRotation = function(x, P, I) { var M, C, k, V = I[0], U = I[1], q = I[2], $ = Math.hypot(V, U, q); return $ < e.EPSILON ? null : (V *= $ = 1 / $, U *= $, q *= $, M = Math.sin(P), C = Math.cos(P), x[0] = V * V * (k = 1 - C) + C, x[1] = U * V * k + q * M, x[2] = q * V * k - U * M, x[3] = 0, x[4] = V * U * k - q * M, x[5] = U * U * k + C, x[6] = q * U * k + V * M, x[7] = 0, x[8] = V * q * k + U * M, x[9] = U * q * k - V * M, x[10] = q * q * k + C, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x); }, pt.fromXRotation = function(x, P) { var I = Math.sin(P), M = Math.cos(P); return x[0] = 1, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = M, x[6] = I, x[7] = 0, x[8] = 0, x[9] = -I, x[10] = M, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; }, pt.fromYRotation = function(x, P) { var I = Math.sin(P), M = Math.cos(P); return x[0] = M, x[1] = 0, x[2] = -I, x[3] = 0, x[4] = 0, x[5] = 1, x[6] = 0, x[7] = 0, x[8] = I, x[9] = 0, x[10] = M, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; }, pt.fromZRotation = function(x, P) { var I = Math.sin(P), M = Math.cos(P); return x[0] = M, x[1] = I, x[2] = 0, x[3] = 0, x[4] = -I, x[5] = M, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = 1, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; }, pt.fromRotationTranslation = l, pt.fromQuat2 = function(x, P) { var I = new e.ARRAY_TYPE(3), M = -P[0], C = -P[1], k = -P[2], V = P[3], U = P[4], q = P[5], $ = P[6], H = P[7], K = M * M + C * C + k * k + V * V; return K > 0 ? (I[0] = 2 * (U * V + H * M + q * k - $ * C) / K, I[1] = 2 * (q * V + H * C + $ * M - U * k) / K, I[2] = 2 * ($ * V + H * k + U * C - q * M) / K) : (I[0] = 2 * (U * V + H * M + q * k - $ * C), I[1] = 2 * (q * V + H * C + $ * M - U * k), I[2] = 2 * ($ * V + H * k + U * C - q * M)), l(x, P, I), x; }, pt.getTranslation = function(x, P) { return x[0] = P[12], x[1] = P[13], x[2] = P[14], x; }, pt.getScaling = f, pt.getRotation = function(x, P) { var I = new e.ARRAY_TYPE(3); f(I, P); var M = 1 / I[0], C = 1 / I[1], k = 1 / I[2], V = P[0] * M, U = P[1] * C, q = P[2] * k, $ = P[4] * M, H = P[5] * C, K = P[6] * k, Q = P[8] * M, ie = P[9] * C, fe = P[10] * k, de = V + H + fe, ue = 0; return de > 0 ? (ue = 2 * Math.sqrt(de + 1), x[3] = 0.25 * ue, x[0] = (K - ie) / ue, x[1] = (Q - q) / ue, x[2] = (U - $) / ue) : V > H && V > fe ? (ue = 2 * Math.sqrt(1 + V - H - fe), x[3] = (K - ie) / ue, x[0] = 0.25 * ue, x[1] = (U + $) / ue, x[2] = (Q + q) / ue) : H > fe ? (ue = 2 * Math.sqrt(1 + H - V - fe), x[3] = (Q - q) / ue, x[0] = (U + $) / ue, x[1] = 0.25 * ue, x[2] = (K + ie) / ue) : (ue = 2 * Math.sqrt(1 + fe - V - H), x[3] = (U - $) / ue, x[0] = (Q + q) / ue, x[1] = (K + ie) / ue, x[2] = 0.25 * ue), x; }, pt.fromRotationTranslationScale = function(x, P, I, M) { var C = P[0], k = P[1], V = P[2], U = P[3], q = C + C, $ = k + k, H = V + V, K = C * q, Q = C * $, ie = C * H, fe = k * $, de = k * H, ue = V * H, Se = U * q, me = U * $, Ee = U * H, ze = M[0], Ie = M[1], Re = M[2]; return x[0] = (1 - (fe + ue)) * ze, x[1] = (Q + Ee) * ze, x[2] = (ie - me) * ze, x[3] = 0, x[4] = (Q - Ee) * Ie, x[5] = (1 - (K + ue)) * Ie, x[6] = (de + Se) * Ie, x[7] = 0, x[8] = (ie + me) * Re, x[9] = (de - Se) * Re, x[10] = (1 - (K + fe)) * Re, x[11] = 0, x[12] = I[0], x[13] = I[1], x[14] = I[2], x[15] = 1, x; }, pt.fromRotationTranslationScaleOrigin = function(x, P, I, M, C) { var k = P[0], V = P[1], U = P[2], q = P[3], $ = k + k, H = V + V, K = U + U, Q = k * $, ie = k * H, fe = k * K, de = V * H, ue = V * K, Se = U * K, me = q * $, Ee = q * H, ze = q * K, Ie = M[0], Re = M[1], Ve = M[2], Ue = C[0], Fe = C[1], et = C[2], dt = (1 - (de + Se)) * Ie, tt = (ie + ze) * Ie, Mt = (fe - Ee) * Ie, wt = (ie - ze) * Re, At = (1 - (Q + Se)) * Re, rt = (ue + me) * Re, Ut = (fe + Ee) * Ve, St = (ue - me) * Ve, Nt = (1 - (Q + de)) * Ve; return x[0] = dt, x[1] = tt, x[2] = Mt, x[3] = 0, x[4] = wt, x[5] = At, x[6] = rt, x[7] = 0, x[8] = Ut, x[9] = St, x[10] = Nt, x[11] = 0, x[12] = I[0] + Ue - (dt * Ue + wt * Fe + Ut * et), x[13] = I[1] + Fe - (tt * Ue + At * Fe + St * et), x[14] = I[2] + et - (Mt * Ue + rt * Fe + Nt * et), x[15] = 1, x; }, pt.fromQuat = function(x, P) { var I = P[0], M = P[1], C = P[2], k = P[3], V = I + I, U = M + M, q = C + C, $ = I * V, H = M * V, K = M * U, Q = C * V, ie = C * U, fe = C * q, de = k * V, ue = k * U, Se = k * q; return x[0] = 1 - K - fe, x[1] = H + Se, x[2] = Q - ue, x[3] = 0, x[4] = H - Se, x[5] = 1 - $ - fe, x[6] = ie + de, x[7] = 0, x[8] = Q + ue, x[9] = ie - de, x[10] = 1 - $ - K, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; }, pt.frustum = function(x, P, I, M, C, k, V) { var U = 1 / (I - P), q = 1 / (C - M), $ = 1 / (k - V); return x[0] = 2 * k * U, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = 2 * k * q, x[6] = 0, x[7] = 0, x[8] = (I + P) * U, x[9] = (C + M) * q, x[10] = (V + k) * $, x[11] = -1, x[12] = 0, x[13] = 0, x[14] = V * k * 2 * $, x[15] = 0, x; }, pt.perspectiveNO = v, pt.perspectiveZO = function(x, P, I, M, C) { var k, V = 1 / Math.tan(P / 2); return x[0] = V / I, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = V, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[11] = -1, x[12] = 0, x[13] = 0, x[15] = 0, C != null && C !== 1 / 0 ? (x[10] = C * (k = 1 / (M - C)), x[14] = C * M * k) : (x[10] = -1, x[14] = -M), x; }, pt.perspectiveFromFieldOfView = function(x, P, I, M) { var C = Math.tan(P.upDegrees * Math.PI / 180), k = Math.tan(P.downDegrees * Math.PI / 180), V = Math.tan(P.leftDegrees * Math.PI / 180), U = Math.tan(P.rightDegrees * Math.PI / 180), q = 2 / (V + U), $ = 2 / (C + k); return x[0] = q, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = $, x[6] = 0, x[7] = 0, x[8] = -(V - U) * q * 0.5, x[9] = (C - k) * $ * 0.5, x[10] = M / (I - M), x[11] = -1, x[12] = 0, x[13] = 0, x[14] = M * I / (I - M), x[15] = 0, x; }, pt.orthoNO = S, pt.orthoZO = function(x, P, I, M, C, k, V) { var U = 1 / (P - I), q = 1 / (M - C), $ = 1 / (k - V); return x[0] = -2 * U, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = -2 * q, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = $, x[11] = 0, x[12] = (P + I) * U, x[13] = (C + M) * q, x[14] = k * $, x[15] = 1, x; }, pt.lookAt = function(x, P, I, M) { var C, k, V, U, q, $, H, K, Q, ie, fe = P[0], de = P[1], ue = P[2], Se = M[0], me = M[1], Ee = M[2], ze = I[0], Ie = I[1], Re = I[2]; return Math.abs(fe - ze) < e.EPSILON && Math.abs(de - Ie) < e.EPSILON && Math.abs(ue - Re) < e.EPSILON ? o(x) : (H = fe - ze, K = de - Ie, Q = ue - Re, C = me * (Q *= ie = 1 / Math.hypot(H, K, Q)) - Ee * (K *= ie), k = Ee * (H *= ie) - Se * Q, V = Se * K - me * H, (ie = Math.hypot(C, k, V)) ? (C *= ie = 1 / ie, k *= ie, V *= ie) : (C = 0, k = 0, V = 0), U = K * V - Q * k, q = Q * C - H * V, $ = H * k - K * C, (ie = Math.hypot(U, q, $)) ? (U *= ie = 1 / ie, q *= ie, $ *= ie) : (U = 0, q = 0, $ = 0), x[0] = C, x[1] = U, x[2] = H, x[3] = 0, x[4] = k, x[5] = q, x[6] = K, x[7] = 0, x[8] = V, x[9] = $, x[10] = Q, x[11] = 0, x[12] = -(C * fe + k * de + V * ue), x[13] = -(U * fe + q * de + $ * ue), x[14] = -(H * fe + K * de + Q * ue), x[15] = 1, x); }, pt.targetTo = function(x, P, I, M) { var C = P[0], k = P[1], V = P[2], U = M[0], q = M[1], $ = M[2], H = C - I[0], K = k - I[1], Q = V - I[2], ie = H * H + K * K + Q * Q; ie > 0 && (H *= ie = 1 / Math.sqrt(ie), K *= ie, Q *= ie); var fe = q * Q - $ * K, de = $ * H - U * Q, ue = U * K - q * H; return (ie = fe * fe + de * de + ue * ue) > 0 && (fe *= ie = 1 / Math.sqrt(ie), de *= ie, ue *= ie), x[0] = fe, x[1] = de, x[2] = ue, x[3] = 0, x[4] = K * ue - Q * de, x[5] = Q * fe - H * ue, x[6] = H * de - K * fe, x[7] = 0, x[8] = H, x[9] = K, x[10] = Q, x[11] = 0, x[12] = C, x[13] = k, x[14] = V, x[15] = 1, x; }, pt.str = function(x) { return "mat4(" + x[0] + ", " + x[1] + ", " + x[2] + ", " + x[3] + ", " + x[4] + ", " + x[5] + ", " + x[6] + ", " + x[7] + ", " + x[8] + ", " + x[9] + ", " + x[10] + ", " + x[11] + ", " + x[12] + ", " + x[13] + ", " + x[14] + ", " + x[15] + ")"; }, pt.frob = function(x) { return Math.hypot(x[0], x[1], x[2], x[3], x[4], x[5], x[6], x[7], x[8], x[9], x[10], x[11], x[12], x[13], x[14], x[15]); }, pt.add = function(x, P, I) { return x[0] = P[0] + I[0], x[1] = P[1] + I[1], x[2] = P[2] + I[2], x[3] = P[3] + I[3], x[4] = P[4] + I[4], x[5] = P[5] + I[5], x[6] = P[6] + I[6], x[7] = P[7] + I[7], x[8] = P[8] + I[8], x[9] = P[9] + I[9], x[10] = P[10] + I[10], x[11] = P[11] + I[11], x[12] = P[12] + I[12], x[13] = P[13] + I[13], x[14] = P[14] + I[14], x[15] = P[15] + I[15], x; }, pt.subtract = D, pt.multiplyScalar = function(x, P, I) { return x[0] = P[0] * I, x[1] = P[1] * I, x[2] = P[2] * I, x[3] = P[3] * I, x[4] = P[4] * I, x[5] = P[5] * I, x[6] = P[6] * I, x[7] = P[7] * I, x[8] = P[8] * I, x[9] = P[9] * I, x[10] = P[10] * I, x[11] = P[11] * I, x[12] = P[12] * I, x[13] = P[13] * I, x[14] = P[14] * I, x[15] = P[15] * I, x; }, pt.multiplyScalarAndAdd = function(x, P, I, M) { return x[0] = P[0] + I[0] * M, x[1] = P[1] + I[1] * M, x[2] = P[2] + I[2] * M, x[3] = P[3] + I[3] * M, x[4] = P[4] + I[4] * M, x[5] = P[5] + I[5] * M, x[6] = P[6] + I[6] * M, x[7] = P[7] + I[7] * M, x[8] = P[8] + I[8] * M, x[9] = P[9] + I[9] * M, x[10] = P[10] + I[10] * M, x[11] = P[11] + I[11] * M, x[12] = P[12] + I[12] * M, x[13] = P[13] + I[13] * M, x[14] = P[14] + I[14] * M, x[15] = P[15] + I[15] * M, x; }, pt.exactEquals = function(x, P) { return x[0] === P[0] && x[1] === P[1] && x[2] === P[2] && x[3] === P[3] && x[4] === P[4] && x[5] === P[5] && x[6] === P[6] && x[7] === P[7] && x[8] === P[8] && x[9] === P[9] && x[10] === P[10] && x[11] === P[11] && x[12] === P[12] && x[13] === P[13] && x[14] === P[14] && x[15] === P[15]; }, pt.equals = function(x, P) { var I = x[0], M = x[1], C = x[2], k = x[3], V = x[4], U = x[5], q = x[6], $ = x[7], H = x[8], K = x[9], Q = x[10], ie = x[11], fe = x[12], de = x[13], ue = x[14], Se = x[15], me = P[0], Ee = P[1], ze = P[2], Ie = P[3], Re = P[4], Ve = P[5], Ue = P[6], Fe = P[7], et = P[8], dt = P[9], tt = P[10], Mt = P[11], wt = P[12], At = P[13], rt = P[14], Ut = P[15]; return Math.abs(I - me) <= e.EPSILON * Math.max(1, Math.abs(I), Math.abs(me)) && Math.abs(M - Ee) <= e.EPSILON * Math.max(1, Math.abs(M), Math.abs(Ee)) && Math.abs(C - ze) <= e.EPSILON * Math.max(1, Math.abs(C), Math.abs(ze)) && Math.abs(k - Ie) <= e.EPSILON * Math.max(1, Math.abs(k), Math.abs(Ie)) && Math.abs(V - Re) <= e.EPSILON * Math.max(1, Math.abs(V), Math.abs(Re)) && Math.abs(U - Ve) <= e.EPSILON * Math.max(1, Math.abs(U), Math.abs(Ve)) && Math.abs(q - Ue) <= e.EPSILON * Math.max(1, Math.abs(q), Math.abs(Ue)) && Math.abs($ - Fe) <= e.EPSILON * Math.max(1, Math.abs($), Math.abs(Fe)) && Math.abs(H - et) <= e.EPSILON * Math.max(1, Math.abs(H), Math.abs(et)) && Math.abs(K - dt) <= e.EPSILON * Math.max(1, Math.abs(K), Math.abs(dt)) && Math.abs(Q - tt) <= e.EPSILON * Math.max(1, Math.abs(Q), Math.abs(tt)) && Math.abs(ie - Mt) <= e.EPSILON * Math.max(1, Math.abs(ie), Math.abs(Mt)) && Math.abs(fe - wt) <= e.EPSILON * Math.max(1, Math.abs(fe), Math.abs(wt)) && Math.abs(de - At) <= e.EPSILON * Math.max(1, Math.abs(de), Math.abs(At)) && Math.abs(ue - rt) <= e.EPSILON * Math.max(1, Math.abs(ue), Math.abs(rt)) && Math.abs(Se - Ut) <= e.EPSILON * Math.max(1, Math.abs(Se), Math.abs(Ut)); }, pt.sub = pt.mul = pt.ortho = pt.perspective = void 0; var e = function(x, P) { if (x && x.__esModule) return x; if (x === null || r(x) !== "object" && typeof x != "function") return { default: x }; var I = n(void 0); if (I && I.has(x)) return I.get(x); var M = {}, C = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var k in x) if (k !== "default" && Object.prototype.hasOwnProperty.call(x, k)) { var V = C ? Object.getOwnPropertyDescriptor(x, k) : null; V && (V.get || V.set) ? Object.defineProperty(M, k, V) : M[k] = x[k]; } return M.default = x, I && I.set(x, M), M; }(ae()); function n(x) { if (typeof WeakMap != "function") return null; var P = /* @__PURE__ */ new WeakMap(), I = /* @__PURE__ */ new WeakMap(); return (n = function(M) { return M ? I : P; })(x); } function o(x) { return x[0] = 1, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = 1, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = 1, x[11] = 0, x[12] = 0, x[13] = 0, x[14] = 0, x[15] = 1, x; } function u(x, P, I) { var M = P[0], C = P[1], k = P[2], V = P[3], U = P[4], q = P[5], $ = P[6], H = P[7], K = P[8], Q = P[9], ie = P[10], fe = P[11], de = P[12], ue = P[13], Se = P[14], me = P[15], Ee = I[0], ze = I[1], Ie = I[2], Re = I[3]; return x[0] = Ee * M + ze * U + Ie * K + Re * de, x[1] = Ee * C + ze * q + Ie * Q + Re * ue, x[2] = Ee * k + ze * $ + Ie * ie + Re * Se, x[3] = Ee * V + ze * H + Ie * fe + Re * me, x[4] = (Ee = I[4]) * M + (ze = I[5]) * U + (Ie = I[6]) * K + (Re = I[7]) * de, x[5] = Ee * C + ze * q + Ie * Q + Re * ue, x[6] = Ee * k + ze * $ + Ie * ie + Re * Se, x[7] = Ee * V + ze * H + Ie * fe + Re * me, x[8] = (Ee = I[8]) * M + (ze = I[9]) * U + (Ie = I[10]) * K + (Re = I[11]) * de, x[9] = Ee * C + ze * q + Ie * Q + Re * ue, x[10] = Ee * k + ze * $ + Ie * ie + Re * Se, x[11] = Ee * V + ze * H + Ie * fe + Re * me, x[12] = (Ee = I[12]) * M + (ze = I[13]) * U + (Ie = I[14]) * K + (Re = I[15]) * de, x[13] = Ee * C + ze * q + Ie * Q + Re * ue, x[14] = Ee * k + ze * $ + Ie * ie + Re * Se, x[15] = Ee * V + ze * H + Ie * fe + Re * me, x; } function l(x, P, I) { var M = P[0], C = P[1], k = P[2], V = P[3], U = M + M, q = C + C, $ = k + k, H = M * U, K = M * q, Q = M * $, ie = C * q, fe = C * $, de = k * $, ue = V * U, Se = V * q, me = V * $; return x[0] = 1 - (ie + de), x[1] = K + me, x[2] = Q - Se, x[3] = 0, x[4] = K - me, x[5] = 1 - (H + de), x[6] = fe + ue, x[7] = 0, x[8] = Q + Se, x[9] = fe - ue, x[10] = 1 - (H + ie), x[11] = 0, x[12] = I[0], x[13] = I[1], x[14] = I[2], x[15] = 1, x; } function f(x, P) { var I = P[4], M = P[5], C = P[6], k = P[8], V = P[9], U = P[10]; return x[0] = Math.hypot(P[0], P[1], P[2]), x[1] = Math.hypot(I, M, C), x[2] = Math.hypot(k, V, U), x; } function v(x, P, I, M, C) { var k, V = 1 / Math.tan(P / 2); return x[0] = V / I, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = V, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[11] = -1, x[12] = 0, x[13] = 0, x[15] = 0, C != null && C !== 1 / 0 ? (x[10] = (C + M) * (k = 1 / (M - C)), x[14] = 2 * C * M * k) : (x[10] = -1, x[14] = -2 * M), x; } function S(x, P, I, M, C, k, V) { var U = 1 / (P - I), q = 1 / (M - C), $ = 1 / (k - V); return x[0] = -2 * U, x[1] = 0, x[2] = 0, x[3] = 0, x[4] = 0, x[5] = -2 * q, x[6] = 0, x[7] = 0, x[8] = 0, x[9] = 0, x[10] = 2 * $, x[11] = 0, x[12] = (P + I) * U, x[13] = (C + M) * q, x[14] = (V + k) * $, x[15] = 1, x; } function D(x, P, I) { return x[0] = P[0] - I[0], x[1] = P[1] - I[1], x[2] = P[2] - I[2], x[3] = P[3] - I[3], x[4] = P[4] - I[4], x[5] = P[5] - I[5], x[6] = P[6] - I[6], x[7] = P[7] - I[7], x[8] = P[8] - I[8], x[9] = P[9] - I[9], x[10] = P[10] - I[10], x[11] = P[11] - I[11], x[12] = P[12] - I[12], x[13] = P[13] - I[13], x[14] = P[14] - I[14], x[15] = P[15] - I[15], x; } return pt.perspective = v, pt.ortho = S, pt.mul = u, pt.sub = D, pt; } var ui, kt = {}, Pt = {}; function Mi() { if (ui) return Pt; function r(C) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(k) { return typeof k; } : function(k) { return k && typeof Symbol == "function" && k.constructor === Symbol && k !== Symbol.prototype ? "symbol" : typeof k; }, r(C); } ui = 1, Object.defineProperty(Pt, "__esModule", { value: !0 }), Pt.create = o, Pt.clone = function(C) { var k = new e.ARRAY_TYPE(3); return k[0] = C[0], k[1] = C[1], k[2] = C[2], k; }, Pt.length = u, Pt.fromValues = function(C, k, V) { var U = new e.ARRAY_TYPE(3); return U[0] = C, U[1] = k, U[2] = V, U; }, Pt.copy = function(C, k) { return C[0] = k[0], C[1] = k[1], C[2] = k[2], C; }, Pt.set = function(C, k, V, U) { return C[0] = k, C[1] = V, C[2] = U, C; }, Pt.add = function(C, k, V) { return C[0] = k[0] + V[0], C[1] = k[1] + V[1], C[2] = k[2] + V[2], C; }, Pt.subtract = l, Pt.multiply = f, Pt.divide = v, Pt.ceil = function(C, k) { return C[0] = Math.ceil(k[0]), C[1] = Math.ceil(k[1]), C[2] = Math.ceil(k[2]), C; }, Pt.floor = function(C, k) { return C[0] = Math.floor(k[0]), C[1] = Math.floor(k[1]), C[2] = Math.floor(k[2]), C; }, Pt.min = function(C, k, V) { return C[0] = Math.min(k[0], V[0]), C[1] = Math.min(k[1], V[1]), C[2] = Math.min(k[2], V[2]), C; }, Pt.max = function(C, k, V) { return C[0] = Math.max(k[0], V[0]), C[1] = Math.max(k[1], V[1]), C[2] = Math.max(k[2], V[2]), C; }, Pt.round = function(C, k) { return C[0] = Math.round(k[0]), C[1] = Math.round(k[1]), C[2] = Math.round(k[2]), C; }, Pt.scale = function(C, k, V) { return C[0] = k[0] * V, C[1] = k[1] * V, C[2] = k[2] * V, C; }, Pt.scaleAndAdd = function(C, k, V, U) { return C[0] = k[0] + V[0] * U, C[1] = k[1] + V[1] * U, C[2] = k[2] + V[2] * U, C; }, Pt.distance = S, Pt.squaredDistance = D, Pt.squaredLength = x, Pt.negate = function(C, k) { return C[0] = -k[0], C[1] = -k[1], C[2] = -k[2], C; }, Pt.inverse = function(C, k) { return C[0] = 1 / k[0], C[1] = 1 / k[1], C[2] = 1 / k[2], C; }, Pt.normalize = function(C, k) { var V = k[0], U = k[1], q = k[2], $ = V * V + U * U + q * q; return $ > 0 && ($ = 1 / Math.sqrt($)), C[0] = k[0] * $, C[1] = k[1] * $, C[2] = k[2] * $, C; }, Pt.dot = P, Pt.cross = function(C, k, V) { var U = k[0], q = k[1], $ = k[2], H = V[0], K = V[1], Q = V[2]; return C[0] = q * Q - $ * K, C[1] = $ * H - U * Q, C[2] = U * K - q * H, C; }, Pt.lerp = function(C, k, V, U) { var q = k[0], $ = k[1], H = k[2]; return C[0] = q + U * (V[0] - q), C[1] = $ + U * (V[1] - $), C[2] = H + U * (V[2] - H), C; }, Pt.hermite = function(C, k, V, U, q, $) { var H = $ * $, K = H * (2 * $ - 3) + 1, Q = H * ($ - 2) + $, ie = H * ($ - 1), fe = H * (3 - 2 * $); return C[0] = k[0] * K + V[0] * Q + U[0] * ie + q[0] * fe, C[1] = k[1] * K + V[1] * Q + U[1] * ie + q[1] * fe, C[2] = k[2] * K + V[2] * Q + U[2] * ie + q[2] * fe, C; }, Pt.bezier = function(C, k, V, U, q, $) { var H = 1 - $, K = H * H, Q = $ * $, ie = K * H, fe = 3 * $ * K, de = 3 * Q * H, ue = Q * $; return C[0] = k[0] * ie + V[0] * fe + U[0] * de + q[0] * ue, C[1] = k[1] * ie + V[1] * fe + U[1] * de + q[1] * ue, C[2] = k[2] * ie + V[2] * fe + U[2] * de + q[2] * ue, C; }, Pt.random = function(C, k) { k = k || 1; var V = 2 * e.RANDOM() * Math.PI, U = 2 * e.RANDOM() - 1, q = Math.sqrt(1 - U * U) * k; return C[0] = Math.cos(V) * q, C[1] = Math.sin(V) * q, C[2] = U * k, C; }, Pt.transformMat4 = function(C, k, V) { var U = k[0], q = k[1], $ = k[2], H = V[3] * U + V[7] * q + V[11] * $ + V[15]; return C[0] = (V[0] * U + V[4] * q + V[8] * $ + V[12]) / (H = H || 1), C[1] = (V[1] * U + V[5] * q + V[9] * $ + V[13]) / H, C[2] = (V[2] * U + V[6] * q + V[10] * $ + V[14]) / H, C; }, Pt.transformMat3 = function(C, k, V) { var U = k[0], q = k[1], $ = k[2]; return C[0] = U * V[0] + q * V[3] + $ * V[6], C[1] = U * V[1] + q * V[4] + $ * V[7], C[2] = U * V[2] + q * V[5] + $ * V[8], C; }, Pt.transformQuat = function(C, k, V) { var U = V[0], q = V[1], $ = V[2], H = k[0], K = k[1], Q = k[2], ie = q * Q - $ * K, fe = $ * H - U * Q, de = U * K - q * H, ue = q * de - $ * fe, Se = $ * ie - U * de, me = U * fe - q * ie, Ee = 2 * V[3]; return fe *= Ee, de *= Ee, Se *= 2, me *= 2, C[0] = H + (ie *= Ee) + (ue *= 2), C[1] = K + fe + Se, C[2] = Q + de + me, C; }, Pt.rotateX = function(C, k, V, U) { var q = [], $ = []; return q[0] = k[0] - V[0], q[1] = k[1] - V[1], q[2] = k[2] - V[2], $[0] = q[0], $[1] = q[1] * Math.cos(U) - q[2] * Math.sin(U), $[2] = q[1] * Math.sin(U) + q[2] * Math.cos(U), C[0] = $[0] + V[0], C[1] = $[1] + V[1], C[2] = $[2] + V[2], C; }, Pt.rotateY = function(C, k, V, U) { var q = [], $ = []; return q[0] = k[0] - V[0], q[1] = k[1] - V[1], q[2] = k[2] - V[2], $[0] = q[2] * Math.sin(U) + q[0] * Math.cos(U), $[1] = q[1], $[2] = q[2] * Math.cos(U) - q[0] * Math.sin(U), C[0] = $[0] + V[0], C[1] = $[1] + V[1], C[2] = $[2] + V[2], C; }, Pt.rotateZ = function(C, k, V, U) { var q = [], $ = []; return q[0] = k[0] - V[0], q[1] = k[1] - V[1], q[2] = k[2] - V[2], $[0] = q[0] * Math.cos(U) - q[1] * Math.sin(U), $[1] = q[0] * Math.sin(U) + q[1] * Math.cos(U), $[2] = q[2], C[0] = $[0] + V[0], C[1] = $[1] + V[1], C[2] = $[2] + V[2], C; }, Pt.angle = function(C, k) { var V = C[0], U = C[1], q = C[2], $ = k[0], H = k[1], K = k[2], Q = Math.sqrt(V * V + U * U + q * q) * Math.sqrt($ * $ + H * H + K * K), ie = Q && P(C, k) / Q; return Math.acos(Math.min(Math.max(ie, -1), 1)); }, Pt.zero = function(C) { return C[0] = 0, C[1] = 0, C[2] = 0, C; }, Pt.str = function(C) { return "vec3(" + C[0] + ", " + C[1] + ", " + C[2] + ")"; }, Pt.exactEquals = function(C, k) { return C[0] === k[0] && C[1] === k[1] && C[2] === k[2]; }, Pt.equals = function(C, k) { var V = C[0], U = C[1], q = C[2], $ = k[0], H = k[1], K = k[2]; return Math.abs(V - $) <= e.EPSILON * Math.max(1, Math.abs(V), Math.abs($)) && Math.abs(U - H) <= e.EPSILON * Math.max(1, Math.abs(U), Math.abs(H)) && Math.abs(q - K) <= e.EPSILON * Math.max(1, Math.abs(q), Math.abs(K)); }, Pt.forEach = Pt.sqrLen = Pt.len = Pt.sqrDist = Pt.dist = Pt.div = Pt.mul = Pt.sub = void 0; var e = function(C, k) { if (C && C.__esModule) return C; if (C === null || r(C) !== "object" && typeof C != "function") return { default: C }; var V = n(void 0); if (V && V.has(C)) return V.get(C); var U = {}, q = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var $ in C) if ($ !== "default" && Object.prototype.hasOwnProperty.call(C, $)) { var H = q ? Object.getOwnPropertyDescriptor(C, $) : null; H && (H.get || H.set) ? Object.defineProperty(U, $, H) : U[$] = C[$]; } return U.default = C, V && V.set(C, U), U; }(ae()); function n(C) { if (typeof WeakMap != "function") return null; var k = /* @__PURE__ */ new WeakMap(), V = /* @__PURE__ */ new WeakMap(); return (n = function(U) { return U ? V : k; })(C); } function o() { var C = new e.ARRAY_TYPE(3); return e.ARRAY_TYPE != Float32Array && (C[0] = 0, C[1] = 0, C[2] = 0), C; } function u(C) { return Math.hypot(C[0], C[1], C[2]); } function l(C, k, V) { return C[0] = k[0] - V[0], C[1] = k[1] - V[1], C[2] = k[2] - V[2], C; } function f(C, k, V) { return C[0] = k[0] * V[0], C[1] = k[1] * V[1], C[2] = k[2] * V[2], C; } function v(C, k, V) { return C[0] = k[0] / V[0], C[1] = k[1] / V[1], C[2] = k[2] / V[2], C; } function S(C, k) { return Math.hypot(k[0] - C[0], k[1] - C[1], k[2] - C[2]); } function D(C, k) { var V = k[0] - C[0], U = k[1] - C[1], q = k[2] - C[2]; return V * V + U * U + q * q; } function x(C) { var k = C[0], V = C[1], U = C[2]; return k * k + V * V + U * U; } function P(C, k) { return C[0] * k[0] + C[1] * k[1] + C[2] * k[2]; } Pt.sub = l, Pt.mul = f, Pt.div = v, Pt.dist = S, Pt.sqrDist = D, Pt.len = u, Pt.sqrLen = x; var I, M = (I = o(), function(C, k, V, U, q, $) { var H, K; for (k || (k = 3), V || (V = 0), K = U ? Math.min(U * k + V, C.length) : C.length, H = V; H < K; H += k) I[0] = C[H], I[1] = C[H + 1], I[2] = C[H + 2], q(I, I, $), C[H] = I[0], C[H + 1] = I[1], C[H + 2] = I[2]; return C; }); return Pt.forEach = M, Pt; } var Pn, hn, Ht = {}; function Si() { if (Pn) return Ht; function r(M) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(C) { return typeof C; } : function(C) { return C && typeof Symbol == "function" && C.constructor === Symbol && C !== Symbol.prototype ? "symbol" : typeof C; }, r(M); } Pn = 1, Object.defineProperty(Ht, "__esModule", { value: !0 }), Ht.create = o, Ht.clone = function(M) { var C = new e.ARRAY_TYPE(4); return C[0] = M[0], C[1] = M[1], C[2] = M[2], C[3] = M[3], C; }, Ht.fromValues = function(M, C, k, V) { var U = new e.ARRAY_TYPE(4); return U[0] = M, U[1] = C, U[2] = k, U[3] = V, U; }, Ht.copy = function(M, C) { return M[0] = C[0], M[1] = C[1], M[2] = C[2], M[3] = C[3], M; }, Ht.set = function(M, C, k, V, U) { return M[0] = C, M[1] = k, M[2] = V, M[3] = U, M; }, Ht.add = function(M, C, k) { return M[0] = C[0] + k[0], M[1] = C[1] + k[1], M[2] = C[2] + k[2], M[3] = C[3] + k[3], M; }, Ht.subtract = u, Ht.multiply = l, Ht.divide = f, Ht.ceil = function(M, C) { return M[0] = Math.ceil(C[0]), M[1] = Math.ceil(C[1]), M[2] = Math.ceil(C[2]), M[3] = Math.ceil(C[3]), M; }, Ht.floor = function(M, C) { return M[0] = Math.floor(C[0]), M[1] = Math.floor(C[1]), M[2] = Math.floor(C[2]), M[3] = Math.floor(C[3]), M; }, Ht.min = function(M, C, k) { return M[0] = Math.min(C[0], k[0]), M[1] = Math.min(C[1], k[1]), M[2] = Math.min(C[2], k[2]), M[3] = Math.min(C[3], k[3]), M; }, Ht.max = function(M, C, k) { return M[0] = Math.max(C[0], k[0]), M[1] = Math.max(C[1], k[1]), M[2] = Math.max(C[2], k[2]), M[3] = Math.max(C[3], k[3]), M; }, Ht.round = function(M, C) { return M[0] = Math.round(C[0]), M[1] = Math.round(C[1]), M[2] = Math.round(C[2]), M[3] = Math.round(C[3]), M; }, Ht.scale = function(M, C, k) { return M[0] = C[0] * k, M[1] = C[1] * k, M[2] = C[2] * k, M[3] = C[3] * k, M; }, Ht.scaleAndAdd = function(M, C, k, V) { return M[0] = C[0] + k[0] * V, M[1] = C[1] + k[1] * V, M[2] = C[2] + k[2] * V, M[3] = C[3] + k[3] * V, M; }, Ht.distance = v, Ht.squaredDistance = S, Ht.length = D, Ht.squaredLength = x, Ht.negate = function(M, C) { return M[0] = -C[0], M[1] = -C[1], M[2] = -C[2], M[3] = -C[3], M; }, Ht.inverse = function(M, C) { return M[0] = 1 / C[0], M[1] = 1 / C[1], M[2] = 1 / C[2], M[3] = 1 / C[3], M; }, Ht.normalize = function(M, C) { var k = C[0], V = C[1], U = C[2], q = C[3], $ = k * k + V * V + U * U + q * q; return $ > 0 && ($ = 1 / Math.sqrt($)), M[0] = k * $, M[1] = V * $, M[2] = U * $, M[3] = q * $, M; }, Ht.dot = function(M, C) { return M[0] * C[0] + M[1] * C[1] + M[2] * C[2] + M[3] * C[3]; }, Ht.cross = function(M, C, k, V) { var U = k[0] * V[1] - k[1] * V[0], q = k[0] * V[2] - k[2] * V[0], $ = k[0] * V[3] - k[3] * V[0], H = k[1] * V[2] - k[2] * V[1], K = k[1] * V[3] - k[3] * V[1], Q = k[2] * V[3] - k[3] * V[2], ie = C[0], fe = C[1], de = C[2], ue = C[3]; return M[0] = fe * Q - de * K + ue * H, M[1] = -ie * Q + de * $ - ue * q, M[2] = ie * K - fe * $ + ue * U, M[3] = -ie * H + fe * q - de * U, M; }, Ht.lerp = function(M, C, k, V) { var U = C[0], q = C[1], $ = C[2], H = C[3]; return M[0] = U + V * (k[0] - U), M[1] = q + V * (k[1] - q), M[2] = $ + V * (k[2] - $), M[3] = H + V * (k[3] - H), M; }, Ht.random = function(M, C) { var k, V, U, q, $, H; C = C || 1; do $ = (k = 2 * e.RANDOM() - 1) * k + (V = 2 * e.RANDOM() - 1) * V; while ($ >= 1); do H = (U = 2 * e.RANDOM() - 1) * U + (q = 2 * e.RANDOM() - 1) * q; while (H >= 1); var K = Math.sqrt((1 - $) / H); return M[0] = C * k, M[1] = C * V, M[2] = C * U * K, M[3] = C * q * K, M; }, Ht.transformMat4 = function(M, C, k) { var V = C[0], U = C[1], q = C[2], $ = C[3]; return M[0] = k[0] * V + k[4] * U + k[8] * q + k[12] * $, M[1] = k[1] * V + k[5] * U + k[9] * q + k[13] * $, M[2] = k[2] * V + k[6] * U + k[10] * q + k[14] * $, M[3] = k[3] * V + k[7] * U + k[11] * q + k[15] * $, M; }, Ht.transformQuat = function(M, C, k) { var V = C[0], U = C[1], q = C[2], $ = k[0], H = k[1], K = k[2], Q = k[3], ie = Q * V + H * q - K * U, fe = Q * U + K * V - $ * q, de = Q * q + $ * U - H * V, ue = -$ * V - H * U - K * q; return M[0] = ie * Q + ue * -$ + fe * -K - de * -H, M[1] = fe * Q + ue * -H + de * -$ - ie * -K, M[2] = de * Q + ue * -K + ie * -H - fe * -$, M[3] = C[3], M; }, Ht.zero = function(M) { return M[0] = 0, M[1] = 0, M[2] = 0, M[3] = 0, M; }, Ht.str = function(M) { return "vec4(" + M[0] + ", " + M[1] + ", " + M[2] + ", " + M[3] + ")"; }, Ht.exactEquals = function(M, C) { return M[0] === C[0] && M[1] === C[1] && M[2] === C[2] && M[3] === C[3]; }, Ht.equals = function(M, C) { var k = M[0], V = M[1], U = M[2], q = M[3], $ = C[0], H = C[1], K = C[2], Q = C[3]; return Math.abs(k - $) <= e.EPSILON * Math.max(1, Math.abs(k), Math.abs($)) && Math.abs(V - H) <= e.EPSILON * Math.max(1, Math.abs(V), Math.abs(H)) && Math.abs(U - K) <= e.EPSILON * Math.max(1, Math.abs(U), Math.abs(K)) && Math.abs(q - Q) <= e.EPSILON * Math.max(1, Math.abs(q), Math.abs(Q)); }, Ht.forEach = Ht.sqrLen = Ht.len = Ht.sqrDist = Ht.dist = Ht.div = Ht.mul = Ht.sub = void 0; var e = function(M, C) { if (M && M.__esModule) return M; if (M === null || r(M) !== "object" && typeof M != "function") return { default: M }; var k = n(void 0); if (k && k.has(M)) return k.get(M); var V = {}, U = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var q in M) if (q !== "default" && Object.prototype.hasOwnProperty.call(M, q)) { var $ = U ? Object.getOwnPropertyDescriptor(M, q) : null; $ && ($.get || $.set) ? Object.defineProperty(V, q, $) : V[q] = M[q]; } return V.default = M, k && k.set(M, V), V; }(ae()); function n(M) { if (typeof WeakMap != "function") return null; var C = /* @__PURE__ */ new WeakMap(), k = /* @__PURE__ */ new WeakMap(); return (n = function(V) { return V ? k : C; })(M); } function o() { var M = new e.ARRAY_TYPE(4); return e.ARRAY_TYPE != Float32Array && (M[0] = 0, M[1] = 0, M[2] = 0, M[3] = 0), M; } function u(M, C, k) { return M[0] = C[0] - k[0], M[1] = C[1] - k[1], M[2] = C[2] - k[2], M[3] = C[3] - k[3], M; } function l(M, C, k) { return M[0] = C[0] * k[0], M[1] = C[1] * k[1], M[2] = C[2] * k[2], M[3] = C[3] * k[3], M; } function f(M, C, k) { return M[0] = C[0] / k[0], M[1] = C[1] / k[1], M[2] = C[2] / k[2], M[3] = C[3] / k[3], M; } function v(M, C) { return Math.hypot(C[0] - M[0], C[1] - M[1], C[2] - M[2], C[3] - M[3]); } function S(M, C) { var k = C[0] - M[0], V = C[1] - M[1], U = C[2] - M[2], q = C[3] - M[3]; return k * k + V * V + U * U + q * q; } function D(M) { return Math.hypot(M[0], M[1], M[2], M[3]); } function x(M) { var C = M[0], k = M[1], V = M[2], U = M[3]; return C * C + k * k + V * V + U * U; } Ht.sub = u, Ht.mul = l, Ht.div = f, Ht.dist = v, Ht.sqrDist = S, Ht.len = D, Ht.sqrLen = x; var P, I = (P = o(), function(M, C, k, V, U, q) { var $, H; for (C || (C = 4), k || (k = 0), H = V ? Math.min(V * C + k, M.length) : M.length, $ = k; $ < H; $ += C) P[0] = M[$], P[1] = M[$ + 1], P[2] = M[$ + 2], P[3] = M[$ + 3], U(P, P, q), M[$] = P[0], M[$ + 1] = P[1], M[$ + 2] = P[2], M[$ + 3] = P[3]; return M; }); return Ht.forEach = I, Ht; } function Ji() { if (hn) return kt; function r(me) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(Ee) { return typeof Ee; } : function(Ee) { return Ee && typeof Symbol == "function" && Ee.constructor === Symbol && Ee !== Symbol.prototype ? "symbol" : typeof Ee; }, r(me); } hn = 1, Object.defineProperty(kt, "__esModule", { value: !0 }), kt.create = v, kt.identity = function(me) { return me[0] = 0, me[1] = 0, me[2] = 0, me[3] = 1, me; }, kt.setAxisAngle = S, kt.getAxisAngle = function(me, Ee) { var ze = 2 * Math.acos(Ee[3]), Ie = Math.sin(ze / 2); return Ie > e.EPSILON ? (me[0] = Ee[0] / Ie, me[1] = Ee[1] / Ie, me[2] = Ee[2] / Ie) : (me[0] = 1, me[1] = 0, me[2] = 0), ze; }, kt.getAngle = function(me, Ee) { var ze = k(me, Ee); return Math.acos(2 * ze * ze - 1); }, kt.multiply = D, kt.rotateX = function(me, Ee, ze) { ze *= 0.5; var Ie = Ee[0], Re = Ee[1], Ve = Ee[2], Ue = Ee[3], Fe = Math.sin(ze), et = Math.cos(ze); return me[0] = Ie * et + Ue * Fe, me[1] = Re * et + Ve * Fe, me[2] = Ve * et - Re * Fe, me[3] = Ue * et - Ie * Fe, me; }, kt.rotateY = function(me, Ee, ze) { ze *= 0.5; var Ie = Ee[0], Re = Ee[1], Ve = Ee[2], Ue = Ee[3], Fe = Math.sin(ze), et = Math.cos(ze); return me[0] = Ie * et - Ve * Fe, me[1] = Re * et + Ue * Fe, me[2] = Ve * et + Ie * Fe, me[3] = Ue * et - Re * Fe, me; }, kt.rotateZ = function(me, Ee, ze) { ze *= 0.5; var Ie = Ee[0], Re = Ee[1], Ve = Ee[2], Ue = Ee[3], Fe = Math.sin(ze), et = Math.cos(ze); return me[0] = Ie * et + Re * Fe, me[1] = Re * et - Ie * Fe, me[2] = Ve * et + Ue * Fe, me[3] = Ue * et - Ve * Fe, me; }, kt.calculateW = function(me, Ee) { var ze = Ee[0], Ie = Ee[1], Re = Ee[2]; return me[0] = ze, me[1] = Ie, me[2] = Re, me[3] = Math.sqrt(Math.abs(1 - ze * ze - Ie * Ie - Re * Re)), me; }, kt.exp = x, kt.ln = P, kt.pow = function(me, Ee, ze) { return P(me, Ee), C(me, me, ze), x(me, me), me; }, kt.slerp = I, kt.random = function(me) { var Ee = e.RANDOM(), ze = e.RANDOM(), Ie = e.RANDOM(), Re = Math.sqrt(1 - Ee), Ve = Math.sqrt(Ee); return me[0] = Re * Math.sin(2 * Math.PI * ze), me[1] = Re * Math.cos(2 * Math.PI * ze), me[2] = Ve * Math.sin(2 * Math.PI * Ie), me[3] = Ve * Math.cos(2 * Math.PI * Ie), me; }, kt.invert = function(me, Ee) { var ze = Ee[0], Ie = Ee[1], Re = Ee[2], Ve = Ee[3], Ue = ze * ze + Ie * Ie + Re * Re + Ve * Ve, Fe = Ue ? 1 / Ue : 0; return me[0] = -ze * Fe, me[1] = -Ie * Fe, me[2] = -Re * Fe, me[3] = Ve * Fe, me; }, kt.conjugate = function(me, Ee) { return me[0] = -Ee[0], me[1] = -Ee[1], me[2] = -Ee[2], me[3] = Ee[3], me; }, kt.fromMat3 = M, kt.fromEuler = function(me, Ee, ze, Ie) { var Re = 0.5 * Math.PI / 180; Ee *= Re, ze *= Re, Ie *= Re; var Ve = Math.sin(Ee), Ue = Math.cos(Ee), Fe = Math.sin(ze), et = Math.cos(ze), dt = Math.sin(Ie), tt = Math.cos(Ie); return me[0] = Ve * et * tt - Ue * Fe * dt, me[1] = Ue * Fe * tt + Ve * et * dt, me[2] = Ue * et * dt - Ve * Fe * tt, me[3] = Ue * et * tt + Ve * Fe * dt, me; }, kt.str = function(me) { return "quat(" + me[0] + ", " + me[1] + ", " + me[2] + ", " + me[3] + ")"; }, kt.setAxes = kt.sqlerp = kt.rotationTo = kt.equals = kt.exactEquals = kt.normalize = kt.sqrLen = kt.squaredLength = kt.len = kt.length = kt.lerp = kt.dot = kt.scale = kt.mul = kt.add = kt.set = kt.copy = kt.fromValues = kt.clone = void 0; var e = f(ae()), n = f(gt()), o = f(Mi()), u = f(Si()); function l(me) { if (typeof WeakMap != "function") return null; var Ee = /* @__PURE__ */ new WeakMap(), ze = /* @__PURE__ */ new WeakMap(); return (l = function(Ie) { return Ie ? ze : Ee; })(me); } function f(me, Ee) { if (me && me.__esModule) return me; if (me === null || r(me) !== "object" && typeof me != "function") return { default: me }; var ze = l(Ee); if (ze && ze.has(me)) return ze.get(me); var Ie = {}, Re = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var Ve in me) if (Ve !== "default" && Object.prototype.hasOwnProperty.call(me, Ve)) { var Ue = Re ? Object.getOwnPropertyDescriptor(me, Ve) : null; Ue && (Ue.get || Ue.set) ? Object.defineProperty(Ie, Ve, Ue) : Ie[Ve] = me[Ve]; } return Ie.default = me, ze && ze.set(me, Ie), Ie; } function v() { var me = new e.ARRAY_TYPE(4); return e.ARRAY_TYPE != Float32Array && (me[0] = 0, me[1] = 0, me[2] = 0), me[3] = 1, me; } function S(me, Ee, ze) { ze *= 0.5; var Ie = Math.sin(ze); return me[0] = Ie * Ee[0], me[1] = Ie * Ee[1], me[2] = Ie * Ee[2], me[3] = Math.cos(ze), me; } function D(me, Ee, ze) { var Ie = Ee[0], Re = Ee[1], Ve = Ee[2], Ue = Ee[3], Fe = ze[0], et = ze[1], dt = ze[2], tt = ze[3]; return me[0] = Ie * tt + Ue * Fe + Re * dt - Ve * et, me[1] = Re * tt + Ue * et + Ve * Fe - Ie * dt, me[2] = Ve * tt + Ue * dt + Ie * et - Re * Fe, me[3] = Ue * tt - Ie * Fe - Re * et - Ve * dt, me; } function x(me, Ee) { var ze = Ee[0], Ie = Ee[1], Re = Ee[2], Ve = Ee[3], Ue = Math.sqrt(ze * ze + Ie * Ie + Re * Re), Fe = Math.exp(Ve), et = Ue > 0 ? Fe * Math.sin(Ue) / Ue : 0; return me[0] = ze * et, me[1] = Ie * et, me[2] = Re * et, me[3] = Fe * Math.cos(Ue), me; } function P(me, Ee) { var ze = Ee[0], Ie = Ee[1], Re = Ee[2], Ve = Ee[3], Ue = Math.sqrt(ze * ze + Ie * Ie + Re * Re), Fe = Ue > 0 ? Math.atan2(Ue, Ve) / Ue : 0; return me[0] = ze * Fe, me[1] = Ie * Fe, me[2] = Re * Fe, me[3] = 0.5 * Math.log(ze * ze + Ie * Ie + Re * Re + Ve * Ve), me; } function I(me, Ee, ze, Ie) { var Re, Ve, Ue, Fe, et, dt = Ee[0], tt = Ee[1], Mt = Ee[2], wt = Ee[3], At = ze[0], rt = ze[1], Ut = ze[2], St = ze[3]; return (Ve = dt * At + tt * rt + Mt * Ut + wt * St) < 0 && (Ve = -Ve, At = -At, rt = -rt, Ut = -Ut, St = -St), 1 - Ve > e.EPSILON ? (Re = Math.acos(Ve), Ue = Math.sin(Re), Fe = Math.sin((1 - Ie) * Re) / Ue, et = Math.sin(Ie * Re) / Ue) : (Fe = 1 - Ie, et = Ie), me[0] = Fe * dt + et * At, me[1] = Fe * tt + et * rt, me[2] = Fe * Mt + et * Ut, me[3] = Fe * wt + et * St, me; } function M(me, Ee) { var ze, Ie = Ee[0] + Ee[4] + Ee[8]; if (Ie > 0) ze = Math.sqrt(Ie + 1), me[3] = 0.5 * ze, me[0] = (Ee[5] - Ee[7]) * (ze = 0.5 / ze), me[1] = (Ee[6] - Ee[2]) * ze, me[2] = (Ee[1] - Ee[3]) * ze; else { var Re = 0; Ee[4] > Ee[0] && (Re = 1), Ee[8] > Ee[3 * Re + Re] && (Re = 2); var Ve = (Re + 1) % 3, Ue = (Re + 2) % 3; ze = Math.sqrt(Ee[3 * Re + Re] - Ee[3 * Ve + Ve] - Ee[3 * Ue + Ue] + 1), me[Re] = 0.5 * ze, me[3] = (Ee[3 * Ve + Ue] - Ee[3 * Ue + Ve]) * (ze = 0.5 / ze), me[Ve] = (Ee[3 * Ve + Re] + Ee[3 * Re + Ve]) * ze, me[Ue] = (Ee[3 * Ue + Re] + Ee[3 * Re + Ue]) * ze; } return me; } kt.clone = u.clone, kt.fromValues = u.fromValues, kt.copy = u.copy, kt.set = u.set, kt.add = u.add, kt.mul = D; var C = u.scale; kt.scale = C; var k = u.dot; kt.dot = k, kt.lerp = u.lerp; var V = u.length; kt.length = V, kt.len = V; var U = u.squaredLength; kt.squaredLength = U, kt.sqrLen = U; var q = u.normalize; kt.normalize = q, kt.exactEquals = u.exactEquals, kt.equals = u.equals; var $, H, K, Q = ($ = o.create(), H = o.fromValues(1, 0, 0), K = o.fromValues(0, 1, 0), function(me, Ee, ze) { var Ie = o.dot(Ee, ze); return Ie < -0.999999 ? (o.cross($, H, Ee), o.len($) < 1e-6 && o.cross($, K, Ee), o.normalize($, $), S(me, $, Math.PI), me) : Ie > 0.999999 ? (me[0] = 0, me[1] = 0, me[2] = 0, me[3] = 1, me) : (o.cross($, Ee, ze), me[0] = $[0], me[1] = $[1], me[2] = $[2], me[3] = 1 + Ie, q(me, me)); }); kt.rotationTo = Q; var ie, fe, de = (ie = v(), fe = v(), function(me, Ee, ze, Ie, Re, Ve) { return I(ie, Ee, Re, Ve), I(fe, ze, Ie, Ve), I(me, ie, fe, 2 * Ve * (1 - Ve)), me; }); kt.sqlerp = de; var ue, Se = (ue = n.create(), function(me, Ee, ze, Ie) { return ue[0] = ze[0], ue[3] = ze[1], ue[6] = ze[2], ue[1] = Ie[0], ue[4] = Ie[1], ue[7] = Ie[2], ue[2] = -Ee[0], ue[5] = -Ee[1], ue[8] = -Ee[2], q(me, M(me, ue)); }); return kt.setAxes = Se, kt; } var fi, jt = {}; function ni() { if (fi) return jt; function r(I) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(M) { return typeof M; } : function(M) { return M && typeof Symbol == "function" && M.constructor === Symbol && M !== Symbol.prototype ? "symbol" : typeof M; }, r(I); } fi = 1, Object.defineProperty(jt, "__esModule", { value: !0 }), jt.create = function() { var I = new e.ARRAY_TYPE(8); return e.ARRAY_TYPE != Float32Array && (I[0] = 0, I[1] = 0, I[2] = 0, I[4] = 0, I[5] = 0, I[6] = 0, I[7] = 0), I[3] = 1, I; }, jt.clone = function(I) { var M = new e.ARRAY_TYPE(8); return M[0] = I[0], M[1] = I[1], M[2] = I[2], M[3] = I[3], M[4] = I[4], M[5] = I[5], M[6] = I[6], M[7] = I[7], M; }, jt.fromValues = function(I, M, C, k, V, U, q, $) { var H = new e.ARRAY_TYPE(8); return H[0] = I, H[1] = M, H[2] = C, H[3] = k, H[4] = V, H[5] = U, H[6] = q, H[7] = $, H; }, jt.fromRotationTranslationValues = function(I, M, C, k, V, U, q) { var $ = new e.ARRAY_TYPE(8); $[0] = I, $[1] = M, $[2] = C, $[3] = k; var H = 0.5 * V, K = 0.5 * U, Q = 0.5 * q; return $[4] = H * k + K * C - Q * M, $[5] = K * k + Q * I - H * C, $[6] = Q * k + H * M - K * I, $[7] = -H * I - K * M - Q * C, $; }, jt.fromRotationTranslation = f, jt.fromTranslation = function(I, M) { return I[0] = 0, I[1] = 0, I[2] = 0, I[3] = 1, I[4] = 0.5 * M[0], I[5] = 0.5 * M[1], I[6] = 0.5 * M[2], I[7] = 0, I; }, jt.fromRotation = function(I, M) { return I[0] = M[0], I[1] = M[1], I[2] = M[2], I[3] = M[3], I[4] = 0, I[5] = 0, I[6] = 0, I[7] = 0, I; }, jt.fromMat4 = function(I, M) { var C = n.create(); o.getRotation(C, M); var k = new e.ARRAY_TYPE(3); return o.getTranslation(k, M), f(I, C, k), I; }, jt.copy = v, jt.identity = function(I) { return I[0] = 0, I[1] = 0, I[2] = 0, I[3] = 1, I[4] = 0, I[5] = 0, I[6] = 0, I[7] = 0, I; }, jt.set = function(I, M, C, k, V, U, q, $, H) { return I[0] = M, I[1] = C, I[2] = k, I[3] = V, I[4] = U, I[5] = q, I[6] = $, I[7] = H, I; }, jt.getDual = function(I, M) { return I[0] = M[4], I[1] = M[5], I[2] = M[6], I[3] = M[7], I; }, jt.setDual = function(I, M) { return I[4] = M[0], I[5] = M[1], I[6] = M[2], I[7] = M[3], I; }, jt.getTranslation = function(I, M) { var C = M[4], k = M[5], V = M[6], U = M[7], q = -M[0], $ = -M[1], H = -M[2], K = M[3]; return I[0] = 2 * (C * K + U * q + k * H - V * $), I[1] = 2 * (k * K + U * $ + V * q - C * H), I[2] = 2 * (V * K + U * H + C * $ - k * q), I; }, jt.translate = function(I, M, C) { var k = M[0], V = M[1], U = M[2], q = M[3], $ = 0.5 * C[0], H = 0.5 * C[1], K = 0.5 * C[2], Q = M[4], ie = M[5], fe = M[6], de = M[7]; return I[0] = k, I[1] = V, I[2] = U, I[3] = q, I[4] = q * $ + V * K - U * H + Q, I[5] = q * H + U * $ - k * K + ie, I[6] = q * K + k * H - V * $ + fe, I[7] = -k * $ - V * H - U * K + de, I; }, jt.rotateX = function(I, M, C) { var k = -M[0], V = -M[1], U = -M[2], q = M[3], $ = M[4], H = M[5], K = M[6], Q = M[7], ie = $ * q + Q * k + H * U - K * V, fe = H * q + Q * V + K * k - $ * U, de = K * q + Q * U + $ * V - H * k, ue = Q * q - $ * k - H * V - K * U; return n.rotateX(I, M, C), I[4] = ie * (q = I[3]) + ue * (k = I[0]) + fe * (U = I[2]) - de * (V = I[1]), I[5] = fe * q + ue * V + de * k - ie * U, I[6] = de * q + ue * U + ie * V - fe * k, I[7] = ue * q - ie * k - fe * V - de * U, I; }, jt.rotateY = function(I, M, C) { var k = -M[0], V = -M[1], U = -M[2], q = M[3], $ = M[4], H = M[5], K = M[6], Q = M[7], ie = $ * q + Q * k + H * U - K * V, fe = H * q + Q * V + K * k - $ * U, de = K * q + Q * U + $ * V - H * k, ue = Q * q - $ * k - H * V - K * U; return n.rotateY(I, M, C), I[4] = ie * (q = I[3]) + ue * (k = I[0]) + fe * (U = I[2]) - de * (V = I[1]), I[5] = fe * q + ue * V + de * k - ie * U, I[6] = de * q + ue * U + ie * V - fe * k, I[7] = ue * q - ie * k - fe * V - de * U, I; }, jt.rotateZ = function(I, M, C) { var k = -M[0], V = -M[1], U = -M[2], q = M[3], $ = M[4], H = M[5], K = M[6], Q = M[7], ie = $ * q + Q * k + H * U - K * V, fe = H * q + Q * V + K * k - $ * U, de = K * q + Q * U + $ * V - H * k, ue = Q * q - $ * k - H * V - K * U; return n.rotateZ(I, M, C), I[4] = ie * (q = I[3]) + ue * (k = I[0]) + fe * (U = I[2]) - de * (V = I[1]), I[5] = fe * q + ue * V + de * k - ie * U, I[6] = de * q + ue * U + ie * V - fe * k, I[7] = ue * q - ie * k - fe * V - de * U, I; }, jt.rotateByQuatAppend = function(I, M, C) { var k = C[0], V = C[1], U = C[2], q = C[3], $ = M[0], H = M[1], K = M[2], Q = M[3]; return I[0] = $ * q + Q * k + H * U - K * V, I[1] = H * q + Q * V + K * k - $ * U, I[2] = K * q + Q * U + $ * V - H * k, I[3] = Q * q - $ * k - H * V - K * U, I[4] = ($ = M[4]) * q + (Q = M[7]) * k + (H = M[5]) * U - (K = M[6]) * V, I[5] = H * q + Q * V + K * k - $ * U, I[6] = K * q + Q * U + $ * V - H * k, I[7] = Q * q - $ * k - H * V - K * U, I; }, jt.rotateByQuatPrepend = function(I, M, C) { var k = M[0], V = M[1], U = M[2], q = M[3], $ = C[0], H = C[1], K = C[2], Q = C[3]; return I[0] = k * Q + q * $ + V * K - U * H, I[1] = V * Q + q * H + U * $ - k * K, I[2] = U * Q + q * K + k * H - V * $, I[3] = q * Q - k * $ - V * H - U * K, I[4] = k * (Q = C[7]) + q * ($ = C[4]) + V * (K = C[6]) - U * (H = C[5]), I[5] = V * Q + q * H + U * $ - k * K, I[6] = U * Q + q * K + k * H - V * $, I[7] = q * Q - k * $ - V * H - U * K, I; }, jt.rotateAroundAxis = function(I, M, C, k) { if (Math.abs(k) < e.EPSILON) return v(I, M); var V = Math.hypot(C[0], C[1], C[2]); k *= 0.5; var U = Math.sin(k), q = U * C[0] / V, $ = U * C[1] / V, H = U * C[2] / V, K = Math.cos(k), Q = M[0], ie = M[1], fe = M[2], de = M[3]; I[0] = Q * K + de * q + ie * H - fe * $, I[1] = ie * K + de * $ + fe * q - Q * H, I[2] = fe * K + de * H + Q * $ - ie * q, I[3] = de * K - Q * q - ie * $ - fe * H; var ue = M[4], Se = M[5], me = M[6], Ee = M[7]; return I[4] = ue * K + Ee * q + Se * H - me * $, I[5] = Se * K + Ee * $ + me * q - ue * H, I[6] = me * K + Ee * H + ue * $ - Se * q, I[7] = Ee * K - ue * q - Se * $ - me * H, I; }, jt.add = function(I, M, C) { return I[0] = M[0] + C[0], I[1] = M[1] + C[1], I[2] = M[2] + C[2], I[3] = M[3] + C[3], I[4] = M[4] + C[4], I[5] = M[5] + C[5], I[6] = M[6] + C[6], I[7] = M[7] + C[7], I; }, jt.multiply = S, jt.scale = function(I, M, C) { return I[0] = M[0] * C, I[1] = M[1] * C, I[2] = M[2] * C, I[3] = M[3] * C, I[4] = M[4] * C, I[5] = M[5] * C, I[6] = M[6] * C, I[7] = M[7] * C, I; }, jt.lerp = function(I, M, C, k) { var V = 1 - k; return D(M, C) < 0 && (k = -k), I[0] = M[0] * V + C[0] * k, I[1] = M[1] * V + C[1] * k, I[2] = M[2] * V + C[2] * k, I[3] = M[3] * V + C[3] * k, I[4] = M[4] * V + C[4] * k, I[5] = M[5] * V + C[5] * k, I[6] = M[6] * V + C[6] * k, I[7] = M[7] * V + C[7] * k, I; }, jt.invert = function(I, M) { var C = P(M); return I[0] = -M[0] / C, I[1] = -M[1] / C, I[2] = -M[2] / C, I[3] = M[3] / C, I[4] = -M[4] / C, I[5] = -M[5] / C, I[6] = -M[6] / C, I[7] = M[7] / C, I; }, jt.conjugate = function(I, M) { return I[0] = -M[0], I[1] = -M[1], I[2] = -M[2], I[3] = M[3], I[4] = -M[4], I[5] = -M[5], I[6] = -M[6], I[7] = M[7], I; }, jt.normalize = function(I, M) { var C = P(M); if (C > 0) { C = Math.sqrt(C); var k = M[0] / C, V = M[1] / C, U = M[2] / C, q = M[3] / C, $ = M[4], H = M[5], K = M[6], Q = M[7], ie = k * $ + V * H + U * K + q * Q; I[0] = k, I[1] = V, I[2] = U, I[3] = q, I[4] = ($ - k * ie) / C, I[5] = (H - V * ie) / C, I[6] = (K - U * ie) / C, I[7] = (Q - q * ie) / C; } return I; }, jt.str = function(I) { return "quat2(" + I[0] + ", " + I[1] + ", " + I[2] + ", " + I[3] + ", " + I[4] + ", " + I[5] + ", " + I[6] + ", " + I[7] + ")"; }, jt.exactEquals = function(I, M) { return I[0] === M[0] && I[1] === M[1] && I[2] === M[2] && I[3] === M[3] && I[4] === M[4] && I[5] === M[5] && I[6] === M[6] && I[7] === M[7]; }, jt.equals = function(I, M) { var C = I[0], k = I[1], V = I[2], U = I[3], q = I[4], $ = I[5], H = I[6], K = I[7], Q = M[0], ie = M[1], fe = M[2], de = M[3], ue = M[4], Se = M[5], me = M[6], Ee = M[7]; return Math.abs(C - Q) <= e.EPSILON * Math.max(1, Math.abs(C), Math.abs(Q)) && Math.abs(k - ie) <= e.EPSILON * Math.max(1, Math.abs(k), Math.abs(ie)) && Math.abs(V - fe) <= e.EPSILON * Math.max(1, Math.abs(V), Math.abs(fe)) && Math.abs(U - de) <= e.EPSILON * Math.max(1, Math.abs(U), Math.abs(de)) && Math.abs(q - ue) <= e.EPSILON * Math.max(1, Math.abs(q), Math.abs(ue)) && Math.abs($ - Se) <= e.EPSILON * Math.max(1, Math.abs($), Math.abs(Se)) && Math.abs(H - me) <= e.EPSILON * Math.max(1, Math.abs(H), Math.abs(me)) && Math.abs(K - Ee) <= e.EPSILON * Math.max(1, Math.abs(K), Math.abs(Ee)); }, jt.sqrLen = jt.squaredLength = jt.len = jt.length = jt.dot = jt.mul = jt.setReal = jt.getReal = void 0; var e = l(ae()), n = l(Ji()), o = l(Gt()); function u(I) { if (typeof WeakMap != "function") return null; var M = /* @__PURE__ */ new WeakMap(), C = /* @__PURE__ */ new WeakMap(); return (u = function(k) { return k ? C : M; })(I); } function l(I, M) { if (I && I.__esModule) return I; if (I === null || r(I) !== "object" && typeof I != "function") return { default: I }; var C = u(M); if (C && C.has(I)) return C.get(I); var k = {}, V = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var U in I) if (U !== "default" && Object.prototype.hasOwnProperty.call(I, U)) { var q = V ? Object.getOwnPropertyDescriptor(I, U) : null; q && (q.get || q.set) ? Object.defineProperty(k, U, q) : k[U] = I[U]; } return k.default = I, C && C.set(I, k), k; } function f(I, M, C) { var k = 0.5 * C[0], V = 0.5 * C[1], U = 0.5 * C[2], q = M[0], $ = M[1], H = M[2], K = M[3]; return I[0] = q, I[1] = $, I[2] = H, I[3] = K, I[4] = k * K + V * H - U * $, I[5] = V * K + U * q - k * H, I[6] = U * K + k * $ - V * q, I[7] = -k * q - V * $ - U * H, I; } function v(I, M) { return I[0] = M[0], I[1] = M[1], I[2] = M[2], I[3] = M[3], I[4] = M[4], I[5] = M[5], I[6] = M[6], I[7] = M[7], I; } function S(I, M, C) { var k = M[0], V = M[1], U = M[2], q = M[3], $ = C[4], H = C[5], K = C[6], Q = C[7], ie = M[4], fe = M[5], de = M[6], ue = M[7], Se = C[0], me = C[1], Ee = C[2], ze = C[3]; return I[0] = k * ze + q * Se + V * Ee - U * me, I[1] = V * ze + q * me + U * Se - k * Ee, I[2] = U * ze + q * Ee + k * me - V * Se, I[3] = q * ze - k * Se - V * me - U * Ee, I[4] = k * Q + q * $ + V * K - U * H + ie * ze + ue * Se + fe * Ee - de * me, I[5] = V * Q + q * H + U * $ - k * K + fe * ze + ue * me + de * Se - ie * Ee, I[6] = U * Q + q * K + k * H - V * $ + de * ze + ue * Ee + ie * me - fe * Se, I[7] = q * Q - k * $ - V * H - U * K + ue * ze - ie * Se - fe * me - de * Ee, I; } jt.getReal = n.copy, jt.setReal = n.copy, jt.mul = S; var D = n.dot; jt.dot = D; var x = n.length; jt.length = x, jt.len = x; var P = n.squaredLength; return jt.squaredLength = P, jt.sqrLen = P, jt; } var Gi, an, qt = {}; function ln() { if (Gi) return qt; function r(M) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(C) { return typeof C; } : function(C) { return C && typeof Symbol == "function" && C.constructor === Symbol && C !== Symbol.prototype ? "symbol" : typeof C; }, r(M); } Gi = 1, Object.defineProperty(qt, "__esModule", { value: !0 }), qt.create = o, qt.clone = function(M) { var C = new e.ARRAY_TYPE(2); return C[0] = M[0], C[1] = M[1], C; }, qt.fromValues = function(M, C) { var k = new e.ARRAY_TYPE(2); return k[0] = M, k[1] = C, k; }, qt.copy = function(M, C) { return M[0] = C[0], M[1] = C[1], M; }, qt.set = function(M, C, k) { return M[0] = C, M[1] = k, M; }, qt.add = function(M, C, k) { return M[0] = C[0] + k[0], M[1] = C[1] + k[1], M; }, qt.subtract = u, qt.multiply = l, qt.divide = f, qt.ceil = function(M, C) { return M[0] = Math.ceil(C[0]), M[1] = Math.ceil(C[1]), M; }, qt.floor = function(M, C) { return M[0] = Math.floor(C[0]), M[1] = Math.floor(C[1]), M; }, qt.min = function(M, C, k) { return M[0] = Math.min(C[0], k[0]), M[1] = Math.min(C[1], k[1]), M; }, qt.max = function(M, C, k) { return M[0] = Math.max(C[0], k[0]), M[1] = Math.max(C[1], k[1]), M; }, qt.round = function(M, C) { return M[0] = Math.round(C[0]), M[1] = Math.round(C[1]), M; }, qt.scale = function(M, C, k) { return M[0] = C[0] * k, M[1] = C[1] * k, M; }, qt.scaleAndAdd = function(M, C, k, V) { return M[0] = C[0] + k[0] * V, M[1] = C[1] + k[1] * V, M; }, qt.distance = v, qt.squaredDistance = S, qt.length = D, qt.squaredLength = x, qt.negate = function(M, C) { return M[0] = -C[0], M[1] = -C[1], M; }, qt.inverse = function(M, C) { return M[0] = 1 / C[0], M[1] = 1 / C[1], M; }, qt.normalize = function(M, C) { var k = C[0], V = C[1], U = k * k + V * V; return U > 0 && (U = 1 / Math.sqrt(U)), M[0] = C[0] * U, M[1] = C[1] * U, M; }, qt.dot = function(M, C) { return M[0] * C[0] + M[1] * C[1]; }, qt.cross = function(M, C, k) { var V = C[0] * k[1] - C[1] * k[0]; return M[0] = M[1] = 0, M[2] = V, M; }, qt.lerp = function(M, C, k, V) { var U = C[0], q = C[1]; return M[0] = U + V * (k[0] - U), M[1] = q + V * (k[1] - q), M; }, qt.random = function(M, C) { C = C || 1; var k = 2 * e.RANDOM() * Math.PI; return M[0] = Math.cos(k) * C, M[1] = Math.sin(k) * C, M; }, qt.transformMat2 = function(M, C, k) { var V = C[0], U = C[1]; return M[0] = k[0] * V + k[2] * U, M[1] = k[1] * V + k[3] * U, M; }, qt.transformMat2d = function(M, C, k) { var V = C[0], U = C[1]; return M[0] = k[0] * V + k[2] * U + k[4], M[1] = k[1] * V + k[3] * U + k[5], M; }, qt.transformMat3 = function(M, C, k) { var V = C[0], U = C[1]; return M[0] = k[0] * V + k[3] * U + k[6], M[1] = k[1] * V + k[4] * U + k[7], M; }, qt.transformMat4 = function(M, C, k) { var V = C[0], U = C[1]; return M[0] = k[0] * V + k[4] * U + k[12], M[1] = k[1] * V + k[5] * U + k[13], M; }, qt.rotate = function(M, C, k, V) { var U = C[0] - k[0], q = C[1] - k[1], $ = Math.sin(V), H = Math.cos(V); return M[0] = U * H - q * $ + k[0], M[1] = U * $ + q * H + k[1], M; }, qt.angle = function(M, C) { var k = M[0], V = M[1], U = C[0], q = C[1], $ = Math.sqrt(k * k + V * V) * Math.sqrt(U * U + q * q); return Math.acos(Math.min(Math.max($ && (k * U + V * q) / $, -1), 1)); }, qt.zero = function(M) { return M[0] = 0, M[1] = 0, M; }, qt.str = function(M) { return "vec2(" + M[0] + ", " + M[1] + ")"; }, qt.exactEquals = function(M, C) { return M[0] === C[0] && M[1] === C[1]; }, qt.equals = function(M, C) { var k = M[0], V = M[1], U = C[0], q = C[1]; return Math.abs(k - U) <= e.EPSILON * Math.max(1, Math.abs(k), Math.abs(U)) && Math.abs(V - q) <= e.EPSILON * Math.max(1, Math.abs(V), Math.abs(q)); }, qt.forEach = qt.sqrLen = qt.sqrDist = qt.dist = qt.div = qt.mul = qt.sub = qt.len = void 0; var e = function(M, C) { if (M && M.__esModule) return M; if (M === null || r(M) !== "object" && typeof M != "function") return { default: M }; var k = n(void 0); if (k && k.has(M)) return k.get(M); var V = {}, U = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var q in M) if (q !== "default" && Object.prototype.hasOwnProperty.call(M, q)) { var $ = U ? Object.getOwnPropertyDescriptor(M, q) : null; $ && ($.get || $.set) ? Object.defineProperty(V, q, $) : V[q] = M[q]; } return V.default = M, k && k.set(M, V), V; }(ae()); function n(M) { if (typeof WeakMap != "function") return null; var C = /* @__PURE__ */ new WeakMap(), k = /* @__PURE__ */ new WeakMap(); return (n = function(V) { return V ? k : C; })(M); } function o() { var M = new e.ARRAY_TYPE(2); return e.ARRAY_TYPE != Float32Array && (M[0] = 0, M[1] = 0), M; } function u(M, C, k) { return M[0] = C[0] - k[0], M[1] = C[1] - k[1], M; } function l(M, C, k) { return M[0] = C[0] * k[0], M[1] = C[1] * k[1], M; } function f(M, C, k) { return M[0] = C[0] / k[0], M[1] = C[1] / k[1], M; } function v(M, C) { return Math.hypot(C[0] - M[0], C[1] - M[1]); } function S(M, C) { var k = C[0] - M[0], V = C[1] - M[1]; return k * k + V * V; } function D(M) { return Math.hypot(M[0], M[1]); } function x(M) { var C = M[0], k = M[1]; return C * C + k * k; } qt.len = D, qt.sub = u, qt.mul = l, qt.div = f, qt.dist = v, qt.sqrDist = S, qt.sqrLen = x; var P, I = (P = o(), function(M, C, k, V, U, q) { var $, H; for (C || (C = 2), k || (k = 0), H = V ? Math.min(V * C + k, M.length) : M.length, $ = k; $ < H; $ += C) P[0] = M[$], P[1] = M[$ + 1], U(P, P, q), M[$] = P[0], M[$ + 1] = P[1]; return M; }); return qt.forEach = I, qt; } function Di() { if (an) return Y; function r(M) { return r = typeof Symbol == "function" && typeof Symbol.iterator == "symbol" ? function(C) { return typeof C; } : function(C) { return C && typeof Symbol == "function" && C.constructor === Symbol && C !== Symbol.prototype ? "symbol" : typeof C; }, r(M); } an = 1, Object.defineProperty(Y, "__esModule", { value: !0 }), Y.vec4 = Y.vec3 = Y.vec2 = Y.quat2 = Y.quat = Y.mat4 = Y.mat3 = Y.mat2d = Y.mat2 = Y.glMatrix = void 0; var e = I(ae()); Y.glMatrix = e; var n = I(be()); Y.mat2 = n; var o = I(ot()); Y.mat2d = o; var u = I(gt()); Y.mat3 = u; var l = I(Gt()); Y.mat4 = l; var f = I(Ji()); Y.quat = f; var v = I(ni()); Y.quat2 = v; var S = I(ln()); Y.vec2 = S; var D = I(Mi()); Y.vec3 = D; var x = I(Si()); function P(M) { if (typeof WeakMap != "function") return null; var C = /* @__PURE__ */ new WeakMap(), k = /* @__PURE__ */ new WeakMap(); return (P = function(V) { return V ? k : C; })(M); } function I(M, C) { if (M && M.__esModule) return M; if (M === null || r(M) !== "object" && typeof M != "function") return { default: M }; var k = P(C); if (k && k.has(M)) return k.get(M); var V = {}, U = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var q in M) if (q !== "default" && Object.prototype.hasOwnProperty.call(M, q)) { var $ = U ? Object.getOwnPropertyDescriptor(M, q) : null; $ && ($.get || $.set) ? Object.defineProperty(V, q, $) : V[q] = M[q]; } return V.default = M, k && k.set(M, V), V; } return Y.vec4 = x, Y; } var xi, Cs, xs, Is, De = Di(), Vs = function() { if (Cs) return xi; function r(e, n, o, u) { this.cx = 3 * e, this.bx = 3 * (o - e) - this.cx, this.ax = 1 - this.cx - this.bx, this.cy = 3 * n, this.by = 3 * (u - n) - this.cy, this.ay = 1 - this.cy - this.by, this.p1x = e, this.p1y = n, this.p2x = o, this.p2y = u; } return Cs = 1, xi = r, r.prototype = { sampleCurveX: function(e) { return ((this.ax * e + this.bx) * e + this.cx) * e; }, sampleCurveY: function(e) { return ((this.ay * e + this.by) * e + this.cy) * e; }, sampleCurveDerivativeX: function(e) { return (3 * this.ax * e + 2 * this.bx) * e + this.cx; }, solveCurveX: function(e, n) { if (n === void 0 && (n = 1e-6), e < 0) return 0; if (e > 1) return 1; for (var o = e, u = 0; u < 8; u++) { var l = this.sampleCurveX(o) - e; if (Math.abs(l) < n) return o; var f = this.sampleCurveDerivativeX(o); if (Math.abs(f) < 1e-6) break; o -= l / f; } var v = 0, S = 1; for (o = e, u = 0; u < 20 && (l = this.sampleCurveX(o), !(Math.abs(l - e) < n)); u++) e > l ? v = o : S = o, o = 0.5 * (S - v) + v; return o; }, solve: function(e, n) { return this.sampleCurveY(this.solveCurveX(e, n)); } }, xi; }(), Us = O(Vs); function Zr() { if (Is) return xs; function r(e, n) { this.x = e, this.y = n; } return Is = 1, xs = r, r.prototype = { clone: function() { return new r(this.x, this.y); }, add: function(e) { return this.clone()._add(e); }, sub: function(e) { return this.clone()._sub(e); }, multByPoint: function(e) { return this.clone()._multByPoint(e); }, divByPoint: function(e) { return this.clone()._divByPoint(e); }, mult: function(e) { return this.clone()._mult(e); }, div: function(e) { return this.clone()._div(e); }, rotate: function(e) { return this.clone()._rotate(e); }, rotateAround: function(e, n) { return this.clone()._rotateAround(e, n); }, matMult: function(e) { return this.clone()._matMult(e); }, 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(e) { return this.x === e.x && this.y === e.y; }, dist: function(e) { return Math.sqrt(this.distSqr(e)); }, distSqr: function(e) { var n = e.x - this.x, o = e.y - this.y; return n * n + o * o; }, angle: function() { return Math.atan2(this.y, this.x); }, angleTo: function(e) { return Math.atan2(this.y - e.y, this.x - e.x); }, angleWith: function(e) { return this.angleWithSep(e.x, e.y); }, angleWithSep: function(e, n) { return Math.atan2(this.x * n - this.y * e, this.x * e + this.y * n); }, _matMult: function(e) { var n = e[2] * this.x + e[3] * this.y; return this.x = e[0] * this.x + e[1] * this.y, this.y = n, this; }, _add: function(e) { return this.x += e.x, this.y += e.y, this; }, _sub: function(e) { return this.x -= e.x, this.y -= e.y, this; }, _mult: function(e) { return this.x *= e, this.y *= e, this; }, _div: function(e) { return this.x /= e, this.y /= e, this; }, _multByPoint: function(e) { return this.x *= e.x, this.y *= e.y, this; }, _divByPoint: function(e) { return this.x /= e.x, this.y /= e.y, this; }, _unit: function() { return this._div(this.mag()), this; }, _perp: function() { var e = this.y; return this.y = this.x, this.x = -e, this; }, _rotate: function(e) { var n = Math.cos(e), o = Math.sin(e), u = o * this.x + n * this.y; return this.x = n * this.x - o * this.y, this.y = u, this; }, _rotateAround: function(e, n) { var o = Math.cos(e), u = Math.sin(e), l = n.y + u * (this.x - n.x) + o * (this.y - n.y); return this.x = n.x + o * (this.x - n.x) - u * (this.y - n.y), this.y = l, this; }, _round: function() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this; } }, r.convert = function(e) { return e instanceof r ? e : Array.isArray(e) ? new r(e[0], e[1]) : e; }, xs; } var Et = O(Zr()); function Ws(r, e) { if (Array.isArray(r)) { if (!Array.isArray(e) || r.length !== e.length) return !1; for (let n = 0; n < r.length; n++) if (!Ws(r[n], e[n])) return !1; return !0; } if (typeof r == "object" && r !== null && e !== null) { if (typeof e != "object" || Object.keys(r).length !== Object.keys(e).length) return !1; for (const n in r) if (!Ws(r[n], e[n])) return !1; return !0; } return r === e; } const $n = Math.PI / 180, $s = 180 / Math.PI; function vi(r) { return r * $n; } function kn(r) { return r * $s; } const Xs = [[0, 0], [1, 0], [1, 1], [0, 1]]; function Hr(r) { if (r <= 0) return 0; if (r >= 1) return 1; const e = r * r, n = e * r; return 4 * (r < 0.5 ? n : 3 * (r - e) + n - 0.75); } function qr(r, e, n, o) { const u = new Us(r, e, n, o); return function(l) { return u.solve(l); }; } const Wr = qr(0.25, 0.1, 0.25, 1); function si(r, e, n) { return Math.min(n, Math.max(e, r)); } function fs(r, e, n) { return (n = si((n - r) / (e - r), 0, 1)) * n * (3 - 2 * n); } function zn(r, e, n) { const o = n - e, u = ((r - e) % o + o) % o + e; return u === e ? n : u; } function Rn(r, e, n) { if (!r.length) return n(null, []); let o = r.length; const u = new Array(r.length); let l = null; r.forEach((f, v) => { e(f, (S, D) => { S && (l = S), u[v] = D, --o == 0 && n(l, u); }); }); } function An(r, ...e) { for (const n of e) for (const o in n) r[o] = n[o]; return r; } let js = 1; function yo() { return js++; } function xo(r) { return r <= 1 ? 1 : Math.pow(2, Math.ceil(Math.log(r) / Math.LN2)); } function vo(r, e) { r.forEach((n) => { e[n] && (e[n] = e[n].bind(e)); }); } function yr(r, e) { return r.indexOf(e, r.length - e.length) !== -1; } function Mr(r, e, n) { const o = {}; for (const u in r) o[u] = e.call(this, r[u], u, r); return o; } function io(r, e, n) { const o = {}; for (const u in r) e.call(this, r[u], u, r) && (o[u] = r[u]); return o; } function Ys(r) { return Array.isArray(r) ? r.map(Ys) : typeof r == "object" && r ? Mr(r, Ys) : r; } const Sr = {}; function mi(r) { Sr[r] || (typeof console < "u" && console.warn(r), Sr[r] = !0); } function On(r, e, n) { return (n.y - r.y) * (e.x - r.x) > (e.y - r.y) * (n.x - r.x); } function Vn(r) { let e = 0; for (let n, o, u = 0, l = r.length, f = l - 1; u < l; f = u++) n = r[u], o = r[f], e += (o.x - n.x) * (n.y + o.y); return e; } function Zi([r, e, n]) { const o = vi(e + 90), u = vi(n); return { x: r * Math.cos(o) * Math.sin(u), y: r * Math.sin(o) * Math.sin(u), z: r * Math.cos(u), azimuthal: e, polar: n }; } function Jn() { return typeof WorkerGlobalScope < "u" && typeof self < "u" && self instanceof WorkerGlobalScope; } function Fn(r) { const e = {}; if (r.replace(/(?:^|(?:\s*\,\s*))([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g, (n, o, u, l) => { const f = u || l; return e[o] = !f || f.toLowerCase(), ""; }), e["max-age"]) { const n = parseInt(e["max-age"], 10); isNaN(n) ? delete e["max-age"] : e["max-age"] = n; } return e; } let Ls = null; function zs(r, e) { return [r[4 * e], r[4 * e + 1], r[4 * e + 2], r[4 * e + 3]]; } function Vo(r, e, n, o) { for (; e < n; ) { const u = e + n >> 1; r[u] < o ? e = u + 1 : n = u; } return e; } function Ke(r, e, n, o) { for (; e < n; ) { const u = e + n >> 1; r[u] <= o ? e = u + 1 : n = u; } return e; } function re(r) { return r > 0 ? 1 / (1.001 - r) : 1 + r; } function le(r) { return r > 0 ? 1 - 1 / (1.001 - r) : -r; } const ge = { API_URL: "https://api.mapbox.com", get API_URL_REGEX() { return /^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/|\?|$)/i; }, 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 (!ge.API_URL) return null; try { const r = new URL(ge.API_URL); return r.hostname === "api.mapbox.cn" ? "https://events.mapbox.cn/events/v2" : r.hostname === "api.mapbox.com" ? "https://events.mapbox.com/events/v2" : null; } catch { return null; } }, SESSION_PATH: "/map-sessions/v1", FEEDBACK_URL: "https://apps.mapbox.com/feedback", TILE_URL_VERSION: "v4", RASTER_URL_PREFIX: "raster/v1", RASTERARRAYS_URL_PREFIX: "rasterarrays/v1", REQUIRE_ACCESS_TOKEN: !0, ACCESS_TOKEN: null, DEFAULT_STYLE: "mapbox://styles/mapbox/standard", MAX_PARALLEL_IMAGE_REQUESTS: 16, DRACO_URL: "https://api.mapbox.com/mapbox-gl-js/draco_decoder_gltf_v1.5.6.wasm", MESHOPT_URL: "https://api.mapbox.com/mapbox-gl-js/meshopt_base_v0.20.wasm", MESHOPT_SIMD_URL: "https://api.mapbox.com/mapbox-gl-js/meshopt_simd_v0.20.wasm", GLYPHS_URL: "mapbox://fonts/mapbox/{fontstack}/{range}.pbf", TILES3D_URL_PREFIX: "3dtiles/v1" }; function Le(r) { return ge.API_URL_REGEX.test(r); } function Ce(r) { return ge.API_SPRITE_REGEX.test(r); } let Be, qe, Pe, Ye, Qe, it; function mt() { return Be == null && (Be = self.OffscreenCanvas && new OffscreenCanvas(1, 1).getContext("2d") && typeof self.createImageBitmap == "function"), Be; } const Ct = { now: () => Ye !== void 0 ? Ye : performance.now(), setNow(r) { Ye = r; }, restoreNow() { Ye = void 0; }, frame(r) { const e = requestAnimationFrame(r); return { cancel: () => cancelAnimationFrame(e) }; }, getImageData(r, e = 0) { const { width: n, height: o } = r; Qe || (Qe = document.createElement("canvas")); const u = Qe.getContext("2d", { willReadFrequently: !0 }); if (!u) throw new Error("failed to create canvas 2d context"); return (n > Qe.width || o > Qe.height) && (Qe.width = n, Qe.height = o), u.clearRect(-e, -e, n + 2 * e, o + 2 * e), u.drawImage(r, 0, 0, n, o), u.getImageData(-e, -e, n + 2 * e, o + 2 * e); }, resolveURL: (r) => (qe || (qe = document.createElement("a")), qe.href = r, qe.href), get devicePixelRatio() { return window.devicePixelRatio; }, get prefersReducedMotion() { return !!window.matchMedia && (Pe == null && (Pe = window.matchMedia("(prefers-reduced-motion: reduce)")), Pe.matches); }, hasCanvasFingerprintNoise() { if (it !== void 0) return it; if (!mt()) return it = !1, !1; const r = new OffscreenCanvas(85, 1), e = r.getContext("2d", { willReadFrequently: !0 }); let n = 0; for (let u = 0; u < r.width; ++u) e.fillStyle = `rgba(${n++},${n++},${n++}, 255)`, e.fillRect(u, 0, 1, 1); const o = e.getImageData(0, 0, r.width, r.height); n = 0; for (let u = 0; u < o.data.length; ++u) if (u % 4 != 3 && n++ !== o.data[u]) return it = !0, !0; return it = !1, !1; } }; function It(r, e) { const n = r.indexOf("?"); if (n < 0) return `${r}?${new URLSearchParams(e).toString()}`; const o = new URLSearchParams(r.slice(n)); for (const u in e) o.set(u, e[u]); return `${r.slice(0, n)}?${o.toString()}`; } function Kt(r, e = { persistentParams: [] }) { const n = r.indexOf("?"); if (n < 0) return r; const o = new URLSearchParams(), u = new URLSearchParams(r.slice(n)); for (const f of e.persistentParams) { const v = u.get(f); v && o.set(f, v); } const l = o.toString(); return `${r.slice(0, n)}${l.length > 0 ? `?${l}` : ""}`; } const di = "mapbox-tiles"; let li = 500, ri = 50; const Ki = ["language", "worldview", "jobid"]; let Ni, Ei; function $i() { try { return caches; } catch { } } function Hi() { const r = $i(); r && Ni == null && (Ni = r.open(di)); } let Xn = 1 / 0; const Gs = { supported: !1, testSupport: function(r) { !ra && vs && (Er ? cl(r) : ps = r); } }; let ps, vs, ra = !1, Er = !1; const oa = typeof self < "u" ? self : {}; function cl(r) { const e = r.createTexture(); r.bindTexture(r.TEXTURE_2D, e); try { if (r.texImage2D(r.TEXTURE_2D, 0, r.RGBA, r.RGBA, r.UNSIGNED_BYTE, vs), r.isContextLost()) return; Gs.supported = !0; } catch { } r.deleteTexture(e), ra = !0; } oa.document && (vs = oa.document.createElement("img"), vs.onload = function() { ps && cl(ps), ps = null, Er = !0; }, vs.onerror = function() { ra = !0, ps = null; }, vs.src = ""); const Uo = { Unknown: "Unknown", Style: "Style", Source: "Source", Tile: "Tile", Glyphs: "Glyphs", SpriteImage: "SpriteImage", SpriteJSON: "SpriteJSON", Iconset: "Iconset", Image: "Image", Model: "Model" }; typeof Object.freeze == "function" && Object.freeze(Uo); class jo extends Error { constructor(e, n, o) { n === 401 && Le(o) && (e += ": you may have provided an invalid Mapbox access token. See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes"), super(e), this.status = n, this.url = o; } toString() { return `${this.name}: ${this.message} (${this.status}): ${this.url}`; } } const tn = Jn() ? () => self.worker && self.worker.referrer : () => (location.protocol === "blob:" ? parent : self).location.href, xn = function(r, e) { if (!(/^file:/.test(n = r.url) || /^file:/.test(tn()) && !/^\w+:/.test(n))) { if (self.fetch && self.Request && self.AbortController && Request.prototype.hasOwnProperty("signal")) return function(o, u) { const l = new AbortController(), f = new Request(o.url, { method: o.method || "GET", body: o.body, credentials: o.credentials, headers: o.headers, referrer: tn(), referrerPolicy: o.referrerPolicy, signal: l.signal }); let v = !1, S = !1; const D = (x = f.url).indexOf("sku=") > 0 && Le(x); var x; o.type === "json" && f.headers.set("Accept", "application/json"); const P = (M, C, k) => { if (S) return; if (M && M.message !== "SecurityError" && mi(M.toString()), C && k) return I(C); const V = Date.now(); fetch(f).then((U) => { if (U.ok) { const q = D ? U.clone() : null; return I(U, q, V); } return u(new jo(U.statusText, U.status, o.url)); }).catch((U) => { U.name !== "AbortError" && u(new Error(`${U.message} ${o.url}`)); }); }, I = (M, C, k) => { (o.type === "arrayBuffer" ? M.arrayBuffer() : o.type === "json" ? M.json() : M.text()).then((V) => { S || (C && k && function(U, q, $) { if (Hi(), Ni == null) return; const H = Fn(q.headers.get("Cache-Control") || ""); if (H["no-store"]) return; const K = { status: q.status, statusText: q.statusText, headers: new Headers() }; q.headers.forEach((fe, de) => K.headers.set(de, fe)), H["max-age"] && K.headers.set("Expires", new Date($ + 1e3 * H["max-age"]).toUTCString()); const Q = K.headers.get("Expires"); if (!Q || new Date(Q).getTime() - $ < 42e4) return; let ie = Kt(U.url, { persistentParams: Ki }); if (q.status === 206) { const fe = U.headers.get("Range"); if (!fe) return; K.status = 200, ie = It(ie, { range: fe }); } (function(fe, de) { if (Ei === void 0) try { new Response(new ReadableStream()), Ei = !0; } catch { Ei = !1; } Ei ? de(fe.body) : fe.blob().then(de); })(q, (fe) => { const de = new Response((ue = q.status) !== 200 && ue !== 404 && [101, 103, 204, 205, 304].includes(ue) ? null : fe, K); var ue; Hi(), Ni != null && Ni.then((Se) => Se.put(ie, de)).catch((Se) => mi(Se.message)); }); }(f, C, k), v = !0, u(null, V, M.headers.get("Cache-Control"), M.headers.get("Expires"))); }).catch((V) => { S || u(new Error(V.message)); }); }; return D ? function(M, C) { if (Hi(), Ni == null) return C(null); Ni.then((k) => { let V = Kt(M.url, { persistentParams: Ki }); const U = M.headers.get("Range"); U && (V = It(V, { range: U })), k.match(V).then((q) => { const $ = function(H) { if (!H) return !1; const K = new Date(H.headers.get("Expires") || 0), Q = Fn(H.headers.get("Cache-Control") || ""); return K > Date.now() && !Q["no-cache"]; }(q); k.delete(V), $ && k.put(V, q.clone()), C(null, q, $); }).catch(C); }).catch(C); }(f, P) : P(null, null), { cancel: () => { S = !0, v || l.abort(); } }; }(r, e); if (Jn() && self.worker && self.worker.actor) return self.worker.actor.send("getResource", r, e, void 0, !0); } var n; return function(o, u) { const l = new XMLHttpRequest(); l.open(o.method || "GET", o.url, !0), o.type === "arrayBuffer" && (l.responseType = "arraybuffer"); for (const f in o.headers) l.setRequestHeader(f, o.headers[f]); return o.type === "json" && (l.responseType = "text", l.setRequestHeader("Accept", "application/json")), l.withCredentials = o.credentials === "include", l.onerror = () => { u(new Error(l.statusText)); }, l.onload = () => { if ((l.status >= 200 && l.status < 300 || l.status === 0) && l.response !== null) { let f = l.response; if (o.type === "json") try { f = JSON.parse(l.response); } catch (v) { return u(v); } u(null, f, l.getResponseHeader("Cache-Control"), l.getResponseHeader("Expires")); } else u(new jo(l.statusText, l.status, o.url)); }, l.send(o.body), { cancel: () => l.abort() }; }(r, e); }, no = function(r, e) { return xn(An(r, { type: "arrayBuffer" }), e); }; function Go(r) { const e = document.createElement("a"); return e.href = r, e.protocol === location.protocol && e.host === location.host; } const aa = ""; let Da, Vi; Da = [], Vi = 0; const Hn = function(r, e) { if (Gs.supported && (r.headers || (r.headers = {}), r.headers.accept = "image/webp,*/*"), Vi >= ge.MAX_PARALLEL_IMAGE_REQUESTS) { const l = { requestParameters: r, callback: e, cancelled: !1, cancel() { this.cancelled = !0; } }; return Da.push(l), l; } Vi++; let n = !1; const o = () => { if (!n) for (n = !0, Vi--; Da.length && Vi < ge.MAX_PARALLEL_IMAGE_REQUESTS; ) { const l = Da.shift(), { requestParameters: f, callback: v, cancelled: S } = l; S || (l.cancel = Hn(f, v).cancel); } }, u = no(r, (l, f, v, S) => { o(), l ? e(l) : f && (self.createImageBitmap ? function(D, x) { const P = new Blob([new Uint8Array(D)], { type: "image/png" }); createImageBitmap(P).then((I) => { x(null, I); }).catch((I) => { x(new Error(`Could not load image because of ${I.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`)); }); }(f, (D, x) => e(D, x, v, S)) : function(D, x) { const P = new Image(); P.onload = () => { x(null, P), URL.revokeObjectURL(P.src), P.onload = null, requestAnimationFrame(() => { P.src = aa; }); }, P.onerror = () => x(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 I = new Blob([new Uint8Array(D)], { type: "image/png" }); P.src = D.byteLength ? URL.createObjectURL(I) : aa; }(f, (D, x) => e(D, x, v, S))); }); return { cancel: () => { u.cancel(), o(); } }; }; var hl, Zs, Qn, Pr = { exports: {} }, nr = { exports: {} }, Ks = { exports: {} }, Yn = function() { if (Qn) return Pr.exports; Qn = 1; var r = (hl || (hl = 1, nr.exports = function(n, o) { var u, l, f, v, S, D, x, P; for (l = n.length - (u = 3 & n.length), f = o, S = 3432918353, D = 461845907, P = 0; P < l; ) x = 255 & n.charCodeAt(P) | (255 & n.charCodeAt(++P)) << 8 | (255 & n.charCodeAt(++P)) << 16 | (255 & n.charCodeAt(++P)) << 24, ++P, f = 27492 + (65535 & (v = 5 * (65535 & (f = (f ^= x = (65535 & (x = (x = (65535 & x) * S + (((x >>> 16) * S & 65535) << 16) & 4294967295) << 15 | x >>> 17)) * D + (((x >>> 16) * D & 65535) << 16) & 4294967295) << 13 | f >>> 19)) + ((5 * (f >>> 16) & 65535) << 16) & 4294967295)) + ((58964 + (v >>> 16) & 65535) << 16); switch (x = 0, u) { case 3: x ^= (255 & n.charCodeAt(P + 2)) << 16; case 2: x ^= (255 & n.charCodeAt(P + 1)) << 8; case 1: f ^= x = (65535 & (x = (x = (65535 & (x ^= 255 & n.charCodeAt(P))) * S + (((x >>> 16) * S & 65535) << 16) & 4294967295) << 15 | x >>> 17)) * D + (((x >>> 16) * D & 65535) << 16) & 4294967295; } return f ^= n.length, f = 2246822507 * (65535 & (f ^= f >>> 16)) + ((2246822507 * (f >>> 16) & 65535) << 16) & 4294967295, f = 3266489909 * (65535 & (f ^= f >>> 13)) + ((3266489909 * (f >>> 16) & 65535) << 16) & 4294967295, (f ^= f >>> 16) >>> 0; }), nr.exports), e = (Zs || (Zs = 1, Ks.exports = function(n, o) { for (var u, l = n.length, f = o ^ l, v = 0; l >= 4; ) u = 1540483477 * (65535 & (u = 255 & n.charCodeAt(v) | (255 & n.charCodeAt(++v)) << 8 | (255 & n.charCodeAt(++v)) << 16 | (255 & n.charCodeAt(++v)) << 24)) + ((1540483477 * (u >>> 16) & 65535) << 16), f = 1540483477 * (65535 & f) + ((1540483477 * (f >>> 16) & 65535) << 16) ^ (u = 1540483477 * (65535 & (u ^= u >>> 24)) + ((1540483477 * (u >>> 16) & 65535) << 16)), l -= 4, ++v; switch (l) { case 3: f ^= (255 & n.charCodeAt(v + 2)) << 16; case 2: f ^= (255 & n.charCodeAt(v + 1)) << 8; case 1: f = 1540483477 * (65535 & (f ^= 255 & n.charCodeAt(v))) + ((1540483477 * (f >>> 16) & 65535) << 16); } return f = 1540483477 * (65535 & (f ^= f >>> 13)) + ((1540483477 * (f >>> 16) & 65535) << 16), (f ^= f >>> 15) >>> 0; }), Ks.exports); return Pr.exports = r, Pr.exports.murmur3 = r, Pr.exports.murmur2 = e, Pr.exports; }(), $r = O(Yn); class Ar { constructor(e, ...n) { An(this, n[0] || {}), this.type = e; } } class Cr extends Ar { constructor(e, n = {}) { super("error", An({ error: e }, n)); } } function ka(r, e, n) { n[r] && n[r].indexOf(e) !== -1 || (n[r] = n[r] || [], n[r].push(e)); } function la(r, e, n) { if (n && n[r]) { const o = n[r].indexOf(e); o !== -1 && n[r].splice(o, 1); } } class Zo { on(e, n) { return this._listeners = this._listeners || {}, ka(e, n, this._listeners), this; } off(e, n) { return la(e, n, this._listeners), la(e, n, this._oneTimeListeners), this; } once(e, n) { return n ? (this._oneTimeListeners = this._oneTimeListeners || {}, ka(e, n, this._oneTimeListeners), this) : new Promise((o) => this.once(e, o)); } fire(e, n) { const o = typeof e == "string" ? new Ar(e, n) : e, u = o.type; if (this.listens(u)) { o.target = this; const l = this._listeners && this._listeners[u] ? this._listeners[u].slice() : []; for (const S of l) S.call(this, o); const f = this._oneTimeListeners && this._oneTimeListeners[u] ? this._oneTimeListeners[u].slice() : []; for (const S of f) la(u, S, this._oneTimeListeners), S.call(this, o); const v = this._eventedParent; v && (An(o, typeof this._eventedParentData == "function" ? this._eventedParentData() : this._eventedParentData), v.fire(o)); } else o instanceof Cr && console.error(o.error); return this; } listens(e) { return !!(this._listeners && this._listeners[e] && this._listeners[e].length > 0 || this._oneTimeListeners && this._oneTimeListeners[e] && this._oneTimeListeners[e].length > 0 || this._eventedParent && this._eventedParent.listens(e)); } setEventedParent(e, n) { return this._eventedParent = e, this._eventedParentData = n, this; } } var sr, ca = {}, Ra = function() { if (sr) return ca; sr = 1; var r = { 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(l) { return (l = Math.round(l)) < 0 ? 0 : l > 255 ? 255 : l; } function n(l) { return e(l[l.length - 1] === "%" ? parseFloat(l) / 100 * 255 : parseInt(l)); } function o(l) { return (f = l[l.length - 1] === "%" ? parseFloat(l) / 100 : parseFloat(l)) < 0 ? 0 : f > 1 ? 1 : f; var f; } function u(l, f, v) { return v < 0 ? v += 1 : v > 1 && (v -= 1), 6 * v < 1 ? l + (f - l) * v * 6 : 2 * v < 1 ? f : 3 * v < 2 ? l + (f - l) * (2 / 3 - v) * 6 : l; } try { ca.parseCSSColor = function(l) { var f, v = l.replace(/ /g, "").toLowerCase(); if (v in r) return r[v].slice(); if (v[0] === "#") return v.length === 4 ? (f = parseInt(v.substr(1), 16)) >= 0 && f <= 4095 ? [(3840 & f) >> 4 | (3840 & f) >> 8, 240 & f | (240 & f) >> 4, 15 & f | (15 & f) << 4, 1] : null : v.length === 7 && (f = parseInt(v.substr(1), 16)) >= 0 && f <= 16777215 ? [(16711680 & f) >> 16, (65280 & f) >> 8, 255 & f, 1] : null; var S = v.indexOf("("), D = v.indexOf(")"); if (S !== -1 && D + 1 === v.length) { var x = v.substr(0, S), P = v.substr(S + 1, D - (S + 1)).split(","), I = 1; switch (x) { case "rgba": if (P.length !== 4) return null; I = o(P.pop()); case "rgb": return P.length !== 3 ? null : [n(P[0]), n(P[1]), n(P[2]), I]; case "hsla": if (P.length !== 4) return null; I = o(P.pop()); case "hsl": if (P.length !== 3) return null; var M = (parseFloat(P[0]) % 360 + 360) % 360 / 360, C = o(P[1]), k = o(P[2]), V = k <= 0.5 ? k * (C + 1) : k + C - k * C, U = 2 * k - V; return [e(255 * u(U, V, M + 1 / 3)), e(255 * u(U, V, M)), e(255 * u(U, V, M - 1 / 3)), I]; default: return null; } } return null; }; } catch { } return ca; }(); class ki { constructor(e, n, o, u = 1) { this.r = e, this.g = n, this.b = o, this.a = u; } static parse(e) { if (!e) return; if (e instanceof ki) return e; if (typeof e != "string") return; const n = Ra.parseCSSColor(e); return n ? new ki(n[0] / 255 * n[3], n[1] / 255 * n[3], n[2] / 255 * n[3], n[3]) : void 0; } toStringPremultipliedAlpha() { const [e, n, o, u] = this.a === 0 ? [0, 0, 0, 0] : [255 * this.r / this.a, 255 * this.g / this.a, 255 * this.b / this.a, this.a]; return `rgba(${Math.round(e)},${Math.round(n)},${Math.round(o)},${u})`; } toString() { const [e, n, o, u] = [this.r, this.g, this.b, this.a]; return `rgba(${Math.round(255 * e)},${Math.round(255 * n)},${Math.round(255 * o)},${u})`; } toRenderColor(e) { const { r: n, g: o, b: u, a: l } = this; return new Gl(e, n, o, u, l); } clone() { return new ki(this.r, this.g, this.b, this.a); } } class Gl { constructor(e, n, o, u, l) { if (e) { const f = e.image.height, v = f * f; n = l === 0 ? 0 : n / l * (f - 1), o = l === 0 ? 0 : o / l * (f - 1), u = l === 0 ? 0 : u / l * (f - 1); const S = Math.floor(n), D = Math.floor(o), x = Math.floor(u), P = Math.ceil(n), I = Math.ceil(o), M = Math.ceil(u), C = n - S, k = o - D, V = u - x, U = e.image.data, q = 4 * (S + D * v + x * f), $ = 4 * (S + D * v + M * f), H = 4 * (S + I * v + x * f), K = 4 * (S + I * v + M * f), Q = 4 * (P + D * v + x * f), ie = 4 * (P + D * v + M * f), fe = 4 * (P + I * v + x * f), de = 4 * (P + I * v + M * f); if (q < 0 || de >= U.length) throw new Error("out of range"); this.r = ei(ei(ei(U[q], U[$], V), ei(U[H], U[K], V), k), ei(ei(U[Q], U[ie], V), ei(U[fe], U[de], V), k), C) / 255 * l, this.g = ei(ei(ei(U[q + 1], U[$ + 1], V), ei(U[H + 1], U[K + 1], V), k), ei(ei(U[Q + 1], U[ie + 1], V), ei(U[fe + 1], U[de + 1], V), k), C) / 255 * l, this.b = ei(ei(ei(U[q + 2], U[$ + 2], V), ei(U[H + 2], U[K + 2], V), k), ei(ei(U[Q + 2], U[ie + 2], V), ei(U[fe + 2], U[de + 2], V), k), C) / 255 * l, this.a = l; } else this.r = n, this.g = o, this.b = u, this.a = l; } toArray() { const { r: e, g: n, b: o, a: u } = this; return u === 0 ? [0, 0, 0, 0] : [255 * e / u, 255 * n / u, 255 * o / u, u]; } toHslaArray() { if (this.a === 0) return [0, 0, 0, 0]; const { r: e, g: n, b: o, a: u } = this, l = Math.min(Math.max(e / u, 0), 1), f = Math.min(Math.max(n / u, 0), 1), v = Math.min(Math.max(o / u, 0), 1), S = Math.min(l, f, v), D = Math.max(l, f, v), x = (S + D) / 2; if (S === D) return [0, 0, 100 * x, u]; const P = D - S, I = x > 0.5 ? P / (2 - D - S) : P / (D + S); let M = 0; return D === l ? M = (f - v) / P + (f < v ? 6 : 0) : D === f ? M = (v - l) / P + 2 : D === v && (M = (l - f) / P + 4), M *= 60, [Math.min(Math.max(M, 0), 360), Math.min(Math.max(100 * I, 0), 100), Math.min(Math.max(100 * x, 0), 100), u]; } toArray01() { const { r: e, g: n, b: o, a: u } = this; return u === 0 ? [0, 0, 0, 0] : [e / u, n / u, o / u, u]; } toArray01Scaled(e) { const { r: n, g: o, b: u, a: l } = this; return l === 0 ? [0, 0, 0] : [n / l * e, o / l * e, u / l * e]; } toArray01PremultipliedAlpha() { const { r: e, g: n, b: o, a: u } = this; return [e, n, o, u]; } toArray01Linear() { const { r: e, g: n, b: o, a: u } = this; return u === 0 ? [0, 0, 0, 0] : [Math.pow(e / u, 2.2), Math.pow(n / u, 2.2), Math.pow(o / u, 2.2), u]; } } function ei(r, e, n) { return r * (1 - n) + e * n; } function ul(r, e, n) { return r.map((o, u) => ei(o, e[u], n)); } ki.black = new ki(0, 0, 0, 1), ki.white = new ki(1, 1, 1, 1), ki.transparent = new ki(0, 0, 0, 0), ki.red = new ki(1, 0, 0, 1), ki.blue = new ki(0, 0, 1, 1); var Oi = Object.freeze({ __proto__: null, array: ul, color: function(r, e, n) { return new ki(ei(r.r, e.r, n), ei(r.g, e.g, n), ei(r.b, e.b, n), ei(r.a, e.a, n)); }, number: ei }); function Bi(r, ...e) { for (const n of e) for (const o in n) r[o] = n[o]; return r; } class ns extends Error { constructor(e, n) { super(n), this.message = n, this.key = e; } } class Cn { constructor(e, n = []) { this.parent = e, this.bindings = {}; for (const [o, u] of n) this.bindings[o] = u; } concat(e) { return new Cn(this, e); } get(e) { if (this.bindings[e]) return this.bindings[e]; if (this.parent) return this.parent.get(e); throw new Error(`${e} not found in scope.`); } has(e) { return !!this.bindings[e] || !!this.parent && this.parent.has(e); } } const ha = { kind: "null" }, Ot = { kind: "number" }, Fi = { kind: "string" }, Li = { kind: "boolean" }, ms = { kind: "color" }, bo = { kind: "object" }, Pi = { kind: "value" }, _s = { kind: "collator" }, Js = { kind: "formatted" }, Ho = { kind: "resolvedImage" }; function Ss(r, e) { return { kind: "array", itemType: r, N: e }; } function un(r) { if (r.kind === "array") { const e = un(r.itemType); return typeof r.N == "number" ? `array<${e}, ${r.N}>` : r.itemType.kind === "value" ? "array" : `array<${e}>`; } return r.kind; } const Bc = [ha, Ot, Fi, Li, ms, Js, bo, Ss(Pi), Ho]; function ua(r, e) { if (e.kind === "error") return null; if (r.kind === "array") { if (e.kind === "array" && (e.N === 0 && e.itemType.kind === "value" || !ua(r.itemType, e.itemType)) && (typeof r.N != "number" || r.N === e.N)) return null; } else { if (r.kind === e.kind) return null; if (r.kind === "value") { for (const n of Bc) if (!ua(n, e)) return null; } } return `Expected ${un(r)} but found ${un(e)} instead.`; } function Zl(r, e) { return e.some((n) => n.kind === r.kind); } function da(r, e) { return e.some((n) => n === "null" ? r === null : n === "array" ? Array.isArray(r) : n === "object" ? r && !Array.isArray(r) && typeof r == "object" : n === typeof r); } class nn { constructor(e, n, o) { this.sensitivity = e ? n ? "variant" : "case" : n ? "accent" : "base", this.locale = o, this.collator = new Intl.Collator(this.locale ? this.locale : [], { sensitivity: this.sensitivity, usage: "search" }); } compare(e, n) { return this.collator.compare(e, n); } resolvedLocale() { return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale; } } class dl { constructor(e, n, o, u, l) { this.text = e.normalize ? e.normalize() : e, this.image = n, this.scale = o, this.fontStack = u, this.textColor = l; } } class Dn { constructor(e) { this.sections = e; } static fromString(e) { return new Dn([new dl(e, null, null, null, null)]); } isEmpty() { return this.sections.length === 0 || !this.sections.some((e) => e.text.length !== 0 || e.image && e.image.namePrimary); } static factory(e) { return e instanceof Dn ? e : Dn.fromString(e); } toString() { return this.sections.length === 0 ? "" : this.sections.map((e) => e.text).join(""); } serialize() { const e = ["format"]; for (const n of this.sections) { if (n.image) { e.push(["image", n.image.namePrimary]); continue; } e.push(n.text); const o = {}; n.fontStack && (o["text-font"] = ["literal", n.fontStack.split(",")]), n.scale && (o["font-scale"] = n.scale), n.textColor && (o["text-color"] = ["rgba"].concat(n.textColor.toRenderColor(null).toArray())), e.push(o); } return e; } } class rr { constructor(e, n) { if (this.id = e, this.options = n || { params: {} }, this.options.transform) { const { a: o, b: u, c: l, d: f, e: v, f: S } = this.options.transform; this.options.transform = new DOMMatrix([o, u, l, f, v, S]); } else this.options.transform = new DOMMatrix([1, 0, 0, 1, 0, 0]); } static deserializeId(e) { return JSON.parse(e).id; } static deserializeFromString(e) { const n = JSON.parse(e), { a: o, b: u, c: l, d: f, e: v, f: S } = n.options.transform; return new DOMMatrix([o, u, l, f, v, S]), new rr(n.id, n.options); } scaleSelf(e) { return this.options.transform = this.options.transform.scale(e), this; } serialize() { const e = { id: this.id }; this.options && (e.options = this.options); const { a: n, b: o, c: u, d: l, e: f, f: v } = this.options.transform; return e.options.transform = { a: n, b: o, c: u, d: l, e: f, f: v }, JSON.stringify(e); } } class ss { constructor(e) { this.namePrimary = e.namePrimary, e.nameSecondary && (this.nameSecondary = e.nameSecondary), e.optionsPrimary && (this.optionsPrimary = e.optionsPrimary), e.optionsSecondary && (this.optionsSecondary = e.optionsSecondary), this.available = e.available; } toString() { return this.namePrimary && this.nameSecondary ? `[${this.namePrimary},${this.nameSecondary}]` : this.namePrimary; } getPrimary() { return new rr(this.namePrimary, { params: this.optionsPrimary && this.optionsPrimary.params || {} }); } getSerializedPrimary() { return this.getPrimary().serialize(); } getSecondary() { return this.nameSecondary ? new rr(this.nameSecondary, { params: this.optionsSecondary && this.optionsSecondary.params || {} }) : null; } static from(e) { return typeof e == "string" ? ss.build(e) : e; } static build(e, n, o, u) { return e ? new ss({ namePrimary: e, nameSecondary: n, optionsPrimary: o, optionsSecondary: u, available: !1 }) : null; } } function fa(r, e, n, o) { return typeof r == "number" && r >= 0 && r <= 255 && typeof e == "number" && e >= 0 && e <= 255 && typeof n == "number" && n >= 0 && n <= 255 ? o === void 0 || typeof o == "number" && o >= 0 && o <= 1 ? null : `Invalid rgba value [${[r, e, n, o].join(", ")}]: 'a' must be between 0 and 1.` : `Invalid rgba value [${(typeof o == "number" ? [r, e, n, o] : [r, e, n]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.`; } function wo(r) { if (r === null || typeof r == "string" || typeof r == "boolean" || typeof r == "number" || r instanceof ki || r instanceof nn || r instanceof Dn || r instanceof ss) return !0; if (Array.isArray(r)) { for (const e of r) if (!wo(e)) return !1; return !0; } if (typeof r == "object") { for (const e in r) if (!wo(r[e])) return !1; return !0; } return !1; } function vn(r) { if (r === null) return ha; if (typeof r == "string") return Fi; if (typeof r == "boolean") return Li; if (typeof r == "number") return Ot; if (r instanceof ki) return ms; if (r instanceof nn) return _s; if (r instanceof Dn) return Js; if (r instanceof ss) return Ho; if (Array.isArray(r)) { const e = r.length; let n; for (const o of r) { const u = vn(o); if (n) { if (n === u) continue; n = Pi; break; } n = u; } return Ss(n || Pi, e); } return bo; } function Ir(r) { const e = typeof r; return r === null ? "" : e === "string" || e === "number" || e === "boolean" ? String(r) : r instanceof ki ? r.toStringPremultipliedAlpha() : r instanceof Dn || r instanceof ss ? r.toString() : JSON.stringify(r); } class Lr { constructor(e, n) { this.type = e, this.value = n; } static parse(e, n) { if (e.length !== 2) return n.error(`'literal' expression requires exactly one argument, but found ${e.length - 1} instead.`); if (!wo(e[1])) return n.error("invalid value"); const o = e[1]; let u = vn(o); const l = n.expectedType; return u.kind !== "array" || u.N !== 0 || !l || l.kind !== "array" || typeof l.N == "number" && l.N !== 0 || (u = l), new Lr(u, o); } evaluate() { return this.value; } eachChild() { } outputDefined() { return !0; } serialize() { return this.type.kind === "array" || this.type.kind === "object" ? ["literal", this.value] : this.value instanceof ki ? ["rgba"].concat(this.value.toRenderColor(null).toArray()) : this.value instanceof Dn ? this.value.serialize() : this.value; } } class qn { constructor(e) { this.name = "ExpressionEvaluationError", this.message = e; } toJSON() { return this.message; } } const pa = { string: Fi, number: Ot, boolean: Li, object: bo }; class zr { constructor(e, n) { this.type = e, this.args = n; } static parse(e, n) { if (e.length < 2) return n.error("Expected at least one argument."); let o, u = 1; const l = e[0]; if (l === "array") { let v, S; if (e.length > 2) { const D = e[1]; if (typeof D != "string" || !(D in pa) || D === "object") return n.error('The item type argument of "array" must be one of string, number, boolean', 1); v = pa[D], u++; } else v = Pi; if (e.length > 3) { if (e[2] !== null && (typeof e[2] != "number" || e[2] < 0 || e[2] !== Math.floor(e[2]))) return n.error('The length argument to "array" must be a positive integer literal', 2); S = e[2], u++; } o = Ss(v, S); } else o = pa[l]; const f = []; for (; u < e.length; u++) { const v = n.parse(e[u], u, Pi); if (!v) return null; f.push(v); } return new zr(o, f); } evaluate(e) { for (let n = 0; n < this.args.length; n++) { const o = this.args[n].evaluate(e); if (!ua(this.type, vn(o))) return o; if (n === this.args.length - 1) throw new qn(`The expression ${JSON.stringify(this.args[n].serialize())} evaluated to ${un(vn(o))} but was expected to be of type ${un(this.type)}.`); } return null; } eachChild(e) { this.args.forEach(e); } outputDefined() { return this.args.every((e) => e.outputDefined()); } serialize() { const e = this.type, n = [e.kind]; if (e.kind === "array") { const o = e.itemType; if (o.kind === "string" || o.kind === "number" || o.kind === "boolean") { n.push(o.kind); const u = e.N; (typeof u == "number" || this.args.length > 1) && n.push(u); } } return n.concat(this.args.map((o) => o.serialize())); } } class Es { constructor(e) { this.type = Js, this.sections = e; } static parse(e, n) { if (e.length < 2) return n.error("Expected at least one argument."); const o = e[1]; if (!Array.isArray(o) && typeof o == "object") return n.error("First argument must be an image or text section."); const u = []; let l = !1; for (let f = 1; f <= e.length - 1; ++f) { const v = e[f]; if (l && typeof v == "object" && !Array.isArray(v)) { l = !1; let S = null; if (v["font-scale"] && (S = n.parseObjectValue(v["font-scale"], f, "font-scale", Ot), !S)) return null; let D = null; if (v["text-font"] && (D = n.parseObjectValue(v["text-font"], f, "text-font", Ss(Fi)), !D)) return null; let x = null; if (v["text-color"] && (x = n.parseObjectValue(v["text-color"], f, "text-color", ms), !x)) return null; const P = u[u.length - 1]; P.scale = S, P.font = D, P.textColor = x; } else { const S = n.parse(e[f], f, Pi); if (!S) return null; const D = S.type.kind; if (D !== "string" && D !== "value" && D !== "null" && D !== "resolvedImage") return n.error("Formatted text type must be 'string', 'value', 'image' or 'null'."); l = !0, u.push({ content: S, scale: null, font: null, textColor: null }); } } return new Es(u); } evaluate(e) { return new Dn(this.sections.map((n) => { const o = n.content.evaluate(e); return vn(o) === Ho ? new dl("", o, null, null, null) : new dl(Ir(o), null, n.scale ? n.scale.evaluate(e) : null, n.font ? n.font.evaluate(e).join(",") : null, n.textColor ? n.textColor.evaluate(e) : null); })); } eachChild(e) { for (const n of this.sections) e(n.content), n.scale && e(n.scale), n.font && e(n.font), n.textColor && e(n.textColor); } outputDefined() { return !1; } serialize() { const e = ["format"]; for (const n of this.sections) { e.push(n.content.serialize()); const o = {}; n.scale && (o["font-scale"] = n.scale.serialize()), n.font && (o["text-font"] = n.font.serialize()), n.textColor && (o["text-color"] = n.textColor.serialize()), e.push(o); } return e; } } class Oa { constructor(e, n, o, u) { this._imageWarnHistory = {}, this.type = Ho, this.inputPrimary = e, this.inputSecondary = n, this.inputPrimaryParams = o, this.inputSecondaryParams = u; } static parse(e, n) { if (e.length < 2) return n.error("Expected two or more arguments."); let o = 1; const u = []; function l() { if (o < e.length) { const v = n.parse(e[o], o++, Fi); return v ? (u.push({ image: v, options: void 0 }), !0) : (n.error(u.length ? "Secondary image variant is not a string." : "No image name provided."), !1); } return !0; } function f() { if (o < e.length) { if ((v = e[o]) === null || typeof v != "object" || Array.isArray(v)) return !0; const S = e[o].params, D = n.concat(o); if (!S) return o++, !0; if (typeof S != "object" || S.constructor !== Object) return D.error('Image options "params" should be an object'), !1; const x = {}, P = D.concat(void 0, "params"); for (const I in S) { if (!I) return P.error("Image parameter name should be non-empty"), !1; const M = P.concat(void 0, I).parse(S[I], void 0, ms, void 0, { typeAnnotation: "coerce" }); if (!M) return !1; x[I] = M; } return u[u.length - 1].options = x, o++, !0; } var v; return !0; } for (let v = 0; v < 2; v++) if (!l() || !f()) return; return new Oa(u[0].image, u[1] ? u[1].image : void 0, u[0].options, u[1] ? u[1].options : void 0); } evaluateParams(e, n) { const o = {}; if (n) { for (const u in n) if (n[u]) try { const l = n[u].evaluate(e), f = `Ignoring image parameter "${u}" with semi-transparent color ${l.toString()}`; if (l.a !== 1) { this._imageWarnHistory[f] || (console.warn(f), this._imageWarnHistory[f] = !0); continue; } o[u] = l; } catch { continue; } if (Object.keys(o).length !== 0) return { params: o }; } } evaluate(e) { const n = ss.build(this.inputPrimary.evaluate(e), this.inputSecondary ? this.inputSecondary.evaluate(e) : void 0, this.inputPrimaryParams ? this.evaluateParams(e, this.inputPrimaryParams) : void 0, this.inputSecondaryParams ? this.evaluateParams(e, this.inputSecondaryParams) : void 0); return n && e.availableImages && (n.available = e.availableImages.indexOf(n.namePrimary) > -1, n.nameSecondary && n.available && e.availableImages && (n.available = e.availableImages.indexOf(n.nameSecondary) > -1)), n; } eachChild(e) { if (e(this.inputPrimary), this.inputPrimaryParams) for (const n in this.inputPrimaryParams) this.inputPrimaryParams[n] && e(this.inputPrimaryParams[n]); if (this.inputSecondary && (e(this.inputSecondary), this.inputSecondaryParams)) for (const n in this.inputSecondaryParams) this.inputSecondaryParams[n] && e(this.inputSecondaryParams[n]); } outputDefined() { return !1; } serializeParams(e) { const n = {}; if (e) { for (const o in e) e[o] && (n[o] = e[o].serialize()); return { params: n }; } } serialize() { const e = ["image", this.inputPrimary.serialize()]; return this.inputPrimaryParams && e.push(this.serializeParams(this.inputPrimaryParams)), this.inputSecondary && (e.push(this.inputSecondary.serialize()), this.inputSecondaryParams && e.push(this.serializeParams(this.inputSecondaryParams))), e; } } function qo(r) { return r instanceof Number ? "number" : r instanceof String ? "string" : r instanceof Boolean ? "boolean" : Array.isArray(r) ? "array" : r === null ? "null" : typeof r; } const Wo = { "to-boolean": Li, "to-color": ms, "to-number": Ot, "to-string": Fi }; class so { constructor(e, n) { this.type = e, this.args = n; } static parse(e, n) { if (e.length < 2) return n.error("Expected at least one argument."); const o = e[0], u = []; let l = ha; if (o === "to-array") { if (!Array.isArray(e[1])) return null; const f = e[1].length; if (n.expectedType) { if (n.expectedType.kind !== "array") return n.error(`Expected ${n.expectedType.kind} but found array.`); l = Ss(n.expectedType.itemType, f); } else { if (!(f > 0 && wo(e[1][0]))) return null; l = Ss(vn(e[1][0]), f); } for (let v = 0; v < f; v++) { const S = e[1][v]; let D; if (qo(S) === "array") D = n.parse(S, void 0, l.itemType); else { const x = qo(S); if (x !== l.itemType.kind) return n.error(`Expected ${l.itemType.kind} but found ${x}.`); D = n.registry.literal.parse(["literal", S === void 0 ? null : S], n); } if (!D) return null; u.push(D); } } else { if ((o === "to-boolean" || o === "to-string") && e.length !== 2) return n.error("Expected one argument."); l = Wo[o]; for (let f = 1; f < e.length; f++) { const v = n.parse(e[f], f, Pi); if (!v) return null; u.push(v); } } return new so(l, u); } evaluate(e) { if (this.type.kind === "boolean") return !!this.args[0].evaluate(e); if (this.type.kind === "color") { let n, o; for (const u of this.args) { if (n = u.evaluate(e), o = null, n instanceof ki) return n; if (typeof n == "string") { const l = e.parseColor(n); if (l) return l; } else if (Array.isArray(n) && (o = n.length < 3 || n.length > 4 ? `Invalid rbga value ${JSON.stringify(n)}: expected an array containing either three or four numeric values.` : fa(n[0], n[1], n[2], n[3]), !o)) return new ki(n[0] / 255, n[1] / 255, n[2] / 255, n[3]); } throw new qn(o || `Could not parse color from value '${typeof n == "string" ? n : String(JSON.stringify(n))}'`); } if (this.type.kind === "number") { let n = null; for (const o of this.args) { if (n = o.evaluate(e), n === null) return 0; const u = Number(n); if (!isNaN(u)) return u; } throw new qn(`Could not convert ${JSON.stringify(n)} to number.`); } return this.type.kind === "formatted" ? Dn.fromString(Ir(this.args[0].evaluate(e))) : this.type.kind === "resolvedImage" ? ss.build(Ir(this.args[0].evaluate(e))) : this.type.kind === "array" ? this.args.map((n) => n.evaluate(e)) : Ir(this.args[0].evaluate(e)); } eachChild(e) { this.args.forEach(e); } outputDefined() { return this.args.every((e) => e.outputDefined()); } serialize() { if (this.type.kind === "formatted") return new Es([{ content: this.args[0], scale: null, font: null, textColor: null }]).serialize(); if (this.type.kind === "resolvedImage") return new Oa(this.args[0]).serialize(); const e = this.type.kind === "array" ? [] : [`to-${this.type.kind}`]; return this.eachChild((n) => { e.push(n.serialize()); }), e; } } const Nc = ["Unknown", "Point", "LineString", "Polygon"]; class Fa { constructor(e, n) { 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, this.scope = e, this.options = n; } id() { return this.feature && this.feature.id !== void 0 ? this.feature.id : null; } geometryType() { return this.feature ? typeof this.feature.type == "number" ? Nc[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 || {}; } measureLight(e) { return this.globals.brightness || 0; } distanceFromCenter() { if (this.featureTileCoord && this.featureDistanceData) { const e = this.featureDistanceData.center, n = this.featureDistanceData.scale, { x: o, y: u } = this.featureTileCoord; return this.featureDistanceData.bearing[0] * (o * n - e[0]) + this.featureDistanceData.bearing[1] * (u * n - e[1]); } return 0; } parseColor(e) { let n = this._parseColorCache[e]; return n || (n = this._parseColorCache[e] = ki.parse(e)), n; } getConfig(e) { return this.options ? this.options.get(e) : null; } } class or { constructor(e, n, o, u, l) { this.name = e, this.type = n, this._evaluate = o, this.args = u, this._overloadIndex = l; } evaluate(e) { if (!this._evaluate) { const n = or.definitions[this.name]; this._evaluate = Array.isArray(n) ? n[2] : n.overloads[this._overloadIndex][1]; } return this._evaluate(e, this.args); } eachChild(e) { this.args.forEach(e); } outputDefined() { return !1; } serialize() { return [this.name].concat(this.args.map((e) => e.serialize())); } static parse(e, n) { const o = e[0], u = or.definitions[o]; if (!u) return n.error(`Unknown expression "${o}". If you wanted a literal array, use ["literal", [...]].`, 0); const l = Array.isArray(u) ? u[0] : u.type, f = Array.isArray(u) ? [[u[1], u[2]]] : u.overloads, v = []; let S = null, D = -1; for (const [x, P] of f) { if (Array.isArray(x) && x.length !== e.length - 1) continue; v.push(x), D++, S = new Qr(n.registry, n.path, null, n.scope, void 0, n._scope, n.options); const I = []; let M = !1; for (let C = 1; C < e.length; C++) { const k = e[C], V = Array.isArray(x) ? x[C - 1] : x.type, U = S.parse(k, 1 + I.length, V); if (!U) { M = !0; break; } I.push(U); } if (!M) if (Array.isArray(x) && x.length !== I.length) S.error(`Expected ${x.length} arguments, but found ${I.length} instead.`); else { for (let C = 0; C < I.length; C++) { const k = Array.isArray(x) ? x[C] : x.type, V = I[C]; S.concat(C + 1).checkSubtype(k, V.type); } if (S.errors.length === 0) return new or(o, l, P, I, D); } } if (v.length === 1) n.errors.push(...S.errors); else { const x = (v.length ? v : f.map(([I]) => I)).map(fl).join(" | "), P = []; for (let I = 1; I < e.length; I++) { const M = n.parse(e[I], 1 + P.length); if (!M) return null; P.push(un(M.type)); } n.error(`Expected arguments of type ${x}, but found (${P.join(", ")}) instead.`); } return null; } static register(e, n) { or.definitions = n; for (const o in n) e[o] = or; } } function fl(r) { return Array.isArray(r) ? `(${r.map(un).join(", ")})` : `(${un(r.type)}...)`; } class pl { constructor(e, n, o) { this.type = _s, this.locale = o, this.caseSensitive = e, this.diacriticSensitive = n; } static parse(e, n) { if (e.length !== 2) return n.error("Expected one argument."); const o = e[1]; if (typeof o != "object" || Array.isArray(o)) return n.error("Collator options argument must be an object."); const u = o["case-sensitive"] === void 0 ? n.parse(!1, 1, Li) : n.parseObjectValue(o["case-sensitive"], 1, "case-sensitive", Li); if (!u) return null; const l = o["diacritic-sensitive"] === void 0 ? n.parse(!1, 1, Li) : n.parseObjectValue(o["diacritic-sensitive"], 1, "diacritic-sensitive", Li); if (!l) return null; let f = null; return o.locale && (f = n.parseObjectValue(o.locale, 1, "locale", Fi), !f) ? null : new pl(u, l, f); } evaluate(e) { return new nn(this.caseSensitive.evaluate(e), this.diacriticSensitive.evaluate(e), this.locale ? this.locale.evaluate(e) : null); } eachChild(e) { e(this.caseSensitive), e(this.diacriticSensitive), this.locale && e(this.locale); } outputDefined() { return !1; } serialize() { const e = {}; return e["case-sensitive"] = this.caseSensitive.serialize(), e["diacritic-sensitive"] = this.diacriticSensitive.serialize(), this.locale && (e.locale = this.locale.serialize()), ["collator", e]; } } function Nh(r, e, n = 0, o = r.length - 1, u = Vc) { for (; o > n; ) { if (o - n > 600) { const S = o - n + 1, D = e - n + 1, x = Math.log(S), P = 0.5 * Math.exp(2 * x / 3), I = 0.5 * Math.sqrt(x * P * (S - P) / S) * (D - S / 2 < 0 ? -1 : 1); Nh(r, e, Math.max(n, Math.floor(e - D * P / S + I)), Math.min(o, Math.floor(e + (S - D) * P / S + I)), u); } const l = r[e]; let f = n, v = o; for (ml(r, n, e), u(r[o], l) > 0 && ml(r, n, o); f < v; ) { for (ml(r, f, v), f++, v--; u(r[f], l) < 0; ) f++; for (; u(r[v], l) > 0; ) v--; } u(r[n], l) === 0 ? ml(r, n, v) : (v++, ml(r, v, o)), v <= e && (n = v + 1), e <= v && (o = v - 1); } } function ml(r, e, n) { const o = r[e]; r[e] = r[n], r[n] = o; } function Vc(r, e) { return r < e ? -1 : r > e ? 1 : 0; } function Qu(r) { let e = 0; for (let n, o, u = 0, l = r.length, f = l - 1; u < l; f = u++) n = r[u], o = r[f], e += (o.x - n.x) * (n.y + o.y); return e; } function Ba(r, e) { r[0] = Math.min(r[0], e[0]), r[1] = Math.min(r[1], e[1]), r[2] = Math.max(r[2], e[0]), r[3] = Math.max(r[3], e[1]); } function Na(r, e) { return !(r[0] <= e[0] || r[2] >= e[2] || r[1] <= e[1] || r[3] >= e[3]); } function _l(r, e, n) { const o = r[0] - e[0], u = r[1] - e[1], l = r[0] - n[0], f = r[1] - n[1]; return o * f - l * u == 0 && o * l <= 0 && u * f <= 0; } function Ds(r, e, n = !1) { let o = !1; for (let v = 0, S = e.length; v < S; v++) { const D = e[v]; for (let x = 0, P = D.length, I = P - 1; x < P; I = x++) { const M = D[I], C = D[x]; if (_l(r, M, C)) return n; (l = M)[1] > (u = r)[1] != (f = C)[1] > u[1] && u[0] < (f[0] - l[0]) * (u[1] - l[1]) / (f[1] - l[1]) + l[0] && (o = !o); } } var u, l, f; return o; } function Vh(r, e, n, o) { const u = o[0] - n[0], l = o[1] - n[1], f = (r[0] - n[0]) * l - u * (r[1] - n[1]), v = (e[0] - n[0]) * l - u * (e[1] - n[1]); return f > 0 && v < 0 || f < 0 && v > 0; } function $o(r, e, n, o) { return (u = [o[0] - n[0], o[1] - n[1]])[0] * (l = [e[0] - r[0], e[1] - r[1]])[1] - u[1] * l[0] != 0 && !(!Vh(r, e, n, o) || !Vh(n, o, r, e)); var u, l; } const rs = 8192; function Uh(r, e) { const n = (180 + r[0]) / 360, o = (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + r[1] * Math.PI / 360))) / 360, u = Math.pow(2, e.z); return [Math.round(n * u * rs), Math.round(o * u * rs)]; } function jh(r, e) { for (let n = 0; n < e.length; n++) if (Ds(r, e[n])) return !0; return !1; } function ed(r, e, n) { for (const o of n) for (let u = 0, l = o.length, f = l - 1; u < l; f = u++) if ($o(r, e, o[f], o[u])) return !0; return !1; } function Hl(r, e) { for (let n = 0; n < r.length; ++n) if (!Ds(r[n], e)) return !1; for (let n = 0; n < r.length - 1; ++n) if (ed(r[n], r[n + 1], e)) return !1; return !0; } function Xo(r, e) { for (let n = 0; n < e.length; n++) if (Hl(r, e[n])) return !0; return !1; } function bi(r, e, n) { const o = []; for (let u = 0; u < r.length; u++) { const l = []; for (let f = 0; f < r[u].length; f++) { const v = Uh(r[u][f], n); Ba(e, v), l.push(v); } o.push(l); } return o; } function Wt(r, e, n) { const o = []; for (let u = 0; u < r.length; u++) { const l = bi(r[u], e, n); o.push(l); } return o; } function gl(r, e, n, o) { if (r[0] < n[0] || r[0] > n[2]) { const u = 0.5 * o; let l = r[0] - n[0] > u ? -o : n[0] - r[0] > u ? o : 0; l === 0 && (l = r[0] - n[2] > u ? -o : n[2] - r[0] > u ? o : 0), r[0] += l; } Ba(e, r); } function ci(r, e, n, o) { const u = Math.pow(2, o.z) * rs, l = [o.x * rs, o.y * rs], f = []; if (!r) return f; for (const v of r) for (const S of v) { const D = [S.x + l[0], S.y + l[1]]; gl(D, e, n, u), f.push(D); } return f; } function ar(r, e, n, o) { const u = Math.pow(2, o.z) * rs, l = [o.x * rs, o.y * rs], f = []; if (!r) return f; for (const S of r) { const D = []; for (const x of S) { const P = [x.x + l[0], x.y + l[1]]; Ba(e, P), D.push(P); } f.push(D); } if (e[2] - e[0] <= u / 2) { (v = e)[0] = v[1] = 1 / 0, v[2] = v[3] = -1 / 0; for (const S of f) for (const D of S) gl(D, e, n, u); } var v; return f; } class lr { constructor(e, n) { this.type = Li, this.geojson = e, this.geometries = n; } static parse(e, n) { if (e.length !== 2) return n.error(`'within' expression requires exactly one argument, but found ${e.length - 1} instead.`); if (wo(e[1])) { const o = e[1]; if (o.type === "FeatureCollection") for (let u = 0; u < o.features.length; ++u) { const l = o.features[u].geometry.type; if (l === "Polygon" || l === "MultiPolygon") return new lr(o, o.features[u].geometry); } else if (o.type === "Feature") { const u = o.geometry.type; if (u === "Polygon" || u === "MultiPolygon") return new lr(o, o.geometry); } else if (o.type === "Polygon" || o.type === "MultiPolygon") return new lr(o, o); } return n.error("'within' expression requires valid geojson object that contains polygon geometry type."); } evaluate(e) { if (e.geometry() != null && e.canonicalID() != null) { if (e.geometryType() === "Point") return function(n, o) { const u = [1 / 0, 1 / 0, -1 / 0, -1 / 0], l = [1 / 0, 1 / 0, -1 / 0, -1 / 0], f = n.canonicalID(); if (!f) return !1; if (o.type === "Polygon") { const v = bi(o.coordinates, l, f), S = ci(n.geometry(), u, l, f); if (!Na(u, l)) return !1; for (const D of S) if (!Ds(D, v)) return !1; } if (o.type === "MultiPolygon") { const v = Wt(o.coordinates, l, f), S = ci(n.geometry(), u, l, f); if (!Na(u, l)) return !1; for (const D of S) if (!jh(D, v)) return !1; } return !0; }(e, this.geometries); if (e.geometryType() === "LineString") return function(n, o) { const u = [1 / 0, 1 / 0, -1 / 0, -1 / 0], l = [1 / 0, 1 / 0, -1 / 0, -1 / 0], f = n.canonicalID(); if (!f) return !1; if (o.type === "Polygon") { const v = bi(o.coordinates, l, f), S = ar(n.geometry(), u, l, f); if (!Na(u, l)) return !1; for (const D of S) if (!Hl(D, v)) return !1; } if (o.type === "MultiPolygon") { const v = Wt(o.coordinates, l, f), S = ar(n.geometry(), u, l, f); if (!Na(u, l)) return !1; for (const D of S) if (!Xo(D, v)) return !1; } return !0; }(e, this.geometries); } return !1; } eachChild() { } outputDefined() { return !0; } serialize() { return ["within", this.geojson]; } } const ti = { kilometers: 1, miles: 1e3 / 1609.344, nauticalmiles: 1e3 / 1852, meters: 1e3, metres: 1e3, yards: 1e3 / 0.9144, feet: 1e3 / 0.3048, inches: 1e3 / 0.0254 }, Xr = 1 / 298.257223563, ql = Xr * (2 - Xr), Yr = Math.PI / 180; class Va { static fromTile(e, n, o) { const u = Math.PI * (1 - 2 * (e + 0.5) / Math.pow(2, n)), l = Math.atan(0.5 * (Math.exp(u) - Math.exp(-u))) / Yr; return new Va(l, o); } static get units() { return ti; } constructor(e, n) { if (e === void 0) throw new Error("No latitude given."); if (n && !ti[n]) throw new Error(`Unknown unit ${n}. Use one of: ${Object.keys(ti).join(", ")}`); const o = 6378.137 * Yr * (n ? ti[n] : 1), u = Math.cos(e * Yr), l = 1 / (1 - ql * (1 - u * u)), f = Math.sqrt(l); this.kx = o * f * u, this.ky = o * f * l * (1 - ql); } distance(e, n) { const o = ks(e[0] - n[0]) * this.kx, u = (e[1] - n[1]) * this.ky; return Math.sqrt(o * o + u * u); } bearing(e, n) { const o = ks(n[0] - e[0]) * this.kx; return Math.atan2(o, (n[1] - e[1]) * this.ky) / Yr; } destination(e, n, o) { const u = o * Yr; return this.offset(e, Math.sin(u) * n, Math.cos(u) * n); } offset(e, n, o) { return [e[0] + n / this.kx, e[1] + o / this.ky]; } lineDistance(e) { let n = 0; for (let o = 0; o < e.length - 1; o++) n += this.distance(e[o], e[o + 1]); return n; } area(e) { let n = 0; for (let o = 0; o < e.length; o++) { const u = e[o]; for (let l = 0, f = u.length, v = f - 1; l < f; v = l++) n += ks(u[l][0] - u[v][0]) * (u[l][1] + u[v][1]) * (o ? -1 : 1); } return Math.abs(n) / 2 * this.kx * this.ky; } along(e, n) { let o = 0; if (n <= 0) return e[0]; for (let u = 0; u < e.length - 1; u++) { const l = e[u], f = e[u + 1], v = this.distance(l, f); if (o += v, o > n) return bs(l, f, (n - (o - v)) / v); } return e[e.length - 1]; } pointToSegmentDistance(e, n, o) { let [u, l] = n, f = ks(o[0] - u) * this.kx, v = (o[1] - l) * this.ky; if (f !== 0 || v !== 0) { const S = (ks(e[0] - u) * this.kx * f + (e[1] - l) * this.ky * v) / (f * f + v * v); S > 1 ? (u = o[0], l = o[1]) : S > 0 && (u += f / this.kx * S, l += v / this.ky * S); } return f = ks(e[0] - u) * this.kx, v = (e[1] - l) * this.ky, Math.sqrt(f * f + v * v); } pointOnLine(e, n) { let o = 1 / 0, u = e[0][0], l = e[0][1], f = 0, v = 0; for (let S = 0; S < e.length - 1; S++) { let D = e[S][0], x = e[S][1], P = ks(e[S + 1][0] - D) * this.kx, I = (e[S + 1][1] - x) * this.ky, M = 0; P === 0 && I === 0 || (M = (ks(n[0] - D) * this.kx * P + (n[1] - x) * this.ky * I) / (P * P + I * I), M > 1 ? (D = e[S + 1][0], x = e[S + 1][1]) : M > 0 && (D += P / this.kx * M, x += I / this.ky * M)), P = ks(n[0] - D) * this.kx, I = (n[1] - x) * this.ky; const C = P * P + I * I; C < o && (o = C, u = D, l = x, f = S, v = M); } return { point: [u, l], index: f, t: Math.max(0, Math.min(1, v)) }; } lineSlice(e, n, o) { let u = this.pointOnLine(o, e), l = this.pointOnLine(o, n); if (u.index > l.index || u.index === l.index && u.t > l.t) { const D = u; u = l, l = D; } const f = [u.point], v = u.index + 1, S = l.index; !To(o[v], f[0]) && v <= S && f.push(o[v]); for (let D = v + 1; D <= S; D++) f.push(o[D]); return To(o[S], l.point) || f.push(l.point), f; } lineSliceAlong(e, n, o) { let u = 0; const l = []; for (let f = 0; f < o.length - 1; f++) { const v = o[f], S = o[f + 1], D = this.distance(v, S); if (u += D, u > e && l.length === 0 && l.push(bs(v, S, (e - (u - D)) / D)), u >= n) return l.push(bs(v, S, (n - (u - D)) / D)), l; u > e && l.push(S); } return l; } bufferPoint(e, n) { const o = n / this.ky, u = n / this.kx; return [e[0] - u, e[1] - o, e[0] + u, e[1] + o]; } bufferBBox(e, n) { const o = n / this.ky, u = n / this.kx; return [e[0] - u, e[1] - o, e[2] + u, e[3] + o]; } insideBBox(e, n) { return ks(e[0] - n[0]) >= 0 && ks(e[0] - n[2]) <= 0 && e[1] >= n[1] && e[1] <= n[3]; } } function To(r, e) { return r[0] === e[0] && r[1] === e[1]; } function bs(r, e, n) { const o = ks(e[0] - r[0]); return [r[0] + o * n, r[1] + (e[1] - r[1]) * n]; } function ks(r) { for (; r < -180; ) r += 360; for (; r > 180; ) r -= 360; return r; } class Wl { constructor(e = [], n = (o, u) => o < u ? -1 : o > u ? 1 : 0) { if (this.data = e, this.length = this.data.length, this.compare = n, this.length > 0) for (let o = (this.length >> 1) - 1; o >= 0; o--) this._down(o); } push(e) { this.data.push(e), this._up(this.length++); } pop() { if (this.length === 0) return; const e = this.data[0], n = this.data.pop(); return --this.length > 0 && (this.data[0] = n, this._down(0)), e; } peek() { return this.data[0]; } _up(e) { const { data: n, compare: o } = this, u = n[e]; for (; e > 0; ) { const l = e - 1 >> 1, f = n[l]; if (o(u, f) >= 0) break; n[e] = f, e = l; } n[e] = u; } _down(e) { const { data: n, compare: o } = this, u = this.length >> 1, l = n[e]; for (; e < u; ) { let f = 1 + (e << 1); const v = f + 1; if (v < this.length && o(n[v], n[f]) < 0 && (f = v), o(n[f], l) >= 0) break; n[e] = n[f], e = f; } n[e] = l; } } var Tt = 8192; function ma(r, e) { return e.dist - r.dist; } const Mo = 100, gs = 50; function Gh(r) { const e = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; if (e.length !== r.length) return !1; for (let n = 0; n < e.length; n++) if (e[n] !== r[n]) return !1; return !0; } function Dr(r) { return r[1] - r[0] + 1; } function So(r, e) { const n = r[1] >= r[0] && r[1] < e; return n || console.warn("Distance Expression: Index is out of range"), n; } function Kr(r, e) { if (r[0] > r[1]) return [null, null]; const n = Dr(r); if (e) { if (n === 2) return [r, null]; const o = Math.floor(n / 2); return [[r[0], r[0] + o], [r[0] + o, r[1]]]; } { if (n === 1) return [r, null]; const o = Math.floor(n / 2) - 1; return [[r[0], r[0] + o], [r[0] + o + 1, r[1]]]; } } function Yo(r, e) { const n = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; if (!So(e, r.length)) return n; for (let o = e[0]; o <= e[1]; ++o) Ba(n, r[o]); return n; } function cr(r) { const e = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; for (let n = 0; n < r.length; ++n) for (let o = 0; o < r[n].length; ++o) Ba(e, r[n][o]); return e; } function Eo(r, e, n) { if (Gh(r) || Gh(e)) return NaN; let o = 0, u = 0; return r[2] < e[0] && (o = e[0] - r[2]), r[0] > e[2] && (o = r[0] - e[2]), r[1] > e[3] && (u = r[1] - e[3]), r[3] < e[1] && (u = e[1] - r[3]), n.distance([0, 0], [o, u]); } function Zh(r) { return 360 * r - 180; } function Uc(r) { return 360 / Math.PI * Math.atan(Math.exp((180 - 360 * r) * Math.PI / 180)) - 90; } function Ua(r, e) { const n = Math.pow(2, e.z), o = (r.y / Tt + e.y) / n; return [Zh((r.x / Tt + e.x) / n), Uc(o)]; } function $l(r, e) { const n = []; for (let o = 0; o < r.length; ++o) n.push(Ua(r[o], e)); return n; } function yl(r, e, n) { const o = n.pointOnLine(e, r).point; return n.distance(r, o); } function _a(r, e, n, o, u) { const l = n.slice(o[0], o[1] + 1); let f = 1 / 0; for (let v = e[0]; v <= e[1]; ++v) if ((f = Math.min(f, yl(r[v], l, u))) === 0) return 0; return f; } function ga(r, e, n, o, u) { const l = Math.min(u.pointToSegmentDistance(r, n, o), u.pointToSegmentDistance(e, n, o)), f = Math.min(u.pointToSegmentDistance(n, r, e), u.pointToSegmentDistance(o, r, e)); return Math.min(l, f); } function Po(r, e, n, o, u) { if (!So(e, r.length) || !So(o, n.length)) return NaN; let l = 1 / 0; for (let f = e[0]; f < e[1]; ++f) for (let v = o[0]; v < o[1]; ++v) { if ($o(r[f], r[f + 1], n[v], n[v + 1])) return 0; l = Math.min(l, ga(r[f], r[f + 1], n[v], n[v + 1], u)); } return l; } function Hh(r, e, n, o, u) { if (!So(e, r.length) || !So(o, n.length)) return NaN; let l = 1 / 0; for (let f = e[0]; f <= e[1]; ++f) for (let v = o[0]; v <= o[1]; ++v) if ((l = Math.min(l, u.distance(r[f], n[v]))) === 0) return l; return l; } function td(r, e, n) { if (Ds(r, e, !0)) return 0; let o = 1 / 0; for (const u of e) { const l = u.length; if (l < 2) return console.warn("Distance Expression: Invalid polygon!"), NaN; if (u[0] !== u[l - 1] && (o = Math.min(o, n.pointToSegmentDistance(r, u[l - 1], u[0]))) === 0 || (o = Math.min(o, yl(r, u, n))) === 0) return o; } return o; } function ja(r, e, n, o) { if (!So(e, r.length)) return NaN; for (let l = e[0]; l <= e[1]; ++l) if (Ds(r[l], n, !0)) return 0; let u = 1 / 0; for (let l = e[0]; l < e[1]; ++l) for (const f of n) for (let v = 0, S = f.length, D = S - 1; v < S; D = v++) { if ($o(r[l], r[l + 1], f[D], f[v])) return 0; u = Math.min(u, ga(r[l], r[l + 1], f[D], f[v], o)); } return u; } function jc(r, e) { for (const n of r) for (let o = 0; o <= n.length - 1; ++o) if (Ds(n[o], e, !0)) return !0; return !1; } function Gc(r, e, n, o = 1 / 0) { const u = cr(r), l = cr(e); if (o !== 1 / 0 && Eo(u, l, n) >= o) return o; if (Na(u, l)) { if (jc(r, e)) return 0; } else if (jc(e, r)) return 0; let f = o; for (const v of r) for (let S = 0, D = v.length, x = D - 1; S < D; x = S++) for (const P of e) for (let I = 0, M = P.length, C = M - 1; I < M; C = I++) { if ($o(v[x], v[S], P[C], P[I])) return 0; f = Math.min(f, ga(v[x], v[S], P[C], P[I], n)); } return f; } function hr(r, e, n, o, u, l, f) { if (l === null || f === null) return; const v = Eo(Yo(o, l), Yo(u, f), n); v < e && r.push({ dist: v, range1: l, range2: f }); } function Zc(r, e, n, o, u = 1 / 0) { let l = Math.min(o.distance(r[0], n[0][0]), u); if (l === 0) return l; const f = new Wl([{ dist: 0, range1: [0, r.length - 1], range2: [0, 0] }], ma), v = e ? gs : Mo, S = cr(n); for (; f.length; ) { const D = f.pop(); if (D.dist >= l) continue; const x = D.range1; if (Dr(x) <= v) { if (!So(x, r.length)) return NaN; if (e) { const P = ja(r, x, n, o); if ((l = Math.min(l, P)) === 0) return l; } else for (let P = x[0]; P <= x[1]; ++P) { const I = td(r[P], n, o); if ((l = Math.min(l, I)) === 0) return l; } } else { const P = Kr(x, e); if (P[0] !== null) { const I = Eo(Yo(r, P[0]), S, o); I < l && f.push({ dist: I, range1: P[0], range2: [0, 0] }); } if (P[1] !== null) { const I = Eo(Yo(r, P[1]), S, o); I < l && f.push({ dist: I, range1: P[1], range2: [0, 0] }); } } } return l; } function Hc(r, e, n, o, u, l = 1 / 0) { let f = Math.min(l, u.distance(r[0], n[0])); if (f === 0) return f; const v = new Wl([{ dist: 0, range1: [0, r.length - 1], range2: [0, n.length - 1] }], ma), S = e ? gs : Mo, D = o ? gs : Mo; for (; v.length; ) { const x = v.pop(); if (x.dist >= f) continue; const P = x.range1, I = x.range2; if (Dr(P) <= S && Dr(I) <= D) { if (!So(P, r.length) || !So(I, n.length)) return NaN; if (e && o ? f = Math.min(f, Po(r, P, n, I, u)) : e || o ? e && !o ? f = Math.min(f, _a(n, I, r, P, u)) : !e && o && (f = Math.min(f, _a(r, P, n, I, u))) : f = Math.min(f, Hh(r, P, n, I, u)), f === 0) return f; } else { const M = Kr(P, e), C = Kr(I, o); hr(v, f, u, r, n, M[0], C[0]), hr(v, f, u, r, n, M[0], C[1]), hr(v, f, u, r, n, M[1], C[0]), hr(v, f, u, r, n, M[1], C[1]); } } return f; } function xr(r, e, n, o, u = 1 / 0) { let l = u; const f = Yo(r, [0, r.length - 1]); for (const v of n) if (!(l !== 1 / 0 && Eo(f, Yo(v, [0, v.length - 1]), o) >= l) && (l = Math.min(l, Hc(r, e, v, !0, o, l)), l === 0)) return l; return l; } function Ko(r, e, n, o, u = 1 / 0) { let l = u; const f = Yo(r, [0, r.length - 1]); for (const v of n) { if (l !== 1 / 0 && Eo(f, cr(v), o) >= l) continue; const S = Zc(r, e, v, o, l); if (isNaN(S)) return S; if ((l = Math.min(l, S)) === 0) return l; } return l; } function Xl(r) { return r === "Point" || r === "MultiPoint" || r === "LineString" || r === "MultiLineString" || r === "Polygon" || r === "MultiPolygon"; } class Jr { constructor(e, n) { this.type = Ot, this.geojson = e, this.geometries = n; } static parse(e, n) { if (e.length !== 2) return n.error(`'distance' expression requires either one argument, but found ' ${e.length - 1} instead.`); if (wo(e[1])) { const o = e[1]; if (o.type === "FeatureCollection") { for (let u = 0; u < o.features.length; ++u) if (Xl(o.features[u].geometry.type)) return new Jr(o, o.features[u].geometry); } else if (o.type === "Feature") { if (Xl(o.geometry.type)) return new Jr(o, o.geometry); } else if (Xl(o.type)) return new Jr(o, o); } return n.error("'distance' expression needs to be an array with format ['Distance', GeoJSONObj]."); } evaluate(e) { const n = e.geometry(), o = e.canonicalID(); if (n != null && o != null) { if (e.geometryType() === "Point") return function(u, l, f) { const v = []; for (const D of u) for (const x of D) v.push(Ua(x, l)); const S = new Va(v[0][1], "meters"); return f.type === "Point" || f.type === "MultiPoint" || f.type === "LineString" ? Hc(v, !1, f.type === "Point" ? [f.coordinates] : f.coordinates, f.type === "LineString", S) : f.type === "MultiLineString" ? xr(v, !1, f.coordinates, S) : f.type === "Polygon" || f.type === "MultiPolygon" ? Ko(v, !1, f.type === "Polygon" ? [f.coordinates] : f.coordinates, S) : null; }(n, o, this.geometries); if (e.geometryType() === "LineString") return function(u, l, f) { const v = []; for (const D of u) { const x = []; for (const P of D) x.push(Ua(P, l)); v.push(x); } const S = new Va(v[0][0][1], "meters"); if (f.type === "Point" || f.type === "MultiPoint" || f.type === "LineString") return xr(f.type === "Point" ? [f.coordinates] : f.coordinates, f.type === "LineString", v, S); if (f.type === "MultiLineString") { let D = 1 / 0; for (let x = 0; x < f.coordinates.length; x++) { const P = xr(f.coordinates[x], !0, v, S, D); if (isNaN(P)) return P; if ((D = Math.min(D, P)) === 0) return D; } return D; } if (f.type === "Polygon" || f.type === "MultiPolygon") { let D = 1 / 0; for (let x = 0; x < v.length; x++) { const P = Ko(v[x], !0, f.type === "Polygon" ? [f.coordinates] : f.coordinates, S, D); if (isNaN(P)) return P; if ((D = Math.min(D, P)) === 0) return D; } return D; } return null; }(n, o, this.geometries); if (e.geometryType() === "Polygon") return function(u, l, f) { const v = []; for (const D of function(x, P) { const I = x.length; if (I <= 1) return [x]; const M = []; let C, k; for (let V = 0; V < I; V++) { const U = Qu(x[V]); U !== 0 && (x[V].area = Math.abs(U), k === void 0 && (k = U < 0), k === U < 0 ? (C && M.push(C), C = [x[V]]) : C.push(x[V])); } return C && M.push(C), M; }(u)) { const x = []; for (let P = 0; P < D.length; ++P) x.push($l(D[P], l)); v.push(x); } const S = new Va(v[0][0][0][1], "meters"); if (f.type === "Point" || f.type === "MultiPoint" || f.type === "LineString") return Ko(f.type === "Point" ? [f.coordinates] : f.coordinates, f.type === "LineString", v, S); if (f.type === "MultiLineString") { let D = 1 / 0; for (let x = 0; x < f.coordinates.length; x++) { const P = Ko(f.coordinates[x], !0, v, S, D); if (isNaN(P)) return P; if ((D = Math.min(D, P)) === 0) return D; } return D; } return f.type === "Polygon" || f.type === "MultiPolygon" ? function(D, x, P) { let I = 1 / 0; for (const M of D) for (const C of x) { const k = Gc(M, C, P, I); if (isNaN(k)) return k; if ((I = Math.min(I, k)) === 0) return I; } return I; }(f.type === "Polygon" ? [f.coordinates] : f.coordinates, v, S) : null; }(n, o, this.geometries); console.warn("Distance Expression: currently only evaluates valid Point/LineString/Polygon geometries."); } else console.warn("Distance Expression: requirs valid feature and canonical information."); return null; } eachChild() { } outputDefined() { return !0; } serialize() { return ["distance", this.geojson]; } } function Yl(r, e) { switch (r) { case "string": return Ir(e); case "number": return +e; case "boolean": return !!e; case "color": return ki.parse(e); case "formatted": return Dn.fromString(Ir(e)); case "resolvedImage": return ss.build(Ir(e)); } return e; } function Kl(r, e, n, o) { return o !== void 0 && (r = o * Math.round(r / o)), e !== void 0 && r < e && (r = e), n !== void 0 && r > n && (r = n), r; } class ya { constructor(e, n, o) { this.type = e, this.key = n, this.scope = o; } static parse(e, n) { let o = n.expectedType; if (o == null && (o = Pi), e.length < 2 || e.length > 3) return n.error("Invalid number of arguments for 'config' expression."); const u = n.parse(e[1], 1); if (!(u instanceof Lr)) return n.error("Key name of 'config' expression must be a string literal."); if (e.length >= 3) { const l = n.parse(e[2], 2); return l instanceof Lr ? new ya(o, Ir(u.value), Ir(l.value)) : n.error("Scope of 'config' expression must be a string literal."); } return new ya(o, Ir(u.value)); } evaluate(e) { const n = [this.key, this.scope, e.scope].filter(Boolean).join(""), o = e.getConfig(n); if (!o) return null; const { type: u, value: l, values: f, minValue: v, maxValue: S, stepValue: D } = o, x = o.default.evaluate(e); let P = x; if (l) { const I = e.scope; e.scope = (I || "").split("").slice(1).join(""), P = l.evaluate(e), e.scope = I; } return u && (P = Yl(u, P)), P === void 0 || v === void 0 && S === void 0 && D === void 0 || (typeof P == "number" ? P = Kl(P, v, S, D) : Array.isArray(P) && (P = P.map((I) => typeof I == "number" ? Kl(I, v, S, D) : I))), l !== void 0 && P !== void 0 && f && !f.includes(P) && (P = x, u && (P = Yl(u, P))), (u && u !== this.type || P !== void 0 && vn(P) !== this.type) && (P = Yl(this.type.kind, P)), P; } eachChild() { } outputDefined() { return !1; } serialize() { const e = ["config", this.key]; return this.scope && e.concat(this.key), e; } } function ro(r) { if (r instanceof or && (r.name === "get" && r.args.length === 1 || r.name === "feature-state" || r.name === "has" && r.args.length === 1 || r.name === "properties" || r.name === "geometry-type" || r.name === "id" || /^filter-/.test(r.name)) || r instanceof lr || r instanceof Jr) return !1; let e = !0; return r.eachChild((n) => { e && !ro(n) && (e = !1); }), e; } function xl(r) { if (r instanceof or && r.name === "feature-state") return !1; let e = !0; return r.eachChild((n) => { e && !xl(n) && (e = !1); }), e; } function kr(r) { if (r instanceof ya) return /* @__PURE__ */ new Set([r.key]); let e = /* @__PURE__ */ new Set(); return r.eachChild((n) => { e = /* @__PURE__ */ new Set([...e, ...kr(n)]); }), e; } function oo(r, e) { if (r instanceof or && e.indexOf(r.name) >= 0) return !1; let n = !0; return r.eachChild((o) => { n && !oo(o, e) && (n = !1); }), n; } class Jo { constructor(e, n) { this.type = n.type, this.name = e, this.boundExpression = n; } static parse(e, n) { if (e.length !== 2 || typeof e[1] != "string") return n.error("'var' expression requires exactly one string literal argument."); const o = e[1]; return n.scope.has(o) ? new Jo(o, n.scope.get(o)) : n.error(`Unknown variable "${o}". Make sure "${o}" has been bound in an enclosing "let" expression before using it.`, 1); } evaluate(e) { return this.boundExpression.evaluate(e); } eachChild() { } outputDefined() { return !1; } serialize() { return ["var", this.name]; } } class Jl { constructor(e, n = [], o, u = new Cn(), l = [], f, v) { this.registry = e, this.path = n, this.key = n.map((S) => typeof S == "string" ? `['${S}']` : `[${S}]`).join(""), this.scope = u, this.errors = l, this.expectedType = o, this._scope = f, this.options = v; } parse(e, n, o, u, l = {}) { return n || o ? this.concat(n, null, o, u)._parse(e, l) : this._parse(e, l); } parseObjectValue(e, n, o, u, l, f = {}) { return this.concat(n, o, u, l)._parse(e, f); } _parse(e, n) { function o(u, l, f) { return f === "assert" ? new zr(l, [u]) : f === "coerce" ? new so(l, [u]) : u; } if (e !== null && typeof e != "string" && typeof e != "boolean" && typeof e != "number" || (e = ["literal", e]), Array.isArray(e)) { if (e.length === 0) return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].'); const u = typeof e[0] == "string" ? this.registry[e[0]] : void 0; if (u) { let l = u.parse(e, this); if (!l) return null; if (this.expectedType) { const f = this.expectedType, v = l.type; if (f.kind !== "string" && f.kind !== "number" && f.kind !== "boolean" && f.kind !== "object" && f.kind !== "array" || v.kind !== "value") if (f.kind !== "color" && f.kind !== "formatted" && f.kind !== "resolvedImage" || v.kind !== "value" && v.kind !== "string") { if (this.checkSubtype(f, v)) return null; } else l = o(l, f, n.typeAnnotation || "coerce"); else l = o(l, f, n.typeAnnotation || "assert"); } if (!(l instanceof Lr) && l.type.kind !== "resolvedImage" && vl(l)) { const f = new Fa(this._scope, this.options); try { l = new Lr(l.type, l.evaluate(f)); } catch (v) { return this.error(v.message), null; } } return l; } return so.parse(["to-array", e], this); } return this.error(e === void 0 ? "'undefined' value invalid. Use null instead." : typeof e == "object" ? 'Bare objects invalid. Use ["literal", {...}] instead.' : `Expected an array, but found ${typeof e} instead.`); } concat(e, n, o, u) { let l = typeof e == "number" ? this.path.concat(e) : this.path; l = typeof n == "string" ? l.concat(n) : l; const f = u ? this.scope.concat(u) : this.scope; return new Jl(this.registry, l, o || null, f, this.errors, this._scope, this.options); } error(e, ...n) { const o = `${this.key}${n.map((u) => `[${u}]`).join("")}`; this.errors.push(new ns(o, e)); } checkSubtype(e, n) { const o = ua(e, n); return o && this.error(o), o; } } var Qr = Jl; function vl(r) { if (r instanceof Jo) return vl(r.boundExpression); if (r instanceof or && r.name === "error" || r instanceof pl || r instanceof lr || r instanceof Jr || r instanceof ya) return !1; const e = r instanceof so || r instanceof zr; let n = !0; return r.eachChild((o) => { n = e ? n && vl(o) : n && o instanceof Lr; }), !!n && ro(r) && oo(r, ["zoom", "heatmap-density", "line-progress", "raster-value", "sky-radial-progress", "accumulated", "is-supported-script", "pitch", "distance-from-center", "measure-light", "raster-particle-speed"]); } function ao(r, e) { const n = r.length - 1; let o, u, l = 0, f = n, v = 0; for (; l <= f; ) if (v = Math.floor((l + f) / 2), o = r[v], u = r[v + 1], o <= e) { if (v === n || e < u) return v; l = v + 1; } else { if (!(o > e)) throw new qn("Input is not a number."); f = v - 1; } return 0; } class Ti { constructor(e, n, o) { this.type = e, this.input = n, this.labels = [], this.outputs = []; for (const [u, l] of o) this.labels.push(u), this.outputs.push(l); } static parse(e, n) { if (e.length - 1 < 4) return n.error(`Expected at least 4 arguments, but found only ${e.length - 1}.`); if ((e.length - 1) % 2 != 0) return n.error("Expected an even number of arguments."); const o = n.parse(e[1], 1, Ot); if (!o) return null; const u = []; let l = null; n.expectedType && n.expectedType.kind !== "value" && (l = n.expectedType); for (let f = 1; f < e.length; f += 2) { const v = f === 1 ? -1 / 0 : e[f], S = e[f + 1], D = f, x = f + 1; if (typeof v != "number") return n.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.', D); if (u.length && u[u.length - 1][0] >= v) return n.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.', D); const P = n.parse(S, x, l); if (!P) return null; l = l || P.type, u.push([v, P]); } return new Ti(l, o, u); } evaluate(e) { const n = this.labels, o = this.outputs; if (n.length === 1) return o[0].evaluate(e); const u = this.input.evaluate(e); if (u <= n[0]) return o[0].evaluate(e); const l = n.length; return u >= n[l - 1] ? o[l - 1].evaluate(e) : o[ao(n, u)].evaluate(e); } eachChild(e) { e(this.input); for (const n of this.outputs) e(n); } outputDefined() { return this.outputs.every((e) => e.outputDefined()); } serialize() { const e = ["step", this.input.serialize()]; for (let n = 0; n < this.labels.length; n++) n > 0 && e.push(this.labels[n]), e.push(this.outputs[n].serialize()); return e; } } const qh = 0.95047, bl = 1.08883, Ga = 4 / 29, Qo = 6 / 29, qc = 3 * Qo * Qo, gn = Qo * Qo * Qo, Wh = Math.PI / 180, $h = 180 / Math.PI; function Ql(r) { return r > gn ? Math.pow(r, 1 / 3) : r / qc + Ga; } function ec(r) { return r > Qo ? r * r * r : qc * (r - Ga); } function tc(r) { return 255 * (r <= 31308e-7 ? 12.92 * r : 1.055 * Math.pow(r, 1 / 2.4) - 0.055); } function Wc(r) { return (r /= 255) <= 0.04045 ? r / 12.92 : Math.pow((r + 0.055) / 1.055, 2.4); } function $c(r) { const e = Wc(r.r), n = Wc(r.g), o = Wc(r.b), u = Ql((0.4124564 * e + 0.3575761 * n + 0.1804375 * o) / qh), l = Ql((0.2126729 * e + 0.7151522 * n + 0.072175 * o) / 1); return { l: 116 * l - 16, a: 500 * (u - l), b: 200 * (l - Ql((0.0193339 * e + 0.119192 * n + 0.9503041 * o) / bl)), alpha: r.a }; } function Xc(r) { let e = (r.l + 16) / 116, n = isNaN(r.a) ? e : e + r.a / 500, o = isNaN(r.b) ? e : e - r.b / 200; return e = 1 * ec(e), n = qh * ec(n), o = bl * ec(o), new ki(tc(3.2404542 * n - 1.5371385 * e - 0.4985314 * o), tc(-0.969266 * n + 1.8760108 * e + 0.041556 * o), tc(0.0556434 * n - 0.2040259 * e + 1.0572252 * o), r.alpha); } function id(r, e, n) { const o = e - r; return r + n * (o > 180 || o < -180 ? o - 360 * Math.round(o / 360) : o); } const p = { forward: $c, reverse: Xc, interpolate: function(r, e, n) { return { l: ei(r.l, e.l, n), a: ei(r.a, e.a, n), b: ei(r.b, e.b, n), alpha: ei(r.alpha, e.alpha, n) }; } }, A = { forward: function(r) { const { l: e, a: n, b: o } = $c(r), u = Math.atan2(o, n) * $h; return { h: u < 0 ? u + 360 : u, c: Math.sqrt(n * n + o * o), l: e, alpha: r.a }; }, reverse: function(r) { const e = r.h * Wh, n = r.c; return Xc({ l: r.l, a: Math.cos(e) * n, b: Math.sin(e) * n, alpha: r.alpha }); }, interpolate: function(r, e, n) { return { h: id(r.h, e.h, n), c: ei(r.c, e.c, n), l: ei(r.l, e.l, n), alpha: ei(r.alpha, e.alpha, n) }; } }; var B = Object.freeze({ __proto__: null, hcl: A, lab: p }); class X { constructor(e, n, o, u, l, f) { this.type = e, this.operator = n, this.interpolation = o, this.input = u, this.dynamicStops = l, this.labels = [], this.outputs = []; for (const [v, S] of f) this.labels.push(v), this.outputs.push(S); } static interpolationFactor(e, n, o, u) { let l = 0; if (e.name === "exponential") l = ne(n, e.base, o, u); else if (e.name === "linear") l = ne(n, 1, o, u); else if (e.name === "cubic-bezier") { const f = e.controlPoints; l = new Us(f[0], f[1], f[2], f[3]).solve(ne(n, 1, o, u)); } return l; } static parse(e, n) { let [o, u, l, ...f] = e; if (!Array.isArray(u) || u.length === 0) return n.error("Expected an interpolation type expression.", 1); if (u[0] === "linear") u = { name: "linear" }; else if (u[0] === "exponential") { const D = u[1]; if (typeof D != "number") return n.error("Exponential interpolation requires a numeric base.", 1, 1); u = { name: "exponential", base: D }; } else { if (u[0] !== "cubic-bezier") return n.error(`Unknown interpolation type ${String(u[0])}`, 1, 0); { const D = u.slice(1); if (D.length !== 4 || D.some((x) => typeof x != "number" || x < 0 || x > 1)) return n.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.", 1); u = { name: "cubic-bezier", controlPoints: D }; } } if (e.length - 1 < 3) return n.error(`Expected at least 3 arguments, but found only ${e.length - 1}.`); if (e.length - 1 > 3 && (e.length - 1) % 2 != 0) return n.error("Expected an even number of arguments."); if (l = n.parse(l, 2, Ot), !l) return null; const v = []; let S = null; if (o === "interpolate-hcl" || o === "interpolate-lab" ? S = ms : n.expectedType && n.expectedType.kind !== "value" && (S = n.expectedType), e.length - 1 == 3) { const D = n.parse(f[0], 3, Pi); return D ? new X(S, o, u, l, D, v) : null; } for (let D = 0; D < f.length; D += 2) { const x = f[D], P = f[D + 1], I = D + 3, M = D + 4; if (typeof x != "number") return n.error('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.', I); if (v.length && v[v.length - 1][0] >= x) return n.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.', I); const C = n.parse(P, M, S); if (!C) return null; S = S || C.type, v.push([x, C]); } return S.kind === "number" || S.kind === "color" || S.kind === "array" && S.itemType.kind === "number" && typeof S.N == "number" ? new X(S, o, u, l, null, v) : n.error(`Type ${un(S)} is not interpolatable.`); } evaluate(e) { let n = this.labels, o = this.outputs; if (this.dynamicStops) { const x = this.dynamicStops.evaluate(e); if (x.length % 2 != 0) throw new qn("Expected an even number of arguments."); n = [], o = []; for (let P = 0; P < x.length; P += 2) { const I = x[P], M = new Lr(Ot, x[P + 1]); if (typeof I != "number") throw new qn('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.'); if (n.length && n[n.length - 1] >= I) throw new qn('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.'); n.push(I), o.push(M); } if (n.length === 0) throw new qn("Expected at least one input/output pair."); } if (n.length === 1) return o[0].evaluate(e); const u = this.input.evaluate(e); if (u <= n[0]) return o[0].evaluate(e); const l = n.length; if (u >= n[l - 1]) return o[l - 1].evaluate(e); const f = ao(n, u), v = X.interpolationFactor(this.interpolation, u, n[f], n[f + 1]), S = o[f].evaluate(e), D = o[f + 1].evaluate(e); return this.operator === "interpolate" ? Oi[this.type.kind.toLowerCase()](S, D, v) : this.operator === "interpolate-hcl" ? A.reverse(A.interpolate(A.forward(S), A.forward(D), v)) : p.reverse(p.interpolate(p.forward(S), p.forward(D), v)); } eachChild(e) { e(this.input); for (const n of this.outputs) e(n); } outputDefined() { return this.outputs.every((e) => e.outputDefined()); } serialize() { let e; e = this.interpolation.name === "linear" ? ["linear"] : this.interpolation.name === "exponential" ? this.interpolation.base === 1 ? ["linear"] : ["exponential", this.interpolation.base] : ["cubic-bezier"].concat(this.interpolation.controlPoints); const n = [this.operator, e, this.input.serialize()]; if (this.dynamicStops) n.push(this.dynamicStops.serialize()); else for (let o = 0; o < this.labels.length; o++) n.push(this.labels[o], this.outputs[o].serialize()); return n; } } function ne(r, e, n, o) { const u = o - n, l = r - n; return u === 0 ? 0 : e === 1 ? l / u : (Math.pow(e, l) - 1) / (Math.pow(e, u) - 1); } class ye { constructor(e, n) { this.type = e, this.args = n; } static parse(e, n) { if (e.length < 2) return n.error("Expectected at least one argument."); let o = null; const u = n.expectedType; u && u.kind !== "value" && (o = u); const l = []; for (const v of e.slice(1)) { const S = n.parse(v, 1 + l.length, o, void 0, { typeAnnotation: "omit" }); if (!S) return null; o = o || S.type, l.push(S); } const f = u && l.some((v) => ua(u, v.type)); return new ye(f ? Pi : o, l); } evaluate(e) { let n, o = null, u = 0; for (const l of this.args) { if (u++, o = l.evaluate(e), o && o instanceof ss && !o.available && (n || (n = o), o = null, u === this.args.length)) return n; if (o !== null) break; } return o; } eachChild(e) { this.args.forEach(e); } outputDefined() { return this.args.every((e) => e.outputDefined()); } serialize() { const e = ["coalesce"]; return this.eachChild((n) => { e.push(n.serialize()); }), e; } } class We { constructor(e, n) { this.type = n.type, this.bindings = [].concat(e), this.result = n; } evaluate(e) { return this.result.evaluate(e); } eachChild(e) { for (const n of this.bindings) e(n[1]); e(this.result); } static parse(e, n) { if (e.length < 4) return n.error(`Expected at least 3 arguments, but found ${e.length - 1} instead.`); const o = []; for (let l = 1; l < e.length - 1; l += 2) { const f = e[l]; if (typeof f != "string") return n.error(`Expected string, but found ${typeof f} instead.`, l); if (/[^a-zA-Z0-9_]/.test(f)) return n.error("Variable names must contain only alphanumeric characters or '_'.", l); const v = n.parse(e[l + 1], l + 1); if (!v) return null; o.push([f, v]); } const u = n.parse(e[e.length - 1], e.length - 1, n.expectedType, o); return u ? new We(o, u) : null; } outputDefined() { return this.result.outputDefined(); } serialize() { const e = ["let"]; for (const [n, o] of this.bindings) e.push(n, o.serialize()); return e.push(this.result.serialize()), e; } } class at { constructor(e, n, o) { this.type = e, this.index = n, this.input = o; } static parse(e, n) { if (e.length !== 3) return n.error(`Expected 2 arguments, but found ${e.length - 1} instead.`); const o = n.parse(e[1], 1, Ot), u = n.parse(e[2], 2, Ss(n.expectedType || Pi)); return o && u ? new at(u.type.itemType, o, u) : null; } evaluate(e) { const n = this.index.evaluate(e), o = this.input.evaluate(e); if (n < 0) throw new qn(`Array index out of bounds: ${n} < 0.`); if (n > o.length - 1) throw new qn(`Array index out of bounds: ${n} > ${o.length - 1}.`); if (n === Math.floor(n)) return o[n]; const u = Math.floor(n), l = Math.ceil(n), f = o[u], v = o[l]; if (typeof f != "number" || typeof v != "number") throw new qn(`Cannot interpolate between non-number values at index ${n}.`); const S = n - u; return f * (1 - S) + v * S; } eachChild(e) { e(this.index), e(this.input); } outputDefined() { return !1; } serialize() { return ["at", this.index.serialize(), this.input.serialize()]; } } class ft { constructor(e, n) { this.type = Li, this.needle = e, this.haystack = n; } static parse(e, n) { if (e.length !== 3) return n.error(`Expected 2 arguments, but found ${e.length - 1} instead.`); const o = n.parse(e[1], 1, Pi), u = n.parse(e[2], 2, Pi); return o && u ? Zl(o.type, [Li, Fi, Ot, ha, Pi]) ? new ft(o, u) : n.error(`Expected first argument to be of type boolean, string, number or null, but found ${un(o.type)} instead`) : null; } evaluate(e) { const n = this.needle.evaluate(e), o = this.haystack.evaluate(e); if (o == null) return !1; if (!da(n, ["boolean", "string", "number", "null"])) throw new qn(`Expected first argument to be of type boolean, string, number or null, but found ${un(vn(n))} instead.`); if (!da(o, ["string", "array"])) throw new qn(`Expected second argument to be of type array or string, but found ${un(vn(o))} instead.`); return o.indexOf(n) >= 0; } eachChild(e) { e(this.needle), e(this.haystack); } outputDefined() { return !0; } serialize() { return ["in", this.needle.serialize(), this.haystack.serialize()]; } } class Rt { constructor(e, n, o) { this.type = Ot, this.needle = e, this.haystack = n, this.fromIndex = o; } static parse(e, n) { if (e.length <= 2 || e.length >= 5) return n.error(`Expected 3 or 4 arguments, but found ${e.length - 1} instead.`); const o = n.parse(e[1], 1, Pi), u = n.parse(e[2], 2, Pi); if (!o || !u) return null; if (!Zl(o.type, [Li, Fi, Ot, ha, Pi])) return n.error(`Expected first argument to be of type boolean, string, number or null, but found ${un(o.type)} instead`); if (e.length === 4) { const l = n.parse(e[3], 3, Ot); return l ? new Rt(o, u, l) : null; } return new Rt(o, u); } evaluate(e) { const n = this.needle.evaluate(e), o = this.haystack.evaluate(e); if (!da(n, ["boolean", "string", "number", "null"])) throw new qn(`Expected first argument to be of type boolean, string, number or null, but found ${un(vn(n))} instead.`); if (!da(o, ["string", "array"])) throw new qn(`Expected second argument to be of type array or string, but found ${un(vn(o))} instead.`); if (this.fromIndex) { const u = this.fromIndex.evaluate(e); return o.indexOf(n, u); } return o.indexOf(n); } eachChild(e) { e(this.needle), e(this.haystack), this.fromIndex && e(this.fromIndex); } outputDefined() { return !1; } serialize() { if (this.fromIndex != null && this.fromIndex !== void 0) { const e = this.fromIndex.serialize(); return ["index-of", this.needle.serialize(), this.haystack.serialize(), e]; } return ["index-of", this.needle.serialize(), this.haystack.serialize()]; } } class ii { constructor(e, n, o, u, l, f) { this.inputType = e, this.type = n, this.input = o, this.cases = u, this.outputs = l, this.otherwise = f; } static parse(e, n) { if (e.length < 5) return n.error(`Expected at least 4 arguments, but found only ${e.length - 1}.`); if (e.length % 2 != 1) return n.error("Expected an even number of arguments."); let o, u; n.expectedType && n.expectedType.kind !== "value" && (u = n.expectedType); const l = {}, f = []; for (let D = 2; D < e.length - 1; D += 2) { let x = e[D]; const P = e[D + 1]; Array.isArray(x) || (x = [x]); const I = n.concat(D); if (x.length === 0) return I.error("Expected at least one branch label."); for (const C of x) { if (typeof C != "number" && typeof C != "string") return I.error("Branch labels must be numbers or strings."); if (typeof C == "number" && Math.abs(C) > Number.MAX_SAFE_INTEGER) return I.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`); if (typeof C == "number" && Math.floor(C) !== C) return I.error("Numeric branch labels must be integer values."); if (o) { if (I.checkSubtype(o, vn(C))) return null; } else o = vn(C); if (l[String(C)] !== void 0) return I.error("Branch labels must be unique."); l[String(C)] = f.length; } const M = n.parse(P, D, u); if (!M) return null; u = u || M.type, f.push(M); } const v = n.parse(e[1], 1, Pi); if (!v) return null; const S = n.parse(e[e.length - 1], e.length - 1, u); return S ? v.type.kind !== "value" && n.concat(1).checkSubtype(o, v.type) ? null : new ii(o, u, v, l, f, S) : null; } evaluate(e) { const n = this.input.evaluate(e); return (vn(n) === this.inputType && this.outputs[this.cases[n]] || this.otherwise).evaluate(e); } eachChild(e) { e(this.input), this.outputs.forEach(e), e(this.otherwise); } outputDefined() { return this.outputs.every((e) => e.outputDefined()) && this.otherwise.outputDefined(); } serialize() { const e = ["match", this.input.serialize()], n = Object.keys(this.cases).sort(), o = [], u = {}; for (const f of n) { const v = u[this.cases[f]]; v === void 0 ? (u[this.cases[f]] = o.length, o.push([this.cases[f], [f]])) : o[v][1].push(f); } const l = (f) => this.inputType.kind === "number" ? Number(f) : f; for (const [f, v] of o) e.push(v.length === 1 ? l(v[0]) : v.map(l)), e.push(this.outputs[f].serialize()); return e.push(this.otherwise.serialize()), e; } } class Ci { constructor(e, n, o) { this.type = e, this.branches = n, this.otherwise = o; } static parse(e, n) { if (e.length < 4) return n.error(`Expected at least 3 arguments, but found only ${e.length - 1}.`); if (e.length % 2 != 0) return n.error("Expected an odd number of arguments."); let o; n.expectedType && n.expectedType.kind !== "value" && (o = n.expectedType); const u = []; for (let f = 1; f < e.length - 1; f += 2) { const v = n.parse(e[f], f, Li); if (!v) return null; const S = n.parse(e[f + 1], f + 1, o); if (!S) return null; u.push([v, S]), o = o || S.type; } const l = n.parse(e[e.length - 1], e.length - 1, o); return l ? new Ci(o, u, l) : null; } evaluate(e) { for (const [n, o] of this.branches) if (n.evaluate(e)) return o.evaluate(e); return this.otherwise.evaluate(e); } eachChild(e) { for (const [n, o] of this.branches) e(n), e(o); e(this.otherwise); } outputDefined() { return this.branches.every(([e, n]) => n.outputDefined()) && this.otherwise.outputDefined(); } serialize() { const e = ["case"]; return this.eachChild((n) => { e.push(n.serialize()); }), e; } } class Wi { constructor(e, n, o, u) { this.type = e, this.input = n, this.beginIndex = o, this.endIndex = u; } static parse(e, n) { if (e.length <= 2 || e.length >= 5) return n.error(`Expected 3 or 4 arguments, but found ${e.length - 1} instead.`); const o = n.parse(e[1], 1, Pi), u = n.parse(e[2], 2, Ot); if (!o || !u) return null; if (!Zl(o.type, [Ss(Pi), Fi, Pi])) return n.error(`Expected first argument to be of type array or string, but found ${un(o.type)} instead`); if (e.length === 4) { const l = n.parse(e[3], 3, Ot); return l ? new Wi(o.type, o, u, l) : null; } return new Wi(o.type, o, u); } evaluate(e) { const n = this.input.evaluate(e), o = this.beginIndex.evaluate(e); if (!da(n, ["string", "array"])) throw new qn(`Expected first argument to be of type array or string, but found ${un(vn(n))} instead.`); if (this.endIndex) { const u = this.endIndex.evaluate(e); return n.slice(o, u); } return n.slice(o); } eachChild(e) { e(this.input), e(this.beginIndex), this.endIndex && e(this.endIndex); } outputDefined() { return !1; } serialize() { if (this.endIndex != null && this.endIndex !== void 0) { const e = this.endIndex.serialize(); return ["slice", this.input.serialize(), this.beginIndex.serialize(), e]; } return ["slice", this.input.serialize(), this.beginIndex.serialize()]; } } function Hs(r, e) { return r === "==" || r === "!=" ? e.kind === "boolean" || e.kind === "string" || e.kind === "number" || e.kind === "null" || e.kind === "value" : e.kind === "string" || e.kind === "number" || e.kind === "value"; } function ws(r, e, n, o) { return o.compare(e, n) === 0; } function Rs(r, e, n) { const o = r !== "==" && r !== "!="; return class bw { constructor(l, f, v) { this.type = Li, this.lhs = l, this.rhs = f, this.collator = v, this.hasUntypedArgument = l.type.kind === "value" || f.type.kind === "value"; } static parse(l, f) { if (l.length !== 3 && l.length !== 4) return f.error("Expected two or three arguments."); const v = l[0]; let S = f.parse(l[1], 1, Pi); if (!S) return null; if (!Hs(v, S.type)) return f.concat(1).error(`"${v}" comparisons are not supported for type '${un(S.type)}'.`); let D = f.parse(l[2], 2, Pi); if (!D) return null; if (!Hs(v, D.type)) return f.concat(2).error(`"${v}" comparisons are not supported for type '${un(D.type)}'.`); if (S.type.kind !== D.type.kind && S.type.kind !== "value" && D.type.kind !== "value") return f.error(`Cannot compare types '${un(S.type)}' and '${un(D.type)}'.`); o && (S.type.kind === "value" && D.type.kind !== "value" ? S = new zr(D.type, [S]) : S.type.kind !== "value" && D.type.kind === "value" && (D = new zr(S.type, [D]))); let x = null; if (l.length === 4) { if (S.type.kind !== "string" && D.type.kind !== "string" && S.type.kind !== "value" && D.type.kind !== "value") return f.error("Cannot use collator to compare non-string types."); if (x = f.parse(l[3], 3, _s), !x) return null; } return new bw(S, D, x); } evaluate(l) { const f = this.lhs.evaluate(l), v = this.rhs.evaluate(l); if (o && this.hasUntypedArgument) { const S = vn(f), D = vn(v); if (S.kind !== D.kind || S.kind !== "string" && S.kind !== "number") throw new qn(`Expected arguments for "${r}" to be (string, string) or (number, number), but found (${S.kind}, ${D.kind}) instead.`); } if (this.collator && !o && this.hasUntypedArgument) { const S = vn(f), D = vn(v); if (S.kind !== "string" || D.kind !== "string") return e(l, f, v); } return this.collator ? n(l, f, v, this.collator.evaluate(l)) : e(l, f, v); } eachChild(l) { l(this.lhs), l(this.rhs), this.collator && l(this.collator); } outputDefined() { return !0; } serialize() { const l = [r]; return this.eachChild((f) => { l.push(f.serialize()); }), l; } }; } const ur = Rs("==", function(r, e, n) { return e === n; }, ws), Za = Rs("!=", function(r, e, n) { return e !== n; }, function(r, e, n, o) { return !ws(0, e, n, o); }), nd = Rs("<", function(r, e, n) { return e < n; }, function(r, e, n, o) { return o.compare(e, n) < 0; }), sd = Rs(">", function(r, e, n) { return e > n; }, function(r, e, n, o) { return o.compare(e, n) > 0; }), rd = Rs("<=", function(r, e, n) { return e <= n; }, function(r, e, n, o) { return o.compare(e, n) <= 0; }), Xh = Rs(">=", function(r, e, n) { return e >= n; }, function(r, e, n, o) { return o.compare(e, n) >= 0; }); class wl { constructor(e, n, o, u, l, f) { this.type = Fi, this.number = e, this.locale = n, this.currency = o, this.unit = u, this.minFractionDigits = l, this.maxFractionDigits = f; } static parse(e, n) { if (e.length !== 3) return n.error("Expected two arguments."); const o = n.parse(e[1], 1, Ot); if (!o) return null; const u = e[2]; if (typeof u != "object" || Array.isArray(u)) return n.error("NumberFormat options argument must be an object."); let l = null; if (u.locale && (l = n.parseObjectValue(u.locale, 2, "locale", Fi), !l)) return null; let f = null; if (u.currency && (f = n.parseObjectValue(u.currency, 2, "currency", Fi), !f)) return null; let v = null; if (u.unit && (v = n.parseObjectValue(u.unit, 2, "unit", Fi), !v)) return null; let S = null; if (u["min-fraction-digits"] && (S = n.parseObjectValue(u["min-fraction-digits"], 2, "min-fraction-digits", Ot), !S)) return null; let D = null; return u["max-fraction-digits"] && (D = n.parseObjectValue(u["max-fraction-digits"], 2, "max-fraction-digits", Ot), !D) ? null : new wl(o, l, f, v, S, D); } evaluate(e) { return new Intl.NumberFormat(this.locale ? this.locale.evaluate(e) : [], { style: (this.currency ? "currency" : this.unit && "unit") || "decimal", currency: this.currency ? this.currency.evaluate(e) : void 0, unit: this.unit ? this.unit.evaluate(e) : void 0, minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(e) : void 0, maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(e) : void 0 }).format(this.number.evaluate(e)); } eachChild(e) { e(this.number), this.locale && e(this.locale), this.currency && e(this.currency), this.unit && e(this.unit), this.minFractionDigits && e(this.minFractionDigits), this.maxFractionDigits && e(this.maxFractionDigits); } outputDefined() { return !1; } serialize() { const e = {}; return this.locale && (e.locale = this.locale.serialize()), this.currency && (e.currency = this.currency.serialize()), this.unit && (e.unit = this.unit.serialize()), this.minFractionDigits && (e["min-fraction-digits"] = this.minFractionDigits.serialize()), this.maxFractionDigits && (e["max-fraction-digits"] = this.maxFractionDigits.serialize()), ["number-format", this.number.serialize(), e]; } } class ic { constructor(e) { this.type = Ot, this.input = e; } static parse(e, n) { if (e.length !== 2) return n.error(`Expected 1 argument, but found ${e.length - 1} instead.`); const o = n.parse(e[1], 1); return o ? o.type.kind !== "array" && o.type.kind !== "string" && o.type.kind !== "value" ? n.error(`Expected argument of type string or array, but found ${un(o.type)} instead.`) : new ic(o) : null; } evaluate(e) { const n = this.input.evaluate(e); if (typeof n == "string" || Array.isArray(n)) return n.length; throw new qn(`Expected value to be of type string or array, but found ${un(vn(n))} instead.`); } eachChild(e) { e(this.input); } outputDefined() { return !1; } serialize() { const e = ["length"]; return this.eachChild((n) => { e.push(n.serialize()); }), e; } } function es(r) { return function() { r = 1831565813 + (r |= 0) | 0; let e = Math.imul(r ^ r >>> 15, 1 | r); return e = e + Math.imul(e ^ e >>> 7, 61 | e) ^ e, ((e ^ e >>> 14) >>> 0) / 4294967296; }; } const Ao = { "==": ur, "!=": Za, ">": sd, "<": nd, ">=": Xh, "<=": rd, array: zr, at, boolean: zr, case: Ci, coalesce: ye, collator: pl, format: Es, image: Oa, in: ft, "index-of": Rt, interpolate: X, "interpolate-hcl": X, "interpolate-lab": X, length: ic, let: We, literal: Lr, match: ii, number: zr, "number-format": wl, object: zr, slice: Wi, step: Ti, string: zr, "to-boolean": so, "to-color": so, "to-number": so, "to-string": so, var: Jo, within: lr, distance: Jr, config: ya }; function Yh(r, [e, n, o, u]) { e = e.evaluate(r), n = n.evaluate(r), o = o.evaluate(r); const l = u ? u.evaluate(r) : 1, f = fa(e, n, o, l); if (f) throw new qn(f); return new ki(e / 255 * l, n / 255 * l, o / 255 * l, l); } function Kh(r, [e, n, o, u]) { e = e.evaluate(r), n = n.evaluate(r), o = o.evaluate(r); const l = u ? u.evaluate(r) : 1, f = function(D, x, P, I) { return typeof D == "number" && D >= 0 && D <= 360 ? typeof x == "number" && x >= 0 && x <= 100 && typeof P == "number" && P >= 0 && P <= 100 ? I === void 0 || typeof I == "number" && I >= 0 && I <= 1 ? null : `Invalid hsla value [${[D, x, P, I].join(", ")}]: 'a' must be between 0 and 1.` : `Invalid hsla value [${(typeof I == "number" ? [D, x, P, I] : [D, x, P]).join(", ")}]: 's', and 'l' must be between 0 and 100.` : `Invalid hsla value [${(typeof I == "number" ? [D, x, P, I] : [D, x, P]).join(", ")}]: 'h' must be between 0 and 360.`; }(e, n, o, l); if (f) throw new qn(f); const v = `hsla(${e}, ${n}%, ${o}%, ${l})`, S = ki.parse(v); if (!S) throw new qn(`Failed to parse HSLA color: ${v}`); return S; } function Yc(r, e) { return r in e; } function Ha(r, e) { const n = e[r]; return n === void 0 ? null : n; } function vr(r) { return { type: r }; } function Kc(r) { return { result: "success", value: r }; } function xa(r) { return { result: "error", value: r }; } function od(r, e) { return !!r && !!r.parameters && r.parameters.indexOf(e) > -1; } function nc(r) { return r["property-type"] === "data-driven"; } function Jh(r) { return od(r.expression, "measure-light"); } function qf(r) { return od(r.expression, "zoom"); } function ad(r) { return !!r.expression && r.expression.interpolated; } function Qh(r) { return typeof r == "object" && r !== null && !Array.isArray(r); } function Wf(r) { return r; } function $f(r, e) { const n = e.type === "color", o = r.stops && typeof r.stops[0][0] == "object", u = o || !(o || r.property !== void 0), l = r.type || (ad(e) ? "exponential" : "interval"); if (n && ((r = Bi({}, r)).stops && (r.stops = r.stops.map((D) => [D[0], ki.parse(D[1])])), r.default = ki.parse(r.default ? r.default : e.default)), r.colorSpace && r.colorSpace !== "rgb" && !B[r.colorSpace]) throw new Error(`Unknown color space: ${r.colorSpace}`); let f, v, S; if (l === "exponential") f = ld; else if (l === "interval") f = Xf; else if (l === "categorical") { f = Jm, v = /* @__PURE__ */ Object.create(null); for (const D of r.stops) v[D[0]] = D[1]; S = typeof r.stops[0][0]; } else { if (l !== "identity") throw new Error(`Unknown function type "${l}"`); f = eu; } if (o) { const D = {}, x = []; for (let M = 0; M < r.stops.length; M++) { const C = r.stops[M], k = C[0].zoom; D[k] === void 0 && (D[k] = { zoom: k, type: r.type, property: r.property, default: r.default, stops: [] }, x.push(k)), D[k].stops.push([C[0].value, C[1]]); } const P = []; for (const M of x) P.push([D[M].zoom, $f(D[M], e)]); const I = { name: "linear" }; return { kind: "composite", interpolationType: I, interpolationFactor: X.interpolationFactor.bind(void 0, I), zoomStops: P.map((M) => M[0]), evaluate: ({ zoom: M }, C) => ld({ stops: P, base: r.base }, e, M).evaluate(M, C) }; } if (u) { const D = l === "exponential" ? { name: "exponential", base: r.base !== void 0 ? r.base : 1 } : null; return { kind: "camera", interpolationType: D, interpolationFactor: X.interpolationFactor.bind(void 0, D), zoomStops: r.stops.map((x) => x[0]), evaluate: ({ zoom: x }) => f(r, e, x, v, S) }; } return { kind: "source", evaluate(D, x) { const P = x && x.properties ? x.properties[r.property] : void 0; return P === void 0 ? Jc(r.default, e.default) : f(r, e, P, v, S); } }; } function Jc(r, e, n) { return r !== void 0 ? r : e !== void 0 ? e : n !== void 0 ? n : void 0; } function Jm(r, e, n, o, u) { return Jc(typeof n === u ? o[n] : void 0, r.default, e.default); } function Xf(r, e, n) { if (qo(n) !== "number") return Jc(r.default, e.default); const o = r.stops.length; if (o === 1 || n <= r.stops[0][0]) return r.stops[0][1]; if (n >= r.stops[o - 1][0]) return r.stops[o - 1][1]; const u = ao(r.stops.map((l) => l[0]), n); return r.stops[u][1]; } function ld(r, e, n) { const o = r.base !== void 0 ? r.base : 1; if (qo(n) !== "number") return Jc(r.default, e.default); const u = r.stops.length; if (u === 1 || n <= r.stops[0][0]) return r.stops[0][1]; if (n >= r.stops[u - 1][0]) return r.stops[u - 1][1]; const l = ao(r.stops.map((x) => x[0]), n), f = function(x, P, I, M) { const C = M - I, k = x - I; return C === 0 ? 0 : P === 1 ? k / C : (Math.pow(P, k) - 1) / (Math.pow(P, C) - 1); }(n, o, r.stops[l][0], r.stops[l + 1][0]), v = r.stops[l][1], S = r.stops[l + 1][1]; let D = Oi[e.type] || Wf; if (r.colorSpace && r.colorSpace !== "rgb") { const x = B[r.colorSpace]; D = (P, I) => x.reverse(x.interpolate(x.forward(P), x.forward(I), f)); } return typeof v.evaluate == "function" ? { evaluate(...x) { const P = v.evaluate.apply(void 0, x), I = S.evaluate.apply(void 0, x); if (P !== void 0 && I !== void 0) return D(P, I, f); } } : D(v, S, f); } function eu(r, e, n) { return e.type === "color" ? n = ki.parse(n) : e.type === "formatted" ? n = Dn.fromString(n.toString()) : e.type === "resolvedImage" ? n = ss.build(n.toString()) : qo(n) === e.type || e.type === "enum" && e.values[n] || (n = void 0), Jc(n, r.default, e.default); } or.register(Ao, { error: [{ kind: "error" }, [Fi], (r, [e]) => { throw new qn(e.evaluate(r)); }], typeof: [Fi, [Pi], (r, [e]) => un(vn(e.evaluate(r)))], "to-rgba": [Ss(Ot, 4), [ms], (r, [e]) => e.evaluate(r).toRenderColor(null).toArray()], "to-hsla": [Ss(Ot, 4), [ms], (r, [e]) => e.evaluate(r).toRenderColor(null).toHslaArray()], rgb: [ms, [Ot, Ot, Ot], Yh], rgba: [ms, [Ot, Ot, Ot, Ot], Yh], hsl: [ms, [Ot, Ot, Ot], Kh], hsla: [ms, [Ot, Ot, Ot, Ot], Kh], has: { type: Li, overloads: [[[Fi], (r, [e]) => Yc(e.evaluate(r), r.properties())], [[Fi, bo], (r, [e, n]) => Yc(e.evaluate(r), n.evaluate(r))]] }, get: { type: Pi, overloads: [[[Fi], (r, [e]) => Ha(e.evaluate(r), r.properties())], [[Fi, bo], (r, [e, n]) => Ha(e.evaluate(r), n.evaluate(r))]] }, "feature-state": [Pi, [Fi], (r, [e]) => Ha(e.evaluate(r), r.featureState || {})], properties: [bo, [], (r) => r.properties()], "geometry-type": [Fi, [], (r) => r.geometryType()], id: [Pi, [], (r) => r.id()], zoom: [Ot, [], (r) => r.globals.zoom], pitch: [Ot, [], (r) => r.globals.pitch || 0], "distance-from-center": [Ot, [], (r) => r.distanceFromCenter()], "measure-light": [Ot, [Fi], (r, [e]) => r.measureLight(e.evaluate(r))], "heatmap-density": [Ot, [], (r) => r.globals.heatmapDensity || 0], "line-progress": [Ot, [], (r) => r.globals.lineProgress || 0], "raster-value": [Ot, [], (r) => r.globals.rasterValue || 0], "raster-particle-speed": [Ot, [], (r) => r.globals.rasterParticleSpeed || 0], "sky-radial-progress": [Ot, [], (r) => r.globals.skyRadialProgress || 0], accumulated: [Pi, [], (r) => r.globals.accumulated === void 0 ? null : r.globals.accumulated], "+": [Ot, vr(Ot), (r, e) => { let n = 0; for (const o of e) n += o.evaluate(r); return n; }], "*": [Ot, vr(Ot), (r, e) => { let n = 1; for (const o of e) n *= o.evaluate(r); return n; }], "-": { type: Ot, overloads: [[[Ot, Ot], (r, [e, n]) => e.evaluate(r) - n.evaluate(r)], [[Ot], (r, [e]) => -e.evaluate(r)]] }, "/": [Ot, [Ot, Ot], (r, [e, n]) => e.evaluate(r) / n.evaluate(r)], "%": [Ot, [Ot, Ot], (r, [e, n]) => e.evaluate(r) % n.evaluate(r)], ln2: [Ot, [], () => Math.LN2], pi: [Ot, [], () => Math.PI], e: [Ot, [], () => Math.E], "^": [Ot, [Ot, Ot], (r, [e, n]) => Math.pow(e.evaluate(r), n.evaluate(r))], sqrt: [Ot, [Ot], (r, [e]) => Math.sqrt(e.evaluate(r))], log10: [Ot, [Ot], (r, [e]) => Math.log(e.evaluate(r)) / Math.LN10], ln: [Ot, [Ot], (r, [e]) => Math.log(e.evaluate(r))], log2: [Ot, [Ot], (r, [e]) => Math.log(e.evaluate(r)) / Math.LN2], sin: [Ot, [Ot], (r, [e]) => Math.sin(e.evaluate(r))], cos: [Ot, [Ot], (r, [e]) => Math.cos(e.evaluate(r))], tan: [Ot, [Ot], (r, [e]) => Math.tan(e.evaluate(r))], asin: [Ot, [Ot], (r, [e]) => Math.asin(e.evaluate(r))], acos: [Ot, [Ot], (r, [e]) => Math.acos(e.evaluate(r))], atan: [Ot, [Ot], (r, [e]) => Math.atan(e.evaluate(r))], min: [Ot, vr(Ot), (r, e) => Math.min(...e.map((n) => n.evaluate(r)))], max: [Ot, vr(Ot), (r, e) => Math.max(...e.map((n) => n.evaluate(r)))], abs: [Ot, [Ot], (r, [e]) => Math.abs(e.evaluate(r))], round: [Ot, [Ot], (r, [e]) => { const n = e.evaluate(r); return n < 0 ? -Math.round(-n) : Math.round(n); }], floor: [Ot, [Ot], (r, [e]) => Math.floor(e.evaluate(r))], ceil: [Ot, [Ot], (r, [e]) => Math.ceil(e.evaluate(r))], "filter-==": [Li, [Fi, Pi], (r, [e, n]) => r.properties()[e.value] === n.value], "filter-id-==": [Li, [Pi], (r, [e]) => r.id() === e.value], "filter-type-==": [Li, [Fi], (r, [e]) => r.geometryType() === e.value], "filter-<": [Li, [Fi, Pi], (r, [e, n]) => { const o = r.properties()[e.value], u = n.value; return typeof o == typeof u && o < u; }], "filter-id-<": [Li, [Pi], (r, [e]) => { const n = r.id(), o = e.value; return typeof n == typeof o && n < o; }], "filter->": [Li, [Fi, Pi], (r, [e, n]) => { const o = r.properties()[e.value], u = n.value; return typeof o == typeof u && o > u; }], "filter-id->": [Li, [Pi], (r, [e]) => { const n = r.id(), o = e.value; return typeof n == typeof o && n > o; }], "filter-<=": [Li, [Fi, Pi], (r, [e, n]) => { const o = r.properties()[e.value], u = n.value; return typeof o == typeof u && o <= u; }], "filter-id-<=": [Li, [Pi], (r, [e]) => { const n = r.id(), o = e.value; return typeof n == typeof o && n <= o; }], "filter->=": [Li, [Fi, Pi], (r, [e, n]) => { const o = r.properties()[e.value], u = n.value; return typeof o == typeof u && o >= u; }], "filter-id->=": [Li, [Pi], (r, [e]) => { const n = r.id(), o = e.value; return typeof n == typeof o && n >= o; }], "filter-has": [Li, [Pi], (r, [e]) => e.value in r.properties()], "filter-has-id": [Li, [], (r) => r.id() !== null && r.id() !== void 0], "filter-type-in": [Li, [Ss(Fi)], (r, [e]) => e.value.indexOf(r.geometryType()) >= 0], "filter-id-in": [Li, [Ss(Pi)], (r, [e]) => e.value.indexOf(r.id()) >= 0], "filter-in-small": [Li, [Fi, Ss(Pi)], (r, [e, n]) => n.value.indexOf(r.properties()[e.value]) >= 0], "filter-in-large": [Li, [Fi, Ss(Pi)], (r, [e, n]) => function(o, u, l, f) { for (; l <= f; ) { const v = l + f >> 1; if (u[v] === o) return !0; u[v] > o ? f = v - 1 : l = v + 1; } return !1; }(r.properties()[e.value], n.value, 0, n.value.length - 1)], all: { type: Li, overloads: [[[Li, Li], (r, [e, n]) => e.evaluate(r) && n.evaluate(r)], [vr(Li), (r, e) => { for (const n of e) if (!n.evaluate(r)) return !1; return !0; }]] }, any: { type: Li, overloads: [[[Li, Li], (r, [e, n]) => e.evaluate(r) || n.evaluate(r)], [vr(Li), (r, e) => { for (const n of e) if (n.evaluate(r)) return !0; return !1; }]] }, "!": [Li, [Li], (r, [e]) => !e.evaluate(r)], "is-supported-script": [Li, [Fi], (r, [e]) => { const n = r.globals && r.globals.isSupportedScript; return !n || n(e.evaluate(r)); }], upcase: [Fi, [Fi], (r, [e]) => e.evaluate(r).toUpperCase()], downcase: [Fi, [Fi], (r, [e]) => e.evaluate(r).toLowerCase()], concat: [Fi, vr(Pi), (r, e) => e.map((n) => Ir(n.evaluate(r))).join("")], "resolved-locale": [Fi, [_s], (r, [e]) => e.evaluate(r).resolvedLocale()], random: [Ot, [Ot, Ot, Pi], (r, e) => { const [n, o, u] = e.map((f) => f.evaluate(r)); if (n > o || n === o) return n; let l; if (typeof u == "string") l = function(f) { let v = 0; if (f.length === 0) return v; for (let S = 0; S < f.length; S++) v = (v << 5) - v + f.charCodeAt(S), v |= 0; return v; }(u); else { if (typeof u != "number") throw new qn(`Invalid seed input: ${u}`); l = u; } return n + es(l)() * (o - n); }] }); class cd { constructor(e, n, o, u) { this.expression = e, this._warningHistory = {}, this._evaluator = new Fa(o, u), this._defaultValue = n ? function(l) { return l.type === "color" && (Qh(l.default) || Array.isArray(l.default)) ? new ki(0, 0, 0, 0) : l.type === "color" ? ki.parse(l.default) || null : l.default === void 0 ? null : l.default; }(n) : null, this._enumValues = n && n.type === "enum" ? n.values : null, this.configDependencies = kr(e); } evaluateWithoutErrorHandling(e, n, o, u, l, f, v, S) { return this._evaluator.globals = e, this._evaluator.feature = n, this._evaluator.featureState = o, this._evaluator.canonical = u || null, this._evaluator.availableImages = l || null, this._evaluator.formattedSection = f, this._evaluator.featureTileCoord = v || null, this._evaluator.featureDistanceData = S || null, this.expression.evaluate(this._evaluator); } evaluate(e, n, o, u, l, f, v, S) { this._evaluator.globals = e, this._evaluator.feature = n || null, this._evaluator.featureState = o || null, this._evaluator.canonical = u || null, this._evaluator.availableImages = l || null, this._evaluator.formattedSection = f || null, this._evaluator.featureTileCoord = v || null, this._evaluator.featureDistanceData = S || null; try { const D = this.expression.evaluate(this._evaluator); if (D == null || typeof D == "number" && D != D) return this._defaultValue; if (this._enumValues && !(D in this._enumValues)) throw new qn(`Expected value to be one of ${Object.keys(this._enumValues).map((x) => JSON.stringify(x)).join(", ")}, but found ${JSON.stringify(D)} instead.`); return D; } catch (D) { return this._warningHistory[D.message] || (this._warningHistory[D.message] = !0, typeof console < "u" && console.warn(`Failed to evaluate expression "${JSON.stringify(this.expression.serialize())}". ${D.message}`)), this._defaultValue; } } } function tu(r) { return Array.isArray(r) && r.length > 0 && typeof r[0] == "string" && r[0] in Ao; } function Qc(r, e, n, o) { const u = new Qr(Ao, [], e ? function(f) { const v = { color: ms, string: Fi, number: Ot, enum: Fi, boolean: Li, formatted: Js, resolvedImage: Ho }; return f.type === "array" ? Ss(v[f.value] || Pi, f.length) : v[f.type]; }(e) : void 0, void 0, void 0, n, o), l = u.parse(r, void 0, void 0, void 0, e && e.type === "string" ? { typeAnnotation: "coerce" } : void 0); return l ? Kc(new cd(l, e, n, o)) : xa(u.errors); } class hd { constructor(e, n, o, u) { this.kind = e, this._styleExpression = n, this.isLightConstant = o, this.isLineProgressConstant = u, this.isStateDependent = e !== "constant" && !xl(n.expression), this.configDependencies = kr(n.expression); } evaluateWithoutErrorHandling(e, n, o, u, l, f) { return this._styleExpression.evaluateWithoutErrorHandling(e, n, o, u, l, f); } evaluate(e, n, o, u, l, f) { return this._styleExpression.evaluate(e, n, o, u, l, f); } } class sc { constructor(e, n, o, u, l, f) { this.kind = e, this.zoomStops = o, this._styleExpression = n, this.isStateDependent = e !== "camera" && !xl(n.expression), this.isLightConstant = l, this.isLineProgressConstant = f, this.configDependencies = kr(n.expression), this.interpolationType = u; } evaluateWithoutErrorHandling(e, n, o, u, l, f) { return this._styleExpression.evaluateWithoutErrorHandling(e, n, o, u, l, f); } evaluate(e, n, o, u, l, f) { return this._styleExpression.evaluate(e, n, o, u, l, f); } interpolationFactor(e, n, o) { return this.interpolationType ? X.interpolationFactor(this.interpolationType, e, n, o) : 0; } } function ud(r, e, n, o) { if ((r = Qc(r, e, n, o)).result === "error") return r; const u = r.value.expression, l = ro(u); if (!l && !nc(e)) return xa([new ns("", "data expressions not supported")]); const f = oo(u, ["zoom", "pitch", "distance-from-center"]); if (!f && !qf(e)) return xa([new ns("", "zoom expressions not supported")]); const v = oo(u, ["measure-light"]); if (!v && !Jh(e)) return xa([new ns("", "measure-light expression not supported")]); const S = oo(u, ["line-progress"]); if (!S && !function(P) { return od(P.expression, "line-progress"); }(e)) return xa([new ns("", "line-progress expression not supported")]); const D = e.expression && e.expression.relaxZoomRestriction, x = nu(u); return x || f || D ? x instanceof ns ? xa([x]) : x instanceof X && !ad(e) ? xa([new ns("", '"interpolate" expressions cannot be used with this property')]) : Kc(x ? new sc(l && S ? "camera" : "composite", r.value, x.labels, x instanceof X ? x.interpolation : void 0, v, S) : new hd(l && S ? "constant" : "source", r.value, v, S)) : xa([new ns("", '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression, or in the properties of atmosphere.')]); } class iu { constructor(e, n) { this._parameters = e, this._specification = n, Bi(this, $f(this._parameters, this._specification)); } static deserialize(e) { return new iu(e._parameters, e._specification); } static serialize(e) { return { _parameters: e._parameters, _specification: e._specification }; } } function nu(r) { let e = null; if (r instanceof We) e = nu(r.result); else if (r instanceof ye) { for (const n of r.args) if (e = nu(n), e) break; } else (r instanceof Ti || r instanceof X) && r.input instanceof or && r.input.name === "zoom" && (e = r); return e instanceof ns || r.eachChild((n) => { const o = nu(n); o instanceof ns ? e = o : e && o && e !== o && (e = new ns("", 'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.')); }), e; } var dd, fd, Qm = function() { if (fd) return dd; fd = 1, dd = e; var r = 3; function e(n, o, u) { var l = this.cells = []; if (n instanceof ArrayBuffer) { this.arrayBuffer = n; var f = new Int32Array(this.arrayBuffer); n = f[0], this.d = (o = f[1]) + 2 * (u = f[2]); for (var v = 0; v < this.d * this.d; v++) { var S = f[r + v], D = f[r + v + 1]; l.push(S === D ? null : f.subarray(S, D)); } var x = f[r + l.length + 1]; this.keys = f.subarray(f[r + l.length], x), this.bboxes = f.subarray(x), this.insert = this._insertReadonly; } else { this.d = o + 2 * u; for (var P = 0; P < this.d * this.d; P++) l.push([]); this.keys = [], this.bboxes = []; } this.n = o, this.extent = n, this.padding = u, this.scale = o / n, this.uid = 0; var I = u / o * n; this.min = -I, this.max = n + I; } return e.prototype.insert = function(n, o, u, l, f) { this._forEachCell(o, u, l, f, this._insertCell, this.uid++), this.keys.push(n), this.bboxes.push(o), this.bboxes.push(u), this.bboxes.push(l), this.bboxes.push(f); }, e.prototype._insertReadonly = function() { throw "Cannot insert into a GridIndex created from an ArrayBuffer."; }, e.prototype._insertCell = function(n, o, u, l, f, v) { this.cells[f].push(v); }, e.prototype.query = function(n, o, u, l, f) { var v = this.min, S = this.max; if (n <= v && o <= v && S <= u && S <= l && !f) return Array.prototype.slice.call(this.keys); var D = []; return this._forEachCell(n, o, u, l, this._queryCell, D, {}, f), D; }, e.prototype._queryCell = function(n, o, u, l, f, v, S, D) { var x = this.cells[f]; if (x !== null) for (var P = this.keys, I = this.bboxes, M = 0; M < x.length; M++) { var C = x[M]; if (S[C] === void 0) { var k = 4 * C; (D ? D(I[k + 0], I[k + 1], I[k + 2], I[k + 3]) : n <= I[k + 2] && o <= I[k + 3] && u >= I[k + 0] && l >= I[k + 1]) ? (S[C] = !0, v.push(P[C])) : S[C] = !1; } } }, e.prototype._forEachCell = function(n, o, u, l, f, v, S, D) { for (var x = this._convertToCellCoord(n), P = this._convertToCellCoord(o), I = this._convertToCellCoord(u), M = this._convertToCellCoord(l), C = x; C <= I; C++) for (var k = P; k <= M; k++) { var V = this.d * k + C; if ((!D || D(this._convertFromCellCoord(C), this._convertFromCellCoord(k), this._convertFromCellCoord(C + 1), this._convertFromCellCoord(k + 1))) && f.call(this, n, o, u, l, V, v, S, D)) return; } }, e.prototype._convertFromCellCoord = function(n) { return (n - this.padding) / this.scale; }, e.prototype._convertToCellCoord = function(n) { return Math.max(0, Math.min(this.d - 1, Math.floor(n * this.scale) + this.padding)); }, e.prototype.toArrayBuffer = function() { if (this.arrayBuffer) return this.arrayBuffer; for (var n = this.cells, o = r + this.cells.length + 1 + 1, u = 0, l = 0; l < this.cells.length; l++) u += this.cells[l].length; var f = new Int32Array(o + u + this.keys.length + this.bboxes.length); f[0] = this.extent, f[1] = this.n, f[2] = this.padding; for (var v = o, S = 0; S < n.length; S++) { var D = n[S]; f[r + S] = v, f.set(D, v), v += D.length; } return f[r + n.length] = v, f.set(this.keys, v), f[r + n.length + 1] = v += this.keys.length, f.set(this.bboxes, v), v += this.bboxes.length, f.buffer; }, dd; }(), rc = O(Qm); const eh = {}; function Ft(r, e, n = {}) { Object.defineProperty(r, "_classRegistryKey", { value: e, writable: !1 }), eh[e] = { klass: r, omit: n.omit || [] }; } Ft(Object, "Object"), rc.serialize = function(r, e) { const n = r.toArrayBuffer(); return e && e.add(n), { buffer: n }; }, rc.deserialize = function(r) { return new rc(r.buffer); }, Object.defineProperty(rc, "name", { value: "Grid" }), Ft(rc, "Grid"), typeof DOMMatrix < "u" && Ft(DOMMatrix, "DOMMatrix"), Ft(ki, "Color"), Ft(Error, "Error"), Ft(Dn, "Formatted"), Ft(dl, "FormattedSection"), Ft(jo, "AJAXError"), Ft(ss, "ResolvedImage"), Ft(iu, "StylePropertyFunction"), Ft(cd, "StyleExpression", { omit: ["_evaluator"] }), Ft(rr, "ImageIdWithOptions"), Ft(sc, "ZoomDependentExpression"), Ft(hd, "ZoomConstantExpression"), Ft(or, "CompoundExpression", { omit: ["_evaluate"] }); for (const r in Ao) eh[Ao[r]._classRegistryKey] || Ft(Ao[r], `Expression${r}`); function pd(r) { return r && typeof ArrayBuffer < "u" && (r instanceof ArrayBuffer || r.constructor && r.constructor.name === "ArrayBuffer"); } function Yf(r) { return self.ImageBitmap && r instanceof ImageBitmap; } function lo(r, e) { if (r == null || typeof r == "boolean" || typeof r == "number" || typeof r == "string" || r instanceof Boolean || r instanceof Number || r instanceof String || r instanceof Date || r instanceof RegExp) return r; if (pd(r) || Yf(r)) return e && e.add(r), r; if (ArrayBuffer.isView(r)) return e && e.add(r.buffer), r; if (r instanceof ImageData) return e && e.add(r.data.buffer), r; if (Array.isArray(r)) { const n = []; for (const o of r) n.push(lo(o, e)); return n; } if (r instanceof Map) { const n = { $name: "Map" }; for (const [o, u] of r.entries()) n[o] = lo(u); return n; } if (r instanceof Set) { const n = { $name: "Set" }; let o = 0; for (const u of r.values()) n[++o] = lo(u); return n; } if (typeof r == "object") { const n = r.constructor, o = n._classRegistryKey; if (!o) throw new Error(`Can't serialize object of unregistered class "${o}".`); const u = n.serialize ? n.serialize(r, e) : {}; if (!n.serialize) { for (const l in r) r.hasOwnProperty(l) && (eh[o].omit.indexOf(l) >= 0 || (u[l] = lo(r[l], e))); r instanceof Error && (u.message = r.message); } if (u.$name) throw new Error("$name property is reserved for worker serialization logic."); return o !== "Object" && (u.$name = o), u; } throw new Error("can't serialize object of type " + typeof r); } function Tl(r) { if (r == null || typeof r == "boolean" || typeof r == "number" || typeof r == "string" || r instanceof Boolean || r instanceof Number || r instanceof String || r instanceof Date || r instanceof RegExp || pd(r) || Yf(r) || ArrayBuffer.isView(r) || r instanceof ImageData) return r; if (Array.isArray(r)) return r.map(Tl); if (typeof r == "object") { const e = r.$name || "Object"; if (e === "Map") { const u = /* @__PURE__ */ new Map(); for (const l of Object.keys(r)) l !== "$name" && u.set(l, Tl(r[l])); return u; } if (e === "Set") { const u = /* @__PURE__ */ new Set(); for (const l of Object.keys(r)) l !== "$name" && u.add(Tl(r[l])); return u; } const { klass: n } = eh[e]; if (!n) throw new Error(`Can't deserialize unregistered class "${e}".`); if (n.deserialize) return n.deserialize(r); const o = Object.create(n.prototype); for (const u of Object.keys(r)) u !== "$name" && (o[u] = Tl(r[u])); return o; } throw new Error("can't deserialize object of type " + typeof r); } const Zt = { "Latin-1 Supplement": (r) => r >= 128 && r <= 255, Arabic: (r) => r >= 1536 && r <= 1791, "Arabic Supplement": (r) => r >= 1872 && r <= 1919, "Arabic Extended-A": (r) => r >= 2208 && r <= 2303, "Hangul Jamo": (r) => r >= 4352 && r <= 4607, "Unified Canadian Aboriginal Syllabics": (r) => r >= 5120 && r <= 5759, Khmer: (r) => r >= 6016 && r <= 6143, "Unified Canadian Aboriginal Syllabics Extended": (r) => r >= 6320 && r <= 6399, "General Punctuation": (r) => r >= 8192 && r <= 8303, "Letterlike Symbols": (r) => r >= 8448 && r <= 8527, "Number Forms": (r) => r >= 8528 && r <= 8591, "Miscellaneous Technical": (r) => r >= 8960 && r <= 9215, "Control Pictures": (r) => r >= 9216 && r <= 9279, "Optical Character Recognition": (r) => r >= 9280 && r <= 9311, "Enclosed Alphanumerics": (r) => r >= 9312 && r <= 9471, "Geometric Shapes": (r) => r >= 9632 && r <= 9727, "Miscellaneous Symbols": (r) => r >= 9728 && r <= 9983, "Miscellaneous Symbols and Arrows": (r) => r >= 11008 && r <= 11263, "CJK Radicals Supplement": (r) => r >= 11904 && r <= 12031, "Kangxi Radicals": (r) => r >= 12032 && r <= 12255, "Ideographic Description Characters": (r) => r >= 12272 && r <= 12287, "CJK Symbols and Punctuation": (r) => r >= 12288 && r <= 12351, Hiragana: (r) => r >= 12352 && r <= 12447, Katakana: (r) => r >= 12448 && r <= 12543, Bopomofo: (r) => r >= 12544 && r <= 12591, "Hangul Compatibility Jamo": (r) => r >= 12592 && r <= 12687, Kanbun: (r) => r >= 12688 && r <= 12703, "Bopomofo Extended": (r) => r >= 12704 && r <= 12735, "CJK Strokes": (r) => r >= 12736 && r <= 12783, "Katakana Phonetic Extensions": (r) => r >= 12784 && r <= 12799, "Enclosed CJK Letters and Months": (r) => r >= 12800 && r <= 13055, "CJK Compatibility": (r) => r >= 13056 && r <= 13311, "CJK Unified Ideographs Extension A": (r) => r >= 13312 && r <= 19903, "Yijing Hexagram Symbols": (r) => r >= 19904 && r <= 19967, "CJK Unified Ideographs": (r) => r >= 19968 && r <= 40959, "Yi Syllables": (r) => r >= 40960 && r <= 42127, "Yi Radicals": (r) => r >= 42128 && r <= 42191, "Hangul Jamo Extended-A": (r) => r >= 43360 && r <= 43391, "Hangul Syllables": (r) => r >= 44032 && r <= 55215, "Hangul Jamo Extended-B": (r) => r >= 55216 && r <= 55295, "Private Use Area": (r) => r >= 57344 && r <= 63743, "CJK Compatibility Ideographs": (r) => r >= 63744 && r <= 64255, "Arabic Presentation Forms-A": (r) => r >= 64336 && r <= 65023, "Vertical Forms": (r) => r >= 65040 && r <= 65055, "CJK Compatibility Forms": (r) => r >= 65072 && r <= 65103, "Small Form Variants": (r) => r >= 65104 && r <= 65135, "Arabic Presentation Forms-B": (r) => r >= 65136 && r <= 65279, "Halfwidth and Fullwidth Forms": (r) => r >= 65280 && r <= 65519, Osage: (r) => r >= 66736 && r <= 66815, "CJK Unified Ideographs Extension B": (r) => r >= 131072 && r <= 173791 }; function md(r) { for (const e of r) if (su(e.charCodeAt(0))) return !0; return !1; } function Kf(r) { for (const e of r) if (!Jf(e.charCodeAt(0))) return !1; return !0; } function Jf(r) { return !(Zt.Arabic(r) || Zt["Arabic Supplement"](r) || Zt["Arabic Extended-A"](r) || Zt["Arabic Presentation Forms-A"](r) || Zt["Arabic Presentation Forms-B"](r)); } function su(r) { return !(r !== 746 && r !== 747 && (r < 4352 || !(Zt["Bopomofo Extended"](r) || Zt.Bopomofo(r) || Zt["CJK Compatibility Forms"](r) && !(r >= 65097 && r <= 65103) || Zt["CJK Compatibility Ideographs"](r) || Zt["CJK Compatibility"](r) || Zt["CJK Radicals Supplement"](r) || Zt["CJK Strokes"](r) || !(!Zt["CJK Symbols and Punctuation"](r) || r >= 12296 && r <= 12305 || r >= 12308 && r <= 12319 || r === 12336) || Zt["CJK Unified Ideographs Extension A"](r) || Zt["CJK Unified Ideographs"](r) || Zt["Enclosed CJK Letters and Months"](r) || Zt["Hangul Compatibility Jamo"](r) || Zt["Hangul Jamo Extended-A"](r) || Zt["Hangul Jamo Extended-B"](r) || Zt["Hangul Jamo"](r) || Zt["Hangul Syllables"](r) || Zt.Hiragana(r) || Zt["Ideographic Description Characters"](r) || Zt.Kanbun(r) || Zt["Kangxi Radicals"](r) || Zt["Katakana Phonetic Extensions"](r) || Zt.Katakana(r) && r !== 12540 || !(!Zt["Halfwidth and Fullwidth Forms"](r) || r === 65288 || r === 65289 || r === 65293 || r >= 65306 && r <= 65310 || r === 65339 || r === 65341 || r === 65343 || r >= 65371 && r <= 65503 || r === 65507 || r >= 65512 && r <= 65519) || !(!Zt["Small Form Variants"](r) || r >= 65112 && r <= 65118 || r >= 65123 && r <= 65126) || Zt["Unified Canadian Aboriginal Syllabics"](r) || Zt["Unified Canadian Aboriginal Syllabics Extended"](r) || Zt["Vertical Forms"](r) || Zt["Yijing Hexagram Symbols"](r) || Zt["Yi Syllables"](r) || Zt["Yi Radicals"](r)))); } function _d(r) { return !(su(r) || function(e) { return !!(Zt["Latin-1 Supplement"](e) && (e === 167 || e === 169 || e === 174 || e === 177 || e === 188 || e === 189 || e === 190 || e === 215 || e === 247) || Zt["General Punctuation"](e) && (e === 8214 || e === 8224 || e === 8225 || e === 8240 || e === 8241 || e === 8251 || e === 8252 || e === 8258 || e === 8263 || e === 8264 || e === 8265 || e === 8273) || Zt["Letterlike Symbols"](e) || Zt["Number Forms"](e) || Zt["Miscellaneous Technical"](e) && (e >= 8960 && e <= 8967 || e >= 8972 && e <= 8991 || e >= 8996 && e <= 9e3 || e === 9003 || e >= 9085 && e <= 9114 || e >= 9150 && e <= 9165 || e === 9167 || e >= 9169 && e <= 9179 || e >= 9186 && e <= 9215) || Zt["Control Pictures"](e) && e !== 9251 || Zt["Optical Character Recognition"](e) || Zt["Enclosed Alphanumerics"](e) || Zt["Geometric Shapes"](e) || Zt["Miscellaneous Symbols"](e) && !(e >= 9754 && e <= 9759) || Zt["Miscellaneous Symbols and Arrows"](e) && (e >= 11026 && e <= 11055 || e >= 11088 && e <= 11097 || e >= 11192 && e <= 11243) || Zt["CJK Symbols and Punctuation"](e) || Zt.Katakana(e) || Zt["Private Use Area"](e) || Zt["CJK Compatibility Forms"](e) || Zt["Small Form Variants"](e) || Zt["Halfwidth and Fullwidth Forms"](e) || e === 8734 || e === 8756 || e === 8757 || e >= 9984 && e <= 10087 || e >= 10102 && e <= 10131 || e === 65532 || e === 65533); }(r)); } function ru(r) { return r >= 1424 && r <= 2303 || Zt["Arabic Presentation Forms-A"](r) || Zt["Arabic Presentation Forms-B"](r); } function gd(r, e) { return !(!e && ru(r) || r >= 2304 && r <= 3583 || r >= 3840 && r <= 4255 || Zt.Khmer(r)); } function Qf(r) { for (const e of r) if (ru(e.charCodeAt(0))) return !0; return !1; } const yd = "deferred", ea = "loading", xd = "loaded"; let vd = null, br = "unavailable", qa = null; const th = function(r) { r && typeof r == "string" && r.indexOf("NetworkError") > -1 && (br = "error"), vd && vd(r); }; function ou() { oc.fire(new Ar("pluginStateChange", { pluginStatus: br, pluginURL: qa })); } const oc = new Zo(), au = function() { return br; }, ep = function() { if (br !== yd || !qa) throw new Error("rtl-text-plugin cannot be downloaded unless a pluginURL is specified"); br = ea, ou(), qa && no({ url: qa }, (r) => { r ? th(r) : (br = xd, ou()); }); }, co = { applyArabicShaping: null, processBidirectionalText: null, processStyledBidirectionalText: null, isLoaded: () => br === xd || co.applyArabicShaping != null, isLoading: () => br === ea, setState(r) { br = r.pluginStatus, qa = r.pluginURL; }, isParsed: () => co.applyArabicShaping != null && co.processBidirectionalText != null && co.processStyledBidirectionalText != null, getPluginURL: () => qa }; class Tn { constructor(e, n) { this.zoom = e, n ? (this.now = n.now, this.fadeDuration = n.fadeDuration, this.transition = n.transition, this.pitch = n.pitch, this.brightness = n.brightness) : (this.now = 0, this.fadeDuration = 0, this.transition = {}, this.pitch = 0, this.brightness = 0); } isSupportedScript(e) { return function(n, o) { for (const u of n) if (!gd(u.charCodeAt(0), o)) return !1; return !0; }(e, co.isLoaded()); } } class ac { constructor(e, n, o, u) { this.property = e, this.value = n, this.expression = function(l, f, v, S) { if (Qh(l)) return new iu(l, f); if (tu(l) || Array.isArray(l) && l.length > 0) { const D = ud(l, f, v, S); if (D.result === "error") throw new Error(D.value.map((x) => `${x.key}: ${x.message}`).join(", ")); return D.value; } { let D = l; return typeof l == "string" && f.type === "color" && (D = ki.parse(l)), { kind: "constant", configDependencies: /* @__PURE__ */ new Set(), evaluate: () => D }; } }(n === void 0 ? e.specification.default : n, e.specification, o, u); } isDataDriven() { return this.expression.kind === "source" || this.expression.kind === "composite"; } possiblyEvaluate(e, n, o) { return this.property.possiblyEvaluate(this, e, n, o); } } class lu { constructor(e, n, o) { this.property = e, this.value = new ac(e, void 0, n, o); } transitioned(e, n) { return new Ml(this.property, this.value, n, An({}, e.transition, this.transition), e.now); } untransitioned() { return new Ml(this.property, this.value, null, {}, 0); } } class ih { constructor(e, n, o) { this._properties = e, this._values = Object.create(e.defaultTransitionablePropertyValues), this._scope = n, this._options = o, this.configDependencies = /* @__PURE__ */ new Set(); } getValue(e) { return Ys(this._values[e].value.value); } setValue(e, n) { this._values.hasOwnProperty(e) || (this._values[e] = new lu(this._values[e].property, this._scope, this._options)), this._values[e].value = new ac(this._values[e].property, n === null ? void 0 : Ys(n), this._scope, this._options), this._values[e].value.expression.configDependencies && (this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...this._values[e].value.expression.configDependencies])); } setTransitionOrValue(e, n) { n && (this._options = n); const o = this._properties.properties; if (e) for (const u in e) { const l = e[u]; if (yr(u, "-transition")) { const f = u.slice(0, -11); o[f] && this.setTransition(f, l); } else o.hasOwnProperty(u) && this.setValue(u, l); } } getTransition(e) { return Ys(this._values[e].transition); } setTransition(e, n) { this._values.hasOwnProperty(e) || (this._values[e] = new lu(this._values[e].property)), this._values[e].transition = Ys(n) || void 0; } serialize() { const e = {}; for (const n of Object.keys(this._values)) { const o = this.getValue(n); o !== void 0 && (e[n] = o); const u = this.getTransition(n); u !== void 0 && (e[`${n}-transition`] = u); } return e; } transitioned(e, n) { const o = new tp(this._properties); for (const u of Object.keys(this._values)) o._values[u] = this._values[u].transitioned(e, n._values[u]); return o; } untransitioned() { const e = new tp(this._properties); for (const n of Object.keys(this._values)) e._values[n] = this._values[n].untransitioned(); return e; } } class Ml { constructor(e, n, o, u, l) { const f = u.delay || 0, v = u.duration || 0; l = l || 0, this.property = e, this.value = n, this.begin = l + f, this.end = this.begin + v, e.specification.transition && (u.delay || u.duration) && (this.prior = o); } possiblyEvaluate(e, n, o) { const u = e.now || 0, l = this.value.possiblyEvaluate(e, n, o), f = this.prior; if (f) { if (u > this.end) return this.prior = null, l; if (this.value.isDataDriven()) return this.prior = null, l; if (u < this.begin) return f.possiblyEvaluate(e, n, o); { const v = (u - this.begin) / (this.end - this.begin); return this.property.interpolate(f.possiblyEvaluate(e, n, o), l, Hr(v)); } } return l; } } class tp { constructor(e) { this._properties = e, this._values = Object.create(e.defaultTransitioningPropertyValues); } possiblyEvaluate(e, n, o) { const u = new cc(this._properties); for (const l of Object.keys(this._values)) u._values[l] = this._values[l].possiblyEvaluate(e, n, o); return u; } hasTransition() { for (const e of Object.keys(this._values)) if (this._values[e].prior) return !0; return !1; } } class e_ { constructor(e, n, o) { this._properties = e, this._values = Object.create(e.defaultPropertyValues), this._scope = n, this._options = o, this.configDependencies = /* @__PURE__ */ new Set(); } getValue(e) { return Ys(this._values[e].value); } setValue(e, n) { this._values[e] = new ac(this._values[e].property, n === null ? void 0 : Ys(n), this._scope, this._options), this._values[e].expression.configDependencies && (this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...this._values[e].expression.configDependencies])); } serialize() { const e = {}; for (const n of Object.keys(this._values)) { const o = this.getValue(n); o !== void 0 && (e[n] = o); } return e; } possiblyEvaluate(e, n, o) { const u = new cc(this._properties); for (const l of Object.keys(this._values)) u._values[l] = this._values[l].possiblyEvaluate(e, n, o); return u; } } class lc { constructor(e, n, o) { this.property = e, this.value = n, this.parameters = o; } isConstant() { return this.value.kind === "constant"; } constantOr(e) { return this.value.kind === "constant" ? this.value.value : e; } evaluate(e, n, o, u) { return this.property.evaluate(this.value, this.parameters, e, n, o, u); } } class cc { constructor(e) { this._properties = e, this._values = Object.create(e.defaultPossiblyEvaluatedValues); } get(e) { return this._values[e]; } } class yt { constructor(e) { this.specification = e; } possiblyEvaluate(e, n) { return e.expression.evaluate(n); } interpolate(e, n, o) { const u = Oi[this.specification.type]; return u ? u(e, n, o) : e; } } class Dt { constructor(e, n) { this.specification = e, this.overrides = n; } possiblyEvaluate(e, n, o, u) { return new lc(this, e.expression.kind === "constant" || e.expression.kind === "camera" ? { kind: "constant", value: e.expression.evaluate(n, null, {}, o, u) } : e.expression, n); } interpolate(e, n, o) { if (e.value.kind !== "constant" || n.value.kind !== "constant") return e; if (e.value.value === void 0 || n.value.value === void 0) return new lc(this, { kind: "constant", value: void 0 }, e.parameters); const u = Oi[this.specification.type]; return u ? new lc(this, { kind: "constant", value: u(e.value.value, n.value.value, o) }, e.parameters) : e; } evaluate(e, n, o, u, l, f) { return e.kind === "constant" ? e.value : e.evaluate(n, o, u, l, f); } } class Wa { constructor(e) { this.specification = e; } possiblyEvaluate(e, n, o, u) { return !!e.expression.evaluate(n, null, {}, o, u); } interpolate() { return !1; } } class Bn { constructor(e) { this.properties = e, this.defaultPropertyValues = {}, this.defaultTransitionablePropertyValues = {}, this.defaultTransitioningPropertyValues = {}, this.defaultPossiblyEvaluatedValues = {}, this.overridableProperties = []; const n = new Tn(0, {}); for (const o in e) { const u = e[o]; u.specification.overridable && this.overridableProperties.push(o); const l = this.defaultPropertyValues[o] = new ac(u, void 0), f = this.defaultTransitionablePropertyValues[o] = new lu(u); this.defaultTransitioningPropertyValues[o] = f.untransitioned(), this.defaultPossiblyEvaluatedValues[o] = l.possiblyEvaluate(n); } } } Ft(Dt, "DataDrivenProperty"), Ft(yt, "DataConstantProperty"), Ft(Wa, "ColorRampProperty"); var $e = JSON.parse('{"$version":8,"$root":{"version":{"required":true,"type":"enum","values":[8]},"fragment":{"type":"boolean"},"name":{"type":"string"},"metadata":{"type":"*"},"center":{"type":"array","value":"number"},"zoom":{"type":"number"},"bearing":{"type":"number","default":0,"period":360},"pitch":{"type":"number","default":0},"light":{"type":"light"},"lights":{"required":false,"type":"array","value":"light-3d"},"terrain":{"type":"terrain","optional":true},"fog":{"type":"fog"},"snow":{"type":"snow","experimental":true},"rain":{"type":"rain","experimental":true},"camera":{"type":"camera"},"color-theme":{"type":"colorTheme"},"indoor":{"type":"indoor","experimental":true},"imports":{"type":"array","value":"import"},"schema":{"type":"schema"},"sources":{"required":true,"type":"sources"},"sprite":{"type":"string"},"glyphs":{"type":"string","default":"mapbox://fonts/mapbox/{fontstack}/{range}.pbf"},"transition":{"type":"transition"},"projection":{"type":"projection"},"layers":{"required":true,"type":"array","value":"layer"},"models":{"type":"models"},"featuresets":{"experimental":true,"type":"featuresets"}},"featuresets":{"experimental":true,"*":{"type":"featureset"}},"featureset":{"experimental":true,"metadata":{"type":"*"},"selectors":{"type":"array","value":"selector"}},"selector":{"experimental":true,"layer":{"type":"string","required":true},"properties":{"type":"selectorProperty","required":false},"featureNamespace":{"type":"string","required":false}},"selectorProperty":{"experimental":true,"*":{"type":"*"}},"model":{"type":"string","required":true},"import":{"id":{"type":"string","required":true},"url":{"type":"string","required":true},"config":{"type":"config"},"data":{"type":"$root"},"color-theme":{"type":"colorTheme","optional":true}},"config":{"*":{"type":"*"}},"schema":{"*":{"type":"option"}},"option":{"default":{"type":"*","property-type":"data-constant","expression":{},"required":true},"type":{"type":"enum","values":{"string":1,"number":1,"boolean":1,"color":1}},"array":{"type":"boolean"},"minValue":{"type":"number"},"maxValue":{"type":"number"},"stepValue":{"type":"number"},"values":{"type":"array","value":"*"},"metadata":{"type":"*"}},"models":{"*":{"type":"model"}},"light-3d":{"id":{"type":"string","required":true},"properties":{"type":"properties"},"type":{"type":"enum","values":{"ambient":{},"directional":{},"flat":{}}}},"properties":["properties_light_directional","properties_light_ambient","properties_light_flat"],"properties_light_directional":{"direction":{"type":"array","default":[210,30],"minimum":[0,0],"maximum":[360,90],"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},"intensity":{"type":"number","property-type":"data-constant","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"cast-shadows":{"type":"boolean","default":false,"property-type":"data-constant"},"shadow-quality":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1,"expression":{"parameters":["zoom"]},"experimental":true},"shadow-intensity":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"properties_light_ambient":{"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}},"properties_light_flat":{"anchor":{"type":"enum","default":"viewport","values":{"map":1,"viewport":1},"property-type":"data-constant","expression":{"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}},"sources":{"*":{"type":"source"}},"source":["source_vector","source_raster","source_raster_dem","source_raster_array","source_geojson","source_video","source_image","source_model"],"source_vector":{"type":{"required":true,"type":"enum","values":{"vector":1}},"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":1,"tms":1},"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":1}},"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},"scheme":{"type":"enum","values":{"xyz":1,"tms":1},"default":"xyz"},"attribution":{"type":"string"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_dem":{"type":{"required":true,"type":"enum","values":{"raster-dem":1}},"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},"attribution":{"type":"string"},"encoding":{"type":"enum","values":{"terrarium":1,"mapbox":1},"default":"mapbox"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_array":{"experimental":true,"type":{"required":true,"type":"enum","values":{"raster-array":1}},"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},"attribution":{"type":"string"},"rasterLayers":{"type":"*"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_geojson":{"type":{"required":true,"type":"enum","values":{"geojson":1}},"data":{"type":"*"},"maxzoom":{"type":"number","default":18},"minzoom":{"type":"number","default":0},"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"},"dynamic":{"type":"boolean","default":false}},"source_video":{"type":{"required":true,"type":"enum","values":{"video":1}},"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":1}},"url":{"required":false,"type":"string"},"coordinates":{"required":true,"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"source_model":{"type":{"required":true,"type":"enum","values":{"model":1,"batched-model":1}},"maxzoom":{"type":"number","default":18},"minzoom":{"type":"number","default":0},"tiles":{"type":"array","value":"string"}},"layer":{"id":{"type":"string","required":true},"type":{"type":"enum","values":{"fill":{},"line":{},"symbol":{},"circle":{},"heatmap":{},"fill-extrusion":{},"raster":{},"raster-particle":{"experimental":true},"hillshade":{},"model":{"experimental":true},"background":{},"sky":{},"slot":{},"clip":{}},"required":true},"metadata":{"type":"*"},"source":{"type":"string"},"source-layer":{"type":"string"},"slot":{"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_clip","layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_raster-particle","layout_hillshade","layout_background","layout_sky","layout_model"],"layout_background":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_sky":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_model":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"},"model-id":{"type":"string","default":"","property-type":"data-driven","expression":{"parameters":["zoom","feature"]}}},"layout_clip":{"clip-layer-types":{"type":"array","value":"enum","values":{"model":1,"symbol":1},"default":[],"expression":{},"property-type":"data-constant"},"clip-layer-scope":{"type":"array","value":"string","default":[],"expression":{},"property-type":"data-constant"}},"layout_fill":{"fill-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"},"fill-elevation-reference":{"type":"enum","values":{"none":1,"hd-road-base":1,"hd-road-markup":1},"default":"none","experimental":true,"private":true,"expression":{},"property-type":"data-constant"}},"layout_circle":{"circle-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_heatmap":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_fill-extrusion":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"},"fill-extrusion-edge-radius":{"type":"number","experimental":true,"default":0,"minimum":0,"maximum":1,"expression":{},"property-type":"constant"}},"layout_line":{"line-cap":{"type":"enum","values":{"butt":1,"round":1,"square":1},"default":"butt","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-join":{"type":"enum","values":{"bevel":1,"round":1,"miter":1,"none":1},"default":"miter","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{"type":"number","default":2,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-round-limit":{"type":"number","default":1.05,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-z-offset":{"type":"number","experimental":true,"default":0,"expression":{"parameters":["zoom","feature","line-progress"]},"property-type":"data-driven"},"line-elevation-reference":{"type":"enum","values":{"none":1,"sea":1,"ground":1,"hd-road-markup":1},"default":"none","experimental":true,"expression":{},"property-type":"data-constant"},"line-cross-slope":{"type":"number","experimental":true,"expression":{},"property-type":"constant"},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"},"line-width-unit":{"type":"enum","values":{"pixels":1,"meters":1},"default":"pixels","experimental":true,"private":true,"expression":{"parameters":["zoom"]},"property-type":"data-constant"}},"layout_symbol":{"symbol-placement":{"type":"enum","values":{"point":1,"line":1,"line-center":1},"default":"point","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"symbol-spacing":{"type":"number","default":250,"minimum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{"type":"enum","values":{"auto":1,"viewport-y":1,"source":1},"default":"auto","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"symbol-z-elevate":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"symbol-elevation-reference":{"type":"enum","values":{"sea":1,"ground":1,"hd-road-markup":1},"default":"ground","experimental":true,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-optional":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-size":{"type":"number","default":1,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-size-scale-range":{"type":"array","value":"number","length":2,"default":[0.8,2],"minimum":0.1,"maximum":10,"experimental":true,"private":true,"expression":{},"property-type":"data-constant"},"icon-text-fit":{"type":"enum","values":{"none":1,"width":1,"height":1,"both":1},"default":"none","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit-padding":{"type":"array","value":"number","length":4,"default":[0,0,0,0],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-image":{"type":"resolvedImage","tokens":true,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{"type":"number","default":0,"period":360,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{"type":"number","default":2,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-offset":{"type":"array","value":"number","length":2,"default":[0,0],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{"type":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-field":{"type":"formatted","default":"","tokens":true,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-font":{"type":"array","value":"string","default":["Open Sans Regular","Arial Unicode MS Regular"],"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size":{"type":"number","default":16,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size-scale-range":{"type":"array","value":"number","length":2,"default":[0.8,2],"minimum":0.1,"maximum":10,"experimental":true,"private":true,"expression":{},"property-type":"data-constant"},"text-max-width":{"type":"number","default":10,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{"type":"number","default":1.2,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{"type":"number","default":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-justify":{"type":"enum","values":{"auto":1,"left":1,"center":1,"right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{"type":"number","default":0,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["zoom","feature"]}},"text-variable-anchor":{"type":"array","value":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-anchor":{"type":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{"type":"number","default":45,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-writing-mode":{"type":"array","value":"enum","values":{"horizontal":1,"vertical":1},"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-rotate":{"type":"number","default":0,"period":360,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-padding":{"type":"number","default":2,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-keep-upright":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-transform":{"type":"enum","values":{"none":1,"uppercase":1,"lowercase":1},"default":"none","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-offset":{"type":"array","value":"number","length":2,"default":[0,0],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"text-optional":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_raster":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_raster-particle":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"layout_hillshade":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{},"property-type":"constant"}},"filter":{"type":"array","value":"*"},"filter_symbol":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature","pitch","distance-from-center"]}},"filter_fill":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_hillshade":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_raster":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_raster-particle":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_clip":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_model":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_line":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_circle":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_fill-extrusion":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_heatmap":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_operator":{"type":"enum","values":{"==":1,"!=":1,">":1,">=":1,"<":1,"<=":1,"in":1,"!in":1,"all":1,"any":1,"none":1,"has":1,"!has":1}},"geometry_type":{"type":"enum","values":{"Point":1,"LineString":1,"Polygon":1}},"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":1,"exponential":1,"interval":1,"categorical":1},"default":"exponential"},"colorSpace":{"type":"enum","values":{"rgb":1,"lab":1,"hcl":1},"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","measure-light"],"relaxZoomRestriction":true}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"high-color":{"type":"color","property-type":"data-constant","default":"#245cdf","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"space-color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"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","measure-light"],"relaxZoomRestriction":true},"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","measure-light"],"relaxZoomRestriction":true},"transition":true},"vertical-range":{"type":"array","default":[0,0],"minimum":0,"length":2,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}}},"snow":{"density":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],11,0,13,0.85],"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"intensity":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"opacity":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],11,0,13,0.3],"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette-color":{"type":"color","property-type":"data-constant","default":"#ffffff","experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"center-thinning":{"type":"number","property-type":"data-constant","default":0.4,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"direction":{"type":"array","default":[0,50],"minimum":0,"maximum":360,"length":2,"value":"number","property-type":"data-constant","transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"flake-size":{"type":"number","property-type":"data-constant","default":0.71,"minimum":0,"maximum":5,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true}},"rain":{"density":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],11,0,13,0.5],"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"intensity":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["measure-light","brightness"],0,"#03113d",0.3,"#a8adbc"],"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"opacity":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["measure-light","brightness"],0,0.88,1,0.7],"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],11,0,13,1],"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette-color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["measure-light","brightness"],0,"#001736",0.3,"#464646"],"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"center-thinning":{"type":"number","property-type":"data-constant","default":0.57,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"direction":{"type":"array","default":[0,80],"minimum":0,"maximum":360,"length":2,"value":"number","property-type":"data-constant","transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"droplet-size":{"type":"array","default":[2.6,18.2],"minimum":0,"maximum":50,"length":2,"value":"number","property-type":"data-constant","transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"distortion-strength":{"type":"number","property-type":"data-constant","default":0.7,"minimum":0,"maximum":1,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true}},"camera":{"camera-projection":{"type":"enum","values":{"perspective":1,"orthographic":1},"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"default":"perspective","property-type":"data-constant"}},"colorTheme":{"data":{"type":"string","property-type":"data-constant","expression":{}}},"indoor":{"floorplanFeaturesetId":{"type":"string","experimental":true,"property-type":"data-constant","expression":{}},"buildingFeaturesetId":{"type":"string","experimental":true,"property-type":"data-constant","expression":{}}},"light":{"anchor":{"type":"enum","default":"viewport","values":{"map":1,"viewport":1},"property-type":"data-constant","expression":{"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":1,"equalEarth":1,"equirectangular":1,"lambertConformalConic":1,"mercator":1,"naturalEarth":1,"winkelTripel":1,"globe":1},"default":"mercator","required":true},"center":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-180,-90],"maximum":[180,90]},"parallels":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-90,-90],"maximum":[90,90]}},"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}},"paint":["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_raster-particle","paint_hillshade","paint_background","paint_sky","paint_model"],"paint_fill":{"fill-antialias":{"type":"boolean","default":true,"expression":{"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","measure-light"]},"property-type":"data-driven"},"fill-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-outline-color":{"type":"color","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"fill-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"fill-z-offset":{"type":"number","default":0,"minimum":0,"transition":true,"experimental":true,"expression":{"interpolated":true,"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,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-extrusion-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-height":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-height-alignment":{"type":"enum","experimental":true,"values":{"terrain":1,"flat":1},"default":"flat","property-type":"data-constant"},"fill-extrusion-base-alignment":{"type":"enum","experimental":true,"values":{"terrain":1,"flat":1},"default":"terrain","property-type":"data-constant"},"fill-extrusion-vertical-gradient":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-ambient-occlusion-intensity":{"property-type":"data-constant","type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-radius":{"property-type":"data-constant","type":"number","default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-wall-radius":{"property-type":"data-constant","type":"number","experimental":true,"default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-ground-radius":{"property-type":"data-constant","type":"number","experimental":true,"default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-ground-attenuation":{"property-type":"data-constant","type":"number","experimental":true,"default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-flood-light-color":{"property-type":"data-constant","type":"color","experimental":true,"default":"#ffffff","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-extrusion-flood-light-intensity":{"property-type":"data-constant","type":"number","experimental":true,"default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-extrusion-flood-light-wall-radius":{"property-type":"data-driven","type":"number","experimental":true,"default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"fill-extrusion-flood-light-ground-radius":{"property-type":"data-driven","type":"number","experimental":true,"default":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"fill-extrusion-flood-light-ground-attenuation":{"property-type":"data-constant","type":"number","experimental":true,"default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-vertical-scale":{"property-type":"data-constant","type":"number","experimental":true,"default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-rounded-roof":{"property-type":"data-constant","type":"boolean","default":true,"experimental":true,"expression":{"parameters":["zoom"]}},"fill-extrusion-cutoff-fade-range":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{},"property-type":"data-constant"},"fill-extrusion-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"property-type":"data-driven"},"fill-extrusion-line-width":{"type":"number","default":0,"minimum":0,"transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-extrusion-cast-shadows":{"type":"boolean","default":true,"property-type":"data-constant"}},"paint_line":{"line-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"line-width":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light","line-progress"]},"property-type":"data-driven"},"line-gap-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-offset":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-dasharray":{"type":"array","value":"number","minimum":0,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-gradient":{"type":"color","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],"property-type":"constant"},"line-trim-fade-range":{"type":"array","value":"number","experimental":true,"length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1],"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"line-trim-color":{"type":"color","experimental":true,"default":"transparent","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"line-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"line-border-width":{"type":"number","private":true,"default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-border-color":{"type":"color","private":true,"default":"rgba(0, 0, 0, 0)","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-occlusion-opacity":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"property-type":"data-constant"}},"paint_circle":{"circle-radius":{"type":"number","default":5,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-blur":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1},"default":"viewport","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-stroke-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"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","measure-light"]},"property-type":"data-driven"},"circle-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"}},"paint_heatmap":{"heatmap-radius":{"type":"number","default":30,"minimum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"heatmap-weight":{"type":"number","default":1,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"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"],"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,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-occlusion-opacity":{"type":"number","minimum":0,"maximum":1,"default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-emissive-strength":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"property-type":"data-driven"},"text-emissive-strength":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"property-type":"data-driven"},"icon-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"icon-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-image-cross-fade":{"type":"number","property-type":"data-driven","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"transition":true},"text-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-occlusion-opacity":{"type":"number","minimum":0,"maximum":1,"default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-color":{"type":"color","default":"#000000","transition":true,"overridable":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"text-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"icon-color-saturation":{"type":"number","default":0,"minimum":-1,"maximum":1,"expression":{},"property-type":"data-constant"},"icon-color-contrast":{"type":"number","default":0,"minimum":-1,"maximum":1,"expression":{},"property-type":"data-constant"},"icon-color-brightness-min":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{},"property-type":"data-constant"},"icon-color-brightness-max":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{},"property-type":"data-constant"},"symbol-z-offset":{"type":"number","default":0,"minimum":0,"transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"}},"paint_raster":{"raster-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-color":{"type":"color","expression":{"interpolated":true,"parameters":["raster-value"]},"property-type":"color-ramp"},"raster-color-mix":{"type":"array","default":[0.2126,0.7152,0.0722,0],"length":4,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-color-range":{"type":"array","length":2,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-hue-rotate":{"type":"number","default":0,"period":360,"transition":true,"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":1,"nearest":1},"default":"linear","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{"type":"number","default":300,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"raster-array-band":{"type":"string","required":false,"experimental":true,"property-type":"data-constant"},"raster-elevation":{"type":"number","default":0,"minimum":0,"transition":true,"experimental":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_raster-particle":{"raster-particle-array-band":{"type":"string","required":false,"property-type":"data-constant"},"raster-particle-count":{"type":"number","default":512,"minimum":1,"property-type":"data-constant"},"raster-particle-color":{"type":"color","expression":{"interpolated":true,"parameters":["raster-particle-speed"]},"property-type":"color-ramp"},"raster-particle-max-speed":{"type":"number","default":1,"minimum":1,"property-type":"data-constant"},"raster-particle-speed-factor":{"type":"number","default":0.2,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-particle-fade-opacity-factor":{"type":"number","default":0.98,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-particle-reset-rate-factor":{"type":"number","default":0.8,"minimum":0,"maximum":1,"property-type":"data-constant"},"raster-particle-elevation":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_hillshade":{"hillshade-illumination-direction":{"type":"number","default":335,"minimum":0,"maximum":359,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"viewport","expression":{"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","measure-light"]},"property-type":"data-constant"},"hillshade-highlight-color":{"type":"color","default":"#FFFFFF","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"hillshade-accent-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"},"hillshade-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"}},"paint_background":{"background-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":[]},"experimental":true,"property-type":"data-constant"},"background-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"background-pattern":{"type":"resolvedImage","expression":{"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"},"background-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-constant"}},"paint_sky":{"sky-type":{"type":"enum","values":{"gradient":1,"atmosphere":1},"default":"atmosphere","expression":{"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{"type":"array","value":"number","length":2,"minimum":[0,0],"maximum":[360,180],"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{"type":"number","default":10,"minimum":0,"maximum":100,"property-type":"data-constant"},"sky-gradient-center":{"type":"array","value":"number","default":[0,0],"length":2,"minimum":[0,0],"maximum":[360,180],"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{"type":"number","default":90,"minimum":0,"maximum":180,"expression":{"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient":{"type":"color","default":["interpolate",["linear"],["sky-radial-progress"],0.8,"#87ceeb",1,"white"],"expression":{"interpolated":true,"parameters":["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{"type":"color","default":"white","property-type":"data-constant"},"sky-atmosphere-color":{"type":"color","default":"white","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"}},"paint_model":{"model-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"property-type":"data-driven"},"model-rotation":{"type":"array","value":"number","length":3,"default":[0,0,0],"period":360,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-scale":{"type":"array","value":"number","length":3,"default":[1,1,1],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-translation":{"type":"array","value":"number","length":3,"default":[0,0,0],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-color":{"type":"color","default":"#ffffff","property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light","zoom"]},"transition":true},"model-color-mix-intensity":{"type":"number","property-type":"data-driven","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-type":{"type":"enum","values":{"common-3d":1,"location-indicator":1},"default":"common-3d","property-type":"data-constant"},"model-cast-shadows":{"type":"boolean","default":true,"property-type":"data-constant"},"model-receive-shadows":{"type":"boolean","default":true,"property-type":"data-constant"},"model-ambient-occlusion-intensity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant","transition":true},"model-emissive-strength":{"type":"number","property-type":"data-driven","default":0,"minimum":0,"maximum":5,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-roughness":{"type":"number","default":1,"minimum":0,"maximum":1,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state"]},"transition":true},"model-height-based-emissive-strength-multiplier":{"type":"array","default":[1,1,1,1,0],"length":5,"value":"number","property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-cutoff-fade-range":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{},"property-type":"data-constant"},"model-front-cutoff":{"type":"array","private":true,"value":"number","property-type":"data-constant","expression":{"interpolated":true,"parameters":["zoom"]},"length":3,"default":[0,0,1],"minimum":[0,0,0],"maximum":[1,1,1]}},"transition":{"duration":{"type":"number","default":300,"minimum":0},"delay":{"type":"number","default":0,"minimum":0}},"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 ip(r) { return r instanceof Number || r instanceof String || r instanceof Boolean ? r.valueOf() : r; } function cu(r) { if (Array.isArray(r)) return r.map(cu); if (r instanceof Object && !(r instanceof Number || r instanceof String || r instanceof Boolean)) { const e = {}; for (const n in r) e[n] = cu(r[n]); return e; } return ip(r); } function bd(r) { if (r === !0 || r === !1) return !0; if (!Array.isArray(r) || r.length === 0) return !1; switch (r[0]) { case "has": return r.length >= 2 && r[1] !== "$id" && r[1] !== "$type"; case "in": return r.length >= 3 && (typeof r[1] != "string" || Array.isArray(r[2])); case "!in": case "!has": case "none": return !1; case "==": case "!=": case ">": case ">=": case "<": case "<=": return r.length !== 3 || Array.isArray(r[1]) || Array.isArray(r[2]); case "any": case "all": for (const e of r.slice(1)) if (!bd(e) && typeof e != "boolean") return !1; return !0; default: return !0; } } function np(r, e = "", n = null, o = "fill") { if (r == null) return { filter: () => !0, needGeometry: !1, needFeature: !1 }; bd(r) || (r = nh(r)); const u = r; let l = !0; try { l = function(x) { if (!hc(x)) return x; let P = cu(x); return rp(P), P = sp(P), P; }(u); } catch { console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate. This is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md and paste the contents of this message in the report. Thank you! Filter Expression: ${JSON.stringify(u, null, 2)} `); } let f = null, v = null; if (o !== "background" && o !== "sky" && o !== "slot") { v = $e[`filter_${o}`]; const x = Qc(l, v, e, n); if (x.result === "error") throw new Error(x.value.map((P) => `${P.key}: ${P.message}`).join(", ")); f = (P, I, M) => x.value.evaluate(P, I, {}, M); } let S = null, D = null; if (l !== u) { const x = Qc(u, v, e, n); if (x.result === "error") throw new Error(x.value.map((P) => `${P.key}: ${P.message}`).join(", ")); S = (P, I, M, C, k) => x.value.evaluate(P, I, {}, M, void 0, void 0, C, k), D = !ro(x.value.expression); } return { filter: f, dynamicFilter: S || void 0, needGeometry: Sl(l), needFeature: !!D }; } function sp(r) { if (!Array.isArray(r)) return r; const e = function(n) { if (t_.has(n[0])) { for (let o = 1; o < n.length; o++) if (hc(n[o])) return !0; } return n; }(r); return e === !0 ? e : e.map((n) => sp(n)); } function rp(r) { let e = !1; const n = []; if (r[0] === "case") { for (let o = 1; o < r.length - 1; o += 2) e = e || hc(r[o]), n.push(r[o + 1]); n.push(r[r.length - 1]); } else if (r[0] === "match") { e = e || hc(r[1]); for (let o = 2; o < r.length - 1; o += 2) n.push(r[o + 1]); n.push(r[r.length - 1]); } else if (r[0] === "step") { e = e || hc(r[1]); for (let o = 1; o < r.length - 1; o += 2) n.push(r[o + 1]); } e && (r.length = 0, r.push("any", ...n)); for (let o = 1; o < r.length; o++) rp(r[o]); } function hc(r) { if (!Array.isArray(r)) return !1; if ((e = r[0]) === "pitch" || e === "distance-from-center") return !0; var e; for (let n = 1; n < r.length; n++) if (hc(r[n])) return !0; return !1; } const t_ = /* @__PURE__ */ new Set(["in", "==", "!=", ">", ">=", "<", "<=", "to-boolean"]); function i_(r, e) { return r < e ? -1 : r > e ? 1 : 0; } function Sl(r) { if (!Array.isArray(r)) return !1; if (r[0] === "within" || r[0] === "distance") return !0; for (let e = 1; e < r.length; e++) if (Sl(r[e])) return !0; return !1; } function nh(r) { if (!r) return !0; const e = r[0]; return r.length <= 1 ? e !== "any" : e === "==" ? hu(r[1], r[2], "==") : e === "!=" ? uu(hu(r[1], r[2], "==")) : e === "<" || e === ">" || e === "<=" || e === ">=" ? hu(r[1], r[2], e) : e === "any" ? (n = r.slice(1), ["any"].concat(n.map(nh))) : e === "all" ? ["all"].concat(r.slice(1).map(nh)) : e === "none" ? ["all"].concat(r.slice(1).map(nh).map(uu)) : e === "in" ? sh(r[1], r.slice(2)) : e === "!in" ? uu(sh(r[1], r.slice(2))) : e === "has" ? op(r[1]) : e !== "!has" || uu(op(r[1])); var n; } function hu(r, e, n) { switch (r) { case "$type": return [`filter-type-${n}`, e]; case "$id": return [`filter-id-${n}`, e]; default: return [`filter-${n}`, r, e]; } } function sh(r, e) { if (e.length === 0) return !1; switch (r) { case "$type": return ["filter-type-in", ["literal", e]]; case "$id": return ["filter-id-in", ["literal", e]]; default: return e.length > 200 && !e.some((n) => typeof n != typeof e[0]) ? ["filter-in-large", r, ["literal", e.sort(i_)]] : ["filter-in-small", r, ["literal", e]]; } } function op(r) { switch (r) { case "$type": return !0; case "$id": return ["filter-has-id"]; default: return ["filter-has", r]; } } function uu(r) { return ["!", r]; } const Co = ""; function Io(r, e) { return e ? `${r}${Co}${e}` : r; } const El = "-transition", n_ = /* @__PURE__ */ new Set(["fill", "line", "background", "hillshade", "raster"]); class wr extends Zo { constructor(e, n, o, u, l) { if (super(), this.id = e.id, this.fqid = Io(this.id, o), this.type = e.type, this.scope = o, this.lut = u, this.options = l, this._featureFilter = { filter: () => !0, needGeometry: !1, needFeature: !1 }, this._filterCompiled = !1, this.configDependencies = /* @__PURE__ */ new Set(), e.type !== "custom") { if (this.metadata = e.metadata, this.minzoom = e.minzoom, this.maxzoom = e.maxzoom, e.type && e.type !== "background" && e.type !== "sky" && e.type !== "slot") { this.source = e.source, this.sourceLayer = e["source-layer"], this.filter = e.filter; const f = Qc(this.filter, $e[`filter_${e.type}`]); f.result !== "error" && (this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...f.value.configDependencies])); } if (e.slot && (this.slot = e.slot), n.layout && (this._unevaluatedLayout = new e_(n.layout, this.scope, l), this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...this._unevaluatedLayout.configDependencies])), n.paint) { this._transitionablePaint = new ih(n.paint, this.scope, l); for (const f in e.paint) this.setPaintProperty(f, e.paint[f]); for (const f in e.layout) this.setLayoutProperty(f, e.layout[f]); this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...this._transitionablePaint.configDependencies]), this._transitioningPaint = this._transitionablePaint.untransitioned(), this.paint = new cc(n.paint); } } } onAdd(e) { } onRemove(e) { } isDraped(e) { return !this.is3D() && n_.has(this.type); } getLayoutProperty(e) { return e === "visibility" ? this.visibility : this._unevaluatedLayout.getValue(e); } setLayoutProperty(e, n) { if (this.type === "custom" && e === "visibility") return void (this.visibility = n); const o = this._unevaluatedLayout; o._properties.properties[e] && (o.setValue(e, n), this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...o.configDependencies]), e === "visibility" && this.possiblyEvaluateVisibility()); } possiblyEvaluateVisibility() { this._unevaluatedLayout._values.visibility && (this.visibility = this._unevaluatedLayout._values.visibility.possiblyEvaluate({ zoom: 0 })); } getPaintProperty(e) { return yr(e, El) ? this._transitionablePaint.getTransition(e.slice(0, -11)) : this._transitionablePaint.getValue(e); } setPaintProperty(e, n) { const o = this._transitionablePaint, u = o._properties.properties; if (yr(e, El)) { const P = e.slice(0, -11); return u[P] && o.setTransition(P, n || void 0), !1; } if (!u[e]) return !1; const l = o._values[e], f = l.value.isDataDriven(), v = l.value; o.setValue(e, n), this.configDependencies = /* @__PURE__ */ new Set([...this.configDependencies, ...o.configDependencies]), this._handleSpecialPaintPropertyUpdate(e); const S = o._values[e].value, D = S.isDataDriven(), x = yr(e, "pattern") || e === "line-dasharray"; return D || f || x || this._handleOverridablePaintPropertyUpdate(e, v, S); } _handleSpecialPaintPropertyUpdate(e) { } getProgramIds() { return null; } getDefaultProgramParams(e, n, o) { return null; } _handleOverridablePaintPropertyUpdate(e, n, o) { return !1; } isHidden(e) { return !!(this.minzoom && e < this.minzoom) || !!(this.maxzoom && e >= this.maxzoom) || this.visibility === "none"; } updateTransitions(e) { this._transitioningPaint = this._transitionablePaint.transitioned(e, this._transitioningPaint); } hasTransition() { return this._transitioningPaint.hasTransition(); } recalculate(e, n) { this._unevaluatedLayout && (this.layout = this._unevaluatedLayout.possiblyEvaluate(e, void 0, n)), this.paint = this._transitioningPaint.possiblyEvaluate(e, void 0, n); } serialize() { return io({ id: this.id, type: this.type, slot: this.slot, 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() }, (e, n) => !(e === void 0 || n === "layout" && !Object.keys(e).length || n === "paint" && !Object.keys(e).length)); } is3D() { return !1; } isSky() { return !1; } isTileClipped() { return !1; } hasOffscreenPass() { return !1; } hasShadowPass() { return !1; } canCastShadows() { return !1; } hasLightBeamPass() { return !1; } cutoffRange() { return 0; } tileCoverLift() { return 0; } resize() { } isStateDependent() { for (const e in this.paint._values) { const n = this.paint.get(e); if (n instanceof lc && nc(n.property.specification) && (n.value.kind === "source" || n.value.kind === "composite") && n.value.isStateDependent) return !0; } return !1; } compileFilter(e) { this._filterCompiled || (this._featureFilter = np(this.filter, this.scope, e), this._filterCompiled = !0); } invalidateCompiledFilter() { this._filterCompiled = !1; } dynamicFilter() { return this._featureFilter.dynamicFilter; } dynamicFilterNeedsFeature() { return this._featureFilter.needFeature; } getLayerRenderingStats() { return this._stats; } resetLayerRenderingStats(e) { this._stats && (e.renderPass === "shadow" ? this._stats.numRenderedVerticesInShadowPass = 0 : this._stats.numRenderedVerticesInTransparentPass = 0); } queryRadius(e) { } queryIntersectsFeature(e, n, o, u, l, f, v, S, D) { } } const s_ = { Int8: Int8Array, Uint8: Uint8Array, Int16: Int16Array, Uint16: Uint16Array, Int32: Int32Array, Uint32: Uint32Array, Float32: Float32Array }; class rh { constructor(e, n) { this._structArray = e, this._pos1 = n * this.size, this._pos2 = this._pos1 / 2, this._pos4 = this._pos1 / 4, this._pos8 = this._pos1 / 8; } } class bn { constructor() { this.isTransferred = !1, this.capacity = -1, this.resize(0); } static serialize(e, n) { return e._trim(), n && (e.isTransferred = !0, n.add(e.arrayBuffer)), { length: e.length, arrayBuffer: e.arrayBuffer }; } static deserialize(e) { const n = Object.create(this.prototype); return n.arrayBuffer = e.arrayBuffer, n.length = e.length, n.capacity = e.arrayBuffer.byteLength / n.bytesPerElement, n._refreshViews(), n; } _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(e) { this.reserve(e), this.length = e; } reserve(e) { if (e > this.capacity) { this.capacity = Math.max(e, Math.floor(5 * this.capacity), 128), this.arrayBuffer = new ArrayBuffer(this.capacity * this.bytesPerElement); const n = this.uint8; this._refreshViews(), n && this.uint8.set(n); } } _refreshViews() { throw new Error("StructArray#_refreshViews() must be implemented by each concrete StructArray layout"); } emplace(...e) { throw new Error("StructArray#emplace() must be implemented by each concrete StructArray layout"); } emplaceBack(...e) { throw new Error("StructArray#emplaceBack() 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 qi(r, e = 1) { let n = 0, o = 0; return { members: r.map((u) => { const l = s_[u.type].BYTES_PER_ELEMENT, f = n = du(n, Math.max(e, l)), v = u.components || 1; return o = Math.max(o, l), n += l * v, { name: u.name, type: u.type, components: v, offset: f }; }), size: du(n, Math.max(o, e)), alignment: e }; } function du(r, e) { return Math.ceil(r / e) * e; } class Lo extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n) { const o = this.length; return this.resize(o + 1), this.emplace(o, e, n); } emplace(e, n, o) { const u = 2 * e; return this.int16[u + 0] = n, this.int16[u + 1] = o, e; } } Lo.prototype.bytesPerElement = 4, Ft(Lo, "StructArrayLayout2i4"); class oh extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o) { const u = this.length; return this.resize(u + 1), this.emplace(u, e, n, o); } emplace(e, n, o, u) { const l = 3 * e; return this.int16[l + 0] = n, this.int16[l + 1] = o, this.int16[l + 2] = u, e; } } oh.prototype.bytesPerElement = 6, Ft(oh, "StructArrayLayout3i6"); class $a extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o, u) { const l = this.length; return this.resize(l + 1), this.emplace(l, e, n, o, u); } emplace(e, n, o, u, l) { const f = 4 * e; return this.int16[f + 0] = n, this.int16[f + 1] = o, this.int16[f + 2] = u, this.int16[f + 3] = l, e; } } $a.prototype.bytesPerElement = 8, Ft($a, "StructArrayLayout4i8"); class wd extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l) { const f = this.length; return this.resize(f + 1), this.emplace(f, e, n, o, u, l); } emplace(e, n, o, u, l, f) { const v = 5 * e; return this.int16[v + 0] = n, this.int16[v + 1] = o, this.int16[v + 2] = u, this.int16[v + 3] = l, this.int16[v + 4] = f, e; } } wd.prototype.bytesPerElement = 10, Ft(wd, "StructArrayLayout5i10"); class ho extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v) { const S = this.length; return this.resize(S + 1), this.emplace(S, e, n, o, u, l, f, v); } emplace(e, n, o, u, l, f, v, S) { const D = 6 * e, x = 12 * e, P = 3 * e; return this.int16[D + 0] = n, this.int16[D + 1] = o, this.uint8[x + 4] = u, this.uint8[x + 5] = l, this.uint8[x + 6] = f, this.uint8[x + 7] = v, this.float32[P + 2] = S, e; } } ho.prototype.bytesPerElement = 12, Ft(ho, "StructArrayLayout2i4ub1f12"); class Xa extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u) { const l = this.length; return this.resize(l + 1), this.emplace(l, e, n, o, u); } emplace(e, n, o, u, l) { const f = 4 * e; return this.float32[f + 0] = n, this.float32[f + 1] = o, this.float32[f + 2] = u, this.float32[f + 3] = l, e; } } Xa.prototype.bytesPerElement = 16, Ft(Xa, "StructArrayLayout4f16"); class va extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o) { const u = this.length; return this.resize(u + 1), this.emplace(u, e, n, o); } emplace(e, n, o, u) { const l = 3 * e; return this.float32[l + 0] = n, this.float32[l + 1] = o, this.float32[l + 2] = u, e; } } va.prototype.bytesPerElement = 12, Ft(va, "StructArrayLayout3f12"); class Ya extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l) { const f = this.length; return this.resize(f + 1), this.emplace(f, e, n, o, u, l); } emplace(e, n, o, u, l, f) { const v = 6 * e, S = 3 * e; return this.uint16[v + 0] = n, this.uint16[v + 1] = o, this.uint16[v + 2] = u, this.uint16[v + 3] = l, this.float32[S + 2] = f, e; } } Ya.prototype.bytesPerElement = 12, Ft(Ya, "StructArrayLayout4ui1f12"); class fu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e, n, o, u) { const l = this.length; return this.resize(l + 1), this.emplace(l, e, n, o, u); } emplace(e, n, o, u, l) { const f = 4 * e; return this.uint16[f + 0] = n, this.uint16[f + 1] = o, this.uint16[f + 2] = u, this.uint16[f + 3] = l, e; } } fu.prototype.bytesPerElement = 8, Ft(fu, "StructArrayLayout4ui8"); class pu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f) { const v = this.length; return this.resize(v + 1), this.emplace(v, e, n, o, u, l, f); } emplace(e, n, o, u, l, f, v) { const S = 6 * e; return this.int16[S + 0] = n, this.int16[S + 1] = o, this.int16[S + 2] = u, this.int16[S + 3] = l, this.int16[S + 4] = f, this.int16[S + 5] = v, e; } } pu.prototype.bytesPerElement = 12, Ft(pu, "StructArrayLayout6i12"); class Td extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v, S, D, x, P, I) { const M = this.length; return this.resize(M + 1), this.emplace(M, e, n, o, u, l, f, v, S, D, x, P, I); } emplace(e, n, o, u, l, f, v, S, D, x, P, I, M) { const C = 12 * e; return this.int16[C + 0] = n, this.int16[C + 1] = o, this.int16[C + 2] = u, this.int16[C + 3] = l, this.uint16[C + 4] = f, this.uint16[C + 5] = v, this.uint16[C + 6] = S, this.uint16[C + 7] = D, this.int16[C + 8] = x, this.int16[C + 9] = P, this.int16[C + 10] = I, this.int16[C + 11] = M, e; } } Td.prototype.bytesPerElement = 24, Ft(Td, "StructArrayLayout4i4ui4i24"); class Md extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f) { const v = this.length; return this.resize(v + 1), this.emplace(v, e, n, o, u, l, f); } emplace(e, n, o, u, l, f, v) { const S = 10 * e, D = 5 * e; return this.int16[S + 0] = n, this.int16[S + 1] = o, this.int16[S + 2] = u, this.float32[D + 2] = l, this.float32[D + 3] = f, this.float32[D + 4] = v, e; } } Md.prototype.bytesPerElement = 20, Ft(Md, "StructArrayLayout3i3f20"); class Sd extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer); } emplaceBack(e) { const n = this.length; return this.resize(n + 1), this.emplace(n, e); } emplace(e, n) { return this.uint32[1 * e + 0] = n, e; } } Sd.prototype.bytesPerElement = 4, Ft(Sd, "StructArrayLayout1ul4"); class Ka extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e, n) { const o = this.length; return this.resize(o + 1), this.emplace(o, e, n); } emplace(e, n, o) { const u = 2 * e; return this.uint16[u + 0] = n, this.uint16[u + 1] = o, e; } } Ka.prototype.bytesPerElement = 4, Ft(Ka, "StructArrayLayout2ui4"); class Ed extends bn { _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(e, n, o, u, l, f, v, S, D, x, P, I, M) { const C = this.length; return this.resize(C + 1), this.emplace(C, e, n, o, u, l, f, v, S, D, x, P, I, M); } emplace(e, n, o, u, l, f, v, S, D, x, P, I, M, C) { const k = 20 * e, V = 10 * e; return this.int16[k + 0] = n, this.int16[k + 1] = o, this.int16[k + 2] = u, this.int16[k + 3] = l, this.int16[k + 4] = f, this.float32[V + 3] = v, this.float32[V + 4] = S, this.float32[V + 5] = D, this.float32[V + 6] = x, this.int16[k + 14] = P, this.uint32[V + 8] = I, this.uint16[k + 18] = M, this.uint16[k + 19] = C, e; } } Ed.prototype.bytesPerElement = 40, Ft(Ed, "StructArrayLayout5i4f1i1ul2ui40"); class mu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v) { const S = this.length; return this.resize(S + 1), this.emplace(S, e, n, o, u, l, f, v); } emplace(e, n, o, u, l, f, v, S) { const D = 8 * e; return this.int16[D + 0] = n, this.int16[D + 1] = o, this.int16[D + 2] = u, this.int16[D + 4] = l, this.int16[D + 5] = f, this.int16[D + 6] = v, this.int16[D + 7] = S, e; } } mu.prototype.bytesPerElement = 16, Ft(mu, "StructArrayLayout3i2i2i16"); class _u extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l) { const f = this.length; return this.resize(f + 1), this.emplace(f, e, n, o, u, l); } emplace(e, n, o, u, l, f) { const v = 4 * e, S = 8 * e; return this.float32[v + 0] = n, this.float32[v + 1] = o, this.float32[v + 2] = u, this.int16[S + 6] = l, this.int16[S + 7] = f, e; } } _u.prototype.bytesPerElement = 16, Ft(_u, "StructArrayLayout2f1f2i16"); class Pd extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f) { const v = this.length; return this.resize(v + 1), this.emplace(v, e, n, o, u, l, f); } emplace(e, n, o, u, l, f, v) { const S = 20 * e, D = 5 * e; return this.uint8[S + 0] = n, this.uint8[S + 1] = o, this.float32[D + 1] = u, this.float32[D + 2] = l, this.float32[D + 3] = f, this.float32[D + 4] = v, e; } } Pd.prototype.bytesPerElement = 20, Ft(Pd, "StructArrayLayout2ub4f20"); class qs extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e, n, o) { const u = this.length; return this.resize(u + 1), this.emplace(u, e, n, o); } emplace(e, n, o, u) { const l = 3 * e; return this.uint16[l + 0] = n, this.uint16[l + 1] = o, this.uint16[l + 2] = u, e; } } qs.prototype.bytesPerElement = 6, Ft(qs, "StructArrayLayout3ui6"); class Ad extends bn { _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(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K) { const Q = this.length; return this.resize(Q + 1), this.emplace(Q, e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K); } emplace(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K, Q) { const ie = 30 * e, fe = 15 * e, de = 60 * e; return this.int16[ie + 0] = n, this.int16[ie + 1] = o, this.int16[ie + 2] = u, this.float32[fe + 2] = l, this.float32[fe + 3] = f, this.uint16[ie + 8] = v, this.uint16[ie + 9] = S, this.uint32[fe + 5] = D, this.uint32[fe + 6] = x, this.uint32[fe + 7] = P, this.uint16[ie + 16] = I, this.uint16[ie + 17] = M, this.uint16[ie + 18] = C, this.float32[fe + 10] = k, this.float32[fe + 11] = V, this.uint8[de + 48] = U, this.uint8[de + 49] = q, this.uint8[de + 50] = $, this.uint32[fe + 13] = H, this.int16[ie + 28] = K, this.uint8[de + 58] = Q, e; } } Ad.prototype.bytesPerElement = 60, Ft(Ad, "StructArrayLayout3i2f2ui3ul3ui2f3ub1ul1i1ub60"); class gu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K, Q, ie, fe, de, ue, Se, me, Ee, ze, Ie, Re) { const Ve = this.length; return this.resize(Ve + 1), this.emplace(Ve, e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K, Q, ie, fe, de, ue, Se, me, Ee, ze, Ie, Re); } emplace(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U, q, $, H, K, Q, ie, fe, de, ue, Se, me, Ee, ze, Ie, Re, Ve) { const Ue = 20 * e, Fe = 40 * e, et = 80 * e; return this.float32[Ue + 0] = n, this.float32[Ue + 1] = o, this.int16[Fe + 4] = u, this.int16[Fe + 5] = l, this.int16[Fe + 6] = f, this.int16[Fe + 7] = v, this.int16[Fe + 8] = S, this.int16[Fe + 9] = D, this.int16[Fe + 10] = x, this.int16[Fe + 11] = P, this.int16[Fe + 12] = I, this.uint16[Fe + 13] = M, this.uint16[Fe + 14] = C, this.uint16[Fe + 15] = k, this.uint16[Fe + 16] = V, this.uint16[Fe + 17] = U, this.uint16[Fe + 18] = q, this.uint16[Fe + 19] = $, this.uint16[Fe + 20] = H, this.uint16[Fe + 21] = K, this.uint16[Fe + 22] = Q, this.uint16[Fe + 23] = ie, this.uint16[Fe + 24] = fe, this.uint16[Fe + 25] = de, this.uint16[Fe + 26] = ue, this.uint16[Fe + 27] = Se, this.uint32[Ue + 14] = me, this.float32[Ue + 15] = Ee, this.float32[Ue + 16] = ze, this.float32[Ue + 17] = Ie, this.float32[Ue + 18] = Re, this.uint8[et + 76] = Ve, e; } } gu.prototype.bytesPerElement = 80, Ft(gu, "StructArrayLayout2f9i15ui1ul4f1ub80"); class uc extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e) { const n = this.length; return this.resize(n + 1), this.emplace(n, e); } emplace(e, n) { return this.float32[1 * e + 0] = n, e; } } uc.prototype.bytesPerElement = 4, Ft(uc, "StructArrayLayout1f4"); class Rr extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l) { const f = this.length; return this.resize(f + 1), this.emplace(f, e, n, o, u, l); } emplace(e, n, o, u, l, f) { const v = 5 * e; return this.float32[v + 0] = n, this.float32[v + 1] = o, this.float32[v + 2] = u, this.float32[v + 3] = l, this.float32[v + 4] = f, e; } } Rr.prototype.bytesPerElement = 20, Ft(Rr, "StructArrayLayout5f20"); class yu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v) { const S = this.length; return this.resize(S + 1), this.emplace(S, e, n, o, u, l, f, v); } emplace(e, n, o, u, l, f, v, S) { const D = 7 * e; return this.float32[D + 0] = n, this.float32[D + 1] = o, this.float32[D + 2] = u, this.float32[D + 3] = l, this.float32[D + 4] = f, this.float32[D + 5] = v, this.float32[D + 6] = S, e; } } yu.prototype.bytesPerElement = 28, Ft(yu, "StructArrayLayout7f28"); class Cd extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v, S, D, x, P) { const I = this.length; return this.resize(I + 1), this.emplace(I, e, n, o, u, l, f, v, S, D, x, P); } emplace(e, n, o, u, l, f, v, S, D, x, P, I) { const M = 11 * e; return this.float32[M + 0] = n, this.float32[M + 1] = o, this.float32[M + 2] = u, this.float32[M + 3] = l, this.float32[M + 4] = f, this.float32[M + 5] = v, this.float32[M + 6] = S, this.float32[M + 7] = D, this.float32[M + 8] = x, this.float32[M + 9] = P, this.float32[M + 10] = I, e; } } Cd.prototype.bytesPerElement = 44, Ft(Cd, "StructArrayLayout11f44"); class Id extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v, S, D) { const x = this.length; return this.resize(x + 1), this.emplace(x, e, n, o, u, l, f, v, S, D); } emplace(e, n, o, u, l, f, v, S, D, x) { const P = 9 * e; return this.float32[P + 0] = n, this.float32[P + 1] = o, this.float32[P + 2] = u, this.float32[P + 3] = l, this.float32[P + 4] = f, this.float32[P + 5] = v, this.float32[P + 6] = S, this.float32[P + 7] = D, this.float32[P + 8] = x, e; } } Id.prototype.bytesPerElement = 36, Ft(Id, "StructArrayLayout9f36"); class Pl extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n) { const o = this.length; return this.resize(o + 1), this.emplace(o, e, n); } emplace(e, n, o) { const u = 2 * e; return this.float32[u + 0] = n, this.float32[u + 1] = o, e; } } Pl.prototype.bytesPerElement = 8, Ft(Pl, "StructArrayLayout2f8"); class ah extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint32 = new Uint32Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e, n, o, u) { const l = this.length; return this.resize(l + 1), this.emplace(l, e, n, o, u); } emplace(e, n, o, u, l) { const f = 6 * e; return this.uint32[3 * e + 0] = n, this.uint16[f + 2] = o, this.uint16[f + 3] = u, this.uint16[f + 4] = l, e; } } ah.prototype.bytesPerElement = 12, Ft(ah, "StructArrayLayout1ul3ui12"); class xu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer); } emplaceBack(e) { const n = this.length; return this.resize(n + 1), this.emplace(n, e); } emplace(e, n) { return this.uint16[1 * e + 0] = n, e; } } xu.prototype.bytesPerElement = 2, Ft(xu, "StructArrayLayout1ui2"); class Ld extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V) { const U = this.length; return this.resize(U + 1), this.emplace(U, e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V); } emplace(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U) { const q = 16 * e; return this.float32[q + 0] = n, this.float32[q + 1] = o, this.float32[q + 2] = u, this.float32[q + 3] = l, this.float32[q + 4] = f, this.float32[q + 5] = v, this.float32[q + 6] = S, this.float32[q + 7] = D, this.float32[q + 8] = x, this.float32[q + 9] = P, this.float32[q + 10] = I, this.float32[q + 11] = M, this.float32[q + 12] = C, this.float32[q + 13] = k, this.float32[q + 14] = V, this.float32[q + 15] = U, e; } } Ld.prototype.bytesPerElement = 64, Ft(Ld, "StructArrayLayout16f64"); class lh extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.uint16 = new Uint16Array(this.arrayBuffer), this.float32 = new Float32Array(this.arrayBuffer); } emplaceBack(e, n, o, u, l, f, v) { const S = this.length; return this.resize(S + 1), this.emplace(S, e, n, o, u, l, f, v); } emplace(e, n, o, u, l, f, v, S) { const D = 10 * e, x = 5 * e; return this.uint16[D + 0] = n, this.uint16[D + 1] = o, this.uint16[D + 2] = u, this.uint16[D + 3] = l, this.float32[x + 2] = f, this.float32[x + 3] = v, this.float32[x + 4] = S, e; } } lh.prototype.bytesPerElement = 20, Ft(lh, "StructArrayLayout4ui3f20"); class zd extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer), this.int16 = new Int16Array(this.arrayBuffer); } emplaceBack(e) { const n = this.length; return this.resize(n + 1), this.emplace(n, e); } emplace(e, n) { return this.int16[1 * e + 0] = n, e; } } zd.prototype.bytesPerElement = 2, Ft(zd, "StructArrayLayout1i2"); class vu extends bn { _refreshViews() { this.uint8 = new Uint8Array(this.arrayBuffer); } emplaceBack(e) { const n = this.length; return this.resize(n + 1), this.emplace(n, e); } emplace(e, n) { return this.uint8[1 * e + 0] = n, e; } } vu.prototype.bytesPerElement = 1, Ft(vu, "StructArrayLayout1ub1"); class ch extends rh { 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]; } } ch.prototype.size = 40; class ap extends Ed { get(e) { return new ch(this, e); } } Ft(ap, "CollisionBoxArray"); class lp extends rh { 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(e) { this._structArray.uint8[this._pos1 + 49] = e; } get hidden() { return this._structArray.uint8[this._pos1 + 50]; } set hidden(e) { this._structArray.uint8[this._pos1 + 50] = e; } get crossTileID() { return this._structArray.uint32[this._pos4 + 13]; } set crossTileID(e) { this._structArray.uint32[this._pos4 + 13] = e; } get associatedIconIndex() { return this._structArray.int16[this._pos2 + 28]; } get flipState() { return this._structArray.uint8[this._pos1 + 58]; } set flipState(e) { this._structArray.uint8[this._pos1 + 58] = e; } } lp.prototype.size = 60; class cp extends Ad { get(e) { return new lp(this, e); } } Ft(cp, "PlacedSymbolArray"); class hp extends rh { get tileAnchorX() { return this._structArray.float32[this._pos4 + 0]; } get tileAnchorY() { return this._structArray.float32[this._pos4 + 1]; } get projectedAnchorX() { return this._structArray.int16[this._pos2 + 4]; } get projectedAnchorY() { return this._structArray.int16[this._pos2 + 5]; } get projectedAnchorZ() { return this._structArray.int16[this._pos2 + 6]; } get rightJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 7]; } get centerJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 8]; } get leftJustifiedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 9]; } get verticalPlacedTextSymbolIndex() { return this._structArray.int16[this._pos2 + 10]; } get placedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 11]; } get verticalPlacedIconSymbolIndex() { return this._structArray.int16[this._pos2 + 12]; } get key() { return this._structArray.uint16[this._pos2 + 13]; } get textBoxStartIndex() { return this._structArray.uint16[this._pos2 + 14]; } get textBoxEndIndex() { return this._structArray.uint16[this._pos2 + 15]; } get verticalTextBoxStartIndex() { return this._structArray.uint16[this._pos2 + 16]; } get verticalTextBoxEndIndex() { return this._structArray.uint16[this._pos2 + 17]; } get iconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 18]; } get iconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 19]; } get verticalIconBoxStartIndex() { return this._structArray.uint16[this._pos2 + 20]; } get verticalIconBoxEndIndex() { return this._structArray.uint16[this._pos2 + 21]; } get featureIndex() { return this._structArray.uint16[this._pos2 + 22]; } get numHorizontalGlyphVertices() { return this._structArray.uint16[this._pos2 + 23]; } get numVerticalGlyphVertices() { return this._structArray.uint16[this._pos2 + 24]; } get numIconVertices() { return this._structArray.uint16[this._pos2 + 25]; } get numVerticalIconVertices() { return this._structArray.uint16[this._pos2 + 26]; } get useRuntimeCollisionCircles() { return this._structArray.uint16[this._pos2 + 27]; } get crossTileID() { return this._structArray.uint32[this._pos4 + 14]; } set crossTileID(e) { this._structArray.uint32[this._pos4 + 14] = e; } get textOffset0() { return this._structArray.float32[this._pos4 + 15]; } get textOffset1() { return this._structArray.float32[this._pos4 + 16]; } get collisionCircleDiameter() { return this._structArray.float32[this._pos4 + 17]; } get zOffset() { return this._structArray.float32[this._pos4 + 18]; } set zOffset(e) { this._structArray.float32[this._pos4 + 18] = e; } get hasIconTextFit() { return this._structArray.uint8[this._pos1 + 76]; } } hp.prototype.size = 80; class up extends gu { get(e) { return new hp(this, e); } } Ft(up, "SymbolInstanceArray"); class hh extends uc { getoffsetX(e) { return this.float32[1 * e + 0]; } } Ft(hh, "GlyphOffsetArray"); class uh extends Lo { getx(e) { return this.int16[2 * e + 0]; } gety(e) { return this.int16[2 * e + 1]; } } Ft(uh, "SymbolLineVertexArray"); class Or extends rh { 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]; } } Or.prototype.size = 12; class dh extends ah { get(e) { return new Or(this, e); } } Ft(dh, "FeatureIndexArray"); class dp extends Ka { geta_centroid_pos0(e) { return this.uint16[2 * e + 0]; } geta_centroid_pos1(e) { return this.uint16[2 * e + 1]; } } Ft(dp, "FillExtrusionCentroidArray"); class fp extends rh { get a_join_normal_inside0() { return this._structArray.int16[this._pos2 + 0]; } get a_join_normal_inside1() { return this._structArray.int16[this._pos2 + 1]; } get a_join_normal_inside2() { return this._structArray.int16[this._pos2 + 2]; } } fp.prototype.size = 6; class pp extends oh { get(e) { return new fp(this, e); } } Ft(pp, "FillExtrusionWallArray"); const r_ = qi([{ name: "a_pos", components: 2, type: "Int16" }], 4), Dd = qi([{ name: "a_pos_3", components: 3, type: "Int16" }, { name: "a_pos_normal_3", components: 3, type: "Int16" }]); class Wn { constructor(e = []) { this.segments = e; } _prepareSegment(e, n, o, u) { let l = this.segments[this.segments.length - 1]; return e > Wn.MAX_VERTEX_ARRAY_LENGTH && mi(`Max vertices per segment is ${Wn.MAX_VERTEX_ARRAY_LENGTH}: bucket requested ${e}`), (!l || l.vertexLength + e > Wn.MAX_VERTEX_ARRAY_LENGTH || l.sortKey !== u) && (l = { vertexOffset: n, primitiveOffset: o, vertexLength: 0, primitiveLength: 0 }, u !== void 0 && (l.sortKey = u), this.segments.push(l)), l; } prepareSegment(e, n, o, u) { return this._prepareSegment(e, n.length, o.length, u); } get() { return this.segments; } destroy() { for (const e of this.segments) for (const n in e.vaos) e.vaos[n].destroy(); } static simpleSegment(e, n, o, u) { return new Wn([{ vertexOffset: e, primitiveOffset: n, vertexLength: o, primitiveLength: u, vaos: {}, sortKey: 0 }]); } } function bu(r, e) { return 256 * (r = si(Math.floor(r), 0, 255)) + si(Math.floor(e), 0, 255); } Wn.MAX_VERTEX_ARRAY_LENGTH = Math.pow(2, 16) - 1, Ft(Wn, "SegmentVector"); const o_ = qi([{ name: "a_pattern", components: 4, type: "Uint16" }, { name: "a_pixel_ratio", components: 1, type: "Float32" }]), a_ = qi([{ name: "a_dash", components: 4, type: "Uint16" }]); class Al { constructor() { this.ids = [], this.uniqueIds = [], this.positions = [], this.indexed = !1; } add(e, n, o, u) { this.ids.push(mp(e)), this.positions.push(n, o, u); } eachPosition(e, n) { const o = mp(e); let u = 0, l = this.ids.length - 1; for (; u < l; ) { const f = u + l >> 1; this.ids[f] >= o ? l = f : u = f + 1; } for (; this.ids[u] === o; ) n(this.positions[3 * u], this.positions[3 * u + 1], this.positions[3 * u + 2]), u++; } static serialize(e, n) { const o = new Float64Array(e.ids), u = new Uint32Array(e.positions); return wu(o, u, 0, o.length - 1), n && (n.add(o.buffer), n.add(u.buffer)), { ids: o, positions: u }; } static deserialize(e) { const n = new Al(); let o; n.ids = e.ids, n.positions = e.positions; for (const u of n.ids) u !== o && n.uniqueIds.push(u), o = u; return n.indexed = !0, n; } } function mp(r) { const e = +r; return !isNaN(e) && Number.MIN_SAFE_INTEGER <= e && e <= Number.MAX_SAFE_INTEGER ? e : $r(String(r)); } function wu(r, e, n, o) { for (; n < o; ) { const u = r[n + o >> 1]; let l = n - 1, f = o + 1; for (; ; ) { do l++; while (r[l] < u); do f--; while (r[f] > u); if (l >= f) break; fh(r, l, f), fh(e, 3 * l, 3 * f), fh(e, 3 * l + 1, 3 * f + 1), fh(e, 3 * l + 2, 3 * f + 2); } f - n < o - f ? (wu(r, e, n, f), n = f + 1) : (wu(r, e, f + 1, o), o = f); } } function fh(r, e, n) { const o = r[e]; r[e] = r[n], r[n] = o; } Ft(Al, "FeaturePositionMap"); class ba { constructor(e) { this.gl = e.gl, this.initialized = !1; } fetchUniformLocation(e, n) { return this.location || this.initialized || (this.location = this.gl.getUniformLocation(e, n), this.initialized = !0), !!this.location; } set(e, n, o) { throw new Error("Uniform#set() must be implemented by each concrete Uniform"); } } class dc extends ba { constructor(e) { super(e), this.current = 0; } set(e, n, o) { this.fetchUniformLocation(e, n) && this.current !== o && (this.current = o, this.gl.uniform1i(this.location, o)); } } class Nn extends ba { constructor(e) { super(e), this.current = 0; } set(e, n, o) { this.fetchUniformLocation(e, n) && this.current !== o && (this.current = o, this.gl.uniform1f(this.location, o)); } } class zo extends ba { constructor(e) { super(e), this.current = [0, 0]; } set(e, n, o) { this.fetchUniformLocation(e, n) && (o[0] === this.current[0] && o[1] === this.current[1] || (this.current = o, this.gl.uniform2f(this.location, o[0], o[1]))); } } class kd extends ba { constructor(e) { super(e), this.current = [0, 0, 0]; } set(e, n, o) { this.fetchUniformLocation(e, n) && (o[0] === this.current[0] && o[1] === this.current[1] && o[2] === this.current[2] || (this.current = o, this.gl.uniform3f(this.location, o[0], o[1], o[2]))); } } class ph extends ba { constructor(e) { super(e), this.current = [0, 0, 0, 0]; } set(e, n, o) { this.fetchUniformLocation(e, n) && (o[0] === this.current[0] && o[1] === this.current[1] && o[2] === this.current[2] && o[3] === this.current[3] || (this.current = o, this.gl.uniform4f(this.location, o[0], o[1], o[2], o[3]))); } } class _p extends ba { constructor(e) { super(e), this.current = ki.transparent.toRenderColor(null); } set(e, n, o) { this.fetchUniformLocation(e, n) && (o.r === this.current.r && o.g === this.current.g && o.b === this.current.b && o.a === this.current.a || (this.current = o, this.gl.uniform4f(this.location, o.r, o.g, o.b, o.a))); } } const Rd = new Float32Array(16); class mh extends ba { constructor(e) { super(e), this.current = Rd; } set(e, n, o) { if (this.fetchUniformLocation(e, n)) { if (o[12] !== this.current[12] || o[0] !== this.current[0]) return this.current = o, void this.gl.uniformMatrix4fv(this.location, !1, o); for (let u = 1; u < 16; u++) if (o[u] !== this.current[u]) { this.current = o, this.gl.uniformMatrix4fv(this.location, !1, o); break; } } } } const l_ = new Float32Array(9), c_ = new Float32Array(4); class Od extends ba { constructor(e) { super(e), this.current = c_; } set(e, n, o) { if (this.fetchUniformLocation(e, n)) { for (let u = 0; u < 4; u++) if (o[u] !== this.current[u]) { this.current = o, this.gl.uniformMatrix2fv(this.location, !1, o); break; } } } } function Tu(r) { return [bu(255 * r.r, 255 * r.g), bu(255 * r.b, 255 * r.a)]; } class fc { constructor(e, n, o, u) { this.value = e, this.uniformNames = n.map((l) => `u_${l}`), this.type = o, this.context = u; } setUniform(e, n, o, u, l) { const f = u.constantOr(this.value); n.set(e, l, f instanceof ki ? f.toRenderColor(this.ignoreLut ? null : this.context.lut) : f); } getBinding(e, n) { return this.type === "color" ? new _p(e) : new Nn(e); } } class pc { constructor(e, n) { this.uniformNames = n.map((o) => `u_${o}`), this.pattern = null, this.pixelRatio = 1; } setConstantPatternPositions(e) { this.pixelRatio = e.pixelRatio || 1, this.pattern = e.tl.concat(e.br); } setUniform(e, n, o, u, l) { const f = l === "u_pattern" || l === "u_dash" ? this.pattern : l === "u_pixel_ratio" ? this.pixelRatio : null; f && n.set(e, l, f); } getBinding(e, n) { return n === "u_pattern" || n === "u_dash" ? new ph(e) : new Nn(e); } } class wa { constructor(e, n, o, u) { this.expression = e, this.type = o, this.maxValue = 0, this.paintVertexAttributes = n.map((l) => ({ name: `a_${l}`, type: "Float32", components: o === "color" ? 2 : 1, offset: 0 })), this.paintVertexArray = new u(); } populatePaintArray(e, n, o, u, l, f, v) { const S = this.paintVertexArray.length, D = this.expression.evaluate(new Tn(0, { brightness: f }), n, {}, l, u, v); this.paintVertexArray.resize(e), this._setPaintValue(S, e, D, this.context); } updatePaintArray(e, n, o, u, l, f, v) { const S = this.expression.evaluate({ zoom: 0, brightness: v }, o, u, void 0, l); this._setPaintValue(e, n, S, this.context); } _setPaintValue(e, n, o, u) { if (this.type === "color") { const l = Tu(o.toRenderColor(this.ignoreLut ? null : u.lut)); for (let f = e; f < n; f++) this.paintVertexArray.emplace(f, l[0], l[1]); } else { for (let l = e; l < n; l++) this.paintVertexArray.emplace(l, o); this.maxValue = Math.max(this.maxValue, Math.abs(o)); } } upload(e) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = e.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent || !this.expression.isLightConstant)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } } class Do { constructor(e, n, o, u, l, f) { this.expression = e, this.uniformNames = n.map((v) => `u_${v}_t`), this.type = o, this.useIntegerZoom = u, this.context = l, this.maxValue = 0, this.paintVertexAttributes = n.map((v) => ({ name: `a_${v}`, type: "Float32", components: o === "color" ? 4 : 2, offset: 0 })), this.paintVertexArray = new f(); } populatePaintArray(e, n, o, u, l, f, v) { const S = this.expression.evaluate(new Tn(this.context.zoom, { brightness: f }), n, {}, l, u, v), D = this.expression.evaluate(new Tn(this.context.zoom + 1, { brightness: f }), n, {}, l, u, v), x = this.paintVertexArray.length; this.paintVertexArray.resize(e), this._setPaintValue(x, e, S, D, this.context); } updatePaintArray(e, n, o, u, l, f, v) { const S = this.expression.evaluate({ zoom: this.context.zoom, brightness: v }, o, u, void 0, l), D = this.expression.evaluate({ zoom: this.context.zoom + 1, brightness: v }, o, u, void 0, l); this._setPaintValue(e, n, S, D, this.context); } _setPaintValue(e, n, o, u, l) { if (this.type === "color") { const f = Tu(o.toRenderColor(this.ignoreLut ? null : l.lut)), v = Tu(o.toRenderColor(this.ignoreLut ? null : l.lut)); for (let S = e; S < n; S++) this.paintVertexArray.emplace(S, f[0], f[1], v[0], v[1]); } else { for (let f = e; f < n; f++) this.paintVertexArray.emplace(f, o, u); this.maxValue = Math.max(this.maxValue, Math.abs(o), Math.abs(u)); } } upload(e) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer && this.paintVertexBuffer.buffer ? this.paintVertexBuffer.updateData(this.paintVertexArray) : this.paintVertexBuffer = e.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent || !this.expression.isLightConstant)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } setUniform(e, n, o, u, l) { const f = this.useIntegerZoom ? Math.floor(o.zoom) : o.zoom, v = si(this.expression.interpolationFactor(f, this.context.zoom, this.context.zoom + 1), 0, 1); n.set(e, l, v); } getBinding(e, n) { return new Nn(e); } } class Ja { constructor(e, n, o, u, l) { this.expression = e, this.layerId = l, this.paintVertexAttributes = (o === "array" ? a_ : o_).members; for (let f = 0; f < n.length; ++f) ; this.paintVertexArray = new u(); } populatePaintArray(e, n, o, u) { const l = this.paintVertexArray.length; this.paintVertexArray.resize(e), this._setPaintValues(l, e, n.patterns && n.patterns[this.layerId], o); } updatePaintArray(e, n, o, u, l, f, v) { this._setPaintValues(e, n, o.patterns && o.patterns[this.layerId], f); } _setPaintValues(e, n, o, u) { if (!u || !o) return; const l = u[o]; if (!l) return; const { tl: f, br: v, pixelRatio: S } = l; for (let D = e; D < n; D++) this.paintVertexArray.emplace(D, f[0], f[1], v[0], v[1], S); } upload(e) { this.paintVertexArray && this.paintVertexArray.arrayBuffer && (this.paintVertexBuffer = e.createVertexBuffer(this.paintVertexArray, this.paintVertexAttributes, this.expression.isStateDependent || !this.expression.isLightConstant)); } destroy() { this.paintVertexBuffer && this.paintVertexBuffer.destroy(); } } class Cl { constructor(e, n, o = () => !0) { this.binders = {}, this._buffers = [], this.context = n; const u = []; for (const l in e.paint._values) { const f = e.paint.get(l), v = e.paint.get(`${l}-use-theme`); if (l.endsWith("-use-theme") || !o(l) || !(f instanceof lc && nc(f.property.specification))) continue; const S = Mu(l, e.type), D = f.value, x = f.property.specification.type, P = !!f.property.useIntegerZoom, I = l === "line-dasharray" || l.endsWith("pattern"), M = l === "line-dasharray" && e.layout.get("line-cap").value.kind !== "constant"; if (D.kind !== "constant" || M) if (D.kind === "source" || M || I) { const C = _h(l, x, "source"); this.binders[l] = I ? new Ja(D, S, x, C, e.id) : new wa(D, S, x, C), u.push(`/a_${l}`); } else { const C = _h(l, x, "composite"); this.binders[l] = new Do(D, S, x, P, n, C), u.push(`/z_${l}`); } else this.binders[l] = I ? new pc(D.value, S) : new fc(D.value, S, x, n), u.push(`/u_${l}`); v && (this.binders[l].ignoreLut = v.constantOr("default") === "none", this.binders[l].checkUseTheme = !0); } this.cacheKey = u.sort().join(""); } getMaxValue(e) { const n = this.binders[e]; return n instanceof wa || n instanceof Do ? n.maxValue : 0; } populatePaintArrays(e, n, o, u, l, f, v) { for (const S in this.binders) { const D = this.binders[S]; D.context = this.context, (D instanceof wa || D instanceof Do || D instanceof Ja) && D.populatePaintArray(e, n, o, u, l, f, v); } } setConstantPatternPositions(e) { for (const n in this.binders) { const o = this.binders[n]; o instanceof pc && o.setConstantPatternPositions(e); } } updatePaintArrays(e, n, o, u, l, f, v, S, D) { let x = !1; const P = Object.keys(e), I = P.length !== 0 && !S, M = I ? P : n.uniqueIds; this.context.lut = l.lut; for (const C in this.binders) { const k = this.binders[C]; if (k.context = this.context, (k instanceof wa || k instanceof Do || k instanceof Ja) && (k.expression.isStateDependent === !0 || k.expression.isLightConstant === !1)) { const V = l.paint.get(C); k.expression = V.value; for (const U of M) { const q = e[U.toString()]; n.eachPosition(U, ($, H, K) => { const Q = u.feature($); k.updatePaintArray(H, K, Q, q, f, v, D); }); } if (!I) for (const U of o.uniqueIds) { const q = e[U.toString()]; o.eachPosition(U, ($, H, K) => { const Q = u.feature($); k.updatePaintArray(H, K, Q, q, f, v, D); }); } x = !0; } } return x; } defines() { const e = []; for (const n in this.binders) { const o = this.binders[n]; (o instanceof fc || o instanceof pc) && e.push(...o.uniformNames.map((u) => `#define HAS_UNIFORM_${u}`)); } return e; } getBinderAttributes() { const e = []; for (const n in this.binders) { const o = this.binders[n]; if (o instanceof wa || o instanceof Do || o instanceof Ja) for (let u = 0; u < o.paintVertexAttributes.length; u++) e.push(o.paintVertexAttributes[u].name); } return e; } getBinderUniforms() { const e = []; for (const n in this.binders) { const o = this.binders[n]; if (o instanceof fc || o instanceof pc || o instanceof Do) for (const u of o.uniformNames) e.push(u); } return e; } getPaintVertexBuffers() { return this._buffers; } getUniforms(e) { const n = []; for (const o in this.binders) { const u = this.binders[o]; if (u instanceof fc || u instanceof pc || u instanceof Do) for (const l of u.uniformNames) n.push({ name: l, property: o, binding: u.getBinding(e, l) }); } return n; } setUniforms(e, n, o, u, l) { for (const { name: f, property: v, binding: S } of o) { if (this.binders[v].checkUseTheme && this.binders[v] instanceof fc) { const D = u.get(`${v}-use-theme`); D.isConstant() && (this.binders[v].ignoreLut = D.constantOr("default") === "none"); } this.binders[v].setUniform(e, S, l, u.get(v), f); } } updatePaintBuffers() { this._buffers = []; for (const e in this.binders) { const n = this.binders[e]; (n instanceof wa || n instanceof Do || n instanceof Ja) && n.paintVertexBuffer && this._buffers.push(n.paintVertexBuffer); } } upload(e) { for (const n in this.binders) { const o = this.binders[n]; (o instanceof wa || o instanceof Do || o instanceof Ja) && o.upload(e); } this.updatePaintBuffers(); } destroy() { for (const e in this.binders) { const n = this.binders[e]; (n instanceof wa || n instanceof Do || n instanceof Ja) && n.destroy(); } } } class Qa { constructor(e, n, o = () => !0) { this.programConfigurations = {}; for (const u of e) this.programConfigurations[u.id] = new Cl(u, n, o); this.needsUpload = !1, this._featureMap = new Al(), this._featureMapWithoutIds = new Al(), this._bufferOffset = 0, this._idlessCounter = 0; } populatePaintArrays(e, n, o, u, l, f, v, S) { for (const D in this.programConfigurations) this.programConfigurations[D].populatePaintArrays(e, n, u, l, f, v, S); n.id !== void 0 ? this._featureMap.add(n.id, o, this._bufferOffset, e) : (this._featureMapWithoutIds.add(this._idlessCounter, o, this._bufferOffset, e), this._idlessCounter += 1), this._bufferOffset = e, this.needsUpload = !0; } updatePaintArrays(e, n, o, u, l, f, v) { for (const S of o) this.needsUpload = this.programConfigurations[S.id].updatePaintArrays(e, this._featureMap, this._featureMapWithoutIds, n, S, u, l, f, v || 0) || this.needsUpload; } get(e) { return this.programConfigurations[e]; } upload(e) { if (this.needsUpload) { for (const n in this.programConfigurations) this.programConfigurations[n].upload(e); this.needsUpload = !1; } } destroy() { for (const e in this.programConfigurations) this.programConfigurations[e].destroy(); } } const h_ = { "text-opacity": ["opacity"], "icon-opacity": ["opacity"], "text-occlusion-opacity": ["occlusion_opacity"], "icon-occlusion-opacity": ["occlusion_opacity"], "text-color": ["fill_color"], "icon-color": ["fill_color"], "text-emissive-strength": ["emissive_strength"], "icon-emissive-strength": ["emissive_strength"], "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"], "symbol-z-offset": ["z_offset"], "line-gap-width": ["gapwidth"], "line-pattern": ["pattern", "pixel_ratio"], "fill-pattern": ["pattern", "pixel_ratio"], "fill-extrusion-pattern": ["pattern", "pixel_ratio"], "line-dasharray": ["dash"] }; function Mu(r, e) { return h_[r] || [r.replace(`${e}-`, "").replace(/-/g, "_")]; } const u_ = { "line-pattern": { source: Ya, composite: Ya }, "fill-pattern": { source: Ya, composite: Ya }, "fill-extrusion-pattern": { source: Ya, composite: Ya }, "line-dasharray": { source: fu, composite: fu } }, d_ = { color: { source: Pl, composite: Xa }, number: { source: uc, composite: Pl } }; function _h(r, e, n) { const o = u_[r]; return o && o[n] || d_[e][n]; } Ft(fc, "ConstantBinder"), Ft(pc, "PatternConstantBinder"), Ft(wa, "SourceExpressionBinder"), Ft(Ja, "PatternCompositeBinder"), Ft(Do, "CompositeExpressionBinder"), Ft(Cl, "ProgramConfiguration", { omit: ["_buffers"] }), Ft(Qa, "ProgramConfigurationSet"); const dr = Tt / Math.PI / 2, Su = 5, gp = 6, yp = 16383, Il = 64, Eu = [Il, 32, 16], uo = -dr, fo = dr; function mc(r, e, n, o = dr) { return n = vi(n), [r * Math.sin(n) * o, -e * o, r * Math.cos(n) * o]; } function el(r, e, n) { return mc(Math.cos(vi(r)), Math.sin(vi(r)), e, n); } const _c = 63710088e-1, Fd = 2 * Math.PI * _c; class Ui { constructor(e, n) { if (isNaN(e) || isNaN(n)) throw new Error(`Invalid LngLat object: (${e}, ${n})`); if (this.lng = +e, this.lat = +n, this.lat > 90 || this.lat < -90) throw new Error("Invalid LngLat latitude value: must be between -90 and 90"); } wrap() { return new Ui(zn(this.lng, -180, 180), this.lat); } toArray() { return [this.lng, this.lat]; } toString() { return `LngLat(${this.lng}, ${this.lat})`; } distanceTo(e) { const n = Math.PI / 180, o = this.lat * n, u = e.lat * n, l = Math.sin(o) * Math.sin(u) + Math.cos(o) * Math.cos(u) * Math.cos((e.lng - this.lng) * n); return _c * Math.acos(Math.min(l, 1)); } toBounds(e = 0) { const n = 360 * e / 40075017, o = n / Math.cos(Math.PI / 180 * this.lat); return new tl({ lng: this.lng - o, lat: this.lat - n }, { lng: this.lng + o, lat: this.lat + n }); } toEcef(e) { return el(this.lat, this.lng, dr + e * dr / _c); } static convert(e) { if (e instanceof Ui) return e; if (Array.isArray(e) && (e.length === 2 || e.length === 3)) return new Ui(Number(e[0]), Number(e[1])); if (!Array.isArray(e) && typeof e == "object" && e !== null) return new Ui(Number("lng" in e ? e.lng : e.lon), Number(e.lat)); throw new Error("`LngLatLike` argument must be specified as a LngLat instance, an object {lng: , lat: }, an object {lon: , lat: }, or an array of [, ]"); } } class tl { constructor(e, n) { if (e) if (n) this.setSouthWest(e).setNorthEast(n); else if (e.length === 4) { const o = e; this.setSouthWest([o[0], o[1]]).setNorthEast([o[2], o[3]]); } else { const o = e; this.setSouthWest(o[0]).setNorthEast(o[1]); } } setNorthEast(e) { return this._ne = e instanceof Ui ? new Ui(e.lng, e.lat) : Ui.convert(e), this; } setSouthWest(e) { return this._sw = e instanceof Ui ? new Ui(e.lng, e.lat) : Ui.convert(e), this; } extend(e) { const n = this._sw, o = this._ne; let u, l; if (e instanceof Ui) u = e, l = e; else { if (!(e instanceof tl)) return Array.isArray(e) ? e.length === 4 || e.every(Array.isArray) ? this.extend(tl.convert(e)) : this.extend(Ui.convert(e)) : typeof e == "object" && e !== null && e.hasOwnProperty("lat") && (e.hasOwnProperty("lon") || e.hasOwnProperty("lng")) ? this.extend(Ui.convert(e)) : this; if (u = e._sw, l = e._ne, !u || !l) return this; } return n || o ? (n.lng = Math.min(u.lng, n.lng), n.lat = Math.min(u.lat, n.lat), o.lng = Math.max(l.lng, o.lng), o.lat = Math.max(l.lat, o.lat)) : (this._sw = new Ui(u.lng, u.lat), this._ne = new Ui(l.lng, l.lat)), this; } getCenter() { return new Ui((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 Ui(this.getWest(), this.getNorth()); } getSouthEast() { return new Ui(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(e) { const { lng: n, lat: o } = Ui.convert(e); let u = this._sw.lng <= n && n <= this._ne.lng; return this._sw.lng > this._ne.lng && (u = this._sw.lng >= n && n >= this._ne.lng), this._sw.lat <= o && o <= this._ne.lat && u; } static convert(e) { if (e) return e instanceof tl ? e : new tl(e); } } const f_ = 0, xp = 25.5; function gh(r) { return Fd * Math.cos(r * Math.PI / 180); } function ta(r) { return (180 + r) / 360; } function Ta(r) { return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + r * Math.PI / 360))) / 360; } function fr(r, e) { return r / gh(e); } function Fr(r) { return 360 * r - 180; } function Os(r) { return 360 / Math.PI * Math.atan(Math.exp((180 - 360 * r) * Math.PI / 180)) - 90; } function vp(r, e) { return r * gh(Os(e)); } const Un = 85.051129; function p_(r) { return Math.cos(vi(si(r, -Un, Un))); } function c(r, e) { const n = si(e, f_, xp), o = Math.pow(2, n); return p_(r) * Fd / (512 * o); } function t(r) { return 1 / Math.cos(r * Math.PI / 180); } function s(r, e = 0) { const n = Math.exp(Math.PI * (1 - (r.y + e / Tt) / (1 << r.z) * 2)); return 80150034 * n / (n * n + 1) / Tt / (1 << r.z); } class h { constructor(e, n, o = 0) { this.x = +e, this.y = +n, this.z = +o; } static fromLngLat(e, n = 0) { const o = Ui.convert(e); return new h(ta(o.lng), Ta(o.lat), fr(n, o.lat)); } toLngLat() { return new Ui(Fr(this.x), Os(this.y)); } toAltitude() { return vp(this.z, this.y); } meterInMercatorCoordinateUnits() { return 1 / Fd * t(Os(this.y)); } } function _(r, e, n, o, u, l, f, v, S) { const D = (e + o) / 2, x = (n + u) / 2, P = new Et(D, x); v(P), function(I, M, C, k, V, U) { const q = C - V, $ = k - U; return Math.abs((k - M) * q - (C - I) * $) / Math.hypot(q, $); }(P.x, P.y, l.x, l.y, f.x, f.y) >= S ? (_(r, e, n, D, x, l, P, v, S), _(r, D, x, o, u, P, f, v, S)) : r.push(f); } function y(r, e, n) { let o = r[0], u = o.x, l = o.y; e(o); const f = [o]; for (let v = 1; v < r.length; v++) { const S = r[v], { x: D, y: x } = S; e(S), _(f, u, l, D, x, o, S, e, n), u = D, l = x, o = S; } return f; } function T(r, e, n, o) { if (o(e, n)) { const u = e.add(n)._mult(0.5); T(r, e, u, o), T(r, u, n, o); } else r.push(n); } function z(r, e) { let n = r[0]; const o = [n]; for (let u = 1; u < r.length; u++) { const l = r[u]; T(o, n, l, e), n = l; } return o; } const R = Math.pow(2, 14) - 1, F = -R - 1; function N(r, e) { const n = Math.round(r.x * e), o = Math.round(r.y * e); return r.x = si(n, F, R), r.y = si(o, F, R), (n < r.x || n > r.x + 1 || o < r.y || o > r.y + 1) && mi("Geometry exceeds allowed extent, reduce your vector tile buffer size"), r; } function G(r, e, n) { const o = r.loadGeometry(), u = r.extent, l = Tt / u; if (e && n && n.projection.isReprojectedInTileSpace) { const f = 1 << e.z, { scale: v, x: S, y: D, projection: x } = n, P = (I) => { const M = Fr((e.x + I.x / u) / f), C = Os((e.y + I.y / u) / f), k = x.project(M, C); I.x = (k.x * v - S) * u, I.y = (k.y * v - D) * u; }; for (let I = 0; I < o.length; I++) if (r.type !== 1) o[I] = y(o[I], P, 1); else { const M = []; for (const C of o[I]) C.x < 0 || C.x >= u || C.y < 0 || C.y >= u || (P(C), M.push(C)); o[I] = M; } } for (const f of o) for (const v of f) N(v, l); return o; } function Z(r, e) { return { type: r.type, id: r.id, properties: r.properties, geometry: e ? G(r) : [] }; } function W(r, e, n, o, u) { r.emplaceBack(2 * e + (o + 1) / 2, 2 * n + (u + 1) / 2); } function te(r, e, n) { r.emplaceBack(e.x, e.y, e.z, n[0] * 16384, n[1] * 16384, n[2] * 16384); } class ee { constructor(e) { this.zoom = e.zoom, this.overscaling = e.overscaling, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.index = e.index, this.hasPattern = !1, this.projection = e.projection, this.layoutVertexArray = new Lo(), this.indexArray = new qs(), this.segments = new Wn(), this.programConfigurations = new Qa(e.layers, { zoom: e.zoom, lut: e.lut }), this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id); } updateFootprints(e, n) { } populate(e, n, o, u) { const l = this.layers[0], f = []; let v = null; l.type === "circle" && (v = l.layout.get("circle-sort-key")); for (const { feature: D, id: x, index: P, sourceLayerIndex: I } of e) { const M = this.layers[0]._featureFilter.needGeometry, C = Z(D, M); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), C, o)) continue; const k = v ? v.evaluate(C, {}, o) : void 0, V = { id: x, properties: D.properties, type: D.type, sourceLayerIndex: I, index: P, geometry: M ? C.geometry : G(D, o, u), patterns: {}, sortKey: k }; f.push(V); } v && f.sort((D, x) => D.sortKey - x.sortKey); let S = null; u.projection.name === "globe" && (this.globeExtVertexArray = new pu(), S = u.projection); for (const D of f) { const { geometry: x, index: P, sourceLayerIndex: I } = D, M = e[P].feature; this.addFeature(D, x, P, n.availableImages, o, S, n.brightness), n.featureIndex.insert(M, x, P, I, this.index); } } update(e, n, o, u, l, f, v) { this.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v); } isEmpty() { return this.layoutVertexArray.length === 0; } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload; } upload(e) { this.uploaded || (this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, r_.members), this.indexBuffer = e.createIndexBuffer(this.indexArray), this.globeExtVertexArray && (this.globeExtVertexBuffer = e.createVertexBuffer(this.globeExtVertexArray, Dd.members))), this.programConfigurations.upload(e), this.uploaded = !0; } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.globeExtVertexBuffer && this.globeExtVertexBuffer.destroy()); } addFeature(e, n, o, u, l, f, v) { for (const S of n) for (const D of S) { const x = D.x, P = D.y; if (x < 0 || x >= Tt || P < 0 || P >= Tt) continue; if (f) { const C = f.projectTilePoint(x, P, l), k = f.upVector(l, x, P), V = this.globeExtVertexArray; te(V, C, k), te(V, C, k), te(V, C, k), te(V, C, k); } const I = this.segments.prepareSegment(4, this.layoutVertexArray, this.indexArray, e.sortKey), M = I.vertexLength; W(this.layoutVertexArray, x, P, -1, -1), W(this.layoutVertexArray, x, P, 1, -1), W(this.layoutVertexArray, x, P, 1, 1), W(this.layoutVertexArray, x, P, -1, 1), this.indexArray.emplaceBack(M, M + 1, M + 2), this.indexArray.emplaceBack(M, M + 2, M + 3), I.vertexLength += 4, I.primitiveLength += 2; } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, e, o, {}, u, l, v); } } function se(r, e) { for (let n = 0; n < r.length; n++) if (Ae(e, r[n])) return !0; for (let n = 0; n < e.length; n++) if (Ae(r, e[n])) return !0; return !!pe(r, e); } function oe(r, e, n) { return !!Ae(r, e) || !!xe(e, r, n); } function he(r, e) { if (r.length === 1) return ve(e, r[0]); for (let n = 0; n < e.length; n++) { const o = e[n]; for (let u = 0; u < o.length; u++) if (Ae(r, o[u])) return !0; } for (let n = 0; n < r.length; n++) if (ve(e, r[n])) return !0; for (let n = 0; n < e.length; n++) if (pe(r, e[n])) return !0; return !1; } function _e(r, e, n) { if (r.length > 1) { if (pe(r, e)) return !0; for (let o = 0; o < e.length; o++) if (xe(e[o], r, n)) return !0; } for (let o = 0; o < r.length; o++) if (xe(r[o], e, n)) return !0; return !1; } function pe(r, e) { if (r.length === 0 || e.length === 0) return !1; for (let n = 0; n < r.length - 1; n++) { const o = r[n], u = r[n + 1]; for (let l = 0; l < e.length - 1; l++) if (Me(o, u, e[l], e[l + 1])) return !0; } return !1; } function Me(r, e, n, o) { return On(r, n, o) !== On(e, n, o) && On(r, e, n) !== On(r, e, o); } function xe(r, e, n) { const o = n * n; if (e.length === 1) return r.distSqr(e[0]) < o; for (let u = 1; u < e.length; u++) if (we(r, e[u - 1], e[u]) < o) return !0; return !1; } function we(r, e, n) { const o = e.distSqr(n); if (o === 0) return r.distSqr(e); const u = ((r.x - e.x) * (n.x - e.x) + (r.y - e.y) * (n.y - e.y)) / o; return r.distSqr(u < 0 ? e : u > 1 ? n : n.sub(e)._mult(u)._add(e)); } function ve(r, e) { let n, o, u, l = !1; for (let f = 0; f < r.length; f++) { n = r[f]; for (let v = 0, S = n.length - 1; v < n.length; S = v++) o = n[v], u = n[S], o.y > e.y != u.y > e.y && e.x < (u.x - o.x) * (e.y - o.y) / (u.y - o.y) + o.x && (l = !l); } return l; } function Ae(r, e) { let n = !1; for (let o = 0, u = r.length - 1; o < r.length; u = o++) { const l = r[o], f = r[u]; l.y > e.y != f.y > e.y && e.x < (f.x - l.x) * (e.y - l.y) / (f.y - l.y) + l.x && (n = !n); } return n; } function Oe(r, e, n, o, u) { for (const f of r) if (e <= f.x && n <= f.y && o >= f.x && u >= f.y) return !0; const l = [new Et(e, n), new Et(e, u), new Et(o, u), new Et(o, n)]; if (r.length > 2) { for (const f of l) if (Ae(r, f)) return !0; } for (let f = 0; f < r.length - 1; f++) if (Xe(r[f], r[f + 1], l)) return !0; return !1; } function Xe(r, e, n) { const o = n[0], u = n[2]; if (r.x < o.x && e.x < o.x || r.x > u.x && e.x > u.x || r.y < o.y && e.y < o.y || r.y > u.y && e.y > u.y) return !1; const l = On(r, e, n[0]); return l !== On(r, e, n[1]) || l !== On(r, e, n[2]) || l !== On(r, e, n[3]); } function He(r, e, n, o, u, l) { let f = e.y - r.y, v = r.x - e.x; if (l = l || 0) { const S = f * f + v * v; if (S === 0) return !0; const D = Math.sqrt(S); f /= D, v /= D; } return !((n.x - r.x) * f + (n.y - r.y) * v - l < 0 || (o.x - r.x) * f + (o.y - r.y) * v - l < 0 || (u.x - r.x) * f + (u.y - r.y) * v - l < 0); } function ke(r, e, n, o, u, l, f) { return !(He(r, e, o, u, l, f) || He(e, n, o, u, l, f) || He(n, r, o, u, l, f) || He(o, u, r, e, n, f) || He(u, l, r, e, n, f) || He(l, o, r, e, n, f)); } function Ne(r, e, n) { const o = e.paint.get(r).value; return o.kind === "constant" ? o.value : n.programConfigurations.get(e.id).getMaxValue(r); } function st(r) { return Math.sqrt(r[0] * r[0] + r[1] * r[1]); } function ut(r, e, n, o, u) { if (!e[0] && !e[1]) return r; const l = Et.convert(e)._mult(u); n === "viewport" && l._rotate(-o); const f = []; for (let v = 0; v < r.length; v++) f.push(r[v].sub(l)); return f; } function xt(r, e, n, o) { const u = Et.convert(r)._mult(o); return e === "viewport" && u._rotate(-n), u; } let Ge, lt; Ft(ee, "CircleBucket", { omit: ["layers"] }); var Je, _t = { exports: {} }, ct = (Je || (Je = 1, function(r, e) { (function(n) { function o(l, f, v) { var S = u(256 * l, 256 * (f = Math.pow(2, v) - f - 1), v), D = u(256 * (l + 1), 256 * (f + 1), v); return S[0] + "," + S[1] + "," + D[0] + "," + D[1]; } function u(l, f, v) { var S = 2 * Math.PI * 6378137 / 256 / Math.pow(2, v); return [l * S - 2 * Math.PI * 6378137 / 2, f * S - 2 * Math.PI * 6378137 / 2]; } n.getURL = function(l, f, v, S, D, x) { return x = x || {}, l + "?" + ["bbox=" + o(v, S, D), "format=" + (x.format || "image/png"), "service=" + (x.service || "WMS"), "version=" + (x.version || "1.1.1"), "request=" + (x.request || "GetMap"), "srs=" + (x.srs || "EPSG:3857"), "width=" + (x.width || 256), "height=" + (x.height || 256), "layers=" + f].join("&"); }, n.getTileBBox = o, n.getMercCoords = u, Object.defineProperty(n, "__esModule", { value: !0 }); })(e); }(0, _t.exports)), _t.exports); class nt { constructor(e, n, o) { this.z = e, this.x = n, this.y = o, this.key = zt(0, e, e, n, o); } equals(e) { return this.z === e.z && this.x === e.x && this.y === e.y; } url(e, n) { const o = ct.getTileBBox(this.x, this.y, this.z), u = function(l, f, v) { let S, D = ""; for (let x = l; x > 0; x--) S = 1 << x - 1, D += (f & S ? 1 : 0) + (v & S ? 2 : 0); return D; }(this.z, this.x, this.y); return e[(this.x + this.y) % e.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(n === "tms" ? Math.pow(2, this.z) - this.y - 1 : this.y)).replace("{quadkey}", u).replace("{bbox-epsg-3857}", o); } toString() { return `${this.z}/${this.x}/${this.y}`; } } class Lt { constructor(e, n) { this.wrap = e, this.canonical = n, this.key = zt(e, n.z, n.z, n.x, n.y); } } class bt { constructor(e, n, o, u, l) { this.overscaledZ = e, this.wrap = n, this.canonical = new nt(o, +u, +l), this.key = n === 0 && e === o ? this.canonical.key : zt(n, e, o, u, l); } equals(e) { return this.overscaledZ === e.overscaledZ && this.wrap === e.wrap && this.canonical.equals(e.canonical); } scaledTo(e) { const n = this.canonical.z - e; return e > this.canonical.z ? new bt(e, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y) : new bt(e, this.wrap, e, this.canonical.x >> n, this.canonical.y >> n); } calculateScaledKey(e, n = !0) { if (this.overscaledZ === e && n) return this.key; if (e > this.canonical.z) return zt(this.wrap * +n, e, this.canonical.z, this.canonical.x, this.canonical.y); { const o = this.canonical.z - e; return zt(this.wrap * +n, e, e, this.canonical.x >> o, this.canonical.y >> o); } } isChildOf(e) { if (e.wrap !== this.wrap) return !1; const n = this.canonical.z - e.canonical.z; return e.overscaledZ === 0 || e.overscaledZ < this.overscaledZ && e.canonical.z < this.canonical.z && e.canonical.x === this.canonical.x >> n && e.canonical.y === this.canonical.y >> n; } children(e) { if (this.overscaledZ >= e) return [new bt(this.overscaledZ + 1, this.wrap, this.canonical.z, this.canonical.x, this.canonical.y)]; const n = this.canonical.z + 1, o = 2 * this.canonical.x, u = 2 * this.canonical.y; return [new bt(n, this.wrap, n, o, u), new bt(n, this.wrap, n, o + 1, u), new bt(n, this.wrap, n, o, u + 1), new bt(n, this.wrap, n, o + 1, u + 1)]; } isLessThan(e) { return this.wrap < e.wrap || !(this.wrap > e.wrap) && (this.overscaledZ < e.overscaledZ || !(this.overscaledZ > e.overscaledZ) && (this.canonical.x < e.canonical.x || !(this.canonical.x > e.canonical.x) && this.canonical.y < e.canonical.y)); } wrapped() { return new bt(this.overscaledZ, 0, this.canonical.z, this.canonical.x, this.canonical.y); } unwrapTo(e) { return new bt(this.overscaledZ, e, this.canonical.z, this.canonical.x, this.canonical.y); } overscaleFactor() { return Math.pow(2, this.overscaledZ - this.canonical.z); } toUnwrapped() { return new Lt(this.wrap, this.canonical); } toString() { return `${this.overscaledZ}/${this.canonical.x}/${this.canonical.y}`; } } function zt(r, e, n, o, u) { const l = 1 << Math.min(n, 22); let f = l * (u % l) + o % l; return r && n < 22 && (f += l * l * ((r < 0 ? -2 * r - 1 : 2 * r) % (1 << 2 * (22 - n)))), 16 * (32 * f + n) + (e - n); } const Bt = [(r) => { let e = r.canonical.x - 1, n = r.wrap; return e < 0 && (e = (1 << r.canonical.z) - 1, n--), new bt(r.overscaledZ, n, r.canonical.z, e, r.canonical.y); }, (r) => { let e = r.canonical.x + 1, n = r.wrap; return e === 1 << r.canonical.z && (e = 0, n++), new bt(r.overscaledZ, n, r.canonical.z, e, r.canonical.y); }, (r) => new bt(r.overscaledZ, r.wrap, r.canonical.z, r.canonical.x, (r.canonical.y === 0 ? 1 << r.canonical.z : r.canonical.y) - 1), (r) => new bt(r.overscaledZ, r.wrap, r.canonical.z, r.canonical.x, r.canonical.y === (1 << r.canonical.z) - 1 ? 0 : r.canonical.y + 1)]; Ft(nt, "CanonicalTileID"), Ft(bt, "OverscaledTileID", { omit: ["projMatrix", "expandedProjMatrix"] }); const oi = qi([{ type: "Float32", name: "a_globe_pos", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }]), { members: $t } = oi, Xt = qi([{ name: "a_pos_3", components: 3, type: "Int16" }]); var ai = qi([{ name: "a_pos", type: "Int16", components: 2 }]); class zi { constructor(e, n) { this.pos = e, this.dir = n; } intersectsPlane(e, n, o) { const u = De.vec3.dot(n, this.dir); if (Math.abs(u) < 1e-6) return !1; const l = ((e[0] - this.pos[0]) * n[0] + (e[1] - this.pos[1]) * n[1] + (e[2] - this.pos[2]) * n[2]) / u; return o[0] = this.pos[0] + this.dir[0] * l, o[1] = this.pos[1] + this.dir[1] * l, o[2] = this.pos[2] + this.dir[2] * l, !0; } closestPointOnSphere(e, n, o) { if (De.vec3.equals(this.pos, e) || n === 0) return o[0] = o[1] = o[2] = 0, !1; const [u, l, f] = this.dir, v = this.pos[0] - e[0], S = this.pos[1] - e[1], D = this.pos[2] - e[2], x = u * u + l * l + f * f, P = 2 * (v * u + S * l + D * f), I = P * P - 4 * x * (v * v + S * S + D * D - n * n); if (I < 0) { const M = Math.max(-P / 2, 0), C = v + u * M, k = S + l * M, V = D + f * M, U = Math.hypot(C, k, V); return o[0] = C * n / U, o[1] = k * n / U, o[2] = V * n / U, !1; } { const M = (-P - Math.sqrt(I)) / (2 * x); if (M < 0) { const C = Math.hypot(v, S, D); return o[0] = v * n / C, o[1] = S * n / C, o[2] = D * n / C, !1; } return o[0] = v + u * M, o[1] = S + l * M, o[2] = D + f * M, !0; } } } class wi { constructor(e, n, o, u, l) { this.TL = e, this.TR = n, this.BR = o, this.BL = u, this.horizon = l; } static fromInvProjectionMatrix(e, n, o) { const u = [-1, 1, 1], l = [1, 1, 1], f = [1, -1, 1], v = [-1, -1, 1], S = De.vec3.transformMat4(u, u, e), D = De.vec3.transformMat4(l, l, e), x = De.vec3.transformMat4(f, f, e), P = De.vec3.transformMat4(v, v, e); return new wi(S, D, x, P, n / o); } } function mn(r, e, n) { let o = 1 / 0, u = -1 / 0; const l = []; for (const f of r) { De.vec3.sub(l, f, e); const v = De.vec3.dot(l, n); o = Math.min(o, v), u = Math.max(u, v); } return [o, u]; } function Mn(r, e) { let n = !0; for (let o = 0; o < r.planes.length; o++) { const u = r.planes[o]; let l = 0; for (let f = 0; f < e.length; f++) l += De.vec3.dot(u, e[f]) + u[3] >= 0; if (l === 0) return 0; l !== e.length && (n = !1); } return n ? 2 : 1; } function Xi(r, e) { for (const n of r.projections) { const o = mn(e, r.points[0], n.axis); if (n.projection[1] < o[0] || n.projection[0] > o[1]) return 0; } return 1; } function sn(r, e) { let n = 0; const o = [0, 0, 0, 0]; for (let u = 0; u < r.length; u++) o[0] = r[u][0], o[1] = r[u][1], o[2] = r[u][2], o[3] = 1, De.vec4.dot(o, e) >= 0 && n++; return n; } class _i { constructor(e, n) { this.points = e || new Array(8).fill([0, 0, 0]), this.planes = n || new Array(6).fill([0, 0, 0, 0]), this.bounds = Jt.fromPoints(this.points), this.projections = [], this.frustumEdges = [De.vec3.sub([], this.points[2], this.points[3]), De.vec3.sub([], this.points[0], this.points[3]), De.vec3.sub([], this.points[4], this.points[0]), De.vec3.sub([], this.points[5], this.points[1]), De.vec3.sub([], this.points[6], this.points[2]), De.vec3.sub([], this.points[7], this.points[3])]; for (const o of this.frustumEdges) { const u = [0, -o[2], o[1]], l = [o[2], 0, -o[0]]; this.projections.push({ axis: u, projection: mn(this.points, this.points[0], u) }), this.projections.push({ axis: l, projection: mn(this.points, this.points[0], l) }); } } static fromInvProjectionMatrix(e, n, o, u) { const l = Math.pow(2, o), f = [[-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((D) => { const x = De.vec4.transformMat4([], D, e), P = 1 / x[3] / n * l; return De.vec4.mul(x, x, [P, P, u ? 1 / x[3] : P, P]); }), v = [[0, 1, 2], [6, 5, 4], [0, 3, 7], [2, 1, 5], [3, 2, 6], [0, 4, 5]].map((D) => { const x = De.vec3.sub([], f[D[0]], f[D[1]]), P = De.vec3.sub([], f[D[2]], f[D[1]]), I = De.vec3.normalize([], De.vec3.cross([], x, P)), M = -De.vec3.dot(I, f[D[1]]); return I.concat(M); }), S = []; for (let D = 0; D < f.length; D++) S.push([f[D][0], f[D][1], f[D][2]]); return new _i(S, v); } intersectsPrecise(e, n, o) { for (let u = 0; u < n.length; u++) if (!sn(e, n[u])) return 0; for (let u = 0; u < this.planes.length; u++) if (!sn(e, this.planes[u])) return 0; for (const u of o) for (const l of this.frustumEdges) { const f = De.vec3.cross([], u, l), v = De.vec3.length(f); if (v === 0) continue; De.vec3.scale(f, f, 1 / v); const S = mn(this.points, this.points[0], f), D = mn(e, this.points[0], f); if (S[0] > D[1] || D[0] > S[1]) return 0; } return 1; } containsPoint(e) { for (const n of this.planes) { const o = n[3]; if (De.vec3.dot([n[0], n[1], n[2]], e) + o < 0) return !1; } return !0; } } class Jt { static fromPoints(e) { const n = [1 / 0, 1 / 0, 1 / 0], o = [-1 / 0, -1 / 0, -1 / 0]; for (const u of e) De.vec3.min(n, n, u), De.vec3.max(o, o, u); return new Jt(n, o); } static fromTileIdAndHeight(e, n, o) { const u = 1 << e.canonical.z, l = e.canonical.x, f = e.canonical.y; return new Jt([l / u, f / u, n], [(l + 1) / u, (f + 1) / u, o]); } static applyTransform(e, n) { const o = e.getCorners(); for (let u = 0; u < o.length; ++u) De.vec3.transformMat4(o[u], o[u], n); return Jt.fromPoints(o); } static applyTransformFast(e, n) { const o = [n[12], n[13], n[14]], u = [...o]; for (let l = 0; l < 3; l++) for (let f = 0; f < 3; f++) { const v = n[4 * f + l], S = v * e.min[f], D = v * e.max[f]; o[l] += Math.min(S, D), u[l] += Math.max(S, D); } return new Jt(o, u); } static projectAabbCorners(e, n) { const o = e.getCorners(); for (let u = 0; u < o.length; ++u) De.vec3.transformMat4(o[u], o[u], n); return o; } constructor(e, n) { this.min = e, this.max = n, this.center = De.vec3.scale([], De.vec3.add([], this.min, this.max), 0.5); } quadrant(e) { const n = [e % 2 == 0, e < 2], o = De.vec3.clone(this.min), u = De.vec3.clone(this.max); for (let l = 0; l < n.length; l++) o[l] = n[l] ? this.min[l] : this.center[l], u[l] = n[l] ? this.center[l] : this.max[l]; return u[2] = this.max[2], new Jt(o, u); } distanceX(e) { return Math.max(Math.min(this.max[0], e[0]), this.min[0]) - e[0]; } distanceY(e) { return Math.max(Math.min(this.max[1], e[1]), this.min[1]) - e[1]; } distanceZ(e) { return Math.max(Math.min(this.max[2], e[2]), this.min[2]) - e[2]; } getCorners() { const e = this.min, n = this.max; return [[e[0], e[1], e[2]], [n[0], e[1], e[2]], [n[0], n[1], e[2]], [e[0], n[1], e[2]], [e[0], e[1], n[2]], [n[0], e[1], n[2]], [n[0], n[1], n[2]], [e[0], n[1], n[2]]]; } intersects(e) { return this.intersectsAabb(e.bounds) ? Mn(e, this.getCorners()) : 0; } intersectsFlat(e) { return this.intersectsAabb(e.bounds) ? Mn(e, [[this.min[0], this.min[1], 0], [this.max[0], this.min[1], 0], [this.max[0], this.max[1], 0], [this.min[0], this.max[1], 0]]) : 0; } intersectsPrecise(e, n) { return n || this.intersects(e) ? Xi(e, this.getCorners()) : 0; } intersectsPreciseFlat(e, n) { return n || this.intersectsFlat(e) ? Xi(e, [[this.min[0], this.min[1], 0], [this.max[0], this.min[1], 0], [this.max[0], this.max[1], 0], [this.min[0], this.max[1], 0]]) : 0; } intersectsAabb(e) { for (let n = 0; n < 3; ++n) if (this.min[n] > e.max[n] || e.min[n] > this.max[n]) return !1; return !0; } intersectsAabbXY(e) { return !(this.min[0] > e.max[0] || e.min[0] > this.max[0] || this.min[1] > e.max[1] || e.min[1] > this.max[1]); } encapsulate(e) { for (let n = 0; n < 3; n++) this.min[n] = Math.min(this.min[n], e.min[n]), this.max[n] = Math.max(this.max[n], e.max[n]); } encapsulatePoint(e) { for (let n = 0; n < 3; n++) this.min[n] = Math.min(this.min[n], e[n]), this.max[n] = Math.max(this.max[n], e[n]); } closestPoint(e) { return [Math.max(Math.min(this.max[0], e[0]), this.min[0]), Math.max(Math.min(this.max[1], e[1]), this.min[1]), Math.max(Math.min(this.max[2], e[2]), this.min[2])]; } } function ji(r) { return r * dr / _c; } Ft(Jt, "Aabb"); const Yi = [new Jt([uo, uo, uo], [fo, fo, fo]), new Jt([uo, uo, uo], [0, 0, fo]), new Jt([0, uo, uo], [fo, 0, fo]), new Jt([uo, 0, uo], [0, fo, fo]), new Jt([0, 0, uo], [fo, fo, fo])]; function In(r, e, n, o = !0) { const u = De.vec3.scale([], r._camera.position, r.worldSize), l = [e, n, 1, 1]; De.vec4.transformMat4(l, l, r.pixelMatrixInverse), De.vec4.scale(l, l, 1 / l[3]); const f = De.vec3.sub([], l, u), v = De.vec3.normalize([], f), S = r.globeMatrix, D = [S[12], S[13], S[14]], x = De.vec3.sub([], D, u), P = De.vec3.length(x), I = De.vec3.normalize([], x), M = r.worldSize / (2 * Math.PI), C = De.vec3.dot(I, v), k = Math.asin(M / P); if (k < Math.acos(C)) { if (!o) return null; const Se = [], me = []; De.vec3.scale(Se, v, P / C), De.vec3.normalize(me, De.vec3.sub(me, Se, x)), De.vec3.normalize(v, De.vec3.add(v, x, De.vec3.scale(v, me, Math.tan(k) * P))); } const V = []; new zi(u, v).closestPointOnSphere(D, M, V); const U = De.vec3.normalize([], zs(S, 0)), q = De.vec3.normalize([], zs(S, 1)), $ = De.vec3.normalize([], zs(S, 2)), H = De.vec3.dot(U, V), K = De.vec3.dot(q, V), Q = De.vec3.dot($, V), ie = kn(Math.asin(-K / M)); let fe = kn(Math.atan2(H, Q)); fe = r.center.lng + function(Se, me) { const Ee = (me - Se + 180) % 360 - 180; return Ee < -180 ? Ee + 360 : Ee; }(r.center.lng, fe); const de = ta(fe), ue = si(Ta(ie), 0, 1); return new h(de, ue); } class Fs { constructor(e, n, o) { this.a = De.vec3.sub([], e, o), this.b = De.vec3.sub([], n, o), this.center = o; const u = De.vec3.normalize([], this.a), l = De.vec3.normalize([], this.b); this.angle = Math.acos(De.vec3.dot(u, l)); } } function pr(r, e) { if (r.angle === 0) return null; let n; return n = r.a[e] === 0 ? 1 / r.angle * 0.5 * Math.PI : 1 / r.angle * Math.atan(r.b[e] / r.a[e] / Math.sin(r.angle) - 1 / Math.tan(r.angle)), n < 0 || n > 1 ? null : function(o, u, l, f) { const v = Math.sin(l); return o * (Math.sin((1 - f) * l) / v) + u * (Math.sin(f * l) / v); }(r.a[e], r.b[e], r.angle, si(n, 0, 1)) + r.center[e]; } function ts(r) { if (r.z <= 1) return Yi[r.z + 2 * r.y + r.x]; const e = _n(dn(r)); return Jt.fromPoints(e); } function Ps(r, e, n) { return De.vec3.scale(r, r, 1 - n), De.vec3.scaleAndAdd(r, r, e, n); } function Qs(r, e, n) { for (const o of r) De.vec3.transformMat4(o, o, e), De.vec3.scale(o, o, n); } function jn(r, e, n, o) { const u = e / r.worldSize, l = r.globeMatrix; if (n.z <= 1) { const de = ts(n).getCorners(); return Qs(de, l, u), Jt.fromPoints(de); } const f = dn(n, o), v = _n(f, dr + ji(r._tileCoverLift)); Qs(v, l, u); const S = Number.MAX_VALUE, D = [-S, -S, -S], x = [S, S, S]; if (f.contains(r.center)) { for (const Se of v) De.vec3.min(x, x, Se), De.vec3.max(D, D, Se); D[2] = 0; const de = r.point, ue = [de.x * u, de.y * u, 0]; return De.vec3.min(x, x, ue), De.vec3.max(D, D, ue), new Jt(x, D); } if (r._tileCoverLift > 0) { for (const de of v) De.vec3.min(x, x, de), De.vec3.max(D, D, de); return new Jt(x, D); } const P = [l[12] * u, l[13] * u, l[14] * u], I = f.getCenter(), M = si(r.center.lat, -Un, Un), C = si(I.lat, -Un, Un), k = ta(r.center.lng), V = Ta(M); let U = k - ta(I.lng); const q = V - Ta(C); U > 0.5 ? U -= 1 : U < -0.5 && (U += 1); let $ = 0; if (Math.abs(U) > Math.abs(q)) $ = U >= 0 ? 1 : 3; else { $ = q >= 0 ? 0 : 2; const de = [l[4] * u, l[5] * u, l[6] * u], ue = -Math.sin(vi(q >= 0 ? f.getSouth() : f.getNorth())) * dr; De.vec3.scaleAndAdd(P, P, de, ue); } const H = v[$], K = v[($ + 1) % 4], Q = new Fs(H, K, P), ie = [pr(Q, 0) || H[0], pr(Q, 1) || H[1], pr(Q, 2) || H[2]], fe = mr(r.zoom); if (fe > 0) { const de = function({ x: Se, y: me, z: Ee }, ze, Ie, Re, Ve) { const Ue = 1 / (1 << Ee); let Fe = Se * Ue, et = Fe + Ue, dt = me * Ue, tt = dt + Ue, Mt = 0; const wt = (Fe + et) / 2 - Re; return wt > 0.5 ? Mt = -1 : wt < -0.5 && (Mt = 1), Fe = ((Fe + Mt) * ze - (Re *= ze)) * Ie + Re, et = ((et + Mt) * ze - Re) * Ie + Re, dt = (dt * ze - (Ve *= ze)) * Ie + Ve, tt = (tt * ze - Ve) * Ie + Ve, [[Fe, tt, 0], [et, tt, 0], [et, dt, 0], [Fe, dt, 0]]; }(n, e, r._pixelsPerMercatorPixel, k, V); for (let Se = 0; Se < v.length; Se++) Ps(v[Se], de[Se], fe); const ue = De.vec3.add([], de[$], de[($ + 1) % 4]); De.vec3.scale(ue, ue, 0.5), Ps(ie, ue, fe); } for (const de of v) De.vec3.min(x, x, de), De.vec3.max(D, D, de); return x[2] = Math.min(H[2], K[2]), De.vec3.min(x, x, ie), De.vec3.max(D, D, ie), new Jt(x, D); } function dn({ x: r, y: e, z: n }, o = !1) { const u = 1 / (1 << n), l = new Ui(Fr(r * u), e === (1 << n) - 1 && o ? -90 : Os((e + 1) * u)), f = new Ui(Fr((r + 1) * u), e === 0 && o ? 90 : Os(e * u)); return new tl(l, f); } function _n(r, e = dr) { const n = vi(r.getNorth()), o = vi(r.getSouth()), u = Math.cos(n), l = Math.cos(o), f = Math.sin(n), v = Math.sin(o), S = r.getWest(), D = r.getEast(); return [mc(l, v, S, e), mc(l, v, D, e), mc(u, f, D, e), mc(u, f, S, e)]; } function Ri(r, e, n, o) { const u = 1 << n.z, l = (r / Tt + n.x) / u; return el(Os((e / Tt + n.y) / u), Fr(l), o); } function Gn({ min: r, max: e }) { return yp / Math.max(e[0] - r[0], e[1] - r[1], e[2] - r[2]); } const Bs = new Float64Array(16); function cn(r) { const e = Gn(r), n = De.mat4.fromScaling(Bs, [e, e, e]); return De.mat4.translate(n, n, De.vec3.negate([], r.min)); } function er(r) { const e = De.mat4.fromTranslation(Bs, r.min), n = 1 / Gn(r); return De.mat4.scale(e, e, [n, n, n]); } function eo(r) { const e = Tt / (2 * Math.PI); return r / (2 * Math.PI) / e; } function Br(r, e) { return Tt / (512 * Math.pow(2, r)) * Gn(ts(e)); } function Ma(r, e, n, o, u) { const l = eo(n), f = [r, e, -n / (2 * Math.PI)], v = De.mat4.identity(new Float64Array(16)); return De.mat4.translate(v, v, f), De.mat4.scale(v, v, [l, l, l]), De.mat4.rotateX(v, v, vi(-u)), De.mat4.rotateY(v, v, vi(-o)), v; } function mr(r) { return fs(Su, gp, r); } function ko(r, e) { const n = el(e.lat, e.lng), o = function(l) { const f = el(l._center.lat, l._center.lng), v = De.vec3.fromValues(0, 1, 0); let S = De.vec3.cross([], v, f); const D = De.mat4.fromRotation([], -l.angle, f); S = De.vec3.transformMat4(S, S, D), De.mat4.fromRotation(D, -l._pitch, S); const x = De.vec3.normalize([], f); return De.vec3.scale(x, x, ji(l.cameraToCenterDistance / l.pixelsPerMeter)), De.vec3.transformMat4(x, x, D), De.vec3.add([], f, x); }(r), u = De.vec3.subtract([], o, n); return De.vec3.angle(u, n); } function Nr(r, e) { return ko(r, e) > Math.PI / 2 * 1.01; } const il = vi(85), ia = Math.cos(il), Ll = Math.sin(il), yh = De.mat4.create(), Pu = (r) => { const e = []; return r.paint.get("circle-pitch-alignment") === "map" && e.push("PITCH_WITH_MAP"), r.paint.get("circle-pitch-scale") === "map" && e.push("SCALE_WITH_MAP"), e; }; function Au(r, e, n, o, u, l, f, v, S) { if (l && r.queryGeometry.isAboveHorizon) return !1; l && (S *= r.pixelToTileUnitsFactor); const D = r.tileID.canonical, x = n.projection.upVectorScale(D, n.center.lat, n.worldSize).metersToTile; for (const P of e) for (const I of P) { const M = I.add(v), C = u && n.elevation ? n.elevation.exaggeration() * u.getElevationAt(M.x, M.y, !0) : 0, k = n.projection.projectTilePoint(M.x, M.y, D); if (C > 0) { const $ = n.projection.upVector(D, M.x, M.y); k.x += $[0] * x * C, k.y += $[1] * x * C, k.z += $[2] * x * C; } const V = l ? M : Ew(k.x, k.y, k.z, o), U = l ? r.tilespaceRays.map(($) => Aw($, C)) : r.queryGeometry.screenGeometry, q = De.vec4.transformMat4([], [k.x, k.y, k.z, 1], o); if (!f && l ? S *= q[3] / n.cameraToCenterDistance : f && !l && (S *= n.cameraToCenterDistance / q[3]), l) { const $ = Os((I.y / Tt + D.y) / (1 << D.z)); S /= n.projection.pixelsPerMeter($, 1) / fr(1, $); } if (oe(U, V, S)) return !0; } return !1; } function Ew(r, e, n, o) { const u = De.vec4.transformMat4([], [r, e, n, 1], o); return new Et(u[0] / u[3], u[1] / u[3]); } const My = De.vec3.fromValues(0, 0, 0), Pw = De.vec3.fromValues(0, 0, 1); function Aw(r, e) { const n = De.vec3.create(); return My[2] = e, r.intersectsPlane(My, Pw, n), new Et(n[0], n[1]); } class Sy extends ee { } let Ey, Py, Ay, Cy; function Iy(r, { width: e, height: n }, o, u) { if (u) { if (u instanceof Uint8ClampedArray) u = new Uint8Array(u.buffer); else if (u.length !== e * n * o) throw new RangeError("mismatched image size"); } else u = new Uint8Array(e * n * o); return r.width = e, r.height = n, r.data = u, r; } function Ly(r, e, n) { const { width: o, height: u } = e; o === r.width && u === r.height || (m_(r, e, { x: 0, y: 0 }, { x: 0, y: 0 }, { width: Math.min(r.width, o), height: Math.min(r.height, u) }, n, null), r.width = o, r.height = u, r.data = e.data); } function m_(r, e, n, o, u, l, f, v) { if (u.width === 0 || u.height === 0) return e; if (u.width > r.width || u.height > r.height || n.x > r.width - u.width || n.y > r.height - u.height) throw new RangeError("out of range source coordinates for image copy"); if (u.width > e.width || u.height > e.height || o.x > e.width - u.width || o.y > e.height - u.height) throw new RangeError("out of range destination coordinates for image copy"); const S = r.data, D = e.data, x = l === 4 && v; for (let P = 0; P < u.height; P++) { const I = ((n.y + P) * r.width + n.x) * l, M = ((o.y + P) * e.width + o.x) * l; if (x) for (let C = 0; C < u.width; C++) { const k = I + C * l + 3, V = M + C * l; D[V + 0] = 255, D[V + 1] = 255, D[V + 2] = 255, D[V + 3] = S[k]; } else if (f) for (let C = 0; C < u.width; C++) { const k = I + C * l, V = M + C * l, U = S[k + 3], q = new ki(S[k + 0] / 255 * U, S[k + 1] / 255 * U, S[k + 2] / 255 * U, U).toRenderColor(f).toArray(); D[V + 0] = q[0], D[V + 1] = q[1], D[V + 2] = q[2], D[V + 3] = q[3]; } else for (let C = 0; C < u.width * l; C++) D[M + C] = S[I + C]; } return e; } Ft(Sy, "HeatmapBucket", { omit: ["layers"] }); class gc { constructor(e, n) { Iy(this, e, 1, n); } resize(e) { Ly(this, new gc(e), 1); } clone() { return new gc({ width: this.width, height: this.height }, new Uint8Array(this.data)); } static copy(e, n, o, u, l) { m_(e, n, o, u, l, 1, null); } } class _r { constructor(e, n) { Iy(this, e, 4, n); } resize(e) { Ly(this, new _r(e), 4); } replace(e, n) { n ? this.data.set(e) : this.data = e instanceof Uint8ClampedArray ? new Uint8Array(e.buffer) : e; } clone() { return new _r({ width: this.width, height: this.height }, new Uint8Array(this.data)); } static copy(e, n, o, u, l, f, v) { m_(e, n, o, u, l, 4, f, v); } } class zy { constructor(e, n) { this.width = e.width, this.height = e.height, this.data = n instanceof Uint8Array ? new Float32Array(n.buffer) : n; } } function Bd(r) { const e = {}, n = r.resolution || 256, o = r.clips ? r.clips.length : 1, u = r.image || new _r({ width: n, height: o }), l = (f, v, S) => { e[r.evaluationKey] = S; const D = r.expression.evaluate(e); D && (u.data[f + v + 0] = Math.floor(255 * D.r / D.a), u.data[f + v + 1] = Math.floor(255 * D.g / D.a), u.data[f + v + 2] = Math.floor(255 * D.b / D.a), u.data[f + v + 3] = Math.floor(255 * D.a)); }; if (r.clips) for (let f = 0, v = 0; f < o; ++f, v += 4 * n) for (let S = 0, D = 0; S < n; S++, D += 4) { const x = S / (n - 1), { start: P, end: I } = r.clips[f]; l(v, D, P * (1 - x) + I * x); } else for (let f = 0, v = 0; f < n; f++, v += 4) l(0, v, f / (n - 1)); return u; } Ft(gc, "AlphaImage"), Ft(_r, "RGBAImage"); const Cw = qi([{ name: "a_pos", components: 2, type: "Int16" }], 4), { members: Iw } = Cw; function Nd(r, e, n = 2) { const o = e && e.length, u = o ? e[0] * n : r.length; let l = Dy(r, 0, u, n, !0); const f = []; if (!l || l.next === l.prev) return f; let v, S, D; if (o && (l = function(x, P, I, M) { const C = []; for (let k = 0, V = P.length; k < V; k++) { const U = Dy(x, P[k] * M, k < V - 1 ? P[k + 1] * M : x.length, M, !1); U === U.next && (U.steiner = !0), C.push(Bw(U)); } C.sort(Rw); for (let k = 0; k < C.length; k++) I = Ow(C[k], I); return I; }(r, e, l, n)), r.length > 80 * n) { v = 1 / 0, S = 1 / 0; let x = -1 / 0, P = -1 / 0; for (let I = n; I < u; I += n) { const M = r[I], C = r[I + 1]; M < v && (v = M), C < S && (S = C), M > x && (x = M), C > P && (P = C); } D = Math.max(x - v, P - S), D = D !== 0 ? 32767 / D : 0; } return Vd(l, f, n, v, S, D, 0), f; } function Dy(r, e, n, o, u) { let l; if (u === function(f, v, S, D) { let x = 0; for (let P = v, I = S - D; P < S; P += D) x += (f[I] - f[P]) * (f[P + 1] + f[I + 1]), I = P; return x; }(r, e, n, o) > 0) for (let f = e; f < n; f += o) l = Oy(f / o | 0, r[f], r[f + 1], l); else for (let f = n - o; f >= e; f -= o) l = Oy(f / o | 0, r[f], r[f + 1], l); return l && bp(l, l.next) && (jd(l), l = l.next), l; } function xh(r, e) { if (!r) return r; e || (e = r); let n, o = r; do if (n = !1, o.steiner || !bp(o, o.next) && Ts(o.prev, o, o.next) !== 0) o = o.next; else { if (jd(o), o = e = o.prev, o === o.next) break; n = !0; } while (n || o !== e); return e; } function Vd(r, e, n, o, u, l, f) { if (!r) return; !f && l && function(S, D, x, P) { let I = S; do I.z === 0 && (I.z = __(I.x, I.y, D, x, P)), I.prevZ = I.prev, I.nextZ = I.next, I = I.next; while (I !== S); I.prevZ.nextZ = null, I.prevZ = null, function(M) { let C, k = 1; do { let V, U = M; M = null; let q = null; for (C = 0; U; ) { C++; let $ = U, H = 0; for (let Q = 0; Q < k && (H++, $ = $.nextZ, $); Q++) ; let K = k; for (; H > 0 || K > 0 && $; ) H !== 0 && (K === 0 || !$ || U.z <= $.z) ? (V = U, U = U.nextZ, H--) : (V = $, $ = $.nextZ, K--), q ? q.nextZ = V : M = V, V.prevZ = q, q = V; U = $; } q.nextZ = null, k *= 2; } while (C > 1); }(I); }(r, o, u, l); let v = r; for (; r.prev !== r.next; ) { const S = r.prev, D = r.next; if (l ? zw(r, o, u, l) : Lw(r)) e.push(S.i, r.i, D.i), jd(r), r = D.next, v = D.next; else if ((r = D) === v) { f ? f === 1 ? Vd(r = Dw(xh(r), e), e, n, o, u, l, 2) : f === 2 && kw(r, e, n, o, u, l) : Vd(xh(r), e, n, o, u, l, 1); break; } } } function Lw(r) { const e = r.prev, n = r, o = r.next; if (Ts(e, n, o) >= 0) return !1; const u = e.x, l = n.x, f = o.x, v = e.y, S = n.y, D = o.y, x = u < l ? u < f ? u : f : l < f ? l : f, P = v < S ? v < D ? v : D : S < D ? S : D, I = u > l ? u > f ? u : f : l > f ? l : f, M = v > S ? v > D ? v : D : S > D ? S : D; let C = o.next; for (; C !== e; ) { if (C.x >= x && C.x <= I && C.y >= P && C.y <= M && Cu(u, v, l, S, f, D, C.x, C.y) && Ts(C.prev, C, C.next) >= 0) return !1; C = C.next; } return !0; } function zw(r, e, n, o) { const u = r.prev, l = r, f = r.next; if (Ts(u, l, f) >= 0) return !1; const v = u.x, S = l.x, D = f.x, x = u.y, P = l.y, I = f.y, M = v < S ? v < D ? v : D : S < D ? S : D, C = x < P ? x < I ? x : I : P < I ? P : I, k = v > S ? v > D ? v : D : S > D ? S : D, V = x > P ? x > I ? x : I : P > I ? P : I, U = __(M, C, e, n, o), q = __(k, V, e, n, o); let $ = r.prevZ, H = r.nextZ; for (; $ && $.z >= U && H && H.z <= q; ) { if ($.x >= M && $.x <= k && $.y >= C && $.y <= V && $ !== u && $ !== f && Cu(v, x, S, P, D, I, $.x, $.y) && Ts($.prev, $, $.next) >= 0 || ($ = $.prevZ, H.x >= M && H.x <= k && H.y >= C && H.y <= V && H !== u && H !== f && Cu(v, x, S, P, D, I, H.x, H.y) && Ts(H.prev, H, H.next) >= 0)) return !1; H = H.nextZ; } for (; $ && $.z >= U; ) { if ($.x >= M && $.x <= k && $.y >= C && $.y <= V && $ !== u && $ !== f && Cu(v, x, S, P, D, I, $.x, $.y) && Ts($.prev, $, $.next) >= 0) return !1; $ = $.prevZ; } for (; H && H.z <= q; ) { if (H.x >= M && H.x <= k && H.y >= C && H.y <= V && H !== u && H !== f && Cu(v, x, S, P, D, I, H.x, H.y) && Ts(H.prev, H, H.next) >= 0) return !1; H = H.nextZ; } return !0; } function Dw(r, e) { let n = r; do { const o = n.prev, u = n.next.next; !bp(o, u) && ky(o, n, n.next, u) && Ud(o, u) && Ud(u, o) && (e.push(o.i, n.i, u.i), jd(n), jd(n.next), n = r = u), n = n.next; } while (n !== r); return xh(n); } function kw(r, e, n, o, u, l) { let f = r; do { let v = f.next.next; for (; v !== f.prev; ) { if (f.i !== v.i && Nw(f, v)) { let S = Ry(f, v); return f = xh(f, f.next), S = xh(S, S.next), Vd(f, e, n, o, u, l, 0), void Vd(S, e, n, o, u, l, 0); } v = v.next; } f = f.next; } while (f !== r); } function Rw(r, e) { return r.x - e.x; } function Ow(r, e) { const n = function(u, l) { let f = l; const v = u.x, S = u.y; let D, x = -1 / 0; do { if (S <= f.y && S >= f.next.y && f.next.y !== f.y) { const k = f.x + (S - f.y) * (f.next.x - f.x) / (f.next.y - f.y); if (k <= v && k > x && (x = k, D = f.x < f.next.x ? f : f.next, k === v)) return D; } f = f.next; } while (f !== l); if (!D) return null; const P = D, I = D.x, M = D.y; let C = 1 / 0; f = D; do { if (v >= f.x && f.x >= I && v !== f.x && Cu(S < M ? v : x, S, I, M, S < M ? x : v, S, f.x, f.y)) { const k = Math.abs(S - f.y) / (v - f.x); Ud(f, u) && (k < C || k === C && (f.x > D.x || f.x === D.x && Fw(D, f))) && (D = f, C = k); } f = f.next; } while (f !== P); return D; }(r, e); if (!n) return e; const o = Ry(n, r); return xh(o, o.next), xh(n, n.next); } function Fw(r, e) { return Ts(r.prev, r, e.prev) < 0 && Ts(e.next, r, r.next) < 0; } function __(r, e, n, o, u) { return (r = 1431655765 & ((r = 858993459 & ((r = 252645135 & ((r = 16711935 & ((r = (r - n) * u | 0) | r << 8)) | r << 4)) | r << 2)) | r << 1)) | (e = 1431655765 & ((e = 858993459 & ((e = 252645135 & ((e = 16711935 & ((e = (e - o) * u | 0) | e << 8)) | e << 4)) | e << 2)) | e << 1)) << 1; } function Bw(r) { let e = r, n = r; do (e.x < n.x || e.x === n.x && e.y < n.y) && (n = e), e = e.next; while (e !== r); return n; } function Cu(r, e, n, o, u, l, f, v) { return (u - f) * (e - v) >= (r - f) * (l - v) && (r - f) * (o - v) >= (n - f) * (e - v) && (n - f) * (l - v) >= (u - f) * (o - v); } function Nw(r, e) { return r.next.i !== e.i && r.prev.i !== e.i && !function(n, o) { let u = n; do { if (u.i !== n.i && u.next.i !== n.i && u.i !== o.i && u.next.i !== o.i && ky(u, u.next, n, o)) return !0; u = u.next; } while (u !== n); return !1; }(r, e) && (Ud(r, e) && Ud(e, r) && function(n, o) { let u = n, l = !1; const f = (n.x + o.x) / 2, v = (n.y + o.y) / 2; do u.y > v != u.next.y > v && u.next.y !== u.y && f < (u.next.x - u.x) * (v - u.y) / (u.next.y - u.y) + u.x && (l = !l), u = u.next; while (u !== n); return l; }(r, e) && (Ts(r.prev, r, e.prev) || Ts(r, e.prev, e)) || bp(r, e) && Ts(r.prev, r, r.next) > 0 && Ts(e.prev, e, e.next) > 0); } function Ts(r, e, n) { return (e.y - r.y) * (n.x - e.x) - (e.x - r.x) * (n.y - e.y); } function bp(r, e) { return r.x === e.x && r.y === e.y; } function ky(r, e, n, o) { const u = Tp(Ts(r, e, n)), l = Tp(Ts(r, e, o)), f = Tp(Ts(n, o, r)), v = Tp(Ts(n, o, e)); return u !== l && f !== v || !(u !== 0 || !wp(r, n, e)) || !(l !== 0 || !wp(r, o, e)) || !(f !== 0 || !wp(n, r, o)) || !(v !== 0 || !wp(n, e, o)); } function wp(r, e, n) { return e.x <= Math.max(r.x, n.x) && e.x >= Math.min(r.x, n.x) && e.y <= Math.max(r.y, n.y) && e.y >= Math.min(r.y, n.y); } function Tp(r) { return r > 0 ? 1 : r < 0 ? -1 : 0; } function Ud(r, e) { return Ts(r.prev, r, r.next) < 0 ? Ts(r, e, r.next) >= 0 && Ts(r, r.prev, e) >= 0 : Ts(r, e, r.prev) < 0 || Ts(r, r.next, e) < 0; } function Ry(r, e) { const n = g_(r.i, r.x, r.y), o = g_(e.i, e.x, e.y), u = r.next, l = e.prev; return r.next = e, e.prev = r, n.next = u, u.prev = n, o.next = n, n.prev = o, l.next = o, o.prev = l, o; } function Oy(r, e, n, o) { const u = g_(r, e, n); return o ? (u.next = o.next, u.prev = o, o.next.prev = u, o.next = u) : (u.prev = u, u.next = u), u; } function jd(r) { r.next.prev = r.prev, r.prev.next = r.next, r.prevZ && (r.prevZ.nextZ = r.nextZ), r.nextZ && (r.nextZ.prevZ = r.prevZ); } function g_(r, e, n) { return { i: r, x: e, y: n, prev: null, next: null, z: 0, prevZ: null, nextZ: null, steiner: !1 }; } function Mp(r, e) { const n = r.length; if (n <= 1) return [r]; const o = []; let u, l; for (let f = 0; f < n; f++) { const v = Vn(r[f]); v !== 0 && (r[f].area = Math.abs(v), l === void 0 && (l = v < 0), l === v < 0 ? (u && o.push(u), u = [r[f]]) : u.push(r[f])); } if (u && o.push(u), e > 1) for (let f = 0; f < o.length; f++) o[f].length <= e || (Nh(o[f], e, 1, o[f].length - 1, Vw), o[f] = o[f].slice(0, e)); return o; } function Vw(r, e) { return e.area - r.area; } function Fy(r, e) { if (!r) return null; const n = typeof r == "string" ? r : r.getPrimary().id; e[n] || (e[n] = []); const o = ss.from(r).getPrimary(); return e[n].push(o), o.serialize(); } function y_(r, e, n) { const o = n.patternDependencies; let u = !1; for (const l of e) { const f = l.paint.get(`${r}-pattern`); f.isConstant() || (u = !0), Fy(f.constantOr(null), o) && (u = !0); } return u; } function x_(r, e, n, o, u) { const l = u.patternDependencies; for (const f of e) { const v = f.paint.get(`${r}-pattern`).value; if (v.kind !== "constant") { let S = v.evaluate({ zoom: o }, n, {}, u.availableImages); S = S && S.name ? S.name : S; const D = Fy(S, l); D && (n.patterns[f.id] = D); } } return n; } class v_ { constructor(e) { this.zoom = e.zoom, this.overscaling = e.overscaling, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.index = e.index, this.hasPattern = !1, this.patternFeatures = [], this.layoutVertexArray = new Lo(), this.indexArray = new qs(), this.indexArray2 = new Ka(), this.programConfigurations = new Qa(e.layers, { zoom: e.zoom, lut: e.lut }), this.segments = new Wn(), this.segments2 = new Wn(), this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id), this.projection = e.projection; } updateFootprints(e, n) { } populate(e, n, o, u) { this.hasPattern = y_("fill", this.layers, n); const l = this.layers[0].layout.get("fill-sort-key"), f = []; for (const { feature: v, id: S, index: D, sourceLayerIndex: x } of e) { const P = this.layers[0]._featureFilter.needGeometry, I = Z(v, P); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), I, o)) continue; const M = l ? l.evaluate(I, {}, o, n.availableImages) : void 0, C = { id: S, properties: v.properties, type: v.type, sourceLayerIndex: x, index: D, geometry: P ? I.geometry : G(v, o, u), patterns: {}, sortKey: M }; f.push(C); } l && f.sort((v, S) => v.sortKey - S.sortKey); for (const v of f) { const { geometry: S, index: D, sourceLayerIndex: x } = v; if (this.hasPattern) { const P = x_("fill", this.layers, v, this.zoom, n); this.patternFeatures.push(P); } else this.addFeature(v, S, D, o, {}, n.availableImages, n.brightness); n.featureIndex.insert(e[D].feature, S, D, x, this.index); } } update(e, n, o, u, l, f, v) { this.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v); } addFeatures(e, n, o, u, l, f) { for (const v of this.patternFeatures) this.addFeature(v, v.geometry, v.index, n, o, u, f); } isEmpty() { return this.layoutVertexArray.length === 0; } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload; } upload(e) { this.uploaded || (this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, Iw), this.indexBuffer = e.createIndexBuffer(this.indexArray), this.indexBuffer2 = e.createIndexBuffer(this.indexArray2)), this.programConfigurations.upload(e), 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(e, n, o, u, l, f = [], v) { for (const S of Mp(n, 500)) { let D = 0; for (const k of S) D += k.length; const x = this.segments.prepareSegment(D, this.layoutVertexArray, this.indexArray), P = x.vertexLength, I = [], M = []; for (const k of S) { if (k.length === 0) continue; k !== S[0] && M.push(I.length / 2); const V = this.segments2.prepareSegment(k.length, this.layoutVertexArray, this.indexArray2), U = V.vertexLength; this.layoutVertexArray.emplaceBack(k[0].x, k[0].y), this.indexArray2.emplaceBack(U + k.length - 1, U), I.push(k[0].x), I.push(k[0].y); for (let q = 1; q < k.length; q++) this.layoutVertexArray.emplaceBack(k[q].x, k[q].y), this.indexArray2.emplaceBack(U + q - 1, U + q), I.push(k[q].x), I.push(k[q].y); V.vertexLength += k.length, V.primitiveLength += k.length; } const C = Nd(I, M); for (let k = 0; k < C.length; k += 3) this.indexArray.emplaceBack(P + C[k], P + C[k + 1], P + C[k + 2]); x.vertexLength += D, x.primitiveLength += C.length / 3; } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, e, o, l, f, u, v); } } let By, Ny, Vy, Uy; Ft(v_, "FillBucket", { omit: ["layers", "patternFeatures"] }); class b_ { constructor(e, n, o, u) { if (this.triangleCount = n.length / 3, this.min = new Et(0, 0), this.max = new Et(0, 0), this.xScale = 0, this.yScale = 0, this.cellsX = 0, this.cellsY = 0, this.cells = [], this.payload = [], this.triangleCount === 0 || e.length === 0) return; const [l, f] = [e[0].clone(), e[0].clone()]; for (let P = 1; P < e.length; ++P) { const I = e[P]; l.x = Math.min(l.x, I.x), l.y = Math.min(l.y, I.y), f.x = Math.max(f.x, I.x), f.y = Math.max(f.y, I.y); } if (u) { const P = Math.ceil(Math.max(f.x - l.x, f.y - l.y) / u); o = Math.max(o, P); } if (o === 0) return; this.min = l, this.max = f; const v = this.max.sub(this.min); v.x = Math.max(v.x, 1), v.y = Math.max(v.y, 1); const S = Math.max(v.x, v.y) / o; this.cellsX = Math.max(1, Math.ceil(v.x / S)), this.cellsY = Math.max(1, Math.ceil(v.y / S)), this.xScale = 1 / S, this.yScale = 1 / S; const D = []; for (let P = 0; P < this.triangleCount; P++) { const I = e[n[3 * P + 0]].sub(this.min), M = e[n[3 * P + 1]].sub(this.min), C = e[n[3 * P + 2]].sub(this.min), k = nl(Math.floor(Math.min(I.x, M.x, C.x)), this.xScale, this.cellsX), V = nl(Math.floor(Math.max(I.x, M.x, C.x)), this.xScale, this.cellsX), U = nl(Math.floor(Math.min(I.y, M.y, C.y)), this.yScale, this.cellsY), q = nl(Math.floor(Math.max(I.y, M.y, C.y)), this.yScale, this.cellsY), $ = new Et(0, 0), H = new Et(0, 0), K = new Et(0, 0), Q = new Et(0, 0); for (let ie = U; ie <= q; ++ie) { $.y = H.y = ie * S, K.y = Q.y = (ie + 1) * S; for (let fe = k; fe <= V; ++fe) $.x = K.x = fe * S, H.x = Q.x = (fe + 1) * S, (ke(I, M, C, $, H, Q) || ke(I, M, C, $, Q, K)) && D.push({ cellIdx: ie * this.cellsX + fe, triIdx: P }); } } if (D.length === 0) return; D.sort((P, I) => P.cellIdx - I.cellIdx || P.triIdx - I.triIdx); let x = 0; for (; x < D.length; ) { const P = D[x].cellIdx, I = { start: this.payload.length, len: 0 }; for (; x < D.length && D[x].cellIdx === P; ) ++I.len, this.payload.push(D[x++].triIdx); this.cells[P] = I; } } _lazyInitLookup() { this.lookup || (this.lookup = new Uint8Array(Math.ceil(this.triangleCount / 8))), this.lookup.fill(0); } queryPoint(e, n) { if (this.triangleCount === 0 || this.cells.length === 0 || e.x > this.max.x || this.min.x > e.x || e.y > this.max.y || this.min.y > e.y) return; const o = nl(e.x - this.min.x, this.xScale, this.cellsX), u = nl(e.y - this.min.y, this.yScale, this.cellsY), l = this.cells[u * this.cellsX + o]; if (l) { this._lazyInitLookup(); for (let f = 0; f < l.len; f++) { const v = this.payload[l.start + f], S = Math.floor(v / 8), D = 1 << v % 8; if (!(this.lookup[S] & D) && (this.lookup[S] |= D, n.push(v), n.length === this.triangleCount)) return; } } } query(e, n, o) { if (this.triangleCount === 0 || this.cells.length === 0 || e.x > this.max.x || this.min.x > n.x || e.y > this.max.y || this.min.y > n.y) return; this._lazyInitLookup(); const u = nl(e.x - this.min.x, this.xScale, this.cellsX), l = nl(n.x - this.min.x, this.xScale, this.cellsX), f = nl(e.y - this.min.y, this.yScale, this.cellsY), v = nl(n.y - this.min.y, this.yScale, this.cellsY); for (let S = f; S <= v; S++) for (let D = u; D <= l; D++) { const x = this.cells[S * this.cellsX + D]; if (x) for (let P = 0; P < x.len; P++) { const I = this.payload[x.start + P], M = Math.floor(I / 8), C = 1 << I % 8; if (!(this.lookup[M] & C) && (this.lookup[M] |= C, o.push(I), o.length === this.triangleCount)) return; } } } } function nl(r, e, n) { return Math.max(0, Math.min(n - 1, Math.floor(r * e))); } Ft(b_, "TriangleGridIndex"); class jy { constructor(e) { this.zoom = e.zoom, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.index = e.index, this.hasPattern = !1, this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id), this.footprints = []; } updateFootprints(e, n) { for (const o of this.footprints) n.push({ footprint: o, id: e }); } populate(e, n, o, u) { const l = []; for (const { feature: f, id: v, index: S, sourceLayerIndex: D } of e) { const x = this.layers[0]._featureFilter.needGeometry, P = Z(f, x); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), P, o)) continue; const I = { id: v, properties: f.properties, type: f.type, sourceLayerIndex: D, index: S, geometry: x ? P.geometry : G(f, o, u), patterns: {} }; l.push(I); } for (const f of l) { const { geometry: v, index: S, sourceLayerIndex: D } = f; this.addFeature(f, v, S, o, {}, n.availableImages, n.brightness), n.featureIndex.insert(e[S].feature, v, S, D, this.index); } } isEmpty() { return this.footprints.length === 0; } uploadPending() { return !1; } upload(e) { } update(e, n, o, u, l, f, v) { } destroy() { } addFeature(e, n, o, u, l, f = [], v) { for (const S of Mp(n, 2)) { const D = [], x = [], P = [], I = new Et(1 / 0, 1 / 0), M = new Et(-1 / 0, -1 / 0); for (const V of S) if (V.length !== 0) { V !== S[0] && P.push(x.length / 2); for (let U = 0; U < V.length; U++) x.push(V[U].x), x.push(V[U].y), D.push(V[U]), I.x = Math.min(I.x, V[U].x), I.y = Math.min(I.y, V[U].y), M.x = Math.max(M.x, V[U].x), M.y = Math.max(M.y, V[U].y); } const C = Nd(x, P), k = new b_(D, C, 8, 256); this.footprints.push({ vertices: D, indices: C, grid: k, min: I, max: M }); } } } Ft(jy, "ClipBucket", { omit: ["layers"] }); const Uw = qi([{ name: "a_pos_normal_ed", components: 4, type: "Int16" }]), jw = qi([{ name: "a_pos_end", components: 4, type: "Int16" }, { name: "a_angular_offset_factor", components: 1, type: "Int16" }]), Gw = qi([{ name: "a_centroid_pos", components: 2, type: "Uint16" }]), Zw = qi([{ name: "a_join_normal_inside", components: 3, type: "Int16" }]), Hw = qi([{ name: "a_hidden_by_landmark", components: 1, type: "Uint8" }]), qw = qi([{ name: "a_pos_3", components: 3, type: "Int16" }, { name: "a_pos_normal_3", components: 3, type: "Int16" }]), { members: Ww } = Uw; var w_, Gy, T_, Zy, M_, Hy, qy, Sp = {}; function Wy() { if (Gy) return w_; Gy = 1; var r = Zr(); function e(u, l, f, v, S) { this.properties = {}, this.extent = f, this.type = 0, this._pbf = u, this._geometry = -1, this._keys = v, this._values = S, u.readFields(n, this, l); } function n(u, l, f) { u == 1 ? l.id = f.readVarint() : u == 2 ? function(v, S) { for (var D = v.readVarint() + v.pos; v.pos < D; ) { var x = S._keys[v.readVarint()], P = S._values[v.readVarint()]; S.properties[x] = P; } }(f, l) : u == 3 ? l.type = f.readVarint() : u == 4 && (l._geometry = f.pos); } function o(u) { for (var l, f, v = 0, S = 0, D = u.length, x = D - 1; S < D; x = S++) v += ((f = u[x]).x - (l = u[S]).x) * (l.y + f.y); return v; } return w_ = e, e.types = ["Unknown", "Point", "LineString", "Polygon"], e.prototype.loadGeometry = function() { var u = this._pbf; u.pos = this._geometry; for (var l, f = u.readVarint() + u.pos, v = 1, S = 0, D = 0, x = 0, P = []; u.pos < f; ) { if (S <= 0) { var I = u.readVarint(); v = 7 & I, S = I >> 3; } if (S--, v === 1 || v === 2) D += u.readSVarint(), x += u.readSVarint(), v === 1 && (l && P.push(l), l = []), l.push(new r(D, x)); else { if (v !== 7) throw new Error("unknown command " + v); l && l.push(l[0].clone()); } } return l && P.push(l), P; }, e.prototype.bbox = function() { var u = this._pbf; u.pos = this._geometry; for (var l = u.readVarint() + u.pos, f = 1, v = 0, S = 0, D = 0, x = 1 / 0, P = -1 / 0, I = 1 / 0, M = -1 / 0; u.pos < l; ) { if (v <= 0) { var C = u.readVarint(); f = 7 & C, v = C >> 3; } if (v--, f === 1 || f === 2) (S += u.readSVarint()) < x && (x = S), S > P && (P = S), (D += u.readSVarint()) < I && (I = D), D > M && (M = D); else if (f !== 7) throw new Error("unknown command " + f); } return [x, I, P, M]; }, e.prototype.toGeoJSON = function(u, l, f) { var v, S, D = this.extent * Math.pow(2, f), x = this.extent * u, P = this.extent * l, I = this.loadGeometry(), M = e.types[this.type]; function C(U) { for (var q = 0; q < U.length; q++) { var $ = U[q]; U[q] = [360 * ($.x + x) / D - 180, 360 / Math.PI * Math.atan(Math.exp((180 - 360 * ($.y + P) / D) * Math.PI / 180)) - 90]; } } switch (this.type) { case 1: var k = []; for (v = 0; v < I.length; v++) k[v] = I[v][0]; C(I = k); break; case 2: for (v = 0; v < I.length; v++) C(I[v]); break; case 3: for (I = function(U) { var q = U.length; if (q <= 1) return [U]; for (var $, H, K = [], Q = 0; Q < q; Q++) { var ie = o(U[Q]); ie !== 0 && (H === void 0 && (H = ie < 0), H === ie < 0 ? ($ && K.push($), $ = [U[Q]]) : $.push(U[Q])); } return $ && K.push($), K; }(I), v = 0; v < I.length; v++) for (S = 0; S < I[v].length; S++) C(I[v][S]); } I.length === 1 ? I = I[0] : M = "Multi" + M; var V = { type: "Feature", geometry: { type: M, coordinates: I }, properties: this.properties }; return "id" in this && (V.id = this.id), V; }, w_; } function $y() { if (Zy) return T_; Zy = 1; var r = Wy(); function e(o, u) { this.version = 1, this.name = null, this.extent = 4096, this.length = 0, this._pbf = o, this._keys = [], this._values = [], this._features = [], o.readFields(n, this, u), this.length = this._features.length; } function n(o, u, l) { o === 15 ? u.version = l.readVarint() : o === 1 ? u.name = l.readString() : o === 5 ? u.extent = l.readVarint() : o === 2 ? u._features.push(l.pos) : o === 3 ? u._keys.push(l.readString()) : o === 4 && u._values.push(function(f) { for (var v = null, S = f.readVarint() + f.pos; f.pos < S; ) { var D = f.readVarint() >> 3; v = D === 1 ? f.readString() : D === 2 ? f.readFloat() : D === 3 ? f.readDouble() : D === 4 ? f.readVarint64() : D === 5 ? f.readVarint() : D === 6 ? f.readSVarint() : D === 7 ? f.readBoolean() : null; } return v; }(l)); } return T_ = e, e.prototype.feature = function(o) { if (o < 0 || o >= this._features.length) throw new Error("feature index out of bounds"); this._pbf.pos = this._features[o]; var u = this._pbf.readVarint() + this._pbf.pos; return new r(this._pbf, u, this.extent, this._keys, this._values); }, T_; } function Xy() { return qy || (qy = 1, Sp.VectorTile = function() { if (Hy) return M_; Hy = 1; var r = $y(); function e(n, o, u) { if (n === 3) { var l = new r(u, u.readVarint() + u.pos); l.length && (o[l.name] = l); } } return M_ = function(n, o) { this.layers = n.readFields(e, {}, o); }, M_; }(), Sp.VectorTileFeature = Wy(), Sp.VectorTileLayer = $y()), Sp; } var Iu = Xy(); class vh extends Et { constructor(e, n, o) { super(e, n), this.z = o; } } class Yy extends vh { constructor(e, n, o, u) { super(e, n, o), this.w = u; } } function Ep(r, e, n, o) { const u = [], l = o === 0 ? (f, v, S, D, x, P) => { f.push(new Et(P, S + (P - v) / (D - v) * (x - S))); } : (f, v, S, D, x, P) => { f.push(new Et(v + (P - S) / (x - S) * (D - v), P)); }; for (const f of r) { const v = []; for (const S of f) { if (S.length <= 2) continue; const D = []; for (let I = 0; I < S.length - 1; I++) { const M = S[I].x, C = S[I].y, k = S[I + 1].x, V = S[I + 1].y, U = o === 0 ? M : C, q = o === 0 ? k : V; U < e ? q > e && l(D, M, C, k, V, e) : U > n ? q < n && l(D, M, C, k, V, n) : D.push(S[I]), q < e && U >= e && l(D, M, C, k, V, e), q > n && U <= n && l(D, M, C, k, V, n); } let x = S[S.length - 1]; const P = o === 0 ? x.x : x.y; P >= e && P <= n && D.push(x), D.length && (x = D[D.length - 1], D[0].x === x.x && D[0].y === x.y || D.push(D[0]), v.push(D)); } v.length && u.push(v); } return u; } function Ky(r, e, n, o) { const u = n === "x" ? "y" : "x", l = (o - r[n]) / (e[n] - r[n]); r[u] = r[u] + (e[u] - r[u]) * l, r[n] = o, r.hasOwnProperty("z") && (r.z = ei(r.z, e.z, l)), r.hasOwnProperty("w") && (r.w = ei(r.w, e.w, l)); } function Jy(r, e, n, o) { const u = n, l = o; for (const f of ["x", "y"]) { let v = r, S = e; v[f] >= S[f] && (v = e, S = r), v[f] < u && S[f] > u && Ky(v, S, f, u), v[f] < l && S[f] > l && Ky(S, v, f, l); } } const Pp = Number.MAX_SAFE_INTEGER; function Qy(r, e, n, o) { return r.order < e || r.order === Pp || !(r.clipMask & n) || function(u, l) { return l.length !== 0 && l.find((f) => f === u) === void 0; }(o, r.clipScope); } function Ap(r, e) { return r.x - e.x || r.y - e.y; } function e0(r, e) { return Ap(r.min, e.min) === 0 && Ap(r.max, e.max) === 0; } function S_(r, e) { return !(r.min.x > e.max.x || r.max.x < e.min.x || r.min.y > e.max.y || r.max.y < e.min.y); } function E_(r, e) { if (r.length !== e.length) return !1; for (let n = 0; n < r.length; n++) if (r[n].sourceId !== e[n].sourceId || !e0(r[n], e[n]) || r[n].order !== e[n].order || r[n].clipMask !== e[n].clipMask || !Ws(r[n].clipScope, e[n].clipScope)) return !1; return !0; } function t0(r, e, n) { const o = 1 / Tt, u = 1 / (1 << n.canonical.z), l = (e.x * o + n.canonical.x) * u + n.wrap, f = (e.y * o + n.canonical.y) * u; return { min: new Et((r.x * o + n.canonical.x) * u + n.wrap, (r.y * o + n.canonical.y) * u), max: new Et(l, f) }; } function $w(r, e, n) { const o = 1 << n.canonical.z, u = ((e.x - n.wrap) * o - n.canonical.x) * Tt, l = (e.y * o - n.canonical.y) * Tt; return { min: new Et(((r.x - n.wrap) * o - n.canonical.x) * Tt, (r.y * o - n.canonical.y) * Tt), max: new Et(u, l) }; } function i0(r, e, n, o, u, l, f) { const v = r.indices, S = r.vertices, D = []; for (let x = o; x < o + u; x += 3) { const P = e[n[x + 0] + l], I = e[n[x + 1] + l], M = e[n[x + 2] + l], C = Math.min(P.x, I.x, M.x), k = Math.max(P.x, I.x, M.x), V = Math.min(P.y, I.y, M.y), U = Math.max(P.y, I.y, M.y); D.length = 0, r.grid.query(new Et(C, V), new Et(k, U), D); for (let q = 0; q < D.length; q++) { const $ = D[q]; if (ke(S[v[3 * $ + 0]], S[v[3 * $ + 1]], S[v[3 * $ + 2]], P, I, M, f)) return !0; } } return !1; } function n0(r, e, n, o) { if (!r || !n) return !1; let u = r.vertices; if (!e.canonical.equals(o.canonical) || e.wrap !== o.wrap) { if (n.vertices.length < r.vertices.length) return n0(n, o, r, e); const l = e.canonical, f = o.canonical, v = Math.pow(2, f.z - l.z); u = r.vertices.map((S) => new Et((S.x + l.x * Tt) * v - f.x * Tt, (S.y + l.y * Tt) * v - f.y * Tt)); } return i0(n, u, r.indices, 0, r.indices.length, 0, 0); } function s0(r, e, n, o) { const u = Math.pow(2, o.z - n.z); return new Et((r + n.x * Tt) * u - o.x * Tt, (e + n.y * Tt) * u - o.y * Tt); } function r0(r, e) { const n = []; e.grid.queryPoint(r, n); const o = e.indices, u = e.vertices; for (let l = 0; l < n.length; l++) { const f = n[l]; if (Ae([u[o[3 * f + 0]], u[o[3 * f + 1]], u[o[3 * f + 2]]], r)) return !0; } return !1; } const P_ = [new Et(0, 0), new Et(Tt, 0), new Et(Tt, Tt), new Et(0, Tt)]; function o0(r, e) { const n = []; let o = []; if (!e || r.length < 2) return [r]; if (r.length === 2) return Xe(r[0], r[1], P_) ? [r] : []; for (let u = 0; u < r.length + 2; u++) { const l = r[u % r.length], f = r[(u + 1) % r.length], v = Xe(u === 0 ? r[r.length - 1] : r[(u - 1) % r.length], l, P_), S = Xe(l, f, P_), D = v || S; D && o.push(l), D && S || o.length > 0 && (o.length > 1 && n.push(o), o = []); } return o.length > 1 && n.push(o), n; } const A_ = Iu.VectorTileFeature.types, Xw = ["fill-extrusion-base", "fill-extrusion-height", "fill-extrusion-color", "fill-extrusion-pattern", "fill-extrusion-flood-light-wall-radius", "fill-extrusion-line-width", "fill-extrusion-emissive-strength"], Yw = ["fill-extrusion-flood-light-ground-radius"], Kw = Math.pow(2, 13), Jw = Math.pow(2, 15) - 1, a0 = new Et(0, 1), yc = 2147483648; function Gd(r, e, n, o, u, l, f, v) { r.emplaceBack((e << 1) + f, (n << 1) + l, (Math.floor(o * Kw) << 1) + u, Math.round(v)); } function Zd(r, e, n) { r.emplaceBack(e.x * Tt, e.y * Tt, n ? 1 : 0); } function Cp(r, e, n, o, u, l) { r.emplaceBack(e.x, e.y, (n.x << 1) + o, (n.y << 1) + u, l); } function Hd(r, e, n) { r.emplaceBack(e.x, e.y, e.z, n[0] * 16384, n[1] * 16384, n[2] * 16384); } class l0 { constructor() { this.vertexOffset = 0, this.vertexCount = 0, this.indexOffset = 0, this.indexCount = 0; } } class c0 { constructor() { this.centroidXY = new Et(0, 0), this.vertexArrayOffset = 0, this.vertexCount = 0, this.groundVertexArrayOffset = 0, this.groundVertexCount = 0, this.flags = 0, this.footprintSegIdx = -1, this.footprintSegLen = 0, this.polygonSegIdx = -1, this.polygonSegLen = 0, this.min = new Et(Number.MAX_VALUE, Number.MAX_VALUE), this.max = new Et(-Number.MAX_VALUE, -Number.MAX_VALUE), this.height = 0; } span() { return new Et(this.max.x - this.min.x, this.max.y - this.min.y); } } class h0 { constructor() { this.acc = new Et(0, 0), this.accCount = 0, this.centroidDataIndex = 0; } startRing(e, n) { e.min.x === Number.MAX_VALUE && (e.min.x = e.max.x = n.x, e.min.y = e.max.y = n.y); } appendEdge(e, n, o) { this.accCount++, this.acc._add(n); let u = !!this.borders; n.x < e.min.x ? (e.min.x = n.x, u = !0) : n.x > e.max.x && (e.max.x = n.x, u = !0), n.y < e.min.y ? (e.min.y = n.y, u = !0) : n.y > e.max.y && (e.max.y = n.y, u = !0), ((n.x === 0 || n.x === Tt) && n.x === o.x) != ((n.y === 0 || n.y === Tt) && n.y === o.y) && this.processBorderOverlap(n, o), u && this.checkBorderIntersection(n, o); } checkBorderIntersection(e, n) { n.x < 0 != e.x < 0 && this.addBorderIntersection(0, ei(n.y, e.y, (0 - n.x) / (e.x - n.x))), n.x > Tt != e.x > Tt && this.addBorderIntersection(1, ei(n.y, e.y, (Tt - n.x) / (e.x - n.x))), n.y < 0 != e.y < 0 && this.addBorderIntersection(2, ei(n.x, e.x, (0 - n.y) / (e.y - n.y))), n.y > Tt != e.y > Tt && this.addBorderIntersection(3, ei(n.x, e.x, (Tt - n.y) / (e.y - n.y))); } addBorderIntersection(e, n) { 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 o = this.borders[e]; n < o[0] && (o[0] = n), n > o[1] && (o[1] = n); } processBorderOverlap(e, n) { if (e.x === n.x) { if (e.y === n.y) return; const o = e.x === 0 ? 0 : 1; this.addBorderIntersection(o, n.y), this.addBorderIntersection(o, e.y); } else { const o = e.y === 0 ? 2 : 3; this.addBorderIntersection(o, n.x), this.addBorderIntersection(o, e.x); } } centroid() { return this.accCount === 0 ? new Et(0, 0) : new Et(Math.floor(Math.max(0, this.acc.x) / this.accCount), Math.floor(Math.max(0, this.acc.y) / this.accCount)); } intersectsCount() { return this.borders ? this.borders.reduce((e, n) => e + +(n[0] !== Number.MAX_VALUE), 0) : 0; } } function u0(r, e) { const n = r.add(e)._unit(), o = si(r.x * n.x + r.y * n.y, -1, 1); var u, l, f; return f = Math.acos(o), Math.min(4, Math.max(-4, Math.tan(f))) / 4 * Jw * ((u = r).x * (l = e).y - u.y * l.x < 0 ? -1 : 1); } const Qw = [(r) => r.x < 0, (r) => r.x > Tt, (r) => r.y < 0, (r) => r.y > Tt]; function eT(r, e, n, o) { const u = [4]; if (o === 0) return u; n._mult(o); const l = r.sub(n), f = e.sub(n), v = [r, e, l, f]; for (let S = 0; S < 4; S++) for (const D of v) if (Qw[S](D)) { u.push(S); break; } return u; } class d0 { constructor(e) { this.vertexArray = new wd(), this.indexArray = new qs(), this.programConfigurations = new Qa(e.layers, { zoom: e.zoom, lut: e.lut }, (n) => Yw.includes(n)), this._segments = new Wn(), this.hiddenByLandmarkVertexArray = new vu(), this._segmentToGroundQuads = {}, this._segmentToGroundQuads[0] = [], this._segmentToRegionTriCounts = {}, this._segmentToRegionTriCounts[0] = [0, 0, 0, 0, 0], this.regionSegments = {}, this.regionSegments[4] = new Wn(); } getDefaultSegment() { return this.regionSegments[4]; } hasData() { return this.vertexArray.length !== 0; } addData(e, n, o, u = !1) { const l = e.length; if (l > 2) { let f = Math.max(0, this._segments.get().length - 1); const v = this._segments._prepareSegment(4 * l, this.vertexArray.length, 2 * this._segmentToGroundQuads[f].length); let S; f !== this._segments.get().length - 1 && (f++, this._segmentToGroundQuads[f] = [], this._segmentToRegionTriCounts[f] = [0, 0, 0, 0, 0]); { const D = e[0], x = e[1]; S = u0(D.sub(e[l - 1])._perp()._unit(), x.sub(D)._perp()._unit()); } for (let D = 0; D < l; D++) { const x = D === l - 1 ? 0 : D + 1, P = e[D], I = e[x], M = e[x === l - 1 ? 0 : x + 1], C = I.sub(P)._perp()._unit(), k = u0(C, M.sub(I)._perp()._unit()), V = S, U = k; if (C_(P, I, n) || u && m0(P, n) && m0(I, n)) { S = k; continue; } const q = v.vertexLength; Cp(this.vertexArray, P, I, 1, 1, V), Cp(this.vertexArray, P, I, 1, 0, V), Cp(this.vertexArray, P, I, 0, 1, U), Cp(this.vertexArray, P, I, 0, 0, U), v.vertexLength += 4; const $ = eT(P, I, C, o); for (const H of $) this._segmentToGroundQuads[f].push({ id: q, region: H }), this._segmentToRegionTriCounts[f][H] += 2, v.primitiveLength += 2; S = k; } } } prepareBorderSegments() { if (!this.hasData()) return; const e = this._segments.get(), n = e.length; for (let o = 0; o < n; o++) this._segmentToGroundQuads[o].sort((u, l) => u.region - l.region); for (let o = 0; o < n; o++) { const u = this._segmentToGroundQuads[o], l = e[o], f = this._segmentToRegionTriCounts[o]; f.reduce((S, D) => S + D, 0); let v = 0; for (let S = 0; S <= 4; S++) { const D = f[S]; if (D !== 0) { let x = this.regionSegments[S]; x || (x = this.regionSegments[S] = new Wn()); const P = { vertexOffset: l.vertexOffset, primitiveOffset: l.primitiveOffset + v, vertexLength: l.vertexLength, primitiveLength: D }; x.get().push(P); } v += D; } for (let S = 0; S < u.length; S++) { const D = u[S].id; this.indexArray.emplaceBack(D, D + 1, D + 3), this.indexArray.emplaceBack(D, D + 3, D + 2); } } this._segmentToGroundQuads = null, this._segmentToRegionTriCounts = null, this._segments.destroy(), this._segments = null; } addPaintPropertiesData(e, n, o, u, l, f) { this.hasData() && this.programConfigurations.populatePaintArrays(this.vertexArray.length, e, n, o, u, l, f); } upload(e) { this.hasData() && (this.vertexBuffer = e.createVertexBuffer(this.vertexArray, jw.members), this.indexBuffer = e.createIndexBuffer(this.indexArray)); } uploadPaintProperties(e) { this.hasData() && this.programConfigurations.upload(e); } update(e, n, o, u, l, f, v) { this.hasData() && this.programConfigurations.updatePaintArrays(e, n, o, u, l, f, v); } updateHiddenByLandmark(e) { if (!this.hasData()) return; const n = e.groundVertexCount + e.groundVertexArrayOffset; if (e.groundVertexCount === 0) return; const o = e.flags & yc ? 1 : 0; for (let u = e.groundVertexArrayOffset; u < n; ++u) this.hiddenByLandmarkVertexArray.emplace(u, o); this._needsHiddenByLandmarkUpdate = !0; } uploadHiddenByLandmark(e) { this.hasData() && this._needsHiddenByLandmarkUpdate && (!this.hiddenByLandmarkVertexBuffer && this.hiddenByLandmarkVertexArray.length > 0 ? this.hiddenByLandmarkVertexBuffer = e.createVertexBuffer(this.hiddenByLandmarkVertexArray, Hw.members, !0) : this.hiddenByLandmarkVertexBuffer && this.hiddenByLandmarkVertexBuffer.updateData(this.hiddenByLandmarkVertexArray), this._needsHiddenByLandmarkUpdate = !1); } destroy() { if (this.vertexBuffer) { this.vertexBuffer.destroy(), this.indexBuffer.destroy(), this.hiddenByLandmarkVertexBuffer && this.hiddenByLandmarkVertexBuffer.destroy(), this._segments && this._segments.destroy(), this.programConfigurations.destroy(); for (let e = 0; e <= 4; e++) { const n = this.regionSegments[e]; n && n.destroy(); } } } } class Ip { constructor(e) { this.zoom = e.zoom, this.canonical = e.canonical, this.overscaling = e.overscaling, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.index = e.index, this.hasPattern = !1, this.edgeRadius = 0, this.projection = e.projection, this.activeReplacements = [], this.replacementUpdateTime = 0, this.centroidData = [], this.footprintIndices = new qs(), this.footprintVertices = new Lo(), this.footprintSegments = [], this.layoutVertexArray = new $a(), this.centroidVertexArray = new dp(), this.wallVertexArray = new pp(), this.indexArray = new qs(), this.programConfigurations = new Qa(e.layers, { zoom: e.zoom, lut: e.lut }, (n) => Xw.includes(n)), this.segments = new Wn(), this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id), this.groundEffect = new d0(e), this.maxHeight = 0, this.partLookup = {}, this.triangleSubSegments = [], this.polygonSegments = []; } updateFootprints(e, n) { } populate(e, n, o, u) { this.features = [], this.hasPattern = y_("fill-extrusion", this.layers, n), this.featuresOnBorder = [], this.borderFeatureIndices = [[], [], [], []], this.borderDoneWithNeighborZ = [-1, -1, -1, -1], this.selfDEMTileTimestamp = Number.MAX_VALUE, this.borderDEMTileTimestamp = [Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE, Number.MAX_VALUE], this.tileToMeter = s(o), this.edgeRadius = this.layers[0].layout.get("fill-extrusion-edge-radius") / this.tileToMeter, this.wallMode = this.layers[0].paint.get("fill-extrusion-line-width").constantOr(1) !== 0; for (const { feature: l, id: f, index: v, sourceLayerIndex: S } of e) { const D = this.layers[0]._featureFilter.needGeometry, x = Z(l, D); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), x, o)) continue; const P = { id: f, sourceLayerIndex: S, index: v, geometry: D ? x.geometry : G(l, o, u), properties: l.properties, type: l.type, patterns: {} }, I = this.layoutVertexArray.length, M = A_[P.type] === "Polygon"; if (this.hasPattern) this.features.push(x_("fill-extrusion", this.layers, P, this.zoom, n)); else if (this.wallMode) for (const C of P.geometry) for (const k of o0(C, M)) this.addFeature(P, [k], v, o, {}, n.availableImages, u, n.brightness); else this.addFeature(P, P.geometry, v, o, {}, n.availableImages, u, n.brightness); n.featureIndex.insert(l, P.geometry, v, S, this.index, I); } this.sortBorders(), this.projection.name === "mercator" && this.splitToSubtiles(), this.groundEffect.prepareBorderSegments(), this.polygonSegments.length = 0; } addFeatures(e, n, o, u, l, f) { for (const v of this.features) { const S = A_[v.type] === "Polygon", { geometry: D } = v; if (this.wallMode) for (const x of D) for (const P of o0(x, S)) this.addFeature(v, [P], v.index, n, o, u, l, f); else this.addFeature(v, D, v.index, n, o, u, l, f); } this.sortBorders(), this.projection.name === "mercator" && this.splitToSubtiles(); } update(e, n, o, u, l, f, v) { this.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v), this.groundEffect.update(e, n, l, o, u, f, v); } isEmpty() { return this.layoutVertexArray.length === 0; } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload || this.groundEffect.programConfigurations.needsUpload; } upload(e) { this.uploaded || (this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, Ww), this.indexBuffer = e.createIndexBuffer(this.indexArray), this.wallVertexBuffer = e.createVertexBuffer(this.wallVertexArray, Zw.members), this.layoutVertexExtArray && (this.layoutVertexExtBuffer = e.createVertexBuffer(this.layoutVertexExtArray, qw.members, !0)), this.groundEffect.upload(e)), this.groundEffect.uploadPaintProperties(e), this.programConfigurations.upload(e), this.uploaded = !0; } uploadCentroid(e) { this.groundEffect.uploadHiddenByLandmark(e), this.needsCentroidUpdate && (!this.centroidVertexBuffer && this.centroidVertexArray.length > 0 ? this.centroidVertexBuffer = e.createVertexBuffer(this.centroidVertexArray, Gw.members, !0) : this.centroidVertexBuffer && this.centroidVertexBuffer.updateData(this.centroidVertexArray), this.needsCentroidUpdate = !1); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.centroidVertexBuffer && this.centroidVertexBuffer.destroy(), this.layoutVertexExtBuffer && this.layoutVertexExtBuffer.destroy(), this.groundEffect.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy()); } addFeature(e, n, o, u, l, f, v, S) { const D = this.layers[0].paint.get("fill-extrusion-flood-light-ground-radius").evaluate(e, {}) / this.tileToMeter, x = [new Et(0, 0), new Et(Tt, Tt)], P = v.projection, I = P.name === "globe", M = this.wallMode || A_[e.type] === "Polygon", C = new h0(); C.centroidDataIndex = this.centroidData.length; const k = new c0(), V = this.layers[0].paint.get("fill-extrusion-base").evaluate(e, {}, u) <= 0, U = this.layers[0].paint.get("fill-extrusion-height").evaluate(e, {}, u); let q; if (k.height = U, k.vertexArrayOffset = this.layoutVertexArray.length, k.groundVertexArrayOffset = this.groundEffect.vertexArray.length, I && !this.layoutVertexExtArray && (this.layoutVertexExtArray = new pu()), this.wallMode) { if (I) return void mi("Non zero fill-extrusion-line-width is not yet supported on globe."); if (n.length !== 1) return; q = function(ue) { const Se = ue[0].x === ue[ue.length - 1].x && ue[0].y === ue[ue.length - 1].y; (function(At) { let rt = 0; const Ut = At.length; for (let St = 0; St < Ut; St++) rt += (At[(St + 1) % Ut].x - At[St].x) * (At[(St + 1) % Ut].y + At[St].y); return rt >= 0; })(ue) || (ue = ue.reverse()); const Ee = { geometry: [], joinNormals: [], indices: [] }, ze = [], Ie = [], Re = []; let Ve = ue.length; for (; Ve >= 2 && ue[Ve - 1].equals(ue[Ve - 2]); ) Ve--; if (Ve < (Se ? 3 : 2)) return Ee; let Ue, Fe, et, dt, tt, Mt = 0; for (; Mt < Ve - 1 && ue[Mt].equals(ue[Mt + 1]); ) Mt++; Se && (Ue = ue[Ve - 2], tt = ue[Mt].sub(Ue)._unit()._perp()); for (let At = Mt; At < Ve; At++) { if (et = At === Ve - 1 ? Se ? ue[Mt + 1] : void 0 : ue[At + 1], et && ue[At].equals(et)) continue; tt && (dt = tt), Ue && (Fe = Ue), Ue = ue[At], tt = et ? et.sub(Ue)._unit()._perp() : dt, dt = dt || tt; let rt = dt.add(tt); rt.x === 0 && rt.y === 0 || rt._unit(); const Ut = rt.x * tt.x + rt.y * tt.y, St = Ut !== 0 ? 1 / Ut : 1 / 0, Nt = dt.x * tt.y - dt.y * tt.x > 0; let Qt = "miter"; const pi = 2; Qt === "miter" && St > pi && (Qt = "bevel"), Qt === "bevel" && (St > 100 && (Qt = "flipbevel"), St < pi && (Qt = "miter")); const gi = (Ai, yi, Ii, fn) => { const rn = new Et(Ai.x, Ai.y), hi = new Et(Ai.x, Ai.y); rn.x += yi.x * fn, rn.y += yi.y * fn, hi.x -= yi.x * Math.max(Ii, 1), hi.y -= yi.y * Math.max(Ii, 1), Re.push(yi), ze.push(rn), Ie.push(hi); }; if (Qt === "miter") rt._mult(St), gi(Ue, rt, 0, 0); else if (Qt === "flipbevel") rt = tt.mult(-1), gi(Ue, rt, 0, 0), gi(Ue, rt.mult(-1), 0, 0); else { const Ai = -Math.sqrt(St * St - 1), yi = Nt ? Ai : 0, Ii = Nt ? 0 : Ai; Fe && gi(Ue, dt, yi, Ii), et && gi(Ue, tt, yi, Ii); } } Ee.geometry = [...ze, ...Ie.reverse(), ze[0]], Ee.joinNormals = [...Re, ...Re.reverse(), Re[Re.length - 1]]; const wt = Ee.geometry.length - 1; for (let At = 0; At < wt / 2; At++) if (At + 1 < wt / 2) { let rt = At, Ut = At + 1, St = wt - 1 - At, Nt = wt - 2 - At; rt = rt === 0 ? wt - 1 : rt - 1, Ut = Ut === 0 ? wt - 1 : Ut - 1, St = St === 0 ? wt - 1 : St - 1, Nt = Nt === 0 ? wt - 1 : Nt - 1, Ee.indices.push(St), Ee.indices.push(Ut), Ee.indices.push(rt), Ee.indices.push(St), Ee.indices.push(Nt), Ee.indices.push(Ut); } return Ee; }(n[0]), n = [q.geometry]; } const $ = (ue, Se) => ue < (Se.length - 1) / 2 || ue === Se.length - 1, H = this.wallMode ? [n] : Mp(n, 500); for (let ue = H.length - 1; ue >= 0; ue--) { const Se = H[ue]; (Se.length === 0 || (K = Se[0]).every((me) => me.x <= 0) || K.every((me) => me.x >= Tt) || K.every((me) => me.y <= 0) || K.every((me) => me.y >= Tt)) && H.splice(ue, 1); } var K; let Q; if (I) Q = x0(H, x, u); else { Q = []; for (const ue of H) Q.push({ polygon: ue, bounds: x }); } const ie = M ? this.edgeRadius : 0, fe = ie > 0 && this.zoom < 17, de = (ue, Se) => { if (ue.length === 0) return !1; const me = ue[ue.length - 1]; return Se.x === me.x && Se.y === me.y; }; for (const { polygon: ue, bounds: Se } of Q) { let me = 0, Ee = 0; for (const Ve of ue) M && !Ve[0].equals(Ve[Ve.length - 1]) && Ve.push(Ve[0]), Ee += M ? Ve.length - 1 : Ve.length; const ze = this.segments.prepareSegment((M ? 5 : 4) * Ee, this.layoutVertexArray, this.indexArray); k.footprintSegIdx < 0 && (k.footprintSegIdx = this.footprintSegments.length), k.polygonSegIdx < 0 && (k.polygonSegIdx = this.polygonSegments.length); const Ie = { triangleArrayOffset: this.indexArray.length, triangleCount: 0, triangleSegIdx: this.segments.segments.length - 1 }, Re = new l0(); if (Re.vertexOffset = this.footprintVertices.length, Re.indexOffset = 3 * this.footprintIndices.length, Re.ringIndices = [], M) { const Ve = [], Ue = []; me = ze.vertexLength; for (let et = 0; et < ue.length; et++) { const dt = ue[et]; dt.length && et !== 0 && Ue.push(Ve.length / 2); const tt = []; let Mt, wt; Mt = dt[1].sub(dt[0])._perp()._unit(), Re.ringIndices.push(dt.length - 1); for (let At = 1; At < dt.length; At++) { const rt = dt[At], Ut = dt[At === dt.length - 1 ? 1 : At + 1], St = rt.clone(); if (ie) { wt = Ut.sub(rt)._perp()._unit(); const Nt = Mt.add(wt)._unit(), Qt = ie * Math.min(4, 1 / (Mt.x * Nt.x + Mt.y * Nt.y)); St.x += Qt * Nt.x, St.y += Qt * Nt.y, St.x = Math.round(St.x), St.y = Math.round(St.y), Mt = wt; } if (!V || ie !== 0 && !fe || de(tt, St) || tt.push(St), Gd(this.layoutVertexArray, St.x, St.y, 0, 0, 1, 1, 0), this.wallMode) { const Nt = $(At, dt); Zd(this.wallVertexArray, q.joinNormals[At], !Nt); } ze.vertexLength++, this.footprintVertices.emplaceBack(rt.x, rt.y), Ve.push(rt.x, rt.y), I && Hd(this.layoutVertexExtArray, P.projectTilePoint(St.x, St.y, u), P.upVector(u, St.x, St.y)); } V && (ie === 0 || fe) && (tt.length !== 0 && de(tt, tt[0]) && tt.pop(), this.groundEffect.addData(tt, Se, D)); } const Fe = this.wallMode ? q.indices : Nd(Ve, Ue); for (let et = 0; et < Fe.length; et += 3) this.footprintIndices.emplaceBack(Re.vertexOffset + Fe[et + 0], Re.vertexOffset + Fe[et + 1], Re.vertexOffset + Fe[et + 2]), this.indexArray.emplaceBack(me + Fe[et], me + Fe[et + 2], me + Fe[et + 1]), ze.primitiveLength++; Re.indexCount += Fe.length, Re.vertexCount += this.footprintVertices.length - Re.vertexOffset; } for (let Ve = 0; Ve < ue.length; Ve++) { const Ue = ue[Ve]; C.startRing(k, Ue[0]); let Fe = Ue.length > 4 && _0(Ue[Ue.length - 2], Ue[0], Ue[1]), et = ie ? tT(Ue[Ue.length - 2], Ue[0], Ue[1], ie) : 0; const dt = []; let tt, Mt, wt; Mt = Ue[1].sub(Ue[0])._perp()._unit(); let At = !0; for (let rt = 1, Ut = 0; rt < Ue.length; rt++) { let St = Ue[rt - 1], Nt = Ue[rt]; const Qt = Ue[rt === Ue.length - 1 ? 1 : rt + 1]; if (C.appendEdge(k, Nt, St), C_(Nt, St, Se)) { ie && (Mt = Qt.sub(Nt)._perp()._unit(), At = !At); continue; } const pi = Nt.sub(St)._perp(), gi = pi.x / (Math.abs(pi.x) + Math.abs(pi.y)), Ai = pi.y > 0 ? 1 : 0, yi = St.dist(Nt); if (Ut + yi > 32768 && (Ut = 0), ie) { wt = Qt.sub(Nt)._perp()._unit(); let hi = p0(St, Nt, Qt, f0(Mt, wt), ie); isNaN(hi) && (hi = 0); const on = Nt.sub(St)._unit(); St = St.add(on.mult(et))._round(), Nt = Nt.add(on.mult(-hi))._round(), et = hi, Mt = wt, V && this.zoom >= 17 && (de(dt, St) || dt.push(St), de(dt, Nt) || dt.push(Nt)); } const Ii = ze.vertexLength, fn = Ue.length > 4 && _0(St, Nt, Qt); let rn = g0(Ut, Fe, At); if (Gd(this.layoutVertexArray, St.x, St.y, gi, Ai, 0, 0, rn), Gd(this.layoutVertexArray, St.x, St.y, gi, Ai, 0, 1, rn), this.wallMode) { const hi = $(rt - 1, Ue), on = q.joinNormals[rt - 1]; Zd(this.wallVertexArray, on, hi), Zd(this.wallVertexArray, on, hi); } if (Ut += yi, rn = g0(Ut, fn, !At), Fe = fn, Gd(this.layoutVertexArray, Nt.x, Nt.y, gi, Ai, 0, 0, rn), Gd(this.layoutVertexArray, Nt.x, Nt.y, gi, Ai, 0, 1, rn), this.wallMode) { const hi = $(rt, Ue), on = q.joinNormals[rt]; Zd(this.wallVertexArray, on, hi), Zd(this.wallVertexArray, on, hi); } if (ze.vertexLength += 4, this.indexArray.emplaceBack(Ii + 0, Ii + 1, Ii + 2), this.indexArray.emplaceBack(Ii + 1, Ii + 3, Ii + 2), ze.primitiveLength += 2, ie) { const hi = me + (rt === 1 ? Ue.length - 2 : rt - 2), on = rt === 1 ? me : hi + 1; if (this.indexArray.emplaceBack(Ii + 1, hi, Ii + 3), this.indexArray.emplaceBack(hi, on, Ii + 3), ze.primitiveLength += 2, tt === void 0 && (tt = Ii), !C_(Qt, Ue[rt], Se)) { const Qi = rt === Ue.length - 1 ? tt : ze.vertexLength; this.indexArray.emplaceBack(Ii + 2, Ii + 3, Qi), this.indexArray.emplaceBack(Ii + 3, Qi + 1, Qi), this.indexArray.emplaceBack(Ii + 3, on, Qi + 1), ze.primitiveLength += 3; } At = !At; } if (I) { const hi = this.layoutVertexExtArray, on = P.projectTilePoint(St.x, St.y, u), Qi = P.projectTilePoint(Nt.x, Nt.y, u), pn = P.upVector(u, St.x, St.y), as = P.upVector(u, Nt.x, Nt.y); Hd(hi, on, pn), Hd(hi, on, pn), Hd(hi, Qi, as), Hd(hi, Qi, as); } } M && (me += Ue.length - 1), V && ie && this.zoom >= 17 && (dt.length !== 0 && de(dt, dt[0]) && dt.pop(), this.groundEffect.addData(dt, Se, D, ie > 0)); } this.footprintSegments.push(Re), Ie.triangleCount = this.indexArray.length - Ie.triangleArrayOffset, this.polygonSegments.push(Ie), ++k.footprintSegLen, ++k.polygonSegLen; } if (k.vertexCount = this.layoutVertexArray.length - k.vertexArrayOffset, k.groundVertexCount = this.groundEffect.vertexArray.length - k.groundVertexArrayOffset, k.vertexCount !== 0) { if (k.centroidXY = C.borders ? a0 : this.encodeCentroid(C, k), this.centroidData.push(k), C.borders) { this.featuresOnBorder.push(C); const ue = this.featuresOnBorder.length - 1; for (let Se = 0; Se < C.borders.length; Se++) C.borders[Se][0] !== Number.MAX_VALUE && this.borderFeatureIndices[Se].push(ue); } this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, e, o, l, f, u, S), this.groundEffect.addPaintPropertiesData(e, o, l, f, u, S), this.maxHeight = Math.max(this.maxHeight, U); } } sortBorders() { for (let e = 0; e < this.borderFeatureIndices.length; e++) this.borderFeatureIndices[e].sort((n, o) => this.featuresOnBorder[n].borders[e][0] - this.featuresOnBorder[o].borders[e][0]); } splitToSubtiles() { const e = []; for (let v = 0; v < this.centroidData.length; v++) { const S = this.centroidData[v], D = +(S.min.y + S.max.y > Tt), x = 2 * D + (+(S.min.x + S.max.x > Tt) ^ D); for (let P = 0; P < S.polygonSegLen; P++) { const I = S.polygonSegIdx + P; e.push({ centroidIdx: v, subtile: x, polygonSegmentIdx: I, triangleSegmentIdx: this.polygonSegments[I].triangleSegIdx }); } } const n = new qs(); e.sort((v, S) => v.triangleSegmentIdx === S.triangleSegmentIdx ? v.subtile - S.subtile : v.triangleSegmentIdx - S.triangleSegmentIdx); let o = 0, u = 0, l = 0; for (const v of e) { if (v.triangleSegmentIdx !== o) break; l++; } const f = e.length; for (; u !== e.length; ) { o = e[u].triangleSegmentIdx; let v = 0, S = u, D = u; for (let x = S; x < l && e[x].subtile === v; x++) D++; for (; S !== l; ) { const x = e[S]; v = x.subtile; const P = this.centroidData[x.centroidIdx].min.clone(), I = this.centroidData[x.centroidIdx].max.clone(), M = { vertexOffset: this.segments.segments[o].vertexOffset, primitiveOffset: n.length, vertexLength: this.segments.segments[o].vertexLength, primitiveLength: 0, sortKey: void 0, vaos: {} }; for (let C = S; C < D; C++) { const k = e[C], V = this.polygonSegments[k.polygonSegmentIdx], U = this.centroidData[k.centroidIdx].min, q = this.centroidData[k.centroidIdx].max, $ = this.indexArray.uint16; for (let H = V.triangleArrayOffset; H < V.triangleArrayOffset + V.triangleCount; H++) n.emplaceBack($[3 * H], $[3 * H + 1], $[3 * H + 2]); M.primitiveLength += V.triangleCount, P.x = Math.min(P.x, U.x), P.y = Math.min(P.y, U.y), I.x = Math.max(I.x, q.x), I.y = Math.max(I.y, q.y); } M.primitiveLength > 0 && this.triangleSubSegments.push({ segment: M, min: P, max: I }), S = D; for (let C = S; C < l && e[C].subtile === e[S].subtile; C++) D++; } u = l; for (let x = u; x < f && e[x].triangleSegmentIdx === e[u].triangleSegmentIdx; x++) l++; } n._trim(), this.indexArray = n; } getVisibleSegments(e, n, o) { const u = new Wn(); if (this.wallMode) { for (const k of this.triangleSubSegments) u.segments.push(k.segment); return u; } let l = 0, f = 0; const v = 1 << e.canonical.z; if (n) { const k = n.getMinMaxForTile(e); k && (l = k.min, f = k.max); } f += this.maxHeight; const S = e.toUnwrapped(); let D; const x = [S.canonical.x / v + S.wrap, S.canonical.y / v], P = [(S.canonical.x + 1) / v + S.wrap, (S.canonical.y + 1) / v], I = (k, V, U) => [k[0] * (1 - U[0]) + V[0] * U[0], k[1] * (1 - U[1]) + V[1] * U[1]], M = [], C = []; for (const k of this.triangleSubSegments) { M[0] = k.min.x / Tt, M[1] = k.min.y / Tt, C[0] = k.max.x / Tt, C[1] = k.max.y / Tt; const V = I(x, P, M), U = I(x, P, C); if (new Jt([V[0], V[1], l], [U[0], U[1], f]).intersectsPrecise(o) === 0) { D && (u.segments.push(D), D = void 0); continue; } const q = k.segment; D && D.vertexOffset !== q.vertexOffset && (u.segments.push(D), D = void 0), D ? (D.vertexLength += q.vertexLength, D.primitiveLength += q.primitiveLength) : D = { vertexOffset: q.vertexOffset, primitiveLength: q.primitiveLength, vertexLength: q.vertexLength, primitiveOffset: q.primitiveOffset, sortKey: void 0, vaos: {} }; } return D && u.segments.push(D), u; } encodeCentroid(e, n) { const o = e.centroid(), u = n.span(), l = Math.min(7, Math.round(u.x * this.tileToMeter / 10)), f = Math.min(7, Math.round(u.y * this.tileToMeter / 10)); return new Et(si(o.x, 1, Tt - 1) << 3 | l, si(o.y, 1, Tt - 1) << 3 | f); } encodeBorderCentroid(e) { if (!e.borders) return new Et(0, 0); const n = e.borders, o = Number.MAX_VALUE; if (n[0][0] !== o || n[1][0] !== o) { const u = n[0][0] !== o ? 0 : 1; return new Et(6 | (n[0][0] !== o ? 0 : 65528), (n[u][0] + n[u][1]) / 2 << 3 | 6); } { const u = n[2][0] !== o ? 2 : 3; return new Et((n[u][0] + n[u][1]) / 2 << 3 | 6, 6 | (n[2][0] !== o ? 0 : 65528)); } } showCentroid(e) { const n = this.centroidData[e.centroidDataIndex]; n.flags &= yc, n.centroidXY.x = 0, n.centroidXY.y = 0, this.writeCentroidToBuffer(n); } writeCentroidToBuffer(e) { this.groundEffect.updateHiddenByLandmark(e); const n = e.vertexArrayOffset, o = e.vertexCount + e.vertexArrayOffset, u = e.flags & yc ? a0 : e.centroidXY, l = this.centroidVertexArray.geta_centroid_pos0(n); if (this.centroidVertexArray.geta_centroid_pos1(n) !== u.y || l !== u.x) { for (let f = n; f < o; ++f) this.centroidVertexArray.emplace(f, u.x, u.y); this.needsCentroidUpdate = !0; } } createCentroidsBuffer() { this.centroidVertexArray.resize(this.layoutVertexArray.length), this.groundEffect.hiddenByLandmarkVertexArray.resize(this.groundEffect.vertexArray.length); for (const e of this.centroidData) this.writeCentroidToBuffer(e); } updateReplacement(e, n, o) { if (n.updateTime === this.replacementUpdateTime) return; this.replacementUpdateTime = n.updateTime; const u = n.getReplacementRegionsForTile(e.toUnwrapped()); if (E_(this.activeReplacements, u)) return; if (this.activeReplacements = u, this.centroidVertexArray.length === 0) this.createCentroidsBuffer(); else for (const f of this.centroidData) f.flags &= 2147483647; const l = []; for (const f of this.activeReplacements) { if (f.order < o) continue; const v = Math.max(1, Math.pow(2, f.footprintTileId.canonical.z - e.canonical.z)); for (const S of this.centroidData) if (!(S.flags & yc || f.min.x > S.max.x || S.min.x > f.max.x || f.min.y > S.max.y || S.min.y > f.max.y)) for (let D = 0; D < S.footprintSegLen; D++) { const x = this.footprintSegments[S.footprintSegIdx + D]; if (l.length = 0, iT(this.footprintVertices, x.vertexOffset, x.vertexCount, f.footprintTileId.canonical, e.canonical, l), i0(f.footprint, l, this.footprintIndices.uint16, x.indexOffset, x.indexCount, -x.vertexOffset, -v)) { S.flags |= yc; break; } } } for (const f of this.centroidData) this.writeCentroidToBuffer(f); this.borderDoneWithNeighborZ = [-1, -1, -1, -1]; } footprintContainsPoint(e, n, o) { let u = !1; for (let l = 0; l < o.footprintSegLen; l++) { const f = this.footprintSegments[o.footprintSegIdx + l]; let v = 0; for (const S of f.ringIndices) { for (let D = v, x = S + v - 1; D < S + v; x = D++) { const P = this.footprintVertices.int16[2 * (D + f.vertexOffset) + 0], I = this.footprintVertices.int16[2 * (D + f.vertexOffset) + 1], M = this.footprintVertices.int16[2 * (x + f.vertexOffset) + 1]; I > n != M > n && e < (this.footprintVertices.int16[2 * (x + f.vertexOffset) + 0] - P) * (n - I) / (M - I) + P && (u = !u); } v = S; } } return u; } getHeightAtTileCoord(e, n) { let o = Number.NEGATIVE_INFINITY, u = !0; const l = 4 * (e + Tt) * Tt + (n + Tt); if (this.partLookup.hasOwnProperty(l)) { const f = this.partLookup[l]; return f ? { height: f.height, hidden: !!(f.flags & yc) } : void 0; } for (const f of this.centroidData) e > f.max.x || f.min.x > e || n > f.max.y || f.min.y > n || this.footprintContainsPoint(e, n, f) && f && f.height > o && (o = f.height, this.partLookup[l] = f, u = !!(f.flags & yc)); if (o !== Number.NEGATIVE_INFINITY) return { height: o, hidden: u }; this.partLookup[l] = void 0; } } function f0(r, e) { const n = r.add(e)._unit(); return r.x * n.x + r.y * n.y; } function tT(r, e, n, o) { const u = e.sub(r)._perp()._unit(), l = n.sub(e)._perp()._unit(); return p0(r, e, n, f0(u, l), o); } function p0(r, e, n, o, u) { const l = Math.sqrt(1 - o * o); return Math.min(r.dist(e) / 3, e.dist(n) / 3, u * l / o); } function C_(r, e, n) { return r.x < n[0].x && e.x < n[0].x || r.x > n[1].x && e.x > n[1].x || r.y < n[0].y && e.y < n[0].y || r.y > n[1].y && e.y > n[1].y; } function m0(r, e) { return r.x < e[0].x || r.x > e[1].x || r.y < e[0].y || r.y > e[1].y; } function _0(r, e, n) { if (r.x < 0 || r.x >= Tt || e.x < 0 || e.x >= Tt || n.x < 0 || n.x >= Tt) return !1; const o = n.sub(e), u = o.perp(), l = r.sub(e); return (o.x * l.x + o.y * l.y) / Math.sqrt((o.x * o.x + o.y * o.y) * (l.x * l.x + l.y * l.y)) > -0.866 && u.x * l.x + u.y * l.y < 0; } function g0(r, e, n) { const o = e ? 2 | r : -3 & r; return n ? 1 | o : -2 & o; } function y0() { const r = Math.PI / 32, e = Math.tan(r), n = _c; return n * Math.sqrt(1 + 2 * e * e) - n; } function x0(r, e, n) { const o = 1 << n.z, u = Fr(n.x / o), l = Fr((n.x + 1) / o), f = Os(n.y / o), v = Os((n.y + 1) / o); return function(S, D, x, P, I = 0, M) { const C = []; if (!S.length || !x || !P) return C; const k = (Q, ie) => { for (const fe of Q) C.push({ polygon: fe, bounds: ie }); }, V = Math.ceil(Math.log2(x)), U = Math.ceil(Math.log2(P)), q = V - U, $ = []; for (let Q = 0; Q < Math.abs(q); Q++) $.push(q > 0 ? 0 : 1); for (let Q = 0; Q < Math.min(V, U); Q++) $.push(0), $.push(1); let H = S; if (H = Ep(H, D[0].y - I, D[1].y + I, 1), H = Ep(H, D[0].x - I, D[1].x + I, 0), !H.length) return C; const K = []; for ($.length ? K.push({ polygons: H, bounds: D, depth: 0 }) : k(H, D); K.length; ) { const Q = K.pop(), ie = Q.depth, fe = $[ie], de = Q.bounds[0], ue = Q.bounds[1], Se = fe === 0 ? de.x : de.y, me = fe === 0 ? ue.x : ue.y, Ee = M ? M(fe, Se, me) : 0.5 * (Se + me), ze = Ep(Q.polygons, Se - I, Ee + I, fe), Ie = Ep(Q.polygons, Ee - I, me + I, fe); if (ze.length) { const Re = [de, new Et(fe === 0 ? Ee : ue.x, fe === 1 ? Ee : ue.y)]; $.length > ie + 1 ? K.push({ polygons: ze, bounds: Re, depth: ie + 1 }) : k(ze, Re); } if (Ie.length) { const Re = [new Et(fe === 0 ? Ee : de.x, fe === 1 ? Ee : de.y), ue]; $.length > ie + 1 ? K.push({ polygons: Ie, bounds: Re, depth: ie + 1 }) : k(Ie, Re); } } return C; }(r, e, Math.ceil((l - u) / 11.25), Math.ceil((f - v) / 11.25), 1, (S, D, x) => { if (S === 0) return 0.5 * (D + x); { const P = Os((n.y + D / Tt) / o); return (Ta(0.5 * (Os((n.y + x / Tt) / o) + P)) * o - n.y) * Tt; } }); } function iT(r, e, n, o, u, l) { const f = Math.pow(2, o.z - u.z); for (let v = 0; v < n; v++) { let S = r.int16[2 * (v + e) + 0], D = r.int16[2 * (v + e) + 1]; S = (S + u.x * Tt) * f - o.x * Tt, D = (D + u.y * Tt) * f - o.y * Tt, l.push(new Et(S, D)); } } let v0, b0; function qd(r, e) { return r.x * e.x + r.y * e.y; } function w0(r, e) { if (r.length === 1) { let n = 0; const o = e[n++]; let u; for (; !u || o.equals(u); ) if (u = e[n++], !u) return 1 / 0; for (; n < e.length; n++) { const l = e[n], f = r[0], v = u.sub(o), S = l.sub(o), D = f.sub(o), x = qd(v, v), P = qd(v, S), I = qd(S, S), M = qd(D, v), C = qd(D, S), k = x * I - P * P, V = (I * M - P * C) / k, U = (x * C - P * M) / k, q = o.z * (1 - V - U) + u.z * V + l.z * U; if (isFinite(q)) return q; } return 1 / 0; } { let n = 1 / 0; for (const o of e) n = Math.min(n, o.z); return n; } } function T0(r, e, n, o, u, l, f, v) { const S = f * u.getElevationAt(r, e, !0, !0), D = l[0] !== 0, x = D ? l[1] === 0 ? f * (l[0] / 7 - 450) : f * function(P, I, M) { const C = Math.floor(I[0] / 8), k = Math.floor(I[1] / 8), V = 10 * (I[0] - 8 * C), U = 10 * (I[1] - 8 * k), q = P.getElevationAt(C, k, !0, !0), $ = P.getMeterToDEM(M), H = Math.floor(0.5 * (V * $ - 1)), K = Math.floor(0.5 * (U * $ - 1)), Q = P.tileCoordToPixel(C, k), ie = 2 * H + 1, fe = 2 * K + 1, de = function(Ie, Re, Ve, Ue, Fe) { return [Ie.getElevationAtPixel(Re, Ve, !0), Ie.getElevationAtPixel(Re + Fe, Ve, !0), Ie.getElevationAtPixel(Re, Ve + Fe, !0), Ie.getElevationAtPixel(Re + Ue, Ve + Fe, !0)]; }(P, Q.x - H, Q.y - K, ie, fe), ue = Math.abs(de[0] - de[1]), Se = Math.abs(de[2] - de[3]), me = Math.abs(de[0] - de[2]) + Math.abs(de[1] - de[3]), Ee = Math.min(0.25, 0.5 * $ * (ue + Se) / ie), ze = Math.min(0.25, 0.5 * $ * me / fe); return q + Math.max(Ee * V, ze * U); }(u, l, v) : S; return { base: S + (n === 0 ? -1 : n), top: D ? Math.max(x + o, S + n + 2) : S + o }; } Ft(Ip, "FillExtrusionBucket", { omit: ["layers", "features"] }), Ft(c0, "PartData"), Ft(l0, "FootprintSegment"), Ft(h0, "BorderCentroidData"), Ft(d0, "GroundEffect"); const nT = qi([{ name: "a_pos_normal", components: 2, type: "Int16" }, { name: "a_data", components: 4, type: "Uint8" }, { name: "a_linesofar", components: 1, type: "Float32" }], 4), sT = qi([{ name: "a_z_offset_width", components: 2, type: "Float32" }], 4), { members: rT } = nT, oT = qi([{ name: "a_packed", components: 4, type: "Float32" }]), { members: aT } = oT, lT = qi([{ name: "a_pattern_data", components: 3, type: "Float32" }]), { members: cT } = lT; class M0 { constructor(e, n) { this.width = e, this.height = n, this.nextRow = 0, this.image = new gc({ width: e, height: n }), this.positions = {}, this.uploaded = !1; } getDash(e, n) { const o = this.getKey(e, n); return this.positions[o]; } trim() { const e = this.width, n = this.height = xo(this.nextRow); this.image.resize({ width: e, height: n }); } getKey(e, n) { return e.join(",") + n; } getDashRanges(e, n, o) { const u = []; let l = e.length % 2 == 1 ? -e[e.length - 1] * o : 0, f = e[0] * o, v = !0; u.push({ left: l, right: f, isDash: v, zeroLength: e[0] === 0 }); let S = e[0]; for (let D = 1; D < e.length; D++) { v = !v; const x = e[D]; l = S * o, S += x, f = S * o, u.push({ left: l, right: f, isDash: v, zeroLength: x === 0 }); } return u; } addRoundDash(e, n, o) { const u = n / 2; for (let l = -o; l <= o; l++) { const f = this.width * (this.nextRow + o + l); let v = 0, S = e[v]; for (let D = 0; D < this.width; D++) { D / S.right > 1 && (S = e[++v]); const x = Math.abs(D - S.left), P = Math.abs(D - S.right), I = Math.min(x, P); let M; const C = l / o * (u + 1); if (S.isDash) { const k = u - Math.abs(C); M = Math.sqrt(I * I + k * k); } else M = u - Math.sqrt(I * I + C * C); this.image.data[f + D] = Math.max(0, Math.min(255, M + 128)); } } } addRegularDash(e, n) { for (let S = e.length - 1; S >= 0; --S) { const D = e[S], x = e[S + 1]; D.zeroLength ? e.splice(S, 1) : x && x.isDash === D.isDash && (x.left = D.left, e.splice(S, 1)); } const o = e[0], u = e[e.length - 1]; o.isDash === u.isDash && (o.left = u.left - this.width, u.right = o.right + this.width); const l = this.width * this.nextRow; let f = 0, v = e[f]; for (let S = 0; S < this.width; S++) { S / v.right > 1 && (v = e[++f]); const D = Math.abs(S - v.left), x = Math.abs(S - v.right), P = Math.min(D, x); this.image.data[l + S] = Math.max(0, Math.min(255, (v.isDash ? P : -P) + n + 128)); } } addDash(e, n) { const o = this.getKey(e, n); if (this.positions[o]) return this.positions[o]; const u = n === "round", l = u ? 7 : 0, f = 2 * l + 1; if (this.nextRow + f > this.height) return mi("LineAtlas out of space"), null; e.length === 0 && e.push(1); let v = 0; for (let x = 0; x < e.length; x++) e[x] < 0 && (mi("Negative value is found in line dasharray, replacing values with 0"), e[x] = 0), v += e[x]; if (v !== 0) { const x = this.width / v, P = this.getDashRanges(e, this.width, x); u ? this.addRoundDash(P, x, l) : this.addRegularDash(P, n === "square" ? 0.5 * x : 0); } const S = this.nextRow + l; this.nextRow += f; const D = { tl: [S, l], br: [v, 0] }; return this.positions[o] = D, D; } } Ft(M0, "LineAtlas"); const hT = Iu.VectorTileFeature.types, uT = Math.cos(Math.PI / 180 * 37.5), dT = Math.cos(Math.PI / 180 * 5); class I_ { constructor(e) { this.evaluationGlobals = { zoom: 0, lineProgress: void 0 }, this.zoom = e.zoom, this.evaluationGlobals.zoom = this.zoom, this.overscaling = e.overscaling, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.index = e.index, this.projection = e.projection, this.hasPattern = !1, this.hasZOffset = !1, this.hasCrossSlope = !1, this.patternFeatures = [], this.lineClipsArray = [], this.gradients = {}, this.layers.forEach((n) => { this.gradients[n.id] = {}; }), this.layoutVertexArray = new ho(), this.layoutVertexArray2 = new Xa(), this.patternVertexArray = new va(), this.indexArray = new qs(), this.programConfigurations = new Qa(e.layers, { zoom: e.zoom, lut: e.lut }), this.segments = new Wn(), this.maxLineLength = 0, this.zOffsetVertexArray = new Pl(), this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id), this.tessellationStep = e.tessellationStep ? e.tessellationStep : Tt / 64; } updateFootprints(e, n) { } populate(e, n, o, u) { this.hasPattern = y_("line", this.layers, n); const l = this.layers[0].layout.get("line-sort-key"); this.tileToMeter = s(o), this.hasZOffset = !this.layers[0].isDraped(); const f = this.layers[0].layout.get("line-elevation-reference"); this.hasZOffset && f === "none" && mi(`line-elevation-reference: ground is used for the layer ${this.layerIds[0]} because non-zero line-z-offset value was found.`); const v = this.layers[0].layout.get("line-cross-slope"); this.hasCrossSlope = this.hasZOffset && v !== void 0; const S = []; for (const { feature: I, id: M, index: C, sourceLayerIndex: k } of e) { const V = this.layers[0]._featureFilter.needGeometry, U = Z(I, V); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), U, o)) continue; const q = l ? l.evaluate(U, {}, o) : void 0, $ = { id: M, properties: I.properties, type: I.type, sourceLayerIndex: k, index: C, geometry: V ? U.geometry : G(I, o, u), patterns: {}, sortKey: q }; S.push($); } l && S.sort((I, M) => I.sortKey - M.sortKey); const { lineAtlas: D, featureIndex: x } = n, P = this.addConstantDashes(D); for (const I of S) { const { geometry: M, index: C, sourceLayerIndex: k } = I; if (P && this.addFeatureDashes(I, D), this.hasPattern) { const V = x_("line", this.layers, I, this.zoom, n); this.patternFeatures.push(V); } else this.addFeature(I, M, C, o, D.positions, n.availableImages, n.brightness); x.insert(e[C].feature, M, C, k, this.index); } } addConstantDashes(e) { let n = !1; for (const o of this.layers) { const u = o.paint.get("line-dasharray").value, l = o.layout.get("line-cap").value; if (u.kind !== "constant" || l.kind !== "constant") n = !0; else { const f = l.value, v = u.value; if (!v) continue; e.addDash(v, f); } } return n; } addFeatureDashes(e, n) { const o = this.zoom; for (const u of this.layers) { const l = u.paint.get("line-dasharray").value, f = u.layout.get("line-cap").value; if (l.kind === "constant" && f.kind === "constant") continue; let v, S; if (l.kind === "constant") { if (v = l.value, !v) continue; } else v = l.evaluate({ zoom: o }, e); S = f.kind === "constant" ? f.value : f.evaluate({ zoom: o }, e), n.addDash(v, S), e.patterns[u.id] = n.getKey(v, S); } } update(e, n, o, u, l, f, v) { this.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v); } addFeatures(e, n, o, u, l, f) { for (const v of this.patternFeatures) this.addFeature(v, v.geometry, v.index, n, o, u, f); } isEmpty() { return this.layoutVertexArray.length === 0; } uploadPending() { return !this.uploaded || this.programConfigurations.needsUpload; } upload(e) { this.uploaded || (this.layoutVertexArray2.length !== 0 && (this.layoutVertexBuffer2 = e.createVertexBuffer(this.layoutVertexArray2, aT)), this.patternVertexArray.length !== 0 && (this.patternVertexBuffer = e.createVertexBuffer(this.patternVertexArray, cT)), !this.zOffsetVertexBuffer && this.zOffsetVertexArray.length > 0 && (this.zOffsetVertexBuffer = e.createVertexBuffer(this.zOffsetVertexArray, sT.members, !0)), this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, rT), this.indexBuffer = e.createIndexBuffer(this.indexArray)), this.programConfigurations.upload(e), this.uploaded = !0; } destroy() { this.layoutVertexBuffer && (this.zOffsetVertexBuffer && this.zOffsetVertexBuffer.destroy(), this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy()); } lineFeatureClips(e) { if (e.properties && e.properties.hasOwnProperty("mapbox_clip_start") && e.properties.hasOwnProperty("mapbox_clip_end")) return { start: +e.properties.mapbox_clip_start, end: +e.properties.mapbox_clip_end }; } addFeature(e, n, o, u, l, f, v) { const S = this.layers[0].layout, D = S.get("line-join").evaluate(e, {}), x = S.get("line-cap").evaluate(e, {}), P = S.get("line-miter-limit"), I = S.get("line-round-limit"); this.lineClips = this.lineFeatureClips(e), this.lineFeature = e, this.zOffsetValue = S.get("line-z-offset").value; const M = this.layers[0].paint.get("line-width").value; M.kind !== "constant" && M.isLineProgressConstant === !1 && (this.variableWidthValue = M); for (const C of n) this.addLine(C, e, u, D, x, P, I); this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length, e, o, l, f, u, v); } addLine(e, n, o, u, l, f, v) { this.distance = 0, this.prevDistance = 0, this.scaledDistance = 0, this.totalDistance = 0, this.totalFeatureLength = 0, this.lineSoFar = 0, this.currentVertex = void 0; const S = u === "none"; if (this.patternJoinNone = this.hasPattern && S, this.segmentStart = 0, this.segmentStartf32 = 0, this.segmentPoints = [], this.lineClips) { this.lineClipsArray.push(this.lineClips); for (let $ = 0; $ < e.length - 1; $++) this.totalDistance += e[$].dist(e[$ + 1]); this.totalFeatureLength = this.totalDistance / (this.lineClips.end - this.lineClips.start), this.updateScaledDistance(), this.maxLineLength = Math.max(this.maxLineLength, this.totalDistance); } const D = hT[n.type] === "Polygon"; let x = e.length; for (; x >= 2 && e[x - 1].equals(e[x - 2]); ) x--; let P = 0; for (; P < x - 1 && e[P].equals(e[P + 1]); ) P++; if (x < (D ? 3 : 2)) return; u === "bevel" && (f = 1.05); const I = this.segments.prepareSegment(10 * x, this.layoutVertexArray, this.indexArray); let M, C, k, V, U, q; this.e1 = this.e2 = -1, D && (M = e[x - 2], U = e[P].sub(M)._unit()._perp()); for (let $ = P; $ < x; $++) { if (k = $ === x - 1 ? D ? e[P + 1] : void 0 : e[$ + 1], k && e[$].equals(k)) continue; U && (V = U), M && (C = M), M = e[$], q = this.evaluateLineProgressFeatures(C ? C.dist(M) : 0), U = k ? k.sub(M)._unit()._perp() : V, V = V || U; const H = C && k; let K = H ? u : D || S ? "butt" : l; const Q = V.x * U.x + V.y * U.y; if (S) { const ze = function(Ie) { if (Ie.patternJoinNone) { const Re = Ie.segmentPoints.length / 2, Ve = Ie.lineSoFar - Ie.segmentStart; for (let Ue = 0; Ue < Re; ++Ue) { const Fe = Ie.segmentPoints[2 * Ue + 1], et = Math.round(Ie.segmentPoints[2 * Ue]) + 0.5 + 0.25 * Fe; Ie.patternVertexArray.emplaceBack(et, Ve, Ie.segmentStart), Ie.patternVertexArray.emplaceBack(et, Ve, Ie.segmentStart); } Ie.segmentPoints.length = 0; } Ie.e1 = Ie.e2 = -1; }; if (H && Q < dT) { this.updateDistance(C, M), this.addCurrentVertex(M, V, 1, 1, I, q), ze(this), this.addCurrentVertex(M, U, -1, -1, I, q); continue; } if (C) { if (!k) { this.updateDistance(C, M), this.addCurrentVertex(M, V, 1, 1, I, q), ze(this); continue; } K = "miter"; } } let ie = V.add(U); ie.x === 0 && ie.y === 0 || ie._unit(); const fe = ie.x * U.x + ie.y * U.y, de = fe !== 0 ? 1 / fe : 1 / 0, ue = 2 * Math.sqrt(2 - 2 * fe), Se = fe < uT && C && k, me = V.x * U.y - V.y * U.x > 0, Ee = this.overscaling <= 16 ? 15 * Tt / (512 * this.overscaling) : 0; if (H && K === "round") { if (de < v) K = "miter"; else if (de <= 2) { const ze = L_(M, -10, Tt + 10); K = this.hasZOffset && (ze || this.hasCrossSlope) ? "miter" : "fakeround"; } } if (K === "miter" && de > f && (K = "bevel"), K === "bevel" && (de > 2 && (K = "flipbevel"), de < f && (K = "miter")), C && !(K === "miter" && Se) && this.updateDistance(C, M), K === "miter") if (Se) { const ze = M.dist(C); if (ze > 2 * Ee) { const Re = M.sub(M.sub(C)._mult(Ee / ze)._round()); this.updateDistance(C, Re), this.addCurrentVertex(Re, V, 0, 0, I, q), C = Re; } this.updateDistance(C, M), ie._mult(de), this.addCurrentVertex(M, ie, 0, 0, I, q); const Ie = M.dist(k); if (Ie > 2 * Ee) { const Re = M.add(k.sub(M)._mult(Ee / Ie)._round()); this.updateDistance(M, Re), this.addCurrentVertex(Re, U, 0, 0, I, q), M = Re; } } else ie._mult(de), this.addCurrentVertex(M, ie, 0, 0, I, q); else if (K === "flipbevel") { if (de > 100) ie = U.mult(-1); else { const ze = de * V.add(U).mag() / V.sub(U).mag(); ie._perp()._mult(ze * (me ? -1 : 1)); } this.addCurrentVertex(M, ie, 0, 0, I, q), this.addCurrentVertex(M, ie.mult(-1), 0, 0, I, q); } else if (K === "bevel" || K === "fakeround") { q != null && C && this.addCurrentVertex(M, V, -1, -1, I, q); const ze = M.dist(C) <= 2 * Ee && K !== "bevel", Ie = ie.mult(me ? 1 : -1); Ie._mult(de); const Re = U.mult(me ? -1 : 1), Ve = V.mult(me ? -1 : 1), Ue = this.evaluateLineProgressFeatures(this.distance); if (q == null && (this.addHalfVertex(M, Ie.x, Ie.y, !1, !me, 0, I, Ue), ze || this.addHalfVertex(M, Ie.x + 2 * Ve.x, Ie.y + 2 * Ve.y, !1, me, 0, I, Ue)), K === "fakeround") { const Fe = Math.round(180 * ue / Math.PI / 20); this.addHalfVertex(M, Ve.x, Ve.y, !1, me, 0, I, Ue); for (let et = 0; et < Fe; et++) { let dt = et / Fe; if (dt !== 0.5) { const Mt = dt - 0.5; dt += dt * Mt * (dt - 1) * ((1.0904 + Q * (Q * (3.55645 - 1.43519 * Q) - 3.2452)) * Mt * Mt + (0.848013 + Q * (0.215638 * Q - 1.06021))); } const tt = Re.sub(Ve)._mult(dt)._add(Ve)._unit(); this.addHalfVertex(M, tt.x, tt.y, !1, me, 0, I, Ue); } this.addHalfVertex(M, Re.x, Re.y, !1, me, 0, I, Ue); } ze || q != null || this.addHalfVertex(M, Ie.x + 2 * Re.x, Ie.y + 2 * Re.y, !1, me, 0, I, Ue), q != null && k && this.addCurrentVertex(M, U, 1, 1, I, q); } else K === "butt" ? this.addCurrentVertex(M, ie, 0, 0, I, q) : K === "square" ? (C || this.addCurrentVertex(M, ie, -1, -1, I, q), this.addCurrentVertex(M, ie, 0, 0, I, q), C && this.addCurrentVertex(M, ie, 1, 1, I, q)) : K === "round" && (C && (this.addCurrentVertex(M, V, 0, 0, I, q), this.addCurrentVertex(M, V, 1, 1, I, q, !0)), k && (this.addCurrentVertex(M, U, -1, -1, I, q, !0), this.addCurrentVertex(M, U, 0, 0, I, q))); } } addVerticesTo(e, n, o, u, l, f, v, S, D, x) { const P = (n.w - e.w) / this.tessellationStep | 0; let I = 0; const M = this.scaledDistance; if (P > 1) { this.lineSoFar = e.w; const k = (n.x - e.x) / P, V = (n.y - e.y) / P, U = (n.z - e.z) / P, q = (n.w - e.w) / P; for (let $ = 1; $ < P; ++$) { e.x += k, e.y += V, e.z += U, this.lineSoFar += q, I += q; const H = this.evaluateLineProgressFeatures(this.prevDistance + I); this.scaledDistance = (this.prevDistance + I) / this.totalDistance, this.addHalfVertex(e, o, u, x, !1, v, D, H), this.addHalfVertex(e, l, f, x, !0, -S, D, H); } } this.lineSoFar = n.w, this.scaledDistance = M; const C = this.evaluateLineProgressFeatures(this.distance); this.addHalfVertex(n, o, u, x, !1, v, D, C), this.addHalfVertex(n, l, f, x, !0, -S, D, C); } evaluateLineProgressFeatures(e) { if (!this.variableWidthValue && !this.hasZOffset) return null; this.evaluationGlobals.lineProgress = 0, this.lineClips ? this.evaluationGlobals.lineProgress = Math.min(1, (this.totalFeatureLength * this.lineClips.start + e) / this.totalFeatureLength) : mi(`line-progress evaluation for ${this.layerIds[0]} requires enabling 'lineMetrics' for the source.`); let n = 0; return this.variableWidthValue && this.variableWidthValue.kind !== "constant" && (n = this.variableWidthValue.evaluate(this.evaluationGlobals, this.lineFeature) || 0), this.hasZOffset ? this.zOffsetValue.kind === "constant" ? { zOffset: this.zOffsetValue.value, variableWidth: n } : { zOffset: this.zOffsetValue.evaluate(this.evaluationGlobals, this.lineFeature) || 0, variableWidth: n } : { zOffset: 0, variableWidth: n }; } addCurrentVertex(e, n, o, u, l, f, v = !1) { const S = n.x + n.y * o, D = n.y - n.x * o, x = n.y * u - n.x, P = -n.y - n.x * u; if (f != null) { const I = this.hasZOffset, M = -10, C = Tt + 10, k = f.zOffset, V = new Yy(e.x, e.y, k, this.lineSoFar), U = !!I && L_(e, M, C), q = this.lineSoFar, $ = this.distance; if (this.currentVertex) if (U) { const H = this.currentVertexIsOutside, K = this.currentVertex, Q = new Yy(e.x, e.y, k, this.lineSoFar); if (Jy(K, Q, M, C), !L_(Q, M, C)) { if (H) { this.e1 = this.e2 = -1, this.distance -= K.dist(V), this.lineSoFar = K.w; const ie = this.evaluateLineProgressFeatures(K.w - this.totalFeatureLength * (this.lineClips ? this.lineClips.start : 0)); this.addHalfVertex(K, S, D, v, !1, o, l, ie), this.addHalfVertex(K, x, P, v, !0, -u, l, ie), this.prevDistance = this.distance; } this.distance = this.prevDistance + K.dist(Q), this.scaledDistance = this.distance / this.totalDistance, this.addVerticesTo(K, Q, S, D, x, P, o, u, l, v), this.distance = $, this.scaledDistance = this.distance / this.totalDistance; } } else { const H = this.currentVertex; if (this.currentVertexIsOutside) { Jy(H, V, M, C), this.e1 = this.e2 = -1, this.distance -= H.dist(V), this.scaledDistance = this.distance / this.totalDistance, this.lineSoFar = H.w; const K = this.evaluateLineProgressFeatures(H.w - this.totalFeatureLength * (this.lineClips ? this.lineClips.start : 0)); this.addHalfVertex(H, S, D, v, !1, o, l, K), this.addHalfVertex(H, x, P, v, !0, -u, l, K), this.prevDistance = this.distance, this.distance = $, this.scaledDistance = this.distance / this.totalDistance; } this.addVerticesTo(H, V, S, D, x, P, o, u, l, v); } else U || (this.addHalfVertex(e, S, D, v, !1, o, l, f), this.addHalfVertex(e, x, P, v, !0, -u, l, f)); this.currentVertex = V, this.currentVertexIsOutside = U, this.lineSoFar = q; } else this.addHalfVertex(e, S, D, v, !1, o, l, f), this.addHalfVertex(e, x, P, v, !0, -u, l, f); } addHalfVertex({ x: e, y: n }, o, u, l, f, v, S, D) { this.patternJoinNone && (this.segmentPoints.length === 0 && (this.segmentStart = this.lineSoFar, this.segmentStartf32 = Math.fround(this.lineSoFar)), f || this.segmentPoints.push(this.lineSoFar - this.segmentStart, v)), this.layoutVertexArray.emplaceBack((e << 1) + (l ? 1 : 0), (n << 1) + (f ? 1 : 0), Math.round(63 * o) + 128, Math.round(63 * u) + 128, 1 + (v === 0 ? 0 : v < 0 ? -1 : 1), 0, this.lineSoFar - this.segmentStartf32), this.lineClips && this.layoutVertexArray2.emplaceBack(this.scaledDistance, this.lineClipsArray.length, this.lineClips.start, this.lineClips.end); const x = S.vertexLength++; this.e1 >= 0 && this.e2 >= 0 && (this.indexArray.emplaceBack(this.e1, this.e2, x), S.primitiveLength++), f ? this.e2 = x : this.e1 = x, D != null && this.zOffsetVertexArray.emplaceBack(D.zOffset, D.variableWidth); } updateScaledDistance() { this.lineClips ? (this.scaledDistance = this.distance / this.totalDistance, this.lineSoFar = this.totalFeatureLength * this.lineClips.start + this.distance) : this.lineSoFar = this.distance; } updateDistance(e, n) { this.prevDistance = this.distance, this.distance += e.dist(n), this.updateScaledDistance(); } } function L_(r, e, n) { return r.x < e || r.x > n || r.y < e || r.y > n; } let S0, E0; function P0(r, e, n) { return e * (Tt / (r.tileSize * Math.pow(2, n - r.tileID.overscaledZ))); } Ft(I_, "LineBucket", { omit: ["layers", "patternFeatures", "currentVertex", "currentVertexIsOutside"] }); const A0 = (r, e, n) => (1 - n) * r + n * e; function C0(r, e) { return 1 / P0(r, 1, e.tileZoom); } function I0(r, e, n, o) { return r.translatePosMatrix(o || e.tileID.projMatrix, e, n.paint.get("line-translate"), n.paint.get("line-translate-anchor")); } const L0 = (r) => { const e = []; z0(r) && e.push("RENDER_LINE_DASH"), r.paint.get("line-gradient") && e.push("RENDER_LINE_GRADIENT"); const n = r.paint.get("line-trim-offset"); n[0] === 0 && n[1] === 0 || e.push("RENDER_LINE_TRIM_OFFSET"), r.paint.get("line-border-width").constantOr(1) !== 0 && e.push("RENDER_LINE_BORDER"); const o = r.layout.get("line-join").constantOr("miter") === "none", u = !!r.paint.get("line-pattern").constantOr(1); return o && u && e.push("LINE_JOIN_NONE"), e; }; function z0(r) { const e = r.paint.get("line-dasharray").value; return e.value || e.kind !== "constant"; } let z_; const D0 = () => z_ || (z_ = { layout: S0 || (S0 = new Bn({ "line-cap": new Dt($e.layout_line["line-cap"]), "line-join": new Dt($e.layout_line["line-join"]), "line-miter-limit": new yt($e.layout_line["line-miter-limit"]), "line-round-limit": new yt($e.layout_line["line-round-limit"]), "line-sort-key": new Dt($e.layout_line["line-sort-key"]), "line-z-offset": new Dt($e.layout_line["line-z-offset"]), "line-elevation-reference": new yt($e.layout_line["line-elevation-reference"]), "line-cross-slope": new yt($e.layout_line["line-cross-slope"]), visibility: new yt($e.layout_line.visibility), "line-width-unit": new yt($e.layout_line["line-width-unit"]) })), paint: E0 || (E0 = new Bn({ "line-opacity": new Dt($e.paint_line["line-opacity"]), "line-color": new Dt($e.paint_line["line-color"]), "line-translate": new yt($e.paint_line["line-translate"]), "line-translate-anchor": new yt($e.paint_line["line-translate-anchor"]), "line-width": new Dt($e.paint_line["line-width"]), "line-gap-width": new Dt($e.paint_line["line-gap-width"]), "line-offset": new Dt($e.paint_line["line-offset"]), "line-blur": new Dt($e.paint_line["line-blur"]), "line-dasharray": new Dt($e.paint_line["line-dasharray"]), "line-pattern": new Dt($e.paint_line["line-pattern"]), "line-gradient": new Wa($e.paint_line["line-gradient"]), "line-trim-offset": new yt($e.paint_line["line-trim-offset"]), "line-trim-fade-range": new yt($e.paint_line["line-trim-fade-range"]), "line-trim-color": new yt($e.paint_line["line-trim-color"]), "line-emissive-strength": new yt($e.paint_line["line-emissive-strength"]), "line-border-width": new Dt($e.paint_line["line-border-width"]), "line-border-color": new Dt($e.paint_line["line-border-color"]), "line-occlusion-opacity": new yt($e.paint_line["line-occlusion-opacity"]), "line-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "line-gradient-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "line-trim-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "line-border-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, z_); class fT extends Dt { possiblyEvaluate(e, n) { return n = new Tn(Math.floor(n.zoom), { now: n.now, fadeDuration: n.fadeDuration, transition: n.transition }), super.possiblyEvaluate(e, n); } evaluate(e, n, o, u) { return n = An({}, n, { zoom: Math.floor(n.zoom) }), super.evaluate(e, n, o, u); } } let Wd; function k0(r, e) { return e > 0 ? e + 2 * r : r; } const pT = qi([{ name: "a_pos_offset", components: 4, type: "Int16" }, { name: "a_tex_size", components: 4, type: "Uint16" }, { name: "a_pixeloffset", components: 4, type: "Int16" }], 4), mT = qi([{ name: "a_globe_anchor", components: 3, type: "Int16" }, { name: "a_globe_normal", components: 3, type: "Float32" }], 4), _T = qi([{ name: "a_projected_pos", components: 4, type: "Float32" }], 4); qi([{ name: "a_fade_opacity", components: 1, type: "Uint32" }], 4); const gT = qi([{ name: "a_auto_z_offset", components: 1, type: "Float32" }], 4), yT = qi([{ name: "a_texb", components: 2, type: "Uint16" }]), xT = qi([{ name: "a_placed", components: 2, type: "Uint8" }, { name: "a_shift", components: 2, type: "Float32" }, { name: "a_elevation_from_sea", components: 2, type: "Float32" }]), vT = qi([{ name: "a_size_scale", components: 1, type: "Float32" }, { name: "a_padding", components: 2, type: "Float32" }, { name: "a_auto_z_offset", components: 1, type: "Float32" }]); qi([{ 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 R0 = qi([{ name: "a_pos", components: 3, type: "Int16" }, { name: "a_anchor_pos", components: 2, type: "Int16" }, { name: "a_extrude", components: 2, type: "Int16" }], 4), bT = qi([{ name: "a_pos_2f", components: 2, type: "Float32" }, { name: "a_radius", components: 1, type: "Float32" }, { name: "a_flags", components: 2, type: "Int16" }], 4); qi([{ name: "triangle", components: 3, type: "Uint16" }]), qi([{ 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" }]), qi([{ type: "Float32", name: "tileAnchorX" }, { type: "Float32", name: "tileAnchorY" }, { type: "Int16", name: "projectedAnchorX" }, { type: "Int16", name: "projectedAnchorY" }, { type: "Int16", name: "projectedAnchorZ" }, { 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" }, { type: "Float32", name: "zOffset" }, { type: "Uint8", name: "hasIconTextFit" }]), qi([{ type: "Float32", name: "offsetX" }]), qi([{ type: "Int16", name: "x" }, { type: "Int16", name: "y" }]); var tr = 24; const Sa = 128; function Lp(r, e, n, o, u) { if (r.kind === "camera") return r.maxSize; if (r.kind === "composite") { const l = e.possiblyEvaluate(new Tn(r.maxZoom), n).evaluate(u, {}, n), f = e.possiblyEvaluate(new Tn(r.minZoom), n).evaluate(u, {}, n); return Math.max(l, f); } return e.possiblyEvaluate(new Tn(o)).evaluate(u, {}, n); } function D_(r, e) { const { expression: n } = e; if (n.kind === "constant") return { kind: "constant", layoutSize: n.evaluate(new Tn(r + 1)) }; if (n.kind === "source") return { kind: "source" }; { const { zoomStops: o, interpolationType: u } = n; let l = 0; for (; l < o.length && o[l] <= r; ) l++; l = Math.max(0, l - 1); let f = l; for (; f < o.length && o[f] < r + 1; ) f++; f = Math.min(o.length - 1, f); const v = o[l], S = o[f]; return n.kind === "composite" ? { kind: "composite", minZoom: v, maxZoom: S, interpolationType: u } : { kind: "camera", minZoom: v, maxZoom: S, minSize: n.evaluate(new Tn(v)), maxSize: n.evaluate(new Tn(S)), interpolationType: u }; } } function zp(r, { uSize: e, uSizeT: n }, { lowerSize: o, upperSize: u }) { return r.kind === "source" ? o / Sa : r.kind === "composite" ? ei(o / Sa, u / Sa, n) : e; } function Lu(r, e, n = 1) { let o = 0, u = 0; if (r.kind === "constant") u = r.layoutSize * n; else if (r.kind !== "source") { const { interpolationType: l, minZoom: f, maxZoom: v } = r, S = l ? si(X.interpolationFactor(l, e, f, v), 0, 1) : 0; r.kind === "camera" ? u = ei(r.minSize, r.maxSize, S) * n : o = S * n; } return { uSizeT: o, uSize: u }; } var wT = Object.freeze({ __proto__: null, SIZE_PACK_FACTOR: Sa, evaluateSizeForFeature: zp, evaluateSizeForZoom: Lu, getRasterizedIconSize: Lp, getSizeData: D_ }); function TT(r, e, n) { return r.sections.forEach((o) => { o.text = function(u, l, f) { const v = l.layout.get("text-transform").evaluate(f, {}); return v === "uppercase" ? u = u.toLocaleUpperCase() : v === "lowercase" && (u = u.toLocaleLowerCase()), co.applyArabicShaping && (u = co.applyArabicShaping(u)), u; }(o.text, e, n); }), r; } const $d = { "!": "︕", "#": "#", $: "$", "%": "%", "&": "&", "(": "︵", ")": "︶", "*": "*", "+": "+", ",": "︐", "-": "︲", ".": "・", "/": "/", ":": "︓", ";": "︔", "<": "︿", "=": "=", ">": "﹀", "?": "︖", "@": "@", "[": "﹇", "\\": "\", "]": "﹈", "^": "^", _: "︳", "`": "`", "{": "︷", "|": "―", "}": "︸", "~": "~", "¢": "¢", "£": "£", "¥": "¥", "¦": "¦", "¬": "¬", "¯": " ̄", "–": "︲", "—": "︱", "‘": "﹃", "’": "﹄", "“": "﹁", "”": "﹂", "…": "︙", "‧": "・", "₩": "₩", "、": "︑", "。": "︒", "〈": "︿", "〉": "﹀", "《": "︽", "》": "︾", "「": "﹁", "」": "﹂", "『": "﹃", "』": "﹄", "【": "︻", "】": "︼", "〔": "︹", "〕": "︺", "〖": "︗", "〗": "︘", "!": "︕", "(": "︵", ")": "︶", ",": "︐", "-": "︲", ".": "・", ":": "︓", ";": "︔", "<": "︿", ">": "﹀", "?": "︖", "[": "﹇", "]": "﹈", "_": "︳", "{": "︷", "|": "―", "}": "︸", "⦅": "︵", "⦆": "︶", "。": "︒", "「": "﹁", "」": "﹂", "←": "↑", "→": "↓" }; function MT(r) { return r === "︶" || r === "﹈" || r === "︸" || r === "﹄" || r === "﹂" || r === "︾" || r === "︼" || r === "︺" || r === "︘" || r === "﹀" || r === "︐" || r === "︓" || r === "︔" || r === "`" || r === " ̄" || r === "︑" || r === "︒"; } function ST(r) { return r === "︵" || r === "﹇" || r === "︷" || r === "﹃" || r === "﹁" || r === "︽" || r === "︻" || r === "︹" || r === "︗" || r === "︿"; } var O0, k_, F0, R_ = {}; /*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */ function ET() { return O0 || (O0 = 1, R_.read = function(r, e, n, o, u) { var l, f, v = 8 * u - o - 1, S = (1 << v) - 1, D = S >> 1, x = -7, P = n ? u - 1 : 0, I = n ? -1 : 1, M = r[e + P]; for (P += I, l = M & (1 << -x) - 1, M >>= -x, x += v; x > 0; l = 256 * l + r[e + P], P += I, x -= 8) ; for (f = l & (1 << -x) - 1, l >>= -x, x += o; x > 0; f = 256 * f + r[e + P], P += I, x -= 8) ; if (l === 0) l = 1 - D; else { if (l === S) return f ? NaN : 1 / 0 * (M ? -1 : 1); f += Math.pow(2, o), l -= D; } return (M ? -1 : 1) * f * Math.pow(2, l - o); }, R_.write = function(r, e, n, o, u, l) { var f, v, S, D = 8 * l - u - 1, x = (1 << D) - 1, P = x >> 1, I = u === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0, M = o ? 0 : l - 1, C = o ? 1 : -1, k = e < 0 || e === 0 && 1 / e < 0 ? 1 : 0; for (e = Math.abs(e), isNaN(e) || e === 1 / 0 ? (v = isNaN(e) ? 1 : 0, f = x) : (f = Math.floor(Math.log(e) / Math.LN2), e * (S = Math.pow(2, -f)) < 1 && (f--, S *= 2), (e += f + P >= 1 ? I / S : I * Math.pow(2, 1 - P)) * S >= 2 && (f++, S /= 2), f + P >= x ? (v = 0, f = x) : f + P >= 1 ? (v = (e * S - 1) * Math.pow(2, u), f += P) : (v = e * Math.pow(2, P - 1) * Math.pow(2, u), f = 0)); u >= 8; r[n + M] = 255 & v, M += C, v /= 256, u -= 8) ; for (f = f << u | v, D += u; D > 0; r[n + M] = 255 & f, M += C, f /= 256, D -= 8) ; r[n + M - C] |= 128 * k; }), R_; } function B0() { if (F0) return k_; F0 = 1, k_ = e; var r = ET(); function e(H) { this.buf = ArrayBuffer.isView && ArrayBuffer.isView(H) ? H : new Uint8Array(H || 0), this.pos = 0, this.type = 0, this.length = this.buf.length; } e.Varint = 0, e.Fixed64 = 1, e.Bytes = 2, e.Fixed32 = 5; var n = 4294967296, o = 1 / n, u = typeof TextDecoder > "u" ? null : new TextDecoder("utf8"); function l(H) { return H.type === e.Bytes ? H.readVarint() + H.pos : H.pos + 1; } function f(H, K, Q) { return Q ? 4294967296 * K + (H >>> 0) : 4294967296 * (K >>> 0) + (H >>> 0); } function v(H, K, Q) { var ie = K <= 16383 ? 1 : K <= 2097151 ? 2 : K <= 268435455 ? 3 : Math.floor(Math.log(K) / (7 * Math.LN2)); Q.realloc(ie); for (var fe = Q.pos - 1; fe >= H; fe--) Q.buf[fe + ie] = Q.buf[fe]; } function S(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeVarint(H[Q]); } function D(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeSVarint(H[Q]); } function x(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeFloat(H[Q]); } function P(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeDouble(H[Q]); } function I(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeBoolean(H[Q]); } function M(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeFixed32(H[Q]); } function C(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeSFixed32(H[Q]); } function k(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeFixed64(H[Q]); } function V(H, K) { for (var Q = 0; Q < H.length; Q++) K.writeSFixed64(H[Q]); } function U(H, K) { return (H[K] | H[K + 1] << 8 | H[K + 2] << 16) + 16777216 * H[K + 3]; } function q(H, K, Q) { H[Q] = K, H[Q + 1] = K >>> 8, H[Q + 2] = K >>> 16, H[Q + 3] = K >>> 24; } function $(H, K) { return (H[K] | H[K + 1] << 8 | H[K + 2] << 16) + (H[K + 3] << 24); } return e.prototype = { destroy: function() { this.buf = null; }, readFields: function(H, K, Q) { for (Q = Q || this.length; this.pos < Q; ) { var ie = this.readVarint(), fe = ie >> 3, de = this.pos; this.type = 7 & ie, H(fe, K, this), this.pos === de && this.skip(ie); } return K; }, readMessage: function(H, K) { return this.readFields(H, K, this.readVarint() + this.pos); }, readFixed32: function() { var H = U(this.buf, this.pos); return this.pos += 4, H; }, readSFixed32: function() { var H = $(this.buf, this.pos); return this.pos += 4, H; }, readFixed64: function() { var H = U(this.buf, this.pos) + U(this.buf, this.pos + 4) * n; return this.pos += 8, H; }, readSFixed64: function() { var H = U(this.buf, this.pos) + $(this.buf, this.pos + 4) * n; return this.pos += 8, H; }, readFloat: function() { var H = r.read(this.buf, this.pos, !0, 23, 4); return this.pos += 4, H; }, readDouble: function() { var H = r.read(this.buf, this.pos, !0, 52, 8); return this.pos += 8, H; }, readVarint: function(H) { var K, Q, ie = this.buf; return K = 127 & (Q = ie[this.pos++]), Q < 128 ? K : (K |= (127 & (Q = ie[this.pos++])) << 7, Q < 128 ? K : (K |= (127 & (Q = ie[this.pos++])) << 14, Q < 128 ? K : (K |= (127 & (Q = ie[this.pos++])) << 21, Q < 128 ? K : function(fe, de, ue) { var Se, me, Ee = ue.buf; if (Se = (112 & (me = Ee[ue.pos++])) >> 4, me < 128 || (Se |= (127 & (me = Ee[ue.pos++])) << 3, me < 128) || (Se |= (127 & (me = Ee[ue.pos++])) << 10, me < 128) || (Se |= (127 & (me = Ee[ue.pos++])) << 17, me < 128) || (Se |= (127 & (me = Ee[ue.pos++])) << 24, me < 128) || (Se |= (1 & (me = Ee[ue.pos++])) << 31, me < 128)) return f(fe, Se, de); throw new Error("Expected varint not more than 10 bytes"); }(K |= (15 & (Q = ie[this.pos])) << 28, H, this)))); }, readVarint64: function() { return this.readVarint(!0); }, readSVarint: function() { var H = this.readVarint(); return H % 2 == 1 ? (H + 1) / -2 : H / 2; }, readBoolean: function() { return !!this.readVarint(); }, readString: function() { var H = this.readVarint() + this.pos, K = this.pos; return this.pos = H, H - K >= 12 && u ? function(Q, ie, fe) { return u.decode(Q.subarray(ie, fe)); }(this.buf, K, H) : function(Q, ie, fe) { for (var de = "", ue = ie; ue < fe; ) { var Se, me, Ee, ze = Q[ue], Ie = null, Re = ze > 239 ? 4 : ze > 223 ? 3 : ze > 191 ? 2 : 1; if (ue + Re > fe) break; Re === 1 ? ze < 128 && (Ie = ze) : Re === 2 ? (192 & (Se = Q[ue + 1])) == 128 && (Ie = (31 & ze) << 6 | 63 & Se) <= 127 && (Ie = null) : Re === 3 ? (me = Q[ue + 2], (192 & (Se = Q[ue + 1])) == 128 && (192 & me) == 128 && ((Ie = (15 & ze) << 12 | (63 & Se) << 6 | 63 & me) <= 2047 || Ie >= 55296 && Ie <= 57343) && (Ie = null)) : Re === 4 && (me = Q[ue + 2], Ee = Q[ue + 3], (192 & (Se = Q[ue + 1])) == 128 && (192 & me) == 128 && (192 & Ee) == 128 && ((Ie = (15 & ze) << 18 | (63 & Se) << 12 | (63 & me) << 6 | 63 & Ee) <= 65535 || Ie >= 1114112) && (Ie = null)), Ie === null ? (Ie = 65533, Re = 1) : Ie > 65535 && (Ie -= 65536, de += String.fromCharCode(Ie >>> 10 & 1023 | 55296), Ie = 56320 | 1023 & Ie), de += String.fromCharCode(Ie), ue += Re; } return de; }(this.buf, K, H); }, readBytes: function() { var H = this.readVarint() + this.pos, K = this.buf.subarray(this.pos, H); return this.pos = H, K; }, readPackedVarint: function(H, K) { if (this.type !== e.Bytes) return H.push(this.readVarint(K)); var Q = l(this); for (H = H || []; this.pos < Q; ) H.push(this.readVarint(K)); return H; }, readPackedSVarint: function(H) { if (this.type !== e.Bytes) return H.push(this.readSVarint()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readSVarint()); return H; }, readPackedBoolean: function(H) { if (this.type !== e.Bytes) return H.push(this.readBoolean()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readBoolean()); return H; }, readPackedFloat: function(H) { if (this.type !== e.Bytes) return H.push(this.readFloat()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readFloat()); return H; }, readPackedDouble: function(H) { if (this.type !== e.Bytes) return H.push(this.readDouble()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readDouble()); return H; }, readPackedFixed32: function(H) { if (this.type !== e.Bytes) return H.push(this.readFixed32()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readFixed32()); return H; }, readPackedSFixed32: function(H) { if (this.type !== e.Bytes) return H.push(this.readSFixed32()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readSFixed32()); return H; }, readPackedFixed64: function(H) { if (this.type !== e.Bytes) return H.push(this.readFixed64()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readFixed64()); return H; }, readPackedSFixed64: function(H) { if (this.type !== e.Bytes) return H.push(this.readSFixed64()); var K = l(this); for (H = H || []; this.pos < K; ) H.push(this.readSFixed64()); return H; }, skip: function(H) { var K = 7 & H; if (K === e.Varint) for (; this.buf[this.pos++] > 127; ) ; else if (K === e.Bytes) this.pos = this.readVarint() + this.pos; else if (K === e.Fixed32) this.pos += 4; else { if (K !== e.Fixed64) throw new Error("Unimplemented type: " + K); this.pos += 8; } }, writeTag: function(H, K) { this.writeVarint(H << 3 | K); }, realloc: function(H) { for (var K = this.length || 16; K < this.pos + H; ) K *= 2; if (K !== this.length) { var Q = new Uint8Array(K); Q.set(this.buf), this.buf = Q, this.length = K; } }, finish: function() { return this.length = this.pos, this.pos = 0, this.buf.subarray(0, this.length); }, writeFixed32: function(H) { this.realloc(4), q(this.buf, H, this.pos), this.pos += 4; }, writeSFixed32: function(H) { this.realloc(4), q(this.buf, H, this.pos), this.pos += 4; }, writeFixed64: function(H) { this.realloc(8), q(this.buf, -1 & H, this.pos), q(this.buf, Math.floor(H * o), this.pos + 4), this.pos += 8; }, writeSFixed64: function(H) { this.realloc(8), q(this.buf, -1 & H, this.pos), q(this.buf, Math.floor(H * o), this.pos + 4), this.pos += 8; }, writeVarint: function(H) { (H = +H || 0) > 268435455 || H < 0 ? function(K, Q) { var ie, fe; if (K >= 0 ? (ie = K % 4294967296 | 0, fe = K / 4294967296 | 0) : (fe = ~(-K / 4294967296), 4294967295 ^ (ie = ~(-K % 4294967296)) ? ie = ie + 1 | 0 : (ie = 0, fe = fe + 1 | 0)), K >= 18446744073709552e3 || K < -18446744073709552e3) throw new Error("Given varint doesn't fit into 10 bytes"); Q.realloc(10), function(de, ue, Se) { Se.buf[Se.pos++] = 127 & de | 128, de >>>= 7, Se.buf[Se.pos++] = 127 & de | 128, de >>>= 7, Se.buf[Se.pos++] = 127 & de | 128, de >>>= 7, Se.buf[Se.pos++] = 127 & de | 128, Se.buf[Se.pos] = 127 & (de >>>= 7); }(ie, 0, Q), function(de, ue) { var Se = (7 & de) << 4; ue.buf[ue.pos++] |= Se | ((de >>>= 3) ? 128 : 0), de && (ue.buf[ue.pos++] = 127 & de | ((de >>>= 7) ? 128 : 0), de && (ue.buf[ue.pos++] = 127 & de | ((de >>>= 7) ? 128 : 0), de && (ue.buf[ue.pos++] = 127 & de | ((de >>>= 7) ? 128 : 0), de && (ue.buf[ue.pos++] = 127 & de | ((de >>>= 7) ? 128 : 0), de && (ue.buf[ue.pos++] = 127 & de))))); }(fe, Q); }(H, this) : (this.realloc(4), this.buf[this.pos++] = 127 & H | (H > 127 ? 128 : 0), H <= 127 || (this.buf[this.pos++] = 127 & (H >>>= 7) | (H > 127 ? 128 : 0), H <= 127 || (this.buf[this.pos++] = 127 & (H >>>= 7) | (H > 127 ? 128 : 0), H <= 127 || (this.buf[this.pos++] = H >>> 7 & 127)))); }, writeSVarint: function(H) { this.writeVarint(H < 0 ? 2 * -H - 1 : 2 * H); }, writeBoolean: function(H) { this.writeVarint(!!H); }, writeString: function(H) { H = String(H), this.realloc(4 * H.length), this.pos++; var K = this.pos; this.pos = function(ie, fe, de) { for (var ue, Se, me = 0; me < fe.length; me++) { if ((ue = fe.charCodeAt(me)) > 55295 && ue < 57344) { if (!Se) { ue > 56319 || me + 1 === fe.length ? (ie[de++] = 239, ie[de++] = 191, ie[de++] = 189) : Se = ue; continue; } if (ue < 56320) { ie[de++] = 239, ie[de++] = 191, ie[de++] = 189, Se = ue; continue; } ue = Se - 55296 << 10 | ue - 56320 | 65536, Se = null; } else Se && (ie[de++] = 239, ie[de++] = 191, ie[de++] = 189, Se = null); ue < 128 ? ie[de++] = ue : (ue < 2048 ? ie[de++] = ue >> 6 | 192 : (ue < 65536 ? ie[de++] = ue >> 12 | 224 : (ie[de++] = ue >> 18 | 240, ie[de++] = ue >> 12 & 63 | 128), ie[de++] = ue >> 6 & 63 | 128), ie[de++] = 63 & ue | 128); } return de; }(this.buf, H, this.pos); var Q = this.pos - K; Q >= 128 && v(K, Q, this), this.pos = K - 1, this.writeVarint(Q), this.pos += Q; }, writeFloat: function(H) { this.realloc(4), r.write(this.buf, H, this.pos, !0, 23, 4), this.pos += 4; }, writeDouble: function(H) { this.realloc(8), r.write(this.buf, H, this.pos, !0, 52, 8), this.pos += 8; }, writeBytes: function(H) { var K = H.length; this.writeVarint(K), this.realloc(K); for (var Q = 0; Q < K; Q++) this.buf[this.pos++] = H[Q]; }, writeRawMessage: function(H, K) { this.pos++; var Q = this.pos; H(K, this); var ie = this.pos - Q; ie >= 128 && v(Q, ie, this), this.pos = Q - 1, this.writeVarint(ie), this.pos += ie; }, writeMessage: function(H, K, Q) { this.writeTag(H, e.Bytes), this.writeRawMessage(K, Q); }, writePackedVarint: function(H, K) { K.length && this.writeMessage(H, S, K); }, writePackedSVarint: function(H, K) { K.length && this.writeMessage(H, D, K); }, writePackedBoolean: function(H, K) { K.length && this.writeMessage(H, I, K); }, writePackedFloat: function(H, K) { K.length && this.writeMessage(H, x, K); }, writePackedDouble: function(H, K) { K.length && this.writeMessage(H, P, K); }, writePackedFixed32: function(H, K) { K.length && this.writeMessage(H, M, K); }, writePackedSFixed32: function(H, K) { K.length && this.writeMessage(H, C, K); }, writePackedFixed64: function(H, K) { K.length && this.writeMessage(H, k, K); }, writePackedSFixed64: function(H, K) { K.length && this.writeMessage(H, V, K); }, writeBytesField: function(H, K) { this.writeTag(H, e.Bytes), this.writeBytes(K); }, writeFixed32Field: function(H, K) { this.writeTag(H, e.Fixed32), this.writeFixed32(K); }, writeSFixed32Field: function(H, K) { this.writeTag(H, e.Fixed32), this.writeSFixed32(K); }, writeFixed64Field: function(H, K) { this.writeTag(H, e.Fixed64), this.writeFixed64(K); }, writeSFixed64Field: function(H, K) { this.writeTag(H, e.Fixed64), this.writeSFixed64(K); }, writeVarintField: function(H, K) { this.writeTag(H, e.Varint), this.writeVarint(K); }, writeSVarintField: function(H, K) { this.writeTag(H, e.Varint), this.writeSVarint(K); }, writeStringField: function(H, K) { this.writeTag(H, e.Bytes), this.writeString(K); }, writeFloatField: function(H, K) { this.writeTag(H, e.Fixed32), this.writeFloat(K); }, writeDoubleField: function(H, K) { this.writeTag(H, e.Fixed64), this.writeDouble(K); }, writeBooleanField: function(H, K) { this.writeVarintField(H, !!K); } }, k_; } var Dp = O(B0()); const O_ = 3; function PT(r, e, n) { e.glyphs = [], r === 1 && n.readMessage(AT, e); } function AT(r, e, n) { if (r === 3) { const { id: o, bitmap: u, width: l, height: f, left: v, top: S, advance: D } = n.readMessage(CT, {}); e.glyphs.push({ id: o, bitmap: new gc({ width: l + 2 * O_, height: f + 2 * O_ }, u), metrics: { width: l, height: f, left: v, top: S, advance: D } }); } else r === 4 ? e.ascender = n.readSVarint() : r === 5 && (e.descender = n.readSVarint()); } function CT(r, e, n) { r === 1 ? e.id = n.readVarint() : r === 2 ? e.bitmap = n.readBytes() : r === 3 ? e.width = n.readVarint() : r === 4 ? e.height = n.readVarint() : r === 5 ? e.left = n.readSVarint() : r === 6 ? e.top = n.readSVarint() : r === 7 && (e.advance = n.readVarint()); } const N0 = O_, Ro = { horizontal: 1, vertical: 2, horizontalOnly: 3 }; class Xd { constructor() { this.scale = 1, this.fontStack = "", this.image = null; } static forText(e, n) { const o = new Xd(); return o.scale = e || 1, o.fontStack = n, o; } static forImage(e) { const n = new Xd(); return n.image = e, n; } } class zu { constructor() { this.text = "", this.sectionIndex = [], this.sections = [], this.imageSectionID = null; } static fromFeature(e, n) { const o = new zu(); for (let u = 0; u < e.sections.length; u++) { const l = e.sections[u]; l.image ? o.addImageSection(l) : o.addTextSection(l, n); } return o; } length() { return this.text.length; } getSection(e) { return this.sections[this.sectionIndex[e]]; } getSections() { return this.sections; } getSectionIndex(e) { return this.sectionIndex[e]; } getCodePoint(e) { return this.text.codePointAt(e); } verticalizePunctuation(e) { this.text = function(n, o) { let u = ""; for (let l = 0; l < n.length; l++) { const f = n.charCodeAt(l + 1) || null, v = n.charCodeAt(l - 1) || null; u += !o && (f && _d(f) && !$d[n[l + 1]] || v && _d(v) && !$d[n[l - 1]]) || !$d[n[l]] ? n[l] : $d[n[l]]; } return u; }(this.text, e); } trim() { let e = 0; for (let o = 0; o < this.text.length && kp[this.text.charCodeAt(o)]; o++) e++; let n = this.text.length; for (let o = this.text.length - 1; o >= 0 && o >= e && kp[this.text.charCodeAt(o)]; o--) n--; this.text = this.text.substring(e, n), this.sectionIndex = this.sectionIndex.slice(e, n); } substring(e, n) { const o = new zu(); return o.text = this.text.substring(e, n), o.sectionIndex = this.sectionIndex.slice(e, n), o.sections = this.sections, o; } toString() { return this.text; } getMaxScale() { return this.sectionIndex.reduce((e, n) => Math.max(e, this.sections[n].scale), 0); } addTextSection(e, n) { this.text += e.text, this.sections.push(Xd.forText(e.scale, e.fontStack || n)); const o = this.sections.length - 1; for (let u = 0; u < e.text.length; ++u) this.sectionIndex.push(o); } addImageSection(e) { const n = e.image && e.image.namePrimary ? e.image.getPrimary() : null; if (!n) return void mi("Can't add FormattedSection with an empty image."); const o = this.getNextImageSectionCharCode(); o ? (this.text += String.fromCodePoint(o), this.sections.push(Xd.forImage(n)), this.sectionIndex.push(this.sections.length - 1)) : mi("Reached maximum number of images 6401"); } getNextImageSectionCharCode() { return this.imageSectionID ? this.imageSectionID >= 63743 ? null : ++this.imageSectionID : (this.imageSectionID = 57344, this.imageSectionID); } } function F_(r, e, n, o, u, l, f, v, S, D, x, P, I, M, C) { const k = zu.fromFeature(r, u); P === Ro.vertical && k.verticalizePunctuation(I); let V = []; const U = function(Q, ie, fe, de, ue, Se) { if (!Q) return []; const me = [], Ee = function(Ve, Ue, Fe, et, dt, tt) { let Mt = 0; for (let wt = 0; wt < Ve.length(); wt++) { const At = Ve.getSection(wt); Mt += V0(Ve.getCodePoint(wt), At, et, dt, Ue, tt); } return Mt / Math.max(1, Math.ceil(Mt / Fe)); }(Q, ie, fe, de, ue, Se), ze = Q.text.indexOf("​") >= 0; let Ie = 0; for (let Ve = 0; Ve < Q.length(); Ve++) { const Ue = Q.getSection(Ve), Fe = Q.getCodePoint(Ve); if (kp[Fe] || (Ie += V0(Fe, Ue, de, ue, ie, Se)), Ve < Q.length() - 1) { const et = !((Re = Fe) < 11904 || !(Zt["Bopomofo Extended"](Re) || Zt.Bopomofo(Re) || Zt["CJK Compatibility Forms"](Re) || Zt["CJK Compatibility Ideographs"](Re) || Zt["CJK Compatibility"](Re) || Zt["CJK Radicals Supplement"](Re) || Zt["CJK Strokes"](Re) || Zt["CJK Symbols and Punctuation"](Re) || Zt["CJK Unified Ideographs Extension A"](Re) || Zt["CJK Unified Ideographs"](Re) || Zt["Enclosed CJK Letters and Months"](Re) || Zt["Halfwidth and Fullwidth Forms"](Re) || Zt.Hiragana(Re) || Zt["Ideographic Description Characters"](Re) || Zt["Kangxi Radicals"](Re) || Zt["Katakana Phonetic Extensions"](Re) || Zt.Katakana(Re) || Zt["Vertical Forms"](Re) || Zt["Yi Radicals"](Re) || Zt["Yi Syllables"](Re))); (IT[Fe] || et || Ue.image) && me.push(j0(Ve + 1, Ie, Ee, me, LT(Fe, Q.getCodePoint(Ve + 1), et && ze), !1)); } } var Re; return G0(j0(Q.length(), Ie, Ee, me, 0, !0)); }(k, D, l, e, o, M), { processBidirectionalText: q, processStyledBidirectionalText: $ } = co; if (q && k.sections.length === 1) { const Q = q(k.toString(), U); for (const ie of Q) { const fe = new zu(); fe.text = ie, fe.sections = k.sections; for (let de = 0; de < ie.length; de++) fe.sectionIndex.push(0); V.push(fe); } } else if ($) { const Q = $(k.text, k.sectionIndex, U); for (const ie of Q) { const fe = new zu(); fe.text = ie[0], fe.sectionIndex = ie[1], fe.sections = k.sections, V.push(fe); } } else V = function(Q, ie) { const fe = [], de = Q.text; let ue = 0; for (const Se of ie) fe.push(Q.substring(ue, Se)), ue = Se; return ue < de.length && fe.push(Q.substring(ue, de.length)), fe; }(k, U); const H = [], K = { positionedLines: H, text: k.toString(), top: x[1], bottom: x[1], left: x[0], right: x[0], writingMode: P, iconsInText: !1, verticalizable: !1, hasBaseline: !1 }; return function(Q, ie, fe, de, ue, Se, me, Ee, ze, Ie, Re, Ve) { let Ue = 0, Fe = 0, et = 0; const dt = Ee === "right" ? 1 : Ee === "left" ? 0 : 0.5; let tt = !1; for (const St of ue) { const Nt = St.getSections(); for (const Qt of Nt) { if (Qt.image) continue; const pi = ie[Qt.fontStack]; if (pi && (tt = pi.ascender !== void 0 && pi.descender !== void 0, !tt)) break; } if (!tt) break; } let Mt = 0; for (const St of ue) { St.trim(); const Nt = St.getMaxScale(), Qt = (Nt - 1) * tr, pi = { positionedGlyphs: [], lineOffset: 0 }; Q.positionedLines[Mt] = pi; const gi = pi.positionedGlyphs; let Ai = 0; if (!St.length()) { Fe += Se, ++Mt; continue; } let yi = 0, Ii = 0; for (let rn = 0; rn < St.length(); rn++) { const hi = St.getSection(rn), on = St.getSectionIndex(rn), Qi = St.getCodePoint(rn); let pn = hi.scale, as = null, ls = null, Kn = null, Vr = tr, Sn = 0; const Ln = !(ze === Ro.horizontal || !Re && !su(Qi) || Re && (kp[Qi] || (wt = Qi, Zt.Arabic(wt) || Zt["Arabic Supplement"](wt) || Zt["Arabic Extended-A"](wt) || Zt["Arabic Presentation Forms-A"](wt) || Zt["Arabic Presentation Forms-B"](wt)))); if (hi.image) { const Tr = de[hi.image.serialize()]; if (!Tr) continue; Kn = hi.image.id, Q.iconsInText = Q.iconsInText || !0, ls = Tr.paddedRect; const cs = Tr.displaySize; pn = pn * tr / Ve, as = { width: cs[0], height: cs[1], left: 0, top: -N0, advance: Ln ? cs[1] : cs[0], localGlyph: !1 }, Sn = tt ? -as.height * pn : Nt * tr - 17 - cs[1] * pn, Vr = as.advance; const to = (Ln ? cs[0] : cs[1]) * pn - tr * Nt; to > 0 && to > Ai && (Ai = to); } else { const Tr = fe[hi.fontStack]; if (!Tr) continue; Tr[Qi] && (ls = Tr[Qi]); const cs = ie[hi.fontStack]; if (!cs) continue; const to = cs.glyphs[Qi]; if (!to) continue; if (as = to.metrics, Vr = Qi !== 8203 ? tr : 0, tt) { const Ms = cs.ascender !== void 0 ? Math.abs(cs.ascender) : 0, sl = cs.descender !== void 0 ? Math.abs(cs.descender) : 0, Mc = (Ms + sl) * pn; yi < Mc && (yi = Mc, Ii = (Ms - sl) / 2 * pn), Sn = -Ms * pn; } else Sn = (Nt - pn) * tr - 17; } Ln ? (Q.verticalizable = !0, gi.push({ glyph: Qi, imageName: Kn, x: Ue, y: Fe + Sn, vertical: Ln, scale: pn, localGlyph: as.localGlyph, fontStack: hi.fontStack, sectionIndex: on, metrics: as, rect: ls }), Ue += Vr * pn + Ie) : (gi.push({ glyph: Qi, imageName: Kn, x: Ue, y: Fe + Sn, vertical: Ln, scale: pn, localGlyph: as.localGlyph, fontStack: hi.fontStack, sectionIndex: on, metrics: as, rect: ls }), Ue += as.advance * pn + Ie); } gi.length !== 0 && (et = Math.max(Ue - Ie, et), tt ? Z0(gi, dt, Ai, Ii, Se * Nt / 2) : Z0(gi, dt, Ai, 0, Se / 2)), Ue = 0; const fn = Se * Nt + Ai; pi.lineOffset = Math.max(Ai, Qt), Fe += fn, ++Mt; } var wt; const At = Fe, { horizontalAlign: rt, verticalAlign: Ut } = B_(me); (function(St, Nt, Qt, pi, gi, Ai) { const yi = (Nt - Qt) * gi, Ii = -Ai * pi; for (const fn of St) for (const rn of fn.positionedGlyphs) rn.x += yi, rn.y += Ii; })(Q.positionedLines, dt, rt, Ut, et, At), Q.top += -Ut * At, Q.bottom = Q.top + At, Q.left += -rt * et, Q.right = Q.left + et, Q.hasBaseline = tt; }(K, e, n, o, V, f, v, S, P, D, I, C), !function(Q) { for (const ie of Q) if (ie.positionedGlyphs.length !== 0) return !1; return !0; }(H) && K; } const kp = { 9: !0, 10: !0, 11: !0, 12: !0, 13: !0, 32: !0 }, IT = { 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 V0(r, e, n, o, u, l) { if (e.image) { const f = o[e.image.serialize()]; return f ? f.displaySize[0] * e.scale * tr / l + u : 0; } { const f = n[e.fontStack], v = f && f.glyphs[r]; return v ? v.metrics.advance * e.scale + u : 0; } } function U0(r, e, n, o) { const u = Math.pow(r - e, 2); return o ? r < e ? u / 2 : 2 * u : u + Math.abs(n) * n; } function LT(r, e, n) { let o = 0; return r === 10 && (o -= 1e4), n && (o += 150), r !== 40 && r !== 65288 || (o += 50), e !== 41 && e !== 65289 || (o += 50), o; } function j0(r, e, n, o, u, l) { let f = null, v = U0(e, n, u, l); for (const S of o) { const D = U0(e - S.x, n, u, l) + S.badness; D <= v && (f = S, v = D); } return { index: r, x: e, priorBreak: f, badness: v }; } function G0(r) { return r ? G0(r.priorBreak).concat(r.index) : []; } function B_(r) { let e = 0.5, n = 0.5; switch (r) { case "right": case "top-right": case "bottom-right": e = 1; break; case "left": case "top-left": case "bottom-left": e = 0; } switch (r) { case "bottom": case "bottom-right": case "bottom-left": n = 1; break; case "top": case "top-right": case "top-left": n = 0; } return { horizontalAlign: e, verticalAlign: n }; } function Z0(r, e, n, o, u) { if (!(e || n || o || u)) return; const l = r.length - 1, f = r[l], v = (f.x + f.metrics.advance * f.scale) * e; for (let S = 0; S <= l; S++) r[S].x -= v, r[S].y += n + o + u; } function zT(r, e, n, o) { const { horizontalAlign: u, verticalAlign: l } = B_(o), f = n[0] - r.displaySize[0] * u, v = n[1] - r.displaySize[1] * l; return { imagePrimary: r, imageSecondary: e, top: v, bottom: v + r.displaySize[1], left: f, right: f + r.displaySize[0] }; } function H0(r, e, n, o, u, l) { const f = r.imagePrimary; let v; if (f.content) { const V = f.content, U = f.pixelRatio || 1; v = [V[0] / U, V[1] / U, f.displaySize[0] - V[2] / U, f.displaySize[1] - V[3] / U]; } const S = e.left * l, D = e.right * l; let x, P, I, M; n === "width" || n === "both" ? (M = u[0] + S - o[3], P = u[0] + D + o[1]) : (M = u[0] + (S + D - f.displaySize[0]) / 2, P = M + f.displaySize[0]); const C = e.top * l, k = e.bottom * l; return n === "height" || n === "both" ? (x = u[1] + C - o[0], I = u[1] + k + o[2]) : (x = u[1] + (C + k - f.displaySize[1]) / 2, I = x + f.displaySize[1]), { imagePrimary: f, imageSecondary: void 0, top: x, right: P, bottom: I, left: M, collisionPadding: v }; } class zl extends Et { constructor(e, n, o, u, l) { super(e, n), this.angle = u, this.z = o, l !== void 0 && (this.segment = l); } clone() { return new zl(this.x, this.y, this.z, this.angle, this.segment); } } function q0(r, e, n, o, u) { if (e.segment === void 0) return !0; let l = e, f = e.segment + 1, v = 0; for (; v > -n / 2; ) { if (f--, f < 0) return !1; v -= r[f].dist(l), l = r[f]; } v += r[f].dist(r[f + 1]), f++; const S = []; let D = 0; for (; v < n / 2; ) { const x = r[f], P = r[f + 1]; if (!P) return !1; let I = r[f - 1].angleTo(x) - x.angleTo(P); for (I = Math.abs((I + 3 * Math.PI) % (2 * Math.PI) - Math.PI), S.push({ distance: v, angleDelta: I }), D += I; v - S[0].distance > o; ) D -= S.shift().angleDelta; if (D > u) return !1; f++, v += x.dist(P); } return !0; } function W0(r) { let e = 0; for (let n = 0; n < r.length - 1; n++) e += r[n].dist(r[n + 1]); return e; } function $0(r, e, n) { return r ? 0.6 * e * n : 0; } function X0(r, e) { return Math.max(r ? r.right - r.left : 0, e ? e.right - e.left : 0); } function DT(r, e, n, o, u, l) { const f = $0(n, u, l), v = X0(n, o) * l; let S = 0; const D = W0(r) / 2; for (let x = 0; x < r.length - 1; x++) { const P = r[x], I = r[x + 1], M = P.dist(I); if (S + M > D) { const C = (D - S) / M, k = ei(P.x, I.x, C), V = ei(P.y, I.y, C), U = new zl(k, V, 0, I.angleTo(P), x); return !f || q0(r, U, v, f, e) ? U : void 0; } S += M; } } function kT(r, e, n, o, u, l, f, v, S) { const D = $0(o, l, f), x = X0(o, u), P = x * f, I = r[0].x === 0 || r[0].x === S || r[0].y === 0 || r[0].y === S; return e - P < e / 4 && (e = P + e / 4), Y0(r, I ? e / 2 * v % e : (x / 2 + 2 * l) * f * v % e, e, D, n, P, I, !1, S); } function Y0(r, e, n, o, u, l, f, v, S) { const D = l / 2, x = W0(r); let P = 0, I = e - n, M = []; for (let C = 0; C < r.length - 1; C++) { const k = r[C], V = r[C + 1], U = k.dist(V), q = V.angleTo(k); for (; I + n < P + U; ) { I += n; const $ = (I - P) / U, H = ei(k.x, V.x, $), K = ei(k.y, V.y, $); if (H >= 0 && H < S && K >= 0 && K < S && I - D >= 0 && I + D <= x) { const Q = new zl(H, K, 0, q, C); o && !q0(r, Q, l, o, u) || M.push(Q); } } P += U; } return v || M.length || f || (M = Y0(r, P / 2, n, o, u, l, f, !0, S)), M; } function K0(r, e, n, o, u) { const l = []; for (let f = 0; f < r.length; f++) { const v = r[f]; let S; for (let D = 0; D < v.length - 1; D++) { let x = v[D], P = v[D + 1]; x.x < e && P.x < e || (x.x < e ? x = new Et(e, x.y + (e - x.x) / (P.x - x.x) * (P.y - x.y))._round() : P.x < e && (P = new Et(e, x.y + (e - x.x) / (P.x - x.x) * (P.y - x.y))._round()), x.y < n && P.y < n || (x.y < n ? x = new Et(x.x + (n - x.y) / (P.y - x.y) * (P.x - x.x), n)._round() : P.y < n && (P = new Et(x.x + (n - x.y) / (P.y - x.y) * (P.x - x.x), n)._round()), x.x >= o && P.x >= o || (x.x >= o ? x = new Et(o, x.y + (o - x.x) / (P.x - x.x) * (P.y - x.y))._round() : P.x >= o && (P = new Et(o, x.y + (o - x.x) / (P.x - x.x) * (P.y - x.y))._round()), x.y >= u && P.y >= u || (x.y >= u ? x = new Et(x.x + (u - x.y) / (P.y - x.y) * (P.x - x.x), u)._round() : P.y >= u && (P = new Et(x.x + (u - x.y) / (P.y - x.y) * (P.x - x.x), u)._round()), S && x.equals(S[S.length - 1]) || (S = [x], l.push(S)), S.push(P))))); } } return l; } function J0(r) { let e = 0, n = 0; for (const f of r) e += f.w * f.h, n = Math.max(n, f.w); r.sort((f, v) => v.h - f.h); const o = [{ x: 0, y: 0, w: Math.max(Math.ceil(Math.sqrt(e / 0.95)), n), h: 1 / 0 }]; let u = 0, l = 0; for (const f of r) for (let v = o.length - 1; v >= 0; v--) { const S = o[v]; if (!(f.w > S.w || f.h > S.h)) { if (f.x = S.x, f.y = S.y, l = Math.max(l, f.y + f.h), u = Math.max(u, f.x + f.w), f.w === S.w && f.h === S.h) { const D = o.pop(); v < o.length && (o[v] = D); } else f.h === S.h ? (S.x += f.w, S.w -= f.w) : f.w === S.w ? (S.y += f.h, S.h -= f.h) : (o.push({ x: S.x + f.w, y: S.y, w: S.w - f.w, h: f.h }), S.y += f.h, S.h -= f.h); break; } } return { w: u, h: l, fill: e / (u * l) || 0 }; } Ft(zl, "Anchor"); const Yd = 1; class N_ { constructor(e, { pixelRatio: n, version: o, stretchX: u, stretchY: l, content: f }, v) { this.paddedRect = e, this.pixelRatio = n, this.stretchX = u, this.stretchY = l, this.content = f, this.version = o, this.padding = v; } get tl() { return [this.paddedRect.x + this.padding, this.paddedRect.y + this.padding]; } get br() { return [this.paddedRect.x + this.paddedRect.w - this.padding, this.paddedRect.y + this.paddedRect.h - this.padding]; } get displaySize() { return [(this.paddedRect.w - 2 * this.padding) / this.pixelRatio, (this.paddedRect.h - 2 * this.padding) / this.pixelRatio]; } } class Q0 { constructor(e, n, o) { const u = {}, l = {}; this.haveRenderCallbacks = []; const f = []; this.addImages(e, u, Yd, f), this.addImages(n, l, 2, f); const { w: v, h: S } = J0(f), D = new _r({ width: v || 1, height: S || 1 }); for (const x in e) { const P = e[x], I = u[x].paddedRect; _r.copy(P.data, D, { x: 0, y: 0 }, { x: I.x + Yd, y: I.y + Yd }, P.data, o, P.sdf); } for (const x in n) { const P = n[x], I = l[x].paddedRect; let M = l[x].padding; const C = I.x + M, k = I.y + M, V = P.data.width, U = P.data.height; M = M > 1 ? M - 1 : M, _r.copy(P.data, D, { x: 0, y: 0 }, { x: C, y: k }, P.data, o), _r.copy(P.data, D, { x: 0, y: U - M }, { x: C, y: k - M }, { width: V, height: M }, o), _r.copy(P.data, D, { x: 0, y: 0 }, { x: C, y: k + U }, { width: V, height: M }, o), _r.copy(P.data, D, { x: V - M, y: 0 }, { x: C - M, y: k }, { width: M, height: U }, o), _r.copy(P.data, D, { x: 0, y: 0 }, { x: C + V, y: k }, { width: M, height: U }, o), _r.copy(P.data, D, { x: V - M, y: U - M }, { x: C - M, y: k - M }, { width: M, height: M }, o), _r.copy(P.data, D, { x: 0, y: U - M }, { x: C + V, y: k - M }, { width: M, height: M }, o), _r.copy(P.data, D, { x: 0, y: 0 }, { x: C + V, y: k + U }, { width: M, height: M }, o), _r.copy(P.data, D, { x: V - M, y: 0 }, { x: C - M, y: k + U }, { width: M, height: M }, o); } this.image = D, this.iconPositions = u, this.patternPositions = l; } addImages(e, n, o, u) { for (const l in e) { const f = e[l], v = { x: 0, y: 0, w: f.data.width + 2 * o, h: f.data.height + 2 * o }; u.push(v), n[l] = new N_(v, f, o), f.hasRenderCallback && this.haveRenderCallbacks.push(rr.deserializeId(l)); } } patchUpdatedImages(e, n, o) { this.haveRenderCallbacks = this.haveRenderCallbacks.filter((u) => e.hasImage(u, o)), e.dispatchRenderCallbacks(this.haveRenderCallbacks, o); for (const u in e.getUpdatedImages(o)) { for (const l of Object.keys(this.iconPositions)) rr.deserializeId(l) === u && this.patchUpdatedImage(this.iconPositions[l], e.getImage(u, o), n); for (const l of Object.keys(this.patternPositions)) rr.deserializeId(l) === u && this.patchUpdatedImage(this.patternPositions[l], e.getImage(u, o), n); } } patchUpdatedImage(e, n, o) { if (!e || !n || e.version === n.version) return; e.version = n.version; const [u, l] = e.tl; o.update(n.data, { position: { x: u, y: l } }); } } Ft(N_, "ImagePosition"), Ft(Q0, "ImageAtlas"); const Kd = 1e20; function ex(r, e, n, o, u, l, f, v, S) { for (let D = e; D < e + o; D++) tx(r, n * l + D, l, u, f, v, S); for (let D = n; D < n + u; D++) tx(r, D * l + e, 1, o, f, v, S); } function tx(r, e, n, o, u, l, f) { l[0] = 0, f[0] = -Kd, f[1] = Kd, u[0] = r[e]; for (let v = 1, S = 0, D = 0; v < o; v++) { u[v] = r[e + v * n]; const x = v * v; do { const P = l[S]; D = (u[v] - u[P] + x - P * P) / (v - P) / 2; } while (D <= f[S] && --S > -1); S++, l[S] = v, f[S] = D, f[S + 1] = Kd; } for (let v = 0, S = 0; v < o; v++) { for (; f[S + 1] < v; ) S++; const D = l[S], x = v - D; r[e + v * n] = u[D] + x * x; } } const Ea = 2, V_ = { none: 0, ideographs: 1, all: 2 }; class Du { constructor(e, n, o) { this.requestManager = e, this.localGlyphMode = n, this.localFontFamily = o, this.urls = {}, this.entries = {}, this.localGlyphs = { 200: {}, 400: {}, 500: {}, 900: {} }; } setURL(e, n) { this.urls[n] = e; } getGlyphs(e, n, o) { const u = [], l = this.urls[n] || ge.GLYPHS_URL; for (const f in e) for (const v of e[f]) u.push({ stack: f, id: v }); Rn(u, ({ stack: f, id: v }, S) => { let D = this.entries[f]; D || (D = this.entries[f] = { glyphs: {}, requests: {}, ranges: {}, ascender: void 0, descender: void 0 }); let x = D.glyphs[v]; if (x !== void 0) return void S(null, { stack: f, id: v, glyph: x }); if (x = this._tinySDF(D, f, v), x) return D.glyphs[v] = x, void S(null, { stack: f, id: v, glyph: x }); const P = Math.floor(v / 256); if (256 * P > 65535) return mi("glyphs > 65535 not supported"), void S(null, { stack: f, id: v, glyph: x }); if (D.ranges[P]) return void S(null, { stack: f, id: v, glyph: x }); let I = D.requests[P]; I || (I = D.requests[P] = [], Du.loadGlyphRange(f, P, l, this.requestManager, (M, C) => { if (C) { D.ascender = C.ascender, D.descender = C.descender; for (const k in C.glyphs) this._doesCharSupportLocalGlyph(+k) || (D.glyphs[+k] = C.glyphs[+k]); D.ranges[P] = !0; } for (const k of I) k(M, C); delete D.requests[P]; })), I.push((M, C) => { M ? S(M) : C && S(null, { stack: f, id: v, glyph: C.glyphs[v] || null }); }); }, (f, v) => { if (f) o(f); else if (v) { const S = {}; for (const { stack: D, id: x, glyph: P } of v) S[D] === void 0 && (S[D] = {}), S[D].glyphs === void 0 && (S[D].glyphs = {}), S[D].glyphs[x] = P && { id: P.id, bitmap: P.bitmap.clone(), metrics: P.metrics }, S[D].ascender = this.entries[D].ascender, S[D].descender = this.entries[D].descender; o(null, S); } }); } _doesCharSupportLocalGlyph(e) { return this.localGlyphMode !== V_.none && (this.localGlyphMode === V_.all ? !!this.localFontFamily : !!this.localFontFamily && (Zt["CJK Unified Ideographs"](e) || Zt["Hangul Syllables"](e) || Zt.Hiragana(e) || Zt.Katakana(e) || Zt["CJK Symbols and Punctuation"](e) || Zt["CJK Unified Ideographs Extension A"](e) || Zt["CJK Unified Ideographs Extension B"](e) || Zt.Osage(e))); } _tinySDF(e, n, o) { const u = this.localFontFamily; if (!u || !this._doesCharSupportLocalGlyph(o)) return; let l = e.tinySDF; if (!l) { let k = "400"; /bold/i.test(n) ? k = "900" : /medium/i.test(n) ? k = "500" : /light/i.test(n) && (k = "200"), l = e.tinySDF = new Du.TinySDF({ fontFamily: u, fontWeight: k, fontSize: 24 * Ea, buffer: 3 * Ea, radius: 8 * Ea }), l.fontWeight = k; } if (this.localGlyphs[l.fontWeight][o]) return this.localGlyphs[l.fontWeight][o]; const f = String.fromCodePoint(o), { data: v, width: S, height: D, glyphWidth: x, glyphHeight: P, glyphLeft: I, glyphTop: M, glyphAdvance: C } = l.draw(f); return this.localGlyphs[l.fontWeight][o] = { id: o, bitmap: new gc({ width: S, height: D }, v), metrics: { width: x / Ea, height: P / Ea, left: I / Ea, top: M / Ea - 27, advance: C / Ea, localGlyph: !0 } }; } } Du.loadGlyphRange = function(r, e, n, o, u) { const l = 256 * e, f = l + 255, v = o.transformRequest(o.normalizeGlyphsURL(n).replace("{fontstack}", r).replace("{range}", `${l}-${f}`), Uo.Glyphs); no(v, (S, D) => { if (S) u(S); else if (D) { const x = {}, P = function(I) { return new Dp(I).readFields(PT, {}); }(D); for (const I of P.glyphs) x[I.id] = I; u(null, { glyphs: x, ascender: P.ascender, descender: P.descender }); } }); }, Du.TinySDF = class { constructor({ fontSize: r = 24, buffer: e = 3, radius: n = 8, cutoff: o = 0.25, fontFamily: u = "sans-serif", fontWeight: l = "normal", fontStyle: f = "normal" } = {}) { this.buffer = e, this.cutoff = o, this.radius = n; const v = this.size = r + 4 * e, S = this._createCanvas(v), D = this.ctx = S.getContext("2d", { willReadFrequently: !0 }); D.font = `${f} ${l} ${r}px ${u}`, D.textBaseline = "alphabetic", D.textAlign = "left", D.fillStyle = "black", this.gridOuter = new Float64Array(v * v), this.gridInner = new Float64Array(v * v), this.f = new Float64Array(v), this.z = new Float64Array(v + 1), this.v = new Uint16Array(v); } _createCanvas(r) { const e = document.createElement("canvas"); return e.width = e.height = r, e; } draw(r) { const { width: e, actualBoundingBoxAscent: n, actualBoundingBoxDescent: o, actualBoundingBoxLeft: u, actualBoundingBoxRight: l } = this.ctx.measureText(r), f = Math.ceil(n), v = Math.max(0, Math.min(this.size - this.buffer, Math.ceil(l - u))), S = Math.min(this.size - this.buffer, f + Math.ceil(o)), D = v + 2 * this.buffer, x = S + 2 * this.buffer, P = Math.max(D * x, 0), I = new Uint8ClampedArray(P), M = { data: I, width: D, height: x, glyphWidth: v, glyphHeight: S, glyphTop: f, glyphLeft: 0, glyphAdvance: e }; if (v === 0 || S === 0) return M; const { ctx: C, buffer: k, gridInner: V, gridOuter: U } = this; C.clearRect(k, k, v, S), C.fillText(r, k, k + f); const q = C.getImageData(k, k, v, S); U.fill(Kd, 0, P), V.fill(0, 0, P); for (let $ = 0; $ < S; $++) for (let H = 0; H < v; H++) { const K = q.data[4 * ($ * v + H) + 3] / 255; if (K === 0) continue; const Q = ($ + k) * D + H + k; if (K === 1) U[Q] = 0, V[Q] = Kd; else { const ie = 0.5 - K; U[Q] = ie > 0 ? ie * ie : 0, V[Q] = ie < 0 ? ie * ie : 0; } } ex(U, 0, 0, D, x, D, this.f, this.v, this.z), ex(V, k, k, v, S, D, this.f, this.v, this.z); for (let $ = 0; $ < P; $++) { const H = Math.sqrt(U[$]) - Math.sqrt(V[$]); I[$] = Math.round(255 - 255 * (H / this.radius + this.cutoff)); } return M; } }; const xc = Yd; function ix(r, e) { return r + e[1] - e[0]; } function nx(r, e, n, o, u = 1) { const l = [], f = r.imagePrimary, v = f.pixelRatio, S = f.paddedRect.w - 2 * xc, D = f.paddedRect.h - 2 * xc, x = (r.right - r.left) * u, P = (r.bottom - r.top) * u, I = f.stretchX || [[0, S]], M = f.stretchY || [[0, D]], C = I.reduce(ix, 0), k = M.reduce(ix, 0), V = S - C, U = D - k; let q = 0, $ = C, H = 0, K = k, Q = 0, ie = V, fe = 0, de = U; if (f.content && o) { const Se = f.content; q = Rp(I, 0, Se[0]), H = Rp(M, 0, Se[1]), $ = Rp(I, Se[0], Se[2]), K = Rp(M, Se[1], Se[3]), Q = Se[0] - q, fe = Se[1] - H, ie = Se[2] - Se[0] - $, de = Se[3] - Se[1] - K; } const ue = (Se, me, Ee, ze) => { const Ie = Op(Se.stretch - q, $, x, r.left * u), Re = Fp(Se.fixed - Q, ie, Se.stretch, C), Ve = Op(me.stretch - H, K, P, r.top * u), Ue = Fp(me.fixed - fe, de, me.stretch, k), Fe = Op(Ee.stretch - q, $, x, r.left * u), et = Fp(Ee.fixed - Q, ie, Ee.stretch, C), dt = Op(ze.stretch - H, K, P, r.top * u), tt = Fp(ze.fixed - fe, de, ze.stretch, k), Mt = new Et(Ie, Ve), wt = new Et(Fe, Ve), At = new Et(Fe, dt), rt = new Et(Ie, dt), Ut = new Et(Re / v, Ue / v), St = new Et(et / v, tt / v), Nt = e * Math.PI / 180; if (Nt) { const Ii = Math.sin(Nt), fn = Math.cos(Nt), rn = [fn, -Ii, Ii, fn]; Mt._matMult(rn), wt._matMult(rn), rt._matMult(rn), At._matMult(rn); } const Qt = Se.stretch + Se.fixed, pi = Ee.stretch + Ee.fixed, gi = me.stretch + me.fixed, Ai = ze.stretch + ze.fixed, yi = r.imageSecondary; return { tl: Mt, tr: wt, bl: rt, br: At, texPrimary: { x: f.paddedRect.x + xc + Qt, y: f.paddedRect.y + xc + gi, w: pi - Qt, h: Ai - gi }, texSecondary: yi ? { x: yi.paddedRect.x + xc + Qt, y: yi.paddedRect.y + xc + gi, w: pi - Qt, h: Ai - gi } : void 0, writingMode: void 0, glyphOffset: [0, 0], sectionIndex: 0, pixelOffsetTL: Ut, pixelOffsetBR: St, minFontScaleX: ie / v / x, minFontScaleY: de / v / P, isSDF: n }; }; if (o && (f.stretchX || f.stretchY)) { const Se = sx(I, V, C), me = sx(M, U, k); for (let Ee = 0; Ee < Se.length - 1; Ee++) { const ze = Se[Ee], Ie = Se[Ee + 1]; for (let Re = 0; Re < me.length - 1; Re++) l.push(ue(ze, me[Re], Ie, me[Re + 1])); } } else l.push(ue({ fixed: 0, stretch: -1 }, { fixed: 0, stretch: -1 }, { fixed: 0, stretch: S + 1 }, { fixed: 0, stretch: D + 1 })); return l; } function Rp(r, e, n) { let o = 0; for (const u of r) o += Math.max(e, Math.min(n, u[1])) - Math.max(e, Math.min(n, u[0])); return o; } function sx(r, e, n) { const o = [{ fixed: -xc, stretch: 0 }]; for (const [u, l] of r) { const f = o[o.length - 1]; o.push({ fixed: u - f.stretch, stretch: f.stretch }), o.push({ fixed: u - f.stretch, stretch: f.stretch + (l - u) }); } return o.push({ fixed: e + xc, stretch: n }), o; } function Op(r, e, n, o) { return r / e * n + o; } function Fp(r, e, n, o) { return r - e * n / o; } function RT(r, e, n, o) { const u = e + r.positionedLines[o].lineOffset; return o === 0 ? n + u / 2 : n + (u + (e + r.positionedLines[o - 1].lineOffset)) / 2; } function OT(r, e = 1, n = !1) { let o = 1 / 0, u = 1 / 0, l = -1 / 0, f = -1 / 0; const v = r[0]; for (let M = 0; M < v.length; M++) { const C = v[M]; (!M || C.x < o) && (o = C.x), (!M || C.y < u) && (u = C.y), (!M || C.x > l) && (l = C.x), (!M || C.y > f) && (f = C.y); } const S = Math.min(l - o, f - u); let D = S / 2; const x = new Wl([], FT); if (S === 0) return new Et(o, u); for (let M = o; M < l; M += S) for (let C = u; C < f; C += S) x.push(new ku(M + D, C + D, D, r)); let P = function(M) { let C = 0, k = 0, V = 0; const U = M[0]; for (let q = 0, $ = U.length, H = $ - 1; q < $; H = q++) { const K = U[q], Q = U[H], ie = K.x * Q.y - Q.x * K.y; k += (K.x + Q.x) * ie, V += (K.y + Q.y) * ie, C += 3 * ie; } return new ku(k / C, V / C, 0, M); }(r), I = x.length; for (; x.length; ) { const M = x.pop(); (M.d > P.d || !P.d) && (P = M, n && console.log("found best %d after %d probes", Math.round(1e4 * M.d) / 1e4, I)), M.max - P.d <= e || (D = M.h / 2, x.push(new ku(M.p.x - D, M.p.y - D, D, r)), x.push(new ku(M.p.x + D, M.p.y - D, D, r)), x.push(new ku(M.p.x - D, M.p.y + D, D, r)), x.push(new ku(M.p.x + D, M.p.y + D, D, r)), I += 4); } return n && (console.log(`num probes: ${I}`), console.log(`best distance: ${P.d}`)), P.p; } function FT(r, e) { return e.max - r.max; } class ku { constructor(e, n, o, u) { this.p = new Et(e, n), this.h = o, this.d = function(l, f) { let v = !1, S = 1 / 0; for (let D = 0; D < f.length; D++) { const x = f[D]; for (let P = 0, I = x.length, M = I - 1; P < I; M = P++) { const C = x[P], k = x[M]; C.y > l.y != k.y > l.y && l.x < (k.x - C.x) * (l.y - C.y) / (k.y - C.y) + C.x && (v = !v), S = Math.min(S, we(l, C, k)); } } return (v ? 1 : -1) * Math.sqrt(S); }(this.p, u), this.max = this.d + this.h * Math.SQRT2; } } const U_ = Number.POSITIVE_INFINITY, BT = Math.sqrt(2); function rx(r, [e, n]) { let o = 0, u = 0; if (n === U_) { e < 0 && (e = 0); const l = e / BT; switch (r) { case "top-right": case "top-left": u = l - 7; break; case "bottom-right": case "bottom-left": u = 7 - l; break; case "bottom": u = 7 - e; break; case "top": u = e - 7; } switch (r) { case "top-right": case "bottom-right": o = -l; break; case "top-left": case "bottom-left": o = l; break; case "left": o = e; break; case "right": o = -e; } } else { switch (e = Math.abs(e), n = Math.abs(n), r) { case "top-right": case "top-left": case "top": u = n - 7; break; case "bottom-right": case "bottom-left": case "bottom": u = 7 - n; } switch (r) { case "top-right": case "bottom-right": case "right": o = -e; break; case "top-left": case "bottom-left": case "left": o = e; } } return [o, u]; } function j_(r) { switch (r) { case "right": case "top-right": case "bottom-right": return "right"; case "left": case "top-left": case "bottom-left": return "left"; } return "center"; } function NT(r, e, n, o, u, l, f, v, S, D, x, P, I, M, C, k) { let V = l.textMaxSize.evaluate(e, {}, I); V === void 0 ? V = f * l.textScaleFactor : V *= l.textScaleFactor; const U = r.layers[0].layout, q = U.get("icon-offset").evaluate(e, {}, I), $ = ax(n.horizontal) || n.vertical, H = M.name === "globe", K = tr, Q = f * l.textScaleFactor / K, ie = r.tilePixelRatio * V / K, fe = (Re = r.overscaling, r.zoom > 18 && Re > 2 && (Re >>= 1), Math.max(Tt / (512 * Re), 1) * U.get("symbol-spacing")), de = U.get("text-padding") * r.tilePixelRatio, ue = U.get("icon-padding") * r.tilePixelRatio, Se = vi(U.get("text-max-angle")), me = U.get("text-rotation-alignment") === "map" && U.get("symbol-placement") !== "point", Ee = U.get("icon-rotation-alignment") === "map" && U.get("symbol-placement") !== "point", ze = U.get("symbol-placement"), Ie = fe / 2; var Re; const Ve = U.get("icon-text-fit").evaluate(e, {}, I), Ue = U.get("icon-text-fit-padding").evaluate(e, {}, I), Fe = Ve !== "none"; let et; r.hasAnyIconTextFit === !1 && Fe && (r.hasAnyIconTextFit = !0), o && Fe && (r.allowVerticalPlacement && n.vertical && (et = H0(o, n.vertical, Ve, Ue, q, Q)), $ && (o = H0(o, $, Ve, Ue, q, Q))); const dt = (tt, Mt, wt) => { if (Mt.x < 0 || Mt.x >= Tt || Mt.y < 0 || Mt.y >= Tt) return; let At = null; if (H) { const { x: rt, y: Ut, z: St } = M.projectTilePoint(Mt.x, Mt.y, wt); At = { anchor: new zl(rt, Ut, St, 0, void 0), up: M.upVector(wt, Mt.x, Mt.y) }; } (function(rt, Ut, St, Nt, Qt, pi, gi, Ai, yi, Ii, fn, rn, hi, on, Qi, pn, as, ls, Kn, Vr, Sn, Ln, Tr, cs, to, Ms, sl, Mc) { const Sc = rt.addToLineVertexArray(Ut, Nt); let Dl, Ec, Pc, hm, Nv, Vv, Uv, jv = 0, Gv = 0, Zv = 0, Hv = 0, Tg = -1, Mg = -1; const rl = {}; let qv = $r(""); const Sh = St ? St.anchor : Ut, Sg = yi.layout.get("icon-text-fit").evaluate(Sn, {}, Ms) !== "none"; let Eg = 0, Pg = 0; if (yi._unevaluatedLayout.getValue("text-radial-offset") === void 0 ? [Eg, Pg] = yi.layout.get("text-offset").evaluate(Sn, {}, Ms).map((Fo) => Fo * tr) : (Eg = yi.layout.get("text-radial-offset").evaluate(Sn, {}, Ms) * tr, Pg = U_), rt.allowVerticalPlacement && Qt.vertical) { const Fo = Qt.vertical; if (Qi) Vv = G_(Fo), Ai && (Uv = G_(Ai)); else { const po = yi.layout.get("text-rotate").evaluate(Sn, {}, Ms) + 90; Pc = Bp(Ii, Sh, Ut, fn, rn, hi, Fo, on, po, pn), Ai && (hm = Bp(Ii, Sh, Ut, fn, rn, hi, Ai, ls, po)); } } if (pi) { const Fo = rt.iconSizeData, po = cs ? Lp(rt.iconSizeData, rt.layers[0]._unevaluatedLayout._values["icon-size"], Ms, rt.zoom, Sn) : 1, Hu = yi.layout.get("icon-rotate").evaluate(Sn, {}, Ms), Wv = nx(pi, Hu, Tr, Sg, cs ? 1 / po : Ln.iconScaleFactor), Cg = Ai ? nx(Ai, Hu, Tr, Sg, Ln.iconScaleFactor) : void 0; Ec = Bp(Ii, Sh, Ut, fn, rn, hi, pi, ls, Hu, null, cs ? Ln.iconScaleFactor * po : 1), jv = 4 * Wv.length; let Eh = null; Fo.kind === "source" ? (Eh = [Sa * yi.layout.get("icon-size").evaluate(Sn, {}, Ms) * Ln.iconScaleFactor], Eh[0] > vc && mi(`${rt.layerIds[0]}: Value for "icon-size" is >= ${Jd}. Reduce your "icon-size".`)) : Fo.kind === "composite" && (Eh = [Sa * Ln.compositeIconSizes[0].evaluate(Sn, {}, Ms) * Ln.iconScaleFactor, Sa * Ln.compositeIconSizes[1].evaluate(Sn, {}, Ms) * Ln.iconScaleFactor], (Eh[0] > vc || Eh[1] > vc) && mi(`${rt.layerIds[0]}: Value for "icon-size" is >= ${Jd}. Reduce your "icon-size".`)), rt.addSymbols(rt.icon, Wv, Eh, Vr, Kn, Sn, !1, St, Ut, Sc.lineStartIndex, Sc.lineLength, -1, to, Ms, sl, Mc), Tg = rt.icon.placedSymbolArray.length - 1, Cg && (Gv = 4 * Cg.length, rt.addSymbols(rt.icon, Cg, Eh, Vr, Kn, Sn, Ro.vertical, St, Ut, Sc.lineStartIndex, Sc.lineLength, -1, to, Ms, sl, Mc), Mg = rt.icon.placedSymbolArray.length - 1); } for (const Fo in Qt.horizontal) { const po = Qt.horizontal[Fo]; Dl || (qv = $r(po.text), Qi ? Nv = G_(po) : Dl = Bp(Ii, Sh, Ut, fn, rn, hi, po, on, yi.layout.get("text-rotate").evaluate(Sn, {}, Ms), pn)); const Hu = po.positionedLines.length === 1; if (Zv += ox(rt, St, Ut, po, gi, yi, Qi, Sn, pn, Sc, Qt.vertical ? Ro.horizontal : Ro.horizontalOnly, Hu ? Object.keys(Qt.horizontal) : [Fo], rl, Tg, Ln, to, Ms, sl), Hu) break; } Qt.vertical && (Hv += ox(rt, St, Ut, Qt.vertical, gi, yi, Qi, Sn, pn, Sc, Ro.vertical, ["vertical"], rl, Mg, Ln, to, Ms, sl)); let Ac = -1; const Ag = (Fo, po) => Fo ? Math.max(Fo, po) : po; Ac = Ag(Nv, Ac), Ac = Ag(Vv, Ac), Ac = Ag(Uv, Ac); const yM = Ac > -1 ? 1 : 0; rt.glyphOffsetArray.length >= 65535 && mi("Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"), Sn.sortKey !== void 0 && rt.addToSortKeyRanges(rt.symbolInstances.length, Sn.sortKey), rt.symbolInstances.emplaceBack(Ut.x, Ut.y, Sh.x, Sh.y, Sh.z, rl.right >= 0 ? rl.right : -1, rl.center >= 0 ? rl.center : -1, rl.left >= 0 ? rl.left : -1, rl.vertical >= 0 ? rl.vertical : -1, Tg, Mg, qv, Dl !== void 0 ? Dl : rt.collisionBoxArray.length, Dl !== void 0 ? Dl + 1 : rt.collisionBoxArray.length, Pc !== void 0 ? Pc : rt.collisionBoxArray.length, Pc !== void 0 ? Pc + 1 : rt.collisionBoxArray.length, Ec !== void 0 ? Ec : rt.collisionBoxArray.length, Ec !== void 0 ? Ec + 1 : rt.collisionBoxArray.length, hm || rt.collisionBoxArray.length, hm ? hm + 1 : rt.collisionBoxArray.length, fn, Zv, Hv, jv, Gv, yM, 0, Eg, Pg, Ac, 0, Sg ? 1 : 0); })(r, Mt, At, tt, n, o, u, et, r.layers[0], r.collisionBoxArray, e.index, e.sourceLayerIndex, r.index, de, me, S, 0, ue, Ee, q, e, l, D, x, P, I, C, k); }; if (ze === "line") for (const tt of K0(e.geometry, 0, 0, Tt, Tt)) { const Mt = kT(tt, fe, Se, n.vertical || $, o, K, ie, r.overscaling, Tt); for (const wt of Mt) $ && VT(r, $.text, Ie, wt) || dt(tt, wt, I); } else if (ze === "line-center") { for (const tt of e.geometry) if (tt.length > 1) { const Mt = DT(tt, Se, n.vertical || $, o, K, ie); Mt && dt(tt, Mt, I); } } else if (e.type === "Polygon") for (const tt of Mp(e.geometry, 0)) { const Mt = OT(tt, 16); dt(tt[0], new zl(Mt.x, Mt.y, 0, 0, void 0), I); } else if (e.type === "LineString") for (const tt of e.geometry) dt(tt, new zl(tt[0].x, tt[0].y, 0, 0, void 0), I); else if (e.type === "Point") for (const tt of e.geometry) for (const Mt of tt) dt([Mt], new zl(Mt.x, Mt.y, 0, 0, void 0), I); } const Jd = 255, vc = Jd * Sa; function ox(r, e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V, U) { const q = function(K, Q, ie, fe, de, ue, Se, me) { const Ee = []; if (Q.positionedLines.length === 0) return Ee; const ze = fe.layout.get("text-rotate").evaluate(ue, {}) * Math.PI / 180, Ie = function(et) { const dt = et[0], tt = et[1], Mt = dt * tt; return Mt > 0 ? [dt, -tt] : Mt < 0 ? [-dt, tt] : dt === 0 ? [tt, dt] : [tt, -dt]; }(ie); let Re = Math.abs(Q.top - Q.bottom); for (const et of Q.positionedLines) Re -= et.lineOffset; const Ve = Q.positionedLines.length, Ue = Re / Ve; let Fe = Q.top - ie[1]; for (let et = 0; et < Ve; ++et) { const dt = Q.positionedLines[et]; Fe = RT(Q, Ue, Fe, et); for (const tt of dt.positionedGlyphs) { if (!tt.rect) continue; const Mt = tt.rect || {}; let wt = N0 + 1, At = !0, rt = 1, Ut = 0; if (tt.imageName) { const Kn = Se[ss.build(tt.imageName).getSerializedPrimary()]; if (!Kn) continue; if (Kn.sdf) { mi("SDF images are not supported in formatted text and will be ignored."); continue; } At = !1, rt = Kn.pixelRatio, wt = Yd / rt; } const St = (de || me) && tt.vertical, Nt = tt.metrics.advance * tt.scale / 2, Qt = tt.metrics, pi = tt.rect; if (pi === null) continue; me && Q.verticalizable && (Ut = tt.imageName ? Nt - tt.metrics.width * tt.scale / 2 : 0); const gi = de ? [tt.x + Nt, tt.y] : [0, 0]; let Ai = [0, 0], yi = [0, 0], Ii = !1; de || (St ? (yi = [tt.x + Nt + Ie[0], tt.y + Ie[1] - Ut], Ii = !0) : Ai = [tt.x + Nt + ie[0], tt.y + ie[1] - Ut]); const fn = pi.w * tt.scale / (rt * (tt.localGlyph ? Ea : 1)), rn = pi.h * tt.scale / (rt * (tt.localGlyph ? Ea : 1)); let hi, on, Qi, pn; if (St) { const Kn = tt.y - Fe, Vr = new Et(-Nt, Nt - Kn), Sn = -Math.PI / 2, Ln = new Et(...yi); hi = new Et(-Nt + Ai[0], Ai[1]), hi._rotateAround(Sn, Vr)._add(Ln), hi.x += -Kn + Nt, hi.y -= (Qt.left - wt) * tt.scale; const Tr = tt.imageName ? Qt.advance * tt.scale : tr * tt.scale, cs = String.fromCodePoint(tt.glyph); MT(cs) ? hi.x += (1 - wt) * tt.scale : ST(cs) ? hi.x += Tr - Qt.height * tt.scale + (-wt - 1) * tt.scale : hi.x += tt.imageName || Qt.width + 2 * wt === pi.w && Qt.height + 2 * wt === pi.h ? (Tr - rn) / 2 : (Tr - (Qt.height + 2 * wt) * tt.scale) / 2, on = new Et(hi.x, hi.y - fn), Qi = new Et(hi.x + rn, hi.y), pn = new Et(hi.x + rn, hi.y - fn); } else { const Kn = (Qt.left - wt) * tt.scale - Nt + Ai[0], Vr = (-Qt.top - wt) * tt.scale + Ai[1], Sn = Kn + fn, Ln = Vr + rn; hi = new Et(Kn, Vr), on = new Et(Sn, Vr), Qi = new Et(Kn, Ln), pn = new Et(Sn, Ln); } if (ze) { let Kn; Kn = de ? new Et(0, 0) : Ii ? new Et(Ie[0], Ie[1]) : new Et(ie[0], ie[1]), hi._rotateAround(ze, Kn), on._rotateAround(ze, Kn), Qi._rotateAround(ze, Kn), pn._rotateAround(ze, Kn); } const as = new Et(0, 0), ls = new Et(0, 0); Ee.push({ tl: hi, tr: on, bl: Qi, br: pn, texPrimary: Mt, texSecondary: void 0, writingMode: Q.writingMode, glyphOffset: gi, sectionIndex: tt.sectionIndex, isSDF: At, pixelOffsetTL: as, pixelOffsetBR: ls, minFontScaleX: 0, minFontScaleY: 0 }); } } return Ee; }(0, o, S, l, f, v, u, r.allowVerticalPlacement), $ = r.textSizeData; let H = null; $.kind === "source" ? (H = [Sa * l.layout.get("text-size").evaluate(v, {}, V) * C.textScaleFactor], H[0] > vc && mi(`${r.layerIds[0]}: Value for "text-size" is >= ${Jd}. Reduce your "text-size".`)) : $.kind === "composite" && (H = [Sa * C.compositeTextSizes[0].evaluate(v, {}, V) * C.textScaleFactor, Sa * C.compositeTextSizes[1].evaluate(v, {}, V) * C.textScaleFactor], (H[0] > vc || H[1] > vc) && mi(`${r.layerIds[0]}: Value for "text-size" is >= ${Jd}. Reduce your "text-size".`)), r.addSymbols(r.text, q, H, S, f, v, x, e, n, D.lineStartIndex, D.lineLength, M, k, V, U, !1); for (const K of P) I[K] = r.text.placedSymbolArray.length - 1; return 4 * q.length; } function ax(r) { for (const e in r) return r[e]; return null; } function Bp(r, e, n, o, u, l, f, v, S, D, x = 1) { let P = f.top / x, I = f.bottom / x, M = f.left / x, C = f.right / x; const k = f.collisionPadding; if (k && (M -= k[0], P -= k[1], C += k[2], I += k[3]), S) { const V = new Et(M, P), U = new Et(C, P), q = new Et(M, I), $ = new Et(C, I), H = vi(S); let K = new Et(0, 0); D && (K = new Et(D[0], D[1])), V._rotateAround(H, K), U._rotateAround(H, K), q._rotateAround(H, K), $._rotateAround(H, K), M = Math.min(V.x, U.x, q.x, $.x), C = Math.max(V.x, U.x, q.x, $.x), P = Math.min(V.y, U.y, q.y, $.y), I = Math.max(V.y, U.y, q.y, $.y); } return r.emplaceBack(e.x, e.y, e.z, n.x, n.y, M, P, C, I, v, o, u, l), r.length - 1; } function G_(r) { r.collisionPadding && (r.top -= r.collisionPadding[1], r.bottom += r.collisionPadding[3]); const e = r.bottom - r.top; return e > 0 ? Math.max(10, e) : null; } function VT(r, e, n, o) { const u = r.compareText; if (e in u) { const l = u[e]; for (let f = l.length - 1; f >= 0; f--) if (o.dist(l[f]) < n) return !0; } else u[e] = []; return u[e].push(o), !1; } function lx(r, e) { const n = r.fovAboveCenter, o = r.elevation ? r.elevation.getMinElevationBelowMSL() * e : 0, u = (r._camera.position[2] * r.worldSize - o) / Math.cos(r._pitch), l = Math.sin(n) * u / Math.sin(Math.max(Math.PI / 2 - r._pitch - n, 0.01)); let f = Math.sin(r._pitch) * l + u; const v = u * (1 / r._horizonShift); return r.elevation && r.elevation.exaggeration() !== 0 || (f *= 1 + Math.max(r.zoom - 17, 0)), Math.min(1.01 * f, v); } function Qd(r, e) { if (!e.isReprojectedInTileSpace) return { scale: 1 << r.z, x: r.x, y: r.y, x2: r.x + 1, y2: r.y + 1, projection: e }; const n = Math.pow(2, -r.z), o = r.x * n, u = (r.x + 1) * n, l = r.y * n, f = (r.y + 1) * n, v = Fr(o), S = Fr(u), D = Os(l), x = Os(f), P = e.project(v, D), I = e.project(S, D), M = e.project(S, x), C = e.project(v, x); let k = Math.min(P.x, I.x, M.x, C.x), V = Math.min(P.y, I.y, M.y, C.y), U = Math.max(P.x, I.x, M.x, C.x), q = Math.max(P.y, I.y, M.y, C.y); const $ = n / 16; function H(Q, ie, fe, de, ue, Se) { const me = (fe + ue) / 2, Ee = (de + Se) / 2, ze = e.project(Fr(me), Os(Ee)), Ie = Math.max(0, k - ze.x, V - ze.y, ze.x - U, ze.y - q); k = Math.min(k, ze.x), U = Math.max(U, ze.x), V = Math.min(V, ze.y), q = Math.max(q, ze.y), Ie > $ && (H(Q, ze, fe, de, me, Ee), H(ze, ie, me, Ee, ue, Se)); } H(P, I, o, l, u, l), H(I, M, u, l, u, f), H(M, C, u, f, o, f), H(C, P, o, f, o, l), k -= $, V -= $, U += $, q += $; const K = 1 / Math.max(U - k, q - V); return { scale: K, x: k * K, y: V * K, x2: U * K, y2: q * K, projection: e }; } function cx(r, { x: e, y: n }, o = 0) { return new Et(((e - o) * r.scale - r.x) * Tt, (n * r.scale - r.y) * Tt); } const UT = De.mat4.identity(new Float32Array(16)); class bc { constructor(e) { this.spec = e, this.name = e.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(e, n) { return { x: 0, y: 0, z: 0 }; } unproject(e, n) { return new Ui(0, 0); } projectTilePoint(e, n, o) { return { x: e, y: n, z: 0 }; } locationPoint(e, n, o = !0) { return e._coordinatePoint(e.locationCoordinate(n), o); } pixelsPerMeter(e, n) { return fr(1, e) * n; } pixelSpaceConversion(e, n, o) { return 1; } farthestPixelDistance(e) { return lx(e, e.pixelsPerMeter); } pointCoordinate(e, n, o, u) { const l = e.horizonLineFromTop(!1), f = new Et(n, Math.max(l, o)); return e.rayIntersectionCoordinate(e.pointRayIntersection(f, u)); } pointCoordinate3D(e, n, o) { const u = new Et(n, o); if (e.elevation) return e.elevation.pointCoordinate(u); { const l = this.pointCoordinate(e, u.x, u.y, 0); return [l.x, l.y, l.z]; } } isPointAboveHorizon(e, n) { if (e.elevation && e.elevation.visibleDemTiles.length) return !this.pointCoordinate3D(e, n.x, n.y); const o = e.horizonLineFromTop(); return n.y < o; } createInversionMatrix(e, n) { return UT; } createTileMatrix(e, n, o) { let u, l, f; const v = o.canonical, S = De.mat4.identity(new Float64Array(16)); if (this.isReprojectedInTileSpace) { const D = Qd(v, this); u = 1, l = D.x + o.wrap * D.scale, f = D.y, De.mat4.scale(S, S, [u / D.scale, u / D.scale, e.pixelsPerMeter / n]); } else u = n / e.zoomScale(v.z), l = (v.x + Math.pow(2, v.z) * o.wrap) * u, f = v.y * u; return De.mat4.translate(S, S, [l, f, 0]), De.mat4.scale(S, S, [u / Tt, u / Tt, 1]), S; } upVector(e, n, o) { return [0, 0, 1]; } upVectorScale(e, n, o) { return { metersToTile: 1 }; } } class jT extends bc { constructor(e) { super(e), this.range = [4, 7], this.center = e.center || [-96, 37.5]; const [n, o] = this.parallels = e.parallels || [29.5, 45.5], u = Math.sin(vi(n)); this.n = (u + Math.sin(vi(o))) / 2, this.c = 1 + u * (2 * this.n - u), this.r0 = Math.sqrt(this.c) / this.n; } project(e, n) { const { n: o, c: u, r0: l } = this, f = vi(e - this.center[0]), v = vi(n), S = Math.sqrt(u - 2 * o * Math.sin(v)) / o; return { x: S * Math.sin(f * o), y: S * Math.cos(f * o) - l, z: 0 }; } unproject(e, n) { const { n: o, c: u, r0: l } = this, f = l + n; let v = Math.atan2(e, Math.abs(f)) * Math.sign(f); f * o < 0 && (v -= Math.PI * Math.sign(e) * Math.sign(f)); const S = vi(this.center[0]) * o; v = zn(v, -Math.PI - S, Math.PI - S); const D = si(kn(v / o) + this.center[0], -180, 180), x = Math.asin(si((u - (e * e + f * f) * o * o) / (2 * o), -1, 1)), P = si(kn(x), -Un, Un); return new Ui(D, P); } } const ef = 1.340264, tf = -0.081106, nf = 893e-6, sf = 3796e-6, Np = Math.sqrt(3) / 2; class GT extends bc { project(e, n) { n = n / 180 * Math.PI, e = e / 180 * Math.PI; const o = Math.asin(Np * Math.sin(n)), u = o * o, l = u * u * u; return { x: 0.5 * (e * Math.cos(o) / (Np * (ef + 3 * tf * u + l * (7 * nf + 9 * sf * u))) / Math.PI + 0.5), y: 1 - 0.5 * (o * (ef + tf * u + l * (nf + sf * u)) / Math.PI + 1), z: 0 }; } unproject(e, n) { e = (2 * e - 0.5) * Math.PI; let o = n = (2 * (1 - n) - 1) * Math.PI, u = o * o, l = u * u * u; for (let x, P, I, M = 0; M < 12 && (P = o * (ef + tf * u + l * (nf + sf * u)) - n, I = ef + 3 * tf * u + l * (7 * nf + 9 * sf * u), x = P / I, o = si(o - x, -Math.PI / 3, Math.PI / 3), u = o * o, l = u * u * u, !(Math.abs(x) < 1e-12)); ++M) ; const f = Np * e * (ef + 3 * tf * u + l * (7 * nf + 9 * sf * u)) / Math.cos(o), v = Math.asin(Math.sin(o) / Np), S = si(180 * f / Math.PI, -180, 180), D = si(180 * v / Math.PI, -Un, Un); return new Ui(S, D); } } class ZT extends bc { constructor(e) { super(e), this.wrap = !0, this.supportsWorldCopies = !0; } project(e, n) { return { x: 0.5 + e / 360, y: 0.5 - n / 360, z: 0 }; } unproject(e, n) { const o = 360 * (e - 0.5), u = si(360 * (0.5 - n), -Un, Un); return new Ui(o, u); } } const Ru = Math.PI / 2; function Vp(r) { return Math.tan((Ru + r) / 2); } class HT extends bc { constructor(e) { super(e), this.center = e.center || [0, 30]; const [n, o] = this.parallels = e.parallels || [30, 30]; let u = vi(n), l = vi(o); this.southernCenter = u + l < 0, this.southernCenter && (u = -u, l = -l); const f = Math.cos(u), v = Vp(u); this.n = u === l ? Math.sin(u) : Math.log(f / Math.cos(l)) / Math.log(Vp(l) / v), this.f = f * Math.pow(Vp(u), this.n) / this.n; } project(e, n) { n = vi(n), this.southernCenter && (n = -n), e = vi(e - this.center[0]); const o = 1e-6, { n: u, f: l } = this; l > 0 ? n < -Ru + o && (n = -Ru + o) : n > Ru - o && (n = Ru - o); const f = l / Math.pow(Vp(n), u); let v = f * Math.sin(u * e), S = l - f * Math.cos(u * e); return v = 0.5 * (v / Math.PI + 0.5), S = 0.5 * (S / Math.PI + 0.5), { x: v, y: this.southernCenter ? S : 1 - S, z: 0 }; } unproject(e, n) { e = (2 * e - 0.5) * Math.PI, this.southernCenter && (n = 1 - n), n = (2 * (1 - n) - 0.5) * Math.PI; const { n: o, f: u } = this, l = u - n, f = Math.sign(l), v = Math.sign(o) * Math.sqrt(e * e + l * l); let S = Math.atan2(e, Math.abs(l)) * f; l * o < 0 && (S -= Math.PI * Math.sign(e) * f); const D = si(kn(S / o) + this.center[0], -180, 180), x = si(kn(2 * Math.atan(Math.pow(u / v, 1 / o)) - Ru), -Un, Un); return new Ui(D, this.southernCenter ? -x : x); } } class hx extends bc { constructor(e) { super(e), this.wrap = !0, this.supportsWorldCopies = !0, this.supportsTerrain = !0, this.supportsFog = !0, this.supportsFreeCamera = !0, this.isReprojectedInTileSpace = !1, this.unsupportedLayers = [], this.range = null; } project(e, n) { return { x: ta(e), y: Ta(n), z: 0 }; } unproject(e, n) { const o = Fr(e), u = Os(n); return new Ui(o, u); } } const ux = vi(Un); class qT extends bc { project(e, n) { const o = (n = vi(n)) * n, u = o * o; return { x: 0.5 * ((e = vi(e)) * (0.8707 - 0.131979 * o + u * (u * (3971e-6 * o - 1529e-6 * u) - 0.013791)) / Math.PI + 0.5), y: 1 - 0.5 * (n * (1.007226 + o * (0.015085 + u * (0.028874 * o - 0.044475 - 5916e-6 * u))) / Math.PI + 1), z: 0 }; } unproject(e, n) { e = (2 * e - 0.5) * Math.PI; let o = n = (2 * (1 - n) - 1) * Math.PI, u = 25, l = 0, f = o * o; do { f = o * o; const D = f * f; l = (o * (1.007226 + f * (0.015085 + D * (0.028874 * f - 0.044475 - 5916e-6 * D))) - n) / (1.007226 + f * (0.045255 + D * (0.259866 * f - 0.311325 - 5916e-6 * 11 * D))), o = si(o - l, -ux, ux); } while (Math.abs(l) > 1e-6 && --u > 0); f = o * o; const v = si(kn(e / (0.8707 + f * (f * (f * f * f * (3971e-6 - 1529e-6 * f) - 0.013791) - 0.131979))), -180, 180), S = kn(o); return new Ui(v, S); } } const dx = vi(Un); class WT extends bc { project(e, n) { n = vi(n), e = vi(e); const o = Math.cos(n), u = 2 / Math.PI, l = Math.acos(o * Math.cos(e / 2)), f = Math.sin(l) / l, v = 0.5 * (e * u + 2 * o * Math.sin(e / 2) / f) || 0, S = 0.5 * (n + Math.sin(n) / f) || 0; return { x: 0.5 * (v / Math.PI + 0.5), y: 1 - 0.5 * (S / Math.PI + 1), z: 0 }; } unproject(e, n) { let o = e = (2 * e - 0.5) * Math.PI, u = n = (2 * (1 - n) - 1) * Math.PI, l = 25; const f = 1e-6; let v = 0, S = 0; do { const D = Math.cos(u), x = Math.sin(u), P = 2 * x * D, I = x * x, M = D * D, C = Math.cos(o / 2), k = Math.sin(o / 2), V = 2 * C * k, U = k * k, q = 1 - M * C * C, $ = q ? 1 / q : 0, H = q ? Math.acos(D * C) * Math.sqrt(1 / q) : 0, K = 0.5 * (2 * H * D * k + 2 * o / Math.PI) - e, Q = 0.5 * (H * x + u) - n, ie = 0.5 * $ * (M * U + H * D * C * I) + 1 / Math.PI, fe = $ * (V * P / 4 - H * x * k), de = 0.125 * $ * (P * k - H * x * M * V), ue = 0.5 * $ * (I * C + H * U * D) + 0.5, Se = fe * de - ue * ie; v = (Q * fe - K * ue) / Se, S = (K * de - Q * ie) / Se, o = si(o - v, -Math.PI, Math.PI), u = si(u - S, -dx, dx); } while ((Math.abs(v) > f || Math.abs(S) > f) && --l > 0); return new Ui(kn(o), kn(u)); } } class fx extends bc { constructor(e) { super(e), this.center = e.center || [0, 0], this.parallels = e.parallels || [0, 0], this.cosPhi = Math.max(0.01, Math.cos(vi(this.parallels[0]))), this.scale = 1 / (2 * Math.max(Math.PI * this.cosPhi, 1 / this.cosPhi)), this.wrap = !0, this.supportsWorldCopies = !0; } project(e, n) { const { scale: o, cosPhi: u } = this; return { x: vi(e) * u * o + 0.5, y: -Math.sin(vi(n)) / u * o + 0.5, z: 0 }; } unproject(e, n) { const { scale: o, cosPhi: u } = this, l = -(n - 0.5) / o, f = si(kn((e - 0.5) / o) / u, -180, 180), v = Math.asin(si(l * u, -1, 1)), S = si(kn(v), -Un, Un); return new Ui(f, S); } } class $T extends hx { constructor(e) { super(e), this.requiresDraping = !0, this.supportsWorldCopies = !1, this.supportsFog = !0, this.zAxisUnit = "pixels", this.unsupportedLayers = ["debug"], this.range = [3, 5]; } projectTilePoint(e, n, o) { const u = Ri(e, n, o), l = cn(ts(o)); return De.vec3.transformMat4(u, u, l), { x: u[0], y: u[1], z: u[2] }; } locationPoint(e, n) { const o = el(n.lat, n.lng), u = De.vec3.normalize([], o), l = e.elevation ? e.elevation.getAtPointOrZero(e.locationCoordinate(n), e._centerAltitude) : e._centerAltitude, f = fr(1, 0) * Tt * l; De.vec3.scaleAndAdd(o, o, u, f); const v = De.mat4.identity(new Float64Array(16)); return De.mat4.multiply(v, e.pixelMatrix, e.globeMatrix), De.vec3.transformMat4(o, o, v), new Et(o[0], o[1]); } pixelsPerMeter(e, n) { return fr(1, 0) * n; } pixelSpaceConversion(e, n, o) { const u = fr(1, e) * n, l = ei(fr(1, 45) * n, u, o); return this.pixelsPerMeter(e, n) / l; } createTileMatrix(e, n, o) { const u = er(ts(o.canonical)); return De.mat4.multiply(new Float64Array(16), e.globeMatrix, u); } createInversionMatrix(e, n) { const { center: o } = e, u = cn(ts(n)); return De.mat4.rotateY(u, u, vi(o.lng)), De.mat4.rotateX(u, u, vi(o.lat)), De.mat4.scale(u, u, [e._pixelsPerMercatorPixel, e._pixelsPerMercatorPixel, 1]), Float32Array.from(u); } pointCoordinate(e, n, o, u) { return In(e, n, o, !0) || new h(0, 0); } pointCoordinate3D(e, n, o) { const u = this.pointCoordinate(e, n, o, 0); return [u.x, u.y, u.z]; } isPointAboveHorizon(e, n) { return !In(e, n.x, n.y, !1); } farthestPixelDistance(e) { const n = function(u, l) { const f = u.cameraToCenterDistance, v = u._centerAltitude * l, S = u._camera, D = u._camera.forward(), x = De.vec3.add([], De.vec3.scale([], D, -f), [0, 0, v]), P = u.worldSize / (2 * Math.PI), I = [0, 0, -P], M = u.width / u.height, C = Math.tan(u.fovAboveCenter), k = De.vec3.scale([], S.up(), C), V = De.vec3.scale([], S.right(), C * M), U = De.vec3.normalize([], De.vec3.add([], De.vec3.add([], D, k), V)), q = []; let $; if (new zi(x, U).closestPointOnSphere(I, P, q)) { const H = De.vec3.add([], q, I), K = De.vec3.sub([], H, x); $ = Math.cos(u.fovAboveCenter) * De.vec3.length(K); } else { const H = De.vec3.sub([], x, I), K = De.vec3.sub([], I, x); De.vec3.normalize(K, K); const Q = De.vec3.length(H) - P; $ = Math.sqrt(Q * (Q + 2 * P)); const ie = Math.acos($ / (P + Q)) - Math.acos(De.vec3.dot(D, K)); $ *= Math.cos(ie); } return 1.01 * $; }(e, this.pixelsPerMeter(e.center.lat, e.worldSize)), o = mr(e.zoom); if (o > 0) { const u = lx(e, fr(1, e.center.lat) * e.worldSize), l = e.worldSize / (2 * Math.PI), f = Math.max(e.width, e.height) / e.worldSize * Math.PI; return ei(n, u + l * (1 - Math.cos(f)), Math.pow(o, 10)); } return n; } upVector(e, n, o) { return Ri(n, o, e, 1); } upVectorScale(e) { return { metersToTile: ji(Gn(ts(e))) }; } } function px(r) { const e = r.parallels, n = !!e && Math.abs(e[0] + e[1]) < 0.01; switch (r.name) { case "mercator": return new hx(r); case "equirectangular": return new ZT(r); case "naturalEarth": return new qT(r); case "equalEarth": return new GT(r); case "winkelTripel": return new WT(r); case "albers": return n ? new fx(r) : new jT(r); case "lambertConformalConic": return n ? new fx(r) : new HT(r); case "globe": return new $T(r); } throw new Error(`Invalid projection name: ${r.name}`); } const XT = Iu.VectorTileFeature.types, YT = [{ name: "a_fade_opacity", components: 1, type: "Uint8", offset: 0 }]; function Up(r, e, n, o, u, l, f, v, S, D, x, P, I) { const M = v ? Math.min(vc, Math.round(v[0])) : 0, C = v ? Math.min(vc, Math.round(v[1])) : 0; r.emplaceBack(e, n, Math.round(32 * o), Math.round(32 * u), l, f, (M << 1) + (S ? 1 : 0), C, 16 * D, 16 * x, 256 * P, 256 * I); } function jp(r, e, n) { r.emplaceBack(e, n); } function Gp(r, e, n, o, u, l, f) { r.emplaceBack(e, n, o, u, l, f); } function Zp(r, e, n, o, u) { r.emplaceBack(e, n, o, u), r.emplaceBack(e, n, o, u), r.emplaceBack(e, n, o, u), r.emplaceBack(e, n, o, u); } function KT(r) { for (const e of r.sections) if (Qf(e.text)) return !0; return !1; } class Z_ { constructor(e) { this.layoutVertexArray = new Td(), this.indexArray = new qs(), this.programConfigurations = e, this.segments = new Wn(), this.dynamicLayoutVertexArray = new Xa(), this.opacityVertexArray = new Sd(), this.placedSymbolArray = new cp(), this.iconTransitioningVertexArray = new Ka(), this.globeExtVertexArray = new Md(), this.zOffsetVertexArray = new uc(); } isEmpty() { return this.layoutVertexArray.length === 0 && this.indexArray.length === 0 && this.dynamicLayoutVertexArray.length === 0 && this.opacityVertexArray.length === 0 && this.iconTransitioningVertexArray.length === 0; } upload(e, n, o, u, l) { this.isEmpty() || (o && (this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, pT.members), this.indexBuffer = e.createIndexBuffer(this.indexArray, n), this.dynamicLayoutVertexBuffer = e.createVertexBuffer(this.dynamicLayoutVertexArray, _T.members, !0), this.opacityVertexBuffer = e.createVertexBuffer(this.opacityVertexArray, YT, !0), this.iconTransitioningVertexArray.length > 0 && (this.iconTransitioningVertexBuffer = e.createVertexBuffer(this.iconTransitioningVertexArray, yT.members, !0)), this.globeExtVertexArray.length > 0 && (this.globeExtVertexBuffer = e.createVertexBuffer(this.globeExtVertexArray, mT.members, !0)), !this.zOffsetVertexBuffer && (this.zOffsetVertexArray.length > 0 || l) && (this.zOffsetVertexBuffer = e.createVertexBuffer(this.zOffsetVertexArray, gT.members, !0)), this.opacityVertexBuffer.itemSize = 1), (o || u) && this.programConfigurations.upload(e)); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.programConfigurations.destroy(), this.segments.destroy(), this.dynamicLayoutVertexBuffer.destroy(), this.opacityVertexBuffer.destroy(), this.iconTransitioningVertexBuffer && this.iconTransitioningVertexBuffer.destroy(), this.globeExtVertexBuffer && this.globeExtVertexBuffer.destroy(), this.zOffsetVertexBuffer && this.zOffsetVertexBuffer.destroy()); } } Ft(Z_, "SymbolBuffers"); class H_ { constructor(e, n, o) { this.layoutVertexArray = new e(), this.layoutAttributes = n, this.indexArray = new o(), this.segments = new Wn(), this.collisionVertexArray = new Pd(), this.collisionVertexArrayExt = new Xa(); } upload(e) { this.layoutVertexBuffer = e.createVertexBuffer(this.layoutVertexArray, this.layoutAttributes), this.indexBuffer = e.createIndexBuffer(this.indexArray), this.collisionVertexBuffer = e.createVertexBuffer(this.collisionVertexArray, xT.members, !0), this.collisionVertexBufferExt = e.createVertexBuffer(this.collisionVertexArrayExt, vT.members, !0); } destroy() { this.layoutVertexBuffer && (this.layoutVertexBuffer.destroy(), this.indexBuffer.destroy(), this.segments.destroy(), this.collisionVertexBuffer.destroy(), this.collisionVertexBufferExt.destroy()); } } Ft(H_, "CollisionBuffers"); class Hp { constructor(e) { this.collisionBoxArray = e.collisionBoxArray, this.zoom = e.zoom, this.lut = e.lut, this.overscaling = e.overscaling, this.layers = e.layers, this.layerIds = this.layers.map((f) => f.fqid), this.index = e.index, this.pixelRatio = e.pixelRatio, this.sourceLayerIndex = e.sourceLayerIndex, this.hasPattern = !1, this.hasRTLText = !1, this.fullyClipped = !1, this.hasAnyIconTextFit = !1, this.sortKeyRanges = [], this.collisionCircleArray = [], this.placementInvProjMatrix = De.mat4.identity([]), this.placementViewportMatrix = De.mat4.identity([]); const n = this.layers[0]._unevaluatedLayout._values; this.textSizeData = D_(this.zoom, n["text-size"]), this.iconSizeData = D_(this.zoom, n["icon-size"]); const o = this.layers[0].layout, u = o.get("symbol-sort-key"), l = o.get("symbol-z-order"); this.canOverlap = o.get("text-allow-overlap") || o.get("icon-allow-overlap") || o.get("text-ignore-placement") || o.get("icon-ignore-placement"), this.sortFeaturesByKey = l !== "viewport-y" && u.constantOr(1) !== void 0, this.sortFeaturesByY = (l === "viewport-y" || l === "auto" && !this.sortFeaturesByKey) && this.canOverlap, this.writingModes = o.get("text-writing-mode").map((f) => Ro[f]), this.stateDependentLayerIds = this.layers.filter((f) => f.isStateDependent()).map((f) => f.id), this.sourceID = e.sourceID, this.projection = e.projection, this.hasAnyZOffset = !1, this.zOffsetSortDirty = !1, this.zOffsetBuffersNeedUpload = o.get("symbol-z-elevate"), this.activeReplacements = [], this.replacementUpdateTime = 0; } createArrays() { this.text = new Z_(new Qa(this.layers, { zoom: this.zoom, lut: this.lut }, (e) => e.startsWith("text") || e.startsWith("symbol"))), this.icon = new Z_(new Qa(this.layers, { zoom: this.zoom, lut: this.lut }, (e) => e.startsWith("icon") || e.startsWith("symbol"))), this.glyphOffsetArray = new hh(), this.lineVertexArray = new uh(), this.symbolInstances = new up(); } calculateGlyphDependencies(e, n, o, u, l) { for (const f of e) { const v = f.codePointAt(0); if (v === void 0) break; if (n[v] = !0, u && l && v <= 65535) { const S = $d[f]; S && (n[S.charCodeAt(0)] = !0); } } } updateFootprints(e, n) { } updateReplacement(e, n) { if (n.updateTime === this.replacementUpdateTime) return !1; this.replacementUpdateTime = n.updateTime; const o = n.getReplacementRegionsForTile(e.toUnwrapped(), !0); return !E_(this.activeReplacements, o) && (this.activeReplacements = o, !0); } populate(e, n, o, u) { const l = this.layers[0], f = l.layout, v = this.projection.name === "globe", S = f.get("text-font"), D = f.get("text-field"), x = f.get("icon-image"), [P, I] = f.get("icon-size-scale-range"), M = si(n.scaleFactor || 1, P, I), C = (D.value.kind !== "constant" || D.value.value instanceof Dn && !D.value.value.isEmpty() || D.value.value.toString().length > 0) && (S.value.kind !== "constant" || S.value.value.length > 0), k = x.value.kind !== "constant" || !!x.value.value || Object.keys(x.parameters).length > 0, V = f.get("symbol-sort-key"); if (this.features = [], !C && !k) return; const U = n.iconDependencies, q = n.glyphDependencies, $ = n.availableImages, H = new Tn(this.zoom); for (const { feature: K, id: Q, index: ie, sourceLayerIndex: fe } of e) { const de = l._featureFilter.needGeometry, ue = Z(K, de); if (!l._featureFilter.filter(H, ue, o)) continue; if (de || (ue.geometry = G(K, o, u)), v && K.type !== 1 && o.z <= 5) { const Ie = ue.geometry, Re = 0.98078528056, Ve = (Ue, Fe) => { const et = Ri(Ue.x, Ue.y, o, 1), dt = Ri(Fe.x, Fe.y, o, 1); return De.vec3.dot(et, dt) < Re; }; for (let Ue = 0; Ue < Ie.length; Ue++) Ie[Ue] = z(Ie[Ue], Ve); } let Se, me; if (C) { const Ie = l.getValueAndResolveTokens("text-field", ue, o, $), Re = Dn.factory(Ie); KT(Re) && (this.hasRTLText = !0), (!this.hasRTLText || au() === "unavailable" || this.hasRTLText && co.isParsed()) && (Se = TT(Re, l, ue)); } if (k) { const Ie = l.getValueAndResolveTokens("icon-image", ue, o, $); me = Ie instanceof ss ? Ie : ss.build(Ie); } if (!Se && !me) continue; const Ee = this.sortFeaturesByKey ? V.evaluate(ue, {}, o) : void 0, ze = { id: Q, text: Se, icon: me, index: ie, sourceLayerIndex: fe, geometry: ue.geometry, properties: K.properties, type: XT[K.type], sortKey: Ee }; if (this.features.push(ze), me) { const Ie = Lp(this.iconSizeData, this.layers[0]._unevaluatedLayout._values["icon-size"], o, this.zoom, ze) * M * this.pixelRatio, Re = me.getPrimary().scaleSelf(Ie); if (U[Re.id] = U[Re.id] || [], U[Re.id].push(Re), me.nameSecondary) { const Ve = me.getSecondary().scaleSelf(Ie); U[Ve.id] = U[Ve.id] || [], U[Ve.id].push(Ve); } } if (Se) { const Ie = S.evaluate(ue, {}, o).join(","), Re = f.get("text-rotation-alignment") === "map" && f.get("symbol-placement") !== "point"; this.allowVerticalPlacement = this.writingModes && this.writingModes.indexOf(Ro.vertical) >= 0; for (const Ve of Se.sections) if (Ve.image) { const Ue = Ve.image.getPrimary().scaleSelf(this.pixelRatio); U[Ue.id] = U[Ue.id] || [], U[Ue.id].push(Ue); } else { const Ue = md(Se.toString()), Fe = Ve.fontStack || Ie, et = q[Fe] = q[Fe] || {}; this.calculateGlyphDependencies(Ve.text, et, Re, this.allowVerticalPlacement, Ue); } } } f.get("symbol-placement") === "line" && (this.features = function(K) { const Q = {}, ie = {}, fe = []; let de = 0; function ue(ze) { fe.push(K[ze]), de++; } function Se(ze, Ie, Re) { const Ve = ie[ze]; return delete ie[ze], ie[Ie] = Ve, fe[Ve].geometry[0].pop(), fe[Ve].geometry[0] = fe[Ve].geometry[0].concat(Re[0]), Ve; } function me(ze, Ie, Re) { const Ve = Q[Ie]; return delete Q[Ie], Q[ze] = Ve, fe[Ve].geometry[0].shift(), fe[Ve].geometry[0] = Re[0].concat(fe[Ve].geometry[0]), Ve; } function Ee(ze, Ie, Re) { const Ve = Re ? Ie[0][Ie[0].length - 1] : Ie[0][0]; return `${ze}:${Ve.x}:${Ve.y}`; } for (let ze = 0; ze < K.length; ze++) { const Ie = K[ze], Re = Ie.geometry, Ve = Ie.text ? Ie.text.toString() : null; if (!Ve) { ue(ze); continue; } const Ue = Ee(Ve, Re), Fe = Ee(Ve, Re, !0); if (Ue in ie && Fe in Q && ie[Ue] !== Q[Fe]) { const et = me(Ue, Fe, Re), dt = Se(Ue, Fe, fe[et].geometry); delete Q[Ue], delete ie[Fe], ie[Ee(Ve, fe[dt].geometry, !0)] = dt, fe[et].geometry = null; } else Ue in ie ? Se(Ue, Fe, Re) : Fe in Q ? me(Ue, Fe, Re) : (ue(ze), Q[Ue] = de - 1, ie[Fe] = de - 1); } return fe.filter((ze) => ze.geometry); }(this.features)), this.sortFeaturesByKey && this.features.sort((K, Q) => K.sortKey - Q.sortKey); } update(e, n, o, u, l, f, v) { this.text.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v), this.icon.programConfigurations.updatePaintArrays(e, n, l, o, u, f, v); } updateZOffset() { const e = (l, f, v) => { o += f, o > l.length && l.resize(o); for (let S = -f; S < 0; S++) l.emplace(S + o, v); }, n = (l, f, v) => { u += f, u > l.length && l.resize(u); for (let S = -f; S < 0; S++) l.emplace(S + u, v); }; if (!this.zOffsetBuffersNeedUpload) return; this.zOffsetBuffersNeedUpload = !1; let o = 0, u = 0; for (let l = 0; l < this.symbolInstances.length; l++) { const f = this.symbolInstances.get(l), { numHorizontalGlyphVertices: v, numVerticalGlyphVertices: S, numIconVertices: D } = f, x = f.zOffset, P = D > 0; if ((v > 0 || S > 0) && (e(this.text.zOffsetVertexArray, v, x), e(this.text.zOffsetVertexArray, S, x)), P) { const { placedIconSymbolIndex: I, verticalPlacedIconSymbolIndex: M } = f; I >= 0 && n(this.icon.zOffsetVertexArray, D, x), M >= 0 && n(this.icon.zOffsetVertexArray, f.numVerticalIconVertices, x); } } this.text.zOffsetVertexBuffer && this.text.zOffsetVertexBuffer.updateData(this.text.zOffsetVertexArray), this.icon.zOffsetVertexBuffer && this.icon.zOffsetVertexBuffer.updateData(this.icon.zOffsetVertexArray); } isEmpty() { return this.symbolInstances.length === 0 && !this.hasRTLText; } uploadPending() { return !this.uploaded || this.text.programConfigurations.needsUpload || this.icon.programConfigurations.needsUpload; } upload(e) { !this.uploaded && this.hasDebugData() && (this.textCollisionBox.upload(e), this.iconCollisionBox.upload(e)), this.text.upload(e, this.sortFeaturesByY, !this.uploaded, this.text.programConfigurations.needsUpload, this.zOffsetBuffersNeedUpload), this.icon.upload(e, this.sortFeaturesByY, !this.uploaded, this.icon.programConfigurations.needsUpload, this.zOffsetBuffersNeedUpload), this.uploaded = !0; } destroyDebugData() { this.textCollisionBox.destroy(), this.iconCollisionBox.destroy(); } getProjection() { return this.projectionInstance || (this.projectionInstance = px(this.projection)), this.projectionInstance; } destroy() { this.text.destroy(), this.icon.destroy(), this.hasDebugData() && this.destroyDebugData(); } addToLineVertexArray(e, n) { const o = this.lineVertexArray.length; if (e.segment !== void 0) for (const { x: u, y: l } of n) this.lineVertexArray.emplaceBack(u, l); return { lineStartIndex: o, lineLength: this.lineVertexArray.length - o }; } addSymbols(e, n, o, u, l, f, v, S, D, x, P, I, M, C, k, V) { const U = e.indexArray, q = e.layoutVertexArray, $ = e.globeExtVertexArray, H = e.segments.prepareSegment(4 * n.length, q, U, this.canOverlap ? f.sortKey : void 0), K = this.glyphOffsetArray.length, Q = H.vertexLength, ie = this.allowVerticalPlacement && v === Ro.vertical ? Math.PI / 2 : 0, fe = f.text && f.text.sections; for (let ue = 0; ue < n.length; ue++) { const { tl: Se, tr: me, bl: Ee, br: ze, texPrimary: Ie, texSecondary: Re, pixelOffsetTL: Ve, pixelOffsetBR: Ue, minFontScaleX: Fe, minFontScaleY: et, glyphOffset: dt, isSDF: tt, sectionIndex: Mt } = n[ue], wt = H.vertexLength, At = dt[1]; if (Up(q, D.x, D.y, Se.x, At + Se.y, Ie.x, Ie.y, o, tt, Ve.x, Ve.y, Fe, et), Up(q, D.x, D.y, me.x, At + me.y, Ie.x + Ie.w, Ie.y, o, tt, Ue.x, Ve.y, Fe, et), Up(q, D.x, D.y, Ee.x, At + Ee.y, Ie.x, Ie.y + Ie.h, o, tt, Ve.x, Ue.y, Fe, et), Up(q, D.x, D.y, ze.x, At + ze.y, Ie.x + Ie.w, Ie.y + Ie.h, o, tt, Ue.x, Ue.y, Fe, et), S) { const { x: rt, y: Ut, z: St } = S.anchor, [Nt, Qt, pi] = S.up; Gp($, rt, Ut, St, Nt, Qt, pi), Gp($, rt, Ut, St, Nt, Qt, pi), Gp($, rt, Ut, St, Nt, Qt, pi), Gp($, rt, Ut, St, Nt, Qt, pi), Zp(e.dynamicLayoutVertexArray, rt, Ut, St, ie); } else Zp(e.dynamicLayoutVertexArray, D.x, D.y, D.z, ie); if (V) { const rt = Re || Ie; jp(e.iconTransitioningVertexArray, rt.x, rt.y), jp(e.iconTransitioningVertexArray, rt.x + rt.w, rt.y), jp(e.iconTransitioningVertexArray, rt.x, rt.y + rt.h), jp(e.iconTransitioningVertexArray, rt.x + rt.w, rt.y + rt.h); } U.emplaceBack(wt, wt + 1, wt + 2), U.emplaceBack(wt + 1, wt + 2, wt + 3), H.vertexLength += 4, H.primitiveLength += 2, this.glyphOffsetArray.emplaceBack(dt[0]), ue !== n.length - 1 && Mt === n[ue + 1].sectionIndex || e.programConfigurations.populatePaintArrays(q.length, f, f.index, {}, M, C, k, fe && fe[Mt]); } const de = S ? S.anchor : D; e.placedSymbolArray.emplaceBack(de.x, de.y, de.z, D.x, D.y, K, this.glyphOffsetArray.length - K, Q, x, P, D.segment, o ? o[0] : 0, o ? o[1] : 0, u[0], u[1], v, 0, !1, 0, I, 0); } _commitLayoutVertex(e, n, o, u, l, f, v) { e.emplaceBack(n, o, u, l, f, Math.round(v.x), Math.round(v.y)); } _addCollisionDebugVertices(e, n, o, u, l, f, v) { const S = o.segments.prepareSegment(4, o.layoutVertexArray, o.indexArray), D = S.vertexLength, x = v.tileAnchorX, P = v.tileAnchorY; for (let M = 0; M < 4; M++) o.collisionVertexArray.emplaceBack(0, 0, 0, 0, 0, 0); this._commitDebugCollisionVertexUpdate(o.collisionVertexArrayExt, n, e.padding, v.zOffset), this._commitLayoutVertex(o.layoutVertexArray, u, l, f, x, P, new Et(e.x1, e.y1)), this._commitLayoutVertex(o.layoutVertexArray, u, l, f, x, P, new Et(e.x2, e.y1)), this._commitLayoutVertex(o.layoutVertexArray, u, l, f, x, P, new Et(e.x2, e.y2)), this._commitLayoutVertex(o.layoutVertexArray, u, l, f, x, P, new Et(e.x1, e.y2)), S.vertexLength += 4; const I = o.indexArray; I.emplaceBack(D, D + 1), I.emplaceBack(D + 1, D + 2), I.emplaceBack(D + 2, D + 3), I.emplaceBack(D + 3, D), S.primitiveLength += 4; } _addTextDebugCollisionBoxes(e, n, o, u, l, f) { for (let v = u; v < l; v++) { const S = o.get(v), D = this.getSymbolInstanceTextSize(e, f, n, v); this._addCollisionDebugVertices(S, D, this.textCollisionBox, S.projectedAnchorX, S.projectedAnchorY, S.projectedAnchorZ, f); } } _addIconDebugCollisionBoxes(e, n, o, u, l, f) { for (let v = u; v < l; v++) { const S = o.get(v), D = this.getSymbolInstanceIconSize(e, n, f.placedIconSymbolIndex); this._addCollisionDebugVertices(S, D, this.iconCollisionBox, S.projectedAnchorX, S.projectedAnchorY, S.projectedAnchorZ, f); } } generateCollisionDebugBuffers(e, n, o) { this.hasDebugData() && this.destroyDebugData(), this.textCollisionBox = new H_(mu, R0.members, Ka), this.iconCollisionBox = new H_(mu, R0.members, Ka); const u = Lu(this.iconSizeData, e), l = Lu(this.textSizeData, e, o); for (let f = 0; f < this.symbolInstances.length; f++) { const v = this.symbolInstances.get(f); this._addTextDebugCollisionBoxes(l, e, n, v.textBoxStartIndex, v.textBoxEndIndex, v), this._addTextDebugCollisionBoxes(l, e, n, v.verticalTextBoxStartIndex, v.verticalTextBoxEndIndex, v), this._addIconDebugCollisionBoxes(u, e, n, v.iconBoxStartIndex, v.iconBoxEndIndex, v), this._addIconDebugCollisionBoxes(u, e, n, v.verticalIconBoxStartIndex, v.verticalIconBoxEndIndex, v); } } getSymbolInstanceTextSize(e, n, o, u) { const l = this.text.placedSymbolArray.get(n.rightJustifiedTextSymbolIndex >= 0 ? n.rightJustifiedTextSymbolIndex : n.centerJustifiedTextSymbolIndex >= 0 ? n.centerJustifiedTextSymbolIndex : n.leftJustifiedTextSymbolIndex >= 0 ? n.leftJustifiedTextSymbolIndex : n.verticalPlacedTextSymbolIndex >= 0 ? n.verticalPlacedTextSymbolIndex : u), f = zp(this.textSizeData, e, l) / tr; return this.tilePixelRatio * f; } getSymbolInstanceIconSize(e, n, o) { const u = this.icon.placedSymbolArray.get(o), l = zp(this.iconSizeData, e, u); return this.tilePixelRatio * l; } _commitDebugCollisionVertexUpdate(e, n, o, u) { e.emplaceBack(n, -o, -o, u), e.emplaceBack(n, o, -o, u), e.emplaceBack(n, o, o, u), e.emplaceBack(n, -o, o, u); } _updateTextDebugCollisionBoxes(e, n, o, u, l, f, v) { for (let S = u; S < l; S++) { const D = o.get(S), x = this.getSymbolInstanceTextSize(e, f, n, S); this._commitDebugCollisionVertexUpdate(this.textCollisionBox.collisionVertexArrayExt, x, D.padding, f.zOffset); } } _updateIconDebugCollisionBoxes(e, n, o, u, l, f, v) { for (let S = u; S < l; S++) { const D = o.get(S), x = this.getSymbolInstanceIconSize(e, n, f.placedIconSymbolIndex); this._commitDebugCollisionVertexUpdate(this.iconCollisionBox.collisionVertexArrayExt, x, D.padding, f.zOffset); } } updateCollisionDebugBuffers(e, n, o, u) { if (!this.hasDebugData()) return; this.hasTextCollisionBoxData() && this.textCollisionBox.collisionVertexArrayExt.clear(), this.hasIconCollisionBoxData() && this.iconCollisionBox.collisionVertexArrayExt.clear(); const l = Lu(this.iconSizeData, e, u), f = Lu(this.textSizeData, e, o); for (let v = 0; v < this.symbolInstances.length; v++) { const S = this.symbolInstances.get(v); this._updateTextDebugCollisionBoxes(f, e, n, S.textBoxStartIndex, S.textBoxEndIndex, S, o), this._updateTextDebugCollisionBoxes(f, e, n, S.verticalTextBoxStartIndex, S.verticalTextBoxEndIndex, S, o), this._updateIconDebugCollisionBoxes(l, e, n, S.iconBoxStartIndex, S.iconBoxEndIndex, S, u), this._updateIconDebugCollisionBoxes(l, e, n, S.verticalIconBoxStartIndex, S.verticalIconBoxEndIndex, S, u); } 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(e, n, o, u, l, f, v, S, D) { const x = {}; if (n < o) { const { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H, featureIndex: K } = e.get(n); x.textBox = { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H }, x.textFeatureIndex = K; } if (u < l) { const { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H, featureIndex: K } = e.get(u); x.verticalTextBox = { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H }, x.verticalTextFeatureIndex = K; } if (f < v) { const { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H, featureIndex: K } = e.get(f); x.iconBox = { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H }, x.iconFeatureIndex = K; } if (S < D) { const { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H, featureIndex: K } = e.get(S); x.verticalIconBox = { x1: P, y1: I, x2: M, y2: C, padding: k, projectedAnchorX: V, projectedAnchorY: U, projectedAnchorZ: q, tileAnchorX: $, tileAnchorY: H }, x.verticalIconFeatureIndex = K; } return x; } deserializeCollisionBoxes(e) { this.collisionArrays = []; for (let n = 0; n < this.symbolInstances.length; n++) { const o = this.symbolInstances.get(n); this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(e, o.textBoxStartIndex, o.textBoxEndIndex, o.verticalTextBoxStartIndex, o.verticalTextBoxEndIndex, o.iconBoxStartIndex, o.iconBoxEndIndex, o.verticalIconBoxStartIndex, o.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; } hasIconTextFit() { return this.hasAnyIconTextFit; } addIndicesForPlacedSymbol(e, n) { const o = e.placedSymbolArray.get(n), u = o.vertexStartIndex + 4 * o.numGlyphs; for (let l = o.vertexStartIndex; l < u; l += 4) e.indexArray.emplaceBack(l, l + 1, l + 2), e.indexArray.emplaceBack(l + 1, l + 2, l + 3); } getSortedSymbolIndexes(e) { if (this.sortedAngle === e && this.symbolInstanceIndexes !== void 0) return this.symbolInstanceIndexes; const n = Math.sin(e), o = Math.cos(e), u = [], l = [], f = []; for (let v = 0; v < this.symbolInstances.length; ++v) { f.push(v); const S = this.symbolInstances.get(v); u.push(0 | Math.round(n * S.tileAnchorX + o * S.tileAnchorY)), l.push(S.featureIndex); } return f.sort((v, S) => u[v] - u[S] || l[S] - l[v]), f; } getSortedIndexesByZOffset() { if (!this.zOffsetSortDirty) return this.symbolInstanceIndexesSortedZOffset; if (!this.symbolInstanceIndexesSortedZOffset) { this.symbolInstanceIndexesSortedZOffset = []; for (let e = 0; e < this.symbolInstances.length; ++e) this.symbolInstanceIndexesSortedZOffset.push(e); } return this.zOffsetSortDirty = !1, this.symbolInstanceIndexesSortedZOffset.sort((e, n) => this.symbolInstances.get(n).zOffset - this.symbolInstances.get(e).zOffset); } addToSortKeyRanges(e, n) { const o = this.sortKeyRanges[this.sortKeyRanges.length - 1]; o && o.sortKey === n ? o.symbolInstanceEnd = e + 1 : this.sortKeyRanges.push({ sortKey: n, symbolInstanceStart: e, symbolInstanceEnd: e + 1 }); } sortFeatures(e) { if (this.sortFeaturesByY && this.sortedAngle !== e && !(this.text.segments.get().length > 1 || this.icon.segments.get().length > 1)) { this.symbolInstanceIndexes = this.getSortedSymbolIndexes(e), this.sortedAngle = e, this.text.indexArray.clear(), this.icon.indexArray.clear(), this.featureSortOrder = []; for (const n of this.symbolInstanceIndexes) { const o = this.symbolInstances.get(n); this.featureSortOrder.push(o.featureIndex); const { rightJustifiedTextSymbolIndex: u, centerJustifiedTextSymbolIndex: l, leftJustifiedTextSymbolIndex: f, verticalPlacedTextSymbolIndex: v, placedIconSymbolIndex: S, verticalPlacedIconSymbolIndex: D } = o; u >= 0 && this.addIndicesForPlacedSymbol(this.text, u), l >= 0 && l !== u && this.addIndicesForPlacedSymbol(this.text, l), f >= 0 && f !== l && f !== u && this.addIndicesForPlacedSymbol(this.text, f), v >= 0 && this.addIndicesForPlacedSymbol(this.text, v), S >= 0 && this.addIndicesForPlacedSymbol(this.icon, S), D >= 0 && this.addIndicesForPlacedSymbol(this.icon, D); } this.text.indexBuffer && this.text.indexBuffer.updateData(this.text.indexArray), this.icon.indexBuffer && this.icon.indexBuffer.updateData(this.icon.indexArray); } } } let mx, _x, q_; Ft(Hp, "SymbolBucket", { omit: ["layers", "collisionBoxArray", "features", "compareText"] }), Hp.addDynamicAttributes = Zp; class gx { constructor(e) { this.type = e.property.overrides ? e.property.overrides.runtimeType : ha, this.defaultValue = e; } evaluate(e) { if (e.formattedSection) { const n = this.defaultValue.property.overrides; if (n && n.hasOverride(e.formattedSection)) return n.getOverride(e.formattedSection); } return e.feature && e.featureState ? this.defaultValue.evaluate(e.feature, e.featureState) : this.defaultValue.property.specification.default; } eachChild(e) { this.defaultValue.isConstant() || e(this.defaultValue.value._styleExpression.expression); } outputDefined() { return !1; } serialize() { return null; } } Ft(gx, "FormatSectionOverride", { omit: ["defaultValue"] }); const W_ = () => q_ || (q_ = { layout: mx || (mx = new Bn({ "symbol-placement": new yt($e.layout_symbol["symbol-placement"]), "symbol-spacing": new yt($e.layout_symbol["symbol-spacing"]), "symbol-avoid-edges": new yt($e.layout_symbol["symbol-avoid-edges"]), "symbol-sort-key": new Dt($e.layout_symbol["symbol-sort-key"]), "symbol-z-order": new yt($e.layout_symbol["symbol-z-order"]), "symbol-z-elevate": new yt($e.layout_symbol["symbol-z-elevate"]), "symbol-elevation-reference": new yt($e.layout_symbol["symbol-elevation-reference"]), "icon-allow-overlap": new yt($e.layout_symbol["icon-allow-overlap"]), "icon-ignore-placement": new yt($e.layout_symbol["icon-ignore-placement"]), "icon-optional": new yt($e.layout_symbol["icon-optional"]), "icon-rotation-alignment": new yt($e.layout_symbol["icon-rotation-alignment"]), "icon-size": new Dt($e.layout_symbol["icon-size"]), "icon-size-scale-range": new yt($e.layout_symbol["icon-size-scale-range"]), "icon-text-fit": new Dt($e.layout_symbol["icon-text-fit"]), "icon-text-fit-padding": new Dt($e.layout_symbol["icon-text-fit-padding"]), "icon-image": new Dt($e.layout_symbol["icon-image"]), "icon-rotate": new Dt($e.layout_symbol["icon-rotate"]), "icon-padding": new yt($e.layout_symbol["icon-padding"]), "icon-keep-upright": new yt($e.layout_symbol["icon-keep-upright"]), "icon-offset": new Dt($e.layout_symbol["icon-offset"]), "icon-anchor": new Dt($e.layout_symbol["icon-anchor"]), "icon-pitch-alignment": new yt($e.layout_symbol["icon-pitch-alignment"]), "text-pitch-alignment": new yt($e.layout_symbol["text-pitch-alignment"]), "text-rotation-alignment": new yt($e.layout_symbol["text-rotation-alignment"]), "text-field": new Dt($e.layout_symbol["text-field"]), "text-font": new Dt($e.layout_symbol["text-font"]), "text-size": new Dt($e.layout_symbol["text-size"]), "text-size-scale-range": new yt($e.layout_symbol["text-size-scale-range"]), "text-max-width": new Dt($e.layout_symbol["text-max-width"]), "text-line-height": new Dt($e.layout_symbol["text-line-height"]), "text-letter-spacing": new Dt($e.layout_symbol["text-letter-spacing"]), "text-justify": new Dt($e.layout_symbol["text-justify"]), "text-radial-offset": new Dt($e.layout_symbol["text-radial-offset"]), "text-variable-anchor": new yt($e.layout_symbol["text-variable-anchor"]), "text-anchor": new Dt($e.layout_symbol["text-anchor"]), "text-max-angle": new yt($e.layout_symbol["text-max-angle"]), "text-writing-mode": new yt($e.layout_symbol["text-writing-mode"]), "text-rotate": new Dt($e.layout_symbol["text-rotate"]), "text-padding": new yt($e.layout_symbol["text-padding"]), "text-keep-upright": new yt($e.layout_symbol["text-keep-upright"]), "text-transform": new Dt($e.layout_symbol["text-transform"]), "text-offset": new Dt($e.layout_symbol["text-offset"]), "text-allow-overlap": new yt($e.layout_symbol["text-allow-overlap"]), "text-ignore-placement": new yt($e.layout_symbol["text-ignore-placement"]), "text-optional": new yt($e.layout_symbol["text-optional"]), visibility: new yt($e.layout_symbol.visibility) })), paint: _x || (_x = new Bn({ "icon-opacity": new Dt($e.paint_symbol["icon-opacity"]), "icon-occlusion-opacity": new Dt($e.paint_symbol["icon-occlusion-opacity"]), "icon-emissive-strength": new Dt($e.paint_symbol["icon-emissive-strength"]), "text-emissive-strength": new Dt($e.paint_symbol["text-emissive-strength"]), "icon-color": new Dt($e.paint_symbol["icon-color"]), "icon-halo-color": new Dt($e.paint_symbol["icon-halo-color"]), "icon-halo-width": new Dt($e.paint_symbol["icon-halo-width"]), "icon-halo-blur": new Dt($e.paint_symbol["icon-halo-blur"]), "icon-translate": new yt($e.paint_symbol["icon-translate"]), "icon-translate-anchor": new yt($e.paint_symbol["icon-translate-anchor"]), "icon-image-cross-fade": new Dt($e.paint_symbol["icon-image-cross-fade"]), "text-opacity": new Dt($e.paint_symbol["text-opacity"]), "text-occlusion-opacity": new Dt($e.paint_symbol["text-occlusion-opacity"]), "text-color": new Dt($e.paint_symbol["text-color"], { runtimeType: ms, getOverride: (r) => r.textColor, hasOverride: (r) => !!r.textColor }), "text-halo-color": new Dt($e.paint_symbol["text-halo-color"]), "text-halo-width": new Dt($e.paint_symbol["text-halo-width"]), "text-halo-blur": new Dt($e.paint_symbol["text-halo-blur"]), "text-translate": new yt($e.paint_symbol["text-translate"]), "text-translate-anchor": new yt($e.paint_symbol["text-translate-anchor"]), "icon-color-saturation": new yt($e.paint_symbol["icon-color-saturation"]), "icon-color-contrast": new yt($e.paint_symbol["icon-color-contrast"]), "icon-color-brightness-min": new yt($e.paint_symbol["icon-color-brightness-min"]), "icon-color-brightness-max": new yt($e.paint_symbol["icon-color-brightness-max"]), "symbol-z-offset": new Dt($e.paint_symbol["symbol-z-offset"]), "icon-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "icon-halo-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "text-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "text-halo-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, q_); class qp extends wr { constructor(e, n, o, u) { super(e, W_(), n, o, u), this._colorAdjustmentMatrix = De.mat4.identity([]), this.hasInitialOcclusionOpacityProperties = e.paint !== void 0 && ("icon-occlusion-opacity" in e.paint || "text-occlusion-opacity" in e.paint); } recalculate(e, n) { super.recalculate(e, n), this.layout.get("icon-rotation-alignment") === "auto" && (this.layout._values["icon-rotation-alignment"] = this.layout.get("symbol-placement") !== "point" ? "map" : "viewport"), this.layout.get("text-rotation-alignment") === "auto" && (this.layout._values["text-rotation-alignment"] = this.layout.get("symbol-placement") !== "point" ? "map" : "viewport"), this.layout.get("text-pitch-alignment") === "auto" && (this.layout._values["text-pitch-alignment"] = this.layout.get("text-rotation-alignment")), this.layout.get("icon-pitch-alignment") === "auto" && (this.layout._values["icon-pitch-alignment"] = this.layout.get("icon-rotation-alignment")); const o = this.layout.get("text-writing-mode"); if (o) { const u = []; for (const l of o) u.indexOf(l) < 0 && u.push(l); this.layout._values["text-writing-mode"] = u; } else this.layout._values["text-writing-mode"] = this.layout.get("symbol-placement") === "point" ? ["horizontal"] : ["horizontal", "vertical"]; this._setPaintOverrides(); } getColorAdjustmentMatrix(e, n, o, u) { return this._saturation === e && this._contrast === n && this._brightnessMin === o && this._brightnessMax === u || (this._colorAdjustmentMatrix = function(l, f, v, S) { l = le(l), f = re(f); const D = De.mat4.create(), x = l / 3, P = 1 - 2 * x, I = [P, x, x, 0, x, P, x, 0, x, x, P, 0, 0, 0, 0, 1], M = 0.5 - 0.5 * f, C = S - v; return De.mat4.multiply(D, [C, 0, 0, 0, 0, C, 0, 0, 0, 0, C, 0, v, v, v, 1], [f, 0, 0, 0, 0, f, 0, 0, 0, 0, f, 0, M, M, M, 1]), De.mat4.multiply(D, D, I), D; }(e, n, o, u), this._saturation = e, this._contrast = n, this._brightnessMin = o, this._brightnessMax = u), this._colorAdjustmentMatrix; } getValueAndResolveTokens(e, n, o, u) { const l = this.layout.get(e).evaluate(n, {}, o, u), f = this._unevaluatedLayout._values[e]; return f.isDataDriven() || tu(f.value) || !l ? l : function(v, S) { return S.replace(/{([^{}]+)}/g, (D, x) => x in v ? String(v[x]) : ""); }(n.properties, l); } createBucket(e) { return new Hp(e); } queryRadius() { return 0; } queryIntersectsFeature() { return !1; } _setPaintOverrides() { for (const e of W_().paint.overridableProperties) { if (!qp.hasPaintOverride(this.layout, e)) continue; const n = this.paint.get(e), o = new gx(n), u = new cd(o, n.property.specification, this.scope, this.options); let l = null; l = n.value.kind === "constant" || n.value.kind === "source" ? new hd("source", u) : new sc("composite", u, n.value.zoomStops, n.value._interpolationType), this.paint._values[e] = new lc(n.property, l, n.parameters); } } _handleOverridablePaintPropertyUpdate(e, n, o) { return !(!this.layout || n.isDataDriven() || o.isDataDriven()) && qp.hasPaintOverride(this.layout, e); } static hasPaintOverride(e, n) { const o = e.get("text-field"), u = W_().paint.properties[n]; let l = !1; const f = (v) => { for (const S of v) if (u.overrides && u.overrides.hasOverride(S)) return void (l = !0); }; if (o.value.kind === "constant" && o.value.value instanceof Dn) f(o.value.value.sections); else if (o.value.kind === "source") { const v = (D) => { l || (D instanceof Lr && vn(D.value) === Js ? f(D.value.sections) : D instanceof Es ? f(D.sections) : D.eachChild(v)); }, S = o.value; S._styleExpression && v(S._styleExpression.expression); } return l; } getProgramIds() { return ["symbol"]; } getDefaultProgramParams(e, n, o) { return { config: new Cl(this, { zoom: n, lut: o }), overrideFog: !1 }; } } let yx, xx, vx, bx; var $_ = qi([{ name: "a_pos", type: "Int16", components: 2 }, { name: "a_texture_pos", type: "Int16", components: 2 }]); function X_(r) { switch (r) { case WebGL2RenderingContext.RGBA8: return WebGL2RenderingContext.RGBA; case WebGL2RenderingContext.DEPTH_COMPONENT16: return WebGL2RenderingContext.DEPTH_COMPONENT; case WebGL2RenderingContext.DEPTH24_STENCIL8: return WebGL2RenderingContext.DEPTH_STENCIL; case WebGL2RenderingContext.R8: case WebGL2RenderingContext.R32F: return WebGL2RenderingContext.RED; } } function Y_(r) { switch (r) { case WebGL2RenderingContext.RGBA8: return WebGL2RenderingContext.UNSIGNED_BYTE; case WebGL2RenderingContext.DEPTH_COMPONENT16: return WebGL2RenderingContext.UNSIGNED_SHORT; case WebGL2RenderingContext.DEPTH24_STENCIL8: return WebGL2RenderingContext.UNSIGNED_INT_24_8; case WebGL2RenderingContext.R8: return WebGL2RenderingContext.UNSIGNED_BYTE; case WebGL2RenderingContext.R32F: return WebGL2RenderingContext.FLOAT; } } class K_ { constructor(e, n, o, u) { this.context = e, this.format = o, this.useMipmap = u && u.useMipmap, this.texture = e.gl.createTexture(), this.update(n, { premultiply: u && u.premultiply }); } update(e, n) { const o = e && e instanceof HTMLVideoElement && e.width === 0 ? e.videoWidth : e.width, u = e && e instanceof HTMLVideoElement && e.height === 0 ? e.videoHeight : e.height, { context: l } = this, { gl: f } = l, { x: v, y: S } = n && n.position ? n.position : { x: 0, y: 0 }, D = v + o, x = S + u; !this.size || this.size[0] === D && this.size[1] === x || (f.bindTexture(f.TEXTURE_2D, null), f.deleteTexture(this.texture), this.texture = f.createTexture(), this.size = null), f.bindTexture(f.TEXTURE_2D, this.texture), l.pixelStoreUnpackFlipY.set(!1), l.pixelStoreUnpack.set(1), l.pixelStoreUnpackPremultiplyAlpha.set(this.format === f.RGBA8 && (!n || n.premultiply !== !1)); const P = e instanceof HTMLImageElement || e instanceof HTMLCanvasElement || e instanceof HTMLVideoElement || e instanceof ImageData || ImageBitmap && e instanceof ImageBitmap; if (!this.size && D > 0 && x > 0) { const I = this.useMipmap ? Math.floor(Math.log2(Math.max(D, x))) + 1 : 1; f.texStorage2D(f.TEXTURE_2D, I, this.format, D, x), this.size = [D, x]; } if (this.size) if (P) f.texSubImage2D(f.TEXTURE_2D, 0, v, S, X_(this.format), Y_(this.format), e); else { const I = e.data; I && f.texSubImage2D(f.TEXTURE_2D, 0, v, S, o, u, X_(this.format), Y_(this.format), I); } this.useMipmap && f.generateMipmap(f.TEXTURE_2D); } bind(e, n, o = !1) { const { context: u } = this, { gl: l } = u; l.bindTexture(l.TEXTURE_2D, this.texture), e !== this.minFilter && (l.texParameteri(l.TEXTURE_2D, l.TEXTURE_MAG_FILTER, e), l.texParameteri(l.TEXTURE_2D, l.TEXTURE_MIN_FILTER, this.useMipmap && !o ? e === l.NEAREST ? l.NEAREST_MIPMAP_NEAREST : l.LINEAR_MIPMAP_LINEAR : e), this.minFilter = e), n !== this.wrapS && (l.texParameteri(l.TEXTURE_2D, l.TEXTURE_WRAP_S, n), l.texParameteri(l.TEXTURE_2D, l.TEXTURE_WRAP_T, n), this.wrapS = n); } bindExtraParam(e, n, o, u) { const { context: l } = this, { gl: f } = l; f.bindTexture(f.TEXTURE_2D, this.texture), n !== this.magFilter && (f.texParameteri(f.TEXTURE_2D, f.TEXTURE_MAG_FILTER, n), this.magFilter = n), e !== this.minFilter && (f.texParameteri(f.TEXTURE_2D, f.TEXTURE_MIN_FILTER, this.useMipmap ? e === f.NEAREST ? f.NEAREST_MIPMAP_NEAREST : f.LINEAR_MIPMAP_LINEAR : e), this.minFilter = e), o !== this.wrapS && (f.texParameteri(f.TEXTURE_2D, f.TEXTURE_WRAP_S, o), this.wrapS = o), u !== this.wrapT && (f.texParameteri(f.TEXTURE_2D, f.TEXTURE_WRAP_T, u), this.wrapT = u); } destroy() { const { gl: e } = this.context; e.deleteTexture(this.texture), this.texture = null; } } class Wp { constructor(e, n) { this.context = e, this.texture = n; } bind(e, n) { const { context: o } = this, { gl: u } = o; u.bindTexture(u.TEXTURE_2D, this.texture), e !== this.minFilter && (u.texParameteri(u.TEXTURE_2D, u.TEXTURE_MAG_FILTER, e), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_MIN_FILTER, e), this.minFilter = e), n !== this.wrapS && (u.texParameteri(u.TEXTURE_2D, u.TEXTURE_WRAP_S, n), u.texParameteri(u.TEXTURE_2D, u.TEXTURE_WRAP_T, n), this.wrapS = n); } } function $p(r, e, n, o, u, l, f, v) { const S = [r, e, 1, n, o, 1, u, l, 1], D = [f, v, 1], x = De.mat3.adjoint([], S), [P, I, M] = De.vec3.transformMat3(D, D, x); return De.mat3.multiply(S, S, [P, 0, 0, 0, I, 0, 0, 0, M]); } function wx(r, e, n, o, u, l, f, v) { const S = function(D, x, P, I, M, C, k, V) { const U = $p(0, 0, 1, 0, 1, 1, 0, 1), q = $p(D, x, P, I, M, C, k, V), $ = De.mat3.adjoint([], U); return De.mat3.multiply(q, q, $); }(r, e, n, o, u, l, f, v); return [S[2] / S[8] / Tt, S[5] / S[8] / Tt]; } function Xp(r) { return [r[0], Math.min(Math.max(r[1], -Un), Un)]; } class Tx extends Zo { constructor(e, n, o, u) { super(), this.id = e, this.dispatcher = o, this.coordinates = n.coordinates, this.type = "image", this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this.tiles = {}, this._loaded = !1, this.onNorthPole = !1, this.onSouthPole = !1, this.setEventedParent(u), this.options = n, this._dirty = !1; } load(e, n) { if (this._loaded = n || !1, this.fire(new Ar("dataloading", { dataType: "source" })), this.url = this.options.url, !this.url) return e && (this.coordinates = e), this._loaded = !0, void this._finishLoading(); this._imageRequest = Hn(this.map._requestManager.transformRequest(this.url, Uo.Image), (o, u) => { this._imageRequest = null, this._loaded = !0, o ? this.fire(new Cr(o)) : u && (this.image = u instanceof HTMLImageElement ? Ct.getImageData(u) : u, this._dirty = !0, this.width = this.image.width, this.height = this.image.height, e && (this.coordinates = e), this._finishLoading()); }); } loaded() { return this._loaded; } updateImage(e) { return 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; } setTexture(e) { if (!(e.handle instanceof WebGLTexture)) throw new Error("The provided handle is not a WebGLTexture instance"); return this.texture = new Wp(this.map.painter.context, e.handle), this.width = e.dimensions[0], this.height = e.dimensions[1], this._dirty = !1, this._loaded = !0, this._finishLoading(), this; } _finishLoading() { this.map && (this.setCoordinates(this.coordinates), this.fire(new Ar("data", { dataType: "source", sourceDataType: "metadata" }))); } onAdd(e) { this.map = e, this.load(); } onRemove(e) { this._imageRequest && (this._imageRequest.cancel(), this._imageRequest = null), !this.texture || this.texture instanceof Wp || this.texture.destroy(), this.boundsBuffer && (this.boundsBuffer.destroy(), this.elevatedGlobeVertexBuffer && this.elevatedGlobeVertexBuffer.destroy(), this.elevatedGlobeIndexBuffer && this.elevatedGlobeIndexBuffer.destroy()); } setCoordinates(e) { if (this.coordinates = e, this._boundsArray = void 0, this._unsupportedCoords = !1, !e.length) return this; this.onNorthPole = !1, this.onSouthPole = !1; let n = e[0][1], o = e[0][1]; for (const l of e) l[1] > o && (o = l[1]), l[1] < n && (n = l[1]); const u = (o + n) / 2; if (u > Un ? this.onNorthPole = !0 : u < -Un && (this.onSouthPole = !0), !this.onNorthPole && !this.onSouthPole) { const l = e.map(h.fromLngLat); this.tileID = function(f) { let v = 1 / 0, S = 1 / 0, D = -1 / 0, x = -1 / 0; for (const k of f) v = Math.min(v, k.x), S = Math.min(S, k.y), D = Math.max(D, k.x), x = Math.max(x, k.y); const P = Math.max(D - v, x - S), I = Math.max(0, Math.floor(-Math.log(P) / Math.LN2)), M = Math.pow(2, I); let C = Math.floor((v + D) / 2 * M); return C > 1 && (C -= 1), new nt(I, C, Math.floor((S + x) / 2 * M)); }(l), this.minzoom = this.maxzoom = this.tileID.z; } return this.fire(new Ar("data", { dataType: "source", sourceDataType: "content" })), this; } _clear() { this._boundsArray = void 0, this._unsupportedCoords = !1; } _prepareData(e) { for (const U in this.tiles) { const q = this.tiles[U]; q.state !== "loaded" && (q.state = "loaded", q.texture = this.texture); } if (this._boundsArray || this.onNorthPole || this.onSouthPole || this._unsupportedCoords) return; const n = Qd(new nt(0, 0, 0), this.map.transform.projection), o = [n.projection.project(this.coordinates[0][0], this.coordinates[0][1]), n.projection.project(this.coordinates[1][0], this.coordinates[1][1]), n.projection.project(this.coordinates[2][0], this.coordinates[2][1]), n.projection.project(this.coordinates[3][0], this.coordinates[3][1])]; if (!function(U) { const q = U[1].x - U[0].x, $ = U[1].y - U[0].y, H = U[2].x - U[1].x, K = U[2].y - U[1].y, Q = U[3].x - U[2].x, ie = U[3].y - U[2].y, fe = U[0].x - U[3].x, de = U[0].y - U[3].y, ue = q * K - H * $, Se = H * ie - Q * K, me = Q * de - fe * ie, Ee = fe * $ - q * de; return ue > 0 && Se > 0 && me > 0 && Ee > 0 || ue < 0 && Se < 0 && me < 0 && Ee < 0; }(o)) return console.warn("Image source coordinates are defining non-convex area in the Mercator projection"), void (this._unsupportedCoords = !0); const u = Qd(this.tileID, this.map.transform.projection), [l, f, v, S] = this.coordinates.map((U) => { const q = u.projection.project(U[0], U[1]); return cx(u, q)._round(); }); this.perspectiveTransform = wx(l.x, l.y, f.x, f.y, v.x, v.y, S.x, S.y); const D = this._boundsArray = new $a(); D.emplaceBack(l.x, l.y, 0, 0), D.emplaceBack(f.x, f.y, Tt, 0), D.emplaceBack(S.x, S.y, 0, Tt), D.emplaceBack(v.x, v.y, Tt, Tt), this.boundsBuffer && (this.boundsBuffer.destroy(), this.elevatedGlobeVertexBuffer && this.elevatedGlobeVertexBuffer.destroy(), this.elevatedGlobeIndexBuffer && this.elevatedGlobeIndexBuffer.destroy()), this.boundsBuffer = e.createVertexBuffer(D, $_.members), this.boundsSegments = Wn.simpleSegment(0, 0, 4, 2); const x = [], P = [Xp((I = this.coordinates)[0]), Xp(I[1]), Xp(I[2]), Xp(I[3])]; var I; const [M, C, k, V] = function(U) { let q = U[0][0], $ = q, H = U[0][1], K = H; for (let Q = 1; Q < U.length; Q++) U[Q][0] < q ? q = U[Q][0] : U[Q][0] > $ && ($ = U[Q][0]), U[Q][1] < H ? H = U[Q][1] : U[Q][1] > K && (K = U[Q][1]); return [q, H, $ - q, K - H]; }(P); { const U = new $a(), [q, $, H, K] = function(Ve) { let Ue = Ve[0].x, Fe = Ue, et = Ve[0].y, dt = et; for (let tt = 1; tt < Ve.length; tt++) Ve[tt].x < Ue ? Ue = Ve[tt].x : Ve[tt].x > Fe && (Fe = Ve[tt].x), Ve[tt].y < et ? et = Ve[tt].y : Ve[tt].y > dt && (dt = Ve[tt].y); return [Ue, et, Fe - Ue, dt - et]; }(o), Q = (Ve) => [(Ve.x - q) / H, (Ve.y - $) / K], [ie, fe, de, ue] = o.map(Q), Se = function(Ve, Ue, Fe, et, dt, tt, Mt, wt) { const At = $p(0, 0, 1, 0, 1, 1, 0, 1), rt = $p(Ve, Ue, Fe, et, dt, tt, Mt, wt), Ut = De.mat3.adjoint([], rt); return De.mat3.multiply(At, At, Ut); }(ie[0], ie[1], fe[0], fe[1], de[0], de[1], ue[0], ue[1]); this.elevatedGlobePerspectiveTransform = wx(ie[0], ie[1], fe[0], fe[1], de[0], de[1], ue[0], ue[1]); const me = (Ve, Ue) => { x.push(Ve.lng); const Fe = Math.round((Ve.lng - M) / k * Tt), et = Math.round((Ve.lat - C) / V * Tt), dt = Q(Ue), tt = De.vec3.transformMat3([], [dt[0], dt[1], 1], Se), Mt = Math.round(tt[0] / tt[2] * Tt), wt = Math.round(tt[1] / tt[2] * Tt); U.emplaceBack(Fe, et, Mt, wt); }, Ee = o[3].x - o[0].x, ze = o[3].y - o[0].y, Ie = o[2].x - o[1].x, Re = o[2].y - o[1].y; for (let Ve = 0; Ve < 65; Ve++) { const Ue = Ve / 64, Fe = [o[0].x + Ue * Ee, o[0].y + Ue * ze], et = [o[1].x + Ue * Ie, o[1].y + Ue * Re], dt = et[0] - Fe[0], tt = et[1] - Fe[1]; for (let Mt = 0; Mt < 65; Mt++) { const wt = Mt / 64, At = { x: Fe[0] + dt * wt, y: Fe[1] + tt * wt, z: 0 }; me(n.projection.unproject(At.x, At.y), At); } } this.elevatedGlobeVertexBuffer = e.createVertexBuffer(U, $_.members); } { this.maxLongitudeTriangleSize = 0; let U = [], q = new qs(); const $ = (H, K, Q) => { q.emplaceBack(H, K, Q); const ie = x[H], fe = x[K], de = x[Q], ue = Math.min(Math.min(ie, fe), de), Se = Math.max(Math.max(ie, fe), de) - ue; Se > this.maxLongitudeTriangleSize && (this.maxLongitudeTriangleSize = Se), U.push(ue + Se / 2); }; for (let H = 0; H < 64; H++) for (let K = 0; K < 64; K++) { const Q = 65 * H + K, ie = Q + 1, fe = Q + 65, de = fe + 1; $(Q, fe, ie), $(ie, fe, de); } [U, q] = function(H, K) { const Q = Array.from({ length: H.length }, (de, ue) => ue); Q.sort((de, ue) => H[de] - H[ue]); const ie = [], fe = new qs(); for (let de = 0; de < Q.length; de++) { const ue = Q[de]; ie.push(H[ue]); const Se = 3 * ue, me = Se + 1; fe.emplaceBack(K.uint16[Se], K.uint16[me], K.uint16[me + 1]); } return [ie, fe]; }(U, q), this.elevatedGlobeTrianglesCenterLongitudes = U, this.elevatedGlobeIndexBuffer = e.createIndexBuffer(q); } this.elevatedGlobeSegments = Wn.simpleSegment(0, 0, 4225, 8192), this.elevatedGlobeGridMatrix = new Float32Array([0, k / Tt, 0, V / Tt, 0, 0, C, M, 0]); } prepare() { const e = Object.keys(this.tiles).length !== 0; if (this.tileID && !e) return; const n = this.map.painter.context, o = n.gl; !this._dirty || this.texture instanceof Wp || (this.texture ? this.texture.update(this.image) : (this.texture = new K_(n, this.image, o.RGBA8), this.texture.bind(o.LINEAR, o.CLAMP_TO_EDGE)), this._dirty = !1), e && this._prepareData(n); } loadTile(e, n) { this.tileID && this.tileID.equals(e.tileID.canonical) ? (this.tiles[String(e.tileID.wrap)] = e, e.buckets = {}, n(null)) : (e.state = "errored", n(null)); } serialize() { return { type: "image", url: this.options.url, coordinates: this.coordinates }; } hasTransition() { return !1; } getSegmentsForLongitude(e) { const n = this.elevatedGlobeSegments; if (!this.elevatedGlobeTrianglesCenterLongitudes || !n) return null; const o = this.elevatedGlobeTrianglesCenterLongitudes; let u = (l = e + 180) + 360 * Math.round((o[0] - l) / 360); var l; const f = new Wn(), v = (P, I) => { f.segments.push({ vertexOffset: 0, primitiveOffset: P, vertexLength: n.segments[0].vertexLength, primitiveLength: I, sortKey: void 0, vaos: {} }); }, S = 0.51 * this.maxLongitudeTriangleSize; if (Math.abs(o[0] - u) <= S) { const P = Ke(o, 0, o.length, u + S); return P === o.length || v(P, Vo(o, P + 1, o.length, u + 360 - S) - P), f; } u < o[0] && (u += 360); const D = Vo(o, 0, o.length, u - S); if (D === o.length) return v(0, o.length), f; v(0, D - 0); const x = Ke(o, D + 1, o.length, u + S); return x !== o.length && v(x, o.length - x), f; } } const JT = (Math.pow(256, 2) - 1) / 16907520; class Mx extends wr { constructor(e, n, o, u) { super(e, { layout: vx || (vx = new Bn({ visibility: new yt($e.layout_raster.visibility) })), paint: bx || (bx = new Bn({ "raster-opacity": new yt($e.paint_raster["raster-opacity"]), "raster-color": new Wa($e.paint_raster["raster-color"]), "raster-color-mix": new yt($e.paint_raster["raster-color-mix"]), "raster-color-range": new yt($e.paint_raster["raster-color-range"]), "raster-hue-rotate": new yt($e.paint_raster["raster-hue-rotate"]), "raster-brightness-min": new yt($e.paint_raster["raster-brightness-min"]), "raster-brightness-max": new yt($e.paint_raster["raster-brightness-max"]), "raster-saturation": new yt($e.paint_raster["raster-saturation"]), "raster-contrast": new yt($e.paint_raster["raster-contrast"]), "raster-resampling": new yt($e.paint_raster["raster-resampling"]), "raster-fade-duration": new yt($e.paint_raster["raster-fade-duration"]), "raster-emissive-strength": new yt($e.paint_raster["raster-emissive-strength"]), "raster-array-band": new yt($e.paint_raster["raster-array-band"]), "raster-elevation": new yt($e.paint_raster["raster-elevation"]), "raster-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, n, o, u), this.updateColorRamp(), this._curRampRange = [NaN, NaN]; } getProgramIds() { return ["raster"]; } hasColorMap() { return !!this._transitionablePaint._values["raster-color"].value.value; } tileCoverLift() { return this.paint.get("raster-elevation"); } isDraped(e) { return !(e && e._source instanceof Tx && (e._source.onNorthPole || e._source.onSouthPole)) && this.paint.get("raster-elevation") === 0; } _handleSpecialPaintPropertyUpdate(e) { e !== "raster-color" && e !== "raster-color-range" || (this._curRampRange = [NaN, NaN], this.updateColorRamp()); } updateColorRamp(e) { if (!this.hasColorMap() || !this._curRampRange) return; const n = this._transitionablePaint._values["raster-color"].value.expression, [o, u] = e || this._transitionablePaint._values["raster-color-range"].value.expression.evaluate({ zoom: 0 }) || [NaN, NaN]; isNaN(o) && isNaN(u) || o === this._curRampRange[0] && u === this._curRampRange[1] || (this.colorRamp = Bd({ expression: n, evaluationKey: "rasterValue", image: this.colorRamp, clips: [{ start: o, end: u }], resolution: 256 }), this.colorRampTexture = null, this._curRampRange = [o, u]); } } let Sx, Ex, Px, Ax, Cx; class Ix extends wr { constructor(e, n, o, u) { super(e, { layout: Sx || (Sx = new Bn({ visibility: new yt($e["layout_raster-particle"].visibility) })), paint: Ex || (Ex = new Bn({ "raster-particle-array-band": new yt($e["paint_raster-particle"]["raster-particle-array-band"]), "raster-particle-count": new yt($e["paint_raster-particle"]["raster-particle-count"]), "raster-particle-color": new Wa($e["paint_raster-particle"]["raster-particle-color"]), "raster-particle-max-speed": new yt($e["paint_raster-particle"]["raster-particle-max-speed"]), "raster-particle-speed-factor": new yt($e["paint_raster-particle"]["raster-particle-speed-factor"]), "raster-particle-fade-opacity-factor": new yt($e["paint_raster-particle"]["raster-particle-fade-opacity-factor"]), "raster-particle-reset-rate-factor": new yt($e["paint_raster-particle"]["raster-particle-reset-rate-factor"]), "raster-particle-elevation": new yt($e["paint_raster-particle"]["raster-particle-elevation"]), "raster-particle-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, n, o, u), this._updateColorRamp(), this.lastInvalidatedAt = Ct.now(); } onRemove(e) { this.colorRampTexture && this.colorRampTexture.destroy(), this.tileFramebuffer && this.tileFramebuffer.destroy(), this.particleFramebuffer && this.particleFramebuffer.destroy(); } hasColorMap() { return !!this._transitionablePaint._values["raster-particle-color"].value.value; } getProgramIds() { return ["rasterParticle"]; } hasOffscreenPass() { return this.visibility !== "none"; } isDraped(e) { return !1; } _handleSpecialPaintPropertyUpdate(e) { e !== "raster-particle-color" && e !== "raster-particle-max-speed" || (this._updateColorRamp(), this._invalidateAnimationState()), e === "raster-particle-count" && this._invalidateAnimationState(); } _updateColorRamp() { if (!this.hasColorMap()) return; const e = this._transitionablePaint._values["raster-particle-color"].value.expression, n = this._transitionablePaint._values["raster-particle-max-speed"].value.expression.evaluate({ zoom: 0 }); this.colorRamp = Bd({ expression: e, evaluationKey: "rasterParticleSpeed", image: this.colorRamp, clips: [{ start: 0, end: n }], resolution: 256 }), this.colorRampTexture = null; } _invalidateAnimationState() { this.lastInvalidatedAt = Ct.now(); } tileCoverLift() { return this.paint.get("raster-particle-elevation"); } } class QT extends wr { constructor(e, n) { super(e, {}, n, null), this.implementation = e, e.slot && (this.slot = e.slot); } is3D() { return this.implementation.renderingMode === "3d"; } hasOffscreenPass() { return this.implementation.prerender !== void 0; } isDraped(e) { return this.implementation.renderToTile !== void 0; } shouldRedrape() { return !!this.implementation.shouldRerenderTiles && this.implementation.shouldRerenderTiles(); } recalculate() { } updateTransitions() { } hasTransition() { return !1; } serialize() { } onAdd(e) { this.implementation.onAdd && this.implementation.onAdd(e, e.painter.context.gl); } onRemove(e) { this.implementation.onRemove && this.implementation.onRemove(e, e.painter.context.gl); } } function J_(r, e, n) { const o = [0, 0, 1], u = De.quat.identity([]); return De.quat.rotateY(u, u, n ? -vi(r) + Math.PI : vi(r)), De.quat.rotateX(u, u, -vi(e)), De.vec3.transformQuat(o, o, u), De.vec3.normalize(o, o); } function Lx(r, e) { const n = Yp(r.projection, r.zoom, r.width, r.height), o = function(l, f, v, S, D) { const x = new Ui(v.lng - 180 * wc, v.lat), P = new Ui(v.lng + 180 * wc, v.lat), I = l.project(x.lng, x.lat), M = l.project(P.lng, P.lat), C = -Math.atan2(M.y - I.y, M.x - I.x), k = h.fromLngLat(v); k.y = si(k.y, -1 + wc, 1 - wc); const V = k.toLngLat(), U = l.project(V.lng, V.lat), q = h.fromLngLat(V); q.x += wc; const $ = q.toLngLat(), H = l.project($.lng, $.lat), K = Dx(H.x - U.x, H.y - U.y, C), Q = h.fromLngLat(V); Q.y += wc; const ie = Q.toLngLat(), fe = l.project(ie.lng, ie.lat), de = Dx(fe.x - U.x, fe.y - U.y, C), ue = Math.abs(K.x) / Math.abs(de.y), Se = De.mat4.identity([]); De.mat4.rotateZ(Se, Se, -C * (1 - (D ? 0 : S))); const me = De.mat4.identity([]); return De.mat4.scale(me, me, [1, 1 - (1 - ue) * S, 1]), me[4] = -de.x / de.y * S, De.mat4.rotateZ(me, me, C), De.mat4.multiply(me, Se, me), me; }(r.projection, 0, r.center, n, e), u = zx(r); return De.mat4.scale(o, o, [u, u, 1]), o; } function zx(r) { const e = r.projection, n = Yp(r.projection, r.zoom, r.width, r.height), o = Q_(e, r.center), u = Q_(e, Ui.convert(e.center)); return Math.pow(2, o * n + (1 - n) * u); } function Yp(r, e, n, o, u = 1 / 0) { const l = r.range; if (!l) return 0; const f = Math.min(u, Math.max(n, o)), v = Math.log(f / 1024) / Math.LN2; return fs(l[0] + v, l[1] + v, e); } const wc = 1 / 4e4; function Q_(r, e) { const n = si(e.lat, -Un, Un), o = new Ui(e.lng - 180 * wc, n), u = new Ui(e.lng + 180 * wc, n), l = r.project(o.lng, n), f = r.project(u.lng, n), v = h.fromLngLat(o), S = h.fromLngLat(u), D = f.x - l.x, x = f.y - l.y, P = S.x - v.x, I = S.y - v.y, M = Math.sqrt((P * P + I * I) / (D * D + x * x)); return Math.log(M) / Math.LN2; } function Dx(r, e, n) { const o = Math.cos(n), u = Math.sin(n); return { x: r * o - e * u, y: r * u + e * o }; } function kx(r, e, n) { De.mat4.identity(r), De.mat4.rotateZ(r, r, vi(e[2])), De.mat4.rotateX(r, r, vi(e[0])), De.mat4.rotateY(r, r, vi(e[1])), De.mat4.scale(r, r, n), De.mat4.multiply(r, r, [1, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1]); } function Kp(r, e, n, o, u, l, f, v) { const S = [n[0] - e[0], n[1] - e[1], 0], D = [o[0] - e[0], o[1] - e[1], 0]; if (De.vec3.length(S) < 1e-12 || De.vec3.length(D) < 1e-12) return De.quat.identity(r); const x = De.vec3.cross([], S, D); De.vec3.normalize(x, x), De.vec3.subtract(D, o, e), S[2] = (l - u) * v, D[2] = (f - u) * v; const P = S; return De.vec3.cross(P, S, D), De.vec3.normalize(P, P), De.quat.rotationTo(r, x, P); } function eg(r, e, n = !1) { const o = mr(e.zoom), u = function(l, f, v) { const S = f.worldSize, D = [l[12], l[13], l[14]], x = Os(D[1] / S), P = Fr(D[0] / S), I = De.mat4.identity([]), M = fr(1, x) * S, C = fr(1, 0) * S * c(x, f.zoom), k = 1 / eo(S); let V = C * k; if (v) { const H = Yp(f.projection, f.zoom, f.width, f.height, 1024); V = k * f.projection.pixelSpaceConversion(f.center.lat, S, H); } const U = el(x, P); De.vec3.add(U, U, De.vec3.scale([], De.vec3.normalize([], U), M * V * D[2])); const q = function(H) { const K = [H[0], H[1], H[2]]; let Q = [0, 1, 0]; const ie = De.vec3.cross([], Q, K); return De.vec3.cross(Q, K, ie), De.vec3.squaredLength(Q) === 0 && (Q = [0, 1, 0], De.vec3.cross(ie, K, Q)), De.vec3.normalize(ie, ie), De.vec3.normalize(Q, Q), De.vec3.normalize(K, K), [ie[0], ie[1], ie[2], 0, Q[0], Q[1], Q[2], 0, K[0], K[1], K[2], 0, H[0], H[1], H[2], 1]; }(U); De.mat4.scale(I, I, [V, V, V * M]), De.mat4.translate(I, I, [-D[0], -D[1], -D[2]]); const $ = De.mat4.multiply([], f.globeMatrix, q); return De.mat4.multiply($, $, I), De.mat4.multiply($, $, l), $; }(r, e, n); if (o > 0) { const l = function(f, v) { const S = v.worldSize, D = fr(1, 0) * S * c(v.center.lat, v.zoom) / eo(S), x = fr(1, v.center.lat) * S, P = De.mat4.identity([]); return De.mat4.rotateY(P, P, vi(v.center.lng)), De.mat4.rotateX(P, P, vi(v.center.lat)), De.mat4.translate(P, P, [0, 0, dr]), De.mat4.scale(P, P, [D, D, D * x]), De.mat4.translate(P, P, [v.point.x - 0.5 * S, v.point.y - 0.5 * S, 0]), De.mat4.multiply(P, P, f), De.mat4.multiply(P, v.globeMatrix, P); }(r, e); return function(f, v, S) { const D = (C, k, V) => { const U = De.vec3.length(C), q = De.vec3.length(k), $ = Ps(C, k, V); return De.vec3.scale($, $, 1 / De.vec3.length($) * ei(U, q, V)); }, x = D([f[0], f[1], f[2]], [v[0], v[1], v[2]], S), P = D([f[4], f[5], f[6]], [v[4], v[5], v[6]], S), I = D([f[8], f[9], f[10]], [v[8], v[9], v[10]], S), M = Ps([f[12], f[13], f[14]], [v[12], v[13], v[14]], S); return [x[0], x[1], x[2], 0, P[0], P[1], P[2], 0, I[0], I[1], I[2], 0, M[0], M[1], M[2], 1]; }(u, l, o); } return u; } function Rx(r, e, n, o) { const u = Jt.projectAabbCorners(o, n); let l = Number.MAX_VALUE, f = -1; for (let D = 0; D < u.length; ++D) { const x = u[D]; x[0] = (0.5 * x[0] + 0.5) * e.width, x[1] = (0.5 - 0.5 * x[1]) * e.height, x[2] < l && (f = D, l = x[2]); } const v = (D) => new Et(u[D][0], u[D][1]); let S; switch (f) { case 0: case 6: S = [v(1), v(5), v(4), v(7), v(3), v(2), v(1)]; break; case 1: case 7: S = [v(0), v(4), v(5), v(6), v(2), v(3), v(0)]; break; case 3: case 5: S = [v(1), v(0), v(4), v(7), v(6), v(2), v(1)]; break; default: S = [v(1), v(5), v(6), v(7), v(3), v(0), v(1)]; } if (se(r, S)) return l; } const e2 = qi([{ name: "a_pos_3f", components: 3, type: "Float32" }]), t2 = qi([{ name: "a_color_3f", components: 3, type: "Float32" }]), i2 = qi([{ name: "a_color_4f", components: 4, type: "Float32" }]), n2 = qi([{ name: "a_uv_2f", components: 2, type: "Float32" }]), s2 = qi([{ name: "a_normal_3f", components: 3, type: "Float32" }]), r2 = qi([{ name: "a_normal_matrix0", components: 4, type: "Float32" }, { name: "a_normal_matrix1", components: 4, type: "Float32" }, { name: "a_normal_matrix2", components: 4, type: "Float32" }, { name: "a_normal_matrix3", components: 4, type: "Float32" }]), o2 = qi([{ name: "a_pbr", components: 4, type: "Uint16" }, { name: "a_heightBasedEmissiveStrength", components: 3, type: "Float32" }]), Ox = { None: 0, Model: 1, Symbol: 2, FillExtrusion: 4, All: 7 }; class Jp { constructor(e, n, o, u) { this.message = (e ? `${e}: ` : "") + o, u && (this.identifier = u), n != null && n.__line__ && (this.line = n.__line__); } } function Fx(r, e) { const n = r.indexOf("://") === -1; try { return new URL(r, n && e ? "http://example.com" : void 0), !0; } catch { return !1; } } class Bx { constructor(e, n) { this.feature = e, this.instancedDataOffset = n, this.instancedDataCount = 0, this.rotation = [0, 0, 0], this.scale = [1, 1, 1], this.translation = [0, 0, 0]; } } class Nx { constructor() { this.instancedDataArray = new Ld(), this.instancesEvaluatedElevation = [], this.features = [], this.idToFeaturesIndex = {}; } } class tg { constructor(e) { this.zoom = e.zoom, this.canonical = e.canonical, this.layers = e.layers, this.layerIds = this.layers.map((n) => n.fqid), this.projection = e.projection, this.index = e.index, this.hasZoomDependentProperties = this.layers[0].isZoomDependent(), this.stateDependentLayerIds = this.layers.filter((n) => n.isStateDependent()).map((n) => n.id), this.hasPattern = !1, this.instancesPerModel = {}, this.validForExaggeration = 0, this.maxVerticalOffset = 0, this.maxScale = 0, this.maxHeight = 0, this.lookupDim = this.zoom > this.canonical.z ? 256 : this.zoom > 15 ? 75 : 100, this.instanceCount = 0, this.terrainElevationMin = 0, this.terrainElevationMax = 0, this.validForDEMTile = { id: null, timestamp: 0 }, this.modelUris = [], this.modelsRequested = !1, this.activeReplacements = [], this.replacementUpdateTime = 0; } updateFootprints(e, n) { } populate(e, n, o, u) { this.tileToMeter = s(o); const l = this.layers[0]._featureFilter.needGeometry; this.lookup = new Uint8Array(this.lookupDim * this.lookupDim); for (const { feature: f, id: v, index: S, sourceLayerIndex: D } of e) { const x = v ?? (f.properties && f.properties.hasOwnProperty("id") ? f.properties.id : void 0), P = Z(f, l); if (!this.layers[0]._featureFilter.filter(new Tn(this.zoom), P, o)) continue; const I = { id: x, sourceLayerIndex: D, index: S, geometry: l ? P.geometry : G(f, o, u), properties: f.properties, type: f.type, patterns: {} }, M = this.addFeature(I, I.geometry, P); M && n.featureIndex.insert(f, I.geometry, S, D, this.index, this.instancesPerModel[M].instancedDataArray.length, Tt / 32); } this.lookup = null; } update(e, n, o, u) { for (const l in this.instancesPerModel) { const f = this.instancesPerModel[l]; for (const v in e) f.idToFeaturesIndex.hasOwnProperty(v) && (this.evaluate(f.features[f.idToFeaturesIndex[v]], e[v], f, !0), this.uploaded = !1); } this.maxHeight = 0; } updateZoomBasedPaintProperties() { if (!this.hasZoomDependentProperties) return !1; let e = !1; for (const n in this.instancesPerModel) { const o = this.instancesPerModel[n]; for (const u of o.features) { const l = this.layers[0], f = u.feature, v = this.canonical, S = l.paint.get("model-rotation").evaluate(f, {}, v), D = l.paint.get("model-scale").evaluate(f, {}, v), x = l.paint.get("model-translation").evaluate(f, {}, v); De.vec3.exactEquals(u.rotation, S) && De.vec3.exactEquals(u.scale, D) && De.vec3.exactEquals(u.translation, x) || (this.evaluate(u, u.featureStates, o, !0), e = !0); } } return e; } updateReplacement(e, n, o, u) { if (n.updateTime === this.replacementUpdateTime) return !1; this.replacementUpdateTime = n.updateTime; const l = n.getReplacementRegionsForTile(e.toUnwrapped(), !0); if (E_(this.activeReplacements, l)) return !1; this.activeReplacements = l; let f = !1; for (const v in this.instancesPerModel) { const S = this.instancesPerModel[v], D = S.instancedDataArray; for (const x of S.features) { const P = x.instancedDataOffset, I = x.instancedDataCount; for (let M = 0; M < I; M++) { const C = 16 * (M + P); let k = D.float32[C + 0]; const V = k > Tt; k = V ? k - Tt : k; const U = Math.floor(k), q = D.float32[C + 1]; let $ = !1; for (const H of this.activeReplacements) if (!Qy(H, o, Ox.Model, u) && !(H.min.x > U || U > H.max.x || H.min.y > q || q > H.max.y) && ($ = r0(s0(U, q, e.canonical, H.footprintTileId.canonical), H.footprint), $)) break; D.float32[C] = $ ? k + Tt : k, f = f || $ !== V; } } } return f; } isEmpty() { for (const e in this.instancesPerModel) if (this.instancesPerModel[e].instancedDataArray.length !== 0) return !1; return !0; } uploadPending() { return !this.uploaded; } upload(e) { if (!this.uploaded) for (const n in this.instancesPerModel) { const o = this.instancesPerModel[n]; o.instancedDataArray.length < 0 || o.instancedDataArray.length === 0 || (o.instancedDataBuffer ? o.instancedDataBuffer.updateData(o.instancedDataArray) : o.instancedDataBuffer = e.createVertexBuffer(o.instancedDataArray, r2.members, !0, void 0, this.instanceCount)); } this.uploaded = !0; } destroy() { for (const n in this.instancesPerModel) { const o = this.instancesPerModel[n]; o.instancedDataArray.length !== 0 && o.instancedDataBuffer && o.instancedDataBuffer.destroy(); } const e = this.layers[0].modelManager; if (e && this.modelUris) for (const n of this.modelUris) e.removeModel(n, ""); } addFeature(e, n, o) { const u = this.layers[0], l = u.layout.get("model-id").evaluate(o, {}, this.canonical); if (!l) return mi(`modelId is not evaluated for layer ${u.id} and it is not going to get rendered.`), l; Fx(l, !1) && (this.modelUris.includes(l) || this.modelUris.push(l)), this.instancesPerModel[l] || (this.instancesPerModel[l] = new Nx()); const f = this.instancesPerModel[l], v = f.instancedDataArray, S = new Bx(o, v.length); for (const D of n) for (const x of D) { if (x.x < 0 || x.x >= Tt || x.y < 0 || x.y >= Tt) continue; const P = (this.lookupDim - 1) / Tt, I = this.lookupDim * (x.y * P | 0) + x.x * P | 0; if (this.lookup) { if (this.lookup[I] !== 0) continue; this.lookup[I] = 1; } this.instanceCount++; const M = v.length; v.resize(M + 1), f.instancesEvaluatedElevation.push(0), v.float32[16 * M] = x.x, v.float32[16 * M + 1] = x.y; } return S.instancedDataCount = f.instancedDataArray.length - S.instancedDataOffset, S.instancedDataCount > 0 && (e.id && (f.idToFeaturesIndex[e.id] = f.features.length), f.features.push(S), this.evaluate(S, {}, f, !1)), l; } getModelUris() { return this.modelUris; } evaluate(e, n, o, u) { const l = this.layers[0], f = e.feature, v = this.canonical, S = e.rotation = l.paint.get("model-rotation").evaluate(f, n, v), D = e.scale = l.paint.get("model-scale").evaluate(f, n, v), x = e.translation = l.paint.get("model-translation").evaluate(f, n, v), P = l.paint.get("model-color").evaluate(f, n, v); P.a = l.paint.get("model-color-mix-intensity").evaluate(f, n, v); const I = []; this.maxVerticalOffset < x[2] && (this.maxVerticalOffset = x[2]), this.maxScale = Math.max(Math.max(this.maxScale, D[0]), Math.max(D[1], D[2])), kx(I, S, D); const M = Math.round(100 * P.a) + P.b / 1.05; for (let C = 0; C < e.instancedDataCount; ++C) { const k = e.instancedDataOffset + C, V = 16 * k, U = o.instancedDataArray.float32; let q = 0; u && (q = U[V + 6] - o.instancesEvaluatedElevation[k]); const $ = 0 | U[V + 1]; U[V] = (0 | U[V]) + P.r / 1.05, U[V + 1] = $ + P.g / 1.05, U[V + 2] = M, U[V + 3] = 1 / (v.z > 10 ? this.tileToMeter : s(v, $)), U[V + 4] = x[0], U[V + 5] = x[1], U[V + 6] = x[2] + q, U[V + 7] = I[0], U[V + 8] = I[1], U[V + 9] = I[2], U[V + 10] = I[4], U[V + 11] = I[5], U[V + 12] = I[6], U[V + 13] = I[8], U[V + 14] = I[9], U[V + 15] = I[10], o.instancesEvaluatedElevation[k] = x[2]; } } } let Vx, Ux; Ft(tg, "ModelBucket", { omit: ["layers"] }), Ft(Nx, "PerModelAttributes"), Ft(Bx, "ModelFeature"); const bh = 64, Ou = { CoordinateSpaceTile: 1, CoordinateSpaceYUp: 2, HasMapboxMeshFeatures: 4, HasMeshoptCompression: 8 }; function jx(r, e, n, o, u, l, f, v, S, D = !1) { const x = n.zoom, P = n.project(o), I = c(o.lat, x), M = 1 / I; De.mat4.identity(r), De.mat4.translate(r, r, [P.x + f[0] * M, P.y + f[1] * M, f[2]]); let C = 1, k = 1; const V = n.worldSize; if (D) { if (n.projection.name === "mercator") { let H = 0; n.elevation && (H = n.elevation.getAtPointOrZero(new h(P.x / V, P.y / V), 0)); const K = De.vec4.transformMat4([], [P.x, P.y, H, 1], n.projMatrix)[3] / n.cameraToCenterDistance; C = K, k = K * c(n.center.lat, x); } else if (n.projection.name === "globe") { const H = eg(r, n), K = De.mat4.multiply([], n.projMatrix, H), Q = [0, 0, 0, 1]; De.vec4.transformMat4(Q, Q, K); const ie = Q[3] / n.cameraToCenterDistance, fe = mr(x), de = n.projection.pixelsPerMeter(o.lat, V) * c(o.lat, x), ue = n.projection.pixelsPerMeter(n.center.lat, V) * c(n.center.lat, x); C = ie / ei(de, p_(n.center.lat), fe), k = ie * I / de, C *= ue, k *= ue; } } else C = M; De.mat4.scale(r, r, [C, C, k]); const U = [...r], q = e.orientation, $ = []; if (kx($, [q[0] + u[0], q[1] + u[1], q[2] + u[2]], l), De.mat4.multiply(r, U, $), v && n.elevation) { let H = 0; const K = []; if (S && n.elevation) { H = function(fe, de, ue, Se, me) { const Ee = de.elevation; if (!Ee) return 0; const ze = Jt.projectAabbCorners(ue, Se), Ie = fr(1, me.lat) * de.worldSize, Re = function(Ut, St) { const Nt = [0, 0, 1], Qt = [{ corners: [0, 1, 3, 2], dotProductWithUp: 0 }, { corners: [1, 5, 2, 6], dotProductWithUp: 0 }, { corners: [0, 4, 1, 5], dotProductWithUp: 0 }, { corners: [2, 6, 3, 7], dotProductWithUp: 0 }, { corners: [4, 7, 5, 6], dotProductWithUp: 0 }, { corners: [0, 3, 4, 7], dotProductWithUp: 0 }]; for (const pi of Qt) { const gi = Ut[pi.corners[0]], Ai = Ut[pi.corners[1]], yi = Ut[pi.corners[2]], Ii = [Ai[0] - gi[0], Ai[1] - gi[1], St * (Ai[2] - gi[2])], fn = De.vec3.cross(Ii, Ii, [yi[0] - gi[0], yi[1] - gi[1], St * (yi[2] - gi[2])]); De.vec3.normalize(fn, fn), pi.dotProductWithUp = De.vec3.dot(fn, Nt); } return Qt.sort((pi, gi) => pi.dotProductWithUp - gi.dotProductWithUp), Qt[0].corners; }(ze, Ie), Ve = ze[Re[0]], Ue = ze[Re[1]], Fe = ze[Re[2]], et = ze[Re[3]], dt = Ee.getAtPointOrZero(new h(Ve[0] / de.worldSize, Ve[1] / de.worldSize), 0), tt = Ee.getAtPointOrZero(new h(Ue[0] / de.worldSize, Ue[1] / de.worldSize), 0), Mt = Ee.getAtPointOrZero(new h(Fe[0] / de.worldSize, Fe[1] / de.worldSize), 0), wt = Ee.getAtPointOrZero(new h(et[0] / de.worldSize, et[1] / de.worldSize), 0), At = (dt + wt) / 2, rt = (tt + Mt) / 2; return At > rt ? tt < Mt ? Kp(fe, Ue, et, Ve, tt, wt, dt, Ie) : Kp(fe, Fe, Ve, et, Mt, dt, wt, Ie) : dt < wt ? Kp(fe, Ve, Ue, Fe, dt, tt, Mt, Ie) : Kp(fe, et, Fe, Ue, wt, Mt, tt, Ie), Math.max(At, rt); }(K, n, e.aabb, r, o); const Q = De.mat4.fromQuat([], K), ie = De.mat4.multiply([], Q, $); De.mat4.multiply(r, U, ie); } else H = n.elevation.getAtPointOrZero(new h(P.x / V, P.y / V), 0); H !== 0 && (r[14] += H); } } function rf(r, e, n = !1) { r.uploaded || (r.gfxTexture = new K_(e, r.image, n ? e.gl.R8 : e.gl.RGBA8, { useMipmap: r.sampler.minFilter >= e.gl.NEAREST_MIPMAP_NEAREST }), r.uploaded = !0, r.image = null); } function a2(r, e, n) { r.indexBuffer = e.createIndexBuffer(r.indexArray, !1, !0), r.vertexBuffer = e.createVertexBuffer(r.vertexArray, e2.members, !1, !0), r.normalArray && (r.normalBuffer = e.createVertexBuffer(r.normalArray, s2.members, !1, !0)), r.texcoordArray && (r.texcoordBuffer = e.createVertexBuffer(r.texcoordArray, n2.members, !1, !0)), r.colorArray && (r.colorBuffer = e.createVertexBuffer(r.colorArray, (r.colorArray.bytesPerElement === 12 ? t2 : i2).members, !1, !0)), r.featureArray && (r.pbrBuffer = e.createVertexBuffer(r.featureArray, o2.members, !0)), r.segments = Wn.simpleSegment(0, 0, r.vertexArray.length, r.indexArray.length); const o = r.material; o.pbrMetallicRoughness.baseColorTexture && rf(o.pbrMetallicRoughness.baseColorTexture, e), o.pbrMetallicRoughness.metallicRoughnessTexture && rf(o.pbrMetallicRoughness.metallicRoughnessTexture, e), o.normalTexture && rf(o.normalTexture, e), o.occlusionTexture && rf(o.occlusionTexture, e, n), o.emissionTexture && rf(o.emissionTexture, e); } function ig(r, e, n) { if (r.meshes) for (const o of r.meshes) a2(o, e, n); if (r.children) for (const o of r.children) ig(o, e, n); } function Qp(r) { if (r.meshes) for (const e of r.meshes) e.indexArray.destroy(), e.vertexArray.destroy(), e.colorArray && e.colorArray.destroy(), e.normalArray && e.normalArray.destroy(), e.texcoordArray && e.texcoordArray.destroy(), e.featureArray && e.featureArray.destroy(); if (r.children) for (const e of r.children) Qp(e); } function ng(r) { if (r.meshes) for (const n of r.meshes) n.vertexBuffer && (n.vertexBuffer.destroy(), n.indexBuffer.destroy(), n.normalBuffer && n.normalBuffer.destroy(), n.texcoordBuffer && n.texcoordBuffer.destroy(), n.colorBuffer && n.colorBuffer.destroy(), n.pbrBuffer && n.pbrBuffer.destroy(), n.segments.destroy(), n.material && ((e = n.material).pbrMetallicRoughness.baseColorTexture && e.pbrMetallicRoughness.baseColorTexture.gfxTexture && e.pbrMetallicRoughness.baseColorTexture.gfxTexture.destroy(), e.pbrMetallicRoughness.metallicRoughnessTexture && e.pbrMetallicRoughness.metallicRoughnessTexture.gfxTexture && e.pbrMetallicRoughness.metallicRoughnessTexture.gfxTexture.destroy(), e.normalTexture && e.normalTexture.gfxTexture && e.normalTexture.gfxTexture.destroy(), e.emissionTexture && e.emissionTexture.gfxTexture && e.emissionTexture.gfxTexture.destroy(), e.occlusionTexture && e.occlusionTexture.gfxTexture && e.occlusionTexture.gfxTexture.destroy())); var e; if (r.children) for (const n of r.children) ng(n); } class Fu { constructor(e, n, o) { this._demTile = e, this._dem = this._demTile.dem, this._scale = n, this._offset = o; } static create(e, n, o) { const u = o || e.findDEMTileFor(n); if (!u || !u.dem) return; const l = u.dem, f = u.tileID, v = 1 << n.canonical.z - f.canonical.z; return new Fu(u, l.dim / Tt / v, [(n.canonical.x / v - f.canonical.x) * l.dim, (n.canonical.y / v - f.canonical.y) * l.dim]); } tileCoordToPixel(e, n) { const o = n * this._scale + this._offset[1], u = Math.floor(e * this._scale + this._offset[0]), l = Math.floor(o); return new Et(u, l); } getElevationAt(e, n, o, u) { const l = e * this._scale + this._offset[0], f = n * this._scale + this._offset[1], v = Math.floor(l), S = Math.floor(f), D = this._dem; return u = !!u, o ? ei(ei(D.get(v, S, u), D.get(v, S + 1, u), f - S), ei(D.get(v + 1, S, u), D.get(v + 1, S + 1, u), f - S), l - v) : D.get(v, S, u); } getElevationAtPixel(e, n, o) { return this._dem.get(e, n, !!o); } getMeterToDEM(e) { return (1 << this._demTile.tileID.canonical.z) * fr(1, e) * this._dem.stride; } } const sg = new Float32Array(262144), wh = new Uint8Array(262144); function Gx(r) { let e = 0; if (r.meshes) for (const n of r.meshes) e = Math.max(e, n.aabb.max[2]); if (r.children) for (const n of r.children) e = Math.max(e, Gx(n)); return e; } function Zx(r, e, n) { if (r.meshes) for (const o of r.meshes) { if (o.aabb.min[0] === 1 / 0) continue; const u = Jt.applyTransform(o.aabb, r.matrix); n.insert(e, u.min[0], u.min[1], u.max[0], u.max[1]); } if (r.children) for (const o of r.children) Zx(o, e, n); } const Hx = ["", "wall", "door", "roof", "window", "lamp", "logo"]; class qx { constructor(e) { this.node = e, this.evaluatedRMEA = [[1, 0, 0, 1], [1, 0, 0, 1], [1, 0, 0, 1], [1, 0, 0, 1], [0.4, 1, 0, 1], [1, 0, 0, 1], [1, 0, 0, 1]], this.hiddenByReplacement = !1, this.evaluatedScale = [1, 1, 1], this.evaluatedColor = [], this.emissionHeightBasedParams = [], this.cameraCollisionOpacity = 1, this.feature = { type: "Point", id: e.id, geometry: [], properties: { height: Gx(e) } }, this.aabb = this._getLocalBounds(), this.state = null; } _getLocalBounds() { if (!this.node.meshes) return new Jt([1 / 0, 1 / 0, 1 / 0], [-1 / 0, -1 / 0, -1 / 0]); if (!this.aabb) { let e = 0; const n = new Jt([1 / 0, 1 / 0, 1 / 0], [-1 / 0, -1 / 0, -1 / 0]); for (const o of this.node.meshes) this.node.lightMeshIndex !== e && (o.transformedAabb = Jt.applyTransformFast(o.aabb, this.node.matrix), n.encapsulate(o.transformedAabb)), e++; this.aabb = n; } return this.aabb; } } class em { constructor(e, n, o, u, l, f, v) { this.id = o, this.layers = e, this.layerIds = this.layers.map((S) => S.fqid), this.stateDependentLayerIds = this.layers.filter((S) => S.isStateDependent()).map((S) => S.id), this.modelTraits |= Ou.CoordinateSpaceTile, this.uploaded = !1, this.hasPattern = !1, u && (this.modelTraits |= Ou.HasMapboxMeshFeatures), l && (this.modelTraits |= Ou.HasMeshoptCompression), this.zoom = -1, this.terrainExaggeration = 1, this.projection = { name: "mercator" }, this.replacementUpdateTime = 0, this.elevationReadFromZ = 255, this.brightness = f, this.dirty = !0, this.needsUpload = !1, this.nodesInfo = []; for (const S of n) this.nodesInfo.push(new qx(S)), Zx(S, v.featureIndexArray.length, v.grid), v.featureIndexArray.emplaceBack(this.nodesInfo.length - 1, 0, v.bucketLayerIDs.length - 1, 0); this.states = {}; } updateFootprints(e, n) { for (const o of this.getNodesInfo()) { const u = o.node; u.footprint && n.push({ footprint: u.footprint, id: e }); } } update(e) { const n = Object.keys(e).length !== 0; if (n && !this.stateDependentLayers.length) return; const o = n ? this.stateDependentLayers : this.layers; if (!Ws(e, this.states)) for (const u of o) this.evaluate(u, e); this.states = structuredClone(e); } populate() { console.log("populate 3D model bucket"); } uploadPending() { return !this.uploaded || this.needsUpload; } upload(e) { if (!this.needsUpload) return; const n = this.getNodesInfo(); for (const o of n) { const u = o.node; this.uploaded ? this.updatePbrBuffer(u) : ig(u, e, !0); } for (const o of n) Qp(o.node); this.uploaded = !0, this.needsUpload = !1; } updatePbrBuffer(e) { let n = !1; if (!e.meshes) return n; for (const o of e.meshes) o.pbrBuffer && (o.pbrBuffer.updateData(o.featureArray), n = !0); return n; } needsReEvaluation(e, n, o) { const u = e.transform.projectionOptions, l = e.style.getBrightness(), f = this.brightness !== l; if (!this.uploaded || this.dirty || u.name !== this.projection.name || of(o.paint.get("model-color").value, f) || of(o.paint.get("model-color-mix-intensity").value, f) || of(o.paint.get("model-roughness").value, f) || of(o.paint.get("model-emissive-strength").value, f) || of(o.paint.get("model-height-based-emissive-strength-multiplier").value, f)) { this.projection = u, this.brightness = l; const v = this.getNodesInfo(); for (const S of v) S.state = null; return !0; } return !1; } evaluateScale(e, n) { if (e.transform.zoom === this.zoom) return; this.zoom = e.transform.zoom; const o = this.getNodesInfo(), u = this.id.canonical; for (const l of o) { const f = l.feature; l.evaluatedScale = n.paint.get("model-scale").evaluate(f, {}, u); } } evaluate(e, n) { const o = this.getNodesInfo(); for (const u of o) { if (!u.node.meshes) continue; const l = u.feature, f = n && n[l.id]; if (Ws(f, u.state)) continue; u.state = structuredClone(f); const v = u.node.meshes && u.node.meshes[0].featureData, S = u.evaluatedColor[2], D = u.evaluatedRMEA[2], x = this.id.canonical; if (u.hasTranslucentParts = !1, v) { for (let P = 0; P < Hx.length; P++) { const I = Hx[P]; I.length && (l.properties.part = I); const M = e.paint.get("model-color").evaluate(l, f, x).toRenderColor(null), C = e.paint.get("model-color-mix-intensity").evaluate(l, f, x); u.evaluatedColor[P] = [M.r, M.g, M.b, C], u.evaluatedRMEA[P][0] = e.paint.get("model-roughness").evaluate(l, f, x), u.evaluatedRMEA[P][2] = e.paint.get("model-emissive-strength").evaluate(l, f, x), u.evaluatedRMEA[P][3] = M.a, u.emissionHeightBasedParams[P] = e.paint.get("model-height-based-emissive-strength-multiplier").evaluate(l, f, x), !u.hasTranslucentParts && M.a < 1 && (u.hasTranslucentParts = !0); } delete l.properties.part, c2(u, S !== u.evaluatedColor[2] || D !== u.evaluatedRMEA[2], this.modelTraits); } else u.evaluatedRMEA[0][2] = e.paint.get("model-emissive-strength").evaluate(l, f, x); u.evaluatedScale = e.paint.get("model-scale").evaluate(l, f, x), this.updatePbrBuffer(u.node) || (this.needsUpload = !0); } this.dirty = !1; } elevationUpdate(e, n, o, u) { const l = e.findDEMTileFor(o); if (l && (l.tileID.canonical !== this.terrainTile || n !== this.terrainExaggeration)) { if (l.dem && l.tileID.overscaledZ !== this.elevationReadFromZ) { this.elevationReadFromZ = l.tileID.overscaledZ; const f = Fu.create(e, o, l); if (!f) return; this.modelTraits & Ou.HasMapboxMeshFeatures && this.updateDEM(e, f, o, u); for (const v of this.getNodesInfo()) { const S = v.node; if (!S.footprint || !S.footprint.vertices || !S.footprint.vertices.length) continue; const D = S.footprint.vertices; let x = f.getElevationAt(D[0].x, D[0].y, !0, !0); for (let P = 1; P < D.length; P++) x = Math.min(x, f.getElevationAt(D[P].x, D[P].y, !0, !0)); S.elevation = x; } } this.terrainTile = l.tileID.canonical, this.terrainExaggeration = n; } } updateDEM(e, n, o, u) { let l = n._dem._modifiedForSources[u]; if (l === void 0 && (n._dem._modifiedForSources[u] = [], l = n._dem._modifiedForSources[u]), l.includes(o.canonical)) return; const f = n._dem.dim; l.push(o.canonical); let v = !1; for (const S of this.getNodesInfo()) { const D = S.node; if (!D.footprint || !D.footprint.grid) continue; const x = D.footprint.grid, P = n.tileCoordToPixel(x.min.x, x.min.y), I = n.tileCoordToPixel(x.max.x, x.max.y), M = Math.min(Math.min(f - I.y, P.x), Math.min(P.y, f - I.x)); if (M < 0) continue; const C = si(M, 2, 5); let k = Math.max(0, P.x - C), V = Math.max(0, P.y - C), U = Math.min(I.x + C, f - 1), q = Math.min(I.y + C, f - 1); for (let Q = V; Q <= q; ++Q) for (let ie = k; ie <= U; ++ie) wh[Q * f + ie] = 255; let $ = 0, H = 0; for (let Q = 0; Q < x.cellsY; ++Q) for (let ie = 0; ie < x.cellsX; ++ie) { if (!x.cells[Q * x.cellsX + ie]) continue; const fe = n.tileCoordToPixel(x.min.x + ie / x.xScale, x.min.y + Q / x.yScale), de = n.tileCoordToPixel(x.min.x + (ie + 1) / x.xScale, x.min.y + (Q + 1) / x.yScale); for (let ue = fe.y; ue <= Math.min(de.y + 1, f - 1); ++ue) for (let Se = fe.x; Se <= Math.min(de.x + 1, f - 1); ++Se) wh[ue * f + Se] === 255 && (wh[ue * f + Se] = 0, $ += n.getElevationAtPixel(Se, ue), H++); } const K = $ / H; k = Math.max(1, P.x - C), V = Math.max(1, P.y - C), U = Math.min(I.x + C, f - 2), q = Math.min(I.y + C, f - 2), v = !0; for (let Q = V; Q <= q; ++Q) for (let ie = k; ie <= U; ++ie) wh[Q * f + ie] === 0 && (sg[Q * f + ie] = n._dem.set(ie, Q, K)); for (let Q = 1; Q < C; ++Q) { k = Math.max(1, P.x - Q), V = Math.max(1, P.y - Q), U = Math.min(I.x + Q, f - 2), q = Math.min(I.y + Q, f - 2); for (let ie = V; ie <= q; ++ie) for (let fe = k; fe <= U; ++fe) { const de = ie * f + fe; if (wh[de] === 255) { let ue = 0, Se = 0, me = -1, Ee = -1; for (let ze = -1; ze <= 1; ++ze) for (let Ie = -1; Ie <= 1; ++Ie) { const Re = (ie + ze) * f + fe + Ie; if (wh[Re] >= Q) continue; const Ve = sg[Re], Ue = Math.abs(Ve); Ue > Se && (ue = Ve, Se = Ue, me = Ie, Ee = ze); } if (Se > 0.1) { const ze = 1 - (Q + 0.5 * Math.abs(me * Ee)) / C; let Ie = n._dem.get(fe, ie) + ue * ze; const Re = n._dem.get(fe + me, ie + Ee), Ve = n._dem.get(fe - me, ie - Ee, !0); (Ie - Re) * (Ie - Ve) > 0 && (Ie = (Re + Ve) / 2), sg[de] = n._dem.set(fe, ie, Ie), wh[de] = Q; } } } } } v && (n._demTile.needsDEMTextureUpload = !0, n._dem._timestamp = Ct.now()); } getNodesInfo() { return this.nodesInfo; } destroy() { const e = this.getNodesInfo(); for (const n of e) Qp(n.node), ng(n.node); } isEmpty() { return !this.nodesInfo.length; } updateReplacement(e, n) { if (n.updateTime === this.replacementUpdateTime) return; this.replacementUpdateTime = n.updateTime; const o = n.getReplacementRegionsForTile(e.toUnwrapped()), u = this.getNodesInfo(); for (let l = 0; l < this.nodesInfo.length; l++) { const f = u[l].node; u[l].hiddenByReplacement = !!f.footprint && !o.find((v) => v.footprint === f.footprint); } } getHeightAtTileCoord(e, n) { const o = this.getNodesInfo(), u = [], l = [0, 0, 0], f = De.mat4.identity([]); for (let v = 0; v < this.nodesInfo.length; v++) { const S = o[v], D = S.node.meshes[0], x = D.transformedAabb; if (e < x.min[0] || n < x.min[1] || e > x.max[0] || n > x.max[1]) continue; if (S.node.hidden === !0) return { height: 1 / 0, maxHeight: S.feature.properties.height, hidden: !1, verticalScale: S.evaluatedScale[2] }; De.mat4.invert(f, S.node.matrix), l[0] = e, l[1] = n, De.vec3.transformMat4(l, l, f); const P = (l[0] - D.aabb.min[0]) / (D.aabb.max[0] - D.aabb.min[0]) * bh | 0, I = Math.min(63, (l[1] - D.aabb.min[1]) / (D.aabb.max[1] - D.aabb.min[1]) * bh | 0) * bh + Math.min(63, P), M = D.heightmap[I]; if (!(M < 0 && S.node.footprint)) return S.hiddenByReplacement ? void 0 : { height: M, maxHeight: S.feature.properties.height, hidden: !1, verticalScale: S.evaluatedScale[2] }; if (S.node.footprint.grid.query(new Et(e, n), new Et(e, n), u), u.length > 0) return { height: void 0, maxHeight: S.feature.properties.height, hidden: S.hiddenByReplacement, verticalScale: S.evaluatedScale[2] }; } } } function of(r, e) { return !r.isLightConstant && e; } function l2(r, e, n, o, u, l, f, v) { let S = (61440 & e | (61440 & e) >> 4) >> 8, D = (3840 & e | (3840 & e) >> 4) >> 4, x = 240 & e | (240 & e) >> 4; n[3] > 0 && (S = ei(S, 255 * n[0], n[3]), D = ei(D, 255 * n[1], n[3]), x = ei(x, 255 * n[2], n[3])); const P = S << 8 | D, I = x << 8 | Math.floor(255 * o[3]), M = function(Q) { const ie = si(Q, 0, 2); return Math.min(Math.round(0.5 * ie * 255), 255); }(o[2]) << 8 | 15 * o[0] << 4 | 15 * o[1], C = si(u[0], 0, 1), k = si(u[1], 0, 1), V = si(u[2], 0, 1), U = si(u[3], 0, 1); let q, $, H, K; if (C !== k && f !== l && k !== C) { const Q = f - l; $ = 1 / (Q * (k - C)), H = -(l + Q * C) / (Q * (k - C)); const ie = si(u[4], -1, 1); K = Math.pow(10, ie), q = 255 * V << 8 | 255 * U; } else q = 65535, $ = 0, H = 1, K = 1; if (r.emplaceBack(P, I, M, q, $, H, K), v) { const Q = v.length; v.clear(); for (let ie = 0; ie < Q; ie++) v.emplaceBack(P, I, M, q, $, H, K); } } function c2(r, e, n) { const o = r.node; let u = 0; const l = n & Ou.HasMeshoptCompression; for (const f of o.meshes) { if (o.lights && o.lightMeshIndex === u || !f.featureData) continue; f.featureArray = new lh(), f.featureArray.reserve(f.featureData.length); let v = e; for (const S of f.featureData) { const D = l ? 65535 & S : S >> 16 & 65535, x = l ? S >> 16 & 65535 : 65535 & S, P = (15 & x) < 8 ? 15 & x : 0, I = r.evaluatedRMEA[P], M = r.evaluatedColor[P], C = r.emissionHeightBasedParams[P]; let k; if (v && P === 2 && o.lights && (k = new lh(), k.resize(10 * o.lights.length)), l2(f.featureArray, D, M, I, C, f.aabb.min[2], f.aabb.max[2], k), k && v) { v = !1; const V = o.meshes[o.lightMeshIndex]; V.featureArray = k, V.featureArray._trim(); } } f.featureArray._trim(), u++; } } function Wx(r, e, n, o) { const u = 1 << r.z; e.lat = Os((o / Tt + r.y) / u), e.lng = Fr((n / Tt + r.x) / u); } Ft(em, "Tiled3dModelBucket", { omit: ["layers"] }), Ft(qx, "Tiled3dModelFeature"); const h2 = { circle: class extends wr { constructor(r, e, n, o) { super(r, { layout: Ge || (Ge = new Bn({ "circle-sort-key": new Dt($e.layout_circle["circle-sort-key"]), visibility: new yt($e.layout_circle.visibility) })), paint: lt || (lt = new Bn({ "circle-radius": new Dt($e.paint_circle["circle-radius"]), "circle-color": new Dt($e.paint_circle["circle-color"]), "circle-blur": new Dt($e.paint_circle["circle-blur"]), "circle-opacity": new Dt($e.paint_circle["circle-opacity"]), "circle-translate": new yt($e.paint_circle["circle-translate"]), "circle-translate-anchor": new yt($e.paint_circle["circle-translate-anchor"]), "circle-pitch-scale": new yt($e.paint_circle["circle-pitch-scale"]), "circle-pitch-alignment": new yt($e.paint_circle["circle-pitch-alignment"]), "circle-stroke-width": new Dt($e.paint_circle["circle-stroke-width"]), "circle-stroke-color": new Dt($e.paint_circle["circle-stroke-color"]), "circle-stroke-opacity": new Dt($e.paint_circle["circle-stroke-opacity"]), "circle-emissive-strength": new yt($e.paint_circle["circle-emissive-strength"]), "circle-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "circle-stroke-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o); } createBucket(r) { return new ee(r); } queryRadius(r) { const e = r; return Ne("circle-radius", this, e) + Ne("circle-stroke-width", this, e) + st(this.paint.get("circle-translate")); } queryIntersectsFeature(r, e, n, o, u, l, f, v) { const S = xt(this.paint.get("circle-translate"), this.paint.get("circle-translate-anchor"), l.angle, r.pixelToTileUnitsFactor), D = this.paint.get("circle-radius").evaluate(e, n) + this.paint.get("circle-stroke-width").evaluate(e, n); return Au(r, o, l, f, v, this.paint.get("circle-pitch-alignment") === "map", this.paint.get("circle-pitch-scale") === "map", S, D); } getProgramIds() { return ["circle"]; } getDefaultProgramParams(r, e, n) { const o = Pu(this); return { config: new Cl(this, { zoom: e, lut: n }), defines: o, overrideFog: !1 }; } }, heatmap: class extends wr { createBucket(r) { return new Sy(r); } constructor(r, e, n, o) { super(r, { layout: Ey || (Ey = new Bn({ visibility: new yt($e.layout_heatmap.visibility) })), paint: Py || (Py = new Bn({ "heatmap-radius": new Dt($e.paint_heatmap["heatmap-radius"]), "heatmap-weight": new Dt($e.paint_heatmap["heatmap-weight"]), "heatmap-intensity": new yt($e.paint_heatmap["heatmap-intensity"]), "heatmap-color": new Wa($e.paint_heatmap["heatmap-color"]), "heatmap-opacity": new yt($e.paint_heatmap["heatmap-opacity"]), "heatmap-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o), this._updateColorRamp(); } _handleSpecialPaintPropertyUpdate(r) { r === "heatmap-color" && this._updateColorRamp(); } _updateColorRamp() { this.colorRamp = Bd({ 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(r) { return Ne("heatmap-radius", this, r); } queryIntersectsFeature(r, e, n, o, u, l, f, v) { const S = this.paint.get("heatmap-radius").evaluate(e, n); return Au(r, o, l, f, v, !0, !0, new Et(0, 0), S); } hasOffscreenPass() { return this.paint.get("heatmap-opacity") !== 0 && this.visibility !== "none"; } getProgramIds() { return ["heatmap", "heatmapTexture"]; } getDefaultProgramParams(r, e, n) { return r === "heatmap" ? { config: new Cl(this, { zoom: e, lut: n }), overrideFog: !1 } : {}; } }, hillshade: class extends wr { constructor(r, e, n, o) { super(r, { layout: Ay || (Ay = new Bn({ visibility: new yt($e.layout_hillshade.visibility) })), paint: Cy || (Cy = new Bn({ "hillshade-illumination-direction": new yt($e.paint_hillshade["hillshade-illumination-direction"]), "hillshade-illumination-anchor": new yt($e.paint_hillshade["hillshade-illumination-anchor"]), "hillshade-exaggeration": new yt($e.paint_hillshade["hillshade-exaggeration"]), "hillshade-shadow-color": new yt($e.paint_hillshade["hillshade-shadow-color"]), "hillshade-highlight-color": new yt($e.paint_hillshade["hillshade-highlight-color"]), "hillshade-accent-color": new yt($e.paint_hillshade["hillshade-accent-color"]), "hillshade-emissive-strength": new yt($e.paint_hillshade["hillshade-emissive-strength"]), "hillshade-shadow-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "hillshade-highlight-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "hillshade-accent-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o); } shouldRedrape() { return this.hasOffscreenPass() && this.paint.get("hillshade-illumination-anchor") === "viewport"; } hasOffscreenPass() { return this.paint.get("hillshade-exaggeration") !== 0 && this.visibility !== "none"; } getProgramIds() { return ["hillshade", "hillshadePrepare"]; } getDefaultProgramParams(r, e, n) { return { overrideFog: !1 }; } }, fill: class extends wr { constructor(r, e, n, o) { super(r, { layout: By || (By = new Bn({ "fill-sort-key": new Dt($e.layout_fill["fill-sort-key"]), visibility: new yt($e.layout_fill.visibility), "fill-elevation-reference": new yt($e.layout_fill["fill-elevation-reference"]) })), paint: Ny || (Ny = new Bn({ "fill-antialias": new yt($e.paint_fill["fill-antialias"]), "fill-opacity": new Dt($e.paint_fill["fill-opacity"]), "fill-color": new Dt($e.paint_fill["fill-color"]), "fill-outline-color": new Dt($e.paint_fill["fill-outline-color"]), "fill-translate": new yt($e.paint_fill["fill-translate"]), "fill-translate-anchor": new yt($e.paint_fill["fill-translate-anchor"]), "fill-pattern": new Dt($e.paint_fill["fill-pattern"]), "fill-emissive-strength": new yt($e.paint_fill["fill-emissive-strength"]), "fill-z-offset": new Dt($e.paint_fill["fill-z-offset"]), "fill-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "fill-outline-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o); } getProgramIds() { const r = this.paint.get("fill-pattern"), e = r && r.constantOr(1), n = [e ? "fillPattern" : "fill"]; return this.paint.get("fill-antialias") && n.push(e && !this.getPaintProperty("fill-outline-color") ? "fillOutlinePattern" : "fillOutline"), n; } getDefaultProgramParams(r, e, n) { return { config: new Cl(this, { zoom: e, lut: n }), overrideFog: !1 }; } recalculate(r, e) { super.recalculate(r, e); const n = this.paint._values["fill-outline-color"]; n.value.kind === "constant" && n.value.value === void 0 && (this.paint._values["fill-outline-color"] = this.paint._values["fill-color"]); } createBucket(r) { return new v_(r); } queryRadius() { return st(this.paint.get("fill-translate")); } queryIntersectsFeature(r, e, n, o, u, l) { return !r.queryGeometry.isAboveHorizon && he(ut(r.tilespaceGeometry, this.paint.get("fill-translate"), this.paint.get("fill-translate-anchor"), l.angle, r.pixelToTileUnitsFactor), o); } isTileClipped() { return !0; } is3D() { return this.paint.get("fill-z-offset").constantOr(1) !== 0; } }, "fill-extrusion": class extends wr { constructor(r, e, n, o) { super(r, { layout: v0 || (v0 = new Bn({ visibility: new yt($e["layout_fill-extrusion"].visibility), "fill-extrusion-edge-radius": new yt($e["layout_fill-extrusion"]["fill-extrusion-edge-radius"]) })), paint: b0 || (b0 = new Bn({ "fill-extrusion-opacity": new yt($e["paint_fill-extrusion"]["fill-extrusion-opacity"]), "fill-extrusion-color": new Dt($e["paint_fill-extrusion"]["fill-extrusion-color"]), "fill-extrusion-translate": new yt($e["paint_fill-extrusion"]["fill-extrusion-translate"]), "fill-extrusion-translate-anchor": new yt($e["paint_fill-extrusion"]["fill-extrusion-translate-anchor"]), "fill-extrusion-pattern": new Dt($e["paint_fill-extrusion"]["fill-extrusion-pattern"]), "fill-extrusion-height": new Dt($e["paint_fill-extrusion"]["fill-extrusion-height"]), "fill-extrusion-base": new Dt($e["paint_fill-extrusion"]["fill-extrusion-base"]), "fill-extrusion-height-alignment": new yt($e["paint_fill-extrusion"]["fill-extrusion-height-alignment"]), "fill-extrusion-base-alignment": new yt($e["paint_fill-extrusion"]["fill-extrusion-base-alignment"]), "fill-extrusion-vertical-gradient": new yt($e["paint_fill-extrusion"]["fill-extrusion-vertical-gradient"]), "fill-extrusion-ambient-occlusion-intensity": new yt($e["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-intensity"]), "fill-extrusion-ambient-occlusion-radius": new yt($e["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-radius"]), "fill-extrusion-ambient-occlusion-wall-radius": new yt($e["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-wall-radius"]), "fill-extrusion-ambient-occlusion-ground-radius": new yt($e["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-ground-radius"]), "fill-extrusion-ambient-occlusion-ground-attenuation": new yt($e["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-ground-attenuation"]), "fill-extrusion-flood-light-color": new yt($e["paint_fill-extrusion"]["fill-extrusion-flood-light-color"]), "fill-extrusion-flood-light-intensity": new yt($e["paint_fill-extrusion"]["fill-extrusion-flood-light-intensity"]), "fill-extrusion-flood-light-wall-radius": new Dt($e["paint_fill-extrusion"]["fill-extrusion-flood-light-wall-radius"]), "fill-extrusion-flood-light-ground-radius": new Dt($e["paint_fill-extrusion"]["fill-extrusion-flood-light-ground-radius"]), "fill-extrusion-flood-light-ground-attenuation": new yt($e["paint_fill-extrusion"]["fill-extrusion-flood-light-ground-attenuation"]), "fill-extrusion-vertical-scale": new yt($e["paint_fill-extrusion"]["fill-extrusion-vertical-scale"]), "fill-extrusion-rounded-roof": new yt($e["paint_fill-extrusion"]["fill-extrusion-rounded-roof"]), "fill-extrusion-cutoff-fade-range": new yt($e["paint_fill-extrusion"]["fill-extrusion-cutoff-fade-range"]), "fill-extrusion-emissive-strength": new Dt($e["paint_fill-extrusion"]["fill-extrusion-emissive-strength"]), "fill-extrusion-line-width": new Dt($e["paint_fill-extrusion"]["fill-extrusion-line-width"]), "fill-extrusion-cast-shadows": new yt($e["paint_fill-extrusion"]["fill-extrusion-cast-shadows"]), "fill-extrusion-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "fill-extrusion-flood-light-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o), this._stats = { numRenderedVerticesInShadowPass: 0, numRenderedVerticesInTransparentPass: 0 }; } createBucket(r) { return new Ip(r); } queryRadius() { return st(this.paint.get("fill-extrusion-translate")); } is3D() { return !0; } hasShadowPass() { return this.paint.get("fill-extrusion-cast-shadows"); } cutoffRange() { return this.paint.get("fill-extrusion-cutoff-fade-range"); } canCastShadows() { return !0; } getProgramIds() { return [this.paint.get("fill-extrusion-pattern").constantOr(1) ? "fillExtrusionPattern" : "fillExtrusion"]; } queryIntersectsFeature(r, e, n, o, u, l, f, v, S) { const D = xt(this.paint.get("fill-extrusion-translate"), this.paint.get("fill-extrusion-translate-anchor"), l.angle, r.pixelToTileUnitsFactor), x = this.paint.get("fill-extrusion-height").evaluate(e, n), P = this.paint.get("fill-extrusion-base").evaluate(e, n), I = [0, 0], M = v && l.elevation, C = l.elevation ? l.elevation.exaggeration() : 1, k = r.tile.getBucket(this); if (M && k instanceof Ip) { const H = k.centroidVertexArray, K = S + 1; K < H.length && (I[0] = H.geta_centroid_pos0(K), I[1] = H.geta_centroid_pos1(K)); } if (I[0] === 0 && I[1] === 1) return !1; l.projection.name === "globe" && (o = x0([o], [new Et(0, 0), new Et(Tt, Tt)], r.tileID.canonical).map((H) => H.polygon).flat()); const V = M ? v : null, [U, q] = function(H, K, Q, ie, fe, de, ue, Se, me, Ee, ze) { return H.projection.name === "globe" ? function(Ie, Re, Ve, Ue, Fe, et, dt, tt, Mt, wt, At) { const rt = [], Ut = [], St = Ie.projection.upVectorScale(At, Ie.center.lat, Ie.worldSize).metersToTile, Nt = [0, 0, 0, 1], Qt = [0, 0, 0, 1], pi = (Ai, yi, Ii, fn) => { Ai[0] = yi, Ai[1] = Ii, Ai[2] = fn, Ai[3] = 1; }, gi = y0(); Ve > 0 && (Ve += gi), Ue += gi; for (const Ai of Re) { const yi = [], Ii = []; for (const fn of Ai) { const rn = fn.x + Fe.x, hi = fn.y + Fe.y, on = Ie.projection.projectTilePoint(rn, hi, At), Qi = Ie.projection.upVector(At, fn.x, fn.y); let pn = Ve, as = Ue; if (dt) { const ls = T0(rn, hi, Ve, Ue, dt, tt, Mt, wt); pn += ls.base, as += ls.top; } Ve !== 0 ? pi(Nt, on.x + Qi[0] * St * pn, on.y + Qi[1] * St * pn, on.z + Qi[2] * St * pn) : pi(Nt, on.x, on.y, on.z), pi(Qt, on.x + Qi[0] * St * as, on.y + Qi[1] * St * as, on.z + Qi[2] * St * as), De.vec3.transformMat4(Nt, Nt, et), De.vec3.transformMat4(Qt, Qt, et), yi.push(new vh(Nt[0], Nt[1], Nt[2])), Ii.push(new vh(Qt[0], Qt[1], Qt[2])); } rt.push(yi), Ut.push(Ii); } return [rt, Ut]; }(H, K, Q, ie, fe, de, ue, Se, me, Ee, ze) : ue ? function(Ie, Re, Ve, Ue, Fe, et, dt, tt, Mt) { const wt = [], At = [], rt = [0, 0, 0, 1]; for (const Ut of Ie) { const St = [], Nt = []; for (const Qt of Ut) { const pi = Qt.x + Ue.x, gi = Qt.y + Ue.y, Ai = T0(pi, gi, Re, Ve, et, dt, tt, Mt); rt[0] = pi, rt[1] = gi, rt[2] = Ai.base, rt[3] = 1, De.vec4.transformMat4(rt, rt, Fe), rt[3] = Math.max(rt[3], 1e-5); const yi = new vh(rt[0] / rt[3], rt[1] / rt[3], rt[2] / rt[3]); rt[0] = pi, rt[1] = gi, rt[2] = Ai.top, rt[3] = 1, De.vec4.transformMat4(rt, rt, Fe), rt[3] = Math.max(rt[3], 1e-5); const Ii = new vh(rt[0] / rt[3], rt[1] / rt[3], rt[2] / rt[3]); St.push(yi), Nt.push(Ii); } wt.push(St), At.push(Nt); } return [wt, At]; }(K, Q, ie, fe, de, ue, Se, me, Ee) : function(Ie, Re, Ve, Ue, Fe) { const et = [], dt = [], tt = Fe[8] * Re, Mt = Fe[9] * Re, wt = Fe[10] * Re, At = Fe[11] * Re, rt = Fe[8] * Ve, Ut = Fe[9] * Ve, St = Fe[10] * Ve, Nt = Fe[11] * Ve; for (const Qt of Ie) { const pi = [], gi = []; for (const Ai of Qt) { const yi = Ai.x + Ue.x, Ii = Ai.y + Ue.y, fn = Fe[0] * yi + Fe[4] * Ii + Fe[12], rn = Fe[1] * yi + Fe[5] * Ii + Fe[13], hi = Fe[2] * yi + Fe[6] * Ii + Fe[14], on = Fe[3] * yi + Fe[7] * Ii + Fe[15], Qi = fn + tt, pn = rn + Mt, as = hi + wt, ls = Math.max(on + At, 1e-5), Kn = fn + rt, Vr = rn + Ut, Sn = hi + St, Ln = Math.max(on + Nt, 1e-5); pi.push(new vh(Qi / ls, pn / ls, as / ls)), gi.push(new vh(Kn / Ln, Vr / Ln, Sn / Ln)); } et.push(pi), dt.push(gi); } return [et, dt]; }(K, Q, ie, fe, de); }(l, o, P, x, D, f, V, I, C, l.center.lat, r.tileID.canonical), $ = r.queryGeometry; return function(H, K, Q) { let ie = 1 / 0; he(Q, K) && (ie = w0(Q, K[0])); for (let fe = 0; fe < K.length; fe++) { const de = K[fe], ue = H[fe]; for (let Se = 0; Se < de.length - 1; Se++) { const me = de[Se], Ee = [me, de[Se + 1], ue[Se + 1], ue[Se], me]; se(Q, Ee) && (ie = Math.min(ie, w0(Q, Ee))); } } return ie !== 1 / 0 && ie; }(U, q, $.isPointQuery() ? $.screenBounds : $.screenGeometry); } }, line: class extends wr { constructor(r, e, n, o) { const u = D0(); super(r, u, e, n, o), u.layout && (this.layout = new cc(u.layout)), this.gradientVersion = 0; } _handleSpecialPaintPropertyUpdate(r) { if (r === "line-gradient") { const e = this._transitionablePaint._values["line-gradient"].value.expression; this.stepInterpolant = e._styleExpression && e._styleExpression.expression instanceof Ti, 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(r, e) { super.recalculate(r, e), this.paint._values["line-floorwidth"] = (() => { if (Wd) return Wd; const n = D0(); return Wd = new fT(n.paint.properties["line-width"].specification), Wd.useIntegerZoom = !0, Wd; })().possiblyEvaluate(this._transitioningPaint._values["line-width"].value, r); } createBucket(r) { return new I_(r); } getProgramIds() { return [this.paint.get("line-pattern").constantOr(1) ? "linePattern" : "line"]; } getDefaultProgramParams(r, e, n) { const o = L0(this); return { config: new Cl(this, { zoom: e, lut: n }), defines: o, overrideFog: !1 }; } queryRadius(r) { const e = r, n = k0(Ne("line-width", this, e), Ne("line-gap-width", this, e)), o = Ne("line-offset", this, e); return n / 2 + Math.abs(o) + st(this.paint.get("line-translate")); } queryIntersectsFeature(r, e, n, o, u, l) { if (r.queryGeometry.isAboveHorizon) return !1; const f = ut(r.tilespaceGeometry, this.paint.get("line-translate"), this.paint.get("line-translate-anchor"), l.angle, r.pixelToTileUnitsFactor), v = r.pixelToTileUnitsFactor / 2 * k0(this.paint.get("line-width").evaluate(e, n), this.paint.get("line-gap-width").evaluate(e, n)), S = this.paint.get("line-offset").evaluate(e, n); return S && (o = function(D, x) { const P = [], I = new Et(0, 0); for (let M = 0; M < D.length; M++) { const C = D[M], k = []; for (let V = 0; V < C.length; V++) { const U = C[V], q = C[V + 1], $ = V === 0 ? I : U.sub(C[V - 1])._unit()._perp(), H = V === C.length - 1 ? I : q.sub(U)._unit()._perp(), K = $._add(H)._unit(); K._mult(1 / (K.x * H.x + K.y * H.y)), k.push(K._mult(x)._add(U)); } P.push(k); } return P; }(o, S * r.pixelToTileUnitsFactor)), function(D, x, P) { for (let I = 0; I < x.length; I++) { const M = x[I]; if (D.length >= 3) { for (let C = 0; C < M.length; C++) if (Ae(D, M[C])) return !0; } if (_e(D, M, P)) return !0; } return !1; }(f, o, v); } isTileClipped() { return !0; } isDraped(r) { const e = this.layout.get("line-z-offset"), n = e.isConstant() && !e.constantOr(0), o = this.layout.get("line-elevation-reference"); return !(o === "sea" || o === "ground") && (n || o !== "none"); } }, symbol: qp, background: class extends wr { constructor(r, e, n, o) { super(r, { layout: yx || (yx = new Bn({ visibility: new yt($e.layout_background.visibility) })), paint: xx || (xx = new Bn({ "background-pitch-alignment": new yt($e.paint_background["background-pitch-alignment"]), "background-color": new yt($e.paint_background["background-color"]), "background-pattern": new yt($e.paint_background["background-pattern"]), "background-opacity": new yt($e.paint_background["background-opacity"]), "background-emissive-strength": new yt($e.paint_background["background-emissive-strength"]), "background-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o); } getProgramIds() { return [this.paint.get("background-pattern") ? "backgroundPattern" : "background"]; } getDefaultProgramParams(r, e, n) { return { overrideFog: !1 }; } is3D() { return this.paint.get("background-pitch-alignment") === "viewport"; } }, raster: Mx, "raster-particle": Ix, sky: class extends wr { constructor(r, e, n, o) { super(r, { layout: Px || (Px = new Bn({ visibility: new yt($e.layout_sky.visibility) })), paint: Ax || (Ax = new Bn({ "sky-type": new yt($e.paint_sky["sky-type"]), "sky-atmosphere-sun": new yt($e.paint_sky["sky-atmosphere-sun"]), "sky-atmosphere-sun-intensity": new yt($e.paint_sky["sky-atmosphere-sun-intensity"]), "sky-gradient-center": new yt($e.paint_sky["sky-gradient-center"]), "sky-gradient-radius": new yt($e.paint_sky["sky-gradient-radius"]), "sky-gradient": new Wa($e.paint_sky["sky-gradient"]), "sky-atmosphere-halo-color": new yt($e.paint_sky["sky-atmosphere-halo-color"]), "sky-atmosphere-color": new yt($e.paint_sky["sky-atmosphere-color"]), "sky-opacity": new yt($e.paint_sky["sky-opacity"]), "sky-gradient-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "sky-atmosphere-halo-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }), "sky-atmosphere-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o), this._updateColorRamp(); } _handleSpecialPaintPropertyUpdate(r) { r === "sky-gradient" ? this._updateColorRamp() : r !== "sky-atmosphere-sun" && r !== "sky-atmosphere-halo-color" && r !== "sky-atmosphere-color" && r !== "sky-atmosphere-sun-intensity" || (this._skyboxInvalidated = !0); } _updateColorRamp() { this.colorRamp = Bd({ expression: this._transitionablePaint._values["sky-gradient"].value.expression, evaluationKey: "skyRadialProgress" }), this.colorRampTexture && (this.colorRampTexture.destroy(), this.colorRampTexture = null); } needsSkyboxCapture(r) { if (this._skyboxInvalidated || !this.skyboxTexture || !this.skyboxGeometry) return !0; if (!this.paint.get("sky-atmosphere-sun")) { const e = r.style.light.properties.get("position"); return this._lightPosition.azimuthal !== e.azimuthal || this._lightPosition.polar !== e.polar; } return !1; } getCenter(r, e) { if (this.paint.get("sky-type") === "atmosphere") { const o = this.paint.get("sky-atmosphere-sun"), u = !o, l = r.style.light, f = l.properties.get("position"); return u && l.properties.get("anchor") === "viewport" && mi("The sun direction is attached to a light with viewport anchor, lighting may behave unexpectedly."), u ? J_(f.azimuthal, 90 - f.polar, e) : J_(o[0], 90 - o[1], e); } const n = this.paint.get("sky-gradient-center"); return J_(n[0], 90 - n[1], e); } isSky() { return !0; } markSkyboxValid(r) { this._skyboxInvalidated = !1, this._lightPosition = r.style.light.properties.get("position"); } hasOffscreenPass() { return !0; } getProgramIds() { const r = this.paint.get("sky-type"); return r === "atmosphere" ? ["skyboxCapture", "skybox"] : r === "gradient" ? ["skyboxGradient"] : null; } }, slot: class extends wr { constructor(r, e, n, o) { super(r, { paint: Cx || (Cx = new Bn({})) }, e, null); } }, model: class extends wr { constructor(r, e, n, o) { super(r, { layout: Vx || (Vx = new Bn({ visibility: new yt($e.layout_model.visibility), "model-id": new Dt($e.layout_model["model-id"]) })), paint: Ux || (Ux = new Bn({ "model-opacity": new Dt($e.paint_model["model-opacity"]), "model-rotation": new Dt($e.paint_model["model-rotation"]), "model-scale": new Dt($e.paint_model["model-scale"]), "model-translation": new Dt($e.paint_model["model-translation"]), "model-color": new Dt($e.paint_model["model-color"]), "model-color-mix-intensity": new Dt($e.paint_model["model-color-mix-intensity"]), "model-type": new yt($e.paint_model["model-type"]), "model-cast-shadows": new yt($e.paint_model["model-cast-shadows"]), "model-receive-shadows": new yt($e.paint_model["model-receive-shadows"]), "model-ambient-occlusion-intensity": new yt($e.paint_model["model-ambient-occlusion-intensity"]), "model-emissive-strength": new Dt($e.paint_model["model-emissive-strength"]), "model-roughness": new Dt($e.paint_model["model-roughness"]), "model-height-based-emissive-strength-multiplier": new Dt($e.paint_model["model-height-based-emissive-strength-multiplier"]), "model-cutoff-fade-range": new yt($e.paint_model["model-cutoff-fade-range"]), "model-front-cutoff": new yt($e.paint_model["model-front-cutoff"]), "model-color-use-theme": new Dt({ type: "string", default: "default", "property-type": "data-driven" }) })) }, e, n, o), this._stats = { numRenderedVerticesInShadowPass: 0, numRenderedVerticesInTransparentPass: 0 }; } createBucket(r) { return new tg(r); } getProgramIds() { return ["model"]; } is3D() { return !0; } hasShadowPass() { return !0; } canCastShadows() { return !0; } hasLightBeamPass() { return !0; } cutoffRange() { return this.paint.get("model-cutoff-fade-range"); } queryRadius(r) { return r instanceof em ? Tt - 1 : 0; } queryIntersectsFeature(r, e, n, o, u, l) { if (!this.modelManager) return !1; const f = this.modelManager, v = r.tile.getBucket(this); if (!(v && v instanceof tg)) return !1; for (const S in v.instancesPerModel) { const D = v.instancesPerModel[S], x = e.id !== void 0 ? e.id : e.properties && e.properties.hasOwnProperty("id") ? e.properties.id : void 0; if (D.idToFeaturesIndex.hasOwnProperty(x)) { const P = D.features[D.idToFeaturesIndex[x]], I = f.getModel(S, this.scope); if (!I) return !1; let M = De.mat4.create(); const C = new Ui(0, 0), k = v.canonical; let V = Number.MAX_VALUE; for (let U = 0; U < P.instancedDataCount; ++U) { const q = 16 * (P.instancedDataOffset + U), $ = D.instancedDataArray.float32, H = [$[q + 4], $[q + 5], $[q + 6]]; Wx(k, C, $[q], 0 | $[q + 1]), jx(M, I, l, C, P.rotation, P.scale, H, !1, !1, !1), l.projection.name === "globe" && (M = eg(M, l)); const K = De.mat4.multiply([], l.projMatrix, M), Q = r.queryGeometry, ie = Rx(Q.isPointQuery() ? Q.screenBounds : Q.screenGeometry, l, K, I.aabb); ie != null && (V = Math.min(ie, V)); } return V !== Number.MAX_VALUE && V; } } return !1; } _handleOverridablePaintPropertyUpdate(r, e, n) { return !(!this.layout || e.isDataDriven() || n.isDataDriven() || r !== "model-color" && r !== "model-color-mix-intensity" && r !== "model-rotation" && r !== "model-scale" && r !== "model-translation" && r !== "model-emissive-strength"); } _isPropertyZoomDependent(r) { const e = this._transitionablePaint._values[r]; return e != null && e.value != null && e.value.expression != null && e.value.expression instanceof sc; } isZoomDependent() { return this._isPropertyZoomDependent("model-scale") || this._isPropertyZoomDependent("model-rotation") || this._isPropertyZoomDependent("model-translation"); } }, clip: class extends wr { constructor(r, e, n, o) { super(r, { layout: Vy || (Vy = new Bn({ "clip-layer-types": new yt($e.layout_clip["clip-layer-types"]), "clip-layer-scope": new yt($e.layout_clip["clip-layer-scope"]) })), paint: Uy || (Uy = new Bn({})) }, e, n, o); } recalculate(r, e) { super.recalculate(r, e); } createBucket(r) { return new jy(r); } isTileClipped() { return !0; } is3D() { return !0; } } }; class u2 { constructor(e) { this._callback = e, this._triggered = !1, typeof MessageChannel < "u" && (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 d2 { constructor() { this.tasks = {}, this.taskQueue = [], vo(["process"], this), this.invoker = new u2(this.process), this.nextId = 0; } add(e, n) { const o = this.nextId++, u = function({ type: l, isSymbolTile: f, zoom: v }) { return v = v || 0, l === "message" ? 0 : l !== "maybePrepare" || f ? l !== "parseTile" || f ? l === "parseTile" && f ? 300 - v : l === "maybePrepare" && f ? 400 - v : 500 : 200 - v : 100 - v; }(n); if (u === 0) { try { e(); } finally { } return null; } return this.tasks[o] = { fn: e, metadata: n, priority: u, id: o }, this.taskQueue.push(o), this.invoker.trigger(), { cancel: () => { delete this.tasks[o]; } }; } process() { try { if (this.taskQueue = this.taskQueue.filter((o) => !!this.tasks[o]), !this.taskQueue.length) return; const e = this.pick(); if (e === null) return; const n = this.tasks[e]; if (delete this.tasks[e], this.taskQueue.length && this.invoker.trigger(), !n) return; n.fn(); } finally { } } pick() { let e = null, n = 1 / 0; for (let u = 0; u < this.taskQueue.length; u++) { const l = this.tasks[this.taskQueue[u]]; l.priority < n && (n = l.priority, e = u); } if (e === null) return null; const o = this.taskQueue[e]; return this.taskQueue.splice(e, 1), o; } remove() { this.invoker.remove(); } } class $x { constructor(e, n, o) { this.target = e, this.parent = n, this.mapId = o, this.callbacks = {}, this.cancelCallbacks = {}, vo(["receive"], this), this.target.addEventListener("message", this.receive, !1), this.scheduler = new d2(); } send(e, n, o, u, l = !1, f) { const v = Math.round(1e18 * Math.random()).toString(36).substring(0, 10); o && (o.metadata = f, this.callbacks[v] = o); const S = /* @__PURE__ */ new Set(); return this.target.postMessage({ id: v, type: e, hasCallback: !!o, targetMapId: u, mustQueue: l, sourceMapId: this.mapId, data: lo(n, S) }, S), { cancel: () => { o && delete this.callbacks[v], this.target.postMessage({ id: v, type: "", targetMapId: u, sourceMapId: this.mapId }); } }; } receive(e) { const n = e.data, o = n.id; if (o && (!n.targetMapId || this.mapId === n.targetMapId)) if (n.type === "") { const u = this.cancelCallbacks[o]; delete this.cancelCallbacks[o], u && u.cancel(); } else if (n.mustQueue || Jn()) { const u = this.callbacks[o], l = this.scheduler.add(() => this.processTask(o, n), u && u.metadata || { type: "message" }); l && (this.cancelCallbacks[o] = l); } else this.processTask(o, n); } processTask(e, n) { if (delete this.cancelCallbacks[e], n.type === "") { const o = this.callbacks[e]; delete this.callbacks[e], o && (n.error ? o(Tl(n.error)) : o(null, Tl(n.data))); } else { const o = /* @__PURE__ */ new Set(), u = n.hasCallback ? (f, v) => { this.target.postMessage({ id: e, type: "", sourceMapId: this.mapId, error: f ? lo(f) : null, data: lo(v, o) }, o); } : () => { }, l = Tl(n.data); if (this.parent[n.type]) this.parent[n.type](n.sourceMapId, l, u); else if (this.parent.getWorkerSource) { const f = n.type.split("."); this.parent.getWorkerSource(n.sourceMapId, f[0], l.source, l.scope)[f[1]](l, u); } else u(new Error(`Could not find function ${n.type}`)); } } remove() { this.scheduler.remove(), this.target.removeEventListener("message", this.receive, !1); } } var af = { workerUrl: "", workerClass: null, workerParams: void 0 }; const rg = "mapboxgl_preloaded_worker_pool"; class Th { constructor() { this.active = {}; } acquire(e, n = Th.workerCount) { if (!this.workers) for (this.workers = []; this.workers.length < n; ) this.workers.push(af.workerClass != null ? new af.workerClass() : new self.Worker(af.workerUrl, af.workerParams)); return this.active[e] = !0, this.workers.slice(); } release(e) { delete this.active[e], this.workers && this.numActive() === 0 && (this.workers.forEach((n) => { n.terminate(); }), this.workers = null); } isPreloaded() { return !!this.active[rg]; } numActive() { return Object.keys(this.active).length; } } Th.workerCount = 2; class Bu { constructor(e, n, o = "Worker", u = Th.workerCount) { this.workerPool = e, this.actors = [], this.currentActor = 0, this.id = yo(); const l = this.workerPool.acquire(this.id, u); for (let f = 0; f < l.length; f++) { const v = new Bu.Actor(l[f], n, this.id); v.name = `${o} ${f}`, this.actors.push(v); } this.ready = !1, this.broadcast("checkIfReady", null, () => { this.ready = !0; }); } broadcast(e, n, o) { Rn(this.actors, (u, l) => { u.send(e, n, l); }, 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); } } let lf, og; function tm() { return lf || (lf = new Th()), lf; } Bu.Actor = $x; const ag = new ki(0, 0, 0); var im = ((r) => (r[r.PATH_RULE_UNSPECIFIED = 0] = "PATH_RULE_UNSPECIFIED", r[r.PATH_RULE_NON_ZERO = 1] = "PATH_RULE_NON_ZERO", r[r.PATH_RULE_EVEN_ODD = 2] = "PATH_RULE_EVEN_ODD", r))(im || {}), nm = ((r) => (r[r.LINE_CAP_UNSPECIFIED = 0] = "LINE_CAP_UNSPECIFIED", r[r.LINE_CAP_BUTT = 1] = "LINE_CAP_BUTT", r[r.LINE_CAP_ROUND = 2] = "LINE_CAP_ROUND", r[r.LINE_CAP_SQUARE = 3] = "LINE_CAP_SQUARE", r))(nm || {}), cf = ((r) => (r[r.LINE_JOIN_UNSPECIFIED = 0] = "LINE_JOIN_UNSPECIFIED", r[r.LINE_JOIN_MITER = 1] = "LINE_JOIN_MITER", r[r.LINE_JOIN_MITER_CLIP = 2] = "LINE_JOIN_MITER_CLIP", r[r.LINE_JOIN_ROUND = 3] = "LINE_JOIN_ROUND", r[r.LINE_JOIN_BEVEL = 4] = "LINE_JOIN_BEVEL", r))(cf || {}), Xx = ((r) => (r[r.PAINT_ORDER_UNSPECIFIED = 0] = "PAINT_ORDER_UNSPECIFIED", r[r.PAINT_ORDER_FILL_AND_STROKE = 1] = "PAINT_ORDER_FILL_AND_STROKE", r[r.PAINT_ORDER_STROKE_AND_FILL = 2] = "PAINT_ORDER_STROKE_AND_FILL", r))(Xx || {}), Nu = ((r) => (r[r.PATH_COMMAND_UNSPECIFIED = 0] = "PATH_COMMAND_UNSPECIFIED", r[r.PATH_COMMAND_MOVE = 1] = "PATH_COMMAND_MOVE", r[r.PATH_COMMAND_LINE = 2] = "PATH_COMMAND_LINE", r[r.PATH_COMMAND_QUAD = 3] = "PATH_COMMAND_QUAD", r[r.PATH_COMMAND_CUBIC = 4] = "PATH_COMMAND_CUBIC", r[r.PATH_COMMAND_CLOSE = 5] = "PATH_COMMAND_CLOSE", r))(Nu || {}), Yx = ((r) => (r[r.MASK_TYPE_UNSPECIFIED = 0] = "MASK_TYPE_UNSPECIFIED", r[r.MASK_TYPE_LUMINANCE = 1] = "MASK_TYPE_LUMINANCE", r[r.MASK_TYPE_ALPHA = 2] = "MASK_TYPE_ALPHA", r))(Yx || {}); function f2(r, e, n) { r === 1 && e.icons.push(function(o, u) { return function(l) { if (l.usvg_tree.height || (l.usvg_tree.height = l.usvg_tree.width), !l.metadata) return l; const { metadata: f } = l; if (f.content_area) { const { content_area: v } = f; v.top == null && (v.top = v.left), v.width == null && (v.width = l.usvg_tree.width), v.height == null && (v.height = v.width); } return f.stretch_x && f.stretch_x.length && Kx(f, "x"), f.stretch_y && f.stretch_y.length && Kx(f, "y"), l; }(o.readFields(p2, { name: void 0 }, u)); }(n, n.readVarint() + n.pos)); } function Kx(r, e) { const n = [], o = r[`stretch_${e}`]; let u = null; for (let l = 0; l < o.length; l++) u === null ? u = n.length === 0 ? o[0] : n[n.length - 1][1] + o[l] : (n.push([u, u + o[l]]), u = null); r[`stretch_${e}_areas`] = n; } function p2(r, e, n) { r === 1 ? e.name = n.readString() : r === 2 ? e.metadata = function(o, u) { return o.readFields(m2, { stretch_x: null, stretch_y: null, stretch_x_areas: null, stretch_y_areas: null, variables: [] }, u); }(n, n.readVarint() + n.pos) : r === 3 && (e.usvg_tree = function(o, u) { return o.readFields(y2, { width: 20, children: [], linear_gradients: [], radial_gradients: [], clip_paths: [], masks: [] }, u); }(n, n.readVarint() + n.pos), e.data = "usvg_tree"); } function m2(r, e, n) { r === 1 ? e.stretch_x = n.readPackedVarint() : r === 2 ? e.stretch_y = n.readPackedVarint() : r === 3 ? e.content_area = function(o, u) { return o.readFields(_2, { left: 0 }, u); }(n, n.readVarint() + n.pos) : r === 4 && e.variables.push(function(o, u) { return o.readFields(g2, { name: void 0 }, u); }(n, n.readVarint() + n.pos)); } function _2(r, e, n) { r === 1 ? e.left = n.readVarint() : r === 2 ? e.width = n.readVarint() : r === 3 ? e.top = n.readVarint() : r === 4 && (e.height = n.readVarint()); } function g2(r, e, n) { r === 1 ? e.name = n.readString() : r === 2 && (e.rgb_color = om(n.readVarint()), e.value = "rgb_color"); } function y2(r, e, n) { r === 1 ? e.width = e.height = n.readVarint() : r === 2 ? e.height = n.readVarint() : r === 3 ? e.children.push(sm(n, n.readVarint() + n.pos)) : r === 4 ? e.linear_gradients.push(function(o, u) { return o.readFields(S2, { spread_method: 1, stops: [], x1: 0, y1: 0, x2: 1, y2: 0 }, u); }(n, n.readVarint() + n.pos)) : r === 5 ? e.radial_gradients.push(function(o, u) { return o.readFields(P2, { spread_method: 1, stops: [], cx: 0.5, cy: 0.5, r: 0.5, fx: 0.5, fy: 0.5, fr: 0 }, u); }(n, n.readVarint() + n.pos)) : r === 7 ? e.clip_paths.push(function(o, u) { return o.readFields(A2, { children: [] }, u); }(n, n.readVarint() + n.pos)) : r === 8 && e.masks.push(function(o, u) { const l = o.readFields(C2, { left: 0, width: 20, mask_type: 1, children: [] }, u); return l.height == null && (l.height = l.width), l.top == null && (l.top = l.left), l; }(n, n.readVarint() + n.pos)); } function sm(r, e) { return r.readFields(x2, {}, e); } function x2(r, e, n) { r === 1 ? (e.group = function(o, u) { return o.readFields(v2, { opacity: 255, children: [] }, u); }(n, n.readVarint() + n.pos), e.node = "group") : r === 2 && (e.path = function(o, u) { return o.readFields(w2, { paint_order: 1, commands: [], step: 1, diffs: [], rule: 1 }, u); }(n, n.readVarint() + n.pos), e.node = "path"); } function v2(r, e, n) { r === 1 ? e.transform = rm(n, n.readVarint() + n.pos) : r === 2 ? e.opacity = n.readVarint() : r === 5 ? e.clip_path_idx = n.readVarint() : r === 6 ? e.mask_idx = n.readVarint() : r === 7 && e.children.push(sm(n, n.readVarint() + n.pos)); } function rm(r, e) { return r.readFields(b2, { sx: 1, ky: 0, kx: 0, sy: 1, tx: 0, ty: 0 }, e); } function b2(r, e, n) { r === 1 ? e.sx = n.readFloat() : r === 2 ? e.ky = n.readFloat() : r === 3 ? e.kx = n.readFloat() : r === 4 ? e.sy = n.readFloat() : r === 5 ? e.tx = n.readFloat() : r === 6 && (e.ty = n.readFloat()); } function w2(r, e, n) { r === 1 ? e.fill = function(o, u) { return o.readFields(T2, { rgb_color: ag, paint: "rgb_color", opacity: 255 }, u); }(n, n.readVarint() + n.pos) : r === 2 ? e.stroke = function(o, u) { return o.readFields(M2, { rgb_color: ag, paint: "rgb_color", dasharray: [], dashoffset: 0, miterlimit: 4, opacity: 255, width: 1, linecap: 1, linejoin: 1 }, u); }(n, n.readVarint() + n.pos) : r === 3 ? e.paint_order = n.readVarint() : r === 5 ? n.readPackedVarint(e.commands) : r === 6 ? e.step = n.readFloat() : r === 7 ? n.readPackedSVarint(e.diffs) : r === 8 && (e.rule = n.readVarint()); } function T2(r, e, n) { r === 1 ? (e.rgb_color = om(n.readVarint()), e.paint = "rgb_color") : r === 2 ? (e.linear_gradient_idx = n.readVarint(), e.paint = "linear_gradient_idx") : r === 3 ? (e.radial_gradient_idx = n.readVarint(), e.paint = "radial_gradient_idx") : r === 5 && (e.opacity = n.readVarint()); } function om(r) { return new ki((r >> 16 & 255) / 255, (r >> 8 & 255) / 255, (255 & r) / 255, 1); } function M2(r, e, n) { r === 1 ? (e.rgb_color = om(n.readVarint()), e.paint = "rgb_color") : r === 2 ? (e.linear_gradient_idx = n.readVarint(), e.paint = "linear_gradient_idx") : r === 3 ? (e.radial_gradient_idx = n.readVarint(), e.paint = "radial_gradient_idx") : r === 5 ? n.readPackedFloat(e.dasharray) : r === 6 ? e.dashoffset = n.readFloat() : r === 7 ? e.miterlimit = n.readFloat() : r === 8 ? e.opacity = n.readVarint() : r === 9 ? e.width = n.readFloat() : r === 10 ? e.linecap = n.readVarint() : r === 11 && (e.linejoin = n.readVarint()); } function S2(r, e, n) { r === 1 ? e.transform = rm(n, n.readVarint() + n.pos) : r === 2 ? e.spread_method = n.readVarint() : r === 3 ? e.stops.push(Jx(n, n.readVarint() + n.pos)) : r === 4 ? e.x1 = n.readFloat() : r === 5 ? e.y1 = n.readFloat() : r === 6 ? e.x2 = n.readFloat() : r === 7 && (e.y2 = n.readFloat()); } function Jx(r, e) { return r.readFields(E2, { offset: 0, opacity: 255, rgb_color: ag }, e); } function E2(r, e, n) { r === 1 ? e.offset = n.readFloat() : r === 2 ? e.opacity = n.readVarint() : r === 3 && (e.rgb_color = om(n.readVarint())); } function P2(r, e, n) { r === 1 ? e.transform = rm(n, n.readVarint() + n.pos) : r === 2 ? e.spread_method = n.readVarint() : r === 3 ? e.stops.push(Jx(n, n.readVarint() + n.pos)) : r === 4 ? e.cx = n.readFloat() : r === 5 ? e.cy = n.readFloat() : r === 6 ? e.r = n.readFloat() : r === 7 ? e.fx = n.readFloat() : r === 8 ? e.fy = n.readFloat() : r === 9 && (e.fr = n.readFloat()); } function A2(r, e, n) { r === 1 ? e.transform = rm(n, n.readVarint() + n.pos) : r === 2 ? e.clip_path_idx = n.readVarint() : r === 3 && e.children.push(sm(n, n.readVarint() + n.pos)); } function C2(r, e, n) { r === 1 ? e.left = e.top = n.readFloat() : r === 2 ? e.width = e.height = n.readFloat() : r === 3 ? e.top = n.readFloat() : r === 4 ? e.height = n.readFloat() : r === 5 ? e.mask_type = n.readVarint() : r === 6 ? e.mask_idx = n.readVarint() : r === 7 && e.children.push(sm(n, n.readVarint() + n.pos)); } class I2 { static calculate(e, n) { const o = /* @__PURE__ */ new Map(), u = /* @__PURE__ */ new Map(); if (Object.keys(e).length === 0) return o; n.forEach((l) => { u.set(l.name, l.rgb_color || new ki(0, 0, 0)); }); for (const [l, f] of Object.entries(e)) u.has(l) ? o.set(u.get(l).toStringPremultipliedAlpha(), f) : console.warn(`Ignoring unknown image variable "${l}"`); return o; } } function Vu(r, e = 255, n) { const o = e / 255, u = r.toStringPremultipliedAlpha(), l = n.has(u) ? n.get(u).clone() : r.clone(); return l.a = o, l.toString(); } function lg(r, e) { if (!mt()) { const n = document.createElement("canvas"); return n.width = r, n.height = e, n; } return new OffscreenCanvas(r, e); } function L2(r, e) { const n = I2.calculate(e.params, r.metadata ? r.metadata.variables : []), o = r.usvg_tree, u = o.width, l = o.height, f = e.transform ? e.transform : new DOMMatrix(), v = Math.max(1, Math.round(u * f.a)), S = Math.max(1, Math.round(l * f.d)), D = new DOMMatrix([v / u, 0, 0, S / l, 0, 0]), x = lg(v, S).getContext("2d"); return cg(x, D, o, o, n), x.getImageData(0, 0, v, S); } function cg(r, e, n, o, u) { for (const l of o.children) Qx(r, e, n, l, u); } function Qx(r, e, n, o, u) { o.group ? (r.save(), function(l, f, v, S, D) { const x = S.mask_idx != null ? v.masks[S.mask_idx] : null, P = S.clip_path_idx != null ? v.clip_paths[S.clip_path_idx] : null; if (S.transform && (f = hf(S.transform).preMultiplySelf(f)), !function(C, k, V) { return C.opacity !== 255 || k || V; }(S, P != null, x != null)) return void cg(l, f, v, S, D); const I = lg(l.canvas.width, l.canvas.height), M = I.getContext("2d"); P && sv(M, f, v, P), cg(M, f, v, S, D), x && rv(M, f, v, x, D), l.globalAlpha = S.opacity / 255, l.drawImage(I, 0, 0); }(r, e, n, o.group, u), r.restore()) : o.path && (r.save(), function(l, f, v, S, D) { const x = ov(S); l.setTransform(f), S.paint_order === Xx.PAINT_ORDER_FILL_AND_STROKE ? (ev(l, v, S, x, D), tv(l, v, S, x, D)) : (tv(l, v, S, x, D), ev(l, v, S, x, D)); }(r, e, n, o.path, u), r.restore()); } function ev(r, e, n, o, u) { const l = n.fill; if (!l) return; const f = l.opacity / 255; switch (l.paint) { case "rgb_color": r.fillStyle = Vu(l.rgb_color, l.opacity, u); break; case "linear_gradient_idx": r.fillStyle = iv(r, e.linear_gradients[l.linear_gradient_idx], f, u); break; case "radial_gradient_idx": r.fillStyle = nv(r, e.radial_gradients[l.radial_gradient_idx], f, u); } let v; switch (n.rule) { case im.PATH_RULE_NON_ZERO: v = "nonzero"; break; case im.PATH_RULE_EVEN_ODD: v = "evenodd"; } r.fill(o, v); } function tv(r, e, n, o, u) { const l = n.stroke; if (!l) return; r.lineWidth = l.width, r.miterLimit = l.miterlimit, r.setLineDash(l.dasharray), r.lineDashOffset = l.dashoffset; const f = l.opacity / 255; switch (l.paint) { case "rgb_color": r.strokeStyle = Vu(l.rgb_color, l.opacity, u); break; case "linear_gradient_idx": r.strokeStyle = iv(r, e.linear_gradients[l.linear_gradient_idx], f, u); break; case "radial_gradient_idx": r.strokeStyle = nv(r, e.radial_gradients[l.radial_gradient_idx], f, u); } switch (l.linejoin) { case cf.LINE_JOIN_MITER_CLIP: case cf.LINE_JOIN_MITER: r.lineJoin = "miter"; break; case cf.LINE_JOIN_ROUND: r.lineJoin = "round"; break; case cf.LINE_JOIN_BEVEL: r.lineJoin = "bevel"; } switch (l.linecap) { case nm.LINE_CAP_BUTT: r.lineCap = "butt"; break; case nm.LINE_CAP_ROUND: r.lineCap = "round"; break; case nm.LINE_CAP_SQUARE: r.lineCap = "square"; } r.stroke(o); } function iv(r, e, n, o) { if (e.stops.length === 1) { const I = e.stops[0]; return Vu(I.rgb_color, I.opacity * n, o); } const u = hf(e.transform), { x1: l, y1: f, x2: v, y2: S } = e, D = u.transformPoint(new DOMPoint(l, f)), x = u.transformPoint(new DOMPoint(v, S)), P = r.createLinearGradient(D.x, D.y, x.x, x.y); for (const I of e.stops) P.addColorStop(I.offset, Vu(I.rgb_color, I.opacity * n, o)); return P; } function nv(r, e, n, o) { if (e.stops.length === 1) { const I = e.stops[0]; return Vu(I.rgb_color, I.opacity * n, o); } const u = hf(e.transform), { fx: l, fy: f, cx: v, cy: S } = e, D = u.transformPoint(new DOMPoint(l, f)), x = u.transformPoint(new DOMPoint(v, S)), P = r.createRadialGradient(D.x, D.y, 0, x.x, x.y, e.r * ((u.a + u.d) / 2)); for (const I of e.stops) P.addColorStop(I.offset, Vu(I.rgb_color, I.opacity * n, o)); return P; } function sv(r, e, n, o) { const u = hf(o.transform).preMultiplySelf(e), l = o.clip_path_idx != null ? n.clip_paths[o.clip_path_idx] : null; l && sv(r, u, n, l); const f = new Path2D(); let v; function S(D, x) { if (D.path) { const P = D.path; f.addPath(ov(P), x), P.rule === im.PATH_RULE_EVEN_ODD && (v = "evenodd"); } else if (D.group) { const P = D.group.transform ? hf(D.group.transform).preMultiplySelf(x) : x; for (const I of D.group.children) S(I, P); } } for (const D of o.children) S(D, u); r.clip(f, v); } function rv(r, e, n, o, u) { if (o.children.length === 0) return; const l = o.mask_idx != null ? n.masks[o.mask_idx] : null; l && rv(r, e, n, l, u); const f = r.canvas.width, v = r.canvas.height, S = lg(f, v), D = S.getContext("2d"), x = o.width, P = o.height, I = o.left, M = o.top, C = new Path2D(), k = new Path2D(); k.rect(I, M, x, P), C.addPath(k, e), D.clip(C); for (const q of o.children) Qx(D, e, n, q, u); const V = D.getImageData(0, 0, f, v), U = V.data; if (o.mask_type === Yx.MASK_TYPE_LUMINANCE) for (let q = 0; q < U.length; q += 4) U[q + 3] = U[q + 3] / 255 * (0.2126 * U[q] + 0.7152 * U[q + 1] + 0.0722 * U[q + 2]); D.putImageData(V, 0, 0), r.globalCompositeOperation = "destination-in", r.drawImage(S, 0, 0); } function hf(r) { return r ? new DOMMatrix([r.sx, r.ky, r.kx, r.sy, r.tx, r.ty]) : new DOMMatrix(); } function ov(r) { const e = new Path2D(), n = r.step; let o = r.diffs[0] * n, u = r.diffs[1] * n; e.moveTo(o, u); for (let l = 0, f = 2; l < r.commands.length; l++) switch (r.commands[l]) { case Nu.PATH_COMMAND_MOVE: o += r.diffs[f++] * n, u += r.diffs[f++] * n, e.moveTo(o, u); break; case Nu.PATH_COMMAND_LINE: o += r.diffs[f++] * n, u += r.diffs[f++] * n, e.lineTo(o, u); break; case Nu.PATH_COMMAND_QUAD: { const v = o + r.diffs[f++] * n, S = u + r.diffs[f++] * n; o = v + r.diffs[f++] * n, u = S + r.diffs[f++] * n, e.quadraticCurveTo(v, S, o, u); break; } case Nu.PATH_COMMAND_CUBIC: { const v = o + r.diffs[f++] * n, S = u + r.diffs[f++] * n, D = v + r.diffs[f++] * n, x = S + r.diffs[f++] * n; o = D + r.diffs[f++] * n, u = x + r.diffs[f++] * n, e.bezierCurveTo(v, S, D, x, o, u); break; } case Nu.PATH_COMMAND_CLOSE: e.closePath(); } return e; } class hg { constructor(e) { this.capacity = e, this.cache = /* @__PURE__ */ new Map(); } get(e) { if (!this.cache.has(e)) return; const n = this.cache.get(e); return this.cache.delete(e), this.cache.set(e, n), n; } put(e, n) { this.cache.has(e) ? this.cache.delete(e) : this.cache.size === this.capacity && this.cache.delete(this.cache.keys().next().value), this.cache.set(e, n); } delete(e) { this.cache.delete(e); } } class ug { constructor() { this.cacheMap = /* @__PURE__ */ new Map(), this.cacheDependenciesMap = /* @__PURE__ */ new Map(); } static _getImage(e) { return new _r(e, e.data); } getFromCache(e, n, o) { return this.cacheMap.has(o) || this.cacheMap.set(o, new hg(150)), this.cacheMap.get(o).get(Io(e.serialize(), n)); } setInCache(e, n, o, u) { this.cacheDependenciesMap.has(u) || this.cacheDependenciesMap.set(u, /* @__PURE__ */ new Map()), this.cacheMap.has(u) || this.cacheMap.set(u, new hg(150)); const l = this.cacheDependenciesMap.get(u); l.get(Io(e.id, o)) || l.set(Io(e.id, o), /* @__PURE__ */ new Set()); const f = this.cacheMap.get(u), v = e.serialize(); l.get(Io(e.id, o)).add(v), f.put(Io(e.serialize(), o), n); } removeImagesFromCacheByIds(e, n, o = "") { if (!this.cacheMap.has(o) || !this.cacheDependenciesMap.has(o)) return; const u = this.cacheMap.get(o), l = this.cacheDependenciesMap.get(o); for (const f of e) if (l.has(Io(f, n))) { for (const v of l.get(Io(f, n))) u.delete(v); l.delete(Io(f, n)); } } rasterize(e, n, o, u, l = L2) { const f = this.getFromCache(e, o, u); if (f) return f.clone(); const v = l(n.icon, e.options), S = ug._getImage(v); return this.setInCache(e, S, o, u), S.clone(); } } class av { constructor(e) { this.size = e, this.minimums = [], this.maximums = [], this.leaves = []; } getElevation(e, n) { const o = this.toIdx(e, n); return { min: this.minimums[o], max: this.maximums[o] }; } isLeaf(e, n) { return this.leaves[this.toIdx(e, n)]; } toIdx(e, n) { return n * this.size + e; } } function lv(r, e, n, o) { let u = 0, l = Number.MAX_VALUE; for (let f = 0; f < 3; f++) if (Math.abs(o[f]) < 1e-15) { if (n[f] < r[f] || n[f] > e[f]) return null; } else { const v = 1 / o[f]; let S = (r[f] - n[f]) * v, D = (e[f] - n[f]) * v; if (S > D) { const x = S; S = D, D = x; } if (S > u && (u = S), D < l && (l = D), u > l) return null; } return u; } function cv(r, e, n, o, u, l, f, v, S, D, x) { const P = o - r, I = u - e, M = l - n, C = f - r, k = v - e, V = S - n, U = x[1] * V - x[2] * k, q = x[2] * C - x[0] * V, $ = x[0] * k - x[1] * C, H = P * U + I * q + M * $; if (Math.abs(H) < 1e-15) return null; const K = 1 / H, Q = D[0] - r, ie = D[1] - e, fe = D[2] - n, de = (Q * U + ie * q + fe * $) * K; if (de < 0 || de > 1) return null; const ue = ie * M - fe * I, Se = fe * P - Q * M, me = Q * I - ie * P, Ee = (x[0] * ue + x[1] * Se + x[2] * me) * K; return Ee < 0 || de + Ee > 1 ? null : (C * ue + k * Se + V * me) * K; } function hv(r, e, n) { return (r - e) / (n - e); } function uv(r, e, n, o, u, l, f, v, S) { const D = 1 << n, x = l - o, P = f - u, I = (r + 1) / D * x + o, M = (e + 0) / D * P + u, C = (e + 1) / D * P + u; v[0] = (r + 0) / D * x + o, v[1] = M, S[0] = I, S[1] = C; } class dv { constructor(e) { if (this.maximums = [], this.minimums = [], this.leaves = [], this.childOffsets = [], this.nodeCount = 0, this.dem = e, this._siblingOffset = [[0, 0], [1, 0], [0, 1], [1, 1]], !this.dem) return; const n = function(l) { const f = Math.ceil(Math.log2(l.dim / 8)), v = []; let S = Math.ceil(Math.pow(2, f)); const D = 1 / S, x = (M, C, k, V, U) => { const q = V ? 1 : 0, $ = (M + 1) * k - q, H = C * k, K = (C + 1) * k - q; U[0] = M * k, U[1] = H, U[2] = $, U[3] = K; }; let P = new av(S); const I = []; for (let M = 0; M < S * S; M++) { x(M % S, Math.floor(M / S), D, !1, I); const C = Tc(I[0], I[1], l), k = Tc(I[2], I[1], l), V = Tc(I[2], I[3], l), U = Tc(I[0], I[3], l); P.minimums.push(Math.min(C, k, V, U)), P.maximums.push(Math.max(C, k, V, U)), P.leaves.push(1); } for (v.push(P), S /= 2; S >= 1; S /= 2) { const M = v[v.length - 1]; P = new av(S); for (let C = 0; C < S * S; C++) { x(C % S, Math.floor(C / S), 2, !0, I); const k = M.getElevation(I[0], I[1]), V = M.getElevation(I[2], I[1]), U = M.getElevation(I[2], I[3]), q = M.getElevation(I[0], I[3]), $ = M.isLeaf(I[0], I[1]), H = M.isLeaf(I[2], I[1]), K = M.isLeaf(I[2], I[3]), Q = M.isLeaf(I[0], I[3]), ie = Math.min(k.min, V.min, U.min, q.min), fe = Math.max(k.max, V.max, U.max, q.max), de = $ && H && K && Q; P.maximums.push(fe), P.minimums.push(ie), P.leaves.push(fe - ie <= 5 && de ? 1 : 0); } v.push(P); } return v; }(this.dem), o = n.length - 1, u = n[o]; this._addNode(u.minimums[0], u.maximums[0], u.leaves[0]), this._construct(n, 0, 0, o, 0); } raycastRoot(e, n, o, u, l, f, v = 1) { return lv([e, n, -100], [o, u, this.maximums[0] * v], l, f); } raycast(e, n, o, u, l, f, v = 1) { if (!this.nodeCount) return null; const S = this.raycastRoot(e, n, o, u, l, f, v); if (S == null) return null; const D = [], x = [], P = [], I = [], M = [{ idx: 0, t: S, nodex: 0, nodey: 0, depth: 0 }]; for (; M.length > 0; ) { const { idx: C, t: k, nodex: V, nodey: U, depth: q } = M.pop(); if (this.leaves[C]) { uv(V, U, q, e, n, o, u, P, I); const H = 1 << q, K = (V + 0) / H, Q = (V + 1) / H, ie = (U + 0) / H, fe = (U + 1) / H, de = Tc(K, ie, this.dem) * v, ue = Tc(Q, ie, this.dem) * v, Se = Tc(Q, fe, this.dem) * v, me = Tc(K, fe, this.dem) * v, Ee = cv(P[0], P[1], de, I[0], P[1], ue, I[0], I[1], Se, l, f), ze = cv(I[0], I[1], Se, P[0], I[1], me, P[0], P[1], de, l, f), Ie = Math.min(Ee !== null ? Ee : Number.MAX_VALUE, ze !== null ? ze : Number.MAX_VALUE); if (Ie !== Number.MAX_VALUE) return Ie; { const Re = De.vec3.scaleAndAdd([], l, f, k); if (fv(de, ue, me, Se, hv(Re[0], P[0], I[0]), hv(Re[1], P[1], I[1])) >= Re[2]) return k; } continue; } let $ = 0; for (let H = 0; H < this._siblingOffset.length; H++) { uv((V << 1) + this._siblingOffset[H][0], (U << 1) + this._siblingOffset[H][1], q + 1, e, n, o, u, P, I), P[2] = -100, I[2] = this.maximums[this.childOffsets[C] + H] * v; const K = lv(P, I, l, f); if (K != null) { const Q = K; D[H] = Q; let ie = !1; for (let fe = 0; fe < $ && !ie; fe++) Q >= D[x[fe]] && (x.splice(fe, 0, H), ie = !0); ie || (x[$] = H), $++; } } for (let H = 0; H < $; H++) { const K = x[H]; M.push({ idx: this.childOffsets[C] + K, t: D[K], nodex: (V << 1) + this._siblingOffset[K][0], nodey: (U << 1) + this._siblingOffset[K][1], depth: q + 1 }); } } return null; } _addNode(e, n, o) { return this.minimums.push(e), this.maximums.push(n), this.leaves.push(o), this.childOffsets.push(0), this.nodeCount++; } _construct(e, n, o, u, l) { if (e[u].isLeaf(n, o) === 1) return; this.childOffsets[l] || (this.childOffsets[l] = this.nodeCount); const f = u - 1, v = e[f]; let S = 0, D = 0; for (let x = 0; x < this._siblingOffset.length; x++) { const P = 2 * n + this._siblingOffset[x][0], I = 2 * o + this._siblingOffset[x][1], M = v.getElevation(P, I), C = v.isLeaf(P, I), k = this._addNode(M.min, M.max, C); C && (S |= 1 << x), D || (D = k); } for (let x = 0; x < this._siblingOffset.length; x++) S & 1 << x || this._construct(e, 2 * n + this._siblingOffset[x][0], 2 * o + this._siblingOffset[x][1], f, D + x); } } function fv(r, e, n, o, u, l) { return ei(ei(r, n, l), ei(e, o, l), u); } function Tc(r, e, n) { const o = n.dim, u = si(r * o - 0.5, 0, o - 1), l = si(e * o - 0.5, 0, o - 1), f = Math.floor(u), v = Math.floor(l), S = Math.min(f + 1, o - 1), D = Math.min(v + 1, o - 1); return fv(n.get(f, v), n.get(S, v), n.get(f, D), n.get(S, D), u - f, l - v); } const z2 = { mapbox: [6553.6, 25.6, 0.1, 1e4], terrarium: [256, 1, 1 / 256, 32768] }; function D2(r, e, n) { return (256 * r * 256 + 256 * e + n) / 10 - 1e4; } function k2(r, e, n) { return 256 * r + e + n / 256 - 32768; } class am { get tree() { return this._tree || this._buildQuadTree(), this._tree; } constructor(e, n, o, u = !1) { if (this.uid = e, n.height !== n.width) throw new RangeError("DEM tiles must be square"); if (o && o !== "mapbox" && o !== "terrarium") return void mi(`"${o}" is not a valid encoding type. Valid types include "mapbox" and "terrarium".`); this.stride = n.height; const l = this.dim = n.height - 2, f = new Uint32Array(n.data.buffer); if (this.pixels = new Uint8Array(n.data.buffer), this.floatView = new Float32Array(n.data.buffer), this.borderReady = u, this._modifiedForSources = {}, !u) { for (let S = 0; S < l; S++) f[this._idx(-1, S)] = f[this._idx(0, S)], f[this._idx(l, S)] = f[this._idx(l - 1, S)], f[this._idx(S, -1)] = f[this._idx(S, 0)], f[this._idx(S, l)] = f[this._idx(S, l - 1)]; f[this._idx(-1, -1)] = f[this._idx(0, 0)], f[this._idx(l, -1)] = f[this._idx(l - 1, 0)], f[this._idx(-1, l)] = f[this._idx(0, l - 1)], f[this._idx(l, l)] = f[this._idx(l - 1, l - 1)]; } const v = o === "terrarium" ? k2 : D2; for (let S = 0; S < f.length; ++S) { const D = 4 * S; this.floatView[S] = v(this.pixels[D], this.pixels[D + 1], this.pixels[D + 2]); } this._timestamp = Ct.now(); } _buildQuadTree() { this._tree = new dv(this); } get(e, n, o = !1) { o && (e = si(e, -1, this.dim), n = si(n, -1, this.dim)); const u = this._idx(e, n); return this.floatView[u]; } set(e, n, o) { const u = this._idx(e, n), l = this.floatView[u]; return this.floatView[u] = o, o - l; } static getUnpackVector(e) { return z2[e]; } _idx(e, n) { if (e < -1 || e >= this.dim + 1 || n < -1 || n >= this.dim + 1) throw new RangeError("out of range source coordinates for DEM data"); return (n + 1) * this.stride + (e + 1); } static pack(e, n) { const o = [0, 0, 0, 0], u = am.getUnpackVector(n); let l = Math.floor((e + u[3]) / u[2]); return o[2] = l % 256, l = Math.floor(l / 256), o[1] = l % 256, l = Math.floor(l / 256), o[0] = l, o; } getPixels() { return new zy({ width: this.stride, height: this.stride }, this.pixels); } backfillBorder(e, n, o) { if (this.dim !== e.dim) throw new Error("dem dimension mismatch"); let u = n * this.dim, l = n * this.dim + this.dim, f = o * this.dim, v = o * this.dim + this.dim; switch (n) { case -1: u = l - 1; break; case 1: l = u + 1; } switch (o) { case -1: f = v - 1; break; case 1: v = f + 1; } const S = -n * this.dim, D = -o * this.dim; for (let x = f; x < v; x++) for (let P = u; P < l; P++) { const I = 4 * this._idx(P, x), M = 4 * this._idx(P + S, x + D); this.pixels[I + 0] = e.pixels[M + 0], this.pixels[I + 1] = e.pixels[M + 1], this.pixels[I + 2] = e.pixels[M + 2], this.pixels[I + 3] = e.pixels[M + 3]; } } onDeserialize() { this._tree && (this._tree.dem = this); } } function R2(r, e, n) { r === 1 ? e.headerLength = n.readFixed32() : r === 2 ? e.x = n.readVarint() : r === 3 ? e.y = n.readVarint() : r === 4 ? e.z = n.readVarint() : r === 5 && e.layers.push(function(o, u) { return o.readFields(V2, { version: 0, name: "", units: "", tileSize: 0, buffer: 0, pixelFormat: 0, dataIndex: [] }, u); }(n, n.readVarint() + n.pos)); } function O2(r, e, n) { r === 1 ? (e.delta_filter = function(o, u) { return o.readFields(F2, { blockSize: 0 }, u); }(n, n.readVarint() + n.pos), e.filter = "delta_filter") : r === 2 ? (n.readVarint(), e.filter = "zigzag_filter") : r === 3 ? (n.readVarint(), e.filter = "bitshuffle_filter") : r === 4 && (n.readVarint(), e.filter = "byteshuffle_filter"); } function F2(r, e, n) { r === 1 && (e.blockSize = n.readVarint()); } function B2(r, e, n) { r === 1 ? (n.readVarint(), e.codec = "gzip_data") : r === 2 ? (n.readVarint(), e.codec = "jpeg_image") : r === 3 ? (n.readVarint(), e.codec = "webp_image") : r === 4 && (n.readVarint(), e.codec = "png_image"); } function N2(r, e, n) { let o = 0, u = 0; r === 1 ? e.firstByte = n.readFixed64() : r === 2 ? e.lastByte = n.readFixed64() : r === 3 ? e.filters.push(function(l, f) { return l.readFields(O2, {}, f); }(n, n.readVarint() + n.pos)) : r === 4 ? e.codec = function(l, f) { return l.readFields(B2, {}, f); }(n, n.readVarint() + n.pos) : r === 5 ? u = n.readFloat() : r === 6 ? o = n.readFloat() : r === 7 ? e.bands.push(n.readString()) : r === 8 ? e.offset = n.readDouble() : r === 9 && (e.scale = n.readDouble()), e.offset === 0 && (e.offset = u), e.scale === 0 && (e.scale = o); } function V2(r, e, n) { r === 1 ? e.version = n.readVarint() : r === 2 ? e.name = n.readString() : r === 3 ? e.units = n.readString() : r === 4 ? e.tileSize = n.readVarint() : r === 5 ? e.buffer = n.readVarint() : r === 6 ? e.pixelFormat = n.readVarint() : r === 7 && e.dataIndex.push(function(o, u) { return o.readFields(N2, { firstByte: 0, lastByte: 0, filters: [], codec: null, offset: 0, scale: 0, bands: [] }, u); }(n, n.readVarint() + n.pos)); } function U2(r, e, n) { if (r === 2) (function(o, u, l) { o.readFields(j2, l, u); })(n, n.readVarint() + n.pos, e); else if (r === 3) throw new Error("Not implemented"); } function j2(r, e, n) { if (r === 1) { let o = 0; const u = n.readVarint() + n.pos; for (; n.pos < u; ) e[o++] = n.readVarint(); } } function G2(r, e) { if (e.length !== 4) throw new Error(`Expected data of dimension 4 but got ${e.length}.`); let n = e[3]; for (let o = 2; o >= 1; o--) { const u = o === 1 ? 1 : 0, l = o === 2 ? 1 : 0; for (let f = 0; f < e[0]; f++) { const v = e[1] * f; for (let S = u; S < e[1]; S++) { const D = e[2] * (S + v); for (let x = l; x < e[2]; x++) { const P = e[3] * (x + D); for (let I = 0; I < e[3]; I++) { const M = P + I; r[M] += r[M - n]; } } } } n *= e[o]; } return r; } function Z2(r) { for (let e = 0, n = r.length; e < n; e++) r[e] = r[e] >>> 1 ^ -(1 & r[e]); return r; } function H2(r, e) { switch (e) { case "uint32": return r; case "uint16": for (let n = 0; n < r.length; n += 2) { const o = r[n], u = r[n + 1]; r[n] = (240 & o) >> 4 | (61440 & o) >> 8 | (240 & u) << 4 | 61440 & u, r[n + 1] = 15 & o | (3840 & o) >> 4 | (15 & u) << 8 | (3840 & u) << 4; } return r; case "uint8": for (let n = 0; n < r.length; n += 4) { const o = r[n], u = r[n + 1], l = r[n + 2], f = r[n + 3]; r[n + 0] = (192 & o) >> 6 | (192 & u) >> 4 | (192 & l) >> 2 | 192 & f, r[n + 1] = (48 & o) >> 4 | (48 & u) >> 2 | 48 & l | (48 & f) << 2, r[n + 2] = (12 & o) >> 2 | 12 & u | (12 & l) << 2 | (12 & f) << 4, r[n + 3] = 3 & o | (3 & u) << 2 | (3 & l) << 4 | (3 & f) << 6; } return r; default: throw new Error(`Invalid pixel format, "${e}"`); } } Ft(am, "DEMData"), Ft(dv, "DemMinMaxQuadTree", { omit: ["dem"] }); var Oo = Uint8Array, uf = Uint16Array, q2 = Int32Array, pv = new Oo([0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 0, 0, 0]), mv = new Oo([0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13, 0, 0]), W2 = new Oo([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]), _v = function(r, e) { for (var n = new uf(31), o = 0; o < 31; ++o) n[o] = e += 1 << r[o - 1]; var u = new q2(n[30]); for (o = 1; o < 30; ++o) for (var l = n[o]; l < n[o + 1]; ++l) u[l] = l - n[o] << 5 | o; return { b: n, r: u }; }, gv = _v(pv, 2), yv = gv.b, $2 = gv.r; yv[28] = 258, $2[258] = 28; for (var X2 = _v(mv, 0).b, xv = new uf(32768), os = 0; os < 32768; ++os) { var Uu = (43690 & os) >> 1 | (21845 & os) << 1; xv[os] = ((65280 & (Uu = (61680 & (Uu = (52428 & Uu) >> 2 | (13107 & Uu) << 2)) >> 4 | (3855 & Uu) << 4)) >> 8 | (255 & Uu) << 8) >> 1; } var df = function(r, e, n) { for (var o = r.length, u = 0, l = new uf(e); u < o; ++u) r[u] && ++l[r[u] - 1]; var f, v = new uf(e); for (u = 1; u < e; ++u) v[u] = v[u - 1] + l[u - 1] << 1; f = new uf(1 << e); var S = 15 - e; for (u = 0; u < o; ++u) if (r[u]) for (var D = u << 4 | r[u], x = e - r[u], P = v[r[u] - 1]++ << x, I = P | (1 << x) - 1; P <= I; ++P) f[xv[P] >> S] = D; return f; }, ff = new Oo(288); for (os = 0; os < 144; ++os) ff[os] = 8; for (os = 144; os < 256; ++os) ff[os] = 9; for (os = 256; os < 280; ++os) ff[os] = 7; for (os = 280; os < 288; ++os) ff[os] = 8; var vv = new Oo(32); for (os = 0; os < 32; ++os) vv[os] = 5; var Y2 = df(ff, 9), K2 = df(vv, 5), dg = function(r) { for (var e = r[0], n = 1; n < r.length; ++n) r[n] > e && (e = r[n]); return e; }, Pa = function(r, e, n) { var o = e / 8 | 0; return (r[o] | r[o + 1] << 8) >> (7 & e) & n; }, fg = function(r, e) { var n = e / 8 | 0; return (r[n] | r[n + 1] << 8 | r[n + 2] << 16) >> (7 & e); }, J2 = ["unexpected EOF", "invalid block type", "invalid length/literal", "invalid distance", "stream finished", "no stream handler", , "no callback", "invalid UTF-8 data", "extra field too long", "date not in range 1980-2099", "filename too long", "stream finishing", "invalid zip data"], Aa = function(r, e, n) { var o = new Error(e || J2[r]); if (o.code = r, Error.captureStackTrace && Error.captureStackTrace(o, Aa), !n) throw o; return o; }, Q2 = new Oo(0), eM = typeof TextDecoder < "u" && new TextDecoder(); try { eM.decode(Q2, { stream: !0 }); } catch { } const tM = { gzip_data: "gzip" }; class na extends Error { constructor(e) { super(e), this.name = "MRTError"; } } const iM = { 0: "uint32", 1: "uint32", 2: "uint16", 3: "uint8" }, bv = { uint32: 1, uint16: 2, uint8: 4 }, nM = { uint32: Uint32Array, uint16: Uint16Array, uint8: Uint8Array }; let pg; class mg { constructor(e = 5) { this.x = NaN, this.y = NaN, this.z = NaN, this.layers = {}, this._cacheSize = e; } getLayer(e) { const n = this.layers[e]; if (!n) throw new na(`Layer '${e}' not found`); return n; } getHeaderLength(e) { const n = new Uint8Array(e), o = new DataView(e); if (n[0] !== 13) throw new na("File is not a valid MRT."); return o.getUint32(1, !0); } parseHeader(e) { const n = new Uint8Array(e), o = this.getHeaderLength(e); if (n.length < o) throw new na(`Expected header with length >= ${o} but got buffer of length ${n.length}`); const u = function(l, f) { return l.readFields(R2, { headerLength: 0, x: 0, y: 0, z: 0, layers: [] }, void 0); }(new pg(n.subarray(0, o))); if (!isNaN(this.x) && (this.x !== u.x || this.y !== u.y || this.z !== u.z)) throw new na(`Invalid attempt to parse header ${u.z}/${u.x}/${u.y} for tile ${this.z}/${this.x}/${this.y}`); this.x = u.x, this.y = u.y, this.z = u.z; for (const l of u.layers) this.layers[l.name] = new sM(l, { cacheSize: this._cacheSize }); return this; } createDecodingTask(e) { const n = [], o = this.getLayer(e.layerName); for (let u of e.blockIndices) { const l = o.dataIndex[u], f = l.firstByte - e.firstByte, v = l.lastByte - e.firstByte; if (o._blocksInProgress.has(u)) continue; const S = { layerName: o.name, firstByte: f, lastByte: v, pixelFormat: o.pixelFormat, blockIndex: u, blockShape: [l.bands.length].concat(o.bandShape), buffer: o.buffer, codec: l.codec.codec, filters: l.filters.map((D) => D.filter) }; o._blocksInProgress.add(u), n.push(S); } return new wv(n, () => { n.forEach((u) => o._blocksInProgress.delete(u.blockIndex)); }, (u, l) => { if (n.forEach((f) => o._blocksInProgress.delete(f.blockIndex)), u) throw u; l.forEach((f) => { this.getLayer(f.layerName).processDecodedData(f); }); }); } } class sM { constructor({ version: e, name: n, units: o, tileSize: u, pixelFormat: l, buffer: f, dataIndex: v }, S) { if (this.version = e, this.version !== 1) throw new na(`Cannot parse raster layer encoded with MRT version ${e}`); this.name = n, this.units = o, this.tileSize = u, this.buffer = f, this.pixelFormat = iM[l], this.dataIndex = v, this.bandShape = [u + 2 * f, u + 2 * f, bv[this.pixelFormat]], this._decodedBlocks = new hg(S ? S.cacheSize : 5), this._blocksInProgress = /* @__PURE__ */ new Set(); } get dimension() { return bv[this.pixelFormat]; } get cacheSize() { return this._decodedBlocks.capacity; } getBandList() { return this.dataIndex.map(({ bands: e }) => e).flat(); } processDecodedData(e) { const n = e.blockIndex.toString(); this._decodedBlocks.get(n) || this._decodedBlocks.put(n, e.data); } getBlockForBand(e) { let n = 0; switch (typeof e) { case "string": for (const [o, u] of this.dataIndex.entries()) { for (const [l, f] of u.bands.entries()) if (f === e) return { bandIndex: n + l, blockIndex: o, blockBandIndex: l }; n += u.bands.length; } break; case "number": for (const [o, u] of this.dataIndex.entries()) { if (e >= n && e < n + u.bands.length) return { bandIndex: e, blockIndex: o, blockBandIndex: e - n }; n += u.bands.length; } break; default: throw new na(`Invalid band \`${JSON.stringify(e)}\`. Expected string or integer.`); } throw new na(`Band not found: ${JSON.stringify(e)}`); } getDataRange(e) { let n = 1 / 0, o = -1 / 0; const u = [], l = /* @__PURE__ */ new Set(); for (const f of e) { const { blockIndex: v } = this.getBlockForBand(f); if (v < 0) throw new na(`Invalid band: ${JSON.stringify(f)}`); const S = this.dataIndex[v]; u.includes(v) || u.push(v), l.add(v), n = Math.min(n, S.firstByte), o = Math.max(o, S.lastByte); } if (l.size > this.cacheSize) throw new na(`Number of blocks to decode (${l.size}) exceeds cache size (${this.cacheSize}).`); return { layerName: this.name, firstByte: n, lastByte: o, blockIndices: u }; } hasBand(e) { const { blockIndex: n } = this.getBlockForBand(e); return n >= 0; } hasDataForBand(e) { const { blockIndex: n } = this.getBlockForBand(e); return n >= 0 && !!this._decodedBlocks.get(n.toString()); } getBandView(e) { const { blockIndex: n, blockBandIndex: o } = this.getBlockForBand(e), u = this._decodedBlocks.get(n.toString()); if (!u) throw new na(`Data for band ${JSON.stringify(e)} of layer "${this.name}" not decoded.`); const l = this.dataIndex[n], f = this.bandShape.reduce((D, x) => D * x, 1), v = o * f, S = u.subarray(v, v + f); return { data: S, bytes: new Uint8Array(S.buffer).subarray(S.byteOffset, S.byteOffset + S.byteLength), tileSize: this.tileSize, buffer: this.buffer, pixelFormat: this.pixelFormat, dimension: this.dimension, offset: l.offset, scale: l.scale }; } } mg.setPbf = function(r) { pg = r; }; class wv { constructor(e, n, o) { this.tasks = e, this._onCancel = n, this._onComplete = o, this._finalized = !1; } cancel() { this._finalized || (this._onCancel(), this._finalized = !0); } complete(e, n) { this._finalized || (this._onComplete(e, n), this._finalized = !0); } } mg.performDecoding = function(r, e) { const n = new Uint8Array(r); return Promise.all(e.tasks.map((o) => { const { layerName: u, firstByte: l, lastByte: f, pixelFormat: v, blockShape: S, blockIndex: D, filters: x, codec: P } = o, I = n.subarray(l, f + 1), M = new Uint32Array(S[0] * S[1] * S[2]); let C; if (P !== "gzip_data") throw new na(`Unhandled codec: ${P}`); return C = function(k, V) { if (!globalThis.DecompressionStream && V === "gzip_data") return Promise.resolve(((H = function(ie) { ie[0] == 31 && ie[1] == 139 && ie[2] == 8 || Aa(6, "invalid gzip data"); var fe = ie[3], de = 10; 4 & fe && (de += 2 + (ie[10] | ie[11] << 8)); for (var ue = (fe >> 3 & 1) + (fe >> 4 & 1); ue > 0; ue -= !ie[de++]) ; return de + (2 & fe); }($ = k)) + 8 > $.length && Aa(6, "invalid gzip data"), function(ie, fe, de, ue) { var Se = ie.length; if (!Se || fe.f && !fe.l) return de || new Oo(0); var me = !de, Ee = me || fe.i != 2, ze = fe.i; me && (de = new Oo(3 * Se)); var Ie, Re, Ve = function(Dl) { var Ec = de.length; if (Dl > Ec) { var Pc = new Oo(Math.max(2 * Ec, Dl)); Pc.set(de), de = Pc; } }, Ue = fe.f || 0, Fe = fe.p || 0, et = fe.b || 0, dt = fe.l, tt = fe.d, Mt = fe.m, wt = fe.n, At = 8 * Se; do { if (!dt) { Ue = Pa(ie, Fe, 1); var rt = Pa(ie, Fe + 1, 3); if (Fe += 3, !rt) { var Ut = ie[(hi = 4 + ((Fe + 7) / 8 | 0)) - 4] | ie[hi - 3] << 8, St = hi + Ut; if (St > Se) { ze && Aa(0); break; } Ee && Ve(et + Ut), de.set(ie.subarray(hi, St), et), fe.b = et += Ut, fe.p = Fe = 8 * St, fe.f = Ue; continue; } if (rt == 1) dt = Y2, tt = K2, Mt = 9, wt = 5; else if (rt == 2) { var Nt = Pa(ie, Fe, 31) + 257, Qt = Pa(ie, Fe + 10, 15) + 4, pi = Nt + Pa(ie, Fe + 5, 31) + 1; Fe += 14; for (var gi = new Oo(pi), Ai = new Oo(19), yi = 0; yi < Qt; ++yi) Ai[W2[yi]] = Pa(ie, Fe + 3 * yi, 7); Fe += 3 * Qt; var Ii = dg(Ai), fn = (1 << Ii) - 1, rn = df(Ai, Ii); for (yi = 0; yi < pi; ) { var hi, on = rn[Pa(ie, Fe, fn)]; if (Fe += 15 & on, (hi = on >> 4) < 16) gi[yi++] = hi; else { var Qi = 0, pn = 0; for (hi == 16 ? (pn = 3 + Pa(ie, Fe, 3), Fe += 2, Qi = gi[yi - 1]) : hi == 17 ? (pn = 3 + Pa(ie, Fe, 7), Fe += 3) : hi == 18 && (pn = 11 + Pa(ie, Fe, 127), Fe += 7); pn--; ) gi[yi++] = Qi; } } var as = gi.subarray(0, Nt), ls = gi.subarray(Nt); Mt = dg(as), wt = dg(ls), dt = df(as, Mt), tt = df(ls, wt); } else Aa(1); if (Fe > At) { ze && Aa(0); break; } } Ee && Ve(et + 131072); for (var Kn = (1 << Mt) - 1, Vr = (1 << wt) - 1, Sn = Fe; ; Sn = Fe) { var Ln = (Qi = dt[fg(ie, Fe) & Kn]) >> 4; if ((Fe += 15 & Qi) > At) { ze && Aa(0); break; } if (Qi || Aa(2), Ln < 256) de[et++] = Ln; else { if (Ln == 256) { Sn = Fe, dt = null; break; } var Tr = Ln - 254; Ln > 264 && (Tr = Pa(ie, Fe, (1 << (Ms = pv[yi = Ln - 257])) - 1) + yv[yi], Fe += Ms); var cs = tt[fg(ie, Fe) & Vr], to = cs >> 4; if (cs || Aa(3), Fe += 15 & cs, ls = X2[to], to > 3) { var Ms = mv[to]; ls += fg(ie, Fe) & (1 << Ms) - 1, Fe += Ms; } if (Fe > At) { ze && Aa(0); break; } Ee && Ve(et + 131072); var sl = et + Tr; if (et < ls) { var Mc = 0 - ls, Sc = Math.min(ls, sl); for (Mc + et < 0 && Aa(3); et < Sc; ++et) de[et] = (void 0)[Mc + et]; } for (; et < sl; ++et) de[et] = de[et - ls]; } } fe.l = dt, fe.p = Sn, fe.b = et, fe.f = Ue, dt && (Ue = 1, fe.m = Mt, fe.d = tt, fe.n = wt); } while (!Ue); return et != de.length && me ? (Ie = de, ((Re = et) == null || Re > Ie.length) && (Re = Ie.length), new Oo(Ie.subarray(0, Re))) : de.subarray(0, et); }($.subarray(H, -8), { i: 2 }, new Oo(((U = $)[(q = U.length) - 4] | U[q - 3] << 8 | U[q - 2] << 16 | U[q - 1] << 24) >>> 0)))); var U, q, $, H; const K = tM[V]; if (!K) throw new Error(`Unhandled codec: ${V}`); const Q = new globalThis.DecompressionStream(K); return new Response(new Blob([k]).stream().pipeThrough(Q)).arrayBuffer().then((ie) => new Uint8Array(ie)); }(I, P).then((k) => (function(V, U) { V.readFields(U2, U); }(new pg(k), M), new nM[v](M.buffer))), C.then((k) => { for (let V = x.length - 1; V >= 0; V--) switch (x[V]) { case "delta_filter": G2(k, S); break; case "zigzag_filter": Z2(k); break; case "bitshuffle_filter": H2(k, v); break; default: throw new na(`Unhandled filter "${x[V]}"`); } return { layerName: u, blockIndex: D, data: k }; }).catch((k) => { throw k; }); })); }, Ft(wv, "MRTDecodingBatch", { omit: ["_onCancel", "_onComplete"] }); let pf, _g, Ca, ju, gg, Gu = null; function Tv() { return Jn() && self.worker && self.worker.dracoUrl ? self.worker.dracoUrl : _g || ge.DRACO_URL; } function Mv() { if (Jn() && self.worker && self.worker.meshoptUrl) return self.worker.meshoptUrl; if (ju) return ju; const r = new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 4, 1, 96, 0, 0, 3, 3, 2, 0, 0, 5, 3, 1, 0, 1, 12, 1, 0, 10, 22, 2, 12, 0, 65, 0, 65, 0, 65, 0, 252, 10, 0, 0, 11, 7, 0, 65, 0, 253, 15, 26, 11]); if (typeof WebAssembly != "object") throw new Error("WebAssembly not supported, cannot instantiate meshoptimizer"); return ju = WebAssembly.validate(r) ? ge.MESHOPT_SIMD_URL : ge.MESHOPT_URL, ju; } const lm = { 5120: Int8Array, 5121: Uint8Array, 5122: Int16Array, 5123: Uint16Array, 5125: Uint32Array, 5126: Float32Array }, rM = { 5120: "DT_INT8", 5121: "DT_UINT8", 5122: "DT_INT16", 5123: "DT_UINT16", 5125: "DT_UINT32", 5126: "DT_FLOAT32" }, mf = { SCALAR: 1, VEC2: 2, VEC3: 3, VEC4: 4, MAT2: 4, MAT3: 9, MAT4: 16 }; function Sv(r, e, n) { const o = n.json.bufferViews.length, u = n.buffers.length; e.bufferView = o, n.json.bufferViews[o] = { buffer: u, byteLength: r.byteLength }, n.buffers[u] = r; } const yg = "KHR_draco_mesh_compression"; function oM(r, e) { const n = r.extensions && r.extensions[yg]; if (!n) return; const o = new Ca.Decoder(), u = Cv(e, n.bufferView), l = new Ca.Mesh(); if (!o.DecodeArrayToMesh(u, u.byteLength, l)) throw new Error("Failed to decode Draco mesh"); const f = e.json.accessors[r.indices], v = lm[f.componentType], S = f.count * v.BYTES_PER_ELEMENT, D = Ca._malloc(S); v === Uint16Array ? o.GetTrianglesUInt16Array(l, S, D) : o.GetTrianglesUInt32Array(l, S, D), Sv(Ca.memory.buffer.slice(D, D + S), f, e), Ca._free(D); for (const x of Object.keys(n.attributes)) { const P = o.GetAttributeByUniqueId(l, n.attributes[x]), I = e.json.accessors[r.attributes[x]], M = rM[I.componentType], C = I.count * mf[I.type] * lm[I.componentType].BYTES_PER_ELEMENT, k = Ca._malloc(C); o.GetAttributeDataArrayForAllPoints(l, P, Ca[M], C, k), Sv(Ca.memory.buffer.slice(k, k + C), I, e), Ca._free(k); } o.destroy(), l.destroy(), delete r.extensions[yg]; } const cm = "EXT_meshopt_compression"; function aM(r, e) { if (!r.extensions || !r.extensions[cm]) return; const n = r.extensions[cm], o = new Uint8Array(e.buffers[n.buffer], n.byteOffset || 0, n.byteLength || 0), u = new Uint8Array(n.count * n.byteStride); gg.decodeGltfBuffer(u, n.count, n.byteStride, o, n.mode, n.filter), r.buffer = e.buffers.length, r.byteOffset = 0, e.buffers[r.buffer] = u.buffer, delete r.extensions[cm]; } const Ev = 1179937895, Pv = new TextDecoder("utf8"); function Av(r, e) { return new URL(r, e).href; } function lM(r, e, n, o) { return fetch(Av(r.uri, o)).then((u) => u.arrayBuffer()).then((u) => { e.buffers[n] = u; }); } function Cv(r, e) { const n = r.json.bufferViews[e]; return new Uint8Array(r.buffers[n.buffer], n.byteOffset || 0, n.byteLength); } function cM(r, e, n, o) { if (r.uri) { const u = Av(r.uri, o); return fetch(u).then((l) => l.blob()).then((l) => createImageBitmap(l)).then((l) => { e.images[n] = l; }); } if (r.bufferView !== void 0) { const u = Cv(e, r.bufferView), l = new Blob([u], { type: r.mimeType }); return createImageBitmap(l).then((f) => { e.images[n] = f; }); } } function Iv(r, e = 0, n) { const o = { json: null, images: [], buffers: [] }; if (new Uint32Array(r, e, 1)[0] === Ev) { const x = new Uint32Array(r, e); let P = 2; const I = (x[P++] >> 2) - 3, M = x[P++] >> 2; if (P++, o.json = JSON.parse(Pv.decode(x.subarray(P, P + M))), P += M, P < I) { const C = x[P++]; P++; const k = e + (P << 2); o.buffers[0] = r.slice(k, k + C); } } else o.json = JSON.parse(Pv.decode(new Uint8Array(r, e))); const { buffers: u, images: l, meshes: f, extensionsUsed: v, bufferViews: S } = o.json; let D = Promise.resolve(); if (u) { const x = []; for (let P = 0; P < u.length; P++) { const I = u[P]; I.uri ? x.push(lM(I, o, P, n)) : o.buffers[P] || (o.buffers[P] = null); } D = Promise.all(x); } return D.then(() => { const x = [], P = v && v.includes(yg), I = v && v.includes(cm); if (P && x.push(function() { if (!Ca) return pf ?? (pf = function(M) { let C, k = null; function V() { C = new Uint8Array(k.buffer); } function U() { throw new Error("Unexpected Draco error."); } const q = { a: { a: U, d: function($, H, K) { return C.copyWithin($, H, H + K); }, c: function($) { const H = C.length, K = Math.max($ >>> 0, Math.ceil(1.2 * H)), Q = Math.ceil((K - H) / 65536); try { return k.grow(Q), V(), !0; } catch { return !1; } }, b: U } }; return (WebAssembly.instantiateStreaming ? WebAssembly.instantiateStreaming(M, q) : M.then(($) => $.arrayBuffer()).then(($) => WebAssembly.instantiate($, q))).then(($) => { const { Rb: H, Qb: K, P: Q, T: ie, X: fe, Ja: de, La: ue, Qa: Se, Va: me, Wa: Ee, eb: ze, jb: Ie, f: Re, e: Ve, yb: Ue, zb: Fe, Ab: et, Bb: dt, Db: tt, Gb: Mt } = $.instance.exports; k = Ve; const wt = (() => { let At = 0, rt = 0, Ut = 0, St = 0; return (Nt) => { Ut && (H(St), H(At), rt += Ut, Ut = At = 0), At || (rt += 128, At = K(rt)); const Qt = Nt.length + 7 & -8; let pi = At; Qt >= rt && (Ut = Qt, pi = St = K(Qt)); for (let gi = 0; gi < Nt.length; gi++) C[pi + gi] = Nt[gi]; return pi; }; })(); return V(), Re(), { memory: Ve, _free: H, _malloc: K, Mesh: class { constructor() { this.ptr = Q(); } destroy() { ie(this.ptr); } }, Decoder: class { constructor() { this.ptr = de(); } destroy() { Ie(this.ptr); } DecodeArrayToMesh(At, rt, Ut) { const St = wt(At), Nt = ue(this.ptr, St, rt, Ut.ptr); return !!fe(Nt); } GetAttributeByUniqueId(At, rt) { return { ptr: Se(this.ptr, At.ptr, rt) }; } GetTrianglesUInt16Array(At, rt, Ut) { me(this.ptr, At.ptr, rt, Ut); } GetTrianglesUInt32Array(At, rt, Ut) { Ee(this.ptr, At.ptr, rt, Ut); } GetAttributeDataArrayForAllPoints(At, rt, Ut, St, Nt) { ze(this.ptr, At.ptr, rt.ptr, Ut, St, Nt); } }, DT_INT8: Ue(), DT_UINT8: Fe(), DT_INT16: et(), DT_UINT16: dt(), DT_UINT32: tt(), DT_FLOAT32: Mt() }; }); }(fetch(Tv())), pf.then((M) => { Ca = M, pf = void 0; })); }()), I && x.push(function() { if (gg) return; const M = function(C) { let k; const V = WebAssembly.instantiateStreaming(C, {}).then(($) => { k = $.instance, k.exports.__wasm_call_ctors(); }), U = { NONE: "", OCTAHEDRAL: "meshopt_decodeFilterOct", QUATERNION: "meshopt_decodeFilterQuat", EXPONENTIAL: "meshopt_decodeFilterExp" }, q = { ATTRIBUTES: "meshopt_decodeVertexBuffer", TRIANGLES: "meshopt_decodeIndexBuffer", INDICES: "meshopt_decodeIndexSequence" }; return { ready: V, supported: !0, decodeGltfBuffer($, H, K, Q, ie, fe) { (function(de, ue, Se, me, Ee, ze, Ie) { const Re = de.exports.sbrk, Ve = me + 3 & -4, Ue = Re(Ve * Ee), Fe = Re(ze.length), et = new Uint8Array(de.exports.memory.buffer); et.set(ze, Fe); const dt = ue(Ue, me, Ee, Fe, ze.length); if (dt === 0 && Ie && Ie(Ue, Ve, Ee), Se.set(et.subarray(Ue, Ue + me * Ee)), Re(Ue - Re(0)), dt !== 0) throw new Error(`Malformed buffer data: ${dt}`); })(k, k.exports[q[ie]], $, H, K, Q, k.exports[U[fe]]); } }; }(fetch(Mv())); return M.ready.then(() => { gg = M; }); }()), l) for (let M = 0; M < l.length; M++) x.push(cM(l[M], o, M, n)); return (x.length ? Promise.all(x) : Promise.resolve()).then(() => { if (P && f) for (const { primitives: M } of f) for (const C of M) oM(C, o); if (I && f && S) for (const M of S) aM(M, o); return o; }); }); } function Mh(r, e) { const n = r.json.bufferViews[e.bufferView], o = lm[e.componentType]; return new o(r.buffers[n.buffer], (e.byteOffset || 0) + (n.byteOffset || 0), e.count * (n.byteStride && n.byteStride !== mf[e.type] * o.BYTES_PER_ELEMENT ? n.byteStride / o.BYTES_PER_ELEMENT : mf[e.type])); } function xg(r, e, n, o) { const u = lm[e.componentType], l = function(x) { switch (x) { case Int8Array: return 1 / 127; case Uint8Array: return 1 / 255; case Int16Array: return 1 / 32767; case Uint16Array: return 1 / 65535; default: return 1; } }(u), f = r.json.bufferViews[e.bufferView], v = f.byteStride ? f.byteStride / u.BYTES_PER_ELEMENT : mf[e.type], S = n.float32, D = S.length / n.capacity; for (let x = 0, P = 0; x < e.count * v; x += v, P += D) for (let I = 0; I < D; I++) S[P + I] = o[x + I] * l; n._trim(); } function hM(r, e, n) { const o = r.indices, u = r.attributes, l = {}; l.indexArray = new qs(); const f = e.json.accessors[o], v = f.count / 3; l.indexArray.reserve(v); const S = Mh(e, f); for (let I = 0; I < v; I++) l.indexArray.emplaceBack(S[3 * I], S[3 * I + 1], S[3 * I + 2]); l.indexArray._trim(), l.vertexArray = new va(); const D = e.json.accessors[u.POSITION]; l.vertexArray.reserve(D.count); const x = Mh(e, D); for (let I = 0; I < D.count; I++) l.vertexArray.emplaceBack(x[3 * I], x[3 * I + 1], x[3 * I + 2]); if (l.vertexArray._trim(), l.aabb = new Jt(D.min, D.max), l.centroid = function(I, M) { const C = [0, 0, 0], k = I.length; if (k > 0) { for (let V = 0; V < k; V++) { const U = 3 * I[V]; C[0] += M[U], C[1] += M[U + 1], C[2] += M[U + 2]; } C[0] /= k, C[1] /= k, C[2] /= k; } return C; }(S, x), u.COLOR_0 !== void 0) { const I = e.json.accessors[u.COLOR_0], M = mf[I.type], C = Mh(e, I); l.colorArray = M === 3 ? new va() : new Xa(), l.colorArray.resize(I.count), xg(e, I, l.colorArray, C); } if (u.NORMAL !== void 0) { l.normalArray = new va(); const I = e.json.accessors[u.NORMAL]; l.normalArray.resize(I.count); const M = Mh(e, I); xg(e, I, l.normalArray, M); } if (u.TEXCOORD_0 !== void 0 && n.length > 0) { l.texcoordArray = new Pl(); const I = e.json.accessors[u.TEXCOORD_0]; l.texcoordArray.resize(I.count); const M = Mh(e, I); xg(e, I, l.texcoordArray, M); } if (u._FEATURE_ID_RGBA4444 !== void 0) { const I = e.json.accessors[u._FEATURE_ID_RGBA4444]; e.json.extensionsUsed && e.json.extensionsUsed.includes("EXT_meshopt_compression") && (l.featureData = Mh(e, I)); } u._FEATURE_RGBA4444 !== void 0 && (l.featureData = new Uint32Array(Mh(e, e.json.accessors[u._FEATURE_RGBA4444]).buffer)); const P = r.material; return l.material = function(I, M) { const { emissiveFactor: C = [0, 0, 0], alphaMode: k = "OPAQUE", alphaCutoff: V = 0.5, normalTexture: U, occlusionTexture: q, emissiveTexture: $, doubleSided: H } = I, { baseColorFactor: K = [1, 1, 1, 1], metallicFactor: Q = 1, roughnessFactor: ie = 1, baseColorTexture: fe, metallicRoughnessTexture: de } = I.pbrMetallicRoughness || {}, ue = q ? M[q.index] : void 0; if (q && q.extensions && q.extensions.KHR_texture_transform && ue) { const Se = q.extensions.KHR_texture_transform; ue.offsetScale = [Se.offset[0], Se.offset[1], Se.scale[0], Se.scale[1]]; } return { pbrMetallicRoughness: { baseColorFactor: new ki(...K), metallicFactor: Q, roughnessFactor: ie, baseColorTexture: fe ? M[fe.index] : void 0, metallicRoughnessTexture: de ? M[de.index] : void 0 }, doubleSided: H, emissiveFactor: C, alphaMode: k, alphaCutoff: V, normalTexture: U ? M[U.index] : void 0, occlusionTexture: ue, emissionTexture: $ ? M[$.index] : void 0, defined: I.defined === void 0 }; }(P !== void 0 ? e.json.materials[P] : { defined: !1 }, n), l; } function Lv(r, e, n) { const { matrix: o, rotation: u, translation: l, scale: f, mesh: v, extras: S, children: D } = r, x = {}; if (x.matrix = o || De.mat4.fromRotationTranslationScale([], u || [0, 0, 0, 1], l || [0, 0, 0], f || [1, 1, 1]), v !== void 0) { x.meshes = n[v]; const P = x.anchor = [0, 0]; for (const I of x.meshes) { const { min: M, max: C } = I.aabb; P[0] += M[0] + C[0], P[1] += M[1] + C[1]; } P[0] = Math.floor(P[0] / x.meshes.length / 2), P[1] = Math.floor(P[1] / x.meshes.length / 2); } if (S && (S.id && (x.id = S.id), S.lights && (x.lights = function(P) { if (!P.length) return []; const I = function(U) { const q = atob(U), $ = new Uint8Array(q.length); for (let H = 0; H < q.length; H++) $[H] = q.codePointAt(H); return $; }(P), M = [], C = I.length / 24, k = new Uint16Array(I.buffer), V = new Float32Array(I.buffer); for (let U = 0; U < C; U++) { const q = k[2 * U * 6] / 30, $ = k[2 * U * 6 + 1] / 30, H = k[2 * U * 6 + 10] / 100, K = V[6 * U + 1], Q = V[6 * U + 2], ie = V[6 * U + 3], fe = V[6 * U + 4], de = ie - K, ue = fe - Q, Se = Math.hypot(de, ue); M.push({ pos: [K + 0.5 * de, Q + 0.5 * ue, $], normal: [ue / Se, -de / Se, 0], width: Se, height: q, depth: H, points: [K, Q, ie, fe] }); } return M; }(S.lights))), D) { const P = []; for (const I of D) P.push(Lv(e.json.nodes[I], e, n)); x.children = P; } return x; } function uM(r) { if (r.vertices.length === 0 || r.indices.length === 0) return null; const e = new b_(r.vertices, r.indices, 8, 256), [n, o] = [e.min.clone(), e.max.clone()]; return { vertices: r.vertices, indices: r.indices, grid: e, min: n, max: o }; } function dM(r) { if (!r.extras || !r.extras.ground) return null; const e = r.extras.ground; if (!e || !Array.isArray(e) || e.length === 0) return null; const n = e[0]; if (!n || !Array.isArray(n) || n.length === 0) return null; const o = []; for (const f of n) { if (!Array.isArray(f) || f.length !== 2) continue; const v = f[0], S = f[1]; typeof v == "number" && typeof S == "number" && o.push(new Et(v, S)); } if (o.length < 3) return null; o.length > 1 && o[o.length - 1].equals(o[0]) && o.pop(); let u = 0; for (let f = 0; f < o.length; f++) { const v = o[f], S = o[(f + 1) % o.length], D = o[(f + 2) % o.length]; u += (v.x - S.x) * (D.y - S.y) - (D.x - S.x) * (v.y - S.y); } u > 0 && o.reverse(); const l = Nd(o.flatMap((f) => [f.x, f.y]), []); return l.length === 0 ? null : { vertices: o, indices: l }; } function fM(r, e) { const n = [], o = []; let u = 0; const l = []; for (const f of r) { u = n.length; const v = f.vertexArray.float32, S = f.indexArray.uint16; for (let D = 0; D < f.vertexArray.length; D++) l[0] = v[3 * D + 0], l[1] = v[3 * D + 1], l[2] = v[3 * D + 2], De.vec3.transformMat4(l, l, e), n.push(new Et(l[0], l[1])); for (let D = 0; D < 3 * f.indexArray.length; D++) o.push(S[D] + u); } if (o.length % 3 != 0) return null; for (let f = 0; f < o.length; f += 3) { const v = n[o[f + 0]], S = n[o[f + 1]], D = n[o[f + 2]]; (v.x - S.x) * (D.y - S.y) - (D.x - S.x) * (v.y - S.y) > 0 && ([o[f + 1], o[f + 2]] = [o[f + 2], o[f + 1]]); } return { vertices: n, indices: o }; } function zv(r) { const e = function(S, D) { const x = [], P = WebGL2RenderingContext; if (S.json.textures) for (const I of S.json.textures) { const M = { magFilter: P.LINEAR, minFilter: P.NEAREST, wrapS: P.REPEAT, wrapT: P.REPEAT }; I.sampler !== void 0 && Object.assign(M, S.json.samplers[I.sampler]), x.push({ image: D[I.source], sampler: M, uploaded: !1 }); } return x; }(r, r.images), n = function(S, D) { const x = []; for (const P of S.json.meshes) { const I = []; for (const M of P.primitives) I.push(hM(M, S, D)); x.push(I); } return x; }(r, e), { scenes: o, scene: u, nodes: l } = r.json, f = o ? o[u || 0].nodes : l, v = []; for (const S of f) v.push(Lv(l[S], r, n)); return function(S, D, x) { const P = {}, I = /* @__PURE__ */ new Set(); for (let M = 0; M < S.length; M++) { const C = x[D[M]]; if (!C.extras) continue; const k = C.extras["mapbox:footprint:version"], V = C.extras["mapbox:footprint:id"]; (k || V) && I.add(M), k === "1.0.0" && V && (P[V] = M); } for (let M = 0; M < S.length; M++) { if (I.has(M)) continue; const C = S[M], k = x[D[M]]; if (!k.extras) continue; let V = null; C.id in P && (V = fM(S[P[C.id]].meshes, C.matrix)), V || (V = dM(k)), V && (C.footprint = uM(V)); } if (I.size > 0) { const M = Array.from(I.values()).sort((C, k) => C - k); for (let C = M.length - 1; C >= 0; C--) S.splice(M[C], 1); } }(v, f, r.json.nodes), v; } function pM(r) { r.heightmap = new Float32Array(4096), r.heightmap.fill(-1); const e = r.vertexArray.float32, n = r.aabb.min[0] - 1, o = r.aabb.min[1] - 1, u = bh / (r.aabb.max[0] - n + 2), l = bh / (r.aabb.max[1] - o + 2); for (let f = 0; f < e.length; f += 3) { const v = e[f + 2], S = (e[f + 0] - n) * u | 0, D = (e[f + 1] - o) * l | 0; v > r.heightmap[D * bh + S] && (r.heightmap[D * bh + S] = v); } } function mM(r, e) { const n = {}; n.indexArray = new qs(), n.indexArray.reserve(4 * r.length), n.vertexArray = new va(), n.vertexArray.reserve(10 * r.length), n.colorArray = new Xa(), n.vertexArray.reserve(10 * r.length); let o = 0; for (const f of r) { const v = Math.min(10, Math.max(4, 1.3 * f.height)) * e, S = [-f.normal[1], f.normal[0], 0], D = Math.min(0.29, 0.1 * f.width / f.depth), x = f.width - 2 * f.depth * e * (D + 0.01), P = De.vec3.scaleAndAdd([], f.pos, S, x / 2), I = De.vec3.scaleAndAdd([], f.pos, S, -x / 2), M = [P[0], P[1], P[2] + f.height], C = [I[0], I[1], I[2] + f.height], k = De.vec3.scaleAndAdd([], f.normal, S, D); De.vec3.scale(k, k, v); const V = De.vec3.scaleAndAdd([], f.normal, S, -D); De.vec3.scale(V, V, v), De.vec3.add(k, P, k), De.vec3.add(V, I, V), P[2] += 0.1, I[2] += 0.1, n.vertexArray.emplaceBack(k[0], k[1], k[2]), n.vertexArray.emplaceBack(V[0], V[1], V[2]), n.vertexArray.emplaceBack(P[0], P[1], P[2]), n.vertexArray.emplaceBack(I[0], I[1], I[2]), n.vertexArray.emplaceBack(M[0], M[1], M[2]), n.vertexArray.emplaceBack(C[0], C[1], C[2]), n.vertexArray.emplaceBack(P[0], P[1], P[2]), n.vertexArray.emplaceBack(I[0], I[1], I[2]), n.vertexArray.emplaceBack(k[0], k[1], k[2]), n.vertexArray.emplaceBack(V[0], V[1], V[2]); const U = x / v / 2; n.colorArray.emplaceBack(-U - D, -1, U, 0.8), n.colorArray.emplaceBack(U + D, -1, U, 0.8), n.colorArray.emplaceBack(-U, 0, U, 1.3), n.colorArray.emplaceBack(U, 0, U, 1.3), n.colorArray.emplaceBack(U + D, -0.8, U, 0.7), n.colorArray.emplaceBack(U + D, -0.8, U, 0.7), n.colorArray.emplaceBack(0, 0, U, 1.3), n.colorArray.emplaceBack(0, 0, U, 1.3), n.colorArray.emplaceBack(U + D, -1.2, U, 0.8), n.colorArray.emplaceBack(U + D, -1.2, U, 0.8), n.indexArray.emplaceBack(6 + o, 4 + o, 8 + o), n.indexArray.emplaceBack(7 + o, 9 + o, 5 + o), n.indexArray.emplaceBack(0 + o, 1 + o, 2 + o), n.indexArray.emplaceBack(1 + o, 3 + o, 2 + o), o += 10; } const u = { defined: !0, emissiveFactor: [0, 0, 0] }, l = {}; return l.baseColorFactor = ki.white, u.pbrMetallicRoughness = l, n.material = u, n.aabb = new Jt([1 / 0, 1 / 0, 1 / 0], [-1 / 0, -1 / 0, -1 / 0]), n; } class Dv { constructor(e) { this._stringToNumber = {}, this._numberToString = []; for (let n = 0; n < e.length; n++) { const o = e[n]; this._stringToNumber[o] = n, this._numberToString[n] = o; } } encode(e) { return this._stringToNumber[e]; } decode(e) { return this._numberToString[e]; } } const _M = ["id", "tile", "layer", "source", "sourceLayer", "state"]; class Zu { constructor(e, n, o, u, l) { this.type = "Feature", this._vectorTileFeature = e, this._z = n, this._x = o, this._y = u, this.properties = e.properties, this.id = l; } clone() { const e = new Zu(this._vectorTileFeature, this._z, this._x, this._y, this.id); return this.state && (e.state = { ...this.state }), this.layer && (e.layer = { ...this.layer }), this.source && (e.source = this.source), this.sourceLayer && (e.sourceLayer = this.sourceLayer), e; } get geometry() { return this._geometry === void 0 && (this._geometry = this._vectorTileFeature.toGeoJSON(this._x, this._y, this._z).geometry), this._geometry; } set geometry(e) { this._geometry = e; } toJSON() { const e = { type: "Feature", state: void 0, geometry: this.geometry, properties: this.properties }; for (const n of _M) this[n] !== void 0 && (e[n] = this[n]); return e; } } class kv { constructor(e, n) { this.tileID = e, this.x = e.canonical.x, this.y = e.canonical.y, this.z = e.canonical.z, this.grid = new rc(Tt, 16, 0), this.featureIndexArray = new dh(), this.promoteId = n, this.is3DTile = !1, this.serializedLayersCache = /* @__PURE__ */ new Map(); } insert(e, n, o, u, l, f = 0, v = 0) { const S = this.featureIndexArray.length; this.featureIndexArray.emplaceBack(o, u, l, f); const D = this.grid; for (let x = 0; x < n.length; x++) { const P = n[x], I = [1 / 0, 1 / 0, -1 / 0, -1 / 0]; for (let M = 0; M < P.length; M++) { const C = P[M]; I[0] = Math.min(I[0], C.x), I[1] = Math.min(I[1], C.y), I[2] = Math.max(I[2], C.x), I[3] = Math.max(I[3], C.y); } v !== 0 && (I[0] -= v, I[1] -= v, I[2] += v, I[3] += v), I[0] < Tt && I[1] < Tt && I[2] >= 0 && I[3] >= 0 && D.insert(S, I[0], I[1], I[2], I[3]); } } loadVTLayers() { if (!this.vtLayers) { this.vtLayers = new Iu.VectorTile(new Dp(this.rawTileData)).layers, this.sourceLayerCoder = new Dv(this.vtLayers ? Object.keys(this.vtLayers).sort() : ["_geojsonTileLayer"]), this.vtFeatures = {}; for (const e in this.vtLayers) this.vtFeatures[e] = []; } return this.vtLayers; } query(e, n) { const { tilespaceGeometry: o, transform: u, tileTransform: l, pixelPosMatrix: f, availableImages: v } = n; this.loadVTLayers(), this.serializedLayersCache.clear(); const S = o.bufferedTilespaceBounds, D = this.grid.query(S.min.x, S.min.y, S.max.x, S.max.y, (M, C, k, V) => Oe(o.bufferedTilespaceGeometry, M, C, k, V)); D.sort(gM); let x = null; u.elevation && D.length > 0 && (x = Fu.create(u.elevation, this.tileID)); const P = {}; let I; for (let M = 0; M < D.length; M++) { const C = D[M]; if (C === I) continue; I = C; const k = this.featureIndexArray.get(C); let V = null; this.is3DTile ? this.loadMatchingModelFeature(P, k, e, o, u) : this.loadMatchingFeature(P, k, e, v, (U, q, $, H = 0) => (V || (V = G(U, this.tileID.canonical, l)), q.queryIntersectsFeature(o, U, $, V, this.z, u, f, x, H))); } return P; } loadMatchingFeature(e, n, o, u, l) { const { featureIndex: f, bucketIndex: v, sourceLayerIndex: S, layoutVertexArrayOffset: D } = n, x = this.bucketLayerIDs[v], P = o.layers, I = Object.keys(P); if (I.length && !function(U, q) { for (let $ = 0; $ < U.length; $++) if (q.indexOf(U[$]) >= 0) return !0; return !1; }(I, x)) return; const M = o.sourceCache, C = this.sourceLayerCoder.decode(S), k = this.vtLayers[C].feature(f), V = this.getId(k, C); for (let U = 0; U < x.length; U++) { const q = x[U]; if (!P[q]) continue; const { styleLayer: $, targets: H } = P[q]; let K = {}; V !== void 0 && (K = M.getFeatureState($.sourceLayer, V)); const Q = !l || l(k, $, K, D); if (!Q) continue; const ie = new Zu(k, this.z, this.x, this.y, V); ie.tile = this.tileID.canonical, ie.state = K; let fe = this.serializedLayersCache.get(q); fe || (fe = $.serialize(), fe.id = q, this.serializedLayersCache.set(q, fe)), ie.source = fe.source, ie.sourceLayer = fe["source-layer"], ie.layer = An({}, fe), ie.layer.paint = Rv(fe.paint, $.paint, k, K, u), ie.layer.layout = Rv(fe.layout, $.layout, k, K, u); let de = !1; for (const ue of H) { this.updateFeatureProperties(ie, ue); const { filter: Se } = ue; if (Se) { if (k.properties = ie.properties, Se.needGeometry) { const me = Z(k, !0); if (!Se.filter(new Tn(this.tileID.overscaledZ), me, this.tileID.canonical)) continue; } else if (!Se.filter(new Tn(this.tileID.overscaledZ), k)) continue; } de = !0, ue.targetId && this.addFeatureVariant(ie, ue); } de && this.appendToResult(e, q, f, ie, Q); } } loadMatchingModelFeature(e, n, o, u, l) { const f = this.bucketLayerIDs[0][0], v = o.layers; if (!v[f]) return; const { styleLayer: S, targets: D } = v[f]; if (S.type !== "model") return; const x = u.tile, P = n.featureIndex, I = x.getBucket(S); if (!(I && I instanceof em)) return; const M = function(fe, de, ue, Se) { const me = fe.getNodesInfo()[de]; if (me.hiddenByReplacement || !me.node.meshes) return; let Ee = Number.MAX_VALUE; const ze = me.node, Ie = ue.tile, Re = Se.calculatePosMatrix(Ie.tileID.toUnwrapped(), Se.worldSize), Ve = me.evaluatedScale; let Ue = 0; Se.elevation && ze.elevation && (Ue = ze.elevation * Se.elevation.exaggeration()), De.mat4.translate(Re, Re, [(ze.anchor ? ze.anchor[0] : 0) * (Ve[0] - 1), (ze.anchor ? ze.anchor[1] : 0) * (Ve[1] - 1), Ue]), De.mat4.scale(Re, Re, Ve); const Fe = ue.queryGeometry, et = Fe.isPointQuery() ? Fe.screenBounds : Fe.screenGeometry, dt = function(Mt) { const wt = De.mat4.multiply([], Re, Mt.matrix); De.mat4.multiply(wt, Se.expandedFarZProjMatrix, wt); for (let At = 0; At < Mt.meshes.length; ++At) { const rt = Mt.meshes[At]; if (At === Mt.lightMeshIndex) continue; const Ut = Rx(et, Se, wt, rt.aabb); Ut != null && (Ee = Math.min(Ut, Ee)); } if (Mt.children) for (const At of Mt.children) dt(At); }; if (dt(ze), Ee === Number.MAX_VALUE) return; const tt = new Ui(0, 0); return Wx(Ie.tileID.canonical, tt, me.node.anchor[0], me.node.anchor[1]), { intersectionZ: Ee, position: tt, feature: me.feature }; }(I, P, u, l); if (!M) return; const { z: C, x: k, y: V } = x.tileID.canonical, { feature: U, intersectionZ: q, position: $ } = M; let H = {}; U.id !== void 0 && (H = o.sourceCache.getFeatureState(S.sourceLayer, U.id)); const K = new Zu({}, C, k, V, U.id); K.tile = this.tileID.canonical, K.state = H, K.properties = U.properties, K.geometry = { type: "Point", coordinates: [$.lng, $.lat] }; let Q = this.serializedLayersCache.get(f); Q || (Q = S.serialize(), Q.id = f, this.serializedLayersCache.set(f, Q)), K.source = Q.source, K.sourceLayer = Q["source-layer"], K.layer = An({}, Q); let ie = !1; for (const fe of D) { this.updateFeatureProperties(K, fe); const { filter: de } = fe; if (de) { if (U.properties = K.properties, de.needGeometry) { if (!de.filter(new Tn(this.tileID.overscaledZ), U, this.tileID.canonical)) continue; } else if (!de.filter(new Tn(this.tileID.overscaledZ), U)) continue; } ie = !0, fe.targetId && this.addFeatureVariant(K, fe); } ie && this.appendToResult(e, f, P, K, q); } updateFeatureProperties(e, n, o) { if (n.properties) { const u = {}; for (const l in n.properties) { const f = n.properties[l].evaluate({ zoom: this.z }, e._vectorTileFeature, e.state, e.tile, o); f != null && (u[l] = f); } e.properties = u; } } addFeatureVariant(e, n, o) { const u = { target: n.target, namespace: n.namespace }; n.properties && (u.properties = e.properties), e.variants = e.variants || {}, e.variants[n.targetId] = e.variants[n.targetId] || [], e.variants[n.targetId].push(u); } appendToResult(e, n, o, u, l) { let f = e[n]; f === void 0 && (f = e[n] = []), f.push({ featureIndex: o, feature: u, intersectionZ: l }); } lookupSymbolFeatures(e, n, o, u, l) { const f = {}; this.loadVTLayers(); for (const v of e) this.loadMatchingFeature(f, { bucketIndex: n, sourceLayerIndex: o, featureIndex: v, layoutVertexArrayOffset: 0 }, u, l); return f; } loadFeature(e) { const { featureIndex: n, sourceLayerIndex: o } = e; this.loadVTLayers(); const u = this.sourceLayerCoder.decode(o), l = this.vtFeatures[u]; if (l[n]) return l[n]; const f = this.vtLayers[u].feature(n); return l[n] = f, f; } hasLayer(e) { for (const n of this.bucketLayerIDs) for (const o of n) if (e === o) return !0; return !1; } getId(e, n) { let o = e.id; if (this.promoteId) { const u = typeof this.promoteId == "string" ? this.promoteId : this.promoteId[n]; u != null && (o = e.properties[u]), typeof o == "boolean" && (o = Number(o)); } return o; } } function Rv(r, e, n, o, u) { return Mr(r, (l, f) => { const v = e instanceof cc ? e.get(f) : null; return v && v.evaluate ? v.evaluate(n, o, u) : v; }); } function gM(r, e) { return e - r; } Ft(kv, "FeatureIndex", { omit: ["rawTileData", "sourceLayerCoder"] }); const Ov = [Int8Array, Uint8Array, Uint8ClampedArray, Int16Array, Uint16Array, Int32Array, Uint32Array, Float32Array, Float64Array]; class vg { static from(e) { if (!(e instanceof ArrayBuffer)) throw new Error("Data must be an instance of ArrayBuffer."); const [n, o] = new Uint8Array(e, 0, 2); if (n !== 219) throw new Error("Data does not appear to be in a KDBush format."); const u = o >> 4; if (u !== 1) throw new Error(`Got v${u} data when expected v1.`); const l = Ov[15 & o]; if (!l) throw new Error("Unrecognized array type."); const [f] = new Uint16Array(e, 2, 1), [v] = new Uint32Array(e, 4, 1); return new vg(v, f, l, e); } constructor(e, n = 64, o = Float64Array, u) { if (isNaN(e) || e < 0) throw new Error(`Unpexpected numItems value: ${e}.`); this.numItems = +e, this.nodeSize = Math.min(Math.max(+n, 2), 65535), this.ArrayType = o, this.IndexArrayType = e < 65536 ? Uint16Array : Uint32Array; const l = Ov.indexOf(this.ArrayType), f = 2 * e * this.ArrayType.BYTES_PER_ELEMENT, v = e * this.IndexArrayType.BYTES_PER_ELEMENT, S = (8 - v % 8) % 8; if (l < 0) throw new Error(`Unexpected typed array class: ${o}.`); u && u instanceof ArrayBuffer ? (this.data = u, this.ids = new this.IndexArrayType(this.data, 8, e), this.coords = new this.ArrayType(this.data, 8 + v + S, 2 * e), this._pos = 2 * e, this._finished = !0) : (this.data = new ArrayBuffer(8 + f + v + S), this.ids = new this.IndexArrayType(this.data, 8, e), this.coords = new this.ArrayType(this.data, 8 + v + S, 2 * e), this._pos = 0, this._finished = !1, new Uint8Array(this.data, 0, 2).set([219, 16 + l]), new Uint16Array(this.data, 2, 1)[0] = n, new Uint32Array(this.data, 4, 1)[0] = e); } add(e, n) { const o = this._pos >> 1; return this.ids[o] = o, this.coords[this._pos++] = e, this.coords[this._pos++] = n, o; } finish() { const e = this._pos >> 1; if (e !== this.numItems) throw new Error(`Added ${e} items when expected ${this.numItems}.`); return bg(this.ids, this.coords, this.nodeSize, 0, this.numItems - 1, 0), this._finished = !0, this; } range(e, n, o, u) { if (!this._finished) throw new Error("Data not yet indexed - call index.finish()."); const { ids: l, coords: f, nodeSize: v } = this, S = [0, l.length - 1, 0], D = []; for (; S.length; ) { const x = S.pop() || 0, P = S.pop() || 0, I = S.pop() || 0; if (P - I <= v) { for (let V = I; V <= P; V++) { const U = f[2 * V], q = f[2 * V + 1]; U >= e && U <= o && q >= n && q <= u && D.push(l[V]); } continue; } const M = I + P >> 1, C = f[2 * M], k = f[2 * M + 1]; C >= e && C <= o && k >= n && k <= u && D.push(l[M]), (x === 0 ? e <= C : n <= k) && (S.push(I), S.push(M - 1), S.push(1 - x)), (x === 0 ? o >= C : u >= k) && (S.push(M + 1), S.push(P), S.push(1 - x)); } return D; } within(e, n, o) { if (!this._finished) throw new Error("Data not yet indexed - call index.finish()."); const { ids: u, coords: l, nodeSize: f } = this, v = [0, u.length - 1, 0], S = [], D = o * o; for (; v.length; ) { const x = v.pop() || 0, P = v.pop() || 0, I = v.pop() || 0; if (P - I <= f) { for (let V = I; V <= P; V++) Bv(l[2 * V], l[2 * V + 1], e, n) <= D && S.push(u[V]); continue; } const M = I + P >> 1, C = l[2 * M], k = l[2 * M + 1]; Bv(C, k, e, n) <= D && S.push(u[M]), (x === 0 ? e - o <= C : n - o <= k) && (v.push(I), v.push(M - 1), v.push(1 - x)), (x === 0 ? e + o >= C : n + o >= k) && (v.push(M + 1), v.push(P), v.push(1 - x)); } return S; } } function bg(r, e, n, o, u, l) { if (u - o <= n) return; const f = o + u >> 1; Fv(r, e, f, o, u, l), bg(r, e, n, o, f - 1, 1 - l), bg(r, e, n, f + 1, u, 1 - l); } function Fv(r, e, n, o, u, l) { for (; u > o; ) { if (u - o > 600) { const D = u - o + 1, x = n - o + 1, P = Math.log(D), I = 0.5 * Math.exp(2 * P / 3), M = 0.5 * Math.sqrt(P * I * (D - I) / D) * (x - D / 2 < 0 ? -1 : 1); Fv(r, e, n, Math.max(o, Math.floor(n - x * I / D + M)), Math.min(u, Math.floor(n + (D - x) * I / D + M)), l); } const f = e[2 * n + l]; let v = o, S = u; for (_f(r, e, o, n), e[2 * u + l] > f && _f(r, e, o, u); v < S; ) { for (_f(r, e, v, S), v++, S--; e[2 * v + l] < f; ) v++; for (; e[2 * S + l] > f; ) S--; } e[2 * o + l] === f ? _f(r, e, o, S) : (S++, _f(r, e, S, u)), S <= n && (o = S + 1), n <= S && (u = S - 1); } } function _f(r, e, n, o) { wg(r, n, o), wg(e, 2 * n, 2 * o), wg(e, 2 * n + 1, 2 * o + 1); } function wg(r, e, n) { const o = r[e]; r[e] = r[n], r[n] = o; } function Bv(r, e, n, o) { const u = r - n, l = e - o; return u * u + l * l; } i.$ = bd, i.A = ss, i.B = 2, i.C = J0, i.D = Bu, i.E = Zo, i.F = N_, i.G = class extends Jp { }, i.H = qo, i.I = ug, i.J = Bi, i.K = ip, i.L = ad, i.M = nc, i.N = qf, i.O = tu, i.P = Et, i.Q = cu, i.R = Uo, i.S = ud, i.T = K_, i.U = Qc, i.V = Jp, i.W = xl, i.X = oo, i.Y = ro, i.Z = or, i._ = Ra, i.a = function(r) { return ge.API_CDN_URL_REGEX.test(r); }, i.a$ = Zu, i.a0 = Qh, i.a1 = Jh, i.a2 = function(r) { const e = r.value; let n = []; if (!e) return n; const o = qo(e); return o !== "string" ? (n = n.concat([new Jp(r.key, e, `string expected, "${o}" found`)]), n) : (Fx(e, !0) || (n = n.concat([new Jp(r.key, e, `invalid url "${e}"`)])), n); }, i.a3 = $e, i.a4 = ih, i.a5 = Bn, i.a6 = yt, i.a7 = class { constructor(r) { this.specification = r; } possiblyEvaluate(r, e) { return Zi(r.expression.evaluate(e)); } interpolate(r, e, n) { return { x: ei(r.x, e.x, n), y: ei(r.y, e.y, n), z: ei(r.z, e.z, n), azimuthal: ei(r.azimuthal, e.azimuthal, n), polar: ei(r.polar, e.polar, n) }; } }, i.a8 = Tn, i.a9 = sc, i.aA = Ta, i.aB = class { constructor(r) { this.entries = {}, this.scheduler = r; } request(r, e, n, o) { const u = this.entries[r] = this.entries[r] || { callbacks: [] }; if (u.result) { const [l, f] = u.result; return this.scheduler ? this.scheduler.add(() => { o(l, f); }, e) : o(l, f), () => { }; } return u.callbacks.push(o), u.cancel || (u.cancel = n((l, f) => { u.result = [l, f]; for (const v of u.callbacks) this.scheduler ? this.scheduler.add(() => { v(l, f); }, e) : v(l, f); setTimeout(() => delete this.entries[r], 3e3); })), () => { u.result || (u.callbacks = u.callbacks.filter((l) => l !== o), u.callbacks.length || (u.cancel(), delete this.entries[r])); }; } }, i.aC = Io, i.aD = function(r, e, n) { const o = JSON.stringify(r.request); return r.data && (this.deduped.entries[o] = { result: [null, r.data] }), this.deduped.request(o, { type: "parseTile", isSymbolTile: r.isSymbolTile, zoom: r.tileZoom }, (u) => { const l = no(r.request, (f, v, S, D) => { f ? u(f) : v && u(null, { vectorTile: n ? void 0 : new Iu.VectorTile(new Dp(v)), rawData: v, cacheControl: S, expires: D }); }); return () => { l.cancel(), u(); }; }, e); }, i.aE = function(r) { Xn++, Xn > ri && (r.getActor().send("enforceCacheSizeLimit", li), Xn = 0); }, i.aF = function(r) { return r <= 1 ? 1 : Math.pow(2, Math.floor(Math.log(r) / Math.LN2)); }, i.aG = bt, i.aH = Mx, i.aI = Ix, i.aJ = Tx, i.aK = function(r, e) { const n = document.createElement("video"); n.muted = !0, n.onloadstart = function() { e(null, n); }; for (let o = 0; o < r.length; o++) { const u = document.createElement("source"); Go(r[o]) || (n.crossOrigin = "Anonymous"), u.src = r[o], n.appendChild(u); } return { cancel: () => { } }; }, i.aL = Wp, i.aM = function(r) { return fetch(r).then((e) => e.arrayBuffer()).then((e) => Iv(e, 0, r)); }, i.aN = zv, i.aO = class { constructor(r, e, n, o) { this.id = r, this.position = e != null ? new Ui(e[0], e[1]) : new Ui(0, 0), this.orientation = n ?? [0, 0, 0], this.nodes = o, this.uploaded = !1, this.aabb = new Jt([1 / 0, 1 / 0, 1 / 0], [-1 / 0, -1 / 0, -1 / 0]), this.matrix = []; } _applyTransformations(r, e) { if (De.mat4.multiply(r.matrix, e, r.matrix), r.meshes) for (const n of r.meshes) { const o = Jt.applyTransformFast(n.aabb, r.matrix); this.aabb.encapsulate(o); } if (r.children) for (const n of r.children) this._applyTransformations(n, r.matrix); } computeBoundsAndApplyParent() { const r = De.mat4.identity([]); for (const e of this.nodes) this._applyTransformations(e, r); } computeModelMatrix(r, e, n, o, u, l, f = !1) { jx(this.matrix, this, r.transform, this.position, e, n, o, u, l, f); } upload(r) { if (!this.uploaded) { for (const e of this.nodes) ig(e, r); for (const e of this.nodes) Qp(e); this.uploaded = !0; } } destroy() { for (const r of this.nodes) ng(r); } }, i.aP = vo, i.aQ = Qd, i.aR = Fr, i.aS = Os, i.aT = $a, i.aU = qs, i.aV = yo, i.aW = ap, i.aX = Hp, i.aY = function() { co.isLoading() || co.isLoaded() || au() !== "deferred" || ep(); }, i.aZ = np, i.a_ = Z, i.aa = h, i.ab = De, i.ac = fs, i.ad = cc, i.ae = mr, i.af = ei, i.ag = Tt, i.ah = ul, i.ai = vi, i.aj = ki, i.ak = class { constructor(r) { this.specification = r; } possiblyEvaluate(r, e) { return function([n, o]) { const u = Zi([1, n, o]); return { x: u.x, y: u.y, z: u.z }; }(r.expression.evaluate(e)); } interpolate(r, e, n) { return { x: ei(r.x, e.x, n), y: ei(r.y, e.y, n), z: ei(r.z, e.z, n) }; } }, i.al = function(r, e, n = 0, o = !0) { const u = new Et(n, n), l = r.sub(u), f = e.add(u), v = [l, new Et(f.x, l.y), f, new Et(l.x, f.y)]; return o && v.push(l.clone()), v; }, i.am = function(r, e) { const n = []; for (let o = 0; o < r.length; o++) { const u = zn(o - 1, -1, r.length - 1), l = zn(o + 1, -1, r.length - 1), f = r[o], v = r[l], S = r[u].sub(f).unit(), D = v.sub(f).unit(), x = D.angleWithSep(S.x, S.y), P = S.add(D).unit().mult(-1 * e / Math.sin(x / 2)); n.push(f.add(P)); } return n; }, i.an = cx, i.ao = Oe, i.ap = function(r, e, n = 0) { return De.vec3.fromValues(((e.x - n) * r.scale - r.x) * Tt, (e.y * r.scale - r.y) * Tt, vp(e.z, e.y)); }, i.aq = zi, i.ar = P0, i.as = function(r) { let e = 1 / 0, n = 1 / 0, o = -1 / 0, u = -1 / 0; for (const l of r) e = Math.min(e, l.x), n = Math.min(n, l.y), o = Math.max(o, l.x), u = Math.max(u, l.y); return { min: new Et(e, n), max: new Et(o, u) }; }, i.at = ta, i.au = Ae, i.av = y, i.aw = si, i.ax = dr, i.ay = function(r, e) { const n = {}; for (let o = 0; o < e.length; o++) { const u = e[o]; u in r && (n[u] = r[u]); } return n; }, i.az = tl, i.b = function(r) { return ge.API_FONTS_REGEX.test(r); }, i.b$ = Yp, i.b0 = Fn, i.b1 = I_, i.b2 = v_, i.b3 = G, i.b4 = Lo, i.b5 = xu, i.b6 = ai, i.b7 = Wn, i.b8 = Nd, i.b9 = $_, i.bA = r0, i.bB = j_, i.bC = rx, i.bD = B_, i.bE = vg, i.bF = zn, i.bG = zs, i.bH = fr, i.bI = function(r, e, n) { r[4 * e + 0] = n[0], r[4 * e + 1] = n[1], r[4 * e + 2] = n[2], r[4 * e + 3] = n[3]; }, i.bJ = mh, i.bK = zo, i.bL = kd, i.bM = Nn, i.bN = dc, i.bO = Ui, i.bP = px, i.bQ = Lt, i.bR = _i, i.bS = zx, i.bT = nt, i.bU = jn, i.bV = function(r, e, n, o, u, l, f, v, S) { if (S.name === "globe") return jn(r, e, new nt(n, o, u), !1); const D = Qd({ z: n, x: o, y: u }, S); return new Jt([(l + D.x / D.scale) * e, e * (D.y / D.scale), f], [(l + D.x2 / D.scale) * e, e * (D.y2 / D.scale), v]); }, i.bW = function(r, e, n) { let o = 0; for (let u = 0; u < 2; ++u) r[u] > 0 && (o += (r[u] - 0) * (r[u] - 0)), e[u] < 0 && (o += (0 - e[u]) * (0 - e[u])); return o; }, i.bX = Un, i.bY = gp, i.bZ = function(r) { const e = De.mat4.identity(new Float64Array(16)); De.mat4.multiply(e, r.pixelMatrix, r.globeMatrix); const n = [0, uo, 0], o = [0, fo, 0]; return De.vec3.transformMat4(n, n, e), De.vec3.transformMat4(o, o, e), [n[0] > 0 && n[0] <= r.width && n[1] > 0 && n[1] <= r.height && !Nr(r, new Ui(r.center.lat, 90)), o[0] > 0 && o[0] <= r.width && o[1] > 0 && o[1] <= r.height && !Nr(r, new Ui(r.center.lat, -90))]; }, i.b_ = function(r, e) { const { scale: n } = r.tileTransform, o = n * Tt / (r.tileSize * Math.pow(2, e.zoom - r.tileID.overscaledZ + r.tileID.canonical.z)); return De.mat2.scale(new Float32Array(4), e.inverseAdjustmentMatrix, [o, o]); }, i.ba = function(r, e) { const n = mr(e.zoom); if (n === 0) return ts(r); const o = dn(r), u = _n(o), l = ta(o.getWest()) * e.worldSize, f = ta(o.getEast()) * e.worldSize, v = Ta(o.getNorth()) * e.worldSize, S = Ta(o.getSouth()) * e.worldSize, D = [l, v, 0], x = [f, v, 0], P = [l, S, 0], I = [f, S, 0], M = De.mat4.invert([], e.globeMatrix); return De.vec3.transformMat4(D, D, M), De.vec3.transformMat4(x, x, M), De.vec3.transformMat4(P, P, M), De.vec3.transformMat4(I, I, M), u[0] = Ps(u[0], P, n), u[1] = Ps(u[1], I, n), u[2] = Ps(u[2], x, n), u[3] = Ps(u[3], D, n), Jt.fromPoints(u); }, i.bb = cn, i.bc = Ri, i.bd = Ps, i.be = oh, i.bf = Xt, i.bg = mg, i.bh = Dp, i.bi = no, i.bj = function(r) { const e = []; for (const n in r) e.push(r[n]); return e; }, i.bk = function(r, e) { const n = []; for (const o in r) o in e || n.push(o); return n; }, i.bl = Rn, i.bm = ["type", "source", "source-layer", "minzoom", "maxzoom", "filter", "layout"], i.bn = Ws, i.bo = function(r, e) { const { x: n, y: o } = r.point, u = Ma(n, o, r.worldSize / r._pixelsPerMercatorPixel, 0, 0); return De.mat4.multiply(u, u, er(ts(e))); }, i.bp = Lu, i.bq = Ro, i.br = zp, i.bs = function(r, e, n, o, u) { const l = 5 * e + 2; r.float32[l + 0] = n, r.float32[l + 1] = o, r.float32[l + 2] = u; }, i.bt = Zp, i.bu = K0, i.bv = se, i.bw = tr, i.bx = Qy, i.by = Ox, i.bz = s0, i.c = Ce, i.c$ = (r, e, n, o, u, l, f, v) => { const S = r.transform, D = S.pitch < 15 ? A0(0.07, 0.7, si((14 - S.zoom) / 5, 0, 1)) : 0.07, x = n.paint.get("line-trim-color-use-theme").constantOr("default") === "none"; return { u_matrix: I0(r, e, n, o), u_texsize: e.imageAtlasTexture ? e.imageAtlasTexture.size : [0, 0], u_pixels_to_tile_units: S.calculatePixelsToTileUnitsMatrix(e), u_device_pixel_ratio: u, u_width_scale: l, u_floor_width_scale: f, u_image: 0, u_tile_units_to_pixels: C0(e, S), u_units_to_pixels: [1 / S.pixelsToGLUnits[0], 1 / S.pixelsToGLUnits[1]], u_alpha_discard_threshold: 0, u_trim_offset: v, u_trim_fade_range: n.paint.get("line-trim-fade-range"), u_trim_color: n.paint.get("line-trim-color").toRenderColor(x ? null : n.lut).toArray01(), u_emissive_strength: n.paint.get("line-emissive-strength"), u_zbias_factor: D, u_tile_to_meter: s(e.tileID.canonical, 0) }; }, i.c0 = Lx, i.c1 = function(r) { const e = Lx(r, !0); return De.mat2.invert([], [e[0], e[1], e[4], e[5]]); }, i.c2 = wi, i.c3 = function(r) { const { x: e, y: n } = r.point, { lng: o, lat: u } = r._center; return Ma(e, n, r.worldSize, o, u); }, i.c4 = kn, i.c5 = zt, i.c6 = Su, i.c7 = function(r) { const e = Math.round((r + 45 + 360) % 360 / 90) % 4; return Xs[e]; }, i.c8 = 45, i.c9 = gh, i.cA = class extends ba { constructor(r) { super(r), this.current = l_; } set(r, e, n) { if (this.fetchUniformLocation(r, e)) { for (let o = 0; o < 9; o++) if (n[o] !== this.current[o]) { this.current = n, this.gl.uniformMatrix3fv(this.location, !1, n); break; } } } }, i.cB = Hr, i.cC = function(r, e, n) { const o = mr(n.zoom), u = r.style.map._antialias, l = e.options.extStandardDerivativesForceOff || r.terrain && r.terrain.exaggeration() > 0; return o === 0 && !u && !l; }, i.cD = function(r) { const e = r.pixelsPerMeter, n = e / fr(1, r.center.lat), o = De.mat4.identity(new Float64Array(16)); return De.mat4.translate(o, o, [r.point.x, r.point.y, 0]), De.mat4.scale(o, o, [n, n, e]), Float32Array.from(o); }, i.cE = dn, i.cF = function(r) { const e = Un - 5; r = si(r, -e, e) / e * 90; const n = Math.pow(Math.abs(Math.sin(vi(r))), 3); return Math.round(n * (Eu.length - 1)); }, i.cG = function(r, e, n, o) { const u = e.getNorth(), l = e.getSouth(), f = e.getWest(), v = e.getEast(), S = 1 << r.z, D = v - f, x = u - l, P = D / Il, I = -x / Eu[n], M = [0, P, 0, I, 0, 0, u, f, 0]; if (r.z > 0) { const C = 180 / o; De.mat3.multiply(M, M, [C / D + 1, 0, 0, 0, C / x + 1, 0, -0.5 * C / P, 0.5 * C / I, 1]); } return M[2] = S, M[5] = r.x, M[8] = r.y, M; }, i.cH = ts, i.cI = function(r, e, n) { const o = De.mat4.identity(new Float64Array(16)), u = (e / (1 << r) - 0.5) * Math.PI * 2; return De.mat4.rotateY(o, n.globeMatrix, u), Float32Array.from(o); }, i.cJ = class { isDataAvailableAtPoint(r) { const e = this._source(); if (this.isUsingMockSource() || !e || r.y < 0 || r.y > 1) return !1; const n = e.getSource().maxzoom, o = 1 << n, u = Math.floor(r.x), l = Math.floor((r.x - u) * o), f = Math.floor(r.y * o), v = this.findDEMTileFor(new bt(n, u, n, l, f)); return !(!v || !v.dem); } getAtPointOrZero(r, e = 0) { return this.getAtPoint(r, e) || 0; } getAtPoint(r, e, n = !0) { if (this.isUsingMockSource()) return null; e == null && (e = null); const o = this._source(); if (!o || r.y < 0 || r.y > 1) return e; const u = o.getSource().maxzoom, l = 1 << u, f = Math.floor(r.x), v = r.x - f, S = new bt(u, f, u, Math.floor(v * l), Math.floor(r.y * l)), D = this.findDEMTileFor(S); if (!D || !D.dem) return e; const x = D.dem, P = 1 << D.tileID.canonical.z, I = (v * P - D.tileID.canonical.x) * x.dim, M = (r.y * P - D.tileID.canonical.y) * x.dim, C = Math.floor(I), k = Math.floor(M); return (n ? this.exaggeration() : 1) * ei(ei(x.get(C, k), x.get(C, k + 1), M - k), ei(x.get(C + 1, k), x.get(C + 1, k + 1), M - k), I - C); } getAtTileOffset(r, e, n) { const o = 1 << r.canonical.z; return this.getAtPointOrZero(new h(r.wrap + (r.canonical.x + e / Tt) / o, (r.canonical.y + n / Tt) / o)); } getAtTileOffsetFunc(r, e, n, o) { return (u) => { const l = this.getAtTileOffset(r, u.x, u.y), f = o.upVector(r.canonical, u.x, u.y), v = o.upVectorScale(r.canonical, e, n).metersToTile; return De.vec3.scale(f, f, l * v), f; }; } getForTilePoints(r, e, n, o) { if (this.isUsingMockSource()) return !1; const u = Fu.create(this, r, o); return !!u && (e.forEach((l) => { l[2] = this.exaggeration() * u.getElevationAt(l[0], l[1], n); }), !0); } getMinMaxForTile(r) { if (this.isUsingMockSource()) return null; const e = this.findDEMTileFor(r); if (!e || !e.dem) return null; const n = e.dem.tree, o = e.tileID, u = 1 << r.canonical.z - o.canonical.z; let l = r.canonical.x / u - o.canonical.x, f = r.canonical.y / u - o.canonical.y, v = 0; for (let S = 0; S < r.canonical.z - o.canonical.z && !n.leaves[v]; S++) { l *= 2, f *= 2; const D = 2 * Math.floor(f) + Math.floor(l); v = n.childOffsets[v] + D, l %= 1, f %= 1; } return { min: this.exaggeration() * n.minimums[v], max: this.exaggeration() * n.maximums[v] }; } getMinElevationBelowMSL() { throw new Error("Pure virtual method called."); } raycast(r, e, n) { throw new Error("Pure virtual method called."); } pointCoordinate(r) { 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(r) { throw new Error("Pure virtual method called."); } get visibleDemTiles() { throw new Error("Getter must be implemented in subclass."); } getMinMaxForVisibleTiles() { const r = this.visibleDemTiles; if (r.length === 0) return null; let e = !1, n = Number.MAX_VALUE, o = Number.MIN_VALUE; for (const u of r) { const l = this.getMinMaxForTile(u.tileID); l && (n = Math.min(n, l.min), o = Math.max(o, l.max), e = !0); } return e ? { min: n, max: o } : null; } }, i.cK = zy, i.cL = ji, i.cM = function(r, e) { return [Math.pow(r[0], 2.2) * e, Math.pow(r[1], 2.2) * e, Math.pow(r[2], 2.2) * e]; }, i.cN = Br, i.cO = le, i.cP = re, i.cQ = 256, i.cR = function(r, e) { const n = [0, 0, 0], o = cn(ts(e.canonical)); return De.vec3.transformMat4(n, n, o), De.vec3.transformMat4(n, n, r), n; }, i.cS = (r) => ({ u_camera_to_center_distance: new Nn(r), u_extrude_scale: new Od(r), u_device_pixel_ratio: new Nn(r), u_matrix: new mh(r), u_inv_rot_matrix: new mh(r), u_merc_center: new zo(r), u_tile_id: new kd(r), u_zoom_transition: new Nn(r), u_up_dir: new kd(r), u_emissive_strength: new Nn(r) }), i.cT = (r) => ({ u_matrix: new mh(r), u_pixels_to_tile_units: new Od(r), u_device_pixel_ratio: new Nn(r), u_width_scale: new Nn(r), u_floor_width_scale: new Nn(r), u_units_to_pixels: new zo(r), u_dash_image: new dc(r), u_gradient_image: new dc(r), u_image_height: new Nn(r), u_texsize: new zo(r), u_tile_units_to_pixels: new Nn(r), u_alpha_discard_threshold: new Nn(r), u_trim_offset: new zo(r), u_trim_fade_range: new zo(r), u_trim_color: new ph(r), u_emissive_strength: new Nn(r), u_zbias_factor: new Nn(r), u_tile_to_meter: new Nn(r) }), i.cU = (r) => ({ u_matrix: new mh(r), u_texsize: new zo(r), u_pixels_to_tile_units: new Od(r), u_device_pixel_ratio: new Nn(r), u_width_scale: new Nn(r), u_floor_width_scale: new Nn(r), u_image: new dc(r), u_units_to_pixels: new zo(r), u_tile_units_to_pixels: new Nn(r), u_alpha_discard_threshold: new Nn(r), u_trim_offset: new zo(r), u_trim_fade_range: new zo(r), u_trim_color: new ph(r), u_emissive_strength: new Nn(r), u_zbias_factor: new Nn(r), u_tile_to_meter: new Nn(r) }), i.cV = _u, i.cW = bT, i.cX = wT, i.cY = Pu, i.cZ = (r, e, n, o, u, l) => { const f = r.transform, v = f.projection.name === "globe"; let S; if (l.paint.get("circle-pitch-alignment") === "map") if (v) { const x = Br(f.zoom, e.canonical) * f._pixelsPerMercatorPixel; S = Float32Array.from([x, 0, 0, x]); } else S = f.calculatePixelsToTileUnitsMatrix(n); else S = new Float32Array([f.pixelsToGLUnits[0], 0, 0, f.pixelsToGLUnits[1]]); const D = { u_camera_to_center_distance: r.transform.getCameraToCenterDistance(f.projection), u_matrix: r.translatePosMatrix(e.projMatrix, n, l.paint.get("circle-translate"), l.paint.get("circle-translate-anchor")), u_device_pixel_ratio: Ct.devicePixelRatio, u_extrude_scale: S, u_inv_rot_matrix: yh, u_merc_center: [0, 0], u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_up_dir: [0, 0, 0], u_emissive_strength: l.paint.get("circle-emissive-strength") }; if (v) { D.u_inv_rot_matrix = o, D.u_merc_center = u, D.u_tile_id = [e.canonical.x, e.canonical.y, 1 << e.canonical.z], D.u_zoom_transition = mr(f.zoom); const x = u[0] * Tt, P = u[1] * Tt; D.u_up_dir = f.projection.upVector(new nt(0, 0, 0), x, P); } return D; }, i.c_ = L0, i.ca = ph, i.cb = function(r, e, n) { const o = Math.sqrt(r * r + e * e + n * n), u = o > 0 ? Math.acos(n / o) * $s : 0; let l = r !== 0 || e !== 0 ? Math.atan2(-e, -r) * $s + 90 : 0; return l < 0 && (l += 360), [o, l, u]; }, i.cc = s, i.cd = Jt, i.ce = Zi, i.cf = function(r) { return [Math.pow(r[0], 1 / 2.2), Math.pow(r[1], 1 / 2.2), Math.pow(r[2], 1 / 2.2)]; }, i.cg = function(r, e) { return r.readFields(f2, { icons: [] }, e); }, i.ch = function(r) { return r({ pluginStatus: br, pluginURL: qa }), oc.on("pluginStateChange", r), r; }, i.ci = tm, i.cj = Du, i.ck = V_, i.cl = tn, i.cm = th, i.cn = Kt, i.co = $r, i.cp = Ys, i.cq = function(r) { const e = r.indexOf(Co); return e >= 0 ? r.slice(0, e) : r; }, i.cr = function(r) { return r.indexOf(Co) >= 0; }, i.cs = function(r) { const e = r.indexOf(Co); return e >= 0 ? r.slice(e + 1) : ""; }, i.ct = function(r) { const e = [], n = r.id; return n === void 0 && e.push({ message: `layers.${n}: missing required property "id"` }), r.render === void 0 && e.push({ message: `layers.${n}: missing required method "render"` }), r.renderingMode && r.renderingMode !== "2d" && r.renderingMode !== "3d" && e.push({ message: `layers.${n}: property "renderingMode" must be either "2d" or "3d"` }), e; }, i.cu = function(r, e, n, o) { return r.type === "custom" ? new QT(r, e) : new h2[r.type](r, e, n, o); }, i.cv = io, i.cw = class extends Zu { constructor(r, e) { super(r._vectorTileFeature, r._z, r._x, r._y, r.id), r.state && (this.state = { ...r.state }), this.target = e.target, this.namespace = e.namespace, e.properties && (this.properties = e.properties), this.target && ("featuresetId" in this.target && !this.target.importId || "layerId" in this.target) && (this.source = r.source, this.sourceLayer = r.sourceLayer, this.layer = r.layer); } toJSON() { const r = super.toJSON(); return r.target = this.target, r.namespace = this.namespace, r; } }, i.cx = oc, i.cy = xn, i.cz = _p, i.d = function(r) { return ge.API_TILEJSON_REGEX.test(r); }, i.d$ = Mr, i.d0 = (r, e, n, o, u, l, f, v, S) => { const D = r.transform, x = D.calculatePixelsToTileUnitsMatrix(e), P = n.paint.get("line-trim-color-use-theme").constantOr("default") === "none", I = D.pitch < 15 ? A0(0.07, 0.7, si((14 - D.zoom) / 5, 0, 1)) : 0.07; return { u_matrix: I0(r, e, n, o), u_pixels_to_tile_units: x, u_device_pixel_ratio: l, u_width_scale: f, u_floor_width_scale: v, u_units_to_pixels: [1 / D.pixelsToGLUnits[0], 1 / D.pixelsToGLUnits[1]], u_dash_image: 0, u_gradient_image: 1, u_image_height: u, u_texsize: z0(n) && e.lineAtlasTexture ? e.lineAtlasTexture.size : [0, 0], u_tile_units_to_pixels: C0(e, r.transform), u_alpha_discard_threshold: 0, u_trim_offset: S, u_trim_fade_range: n.paint.get("line-trim-fade-range"), u_trim_color: n.paint.get("line-trim-color").toRenderColor(P ? null : n.lut).toArray01(), u_emissive_strength: n.paint.get("line-emissive-strength"), u_zbias_factor: I, u_tile_to_meter: s(e.tileID.canonical, 0) }; }, i.d1 = xo, i.d2 = Bd, i.d3 = y0, i.d4 = Bt, i.d5 = Ip, i.d6 = yc, i.d7 = 450, i.d8 = 7, i.d9 = JT, i.dA = Wr, i.dB = t, i.dC = el, i.dD = function([r, e, n]) { const o = Math.hypot(r, e, n), u = Math.atan2(r, n), l = 0.5 * Math.PI - Math.acos(-e / o); return new Ui(kn(u), kn(l)); }, i.dE = Q_, i.dF = function(r) { const e = r.navigator ? r.navigator.userAgent : null; return !!function(n) { if (Ls == null) { const o = n.navigator ? n.navigator.userAgent : null; Ls = !!n.safari || !(!o || !(/\b(iPad|iPhone|iPod)\b/.test(o) || o.match("Safari") && !o.match("Chrome"))); } return Ls; }(r) && 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/)); }, i.dG = function(r, e) { li = r, ri = e; }, i.dH = Nr, i.dI = ko, i.dJ = function(r) { const e = [0, 0, 0], n = De.mat4.identity(new Float64Array(16)); return De.mat4.multiply(n, r.pixelMatrix, r.globeMatrix), De.vec3.transformMat4(e, e, n), new Et(e[0], e[1]); }, i.dK = function(r, e, n = !1) { if (br === yd || br === ea || br === xd) throw new Error("setRTLTextPlugin cannot be called multiple times."); qa = Ct.resolveURL(r), br = yd, vd = e, ou(), n || ep(); }, i.dL = au, i.dM = function() { tm().acquire(rg); }, i.dN = function() { const r = lf; r && (r.isPreloaded() && r.numActive() === 1 ? (r.release(rg), lf = 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()")); }, i.dO = Th, i.dP = function(r) { const e = $i(); if (!e) return; const n = e.delete(di); r && n.catch(r).then(() => r()); }, i.dQ = af, i.dR = Tv, i.dS = function(r) { _g = Ct.resolveURL(r), Gu || (Gu = new Bu(tm(), new Zo())), Gu.broadcast("setDracoUrl", _g); }, i.dT = Mv, i.dU = function(r) { ju = Ct.resolveURL(r), Gu || (Gu = new Bu(tm(), new Zo())), Gu.broadcast("setMeshoptUrl", ju); }, i.dV = Ft, i.dW = gc, i.dX = Ea, i.dY = Dv, i.dZ = kv, i.d_ = M0, i.da = qi, i.db = zd, i.dc = 256, i.dd = er, i.de = va, i.df = Rr, i.dg = yu, i.dh = function(r, e, n, o, u) { return si((r - e) / (n - e) * (u - o) + o, o, u); }, i.di = es, i.dj = c, i.dk = class { constructor(r, e, n, o) { this.context = r, this.format = o, this.size = n, this.texture = r.gl.createTexture(); const [u, l, f] = this.size, { gl: v } = r; v.bindTexture(v.TEXTURE_3D, this.texture), r.pixelStoreUnpackFlipY.set(!1), r.pixelStoreUnpack.set(1), r.pixelStoreUnpackPremultiplyAlpha.set(!1), v.texImage3D(v.TEXTURE_3D, 0, this.format, u, l, f, 0, X_(this.format), Y_(this.format), e.data); } bind(r, e) { const { context: n } = this, { gl: o } = n; o.bindTexture(o.TEXTURE_3D, this.texture), r !== this.minFilter && (o.texParameteri(o.TEXTURE_3D, o.TEXTURE_MAG_FILTER, r), o.texParameteri(o.TEXTURE_3D, o.TEXTURE_MIN_FILTER, r), this.minFilter = r), e !== this.wrapS && (o.texParameteri(o.TEXTURE_3D, o.TEXTURE_WRAP_S, e), o.texParameteri(o.TEXTURE_3D, o.TEXTURE_WRAP_T, e), this.wrapS = e); } destroy() { const { gl: r } = this.context; r.deleteTexture(this.texture), this.texture = null; } }, i.dl = eg, i.dm = [1, 1, 1], i.dn = Fu, i.dp = Ou, i.dq = Ka, i.dr = Pl, i.ds = _c, i.dt = Id, i.du = Cd, i.dv = class { constructor() { this._updateTime = 0, this._sourceIds = [], this._activeRegions = [], this._prevRegions = [], this._globalClipBounds = { min: new Et(1 / 0, 1 / 0), max: new Et(-1 / 0, -1 / 0) }; } clear() { this._activeRegions.length > 0 && ++this._updateTime, this._activeRegions = [], this._prevRegions = []; } get updateTime() { return this._updateTime; } getReplacementRegionsForTile(r, e = !1) { const n = t0(new Et(0, 0), new Et(Tt, Tt), r), o = []; if (e && !S_(n, this._globalClipBounds)) return o; for (const u of this._activeRegions) { if (u.hiddenByOverlap || !S_(n, u)) continue; const l = $w(u.min, u.max, r); o.push({ min: l.min, max: l.max, sourceId: this._sourceIds[u.priority], footprint: u.footprint, footprintTileId: u.tileId, order: u.order, clipMask: u.clipMask, clipScope: u.clipScope }); } return o; } setSources(r) { this._setSources(r.map((e) => ({ getSourceId: () => e.cache.id, getFootprints: () => { const n = []; for (const o of e.cache.getVisibleCoordinates()) { const u = e.cache.getTile(o).buckets[e.layer]; u && u.updateFootprints(o.toUnwrapped(), n); } return n; }, getOrder: () => e.order, getClipMask: () => e.clipMask, getClipScope: () => e.clipScope }))); } _addSource(r) { const e = r.getFootprints(); if (e.length === 0) return; const n = r.getOrder(), o = r.getClipMask(), u = r.getClipScope(); for (const l of e) { if (!l.footprint) continue; const f = t0(l.footprint.min, l.footprint.max, l.id); this._activeRegions.push({ min: f.min, max: f.max, hiddenByOverlap: !1, priority: this._sourceIds.length, tileId: l.id, footprint: l.footprint, order: n, clipMask: o, clipScope: u }); } this._sourceIds.push(r.getSourceId()); } _computeReplacement() { this._activeRegions.sort((e, n) => e.priority - n.priority || Ap(e.min, n.min) || Ap(e.max, n.max) || e.order - n.order || e.clipMask - n.clipMask || function(o, u) { const l = (f, v) => f + v; return o.length - u.length || o.reduce(l, "").localeCompare(u.reduce(l, "")); }(e.clipScope, n.clipScope)); let r = this._activeRegions.length !== this._prevRegions.length; if (!r) { let e = 0; for (; !r && e !== this._activeRegions.length; ) { const n = this._activeRegions[e], o = this._prevRegions[e]; r = n.priority !== o.priority || !e0(n, o) || n.order !== o.order || n.clipMask !== o.clipMask || !Ws(n.clipScope, o.clipScope), ++e; } } if (r) { ++this._updateTime; for (const n of this._activeRegions) n.order !== Pp && (this._globalClipBounds.min.x = Math.min(this._globalClipBounds.min.x, n.min.x), this._globalClipBounds.min.y = Math.min(this._globalClipBounds.min.y, n.min.y), this._globalClipBounds.max.x = Math.max(this._globalClipBounds.max.x, n.max.x), this._globalClipBounds.max.y = Math.max(this._globalClipBounds.max.y, n.max.y)); const e = (n) => { const o = this._activeRegions; if (n >= o.length) return n; const u = o[n].priority; for (; n < o.length && o[n].priority === u; ) ++n; return n; }; if (this._sourceIds.length > 1) { let n = 0, o = e(n); for (; n !== o; ) { let u = n; const l = n; for (; u !== o; ) { const f = this._activeRegions[u]; f.hiddenByOverlap = !1; for (let v = 0; v < l; v++) { const S = this._activeRegions[v]; if (!S.hiddenByOverlap && f.order === Pp && S_(f, S) && (f.hiddenByOverlap = n0(f.footprint, f.tileId, S.footprint, S.tileId), f.hiddenByOverlap)) break; } ++u; } n = o, o = e(n); } } } } _setSources(r) { [this._prevRegions, this._activeRegions] = [this._activeRegions, []], this._sourceIds = []; for (let e = r.length - 1; e >= 0; e--) this._addSource(r[e]); this._computeReplacement(); } }, i.dw = class { constructor(r) { this._createGrid(r), this._createPoles(r); } destroy() { this._poleIndexBuffer.destroy(), this._gridBuffer.destroy(), this._gridIndexBuffer.destroy(), this._poleNorthVertexBuffer.destroy(), this._poleSouthVertexBuffer.destroy(); for (const r of this._poleSegments) r.destroy(); for (const r of this._gridSegments) r.withSkirts.destroy(), r.withoutSkirts.destroy(); } _fillGridMeshWithLods(r, e) { const n = new Lo(), o = new qs(), u = [], l = r + 1 + 2, f = e[0] + 1, v = e[0] + 1 + (1 + e.length), S = (D, x, P) => { let I = D === l - 1 ? D - 2 : D === 0 ? D : D - 1; return I += P ? 24575 : 0, [I, x]; }; for (let D = 0; D < l; ++D) n.emplaceBack(...S(D, 0, !0)); for (let D = 0; D < f; ++D) for (let x = 0; x < l; ++x) n.emplaceBack(...S(x, D, (x === 0 || x === l - 1) && !0)); for (let D = 0; D < e.length; ++D) { const x = e[D]; for (let P = 0; P < l; ++P) n.emplaceBack(...S(P, x, !0)); } for (let D = 0; D < e.length; ++D) { const x = o.length, P = e[D] + 1 + 2, I = new qs(); for (let k = 0; k < P - 1; k++) { const V = k === P - 2, U = V ? l * (v - e.length + D - k) : l; for (let q = 0; q < l - 1; q++) { const $ = k * l + q; k === 0 || V || q === 0 || q === l - 2 ? (I.emplaceBack($ + 1, $, $ + U), I.emplaceBack($ + U, $ + U + 1, $ + 1)) : (o.emplaceBack($ + 1, $, $ + U), o.emplaceBack($ + U, $ + U + 1, $ + 1)); } } const M = Wn.simpleSegment(0, x, n.length, o.length - x); for (let k = 0; k < I.uint16.length; k += 3) o.emplaceBack(I.uint16[k], I.uint16[k + 1], I.uint16[k + 2]); const C = Wn.simpleSegment(0, x, n.length, o.length - x); u.push({ withoutSkirts: M, withSkirts: C }); } return { vertices: n, indices: o, segments: u }; } _createGrid(r) { const e = this._fillGridMeshWithLods(Il, Eu); this._gridSegments = e.segments, this._gridBuffer = r.createVertexBuffer(e.vertices, ai.members), this._gridIndexBuffer = r.createIndexBuffer(e.indices, !0); } _createPoles(r) { const e = new qs(); for (let f = 0; f <= Il; f++) e.emplaceBack(0, f + 1, f + 2); this._poleIndexBuffer = r.createIndexBuffer(e, !0); const n = new Rr(), o = new Rr(), u = new Rr(), l = new Rr(); this._poleSegments = []; for (let f = 0, v = 0; f < Su; f++) { const S = 360 / (1 << f); n.emplaceBack(0, -dr, 0, 0.5, 0), o.emplaceBack(0, -dr, 0, 0.5, 1), u.emplaceBack(0, -dr, 0, 0.5, 0.5), l.emplaceBack(0, -dr, 0, 0.5, 0.5); for (let D = 0; D <= Il; D++) { let x = D / Il, P = 0; const I = ei(0, S, x), [M, C, k] = mc(ia, Ll, I, dr); n.emplaceBack(M, C, k, x, P), o.emplaceBack(M, C, k, x, 1 - P); const V = vi(I); x = 0.5 + 0.5 * Math.sin(V), P = 0.5 + 0.5 * Math.cos(V), u.emplaceBack(M, C, k, x, P), l.emplaceBack(M, C, k, x, 1 - P); } this._poleSegments.push(Wn.simpleSegment(v, 0, 66, 64)), v += 66; } this._poleNorthVertexBuffer = r.createVertexBuffer(n, $t, !1), this._poleSouthVertexBuffer = r.createVertexBuffer(o, $t, !1), this._texturedPoleNorthVertexBuffer = r.createVertexBuffer(u, $t, !1), this._texturedPoleSouthVertexBuffer = r.createVertexBuffer(l, $t, !1); } getGridBuffers(r, e) { return [this._gridBuffer, this._gridIndexBuffer, e ? this._gridSegments[r].withSkirts : this._gridSegments[r].withoutSkirts]; } getPoleBuffers(r, e) { return [e ? this._texturedPoleNorthVertexBuffer : this._poleNorthVertexBuffer, e ? this._texturedPoleSouthVertexBuffer : this._poleSouthVertexBuffer, this._poleIndexBuffer, this._poleSegments[r]]; } }, i.dx = Pp, i.dy = qr, i.dz = function() { return !!document.fullscreenElement || !!document.webkitFullscreenElement; }, i.e = ge, i.e0 = rr, i.e1 = Q0, i.e2 = function(r, e, n, o, u, l, f, v, S, D, x = 1, P, I) { r.createArrays(), r.tilePixelRatio = Tt / (512 * r.overscaling), r.compareText = {}, r.iconsNeedLinear = !1; const M = r.layers[0].layout, C = r.layers[0]._unevaluatedLayout._values, k = {}; k.scaleFactor = x, k.textSizeScaleRange = M.get("text-size-scale-range"), k.iconSizeScaleRange = M.get("icon-size-scale-range"); const [V, U] = k.textSizeScaleRange, [q, $] = k.iconSizeScaleRange; if (k.textScaleFactor = si(k.scaleFactor, V, U), k.iconScaleFactor = si(k.scaleFactor, q, $), r.textSizeData.kind === "composite") { const { minZoom: ie, maxZoom: fe } = r.textSizeData; k.compositeTextSizes = [C["text-size"].possiblyEvaluate(new Tn(ie), v), C["text-size"].possiblyEvaluate(new Tn(fe), v)]; } if (r.iconSizeData.kind === "composite") { const { minZoom: ie, maxZoom: fe } = r.iconSizeData; k.compositeIconSizes = [C["icon-size"].possiblyEvaluate(new Tn(ie), v), C["icon-size"].possiblyEvaluate(new Tn(fe), v)]; } k.layoutTextSize = C["text-size"].possiblyEvaluate(new Tn(S + 1), v), k.layoutIconSize = C["icon-size"].possiblyEvaluate(new Tn(S + 1), v), k.textMaxSize = C["text-size"].possiblyEvaluate(new Tn(18), v); const H = M.get("text-rotation-alignment") === "map" && M.get("symbol-placement") !== "point", K = M.get("text-size"); let Q = !1; for (const ie of r.features) if (ie.icon && ie.icon.nameSecondary) { Q = !0; break; } for (const ie of r.features) { const fe = M.get("text-font").evaluate(ie, {}, v).join(","), de = K.evaluate(ie, {}, v) * k.textScaleFactor, ue = k.layoutTextSize.evaluate(ie, {}, v) * k.textScaleFactor, Se = (k.layoutIconSize.evaluate(ie, {}, v), { horizontal: {}, vertical: void 0 }), me = ie.text; let Ee, ze = [0, 0]; if (me) { const Ue = me.toString(), Fe = M.get("text-letter-spacing").evaluate(ie, {}, v) * tr, et = M.get("text-line-height").evaluate(ie, {}, v) * tr, dt = Kf(Ue) ? Fe : 0, tt = M.get("text-anchor").evaluate(ie, {}, v), Mt = M.get("text-variable-anchor"); if (!Mt) { const St = M.get("text-radial-offset").evaluate(ie, {}, v); ze = St ? rx(tt, [St * tr, U_]) : M.get("text-offset").evaluate(ie, {}, v).map((Nt) => Nt * tr); } let wt = H ? "center" : M.get("text-justify").evaluate(ie, {}, v); const At = M.get("symbol-placement") === "point", rt = At ? M.get("text-max-width").evaluate(ie, {}, v) * tr : 1 / 0, Ut = (St) => { r.allowVerticalPlacement && md(Ue) && (Se.vertical = F_(me, e, n, u, fe, rt, et, tt, St, dt, ze, Ro.vertical, !0, ue, de)); }; if (!H && Mt) { const St = wt === "auto" ? Mt.map((Qt) => j_(Qt)) : [wt]; let Nt = !1; for (let Qt = 0; Qt < St.length; Qt++) { const pi = St[Qt]; if (!Se.horizontal[pi]) if (Nt) Se.horizontal[pi] = Se.horizontal[0]; else { const gi = F_(me, e, n, u, fe, rt, et, "center", pi, dt, ze, Ro.horizontal, !1, ue, de); gi && (Se.horizontal[pi] = gi, Nt = gi.positionedLines.length === 1); } } Ut("left"); } else { if (wt === "auto" && (wt = j_(tt)), At || M.get("text-writing-mode").indexOf("horizontal") >= 0 || !md(Ue)) { const St = F_(me, e, n, u, fe, rt, et, tt, wt, dt, ze, Ro.horizontal, !1, ue, de); St && (Se.horizontal[wt] = St); } Ut(At ? "left" : wt); } } let Ie = !1, Re = !1; if (ie.icon && ie.icon.namePrimary) { const Ue = Lp(r.iconSizeData, C["icon-size"], v, r.zoom, ie) * k.iconScaleFactor * P, Fe = ie.icon.getPrimary().scaleSelf(Ue).serialize(), et = o[Fe]; et && (Ee = zT(u[Fe], ie.icon.nameSecondary ? u[ie.icon.getSecondary().scaleSelf(Ue).serialize()] : void 0, M.get("icon-offset").evaluate(ie, {}, v), M.get("icon-anchor").evaluate(ie, {}, v)), Ie = et.sdf, Re = et.usvg, r.sdfIcons === void 0 ? r.sdfIcons = et.sdf : r.sdfIcons !== et.sdf && mi("Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer"), (et.pixelRatio !== r.pixelRatio || M.get("icon-rotate").constantOr(1) !== 0) && (r.iconsNeedLinear = !0)); } const Ve = ax(Se.horizontal) || Se.vertical; r.iconsInText || (r.iconsInText = !!Ve && Ve.iconsInText), (Ve || Ee) && NT(r, ie, Se, Ee, o, k, ue, 0, ze, Ie, Re, f, v, D, I, Q); } l && r.generateCollisionDebugBuffers(S, r.collisionBoxArray, k.textScaleFactor); }, i.e3 = Iu, i.e4 = am, i.e5 = Zr, i.e6 = Xy, i.e7 = B0, i.e8 = O, i.e9 = function(r) { let e = 0; if (new Uint32Array(r, 0, 1)[0] !== Ev) { const n = new Uint32Array(r, 0, 7), [, , o, u, l, f] = n; e = n.byteLength + u + l + f + l, (o !== r.byteLength || e >= r.byteLength) && mi("Invalid b3dm header information."); } return Iv(r, e); }, i.ea = function(r, e) { const n = zv(r); for (const o of n) { for (const u of o.meshes) pM(u); o.lights && (o.lightMeshIndex = o.meshes.length, o.meshes.push(mM(o.lights, e))); } return n; }, i.eb = em, i.ec = $x, i.ed = co, i.ee = function(r) { Hi(), Ni != null && Ni.then((e) => { e.keys().then((n) => { for (let o = 0; o < n.length - r; o++) e.delete(n[o]); }); }); }, i.f = function(r) { return r.indexOf("mapbox:") === 0; }, i.g = function(r, e) { return xn(An(r, { method: "GET" }), e); }, i.h = Le, i.i = function(r) { return ge.API_STYLE_REGEX.test(r) && !Ce(r); }, i.j = function(r) { return decodeURIComponent(atob(r).split("").map((e) => "%" + ("00" + e.charCodeAt(0).toString(16)).slice(-2)).join("")); }, i.k = function(r) { return btoa(encodeURIComponent(r).replace(/%([0-9A-F]{2})/g, (e, n) => String.fromCharCode(+("0x" + n)))); }, i.l = An, i.m = Gs, i.n = function(r, e) { return xn(An(r, { type: "json" }), e); }, i.o = Hn, i.p = function(r, e) { return xn(An(r, { method: "POST" }), e); }, i.q = Ct, i.r = _r, i.s = function(r) { try { const e = self[r]; return e.setItem("_mapbox_test_", 1), e.removeItem("_mapbox_test_"), !0; } catch { return !1; } }, i.t = mt, i.u = function() { return function r(e) { return e ? (e ^ Math.random() * (16 >> e / 4)).toString(16) : ([1e7] + -[1e3] + -4e3 + -8e3 + -1e11).replace(/[018]/g, r); }(); }, i.v = function(r) { return !!r && /^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(r); }, i.w = mi, i.x = function() { return og || (og = new Th()), og; }, i.y = Cr, i.z = Ar; }), b(["./shared"], function(i) { function O(Ke) { const re = Ke ? Ke.url.toString() : void 0; return re ? performance.getEntriesByName(re) : []; } function j(Ke) { if (typeof Ke == "number" || typeof Ke == "boolean" || typeof Ke == "string" || Ke == null) return JSON.stringify(Ke); if (Array.isArray(Ke)) { let le = "["; for (const ge of Ke) le += `${j(ge)},`; return `${le}]`; } let re = "{"; for (const le of Object.keys(Ke).sort()) re += `${le}:${j(Ke[le])},`; return `${re}}`; } function Y(Ke) { let re = ""; for (const le of i.bm) re += `/${j(Ke[le])}`; return re; } class J { constructor(re) { this.keyCache = {}, this._layers = {}, this._layerConfigs = {}, re && this.replace(re); } replace(re, le) { this._layerConfigs = {}, this._layers = {}, this.update(re, [], le); } update(re, le, ge) { this._options = ge; for (const Ce of re) this._layerConfigs[Ce.id] = Ce, (this._layers[Ce.id] = i.cu(Ce, this.scope, null, this._options)).compileFilter(ge), this.keyCache[Ce.id] && delete this.keyCache[Ce.id]; for (const Ce of le) delete this.keyCache[Ce], delete this._layerConfigs[Ce], delete this._layers[Ce]; this.familiesBySource = {}; const Le = function(Ce, Be) { const qe = {}; for (let Ye = 0; Ye < Ce.length; Ye++) { const Qe = Ce[Ye]; let it = Be && Be[Qe.id]; !it && (it = Y(Qe), Qe.type === "line" && Qe.paint) && function Ct(It) { return typeof It == "string" && It === "line-progress" || (Array.isArray(It) ? It.some(Ct) : !(!It || typeof It != "object") && Object.values(It).some(Ct)); }(Qe.paint["line-width"]) && (it += `/${j(Qe.paint["line-width"])}`), Be && (Be[Qe.id] = it); let mt = qe[it]; mt || (mt = qe[it] = []), mt.push(Qe); } const Pe = []; for (const Ye in qe) Pe.push(qe[Ye]); return Pe; }(i.bj(this._layerConfigs), this.keyCache); for (const Ce of Le) { const Be = Ce.map((mt) => this._layers[mt.id]), qe = Be[0]; if (qe.visibility === "none") continue; const Pe = qe.source || ""; let Ye = this.familiesBySource[Pe]; Ye || (Ye = this.familiesBySource[Pe] = {}); const Qe = qe.sourceLayer || "_geojsonTileLayer"; let it = Ye[Qe]; it || (it = Ye[Qe] = []), it.push(Be); } } } const ae = 1 * i.dX; class ce { constructor(re) { const le = {}, ge = []; for (const qe in re) { const Pe = re[qe], Ye = le[qe] = {}; for (const Qe in Pe.glyphs) { const it = Pe.glyphs[+Qe]; if (!it || it.bitmap.width === 0 || it.bitmap.height === 0) continue; const mt = it.metrics.localGlyph ? ae : 1, Ct = { x: 0, y: 0, w: it.bitmap.width + 2 * mt, h: it.bitmap.height + 2 * mt }; ge.push(Ct), Ye[Qe] = Ct; } } const { w: Le, h: Ce } = i.C(ge), Be = new i.dW({ width: Le || 1, height: Ce || 1 }); for (const qe in re) { const Pe = re[qe]; for (const Ye in Pe.glyphs) { const Qe = Pe.glyphs[+Ye]; if (!Qe || Qe.bitmap.width === 0 || Qe.bitmap.height === 0) continue; const it = le[qe][Ye], mt = Qe.metrics.localGlyph ? ae : 1; i.dW.copy(Qe.bitmap, Be, { x: 0, y: 0 }, { x: it.x + mt, y: it.y + mt }, Qe.bitmap); } } this.image = Be, this.positions = le; } } i.dV(ce, "GlyphAtlas"); class Te { constructor(re) { this.tileID = new i.aG(re.tileID.overscaledZ, re.tileID.wrap, re.tileID.canonical.z, re.tileID.canonical.x, re.tileID.canonical.y), this.tileZoom = re.tileZoom, this.uid = re.uid, this.zoom = re.zoom, this.lut = re.lut, this.canonical = re.tileID.canonical, this.pixelRatio = re.pixelRatio, this.tileSize = re.tileSize, this.source = re.source, this.scope = re.scope, this.overscaling = this.tileID.overscaleFactor(), this.showCollisionBoxes = re.showCollisionBoxes, this.collectResourceTiming = !!re.request && re.request.collectResourceTiming, this.promoteId = re.promoteId, this.isSymbolTile = re.isSymbolTile, this.tileTransform = i.aQ(re.tileID.canonical, re.projection), this.projection = re.projection, this.worldview = re.worldview, this.localizableLayerIds = re.localizableLayerIds, this.brightness = re.brightness, this.extraShadowCaster = !!re.extraShadowCaster, this.tessellationStep = re.tessellationStep, this.scaleFactor = re.scaleFactor; } parse(re, le, ge, Le, Ce) { this.status = "parsing", this.data = re, this.collisionBoxArray = new i.aW(); const Be = new i.dY(Object.keys(re.layers).sort()), qe = new i.dZ(this.tileID, this.promoteId); qe.bucketLayerIDs = []; const Pe = {}, Ye = new i.d_(256, 256), Qe = { featureIndex: qe, iconDependencies: {}, patternDependencies: {}, glyphDependencies: {}, lineAtlas: Ye, availableImages: ge, brightness: this.brightness, scaleFactor: this.scaleFactor }, it = le.familiesBySource[this.source]; for (const ri in it) { const Ki = re.layers[ri]; if (!Ki) continue; let Ni = !1, Ei = !1, $i = !1; for (const Gs of it[ri]) Gs[0].type === "symbol" ? Ni = !0 : Ei = !0, Gs[0].is3D() && Gs[0].type !== "model" && ($i = !0); if (this.extraShadowCaster && !$i || this.isSymbolTile === !0 && !Ni || this.isSymbolTile === !1 && !Ei) continue; Ki.version === 1 && i.w(`Vector tile source "${this.source}" layer "${ri}" does not use vector tile spec v2 and therefore may have some rendering errors.`); const Hi = Be.encode(ri), Xn = []; for (let Gs = 0, ps = 0; Gs < Ki.length; Gs++) { const vs = Ki.feature(Gs), ra = qe.getId(vs, ri); if (this.localizableLayerIds && this.localizableLayerIds.has(ri)) { const Er = vs.properties ? vs.properties.worldview : null; if (this.worldview && typeof Er == "string") if (Er === "all") vs.properties.$localized = !0; else { if (!Er.split(",").includes(this.worldview)) continue; vs.properties.$localized = !0, vs.properties.worldview = this.worldview; } } Xn.push({ feature: vs, id: ra, index: ps, sourceLayerIndex: Hi }), ps++; } for (const Gs of it[ri]) { const ps = Gs[0]; (!this.extraShadowCaster || ps.is3D() && ps.type !== "model") && (this.isSymbolTile !== void 0 && ps.type === "symbol" !== this.isSymbolTile || ps.minzoom && this.zoom < Math.floor(ps.minzoom) || ps.maxzoom && this.zoom >= ps.maxzoom || ps.visibility !== "none" && (be(Gs, this.zoom, Qe.brightness, ge), (Pe[ps.id] = ps.createBucket({ index: qe.bucketLayerIDs.length, layers: Gs, zoom: this.zoom, lut: this.lut, canonical: this.canonical, pixelRatio: this.pixelRatio, overscaling: this.overscaling, collisionBoxArray: this.collisionBoxArray, sourceLayerIndex: Hi, sourceID: this.source, projection: this.projection.spec, tessellationStep: this.tessellationStep })).populate(Xn, Qe, this.tileID.canonical, this.tileTransform), qe.bucketLayerIDs.push(Gs.map((vs) => i.aC(vs.id, vs.scope))))); } } let mt, Ct, It, Kt; Ye.trim(); const di = { type: "maybePrepare", isSymbolTile: this.isSymbolTile, zoom: this.zoom }, li = () => { if (mt) return this.status = "done", Ce(mt); if (this.extraShadowCaster) this.status = "done", Ce(null, { buckets: i.bj(Pe).filter((ri) => !ri.isEmpty()), featureIndex: qe, collisionBoxArray: null, glyphAtlasImage: null, lineAtlas: null, imageAtlas: null, brightness: Qe.brightness, glyphMap: null, iconMap: null, glyphPositions: null }); else if (Ct && It && Kt) { const ri = new ce(Ct), Ki = new i.e1(It, Kt, this.lut); for (const Ni in Pe) { const Ei = Pe[Ni]; Ei instanceof i.aX ? (be(Ei.layers, this.zoom, Qe.brightness, ge), i.e2(Ei, Ct, ri.positions, It, Ki.iconPositions, this.showCollisionBoxes, ge, this.tileID.canonical, this.tileZoom, this.projection, this.scaleFactor, this.pixelRatio, this.brightness)) : Ei.hasPattern && (Ei instanceof i.b1 || Ei instanceof i.b2 || Ei instanceof i.d5) && (be(Ei.layers, this.zoom, Qe.brightness, ge), Ei.addFeatures(Qe, this.tileID.canonical, Ki.patternPositions, ge, this.tileTransform, this.brightness)); } this.status = "done", Ce(null, { buckets: i.bj(Pe).filter((Ni) => !Ni.isEmpty()), featureIndex: qe, collisionBoxArray: this.collisionBoxArray, glyphAtlasImage: ri.image, lineAtlas: Ye, imageAtlas: Ki, brightness: Qe.brightness }); } }; if (!this.extraShadowCaster) { const ri = i.d$(Qe.glyphDependencies, (Ei) => Object.keys(Ei).map(Number)); Object.keys(ri).length ? Le.send("getGlyphs", { uid: this.uid, stacks: ri, scope: this.scope }, (Ei, $i) => { mt || (mt = Ei, Ct = $i, li()); }, void 0, !1, di) : Ct = {}; const Ki = Object.keys(Qe.iconDependencies); Ki.length ? Le.send("getImages", { icons: Ki, source: this.source, scope: this.scope, tileID: this.tileID, type: "icons" }, (Ei, $i) => { if (mt) return; mt = Ei; const Hi = {}; Object.values($i).some((Xn) => Xn.usvg) ? this.rasterize(Le, Hi, $i, Qe.iconDependencies, () => { It = Hi, li(); }) : (this.fillImageMap(Hi, Qe.iconDependencies, $i), It = Hi, li()); }, void 0, !1, di) : It = {}; const Ni = Object.keys(Qe.patternDependencies); Ni.length ? Le.send("getImages", { icons: Ni, source: this.source, scope: this.scope, tileID: this.tileID, type: "patterns" }, (Ei, $i) => { if (!mt) { mt = Ei; const Hi = {}; Object.values($i).some((Xn) => Xn.usvg) ? this.rasterize(Le, Hi, $i, Qe.patternDependencies, () => { Kt = Hi, li(); }) : (this.fillImageMap(Hi, Qe.patternDependencies, $i), Kt = Hi, li()); } }, void 0, !1, di) : Kt = {}; } li(); } fillImageMap(re, le, ge) { for (const Le in ge) { const Ce = le[Le] || []; for (const Be of Ce) ge[Be.id].usvg || (re[Be.serialize()] = ge[Be.id]); } } getImageTaskQueue(re, le, ge) { const Le = {}; for (const Ce in le) { const Be = ge[Ce] || []; for (const qe of Be) { const Pe = qe.serialize(); le[qe.id].usvg ? Le[Pe] || (Le[Pe] = qe) : re[Pe] = le[qe.id]; } } return Le; } rasterize(re, le, ge, Le, Ce) { const Be = this.getImageTaskQueue(le, ge, Le); this.rasterizeTask = re.send("rasterizeImages", { scope: this.scope, imageTasks: Be }, (qe, Pe) => { if (!qe) for (const Ye in Pe) { const { id: Qe } = i.e0.deserializeFromString(Ye); le[Ye] = Object.assign({}, ge[Qe], { data: Pe[Ye] }); } Ce(); }); } cancelRasterize() { this.rasterizeTask && this.rasterizeTask.cancel(); } } function be(Ke, re, le, ge) { const Le = new i.a8(re, { brightness: le }); for (const Ce of Ke) Ce.recalculate(Le, ge); } class Ze extends i.E { constructor(re, le, ge, Le, Ce, Be) { super(), this.actor = re, this.layerIndex = le, this.availableImages = ge, this.loadVectorData = Ce || i.aD, this.loading = {}, this.loaded = {}, this.deduped = new i.aB(re.scheduler), this.isSpriteLoaded = Le, this.scheduler = re.scheduler, this.brightness = Be; } loadTile(re, le) { const ge = re.uid, Le = re && re.request, Ce = Le && Le.collectResourceTiming, Be = this.loading[ge] = new Te(re); Be.abort = this.loadVectorData(re, (qe, Pe) => { const Ye = !this.loading[ge]; if (delete this.loading[ge], Be.cancelRasterize(), Ye || qe || !Pe) return Be.status = "done", Ye || (this.loaded[ge] = Be), le(qe); const Qe = Pe.rawData, it = {}; Pe.expires && (it.expires = Pe.expires), Pe.cacheControl && (it.cacheControl = Pe.cacheControl), Be.vectorTile = Pe.vectorTile || new i.e3.VectorTile(new i.bh(Qe)); const mt = () => { Be.parse(Be.vectorTile, this.layerIndex, this.availableImages, this.actor, (Ct, It) => { if (Ct || !It) return le(Ct); const Kt = {}; if (Ce) { const di = O(Le); di.length > 0 && (Kt.resourceTiming = JSON.parse(JSON.stringify(di))); } le(null, i.l({ rawTileData: Qe.slice(0) }, It, it, Kt)); }); }; this.isSpriteLoaded ? mt() : this.once("isSpriteLoaded", () => { this.scheduler ? this.scheduler.add(mt, { type: "parseTile", isSymbolTile: re.isSymbolTile, zoom: re.tileZoom }) : mt(); }), this.loaded = this.loaded || {}, this.loaded[ge] = Be; }); } reloadTile(re, le) { const ge = this.loaded, Le = re.uid; if (ge && ge[Le]) { const Ce = ge[Le]; Ce.scaleFactor = re.scaleFactor, Ce.showCollisionBoxes = re.showCollisionBoxes, Ce.projection = re.projection, Ce.brightness = re.brightness, Ce.tileTransform = i.aQ(re.tileID.canonical, re.projection), Ce.extraShadowCaster = re.extraShadowCaster, Ce.lut = re.lut; const Be = (qe, Pe) => { const Ye = Ce.reloadCallback; Ye && (delete Ce.reloadCallback, Ce.parse(Ce.vectorTile, this.layerIndex, this.availableImages, this.actor, Ye)), le(qe, Pe); }; Ce.status === "parsing" ? Ce.reloadCallback = Be : Ce.status === "done" && (Ce.vectorTile ? Ce.parse(Ce.vectorTile, this.layerIndex, this.availableImages, this.actor, Be) : Be()); } else le(null, void 0); } abortTile(re, le) { const ge = re.uid, Le = this.loading[ge]; Le && (Le.abort && Le.abort(), delete this.loading[ge]), le(); } removeTile(re, le) { const ge = this.loaded, Le = re.uid; ge && ge[Le] && delete ge[Le], le(); } } class je { loadTile(re, le) { const { uid: ge, encoding: Le, rawImageData: Ce, padding: Be } = re, qe = ImageBitmap && Ce instanceof ImageBitmap ? this.getImageData(Ce, Be) : Ce; le(null, new i.e4(ge, qe, Le, Be < 1)); } getImageData(re, le) { this.offscreenCanvas && this.offscreenCanvasContext || (this.offscreenCanvas = new OffscreenCanvas(re.width, re.height), this.offscreenCanvasContext = this.offscreenCanvas.getContext("2d", { willReadFrequently: !0 })), this.offscreenCanvas.width = re.width, this.offscreenCanvas.height = re.height, this.offscreenCanvasContext.drawImage(re, 0, 0, re.width, re.height); const ge = this.offscreenCanvasContext.getImageData(-le, -le, re.width + 2 * le, re.height + 2 * le); return this.offscreenCanvasContext.clearRect(0, 0, this.offscreenCanvas.width, this.offscreenCanvas.height), ge; } } i.bg.setPbf(i.bh); class ot { decodeRasterArray({ task: re, buffer: le }, ge) { i.bg.performDecoding(le, re).then((Le) => { ge(null, Le); }, (Le) => { ge(Le); }); } } const vt = i.e3.VectorTileFeature.prototype.toGeoJSON; class ht { constructor(re) { this._feature = re, this.extent = i.ag, this.type = re.type, this.properties = re.tags, "id" in re && !isNaN(re.id) && (this.id = parseInt(re.id, 10)); } loadGeometry() { if (this._feature.type === 1) { const re = []; for (const le of this._feature.geometry) re.push([new i.P(le[0], le[1])]); return re; } { const re = []; for (const le of this._feature.geometry) { const ge = []; for (const Le of le) ge.push(new i.P(Le[0], Le[1])); re.push(ge); } return re; } } toGeoJSON(re, le, ge) { return vt.call(this, re, le, ge); } } class gt { constructor(re) { this.layers = { _geojsonTileLayer: this }, this.name = "_geojsonTileLayer", this.extent = i.ag, this.length = re.length, this._features = re; } feature(re) { return new ht(this._features[re]); } } const Vt = 64 / 4096, pt = 128; class Gt { constructor() { this.features = /* @__PURE__ */ new Map(); } clear() { this.features.clear(); } load(re = [], le) { for (const ge of re) { const Le = ge.id; if (Le == null) continue; let Ce = this.features.get(Le); Ce && this.updateCache(Ce, le), ge.geometry ? (Ce = kt(ge), this.updateCache(Ce, le), this.features.set(Le, Ce)) : this.features.delete(Le), this.updateCache(Ce, le); } } updateCache(re, le) { for (const { canonical: ge, uid: Le } of Object.values(le)) { const { z: Ce, x: Be, y: qe } = ge; ui(re, Math.pow(2, Ce), Be, qe) && delete le[Le]; } } getTile(re, le, ge) { const Le = Math.pow(2, re), Ce = []; for (const Be of this.features.values()) ui(Be, Le, le, ge) && Ce.push(hn(Be, Le, le, ge)); return { features: Ce }; } getFeatures() { return [...this.features.values()]; } } function ui({ minX: Ke, minY: re, maxX: le, maxY: ge }, Le, Ce, Be) { return Ke < (Ce + 1 + Vt) / Le && re < (Be + 1 + Vt) / Le && le > (Ce - Vt) / Le && ge > (Be - Vt) / Le; } function kt(Ke) { const { id: re, geometry: le, properties: ge } = Ke; if (!le) return; if (le.type === "GeometryCollection") throw new Error("GeometryCollection not supported in dynamic mode."); const { type: Le, coordinates: Ce } = le, Be = { id: re, type: 1, geometry: [], tags: ge, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 }, qe = Be.geometry; if (Le === "Point") Pt(Ce, qe, Be); else if (Le === "MultiPoint") for (const Pe of Ce) Pt(Pe, qe, Be); else if (Le === "LineString") Be.type = 2, Mi(Ce, qe, Be); else if (Le === "MultiLineString") Be.type = 2, Pn(Ce, qe, Be); else if (Le === "Polygon") Be.type = 3, Pn(Ce, qe, Be, !0); else { if (Le !== "MultiPolygon") throw new Error("Input data is not a valid GeoJSON object."); Be.type = 3; for (const Pe of Ce) Pn(Pe, qe, Be, !0); } return Be; } function Pt([Ke, re], le, ge) { const Le = i.at(Ke); let Ce = i.aA(re); Ce = Ce < 0 ? 0 : Ce > 1 ? 1 : Ce, le.push(Le, Ce), ge.minX = Math.min(ge.minX, Le), ge.minY = Math.min(ge.minY, Ce), ge.maxX = Math.max(ge.maxX, Le), ge.maxY = Math.max(ge.maxY, Ce); } function Mi(Ke, re, le, ge = !1, Le = !1) { const Ce = []; for (const Be of Ke) Pt(Be, Ce, le); re.push(Ce), ge && function(Be, qe) { let Pe = 0; for (let Ye = 0, Qe = Be.length, it = Qe - 2; Ye < Qe; it = Ye, Ye += 2) Pe += (Be[Ye] - Be[it]) * (Be[Ye + 1] + Be[it + 1]); if (Pe > 0 === qe) for (let Ye = 0, Qe = Be.length; Ye < Qe / 2; Ye += 2) { const it = Be[Ye], mt = Be[Ye + 1]; Be[Ye] = Be[Qe - 2 - Ye], Be[Ye + 1] = Be[Qe - 1 - Ye], Be[Qe - 2 - Ye] = it, Be[Qe - 1 - Ye] = mt; } }(Ce, Le); } function Pn(Ke, re, le, ge = !1) { for (let Le = 0; Le < Ke.length; Le++) Mi(Ke[Le], re, le, ge, Le === 0); } function hn(Ke, re, le, ge) { const { id: Le, type: Ce, geometry: Be, tags: qe } = Ke, Pe = []; if (Ce === 1) (function(Ye, Qe, it, mt, Ct) { for (let It = 0; It < Ye.length; It += 2) { const Kt = Math.round(i.ag * (Ye[It + 0] * Qe - it)), di = Math.round(i.ag * (Ye[It + 1] * Qe - mt)); Ct.push([Kt, di]); } })(Be, re, le, ge, Pe); else for (const Ye of Be) Ht(Ye, re, le, ge, Pe); return { id: Le, type: Ce, geometry: Pe, tags: qe }; } function Ht(Ke, re, le, ge, Le) { const Ce = -pt, Be = i.ag + pt; let qe; for (let Pe = 0; Pe < Ke.length - 2; Pe += 2) { let Ye = Math.round(i.ag * (Ke[Pe + 0] * re - le)), Qe = Math.round(i.ag * (Ke[Pe + 1] * re - ge)), it = Math.round(i.ag * (Ke[Pe + 2] * re - le)), mt = Math.round(i.ag * (Ke[Pe + 3] * re - ge)); const Ct = it - Ye, It = mt - Qe; Ye < Ce && it < Ce || (Ye < Ce ? (Qe += Math.round(It * ((Ce - Ye) / Ct)), Ye = Ce) : it < Ce && (mt = Qe + Math.round(It * ((Ce - Ye) / Ct)), it = Ce), Qe < Ce && mt < Ce || (Qe < Ce ? (Ye += Math.round(Ct * ((Ce - Qe) / It)), Qe = Ce) : mt < Ce && (it = Ye + Math.round(Ct * ((Ce - Qe) / It)), mt = Ce), Ye >= Be && it >= Be || (Ye >= Be ? (Qe += Math.round(It * ((Be - Ye) / Ct)), Ye = Be) : it >= Be && (mt = Qe + Math.round(It * ((Be - Ye) / Ct)), it = Be), Qe >= Be && mt >= Be || (Qe >= Be ? (Ye += Math.round(Ct * ((Be - Qe) / It)), Qe = Be) : mt >= Be && (it = Ye + Math.round(Ct * ((Be - Qe) / It)), mt = Be), qe && Ye === qe[qe.length - 1][0] && Qe === qe[qe.length - 1][1] || (qe = [[Ye, Qe]], Le.push(qe)), qe.push([it, mt]))))); } } var Si, Ji, fi, jt = { exports: {} }, ni = function() { if (fi) return jt.exports; fi = 1; var Ke = i.e7(), re = function() { if (Ji) return Si; Ji = 1; var Qe = i.e5(), it = i.e6().VectorTileFeature; function mt(It, Kt) { this.options = Kt || {}, this.features = It, this.length = It.length; } function Ct(It, Kt) { this.id = typeof It.id == "number" ? It.id : void 0, this.type = It.type, this.rawGeometry = It.type === 1 ? [It.geometry] : It.geometry, this.properties = It.tags, this.extent = Kt || 4096; } return Si = mt, mt.prototype.feature = function(It) { return new Ct(this.features[It], this.options.extent); }, Ct.prototype.loadGeometry = function() { var It = this.rawGeometry; this.geometry = []; for (var Kt = 0; Kt < It.length; Kt++) { for (var di = It[Kt], li = [], ri = 0; ri < di.length; ri++) li.push(new Qe(di[ri][0], di[ri][1])); this.geometry.push(li); } return this.geometry; }, Ct.prototype.bbox = function() { this.geometry || this.loadGeometry(); for (var It = this.geometry, Kt = 1 / 0, di = -1 / 0, li = 1 / 0, ri = -1 / 0, Ki = 0; Ki < It.length; Ki++) for (var Ni = It[Ki], Ei = 0; Ei < Ni.length; Ei++) { var $i = Ni[Ei]; Kt = Math.min(Kt, $i.x), di = Math.max(di, $i.x), li = Math.min(li, $i.y), ri = Math.max(ri, $i.y); } return [Kt, li, di, ri]; }, Ct.prototype.toGeoJSON = it.prototype.toGeoJSON, Si; }(); function le(Qe) { var it = new Ke(); return function(mt, Ct) { for (var It in mt.layers) Ct.writeMessage(3, ge, mt.layers[It]); }(Qe, it), it.finish(); } function ge(Qe, it) { var mt; it.writeVarintField(15, Qe.version || 1), it.writeStringField(1, Qe.name || ""), it.writeVarintField(5, Qe.extent || 4096); var Ct = { keys: [], values: [], keycache: {}, valuecache: {} }; for (mt = 0; mt < Qe.length; mt++) Ct.feature = Qe.feature(mt), it.writeMessage(2, Le, Ct); var It = Ct.keys; for (mt = 0; mt < It.length; mt++) it.writeStringField(3, It[mt]); var Kt = Ct.values; for (mt = 0; mt < Kt.length; mt++) it.writeMessage(4, Ye, Kt[mt]); } function Le(Qe, it) { var mt = Qe.feature; mt.id !== void 0 && it.writeVarintField(1, mt.id), it.writeMessage(2, Ce, Qe), it.writeVarintField(3, mt.type), it.writeMessage(4, Pe, mt); } function Ce(Qe, it) { var mt = Qe.feature, Ct = Qe.keys, It = Qe.values, Kt = Qe.keycache, di = Qe.valuecache; for (var li in mt.properties) { var ri = mt.properties[li], Ki = Kt[li]; if (ri !== null) { Ki === void 0 && (Ct.push(li), Kt[li] = Ki = Ct.length - 1), it.writeVarint(Ki); var Ni = typeof ri; Ni !== "string" && Ni !== "boolean" && Ni !== "number" && (ri = JSON.stringify(ri)); var Ei = Ni + ":" + ri, $i = di[Ei]; $i === void 0 && (It.push(ri), di[Ei] = $i = It.length - 1), it.writeVarint($i); } } } function Be(Qe, it) { return (it << 3) + (7 & Qe); } function qe(Qe) { return Qe << 1 ^ Qe >> 31; } function Pe(Qe, it) { for (var mt = Qe.loadGeometry(), Ct = Qe.type, It = 0, Kt = 0, di = mt.length, li = 0; li < di; li++) { var ri = mt[li], Ki = 1; Ct === 1 && (Ki = ri.length), it.writeVarint(Be(1, Ki)); for (var Ni = Ct === 3 ? ri.length - 1 : ri.length, Ei = 0; Ei < Ni; Ei++) { Ei === 1 && Ct !== 1 && it.writeVarint(Be(2, Ni - 1)); var $i = ri[Ei].x - It, Hi = ri[Ei].y - Kt; it.writeVarint(qe($i)), it.writeVarint(qe(Hi)), It += $i, Kt += Hi; } Ct === 3 && it.writeVarint(Be(7, 1)); } } function Ye(Qe, it) { var mt = typeof Qe; mt === "string" ? it.writeStringField(1, Qe) : mt === "boolean" ? it.writeBooleanField(7, Qe) : mt === "number" && (Qe % 1 != 0 ? it.writeDoubleField(3, Qe) : Qe < 0 ? it.writeSVarintField(6, Qe) : it.writeVarintField(5, Qe)); } return jt.exports = le, jt.exports.fromVectorTileJs = le, jt.exports.fromGeojsonVt = function(Qe, it) { it = it || {}; var mt = {}; for (var Ct in Qe) mt[Ct] = new re(Qe[Ct].features, it), mt[Ct].name = Ct, mt[Ct].version = it.version, mt[Ct].extent = it.extent; return le({ layers: mt }); }, jt.exports.GeoJSONWrapper = re, jt.exports; }(), Gi = i.e8(ni); const an = { minZoom: 0, maxZoom: 16, minPoints: 2, radius: 40, extent: 512, nodeSize: 64, log: !1, generateId: !1, reduce: null, map: (Ke) => Ke }, qt = Math.fround || (ln = new Float32Array(1), (Ke) => (ln[0] = +Ke, ln[0])); var ln; const Di = 3, xi = 5, Cs = 6; class xs { constructor(re) { this.options = Object.assign(Object.create(an), re), this.trees = new Array(this.options.maxZoom + 1), this.stride = this.options.reduce ? 7 : 6, this.clusterProps = []; } load(re) { const { log: le, minZoom: ge, maxZoom: Le } = this.options; le && console.time("total time"); const Ce = `prepare ${re.length} points`; le && console.time(Ce), this.points = re; const Be = []; for (let Pe = 0; Pe < re.length; Pe++) { const Ye = re[Pe]; if (!Ye.geometry) continue; const [Qe, it] = Ye.geometry.coordinates, mt = qt(Vs(Qe)), Ct = qt(Us(it)); Be.push(mt, Ct, 1 / 0, Pe, -1, 1), this.options.reduce && Be.push(0); } let qe = this.trees[Le + 1] = this._createTree(Be); le && console.timeEnd(Ce); for (let Pe = Le; Pe >= ge; Pe--) { const Ye = +Date.now(); qe = this.trees[Pe] = this._createTree(this._cluster(qe, Pe)), le && console.log("z%d: %d clusters in %dms", Pe, qe.numItems, +Date.now() - Ye); } return le && console.timeEnd("total time"), this; } getClusters(re, le) { let ge = ((re[0] + 180) % 360 + 360) % 360 - 180; const Le = Math.max(-90, Math.min(90, re[1])); let Ce = re[2] === 180 ? 180 : ((re[2] + 180) % 360 + 360) % 360 - 180; const Be = Math.max(-90, Math.min(90, re[3])); if (re[2] - re[0] >= 360) ge = -180, Ce = 180; else if (ge > Ce) { const it = this.getClusters([ge, Le, 180, Be], le), mt = this.getClusters([-180, Le, Ce, Be], le); return it.concat(mt); } const qe = this.trees[this._limitZoom(le)], Pe = qe.range(Vs(ge), Us(Be), Vs(Ce), Us(Le)), Ye = qe.data, Qe = []; for (const it of Pe) { const mt = this.stride * it; Qe.push(Ye[mt + xi] > 1 ? Is(Ye, mt, this.clusterProps) : this.points[Ye[mt + Di]]); } return Qe; } getChildren(re) { const le = this._getOriginId(re), ge = this._getOriginZoom(re), Le = "No cluster with the specified id.", Ce = this.trees[ge]; if (!Ce) throw new Error(Le); const Be = Ce.data; if (le * this.stride >= Be.length) throw new Error(Le); const qe = this.options.radius / (this.options.extent * Math.pow(2, ge - 1)), Pe = Ce.within(Be[le * this.stride], Be[le * this.stride + 1], qe), Ye = []; for (const Qe of Pe) { const it = Qe * this.stride; Be[it + 4] === re && Ye.push(Be[it + xi] > 1 ? Is(Be, it, this.clusterProps) : this.points[Be[it + Di]]); } if (Ye.length === 0) throw new Error(Le); return Ye; } getLeaves(re, le, ge) { const Le = []; return this._appendLeaves(Le, re, le = le || 10, ge = ge || 0, 0), Le; } getTile(re, le, ge) { const Le = this.trees[this._limitZoom(re)], Ce = Math.pow(2, re), { extent: Be, radius: qe } = this.options, Pe = qe / Be, Ye = (ge - Pe) / Ce, Qe = (ge + 1 + Pe) / Ce, it = { features: [] }; return this._addTileFeatures(Le.range((le - Pe) / Ce, Ye, (le + 1 + Pe) / Ce, Qe), Le.data, le, ge, Ce, it), le === 0 && this._addTileFeatures(Le.range(1 - Pe / Ce, Ye, 1, Qe), Le.data, Ce, ge, Ce, it), le === Ce - 1 && this._addTileFeatures(Le.range(0, Ye, Pe / Ce, Qe), Le.data, -1, ge, Ce, it), it.features.length ? it : null; } getClusterExpansionZoom(re) { let le = this._getOriginZoom(re) - 1; for (; le <= this.options.maxZoom; ) { const ge = this.getChildren(re); if (le++, ge.length !== 1) break; re = ge[0].properties.cluster_id; } return le; } _appendLeaves(re, le, ge, Le, Ce) { const Be = this.getChildren(le); for (const qe of Be) { const Pe = qe.properties; if (Pe && Pe.cluster ? Ce + Pe.point_count <= Le ? Ce += Pe.point_count : Ce = this._appendLeaves(re, Pe.cluster_id, ge, Le, Ce) : Ce < Le ? Ce++ : re.push(qe), re.length === ge) break; } return Ce; } _createTree(re) { const le = new i.bE(re.length / this.stride | 0, this.options.nodeSize, Float32Array); for (let ge = 0; ge < re.length; ge += this.stride) le.add(re[ge], re[ge + 1]); return le.finish(), le.data = re, le; } _addTileFeatures(re, le, ge, Le, Ce, Be) { for (const qe of re) { const Pe = qe * this.stride, Ye = le[Pe + xi] > 1; let Qe, it, mt; if (Ye) Qe = De(le, Pe, this.clusterProps), it = le[Pe], mt = le[Pe + 1]; else { const Kt = this.points[le[Pe + Di]]; Qe = Kt.properties; const [di, li] = Kt.geometry.coordinates; it = Vs(di), mt = Us(li); } const Ct = { type: 1, geometry: [[Math.round(this.options.extent * (it * Ce - ge)), Math.round(this.options.extent * (mt * Ce - Le))]], tags: Qe }; let It; It = Ye || this.options.generateId ? le[Pe + Di] : this.points[le[Pe + Di]].id, It !== void 0 && (Ct.id = It), Be.features.push(Ct); } } _limitZoom(re) { return Math.max(this.options.minZoom, Math.min(Math.floor(+re), this.options.maxZoom + 1)); } _cluster(re, le) { const { radius: ge, extent: Le, reduce: Ce, minPoints: Be } = this.options, qe = ge / (Le * Math.pow(2, le)), Pe = re.data, Ye = [], Qe = this.stride; for (let it = 0; it < Pe.length; it += Qe) { if (Pe[it + 2] <= le) continue; Pe[it + 2] = le; const mt = Pe[it], Ct = Pe[it + 1], It = re.within(Pe[it], Pe[it + 1], qe), Kt = Pe[it + xi]; let di = Kt; for (const li of It) { const ri = li * Qe; Pe[ri + 2] > le && (di += Pe[ri + xi]); } if (di > Kt && di >= Be) { let li, ri = mt * Kt, Ki = Ct * Kt, Ni = -1; const Ei = (it / Qe << 5) + (le + 1) + this.points.length; for (const $i of It) { const Hi = $i * Qe; if (Pe[Hi + 2] <= le) continue; Pe[Hi + 2] = le; const Xn = Pe[Hi + xi]; ri += Pe[Hi] * Xn, Ki += Pe[Hi + 1] * Xn, Pe[Hi + 4] = Ei, Ce && (li || (li = this._map(Pe, it, !0), Ni = this.clusterProps.length, this.clusterProps.push(li)), Ce(li, this._map(Pe, Hi))); } Pe[it + 4] = Ei, Ye.push(ri / di, Ki / di, 1 / 0, Ei, -1, di), Ce && Ye.push(Ni); } else { for (let li = 0; li < Qe; li++) Ye.push(Pe[it + li]); if (di > 1) for (const li of It) { const ri = li * Qe; if (!(Pe[ri + 2] <= le)) { Pe[ri + 2] = le; for (let Ki = 0; Ki < Qe; Ki++) Ye.push(Pe[ri + Ki]); } } } } return Ye; } _getOriginId(re) { return re - this.points.length >> 5; } _getOriginZoom(re) { return (re - this.points.length) % 32; } _map(re, le, ge) { if (re[le + xi] > 1) { const Be = this.clusterProps[re[le + Cs]]; return ge ? Object.assign({}, Be) : Be; } const Le = this.points[re[le + Di]].properties, Ce = this.options.map(Le); return ge && Ce === Le ? Object.assign({}, Ce) : Ce; } } function Is(Ke, re, le) { return { type: "Feature", id: Ke[re + Di], properties: De(Ke, re, le), geometry: { type: "Point", coordinates: [(ge = Ke[re], 360 * (ge - 0.5)), Zr(Ke[re + 1])] } }; var ge; } function De(Ke, re, le) { const ge = Ke[re + xi], Le = ge >= 1e4 ? `${Math.round(ge / 1e3)}k` : ge >= 1e3 ? Math.round(ge / 100) / 10 + "k" : ge, Ce = Ke[re + Cs], Be = Ce === -1 ? {} : Object.assign({}, le[Ce]); return Object.assign(Be, { cluster: !0, cluster_id: Ke[re + Di], point_count: ge, point_count_abbreviated: Le }); } function Vs(Ke) { return Ke / 360 + 0.5; } function Us(Ke) { const re = Math.sin(Ke * Math.PI / 180), le = 0.5 - 0.25 * Math.log((1 + re) / (1 - re)) / Math.PI; return le < 0 ? 0 : le > 1 ? 1 : le; } function Zr(Ke) { const re = (180 - 360 * Ke) * Math.PI / 180; return 360 * Math.atan(Math.exp(re)) / Math.PI - 90; } function Et(Ke, re, le, ge) { let Le = ge; const Ce = re + (le - re >> 1); let Be, qe = le - re; const Pe = Ke[re], Ye = Ke[re + 1], Qe = Ke[le], it = Ke[le + 1]; for (let mt = re + 3; mt < le; mt += 3) { const Ct = Ws(Ke[mt], Ke[mt + 1], Pe, Ye, Qe, it); if (Ct > Le) Be = mt, Le = Ct; else if (Ct === Le) { const It = Math.abs(mt - Ce); It < qe && (Be = mt, qe = It); } } Le > ge && (Be - re > 3 && Et(Ke, re, Be, ge), Ke[Be + 2] = Le, le - Be > 3 && Et(Ke, Be, le, ge)); } function Ws(Ke, re, le, ge, Le, Ce) { let Be = Le - le, qe = Ce - ge; if (Be !== 0 || qe !== 0) { const Pe = ((Ke - le) * Be + (re - ge) * qe) / (Be * Be + qe * qe); Pe > 1 ? (le = Le, ge = Ce) : Pe > 0 && (le += Be * Pe, ge += qe * Pe); } return Be = Ke - le, qe = re - ge, Be * Be + qe * qe; } function $n(Ke, re, le, ge) { const Le = { id: Ke ?? null, type: re, geometry: le, tags: ge, minX: 1 / 0, minY: 1 / 0, maxX: -1 / 0, maxY: -1 / 0 }; if (re === "Point" || re === "MultiPoint" || re === "LineString") $s(Le, le); else if (re === "Polygon") $s(Le, le[0]); else if (re === "MultiLineString") for (const Ce of le) $s(Le, Ce); else if (re === "MultiPolygon") for (const Ce of le) $s(Le, Ce[0]); return Le; } function $s(Ke, re) { for (let le = 0; le < re.length; le += 3) Ke.minX = Math.min(Ke.minX, re[le]), Ke.minY = Math.min(Ke.minY, re[le + 1]), Ke.maxX = Math.max(Ke.maxX, re[le]), Ke.maxY = Math.max(Ke.maxY, re[le + 1]); } function vi(Ke, re, le, ge) { if (!re.geometry) return; const Le = re.geometry.coordinates; if (Le && Le.length === 0) return; const Ce = re.geometry.type, Be = Math.pow(le.tolerance / ((1 << le.maxZoom) * le.extent), 2); let qe = [], Pe = re.id; if (le.promoteId ? Pe = re.properties[le.promoteId] : le.generateId && (Pe = ge || 0), Ce === "Point") kn(Le, qe); else if (Ce === "MultiPoint") for (const Ye of Le) kn(Ye, qe); else if (Ce === "LineString") Xs(Le, qe, Be, !1); else if (Ce === "MultiLineString") { if (le.lineMetrics) { for (const Ye of Le) qe = [], Xs(Ye, qe, Be, !1), Ke.push($n(Pe, "LineString", qe, re.properties)); return; } Hr(Le, qe, Be, !1); } else if (Ce === "Polygon") Hr(Le, qe, Be, !0); else { if (Ce !== "MultiPolygon") { if (Ce === "GeometryCollection") { for (const Ye of re.geometry.geometries) vi(Ke, { id: Pe, geometry: Ye, properties: re.properties }, le, ge); return; } throw new Error("Input data is not a valid GeoJSON object."); } for (const Ye of Le) { const Qe = []; Hr(Ye, Qe, Be, !0), qe.push(Qe); } } Ke.push($n(Pe, Ce, qe, re.properties)); } function kn(Ke, re) { re.push(qr(Ke[0]), Wr(Ke[1]), 0); } function Xs(Ke, re, le, ge) { let Le, Ce, Be = 0; for (let Pe = 0; Pe < Ke.length; Pe++) { const Ye = qr(Ke[Pe][0]), Qe = Wr(Ke[Pe][1]); re.push(Ye, Qe, 0), Pe > 0 && (Be += ge ? (Le * Qe - Ye * Ce) / 2 : Math.sqrt(Math.pow(Ye - Le, 2) + Math.pow(Qe - Ce, 2))), Le = Ye, Ce = Qe; } const qe = re.length - 3; re[2] = 1, Et(re, 0, qe, le), re[qe + 2] = 1, re.size = Math.abs(Be), re.start = 0, re.end = re.size; } function Hr(Ke, re, le, ge) { for (let Le = 0; Le < Ke.length; Le++) { const Ce = []; Xs(Ke[Le], Ce, le, ge), re.push(Ce); } } function qr(Ke) { return Ke / 360 + 0.5; } function Wr(Ke) { const re = Math.sin(Ke * Math.PI / 180), le = 0.5 - 0.25 * Math.log((1 + re) / (1 - re)) / Math.PI; return le < 0 ? 0 : le > 1 ? 1 : le; } function si(Ke, re, le, ge, Le, Ce, Be, qe) { if (ge /= re, Ce >= (le /= re) && Be < ge) return Ke; if (Be < le || Ce >= ge) return null; const Pe = []; for (const Ye of Ke) { const Qe = Ye.geometry; let it = Ye.type; const mt = Le === 0 ? Ye.minX : Ye.minY, Ct = Le === 0 ? Ye.maxX : Ye.maxY; if (mt >= le && Ct < ge) { Pe.push(Ye); continue; } if (Ct < le || mt >= ge) continue; let It = []; if (it === "Point" || it === "MultiPoint") fs(Qe, It, le, ge, Le); else if (it === "LineString") zn(Qe, It, le, ge, Le, !1, qe.lineMetrics); else if (it === "MultiLineString") An(Qe, It, le, ge, Le, !1); else if (it === "Polygon") An(Qe, It, le, ge, Le, !0); else if (it === "MultiPolygon") for (const Kt of Qe) { const di = []; An(Kt, di, le, ge, Le, !0), di.length && It.push(di); } if (It.length) { if (qe.lineMetrics && it === "LineString") { for (const Kt of It) Pe.push($n(Ye.id, it, Kt, Ye.tags)); continue; } it !== "LineString" && it !== "MultiLineString" || (It.length === 1 ? (it = "LineString", It = It[0]) : it = "MultiLineString"), it !== "Point" && it !== "MultiPoint" || (it = It.length === 3 ? "Point" : "MultiPoint"), Pe.push($n(Ye.id, it, It, Ye.tags)); } } return Pe.length ? Pe : null; } function fs(Ke, re, le, ge, Le) { for (let Ce = 0; Ce < Ke.length; Ce += 3) { const Be = Ke[Ce + Le]; Be >= le && Be <= ge && js(re, Ke[Ce], Ke[Ce + 1], Ke[Ce + 2]); } } function zn(Ke, re, le, ge, Le, Ce, Be) { let qe = Rn(Ke); const Pe = Le === 0 ? yo : xo; let Ye, Qe, it = Ke.start; for (let di = 0; di < Ke.length - 3; di += 3) { const li = Ke[di], ri = Ke[di + 1], Ki = Ke[di + 2], Ni = Ke[di + 3], Ei = Ke[di + 4], $i = Le === 0 ? li : ri, Hi = Le === 0 ? Ni : Ei; let Xn = !1; Be && (Ye = Math.sqrt(Math.pow(li - Ni, 2) + Math.pow(ri - Ei, 2))), $i < le ? Hi > le && (Qe = Pe(qe, li, ri, Ni, Ei, le), Be && (qe.start = it + Ye * Qe)) : $i > ge ? Hi < ge && (Qe = Pe(qe, li, ri, Ni, Ei, ge), Be && (qe.start = it + Ye * Qe)) : js(qe, li, ri, Ki), Hi < le && $i >= le && (Qe = Pe(qe, li, ri, Ni, Ei, le), Xn = !0), Hi > ge && $i <= ge && (Qe = Pe(qe, li, ri, Ni, Ei, ge), Xn = !0), !Ce && Xn && (Be && (qe.end = it + Ye * Qe), re.push(qe), qe = Rn(Ke)), Be && (it += Ye); } let mt = Ke.length - 3; const Ct = Ke[mt], It = Ke[mt + 1], Kt = Le === 0 ? Ct : It; Kt >= le && Kt <= ge && js(qe, Ct, It, Ke[mt + 2]), mt = qe.length - 3, Ce && mt >= 3 && (qe[mt] !== qe[0] || qe[mt + 1] !== qe[1]) && js(qe, qe[0], qe[1], qe[2]), qe.length && re.push(qe); } function Rn(Ke) { const re = []; return re.size = Ke.size, re.start = Ke.start, re.end = Ke.end, re; } function An(Ke, re, le, ge, Le, Ce) { for (const Be of Ke) zn(Be, re, le, ge, Le, Ce, !1); } function js(Ke, re, le, ge) { Ke.push(re, le, ge); } function yo(Ke, re, le, ge, Le, Ce) { const Be = (Ce - re) / (ge - re); return js(Ke, Ce, le + (Le - le) * Be, 1), Be; } function xo(Ke, re, le, ge, Le, Ce) { const Be = (Ce - le) / (Le - le); return js(Ke, re + (ge - re) * Be, Ce, 1), Be; } function vo(Ke, re) { const le = []; for (let ge = 0; ge < Ke.length; ge++) { const Le = Ke[ge], Ce = Le.type; let Be; if (Ce === "Point" || Ce === "MultiPoint" || Ce === "LineString") Be = yr(Le.geometry, re); else if (Ce === "MultiLineString" || Ce === "Polygon") { Be = []; for (const qe of Le.geometry) Be.push(yr(qe, re)); } else if (Ce === "MultiPolygon") { Be = []; for (const qe of Le.geometry) { const Pe = []; for (const Ye of qe) Pe.push(yr(Ye, re)); Be.push(Pe); } } le.push($n(Le.id, Ce, Be, Le.tags)); } return le; } function yr(Ke, re) { const le = []; le.size = Ke.size, Ke.start !== void 0 && (le.start = Ke.start, le.end = Ke.end); for (let ge = 0; ge < Ke.length; ge += 3) le.push(Ke[ge] + re, Ke[ge + 1], Ke[ge + 2]); return le; } function Mr(Ke, re) { if (Ke.transformed) return Ke; const le = 1 << Ke.z, ge = Ke.x, Le = Ke.y; for (const Ce of Ke.features) { const Be = Ce.geometry, qe = Ce.type; if (Ce.geometry = [], qe === 1) for (let Pe = 0; Pe < Be.length; Pe += 2) Ce.geometry.push(io(Be[Pe], Be[Pe + 1], re, le, ge, Le)); else for (let Pe = 0; Pe < Be.length; Pe++) { const Ye = []; for (let Qe = 0; Qe < Be[Pe].length; Qe += 2) Ye.push(io(Be[Pe][Qe], Be[Pe][Qe + 1], re, le, ge, Le)); Ce.geometry.push(Ye); } } return Ke.transformed = !0, Ke; } function io(Ke, re, le, ge, Le, Ce) { return [Math.round(le * (Ke * ge - Le)), Math.round(le * (re * ge - Ce))]; } function Ys(Ke, re, le, ge, Le) { const Ce = re === Le.maxZoom ? 0 : Le.tolerance / ((1 << re) * Le.extent), Be = { features: [], numPoints: 0, numSimplified: 0, numFeatures: Ke.length, source: null, x: le, y: ge, z: re, transformed: !1, minX: 2, minY: 1, maxX: -1, maxY: 0 }; for (const qe of Ke) Sr(Be, qe, Ce, Le); return Be; } function Sr(Ke, re, le, ge) { const Le = re.geometry, Ce = re.type, Be = []; if (Ke.minX = Math.min(Ke.minX, re.minX), Ke.minY = Math.min(Ke.minY, re.minY), Ke.maxX = Math.max(Ke.maxX, re.maxX), Ke.maxY = Math.max(Ke.maxY, re.maxY), Ce === "Point" || Ce === "MultiPoint") for (let qe = 0; qe < Le.length; qe += 3) Be.push(Le[qe], Le[qe + 1]), Ke.numPoints++, Ke.numSimplified++; else if (Ce === "LineString") mi(Be, Le, Ke, le, !1, !1); else if (Ce === "MultiLineString" || Ce === "Polygon") for (let qe = 0; qe < Le.length; qe++) mi(Be, Le[qe], Ke, le, Ce === "Polygon", qe === 0); else if (Ce === "MultiPolygon") for (let qe = 0; qe < Le.length; qe++) { const Pe = Le[qe]; for (let Ye = 0; Ye < Pe.length; Ye++) mi(Be, Pe[Ye], Ke, le, !0, Ye === 0); } if (Be.length) { let qe = re.tags || null; if (Ce === "LineString" && ge.lineMetrics) { qe = {}; for (const Ye in re.tags) qe[Ye] = re.tags[Ye]; qe.mapbox_clip_start = Le.start / Le.size, qe.mapbox_clip_end = Le.end / Le.size; } const Pe = { geometry: Be, type: Ce === "Polygon" || Ce === "MultiPolygon" ? 3 : Ce === "LineString" || Ce === "MultiLineString" ? 2 : 1, tags: qe }; re.id !== null && (Pe.id = re.id), Ke.features.push(Pe); } } function mi(Ke, re, le, ge, Le, Ce) { const Be = ge * ge; if (ge > 0 && re.size < (Le ? Be : ge)) return void (le.numPoints += re.length / 3); const qe = []; for (let Pe = 0; Pe < re.length; Pe += 3) (ge === 0 || re[Pe + 2] > Be) && (le.numSimplified++, qe.push(re[Pe], re[Pe + 1])), le.numPoints++; Le && function(Pe, Ye) { let Qe = 0; for (let it = 0, mt = Pe.length, Ct = mt - 2; it < mt; Ct = it, it += 2) Qe += (Pe[it] - Pe[Ct]) * (Pe[it + 1] + Pe[Ct + 1]); if (Qe > 0 === Ye) for (let it = 0, mt = Pe.length; it < mt / 2; it += 2) { const Ct = Pe[it], It = Pe[it + 1]; Pe[it] = Pe[mt - 2 - it], Pe[it + 1] = Pe[mt - 1 - it], Pe[mt - 2 - it] = Ct, Pe[mt - 1 - it] = It; } }(qe, Ce), Ke.push(qe); } const On = { maxZoom: 14, indexMaxZoom: 5, indexMaxPoints: 1e5, tolerance: 3, extent: 4096, buffer: 64, lineMetrics: !1, promoteId: null, generateId: !1, debug: 0 }; class Vn { constructor(re, le) { const ge = (le = this.options = function(Ce, Be) { for (const qe in Be) Ce[qe] = Be[qe]; return Ce; }(Object.create(On), le)).debug; if (ge && console.time("preprocess data"), le.maxZoom < 0 || le.maxZoom > 24) throw new Error("maxZoom should be in the 0-24 range"); if (le.promoteId && le.generateId) throw new Error("promoteId and generateId cannot be used together."); let Le = function(Ce, Be) { const qe = []; if (Ce.type === "FeatureCollection") for (let Pe = 0; Pe < Ce.features.length; Pe++) vi(qe, Ce.features[Pe], Be, Pe); else vi(qe, Ce.type === "Feature" ? Ce : { geometry: Ce }, Be); return qe; }(re, le); this.tiles = {}, this.tileCoords = [], ge && (console.timeEnd("preprocess data"), console.log("index: maxZoom: %d, maxPoints: %d", le.indexMaxZoom, le.indexMaxPoints), console.time("generate tiles"), this.stats = {}, this.total = 0), Le = function(Ce, Be) { const qe = Be.buffer / Be.extent; let Pe = Ce; const Ye = si(Ce, 1, -1 - qe, qe, 0, -1, 2, Be), Qe = si(Ce, 1, 1 - qe, 2 + qe, 0, -1, 2, Be); return (Ye || Qe) && (Pe = si(Ce, 1, -qe, 1 + qe, 0, -1, 2, Be) || [], Ye && (Pe = vo(Ye, 1).concat(Pe)), Qe && (Pe = Pe.concat(vo(Qe, -1)))), Pe; }(Le, le), Le.length && this.splitTile(Le, 0, 0, 0), ge && (Le.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))); } splitTile(re, le, ge, Le, Ce, Be, qe) { const Pe = [re, le, ge, Le], Ye = this.options, Qe = Ye.debug; for (; Pe.length; ) { Le = Pe.pop(), ge = Pe.pop(), le = Pe.pop(), re = Pe.pop(); const it = 1 << le, mt = Zi(le, ge, Le); let Ct = this.tiles[mt]; if (!Ct && (Qe > 1 && console.time("creation"), Ct = this.tiles[mt] = Ys(re, le, ge, Le, Ye), this.tileCoords.push({ z: le, x: ge, y: Le }), Qe)) { Qe > 1 && (console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)", le, ge, Le, Ct.numFeatures, Ct.numPoints, Ct.numSimplified), console.timeEnd("creation")); const Xn = `z${le}`; this.stats[Xn] = (this.stats[Xn] || 0) + 1, this.total++; } if (Ct.source = re, Ce == null) { if (le === Ye.indexMaxZoom || Ct.numPoints <= Ye.indexMaxPoints) continue; } else { if (le === Ye.maxZoom || le === Ce) continue; if (Ce != null) { const Xn = Ce - le; if (ge !== Be >> Xn || Le !== qe >> Xn) continue; } } if (Ct.source = null, re.length === 0) continue; Qe > 1 && console.time("clipping"); const It = 0.5 * Ye.buffer / Ye.extent, Kt = 0.5 - It, di = 0.5 + It, li = 1 + It; let ri = null, Ki = null, Ni = null, Ei = null, $i = si(re, it, ge - It, ge + di, 0, Ct.minX, Ct.maxX, Ye), Hi = si(re, it, ge + Kt, ge + li, 0, Ct.minX, Ct.maxX, Ye); re = null, $i && (ri = si($i, it, Le - It, Le + di, 1, Ct.minY, Ct.maxY, Ye), Ki = si($i, it, Le + Kt, Le + li, 1, Ct.minY, Ct.maxY, Ye), $i = null), Hi && (Ni = si(Hi, it, Le - It, Le + di, 1, Ct.minY, Ct.maxY, Ye), Ei = si(Hi, it, Le + Kt, Le + li, 1, Ct.minY, Ct.maxY, Ye), Hi = null), Qe > 1 && console.timeEnd("clipping"), Pe.push(ri || [], le + 1, 2 * ge, 2 * Le), Pe.push(Ki || [], le + 1, 2 * ge, 2 * Le + 1), Pe.push(Ni || [], le + 1, 2 * ge + 1, 2 * Le), Pe.push(Ei || [], le + 1, 2 * ge + 1, 2 * Le + 1); } } getTile(re, le, ge) { re = +re, le = +le, ge = +ge; const Le = this.options, { extent: Ce, debug: Be } = Le; if (re < 0 || re > 24) return null; const qe = 1 << re, Pe = Zi(re, le = le + qe & qe - 1, ge); if (this.tiles[Pe]) return Mr(this.tiles[Pe], Ce); Be > 1 && console.log("drilling down to z%d-%d-%d", re, le, ge); let Ye, Qe = re, it = le, mt = ge; for (; !Ye && Qe > 0; ) Qe--, it >>= 1, mt >>= 1, Ye = this.tiles[Zi(Qe, it, mt)]; return Ye && Ye.source ? (Be > 1 && (console.log("found parent tile z%d-%d-%d", Qe, it, mt), console.time("drilling down")), this.splitTile(Ye.source, Qe, it, mt, re, le, ge), Be > 1 && console.timeEnd("drilling down"), this.tiles[Pe] ? Mr(this.tiles[Pe], Ce) : null) : null; } } function Zi(Ke, re, le) { return 32 * ((1 << Ke) * le + re) + Ke; } function Jn(Ke, re) { const le = Ke.tileID.canonical; if (!this._geoJSONIndex) return void re(null, null); const ge = this._geoJSONIndex.getTile(le.z, le.x, le.y); if (!ge) return void re(null, null); const Le = new gt(ge.features); let Ce = Gi(Le); Ce.byteOffset === 0 && Ce.byteLength === Ce.buffer.byteLength || (Ce = new Uint8Array(Ce)), re(null, { vectorTile: Le, rawData: Ce.buffer }); } class Fn extends Ze { constructor(re, le, ge, Le, Ce, Be) { super(re, le, ge, Le, Jn, Be), Ce && (this.loadGeoJSON = Ce), this._dynamicIndex = new Gt(); } loadData(re, le) { const ge = re && re.request, Le = ge && ge.collectResourceTiming; this.loadGeoJSON(re, (Ce, Be) => { if (Ce || !Be) return le(Ce); if (typeof Be != "object") return le(new Error(`Input data given to '${re.source}' is not a valid GeoJSON object.`)); { try { if (re.filter) { const Pe = i.U(re.filter, { type: "boolean", "property-type": "data-driven", overridable: !1, transition: !1 }); if (Pe.result === "error") throw new Error(Pe.value.map((Ye) => `${Ye.key}: ${Ye.message}`).join(", ")); Be.features = Be.features.filter((Ye) => Pe.value.evaluate({ zoom: 0 }, Ye)); } re.dynamic ? (Be.type === "Feature" && (Be = { type: "FeatureCollection", features: [Be] }), re.append || (this._dynamicIndex.clear(), this.loaded = {}), this._dynamicIndex.load(Be.features, this.loaded), re.cluster && (Be.features = this._dynamicIndex.getFeatures())) : this.loaded = {}, this._geoJSONIndex = re.cluster ? new xs(function({ superclusterOptions: Pe, clusterProperties: Ye }) { if (!Ye || !Pe) return Pe; const Qe = {}, it = {}, mt = { accumulated: null, zoom: 0 }, Ct = { properties: null }, It = Object.keys(Ye); for (const Kt of It) { const [di, li] = Ye[Kt], ri = i.U(li), Ki = i.U(typeof di == "string" ? [di, ["accumulated"], ["get", Kt]] : di); Qe[Kt] = ri.value, it[Kt] = Ki.value; } return Pe.map = (Kt) => { Ct.properties = Kt; const di = {}; for (const li of It) di[li] = Qe[li].evaluate(mt, Ct); return di; }, Pe.reduce = (Kt, di) => { Ct.properties = di; for (const li of It) mt.accumulated = Kt[li], Kt[li] = it[li].evaluate(mt, Ct); }, Pe; }(re)).load(Be.features) : re.dynamic ? this._dynamicIndex : function(Pe, Ye) { return new Vn(Pe, Ye); }(Be, re.geojsonVtOptions); } catch (Pe) { return le(Pe); } const qe = {}; if (Le) { const Pe = O(ge); Pe && (qe.resourceTiming = {}, qe.resourceTiming[re.source] = JSON.parse(JSON.stringify(Pe))); } le(null, qe); } }); } reloadTile(re, le) { const ge = this.loaded; return ge && ge[re.uid] ? re.partial ? le(null, void 0) : super.reloadTile(re, le) : this.loadTile(re, le); } loadGeoJSON(re, le) { if (re.request) i.n(re.request, le); else { if (typeof re.data != "string") return le(new Error(`Input data given to '${re.source}' is not a valid GeoJSON object.`)); try { return le(null, JSON.parse(re.data)); } catch { return le(new Error(`Input data given to '${re.source}' is not a valid GeoJSON object.`)); } } } getClusterExpansionZoom(re, le) { try { le(null, this._geoJSONIndex.getClusterExpansionZoom(re.clusterId)); } catch (ge) { le(ge); } } getClusterChildren(re, le) { try { le(null, this._geoJSONIndex.getChildren(re.clusterId)); } catch (ge) { le(ge); } } getClusterLeaves(re, le) { try { le(null, this._geoJSONIndex.getLeaves(re.clusterId, re.limit, re.offset)); } catch (ge) { le(ge); } } } class Ls { constructor(re, le) { this.tileID = new i.aG(re.tileID.overscaledZ, re.tileID.wrap, re.tileID.canonical.z, re.tileID.canonical.x, re.tileID.canonical.y), this.tileZoom = re.tileZoom, this.uid = re.uid, this.zoom = re.zoom, this.canonical = re.tileID.canonical, this.pixelRatio = re.pixelRatio, this.tileSize = re.tileSize, this.source = re.source, this.overscaling = this.tileID.overscaleFactor(), this.projection = re.projection, this.brightness = le; } parse(re, le, ge, Le) { this.status = "parsing"; const Ce = new i.aG(ge.tileID.overscaledZ, ge.tileID.wrap, ge.tileID.canonical.z, ge.tileID.canonical.x, ge.tileID.canonical.y), Be = [], qe = le.familiesBySource[ge.source], Pe = new i.dZ(Ce, ge.promoteId); return Pe.bucketLayerIDs = [], Pe.is3DTile = !0, i.e9(re).then((Ye) => { if (!Ye) return Le(new Error("Could not parse tile")); const Qe = i.ea(Ye, 1 / i.cc(ge.tileID.canonical)), it = Ye.json.extensionsUsed && Ye.json.extensionsUsed.includes("MAPBOX_mesh_features") || Ye.json.asset.extras && Ye.json.asset.extras.MAPBOX_mesh_features, mt = Ye.json.extensionsUsed && Ye.json.extensionsUsed.includes("EXT_meshopt_compression"), Ct = new i.a8(this.zoom, { brightness: this.brightness }); for (const It in qe) for (const Kt of qe[It]) { const di = Kt[0]; Pe.bucketLayerIDs.push(Kt.map((ri) => i.aC(ri.id, ri.scope))), di.recalculate(Ct, []); const li = new i.eb(Kt, Qe, Ce, it, mt, this.brightness, Pe); it || (li.needsUpload = !0), Be.push(li), li.evaluate(di); } this.status = "done", Le(null, { buckets: Be, featureIndex: Pe, collisionBoxArray: null, glyphAtlasImage: null, lineAtlas: null, imageAtlas: null, brightness: null }); }).catch((Ye) => Le(new Error(Ye.message))); } } class zs { constructor(re, le, ge, Le, Ce, Be) { this.actor = re, this.layerIndex = le, this.availableImages = ge, this.brightness = Be, this.loading = {}, this.loaded = {}; } loadTile(re, le) { const ge = re.uid, Le = this.loading[ge] = new Ls(re, this.brightness); i.bi(re.request, (Ce, Be) => { const qe = !this.loading[ge]; return delete this.loading[ge], qe || Ce ? (Le.status = "done", qe || (this.loaded[ge] = Le), le(Ce)) : Be && Be.byteLength !== 0 ? void Le.parse(Be, this.layerIndex, re, (Pe, Ye) => { Le.status = "done", this.loaded = this.loaded || {}, this.loaded[ge] = Le, Pe || !Ye ? le(Pe) : le(null, Ye); }) : (Le.status = "done", this.loaded[ge] = Le, le()); }); } reloadTile(re, le) { const ge = this.loaded, Le = re.uid; if (ge && ge[Le]) { const Ce = ge[Le]; Ce.projection = re.projection, Ce.brightness = re.brightness; const Be = (qe, Pe) => { Ce.reloadCallback && (delete Ce.reloadCallback, this.loadTile(re, le)), le(qe, Pe); }; Ce.status === "parsing" ? Ce.reloadCallback = Be : Ce.status === "done" && this.loadTile(re, le); } } abortTile(re, le) { const ge = re.uid; this.loading[ge] && delete this.loading[ge], le(); } removeTile(re, le) { const ge = this.loaded, Le = re.uid; ge && ge[Le] && delete ge[Le], le(); } } class Vo { constructor(re) { this.self = re, this.actor = new i.ec(re, this), this.layerIndexes = {}, this.availableImages = {}, this.isSpriteLoaded = {}, this.imageRasterizer = new i.I(), this.projections = {}, this.defaultProjection = i.bP({ name: "mercator" }), this.workerSourceTypes = { vector: Ze, geojson: Fn, "batched-model": zs }, this.workerSources = {}, this.demWorkerSources = {}, this.self.registerWorkerSource = (le, ge) => { if (this.workerSourceTypes[le]) throw new Error(`Worker source with name "${le}" already registered.`); this.workerSourceTypes[le] = ge; }, this.self.registerRTLTextPlugin = (le) => { if (i.ed.isParsed()) throw new Error("RTL text plugin already registered."); i.ed.applyArabicShaping = le.applyArabicShaping, i.ed.processBidirectionalText = le.processBidirectionalText, i.ed.processStyledBidirectionalText = le.processStyledBidirectionalText; }; } clearCaches(re, le, ge) { delete this.layerIndexes[re], delete this.availableImages[re], delete this.workerSources[re], delete this.demWorkerSources[re], delete this.rasterArrayWorkerSource, ge(); } checkIfReady(re, le, ge) { ge(); } setReferrer(re, le) { this.referrer = le; } spriteLoaded(re, { scope: le, isLoaded: ge }) { if (this.isSpriteLoaded[re] || (this.isSpriteLoaded[re] = {}), this.isSpriteLoaded[re][le] = ge, this.workerSources[re] && this.workerSources[re][le]) for (const Le in this.workerSources[re][le]) { const Ce = this.workerSources[re][le][Le]; for (const Be in Ce) { const qe = Ce[Be]; qe instanceof Ze && (qe.isSpriteLoaded = ge, qe.fire(new i.z("isSpriteLoaded"))); } } } setImages(re, { scope: le, images: ge }, Le) { if (this.availableImages[re] || (this.availableImages[re] = {}), this.availableImages[re][le] = ge, this.workerSources[re] && this.workerSources[re][le]) { for (const Ce in this.workerSources[re][le]) { const Be = this.workerSources[re][le][Ce]; for (const qe in Be) Be[qe].availableImages = ge; } Le(); } else Le(); } setProjection(re, le) { this.projections[re] = i.bP(le); } setBrightness(re, le, ge) { this.brightness = le, ge(); } setLayers(re, le, ge) { this.getLayerIndex(re, le.scope).replace(le.layers, le.options), ge(); } updateLayers(re, le, ge) { this.getLayerIndex(re, le.scope).update(le.layers, le.removedIds, le.options), ge(); } loadTile(re, le, ge) { le.projection = this.projections[re] || this.defaultProjection, this.getWorkerSource(re, le.type, le.source, le.scope).loadTile(le, ge); } loadDEMTile(re, le, ge) { this.getDEMWorkerSource(re, le.source, le.scope).loadTile(le, ge); } decodeRasterArray(re, le, ge) { this.getRasterArrayWorkerSource().decodeRasterArray(le, ge); } reloadTile(re, le, ge) { le.projection = this.projections[re] || this.defaultProjection, this.getWorkerSource(re, le.type, le.source, le.scope).reloadTile(le, ge); } abortTile(re, le, ge) { this.getWorkerSource(re, le.type, le.source, le.scope).abortTile(le, ge); } removeTile(re, le, ge) { this.getWorkerSource(re, le.type, le.source, le.scope).removeTile(le, ge); } removeSource(re, le, ge) { if (!(this.workerSources[re] && this.workerSources[re][le.scope] && this.workerSources[re][le.scope][le.type] && this.workerSources[re][le.scope][le.type][le.source])) return; const Le = this.workerSources[re][le.scope][le.type][le.source]; delete this.workerSources[re][le.scope][le.type][le.source], Le.removeSource !== void 0 ? Le.removeSource(le, ge) : ge(); } loadWorkerSource(re, le, ge) { try { this.self.importScripts(le.url), ge(); } catch (Le) { ge(Le.toString()); } } syncRTLPluginState(re, le, ge) { try { i.ed.setState(le); const Le = i.ed.getPluginURL(); if (i.ed.isLoaded() && !i.ed.isParsed() && Le != null) { this.self.importScripts(Le); const Ce = i.ed.isParsed(); ge(Ce ? void 0 : new Error(`RTL Text Plugin failed to import scripts from ${Le}`), Ce); } } catch (Le) { ge(Le.toString()); } } setDracoUrl(re, le) { this.dracoUrl = le; } getAvailableImages(re, le) { this.availableImages[re] || (this.availableImages[re] = {}); let ge = this.availableImages[re][le]; return ge || (ge = []), ge; } getLayerIndex(re, le) { this.layerIndexes[re] || (this.layerIndexes[re] = {}); let ge = this.layerIndexes[re][le]; return ge || (ge = this.layerIndexes[re][le] = new J(), ge.scope = le), ge; } getWorkerSource(re, le, ge, Le) { return this.workerSources[re] || (this.workerSources[re] = {}), this.workerSources[re][Le] || (this.workerSources[re][Le] = {}), this.workerSources[re][Le][le] || (this.workerSources[re][Le][le] = {}), this.isSpriteLoaded[re] || (this.isSpriteLoaded[re] = {}), this.workerSources[re][Le][le][ge] || (this.workerSources[re][Le][le][ge] = new this.workerSourceTypes[le]({ send: (Ce, Be, qe, Pe, Ye, Qe) => { this.actor.send(Ce, Be, qe, re, Ye, Qe); }, scheduler: this.actor.scheduler }, this.getLayerIndex(re, Le), this.getAvailableImages(re, Le), this.isSpriteLoaded[re][Le], void 0, this.brightness)), this.workerSources[re][Le][le][ge]; } rasterizeImages(re, le, ge) { const { imageTasks: Le, scope: Ce } = le, Be = {}; for (const qe in Le) { const { image: Pe, imageIdWithOptions: Ye } = Le[qe]; Be[qe] = this.imageRasterizer.rasterize(Ye, Pe, Ce, re); } ge(void 0, Be); } removeRasterizedImages(re, le, ge) { const { imageIds: Le, scope: Ce } = le; this.imageRasterizer.removeImagesFromCacheByIds(Le, Ce, re), ge(); } getDEMWorkerSource(re, le, ge) { return this.demWorkerSources[re] || (this.demWorkerSources[re] = {}), this.demWorkerSources[re][ge] || (this.demWorkerSources[re][ge] = {}), this.demWorkerSources[re][ge][le] || (this.demWorkerSources[re][ge][le] = new je()), this.demWorkerSources[re][ge][le]; } getRasterArrayWorkerSource() { return this.rasterArrayWorkerSource || (this.rasterArrayWorkerSource = new ot()), this.rasterArrayWorkerSource; } enforceCacheSizeLimit(re, le) { i.ee(le); } getWorkerPerformanceMetrics(re, le, ge) { ge(void 0, void 0); } } return typeof WorkerGlobalScope < "u" && typeof self < "u" && self instanceof WorkerGlobalScope && (self.worker = new Vo(self)), Vo; }), b(["./shared"], function(i) { var O = "3.9.4"; const j = { create: "create", load: "load", fullLoad: "fullLoad" }, Y = { mark(c) { performance.mark(c); }, measure(c, t, s) { performance.measure(c, t, s); } }; function J(c) { const t = c.name.split("?")[0]; return i.a(t) && t.includes("mapbox-gl.js") ? "javascript" : i.a(t) && t.includes("mapbox-gl.css") ? "css" : i.b(t) ? "fontRange" : i.c(t) ? "sprite" : i.i(t) ? "style" : i.d(t) ? "tilejson" : "other"; } var ae, ce = {}, Te = function() { if (ae) return ce; function c(h) { return !t(h); } function t(h) { return typeof window > "u" || typeof document > "u" ? "not a browser" : function() { if (!("Worker" in window && "Blob" in window && "URL" in window)) return !1; var y, T, z = new Blob([""], { type: "text/javascript" }), R = URL.createObjectURL(z); try { T = new Worker(R), y = !0; } catch { y = !1; } return T && T.terminate(), URL.revokeObjectURL(R), y; }() ? function() { var y = document.createElement("canvas"); y.width = y.height = 1; var T = y.getContext("2d"); if (!T) return !1; var z = T.getImageData(0, 0, 1, 1); return z && z.width === y.width; }() ? (s[_ = h && h.failIfMajorPerformanceCaveat] === void 0 && (s[_] = function(y) { var T, z = function(R) { var F = document.createElement("canvas"), N = Object.create(c.webGLContextAttributes); return N.failIfMajorPerformanceCaveat = R, F.getContext("webgl2", N); }(y); if (!z) return !1; try { T = z.createShader(z.VERTEX_SHADER); } catch { return !1; } return !(!T || z.isContextLost()) && (z.shaderSource(T, "void main() {}"), z.compileShader(T), z.getShaderParameter(T, z.COMPILE_STATUS) === !0); }(_)), s[_] ? document.documentMode ? "insufficient ECMAScript 6 support" : void 0 : "insufficient WebGL2 support") : "insufficient Canvas/getImageData support" : "insufficient worker support"; var _; } ae = 1, ce.supported = c, ce.notSupportedReason = t; var s = {}; return c.webGLContextAttributes = { antialias: !1, alpha: !0, stencil: !0, depth: !0 }, ce; }(); function be(c, t, s) { const h = document.createElement(c); return t != null && (h.className = t), s && s.appendChild(h), h; } function Ze(c, t, s) { const h = document.createElementNS("http://www.w3.org/2000/svg", c); for (const _ of Object.keys(t)) h.setAttributeNS(null, _, String(t[_])); return s && s.appendChild(h), h; } const je = typeof document < "u" ? document.documentElement && document.documentElement.style : null, ot = je && je.userSelect !== void 0 ? "userSelect" : "WebkitUserSelect"; let vt; function ht() { je && ot && (vt = je[ot], je[ot] = "none"); } function gt() { je && ot && (je[ot] = vt); } function Vt(c) { c.preventDefault(), c.stopPropagation(), window.removeEventListener("click", Vt, !0); } function pt() { window.addEventListener("click", Vt, !0), window.setTimeout(() => { window.removeEventListener("click", Vt, !0); }, 0); } function Gt(c, t) { const s = c.getBoundingClientRect(); return Pt(c, s, t); } function ui(c, t) { const s = c.getBoundingClientRect(), h = []; for (let _ = 0; _ < t.length; _++) h.push(Pt(c, s, t[_])); return h; } function kt(c) { return window.InstallTrigger !== void 0 && c.button === 2 && c.ctrlKey && window.navigator.platform.toUpperCase().indexOf("MAC") >= 0 ? 0 : c.button; } function Pt(c, t, s) { const h = c.offsetWidth === t.width ? 1 : c.offsetWidth / t.width; return new i.P((s.clientX - t.left) * h, (s.clientY - t.top) * h); } const Mi = "01", Pn = "NO_ACCESS_TOKEN"; class hn { constructor(t, s, h) { this._transformRequestFn = t, this._customAccessToken = s, this._silenceAuthErrors = !!h, this._createSkuToken(); } _createSkuToken() { const t = function() { let s = ""; for (let h = 0; h < 10; h++) s += "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"[Math.floor(62 * Math.random())]; return { token: ["1", Mi, s].join(""), tokenExpiresAt: Date.now() + 432e5 }; }(); this._skuToken = t.token, this._skuTokenExpiresAt = t.tokenExpiresAt; } _isSkuTokenExpired() { return Date.now() > this._skuTokenExpiresAt; } transformRequest(t, s) { return this._transformRequestFn && this._transformRequestFn(t, s) || { url: t }; } normalizeStyleURL(t, s) { if (!i.f(t)) return t; const h = Si(t); return h.params.push(`sdk=js-${O}`), h.path = `/styles/v1${h.path}`, this._makeAPIURL(h, this._customAccessToken || s); } normalizeGlyphsURL(t, s) { if (!i.f(t)) return t; const h = Si(t); return h.path = `/fonts/v1${h.path}`, this._makeAPIURL(h, this._customAccessToken || s); } normalizeModelURL(t, s) { if (!i.f(t)) return t; const h = Si(t); return h.path = `/models/v1${h.path}`, this._makeAPIURL(h, this._customAccessToken || s); } normalizeSourceURL(t, s, h, _) { if (!i.f(t)) return t; const y = Si(t); return y.path = `/v4/${y.authority}.json`, y.params.push("secure"), h && y.params.push(`language=${h}`), _ && y.params.push(`worldview=${_}`), this._makeAPIURL(y, this._customAccessToken || s); } normalizeIconsetURL(t, s) { const h = Si(t); return i.f(t) ? (h.path = `/styles/v1${h.path}/iconset.pbf`, this._makeAPIURL(h, this._customAccessToken || s)) : Ji(h); } normalizeSpriteURL(t, s, h, _) { const y = Si(t); return i.f(t) ? (y.path = `/styles/v1${y.path}/sprite${s}${h}`, this._makeAPIURL(y, this._customAccessToken || _)) : (y.path += `${s}${h}`, Ji(y)); } normalizeTileURL(t, s, h) { if (this._isSkuTokenExpired() && this._createSkuToken(), t && !i.f(t)) return t; const _ = Si(t); _.path = _.path.replace(/(\.(png|jpg)\d*)(?=$)/, `${s || h && _.authority !== "raster" && h === 512 ? "@2x" : ""}${i.m.supported ? ".webp" : "$1"}`), _.authority === "raster" ? _.path = `/${i.e.RASTER_URL_PREFIX}${_.path}` : _.authority === "rasterarrays" ? _.path = `/${i.e.RASTERARRAYS_URL_PREFIX}${_.path}` : _.authority === "3dtiles" ? _.path = `/${i.e.TILES3D_URL_PREFIX}${_.path}` : (_.path = _.path.replace(/^.+\/v4\//, "/"), _.path = `/${i.e.TILE_URL_VERSION}${_.path}`); const y = this._customAccessToken || function(T) { for (const z of T) { const R = z.match(/^access_token=(.*)$/); if (R) return R[1]; } return null; }(_.params) || i.e.ACCESS_TOKEN; return i.e.REQUIRE_ACCESS_TOKEN && y && this._skuToken && _.params.push(`sku=${this._skuToken}`), this._makeAPIURL(_, y); } canonicalizeTileURL(t, s) { const h = Si(t); if (!h.path.match(/^(\/v4\/|\/(raster|rasterarrays)\/v1\/)/) || !h.path.match(/\.[\w]+$/)) return t; let _ = "mapbox://"; h.path.match(/^\/raster\/v1\//) ? _ += `raster/${h.path.replace(`/${i.e.RASTER_URL_PREFIX}/`, "")}` : h.path.match(/^\/rasterarrays\/v1\//) ? _ += `rasterarrays/${h.path.replace(`/${i.e.RASTERARRAYS_URL_PREFIX}/`, "")}` : _ += `tiles/${h.path.replace(`/${i.e.TILE_URL_VERSION}/`, "")}`; let y = h.params; return s && (y = y.filter((T) => !T.match(/^access_token=/))), y.length && (_ += `?${y.join("&")}`), _; } canonicalizeTileset(t, s) { const h = !!s && i.f(s), _ = []; for (const y of t.tiles || []) i.h(y) ? _.push(this.canonicalizeTileURL(y, h)) : _.push(y); return _; } _makeAPIURL(t, s) { const h = "See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes", _ = Si(i.e.API_URL); if (t.protocol = _.protocol, t.authority = _.authority, t.protocol === "http") { const y = t.params.indexOf("secure"); y >= 0 && t.params.splice(y, 1); } if (_.path !== "/" && (t.path = `${_.path}${t.path}`), !i.e.REQUIRE_ACCESS_TOKEN) return Ji(t); if (s = s || i.e.ACCESS_TOKEN, !this._silenceAuthErrors) { if (!s) throw new Error(`An API access token is required to use Mapbox GL. ${h}`); if (s[0] === "s") throw new Error(`Use a public access token (pk.*) with Mapbox GL, not a secret access token (sk.*). ${h}`); } return t.params = t.params.filter((y) => y.indexOf("access_token") === -1), t.params.push(`access_token=${s || ""}`), Ji(t); } } const Ht = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/; function Si(c) { const t = c.match(Ht); if (!t) throw new Error("Unable to parse URL object"); return { protocol: t[1], authority: t[2], path: t[3] || "/", params: t[4] ? t[4].split("&") : [] }; } function Ji(c) { const t = c.params.length ? `?${c.params.join("&")}` : ""; return `${c.protocol}://${c.authority}${c.path}${t}`; } const fi = "mapbox.eventData"; function jt(c) { if (!c) return null; const t = c.split("."); if (!t || t.length !== 3) return null; try { return JSON.parse(i.j(t[1])); } catch { return null; } } class ni { constructor(t) { this.type = t, this.anonId = null, this.eventData = {}, this.queue = [], this.pendingRequest = null; } getStorageKey(t) { const s = jt(i.e.ACCESS_TOKEN); let h = ""; return h = s && s.u ? i.k(s.u) : i.e.ACCESS_TOKEN || "", t ? `${fi}.${t}:${h}` : `${fi}:${h}`; } fetchEventData() { const t = i.s("localStorage"), s = this.getStorageKey(), h = this.getStorageKey("uuid"); if (t) try { const _ = localStorage.getItem(s); _ && (this.eventData = JSON.parse(_)); const y = localStorage.getItem(h); y && (this.anonId = y); } catch { i.w("Unable to read from LocalStorage"); } } saveEventData() { const t = i.s("localStorage"), s = this.getStorageKey(), h = this.getStorageKey("uuid"), _ = this.anonId; if (t && _) try { localStorage.setItem(h, _), Object.keys(this.eventData).length >= 1 && localStorage.setItem(s, JSON.stringify(this.eventData)); } catch { i.w("Unable to write to LocalStorage"); } } processRequests(t) { } postEvent(t, s, h, _) { if (!i.e.EVENTS_URL) return; const y = Si(i.e.EVENTS_URL); y.params.push(`access_token=${_ || i.e.ACCESS_TOKEN || ""}`); const T = { event: this.type, created: new Date(t).toISOString() }, z = s ? i.l(T, s) : T, R = { url: Ji(y), headers: { "Content-Type": "text/plain" }, body: JSON.stringify([z]) }; this.pendingRequest = i.p(R, (F) => { this.pendingRequest = null, h(F), this.saveEventData(), this.processRequests(_); }); } queueRequest(t, s) { this.queue.push(t), this.processRequests(s); } } const Gi = new class extends ni { constructor(c) { super("appUserTurnstile"), this._customAccessToken = c; } postTurnstileEvent(c, t) { i.e.EVENTS_URL && i.e.ACCESS_TOKEN && Array.isArray(c) && c.some((s) => i.f(s) || i.h(s)) && this.queueRequest(Date.now(), t); } processRequests(c) { if (this.pendingRequest || this.queue.length === 0) return; this.anonId && this.eventData.lastSuccess && this.eventData.tokenU || this.fetchEventData(); const t = jt(i.e.ACCESS_TOKEN), s = t ? t.u : i.e.ACCESS_TOKEN; let h = s !== this.eventData.tokenU; i.v(this.anonId) || (this.anonId = i.u(), h = !0); const _ = this.queue.shift(); if (this.eventData.lastSuccess) { const y = new Date(this.eventData.lastSuccess), T = new Date(_), z = (_ - this.eventData.lastSuccess) / 864e5; h = h || z >= 1 || z < -1 || y.getDate() !== T.getDate(); } else h = !0; h ? this.postEvent(_, { sdkIdentifier: "mapbox-gl-js", sdkVersion: O, skuId: Mi, "enabled.telemetry": !1, userId: this.anonId }, (y) => { y || (this.eventData.lastSuccess = _, this.eventData.tokenU = s); }, c) : this.processRequests(); } }(), an = Gi.postTurnstileEvent.bind(Gi), qt = new class extends ni { constructor() { super("map.load"), this.success = {}, this.skuToken = ""; } postMapLoadEvent(c, t, s, h) { this.skuToken = t, this.errorCb = h, i.e.EVENTS_URL && (s || i.e.ACCESS_TOKEN ? this.queueRequest({ id: c, timestamp: Date.now() }, s) : this.errorCb(new Error(Pn))); } processRequests(c) { if (this.pendingRequest || this.queue.length === 0) return; const { id: t, timestamp: s } = this.queue.shift(); t && this.success[t] || (this.anonId || this.fetchEventData(), i.v(this.anonId) || (this.anonId = i.u()), this.postEvent(s, { sdkIdentifier: "mapbox-gl-js", sdkVersion: O, skuId: Mi, skuToken: this.skuToken, userId: this.anonId }, (h) => { h ? this.errorCb(h) : t && (this.success[t] = !0); }, c)); } remove() { this.errorCb = null; } }(), ln = qt.postMapLoadEvent.bind(qt), Di = new class extends ni { constructor() { super("style.load"), this.eventIdPerMapInstanceMap = /* @__PURE__ */ new Map(), this.mapInstanceIdMap = /* @__PURE__ */ new WeakMap(); } getMapInstanceId(c) { let t = this.mapInstanceIdMap.get(c); return t || (t = i.u(), this.mapInstanceIdMap.set(c, t)), t; } getEventId(c) { const t = this.eventIdPerMapInstanceMap.get(c) || 0; return this.eventIdPerMapInstanceMap.set(c, t + 1), t; } postStyleLoadEvent(c, t) { const { map: s, style: h, importedStyles: _ } = t; if (!i.e.EVENTS_URL || !c && !i.e.ACCESS_TOKEN) return; const y = this.getMapInstanceId(s), T = { mapInstanceId: y, eventId: this.getEventId(y), style: h }; _.length && (T.importedStyles = _), this.queueRequest({ timestamp: Date.now(), payload: T }, c); } processRequests(c) { if (this.pendingRequest || this.queue.length === 0) return; const { timestamp: t, payload: s } = this.queue.shift(); this.postEvent(t, s, () => { }, c); } }(), xi = Di.postStyleLoadEvent.bind(Di), Cs = new class extends ni { constructor() { super("gljs.performance"); } postPerformanceEvent(c, t) { i.e.EVENTS_URL && (c || i.e.ACCESS_TOKEN) && this.queueRequest({ timestamp: Date.now(), performanceData: t }, c); } processRequests(c) { if (this.pendingRequest || this.queue.length === 0) return; const { timestamp: t, performanceData: s } = this.queue.shift(), h = function(_) { const y = performance.getEntriesByType("resource"), T = performance.getEntriesByType("mark"), z = function(W) { const te = {}; if (W) { for (const ee in W) if (ee !== "other") for (const se of W[ee]) { const oe = `${ee}ResolveRangeMin`, he = `${ee}ResolveRangeMax`, _e = `${ee}RequestCount`, pe = `${ee}RequestCachedCount`; te[oe] = Math.min(te[oe] || 1 / 0, se.startTime), te[he] = Math.max(te[he] || -1 / 0, se.responseEnd); const Me = (xe) => { te[xe] === void 0 && (te[xe] = 0), ++te[xe]; }; se.transferSize !== void 0 && se.transferSize === 0 && Me(pe), Me(_e); } } return te; }(function(W, te) { const ee = {}; if (W) for (const se of W) { const oe = te(se); ee[oe] === void 0 && (ee[oe] = []), ee[oe].push(se); } return ee; }(y, J)), R = window.devicePixelRatio, F = navigator.connection || navigator.mozConnection || navigator.webkitConnection, N = F ? F.effectiveType : void 0, G = { counters: [], metadata: [], attributes: [] }, Z = (W, te, ee) => { ee != null && W.push({ name: te, value: ee.toString() }); }; for (const W in z) Z(G.counters, W, z[W]); if (_.interactionRange[0] !== 1 / 0 && _.interactionRange[1] !== -1 / 0 && (Z(G.counters, "interactionRangeMin", _.interactionRange[0]), Z(G.counters, "interactionRangeMax", _.interactionRange[1])), T) for (const W of Object.keys(j)) { const te = j[W], ee = T.find((se) => se.name === te); ee && Z(G.counters, te, ee.startTime); } return Z(G.counters, "visibilityHidden", _.visibilityHidden), Z(G.attributes, "style", function(W) { if (W) for (const te of W) { const ee = te.name.split("?")[0]; if (i.i(ee)) { const se = ee.split("/").slice(-2); if (se.length === 2) return `mapbox://styles/${se[0]}/${se[1]}`; } } }(y)), Z(G.attributes, "terrainEnabled", _.terrainEnabled ? "true" : "false"), Z(G.attributes, "fogEnabled", _.fogEnabled ? "true" : "false"), Z(G.attributes, "projection", _.projection), Z(G.attributes, "zoom", _.zoom), Z(G.metadata, "devicePixelRatio", R), Z(G.metadata, "connectionEffectiveType", N), Z(G.metadata, "navigatorUserAgent", navigator.userAgent), Z(G.metadata, "screenWidth", window.screen.width), Z(G.metadata, "screenHeight", window.screen.height), Z(G.metadata, "windowWidth", window.innerWidth), Z(G.metadata, "windowHeight", window.innerHeight), Z(G.metadata, "mapWidth", _.width / R), Z(G.metadata, "mapHeight", _.height / R), Z(G.metadata, "webglRenderer", _.renderer), Z(G.metadata, "webglVendor", _.vendor), Z(G.metadata, "sdkVersion", O), Z(G.metadata, "sdkIdentifier", "mapbox-gl-js"), G; }(s); for (const _ of h.metadata) ; for (const _ of h.counters) ; for (const _ of h.attributes) ; this.postEvent(t, h, () => { }, c); } }(), xs = Cs.postPerformanceEvent.bind(Cs), Is = new class extends ni { constructor() { super("map.auth"), this.success = {}, this.skuToken = ""; } getSession(c, t, s, h) { if (!i.e.API_URL || !i.e.SESSION_PATH) return; const _ = Si(i.e.API_URL + i.e.SESSION_PATH); _.params.push(`sku=${t || ""}`), _.params.push(`access_token=${h || i.e.ACCESS_TOKEN || ""}`); const y = { url: Ji(_), headers: { "Content-Type": "text/plain" } }; this.pendingRequest = i.g(y, (T) => { this.pendingRequest = null, s(T), this.saveEventData(), this.processRequests(h); }); } getSessionAPI(c, t, s, h) { this.skuToken = t, this.errorCb = h, i.e.SESSION_PATH && i.e.API_URL && (s || i.e.ACCESS_TOKEN ? this.queueRequest({ id: c, timestamp: Date.now() }, s) : this.errorCb(new Error(Pn))); } processRequests(c) { if (this.pendingRequest || this.queue.length === 0) return; const { id: t, timestamp: s } = this.queue.shift(); t && this.success[t] || this.getSession(s, this.skuToken, (h) => { h ? this.errorCb(h) : t && (this.success[t] = !0); }, c); } remove() { this.errorCb = null; } }(), De = Is.getSessionAPI.bind(Is), Vs = /* @__PURE__ */ new Set(); function Us(c, t) { t ? Vs.add(c) : Vs.delete(c); } class Zr { constructor() { this._changed = !1, this._updatedLayers = {}, this._removedLayers = {}, this._updatedSourceCaches = {}, this._updatedPaintProps = /* @__PURE__ */ new Set(), this._updatedImages = /* @__PURE__ */ new Set(); } isDirty() { return this._changed; } setDirty() { this._changed = !0; } getUpdatedSourceCaches() { return this._updatedSourceCaches; } updateSourceCache(t, s) { this._updatedSourceCaches[t] = s, this.setDirty(); } discardSourceCacheUpdate(t) { delete this._updatedSourceCaches[t]; } updateLayer(t) { const s = t.scope; this._updatedLayers[s] = this._updatedLayers[s] || /* @__PURE__ */ new Set(), this._updatedLayers[s].add(t.id), this.setDirty(); } removeLayer(t) { const s = t.scope; this._removedLayers[s] = this._removedLayers[s] || {}, this._updatedLayers[s] = this._updatedLayers[s] || /* @__PURE__ */ new Set(), this._removedLayers[s][t.id] = t, this._updatedLayers[s].delete(t.id), this._updatedPaintProps.delete(t.fqid), this.setDirty(); } getRemovedLayer(t) { return this._removedLayers[t.scope] ? this._removedLayers[t.scope][t.id] : null; } discardLayerRemoval(t) { this._removedLayers[t.scope] && delete this._removedLayers[t.scope][t.id]; } getLayerUpdatesByScope() { const t = {}; for (const s in this._updatedLayers) t[s] = t[s] || {}, t[s].updatedIds = Array.from(this._updatedLayers[s].values()); for (const s in this._removedLayers) t[s] = t[s] || {}, t[s].removedIds = Object.keys(this._removedLayers[s]); return t; } getUpdatedPaintProperties() { return this._updatedPaintProps; } updatePaintProperties(t) { this._updatedPaintProps.add(t.fqid), this.setDirty(); } getUpdatedImages() { return Array.from(this._updatedImages.values()); } updateImage(t) { this._updatedImages.add(t), this.setDirty(); } resetUpdatedImages() { this._updatedImages.clear(); } reset() { this._changed = !1, this._updatedLayers = {}, this._removedLayers = {}, this._updatedSourceCaches = {}, this._updatedPaintProps.clear(), this._updatedImages.clear(); } } function Et(c) { const { userImage: t } = c; return !!(t && t.render && t.render()) && (c.data.replace(new Uint8Array(t.data.buffer)), !0); } class Ws extends i.E { constructor(t) { super(), this.images = {}, this.updatedImages = {}, this.callbackDispatchedThisFrame = {}, this.loaded = {}, this.requestors = [], this.patterns = {}, this.atlasImage = {}, this.atlasTexture = {}, this.dirty = !0, this.spriteFormat = t, t !== "raster" && i.t() && (this.imageRasterizerDispatcher = new i.D(i.x(), this, "Image Rasterizer Worker", 1)); } get imageRasterizer() { return this._imageRasterizer || (this._imageRasterizer = new i.I()), this._imageRasterizer; } createScope(t) { this.images[t] = {}, this.loaded[t] = !1, this.updatedImages[t] = {}, this.patterns[t] = {}, this.callbackDispatchedThisFrame[t] = {}, this.atlasImage[t] = new i.r({ width: 1, height: 1 }); } isLoaded() { for (const t in this.loaded) if (!this.loaded[t]) return !1; return !0; } setLoaded(t, s) { if (this.loaded[s] !== t && (this.loaded[s] = t, t)) { for (const { ids: h, callback: _ } of this.requestors) this._notify(h, s, _); this.requestors = []; } } hasImage(t, s) { return !!this.getImage(t, s); } getImage(t, s) { return this.images[s][t]; } addImage(t, s, h) { this._validate(t, h) && (this.images[s][t] = h); } _validate(t, s) { let h = !0; return this._validateStretch(s.stretchX, s.data && s.data.width) || (this.fire(new i.y(new Error(`Image "${t}" has invalid "stretchX" value`))), h = !1), this._validateStretch(s.stretchY, s.data && s.data.height) || (this.fire(new i.y(new Error(`Image "${t}" has invalid "stretchY" value`))), h = !1), this._validateContent(s.content, s) || (this.fire(new i.y(new Error(`Image "${t}" has invalid "content" value`))), h = !1), h; } _validateStretch(t, s) { if (!t) return !0; let h = 0; for (const _ of t) { if (_[0] < h || _[1] < _[0] || s < _[1]) return !1; h = _[1]; } return !0; } _validateContent(t, s) { return t ? t.length !== 4 || !s.usvg && (t[0] < 0 || s.data.width < t[0] || t[1] < 0 || s.data.height < t[1] || t[2] < 0 || s.data.width < t[2] || t[3] < 0 || s.data.height < t[3]) ? !1 : !(t[2] < t[0] || t[3] < t[1]) : !0; } updateImage(t, s, h) { h.version = this.images[s][t].version + 1, this.images[s][t] = h, this.updatedImages[s][t] = !0, this.removeFromImageRasterizerCache(t, s); } removeFromImageRasterizerCache(t, s) { this.spriteFormat !== "raster" && (i.t() ? this.imageRasterizerDispatcher.getActor().send("removeRasterizedImages", { imageIds: [t], scope: s }) : this.imageRasterizer.removeImagesFromCacheByIds([t], s)); } removeImage(t, s) { const h = this.images[s][t]; delete this.images[s][t], delete this.patterns[s][t], this.removeFromImageRasterizerCache(t, s), h.userImage && h.userImage.onRemove && h.userImage.onRemove(); } listImages(t) { return Object.keys(this.images[t]); } getImages(t, s, h) { let _ = !0; const y = !!this.loaded[s]; if (!y) for (const T of t) this.images[s][T] || (_ = !1); y || _ ? this._notify(t, s, h) : this.requestors.push({ ids: t, scope: s, callback: h }); } rasterizeImages({ scope: t, imageTasks: s }, h) { const _ = {}; for (const y in s) { const T = s[y], z = this.getImage(T.id, t); z && (_[y] = { image: z, imageIdWithOptions: T }); } i.t() ? this.imageRasterizerDispatcher.getActor().send("rasterizeImages", { imageTasks: _, scope: t }, h) : this.rasterizeImagesInMainThread({ imageTasks: _, scope: t }, h); } rasterizeImagesInMainThread(t, s) { const { imageTasks: h, scope: _ } = t, y = {}; for (const T in h) { const { image: z, imageIdWithOptions: R } = h[T]; y[T] = this.imageRasterizer.rasterize(R, z, _, ""); } s(void 0, y); } getUpdatedImages(t) { return this.updatedImages[t]; } _notify(t, s, h) { const _ = {}; for (const y of t) { this.images[s][y] || this.fire(new i.z("styleimagemissing", { id: y })); const T = this.images[s][y]; T ? _[y] = { data: T.usvg ? null : T.data.clone(), pixelRatio: T.pixelRatio, sdf: T.sdf, usvg: T.usvg, version: T.version, stretchX: T.stretchX, stretchY: T.stretchY, content: T.content, hasRenderCallback: !!(T.userImage && T.userImage.render) } : i.w(`Image "${y}" 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.`); } h(null, _); } getPixelSize(t) { const { width: s, height: h } = this.atlasImage[t]; return { width: s, height: h }; } getPattern(t, s, h) { const _ = this.patterns[s][t], y = this.getImage(t, s); if (!y) return null; if (_ && _.position.version === y.version) return _.position; if (_) _.position.version = y.version; else { y.usvg && !y.data && (y.data = this.imageRasterizer.rasterize(i.A.from(t).getPrimary(), y, s, "")); const T = { w: y.data.width + 2 * i.B, h: y.data.height + 2 * i.B, x: 0, y: 0 }, z = new i.F(T, y, i.B); this.patterns[s][t] = { bin: T, position: z }; } return this._updatePatternAtlas(s, h), this.patterns[s][t].position; } bind(t, s) { const h = t.gl; let _ = this.atlasTexture[s]; _ ? this.dirty && (_.update(this.atlasImage[s]), this.dirty = !1) : (_ = new i.T(t, this.atlasImage[s], h.RGBA8), this.atlasTexture[s] = _), _.bind(h.LINEAR, h.CLAMP_TO_EDGE); } _updatePatternAtlas(t, s) { const h = []; for (const z in this.patterns[t]) h.push(this.patterns[t][z].bin); const { w: _, h: y } = i.C(h), T = this.atlasImage[t]; T.resize({ width: _ || 1, height: y || 1 }); for (const z in this.patterns[t]) { const { bin: R, position: F } = this.patterns[t][z]; let N = F.padding; const G = R.x + N, Z = R.y + N, W = this.images[t][z].data, te = W.width, ee = W.height; N = N > 1 ? N - 1 : N, i.r.copy(W, T, { x: 0, y: 0 }, { x: G, y: Z }, { width: te, height: ee }, s), i.r.copy(W, T, { x: 0, y: ee - N }, { x: G, y: Z - N }, { width: te, height: N }, s), i.r.copy(W, T, { x: 0, y: 0 }, { x: G, y: Z + ee }, { width: te, height: N }, s), i.r.copy(W, T, { x: te - N, y: 0 }, { x: G - N, y: Z }, { width: N, height: ee }, s), i.r.copy(W, T, { x: 0, y: 0 }, { x: G + te, y: Z }, { width: N, height: ee }, s), i.r.copy(W, T, { x: te - N, y: ee - N }, { x: G - N, y: Z - N }, { width: N, height: N }, s), i.r.copy(W, T, { x: 0, y: ee - N }, { x: G + te, y: Z - N }, { width: N, height: N }, s), i.r.copy(W, T, { x: 0, y: 0 }, { x: G + te, y: Z + ee }, { width: N, height: N }, s), i.r.copy(W, T, { x: te - N, y: 0 }, { x: G - N, y: Z + ee }, { width: N, height: N }, s); } this.dirty = !0; } beginFrame() { for (const t in this.images) this.callbackDispatchedThisFrame[t] = {}; } dispatchRenderCallbacks(t, s) { for (const h of t) { if (this.callbackDispatchedThisFrame[s][h]) continue; this.callbackDispatchedThisFrame[s][h] = !0; const _ = this.images[s][h]; Et(_) && this.updateImage(h, s, _); } } } function $n(c) { const t = c.key, s = c.value, h = c.valueSpec || {}, _ = c.objectElementValidators || {}, y = c.style, T = c.styleSpec; let z = []; const R = i.H(s); if (R !== "object") return [new i.V(t, s, `object expected, ${R} found`)]; for (const F in s) { const N = F.split(".")[0]; let G; _[N] ? G = _[N] : h[N] ? G = mi : _["*"] ? G = _["*"] : h["*"] && (G = mi), G ? z = z.concat(G({ key: (t && `${t}.`) + F, value: s[F], valueSpec: h[N] || h["*"], style: y, styleSpec: T, object: s, objectKey: F }, s)) : z.push(new i.G(t, s[F], `unknown property "${F}"`)); } for (const F in h) _[F] || h[F].required && h[F].default === void 0 && s[F] === void 0 && z.push(new i.V(t, s, `missing required property "${F}"`)); return z; } function $s(c) { const t = c.value, s = c.valueSpec, h = c.style, _ = c.styleSpec, y = c.key, T = c.arrayElementValidator || mi; if (i.H(t) !== "array") return [new i.V(y, t, `array expected, ${i.H(t)} found`)]; if (s.length && t.length !== s.length) return [new i.V(y, t, `array length ${s.length} expected, length ${t.length} found`)]; if (s["min-length"] && t.length < s["min-length"]) return [new i.V(y, t, `array length at least ${s["min-length"]} expected, length ${t.length} found`)]; let z = { type: s.value, values: s.values, minimum: s.minimum, maximum: s.maximum, function: void 0 }; _.$version < 7 && (z.function = s.function), i.H(s.value) === "object" && (z = s.value); let R = []; for (let F = 0; F < t.length; F++) R = R.concat(T({ array: t, arrayIndex: F, value: t[F], valueSpec: z, style: h, styleSpec: _, key: `${y}[${F}]` }, !0)); return R; } function vi(c) { const t = c.key, s = c.value, h = c.valueSpec; let _ = i.H(s); if (_ === "number" && s != s && (_ = "NaN"), _ !== "number") return [new i.V(t, s, `number expected, ${_} found`)]; if ("minimum" in h) { let y = h.minimum; if (i.H(h.minimum) === "array" && (y = h.minimum[c.arrayIndex]), s < y) return [new i.V(t, s, `${s} is less than the minimum value ${y}`)]; } if ("maximum" in h) { let y = h.maximum; if (i.H(h.maximum) === "array" && (y = h.maximum[c.arrayIndex]), s > y) return [new i.V(t, s, `${s} is greater than the maximum value ${y}`)]; } return []; } function kn(c) { const t = c.valueSpec, s = i.K(c.value.type); let h, _, y, T = {}; const z = s !== "categorical" && c.value.property === void 0, R = !z, F = i.H(c.value.stops) === "array" && i.H(c.value.stops[0]) === "array" && i.H(c.value.stops[0][0]) === "object", N = $n({ key: c.key, value: c.value, valueSpec: c.styleSpec.function, style: c.style, styleSpec: c.styleSpec, objectElementValidators: { stops: function(W) { if (s === "identity") return [new i.V(W.key, W.value, 'identity function may not have a "stops" property')]; let te = []; const ee = W.value; return te = te.concat($s({ key: W.key, value: ee, valueSpec: W.valueSpec, style: W.style, styleSpec: W.styleSpec, arrayElementValidator: G })), i.H(ee) === "array" && ee.length === 0 && te.push(new i.V(W.key, ee, "array must have at least one stop")), te; }, default: function(W) { return mi({ key: W.key, value: W.value, valueSpec: t, style: W.style, styleSpec: W.styleSpec }); } } }); return s === "identity" && z && N.push(new i.V(c.key, c.value, 'missing required property "property"')), s === "identity" || c.value.stops || N.push(new i.V(c.key, c.value, 'missing required property "stops"')), s === "exponential" && c.valueSpec.expression && !i.L(c.valueSpec) && N.push(new i.V(c.key, c.value, "exponential functions not supported")), c.styleSpec.$version >= 8 && (R && !i.M(c.valueSpec) ? N.push(new i.V(c.key, c.value, "property functions not supported")) : z && !i.N(c.valueSpec) && N.push(new i.V(c.key, c.value, "zoom functions not supported"))), s !== "categorical" && !F || c.value.property !== void 0 || N.push(new i.V(c.key, c.value, '"property" property is required')), N; function G(W) { let te = []; const ee = W.value, se = W.key; if (i.H(ee) !== "array") return [new i.V(se, ee, `array expected, ${i.H(ee)} found`)]; if (ee.length !== 2) return [new i.V(se, ee, `array length 2 expected, length ${ee.length} found`)]; if (F) { if (i.H(ee[0]) !== "object") return [new i.V(se, ee, `object expected, ${i.H(ee[0])} found`)]; if (ee[0].zoom === void 0) return [new i.V(se, ee, "object stop key must have zoom")]; if (ee[0].value === void 0) return [new i.V(se, ee, "object stop key must have value")]; const oe = i.K(ee[0].zoom); if (typeof oe != "number") return [new i.V(se, ee[0].zoom, "stop zoom values must be numbers")]; if (y && y > oe) return [new i.V(se, ee[0].zoom, "stop zoom values must appear in ascending order")]; oe !== y && (y = oe, _ = void 0, T = {}), te = te.concat($n({ key: `${se}[0]`, value: ee[0], valueSpec: { zoom: {} }, style: W.style, styleSpec: W.styleSpec, objectElementValidators: { zoom: vi, value: Z } })); } else te = te.concat(Z({ key: `${se}[0]`, value: ee[0], valueSpec: {}, style: W.style, styleSpec: W.styleSpec }, ee)); return i.O(i.Q(ee[1])) ? te.concat([new i.V(`${se}[1]`, ee[1], "expressions are not allowed in function stops.")]) : te.concat(mi({ key: `${se}[1]`, value: ee[1], valueSpec: t, style: W.style, styleSpec: W.styleSpec })); } function Z(W, te) { const ee = i.H(W.value), se = i.K(W.value), oe = W.value !== null ? W.value : te; if (h) { if (ee !== h) return [new i.V(W.key, oe, `${ee} stop domain type must match previous stop domain type ${h}`)]; } else h = ee; if (ee !== "number" && ee !== "string" && ee !== "boolean" && typeof se != "number" && typeof se != "string" && typeof se != "boolean") return [new i.V(W.key, oe, "stop domain value must be a number, string, or boolean")]; if (ee !== "number" && s !== "categorical") { let he = `number expected, ${ee} found`; return i.M(t) && s === void 0 && (he += '\nIf you intended to use a categorical function, specify `"type": "categorical"`.'), [new i.V(W.key, oe, he)]; } return s !== "categorical" || ee !== "number" || typeof se == "number" && isFinite(se) && Math.floor(se) === se ? s !== "categorical" && ee === "number" && typeof se == "number" && typeof _ == "number" && _ !== void 0 && se < _ ? [new i.V(W.key, oe, "stop domain values must appear in ascending order")] : (_ = se, s === "categorical" && se in T ? [new i.V(W.key, oe, "stop domain values must be unique")] : (T[se] = !0, [])) : [new i.V(W.key, oe, `integer expected, found ${String(se)}`)]; } } function Xs(c) { const t = (c.expressionContext === "property" ? i.S : i.U)(i.Q(c.value), c.valueSpec); if (t.result === "error") return t.value.map((h) => new i.V(`${c.key}${h.key}`, c.value, h.message)); const s = t.value.expression || t.value._styleExpression.expression; if (c.expressionContext === "property" && c.propertyKey === "text-font" && !s.outputDefined()) return [new i.V(c.key, c.value, `Invalid data expression for "${c.propertyKey}". Output values must be contained as literals within the expression.`)]; if (c.expressionContext === "property" && c.propertyType === "layout" && !i.W(s)) return [new i.V(c.key, c.value, '"feature-state" data expressions are not supported with layout properties.')]; if (c.expressionContext === "filter") return Hr(s, c); if (c.expressionContext && c.expressionContext.indexOf("cluster") === 0) { if (!i.X(s, ["zoom", "feature-state"])) return [new i.V(c.key, c.value, '"zoom" and "feature-state" expressions are not supported with cluster properties.')]; if (c.expressionContext === "cluster-initial" && !i.Y(s)) return [new i.V(c.key, c.value, "Feature data expressions are not supported with initial expression part of cluster properties.")]; } return []; } function Hr(c, t) { const s = /* @__PURE__ */ new Set(["zoom", "feature-state", "pitch", "distance-from-center"]); if (t.valueSpec && t.valueSpec.expression) for (const _ of t.valueSpec.expression.parameters) s.delete(_); if (s.size === 0) return []; const h = []; return c instanceof i.Z && s.has(c.name) ? [new i.V(t.key, t.value, `["${c.name}"] expression is not supported in a filter for a ${t.object.type} layer with id: ${t.object.id}`)] : (c.eachChild((_) => { h.push(...Hr(_, t)); }), h); } function qr(c) { const t = c.key, s = c.value, h = c.valueSpec, _ = []; return Array.isArray(h.values) ? h.values.indexOf(i.K(s)) === -1 && _.push(new i.V(t, s, `expected one of [${h.values.join(", ")}], ${JSON.stringify(s)} found`)) : Object.keys(h.values).indexOf(i.K(s)) === -1 && _.push(new i.V(t, s, `expected one of [${Object.keys(h.values).join(", ")}], ${JSON.stringify(s)} found`)), _; } function Wr(c) { return i.$(i.Q(c.value)) ? Xs(i.J({}, c, { expressionContext: "filter", valueSpec: c.styleSpec[`filter_${c.layerType || "fill"}`] })) : si(c); } function si(c) { const t = c.value, s = c.key; if (i.H(t) !== "array") return [new i.V(s, t, `array expected, ${i.H(t)} found`)]; const h = c.styleSpec; let _, y = []; if (t.length < 1) return [new i.V(s, t, "filter array must have at least 1 element")]; switch (y = y.concat(qr({ key: `${s}[0]`, value: t[0], valueSpec: h.filter_operator, style: c.style, styleSpec: c.styleSpec })), i.K(t[0])) { case "<": case "<=": case ">": case ">=": t.length >= 2 && i.K(t[1]) === "$type" && y.push(new i.V(s, t, `"$type" cannot be use with operator "${t[0]}"`)); case "==": case "!=": t.length !== 3 && y.push(new i.V(s, t, `filter array for operator "${t[0]}" must have 3 elements`)); case "in": case "!in": t.length >= 2 && (_ = i.H(t[1]), _ !== "string" && y.push(new i.V(`${s}[1]`, t[1], `string expected, ${_} found`))); for (let T = 2; T < t.length; T++) _ = i.H(t[T]), i.K(t[1]) === "$type" ? y = y.concat(qr({ key: `${s}[${T}]`, value: t[T], valueSpec: h.geometry_type, style: c.style, styleSpec: c.styleSpec })) : _ !== "string" && _ !== "number" && _ !== "boolean" && y.push(new i.V(`${s}[${T}]`, t[T], `string, number, or boolean expected, ${_} found`)); break; case "any": case "all": case "none": for (let T = 1; T < t.length; T++) y = y.concat(si({ key: `${s}[${T}]`, value: t[T], style: c.style, styleSpec: c.styleSpec })); break; case "has": case "!has": _ = i.H(t[1]), t.length !== 2 ? y.push(new i.V(s, t, `filter array for "${t[0]}" operator must have 2 elements`)) : _ !== "string" && y.push(new i.V(`${s}[1]`, t[1], `string expected, ${_} found`)); } return y; } function fs(c, t) { const s = c.key, h = c.style, _ = c.layer, y = c.styleSpec, T = c.value, z = c.objectKey, R = y[`${t}_${c.layerType}`]; if (!R) return []; const F = z.match(/^(.*)-use-theme$/); if (t === "paint" && F && R[F[1]]) return mi({ key: s, value: T, valueSpec: { type: "string" }, style: h, styleSpec: y }); const N = z.match(/^(.*)-transition$/); if (t === "paint" && N && R[N[1]] && R[N[1]].transition) return mi({ key: s, value: T, valueSpec: y.transition, style: h, styleSpec: y }); const G = c.valueSpec || R[z]; if (!G) return [new i.G(s, T, `unknown property "${z}"`)]; let Z; if (i.H(T) === "string" && i.M(G) && !G.tokens && (Z = /^{([^}]+)}$/.exec(T))) { const te = `\`{ "type": "identity", "property": ${Z ? JSON.stringify(Z[1]) : '"_"'} }\``; return [new i.V(s, T, `"${z}" does not support interpolation syntax Use an identity property function instead: ${te}.`)]; } const W = []; if (c.layerType === "symbol") z !== "text-field" || !h || h.glyphs || h.imports || W.push(new i.V(s, T, 'use of "text-field" requires a style "glyphs" property')), z === "text-font" && i.a0(i.Q(T)) && i.K(T.type) === "identity" && W.push(new i.V(s, T, '"text-font" does not support identity functions')); else if (c.layerType === "model" && t === "paint" && _ && _.layout && _.layout.hasOwnProperty("model-id") && i.M(G) && (i.a1(G) || i.N(G))) { const te = i.S(i.Q(T), G), ee = te.value.expression || te.value._styleExpression.expression; ee && !i.X(ee, ["measure-light"]) && (z === "model-emissive-strength" && i.Y(ee) && i.W(ee) || W.push(new i.V(s, T, `${z} does not support measure-light expressions when the model layer source is vector tile or GeoJSON.`))); } return W.concat(mi({ key: c.key, value: T, valueSpec: G, style: h, styleSpec: y, expressionContext: "property", propertyType: t, propertyKey: z })); } function zn(c) { return fs(c, "paint"); } function Rn(c) { return fs(c, "layout"); } function An(c) { let t = []; const s = c.value, h = c.key, _ = c.style, y = c.styleSpec; s.type || s.ref || t.push(new i.V(h, s, 'either "type" or "ref" is required')); let T = i.K(s.type); const z = i.K(s.ref); if (s.id) { const R = i.K(s.id); for (let F = 0; F < c.arrayIndex; F++) { const N = _.layers[F]; i.K(N.id) === R && t.push(new i.V(h, s.id, `duplicate layer id "${s.id}", previously used at line ${N.id.__line__}`)); } } if ("ref" in s) { let R; ["type", "source", "source-layer", "filter", "layout"].forEach((F) => { F in s && t.push(new i.V(h, s[F], `"${F}" is prohibited for ref layers`)); }), _.layers.forEach((F) => { i.K(F.id) === z && (R = F); }), R ? R.ref ? t.push(new i.V(h, s.ref, "ref cannot reference another ref layer")) : T = i.K(R.type) : typeof z == "string" && t.push(new i.V(h, s.ref, `ref layer "${z}" not found`)); } else if (T !== "background" && T !== "sky" && T !== "slot") if (s.source) { const R = _.sources && _.sources[s.source], F = R && i.K(R.type); R ? F === "vector" && T === "raster" ? t.push(new i.V(h, s.source, `layer "${s.id}" requires a raster source`)) : F === "raster" && T !== "raster" ? t.push(new i.V(h, s.source, `layer "${s.id}" requires a vector source`)) : F !== "vector" || s["source-layer"] ? F === "raster-dem" && T !== "hillshade" ? t.push(new i.V(h, s.source, "raster-dem source can only be used with layer type 'hillshade'.")) : F !== "raster-array" || ["raster", "raster-particle"].includes(T) ? T !== "line" || !s.paint || !s.paint["line-gradient"] && !s.paint["line-trim-offset"] || F === "geojson" && R.lineMetrics ? T === "raster-particle" && F !== "raster-array" && t.push(new i.V(h, s.source, `layer "${s.id}" requires a 'raster-array' source.`)) : t.push(new i.V(h, s, `layer "${s.id}" specifies a line-gradient, which requires a GeoJSON source with \`lineMetrics\` enabled.`)) : t.push(new i.V(h, s.source, "raster-array source can only be used with layer type 'raster'.")) : t.push(new i.V(h, s, `layer "${s.id}" must specify a "source-layer"`)) : t.push(new i.V(h, s.source, `source "${s.source}" not found`)); } else t.push(new i.V(h, s, 'missing required property "source"')); return t = t.concat($n({ key: h, value: s, valueSpec: y.layer, style: c.style, styleSpec: c.styleSpec, objectElementValidators: { "*": () => [], type: () => mi({ key: `${h}.type`, value: s.type, valueSpec: y.layer.type, style: c.style, styleSpec: c.styleSpec, object: s, objectKey: "type" }), filter: (R) => Wr(i.J({ layerType: T }, R)), layout: (R) => $n({ layer: s, key: R.key, value: R.value, valueSpec: {}, style: R.style, styleSpec: R.styleSpec, objectElementValidators: { "*": (F) => Rn(i.J({ layerType: T }, F)) } }), paint: (R) => $n({ layer: s, key: R.key, value: R.value, valueSpec: {}, style: R.style, styleSpec: R.styleSpec, objectElementValidators: { "*": (F) => zn(i.J({ layerType: T, layer: s }, F)) } }) } })), t; } function js(c) { const t = c.value, s = c.key, h = i.H(t); return h !== "string" ? [new i.V(s, t, `string expected, ${h} found`)] : []; } const yo = { promoteId: function({ key: c, value: t }) { if (i.H(t) === "string") return js({ key: c, value: t }); { const s = []; for (const h in t) s.push(...js({ key: `${c}.${h}`, value: t[h] })); return s; } } }; function xo(c) { const t = c.value, s = c.key, h = c.styleSpec, _ = c.style; if (!t.type) return [new i.V(s, t, '"type" is required')]; const y = i.K(t.type); let T = []; switch (["vector", "raster", "raster-dem", "raster-array"].includes(y) && (t.url || t.tiles || T.push(new i.G(s, t, 'Either "url" or "tiles" is required.'))), y) { case "vector": case "raster": case "raster-dem": case "raster-array": return T = T.concat($n({ key: s, value: t, valueSpec: h[`source_${y.replace("-", "_")}`], style: c.style, styleSpec: h, objectElementValidators: yo })), T; case "geojson": if (T = $n({ key: s, value: t, valueSpec: h.source_geojson, style: _, styleSpec: h, objectElementValidators: yo }), t.cluster) for (const z in t.clusterProperties) { const [R, F] = t.clusterProperties[z], N = typeof R == "string" ? [R, ["accumulated"], ["get", z]] : R; T.push(...Xs({ key: `${s}.${z}.map`, value: F, expressionContext: "cluster-map" })), T.push(...Xs({ key: `${s}.${z}.reduce`, value: N, expressionContext: "cluster-reduce" })); } return T; case "video": return $n({ key: s, value: t, valueSpec: h.source_video, style: _, styleSpec: h }); case "image": return $n({ key: s, value: t, valueSpec: h.source_image, style: _, styleSpec: h }); case "canvas": return [new i.V(s, null, "Please use runtime APIs to add canvas sources, rather than including them in stylesheets.", "source.canvas")]; default: return qr({ key: `${s}.type`, value: t.type, valueSpec: { values: vo(h) }, style: _, styleSpec: h }); } } function vo(c) { return c.source.reduce((t, s) => { const h = c[s]; return h.type.type === "enum" && (t = t.concat(Object.keys(h.type.values))), t; }, []); } function yr(c) { const t = c.value, s = c.styleSpec, h = s.light, _ = c.style; let y = []; const T = i.H(t); if (t === void 0) return y; if (T !== "object") return y = y.concat([new i.V("light", t, `object expected, ${T} found`)]), y; for (const z in t) { const R = z.match(/^(.*)-transition$/), F = z.match(/^(.*)-use-theme$/); y = y.concat(F && h[F[1]] ? mi({ key: z, value: t[z], valueSpec: { type: "string" }, style: _, styleSpec: s }) : R && h[R[1]] && h[R[1]].transition ? mi({ key: z, value: t[z], valueSpec: s.transition, style: _, styleSpec: s }) : h[z] ? mi({ key: z, value: t[z], valueSpec: h[z], style: _, styleSpec: s }) : [new i.V(z, t[z], `unknown property "${z}"`)]); } return y; } function Mr(c) { const t = c.value; let s = []; if (!t) return s; const h = i.H(t); if (h !== "object") return s = s.concat([new i.V("light-3d", t, `object expected, ${h} found`)]), s; const _ = c.styleSpec, y = _["light-3d"], T = c.key, z = c.style, R = c.style.lights; for (const G of ["type", "id"]) if (!(G in t)) return s = s.concat([new i.V("light-3d", t, `missing property ${G} on light`)]), s; if (t.type && R) for (let G = 0; G < c.arrayIndex; G++) { const Z = i.K(t.type), W = R[G]; i.K(W.type) === Z && s.push(new i.V(T, t.id, `duplicate light type "${t.type}", previously defined at line ${W.id.__line__}`)); } const F = `properties_light_${t.type}`; if (!(F in _)) return s = s.concat([new i.V("light-3d", t, `Invalid light type ${t.type}`)]), s; const N = _[F]; for (const G in t) if (G === "properties") { const Z = t[G], W = i.H(Z); if (W !== "object") return s = s.concat([new i.V("properties", Z, `object expected, ${W} found`)]), s; for (const te in Z) s = s.concat(N[te] ? mi({ key: te, value: Z[te], valueSpec: N[te], style: z, styleSpec: _ }) : [new i.G(c.key, Z[te], `unknown property "${te}"`)]); } else { const Z = G.match(/^(.*)-transition$/), W = G.match(/^(.*)-use-theme$/); s = s.concat(W && y[W[1]] ? mi({ key: G, value: t[G], valueSpec: { type: "string" }, style: z, styleSpec: _ }) : Z && y[Z[1]] && y[Z[1]].transition ? mi({ key: G, value: t[G], valueSpec: _.transition, style: z, styleSpec: _ }) : y[G] ? mi({ key: G, value: t[G], valueSpec: y[G], style: z, styleSpec: _ }) : [new i.G(G, t[G], `unknown property "${G}"`)]); } return s; } function io(c) { const t = c.value, s = c.key, h = c.style, _ = c.styleSpec, y = _.terrain; let T = []; const z = i.H(t); if (t === void 0 || z === "null") return T; if (z !== "object") return T = T.concat([new i.V("terrain", t, `object expected, ${z} found`)]), T; for (const R in t) { const F = R.match(/^(.*)-transition$/), N = R.match(/^(.*)-use-theme$/); T = T.concat(N && y[N[1]] ? mi({ key: R, value: t[R], valueSpec: { type: "string" }, style: h, styleSpec: _ }) : F && y[F[1]] && y[F[1]].transition ? mi({ key: R, value: t[R], valueSpec: _.transition, style: h, styleSpec: _ }) : y[R] ? mi({ key: R, value: t[R], valueSpec: y[R], style: h, styleSpec: _ }) : [new i.G(R, t[R], `unknown property "${R}"`)]); } if (t.source) { const R = h.sources && h.sources[t.source], F = R && i.K(R.type); R ? F !== "raster-dem" && T.push(new i.V(s, t.source, `terrain cannot be used with a source of type ${String(F)}, it only be used with a "raster-dem" source type`)) : T.push(new i.V(s, t.source, `source "${t.source}" not found`)); } else T.push(new i.V(s, t, 'terrain is missing required property "source"')); return T; } function Ys(c) { const t = c.value, s = c.style, h = c.styleSpec, _ = h.fog; let y = []; const T = i.H(t); if (t === void 0) return y; if (T !== "object") return y = y.concat([new i.V("fog", t, `object expected, ${T} found`)]), y; for (const z in t) { const R = z.match(/^(.*)-transition$/), F = z.match(/^(.*)-use-theme$/); y = y.concat(F && _[F[1]] ? mi({ key: z, value: t[z], valueSpec: { type: "string" }, style: s, styleSpec: h }) : R && _[R[1]] && _[R[1]].transition ? mi({ key: z, value: t[z], valueSpec: h.transition, style: s, styleSpec: h }) : _[z] ? mi({ key: z, value: t[z], valueSpec: _[z], style: s, styleSpec: h }) : [new i.G(z, t[z], `unknown property "${z}"`)]); } return y; } const Sr = { "*": () => [], array: $s, boolean: function(c) { const t = c.value, s = c.key, h = i.H(t); return h !== "boolean" ? [new i.V(s, t, `boolean expected, ${h} found`)] : []; }, number: vi, color: function(c) { const t = c.key, s = c.value, h = i.H(s); return h !== "string" ? [new i.V(t, s, `color expected, ${h} found`)] : i._.parseCSSColor(s) === null ? [new i.V(t, s, `color expected, "${s}" found`)] : []; }, enum: qr, filter: Wr, function: kn, layer: An, object: $n, source: xo, model: i.a2, light: yr, "light-3d": Mr, terrain: io, fog: Ys, string: js, formatted: function(c) { return js(c).length === 0 ? [] : Xs(c); }, resolvedImage: function(c) { return js(c).length === 0 ? [] : Xs(c); }, projection: function(c) { const t = c.value, s = c.styleSpec, h = s.projection, _ = c.style; let y = []; const T = i.H(t); if (T === "object") for (const z in t) y = y.concat(mi({ key: z, value: t[z], valueSpec: h[z], style: _, styleSpec: s })); else T !== "string" && (y = y.concat([new i.V("projection", t, `object or string expected, ${T} found`)])); return y; }, import: function(c) { const { value: t, styleSpec: s } = c, { data: h, ..._ } = t; Object.defineProperty(_, "__line__", { value: t.__line__, enumerable: !1 }); let y = $n(i.J({}, c, { value: _, valueSpec: s.import })); return i.K(_.id) === "" && y.push(new i.V(`${c.key}.id`, _, "import id can't be an empty string")), h && (y = y.concat(Vn(h, s, { key: `${c.key}.data` }))), y; } }; function mi(c, t = !1) { const s = c.value, h = c.valueSpec, _ = c.styleSpec; if (h.expression && i.a0(i.K(s))) return kn(c); if (h.expression && i.O(i.Q(s))) return Xs(c); if (h.type && Sr[h.type]) { const y = Sr[h.type](c); return t === !0 && y.length > 0 && i.H(c.value) === "array" ? Xs(c) : y; } return $n(i.J({}, c, { valueSpec: h.type ? _[h.type] : h })); } function On(c) { const t = c.value, s = c.key, h = js(c); return h.length || (t.indexOf("{fontstack}") === -1 && h.push(new i.V(s, t, '"glyphs" url must include a "{fontstack}" token')), t.indexOf("{range}") === -1 && h.push(new i.V(s, t, '"glyphs" url must include a "{range}" token'))), h; } function Vn(c, t = i.a3, s = {}) { return mi({ key: s.key || "", value: c, valueSpec: t.$root, styleSpec: t, style: c, objectElementValidators: { glyphs: On, "*": () => [] } }); } function Zi(c, t = i.a3) { return qe(Vn(c, t)); } const Jn = (c) => qe(xo(c)), Fn = (c) => qe(yr(c)), Ls = (c) => qe(Mr(c)), zs = (c) => qe(io(c)), Vo = (c) => qe(Ys(c)), Ke = (c) => qe(function(t) { const s = t.value, h = t.style, _ = t.styleSpec, y = _.snow; let T = []; const z = i.H(s); if (s === void 0) return T; if (z !== "object") return T = T.concat([new i.V("snow", s, `object expected, ${z} found`)]), T; for (const R in s) { const F = R.match(/^(.*)-transition$/); T = T.concat(F && y[F[1]] && y[F[1]].transition ? mi({ key: R, value: s[R], valueSpec: _.transition, style: h, styleSpec: _ }) : y[R] ? mi({ key: R, value: s[R], valueSpec: y[R], style: h, styleSpec: _ }) : [new i.G(R, s[R], `unknown property "${R}"`)]); } return T; }(c)), re = (c) => qe(function(t) { const s = t.value, h = t.style, _ = t.styleSpec, y = _.rain; let T = []; const z = i.H(s); if (s === void 0) return T; if (z !== "object") return T = T.concat([new i.V("rain", s, `object expected, ${z} found`)]), T; for (const R in s) { const F = R.match(/^(.*)-transition$/); T = T.concat(F && y[F[1]] && y[F[1]].transition ? mi({ key: R, value: s[R], valueSpec: _.transition, style: h, styleSpec: _ }) : y[R] ? mi({ key: R, value: s[R], valueSpec: y[R], style: h, styleSpec: _ }) : [new i.G(R, s[R], `unknown property "${R}"`)]); } return T; }(c)), le = (c) => qe(An(c)), ge = (c) => qe(Wr(c)), Le = (c) => qe(zn(c)), Ce = (c) => qe(Rn(c)), Be = (c) => qe(i.a2(c)); function qe(c) { return c.slice().sort((t, s) => t.line && s.line ? t.line - s.line : 0); } function Pe(c, t) { let s = !1; if (t && t.length) for (const h of t) h instanceof i.G ? i.w(h.message) : (c.fire(new i.y(new Error(h.message))), s = !0); return s; } let Ye; class Qe extends i.E { constructor(t, s = "flat") { super(), this._transitionable = new i.a4(Ye || (Ye = new i.a5({ anchor: new i.a6(i.a3.light.anchor), position: new i.a7(i.a3.light.position), color: new i.a6(i.a3.light.color), intensity: new i.a6(i.a3.light.intensity) }))), this.setLight(t, s), this._transitioning = this._transitionable.untransitioned(); } getLight() { return this._transitionable.serialize(); } setLight(t, s, h = {}) { this._validate(Fn, t, h) || (this._transitionable.setTransitionOrValue(t), this.id = s); } updateTransitions(t) { this._transitioning = this._transitionable.transitioned(t, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(t) { this.properties = this._transitioning.possiblyEvaluate(t); } _validate(t, s, h) { return (!h || h.validate !== !1) && Pe(this, t.call(Zi, i.l({ value: s, style: { glyphs: !0, sprite: !0 }, styleSpec: i.a3 }))); } } let it = class extends i.E { constructor(c, t, s, h) { super(), this.scope = s, this._transitionable = new i.a4(new i.a5({ source: new i.a6(i.a3.terrain.source), exaggeration: new i.a6(i.a3.terrain.exaggeration) }), s, h), this._transitionable.setTransitionOrValue(c, h), this._transitioning = this._transitionable.untransitioned(), this.drapeRenderMode = t; } get() { return this._transitionable.serialize(); } set(c, t) { this._transitionable.setTransitionOrValue(c, t); } updateTransitions(c) { this._transitioning = this._transitionable.transitioned(c, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(c) { this.properties = this._transitioning.possiblyEvaluate(c); } getExaggeration(c) { return this._transitioning.possiblyEvaluate(new i.a8(c)).get("exaggeration"); } getAttenuationRange() { if (!this.isZoomDependent()) return null; const c = this._transitionable._values.exaggeration; if (!c) return null; const t = c.value.expression; if (!t) return null; let s = -1, h = -1, _ = 1; for (const y of t.zoomStops) _ = t.evaluate(new i.a8(y)), _ > 0.01 ? (s = y, h = -1) : h = y; return _ < 0.01 && s > 0 && h > s ? [s, h] : null; } isZoomDependent() { const c = this._transitionable._values.exaggeration; return c != null && c.value != null && c.value.expression != null && c.value.expression instanceof i.a9; } }; const mt = 45, Ct = 65, It = 0.05; function Kt(c, t, s, h) { const _ = i.ac(mt, Ct, s), [y, T] = di(c, h); let z = 1 - Math.min(1, Math.exp((t - y) / (T - y) * -6)); return z *= z * z, z = Math.min(1, 1.00747 * z), z * _ * c.alpha; } function di(c, t) { const s = 0.5 / Math.tan(0.5 * t); return [c.range[0] + s, c.range[1] + s]; } function li(c, t, s, h, _) { const y = i.ab.vec3.transformMat4([], [t, s, h], _.mercatorFogMatrix); return Kt(c, i.ab.vec3.length(y), _.pitch, _._fov); } function ri(c, t, s, h, _, y, T) { const z = [[s, h, 0], [_, h, 0], [_, y, 0], [s, y, 0]]; let R = Number.MAX_VALUE, F = -Number.MAX_VALUE; for (const N of z) { const G = i.ab.vec3.transformMat4([], N, t), Z = i.ab.vec3.length(G); R = Math.min(R, Z), F = Math.max(F, Z); } return [Kt(c, R, T.pitch, T._fov), Kt(c, F, T.pitch, T._fov)]; } class Ki extends i.E { constructor(t, s, h, _) { super(); const y = new i.a5({ range: new i.a6(i.a3.fog.range), color: new i.a6(i.a3.fog.color), "color-use-theme": new i.a6({ type: "string", "property-type": "data-constant", default: "default" }), "high-color": new i.a6(i.a3.fog["high-color"]), "high-color-use-theme": new i.a6({ type: "string", "property-type": "data-constant", default: "default" }), "space-color": new i.a6(i.a3.fog["space-color"]), "space-color-use-theme": new i.a6({ type: "string", "property-type": "data-constant", default: "default" }), "horizon-blend": new i.a6(i.a3.fog["horizon-blend"]), "star-intensity": new i.a6(i.a3.fog["star-intensity"]), "vertical-range": new i.a6(i.a3.fog["vertical-range"]) }); this._transitionable = new i.a4(y, h, new Map(_)), this.set(t, _), this._transitioning = this._transitionable.untransitioned(), this._transform = s, this.properties = new i.ad(y), this.scope = h; } get state() { const t = this._transform, s = t.projection.name === "globe", h = i.ae(t.zoom), _ = this.properties.get("range"), y = [0.5, 3]; return { range: s ? [i.af(y[0], _[0], h), i.af(y[1], _[1], h)] : _, horizonBlend: this.properties.get("horizon-blend"), alpha: this.properties.get("color").a }; } get() { return this._transitionable.serialize(); } set(t, s, h = {}) { if (this._validate(Vo, t, h)) return; const _ = i.l({}, t); for (const y of Object.keys(i.a3.fog)) _[y] === void 0 && (_[y] = i.a3.fog[y].default); this._options = _, this._transitionable.setTransitionOrValue(this._options, s); } getOpacity(t) { if (!this._transform.projection.supportsFog) return 0; const s = this.properties && this.properties.get("color") || 1; return (this._transform.projection.name === "globe" ? 1 : i.ac(mt, Ct, t)) * s.a; } getOpacityAtLatLng(t, s) { return this._transform.projection.supportsFog ? function(h, _, y) { const T = i.aa.fromLngLat(_), z = y.elevation ? y.elevation.getAtPointOrZero(T) : 0; return li(h, T.x, T.y, z, y); }(this.state, t, s) : 0; } getOpacityForTile(t) { if (!this._transform.projection.supportsFog) return [1, 1]; const s = this._transform.calculateFogTileMatrix(t.toUnwrapped()); return ri(this.state, s, 0, 0, i.ag, i.ag, this._transform); } getOpacityForBounds(t, s, h, _, y) { return this._transform.projection.supportsFog ? ri(this.state, t, s, h, _, y, this._transform) : [1, 1]; } getFovAdjustedRange(t) { return this._transform.projection.supportsFog ? di(this.state, t) : [0, 1]; } isVisibleOnFrustum(t) { if (!this._transform.projection.supportsFog) return !1; const s = [4, 5, 6, 7]; for (const h of s) { const _ = t.points[h]; let y; if (_[2] >= 0) y = _; else { const T = t.points[h - 4]; y = i.ah(T, _, T[2] / (T[2] - _[2])); } if (li(this.state, y[0], y[1], 0, this._transform) >= It) return !0; } return !1; } updateConfig(t) { this._transitionable.setTransitionOrValue(this._options, new Map(t)); } updateTransitions(t) { this._transitioning = this._transitionable.transitioned(t, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(t) { this.properties = this._transitioning.possiblyEvaluate(t); } _validate(t, s, h) { return (!h || h.validate !== !1) && Pe(this, t.call(Zi, i.l({ value: s, style: { glyphs: !0, sprite: !0 }, styleSpec: i.a3 }))); } } let Ni, Ei, $i, Hi, Xn = class extends i.E { constructor(c, t, s, h) { super(); const _ = Ni || (Ni = new i.a5({ density: new i.a6(i.a3.snow.density), intensity: new i.a6(i.a3.snow.intensity), color: new i.a6(i.a3.snow.color), opacity: new i.a6(i.a3.snow.opacity), vignette: new i.a6(i.a3.snow.vignette), "vignette-color": new i.a6(i.a3.snow["vignette-color"]), "center-thinning": new i.a6(i.a3.snow["center-thinning"]), direction: new i.a6(i.a3.snow.direction), "flake-size": new i.a6(i.a3.snow["flake-size"]) })); this._transitionable = new i.a4(_, s, new Map(h)), this.set(c, h), this._transitioning = this._transitionable.untransitioned(), this.properties = new i.ad(_), this.scope = s; } get state() { const c = this.properties.get("opacity"), t = this.properties.get("color"), s = this.properties.get("direction"), h = i.ai(s[0]), _ = -Math.max(i.ai(s[1]), 0.01), y = [Math.cos(h) * Math.cos(_), Math.sin(h) * Math.cos(_), Math.sin(_)], T = this.properties.get("vignette"), z = this.properties.get("vignette-color"); return z.a = T, { density: this.properties.get("density"), intensity: this.properties.get("intensity"), color: new i.aj(t.r, t.g, t.b, t.a * c), direction: y, centerThinning: this.properties.get("center-thinning"), flakeSize: this.properties.get("flake-size"), vignetteColor: z }; } get() { return this._transitionable.serialize(); } set(c, t, s = {}) { if (this._validate(Ke, c, s)) return; const h = i.l({}, c); for (const _ of Object.keys(i.a3.snow)) h[_] === void 0 && (h[_] = i.a3.snow[_].default); this._options = h, this._transitionable.setTransitionOrValue(this._options, t); } updateConfig(c) { this._transitionable.setTransitionOrValue(this._options, new Map(c)); } updateTransitions(c) { this._transitioning = this._transitionable.transitioned(c, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(c) { this.properties = this._transitioning.possiblyEvaluate(c); } _validate(c, t, s) { return (!s || s.validate !== !1) && Pe(this, c.call(Zi, i.l({ value: t, style: { glyphs: !0, sprite: !0 }, styleSpec: i.a3 }))); } }, Gs = class extends i.E { constructor(c, t, s, h) { super(); const _ = Ei || (Ei = new i.a5({ density: new i.a6(i.a3.rain.density), intensity: new i.a6(i.a3.rain.intensity), color: new i.a6(i.a3.rain.color), opacity: new i.a6(i.a3.rain.opacity), vignette: new i.a6(i.a3.rain.vignette), "vignette-color": new i.a6(i.a3.rain["vignette-color"]), "center-thinning": new i.a6(i.a3.rain["center-thinning"]), direction: new i.a6(i.a3.rain.direction), "droplet-size": new i.a6(i.a3.rain["droplet-size"]), "distortion-strength": new i.a6(i.a3.rain["distortion-strength"]) })); this._transitionable = new i.a4(_, s, new Map(h)), this.set(c, h), this._transitioning = this._transitionable.untransitioned(), this.properties = new i.ad(_), this.scope = s; } get state() { const c = this.properties.get("opacity"), t = this.properties.get("color"), s = this.properties.get("direction"), h = i.ai(s[0]), _ = -Math.max(i.ai(s[1]), 0.01), y = [Math.cos(h) * Math.cos(_), Math.sin(h) * Math.cos(_), Math.sin(_)], T = this.properties.get("vignette-color"); return T.a = this.properties.get("vignette"), { density: this.properties.get("density"), intensity: this.properties.get("intensity"), color: new i.aj(t.r, t.g, t.b, t.a * c), direction: y, centerThinning: this.properties.get("center-thinning"), dropletSize: this.properties.get("droplet-size"), distortionStrength: this.properties.get("distortion-strength"), vignetteColor: T }; } get() { return this._transitionable.serialize(); } set(c, t, s = {}) { if (this._validate(re, c, s)) return; const h = i.l({}, c); for (const _ of Object.keys(i.a3.rain)) h[_] === void 0 && (h[_] = i.a3.rain[_].default); this._options = h, this._transitionable.setTransitionOrValue(this._options, t); } updateConfig(c) { this._transitionable.setTransitionOrValue(this._options, new Map(c)); } updateTransitions(c) { this._transitioning = this._transitionable.transitioned(c, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(c) { this.properties = this._transitioning.possiblyEvaluate(c); } _validate(c, t, s) { return (!s || s.validate !== !1) && Pe(this, c.call(Zi, i.l({ value: t, style: { glyphs: !0, sprite: !0 }, styleSpec: i.a3 }))); } }; class ps extends i.E { constructor(t, s, h, _) { super(), this.scope = h, this._options = t, this.properties = new i.ad(s), this._transitionable = new i.a4(s, h, new Map(_)), this._transitionable.setTransitionOrValue(t.properties), this._transitioning = this._transitionable.untransitioned(); } updateConfig(t) { this._transitionable.setTransitionOrValue(this._options.properties, new Map(t)); } updateTransitions(t) { this._transitioning = this._transitionable.transitioned(t, this._transitioning); } hasTransition() { return this._transitioning.hasTransition(); } recalculate(t) { this.properties = this._transitioning.possiblyEvaluate(t); } get() { return this._options.properties = this._transitionable.serialize(), this._options; } set(t, s) { this._options = t, this._transitionable.setTransitionOrValue(t.properties, s); } shadowsEnabled() { return !!this.properties && this.properties.get("cast-shadows") === !0; } } class vs { constructor(t, s, h, _) { this.screenBounds = t, this.cameraPoint = s, this._screenRaycastCache = {}, this._cameraRaycastCache = {}, this.isAboveHorizon = h, this.screenGeometry = this.bufferedScreenGeometry(0), this.screenGeometryMercator = this._bufferedScreenMercator(0, _); } static createFromScreenPoints(t, s) { let h, _; if (t instanceof i.P || typeof t[0] == "number") { const y = i.P.convert(t); h = [y], _ = s.isPointAboveHorizon(y); } else { const y = i.P.convert(t[0]), T = i.P.convert(t[1]); h = [y, T], _ = i.al(y, T).every((z) => s.isPointAboveHorizon(z)); } return new vs(h, s.getCameraPoint(), _, s); } isPointQuery() { return this.screenBounds.length === 1; } bufferedScreenGeometry(t) { return i.al(this.screenBounds[0], this.screenBounds.length === 1 ? this.screenBounds[0] : this.screenBounds[1], t); } bufferedCameraGeometry(t) { const s = this.screenBounds[0], h = this.screenBounds.length === 1 ? this.screenBounds[0].add(new i.P(1, 1)) : this.screenBounds[1], _ = i.al(s, h, 0, !1); return this.cameraPoint.y > h.y && (this.cameraPoint.x > s.x && this.cameraPoint.x < h.x ? _.splice(3, 0, this.cameraPoint) : this.cameraPoint.x >= h.x ? _[2] = this.cameraPoint : this.cameraPoint.x <= s.x && (_[3] = this.cameraPoint)), i.am(_, t); } bufferedCameraGeometryGlobe(t) { const s = this.screenBounds[0], h = this.screenBounds.length === 1 ? this.screenBounds[0].add(new i.P(1, 1)) : this.screenBounds[1], _ = i.al(s, h, t), y = this.cameraPoint.clone(); switch (3 * ((y.y > s.y) + (y.y > h.y)) + ((y.x > s.x) + (y.x > h.x))) { case 0: _[0] = y, _[4] = y.clone(); break; case 1: _.splice(1, 0, y); break; case 2: _[1] = y; break; case 3: _.splice(4, 0, y); break; case 5: _.splice(2, 0, y); break; case 6: _[3] = y; break; case 7: _.splice(3, 0, y); break; case 8: _[2] = y; } return _; } containsTile(t, s, h, _ = 0) { const y = t.queryPadding / s._pixelsPerMercatorPixel + 1, T = h ? this._bufferedCameraMercator(y, s) : this._bufferedScreenMercator(y, s); let z = t.tileID.wrap + (T.unwrapped ? _ : 0); const R = T.polygon.map((se) => i.an(t.tileTransform, se, z)); if (!i.ao(R, 0, 0, i.ag, i.ag)) return; z = t.tileID.wrap + (this.screenGeometryMercator.unwrapped ? _ : 0); const F = this.screenGeometryMercator.polygon.map((se) => i.ap(t.tileTransform, se, z)), N = F.map((se) => new i.P(se[0], se[1])), G = s.getFreeCameraOptions().position || new i.aa(0, 0, 0), Z = i.ap(t.tileTransform, G, z), W = F.map((se) => { const oe = i.ab.vec3.sub(se, se, Z); return i.ab.vec3.normalize(oe, oe), new i.aq(Z, oe); }), te = i.ar(t, 1, s.zoom) * s._pixelsPerMercatorPixel; return { queryGeometry: this, tilespaceGeometry: N, tilespaceRays: W, bufferedTilespaceGeometry: R, bufferedTilespaceBounds: (ee = i.as(R), ee.min.x = i.aw(ee.min.x, 0, i.ag), ee.min.y = i.aw(ee.min.y, 0, i.ag), ee.max.x = i.aw(ee.max.x, 0, i.ag), ee.max.y = i.aw(ee.max.y, 0, i.ag), ee), tile: t, tileID: t.tileID, pixelToTileUnitsFactor: te }; var ee; } _bufferedScreenMercator(t, s) { const h = oa(t); if (this._screenRaycastCache[h]) return this._screenRaycastCache[h]; { let _; return _ = s.projection.name === "globe" ? this._projectAndResample(this.bufferedScreenGeometry(t), s) : { polygon: this.bufferedScreenGeometry(t).map((y) => s.pointCoordinate3D(y)), unwrapped: !0 }, this._screenRaycastCache[h] = _, _; } } _bufferedCameraMercator(t, s) { const h = oa(t); if (this._cameraRaycastCache[h]) return this._cameraRaycastCache[h]; { let _; return _ = s.projection.name === "globe" ? this._projectAndResample(this.bufferedCameraGeometryGlobe(t), s) : { polygon: this.bufferedCameraGeometry(t).map((y) => s.pointCoordinate3D(y)), unwrapped: !0 }, this._cameraRaycastCache[h] = _, _; } } _projectAndResample(t, s) { const h = function(y, T) { const z = i.ab.mat4.multiply([], T.pixelMatrix, T.globeMatrix), R = [0, -i.ax, 0, 1], F = [0, i.ax, 0, 1], N = [0, 0, 0, 1]; i.ab.vec4.transformMat4(R, R, z), i.ab.vec4.transformMat4(F, F, z), i.ab.vec4.transformMat4(N, N, z); const G = new i.P(R[0] / R[3], R[1] / R[3]), Z = new i.P(F[0] / F[3], F[1] / F[3]), W = i.au(y, G) && R[3] < N[3], te = i.au(y, Z) && F[3] < N[3]; if (!W && !te) return null; const ee = function(we, ve, Ae) { for (let Oe = 1; Oe < we.length; Oe++) { const Xe = Er(ve.pointCoordinate3D(we[Oe - 1]).x), He = Er(ve.pointCoordinate3D(we[Oe]).x); if (Ae < 0) { if (Xe < He) return { idx: Oe, t: -Xe / (He - 1 - Xe) }; } else if (He < Xe) return { idx: Oe, t: (1 - Xe) / (He + 1 - Xe) }; } return null; }(y, T, W ? -1 : 1); if (!ee) return null; const { idx: se, t: oe } = ee; let he = se > 1 ? ra(y.slice(0, se), T) : [], _e = se < y.length ? ra(y.slice(se), T) : []; he = he.map((we) => new i.P(Er(we.x), we.y)), _e = _e.map((we) => new i.P(Er(we.x), we.y)); const pe = [...he]; pe.length === 0 && pe.push(_e[_e.length - 1]); const Me = i.af(pe[pe.length - 1].y, (_e.length === 0 ? he[0] : _e[0]).y, oe); let xe; return xe = W ? [new i.P(0, Me), new i.P(0, 0), new i.P(1, 0), new i.P(1, Me)] : [new i.P(1, Me), new i.P(1, 1), new i.P(0, 1), new i.P(0, Me)], pe.push(...xe), _e.length === 0 ? pe.push(he[0]) : pe.push(..._e), { polygon: pe.map((we) => new i.aa(we.x, we.y)), unwrapped: !1 }; }(t, s); if (h) return h; const _ = function(y, T) { let z = !1, R = -1 / 0, F = 0; for (let G = 0; G < y.length - 1; G++) y[G].x > R && (R = y[G].x, F = G); for (let G = 0; G < y.length - 1; G++) { const Z = (F + G) % (y.length - 1), W = y[Z], te = y[Z + 1]; Math.abs(W.x - te.x) > 0.5 && (W.x < te.x ? (W.x += 1, Z === 0 && (y[y.length - 1].x += 1)) : (te.x += 1, Z + 1 === y.length - 1 && (y[0].x += 1)), z = !0); } const N = i.at(T.center.lng); return z && N < Math.abs(N - 1) && y.forEach((G) => { G.x -= 1; }), { polygon: y, unwrapped: z }; }(ra(t, s).map((y) => new i.P(Er(y.x), y.y)), s); return { polygon: _.polygon.map((y) => new i.aa(y.x, y.y)), unwrapped: _.unwrapped }; } } function ra(c, t) { return i.av(c, (s) => { const h = t.pointCoordinate3D(s); s.x = h.x, s.y = h.y; }, 1 / 256); } function Er(c) { return c < 0 ? 1 + c % 1 : c % 1; } function oa(c) { return 100 * c | 0; } function cl(c, t, s, h, _) { const y = function(z, R) { if (z) return _(z); if (R) { if (c.url && R.tiles && c.tiles && delete c.tiles, R.variants) { if (!Array.isArray(R.variants)) return _(new Error("variants must be an array")); for (const N of R.variants) { if (N == null || typeof N != "object" || N.constructor !== Object) return _(new Error("variant must be an object")); if (!Array.isArray(N.capabilities)) return _(new Error("capabilities must be an array")); if (N.capabilities.length === 1 && N.capabilities[0] === "meshopt") { R = i.l(R, N); break; } } } const F = i.ay(i.l({}, R, c), ["tilejson", "tiles", "minzoom", "maxzoom", "attribution", "mapbox_logo", "bounds", "scheme", "tileSize", "encoding", "vector_layers", "raster_layers", "worldview_options", "worldview_default", "worldview"]); F.tiles = t.canonicalizeTileset(F, c.url), _(null, F); } }, T = function(z, R, F) { if (!z) return null; if (!R && !F) return z; F = F || z.worldview_default; const N = Object.values(z.language || {}); if (N.length === 0) return null; const G = Object.values(z.worldview || {}); if (G.length === 0) return null; const Z = N.every((te) => te === R), W = G.every((te) => te === F); return Z && W ? z : R in (z.language_options || {}) || F in (z.worldview_options || {}) ? null : z.language_options && z.worldview_options ? z : null; }(c.data, s, h); return T ? i.q.frame(() => y(null, T)) : c.url ? i.n(t.transformRequest(t.normalizeSourceURL(c.url, null, s, h), i.R.Source), y) : i.q.frame(() => { const { data: z, ...R } = c; y(null, R); }); } class Uo { constructor(t, s, h) { this.bounds = i.az.convert(this.validateBounds(t)), this.minzoom = s || 0, this.maxzoom = h || 24; } validateBounds(t) { return Array.isArray(t) && t.length === 4 ? [Math.max(-180, t[0]), Math.max(-90, t[1]), Math.min(180, t[2]), Math.min(90, t[3])] : [-180, -90, 180, 90]; } contains(t) { const s = Math.pow(2, t.z), h = Math.floor(i.at(this.bounds.getWest()) * s), _ = Math.floor(i.aA(this.bounds.getNorth()) * s), y = Math.ceil(i.at(this.bounds.getEast()) * s), T = Math.ceil(i.aA(this.bounds.getSouth()) * s); return t.x >= h && t.x < y && t.y >= _ && t.y < T; } } class jo extends i.E { constructor(t, s, h, _) { if (super(), this.id = t, this.dispatcher = h, this.type = "vector", this.minzoom = 0, this.maxzoom = 22, this.scheme = "xyz", this.tileSize = 512, this.reparseOverscaled = !0, this.isTileClipped = !0, this._loaded = !1, i.l(this, i.ay(s, ["url", "scheme", "tileSize", "promoteId"])), this._options = i.l({ type: "vector" }, s), this._collectResourceTiming = !!s.collectResourceTiming, this.tileSize !== 512) throw new Error("vector tile sources must have a tileSize of 512"); this.setEventedParent(_), this._tileWorkers = {}, this._deduped = new i.aB(); } load(t) { this._loaded = !1, this.fire(new i.z("dataloading", { dataType: "source" })); const s = Array.isArray(this.map._language) ? this.map._language.join() : this.map._language, h = this.map.getWorldview(); this._tileJSONRequest = cl(this._options, this.map._requestManager, s, h, (_, y) => { if (this._tileJSONRequest = null, this._loaded = !0, _) s && console.warn(`Ensure that your requested language string is a valid BCP-47 code or list of codes. Found: ${s}`), h && console.warn(`Requested worldview strings must be a valid ISO alpha-2 code. Found: ${h}`), this.fire(new i.y(_)); else if (y) { if (i.l(this, y), this.hasWorldviews = !!y.worldview_options, y.worldview_default && (this.worldviewDefault = y.worldview_default), y.vector_layers) { this.vectorLayers = y.vector_layers, this.vectorLayerIds = [], this.localizableLayerIds = /* @__PURE__ */ new Set(); for (const T of y.vector_layers) this.vectorLayerIds.push(T.id), y.worldview && y.worldview[T.source] && this.localizableLayerIds.add(T.id); } y.bounds && (this.tileBounds = new Uo(y.bounds, this.minzoom, this.maxzoom)), an(y.tiles, this.map._requestManager._customAccessToken), this.fire(new i.z("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new i.z("data", { dataType: "source", sourceDataType: "content" })); } t && t(_); }); } loaded() { return this._loaded; } hasTile(t) { return !this.tileBounds || this.tileBounds.contains(t.canonical); } onAdd(t) { this.map = t, this.load(); } reload() { this.cancelTileJSONRequest(); const t = i.aC(this.id, this.scope); this.load(() => this.map.style.clearSource(t)); } setTiles(t) { return this._options.tiles = t, this.reload(), this; } setUrl(t) { return this.url = t, this._options.url = t, this.reload(), this; } onRemove(t) { this.cancelTileJSONRequest(); } serialize() { return i.l({}, this._options); } loadTile(t, s) { const h = t.tileID.canonical.url(this.tiles, this.scheme), _ = this.map._requestManager.normalizeTileURL(h), y = this.map._requestManager.transformRequest(_, i.R.Tile), T = this.map.style ? this.map.style.getLut(this.scope) : null, z = T ? { image: T.image.clone() } : null, R = { request: y, data: void 0, uid: t.uid, tileID: t.tileID, tileZoom: t.tileZoom, zoom: t.tileID.overscaledZ, maxZoom: this.maxzoom, lut: z, tileSize: this.tileSize * t.tileID.overscaleFactor(), type: this.type, source: this.id, scope: this.scope, pixelRatio: i.q.devicePixelRatio, showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId, isSymbolTile: t.isSymbolTile, brightness: this.map.style && this.map.style.getBrightness() || 0, extraShadowCaster: t.isExtraShadowCaster, tessellationStep: this.map._tessellationStep, scaleFactor: this.map.getScaleFactor() }; if (this.hasWorldviews && i.f(h) && (R.worldview = this.map.getWorldview() || this.worldviewDefault, R.localizableLayerIds = this.localizableLayerIds), R.request.collectResourceTiming = this._collectResourceTiming, t.actor && t.state !== "expired") t.state === "loading" ? t.reloadCallback = s : t.request = t.actor.send("reloadTile", R, F.bind(this)); else if (t.actor = this._tileWorkers[_] = this._tileWorkers[_] || this.dispatcher.getActor(), this.dispatcher.ready) t.request = t.actor.send("loadTile", R, F.bind(this), void 0, !0); else { const N = i.aD.call({ deduped: this._deduped }, R, (G, Z) => { G || !Z ? F.call(this, G) : (R.data = { cacheControl: Z.cacheControl, expires: Z.expires, rawData: Z.rawData.slice(0) }, t.actor && t.actor.send("loadTile", R, F.bind(this), void 0, !0)); }, !0); t.request = { cancel: N }; } function F(N, G) { return delete t.request, t.aborted ? s(null) : N && N.status !== 404 ? s(N) : (G && G.resourceTiming && (t.resourceTiming = G.resourceTiming), this.map._refreshExpiredTiles && G && t.setExpiryData(G), t.loadVectorData(G, this.map.painter), i.aE(this.dispatcher), s(null), void (t.reloadCallback && (this.loadTile(t, t.reloadCallback), t.reloadCallback = null))); } } abortTile(t) { t.request && (t.request.cancel(), delete t.request), t.actor && t.actor.send("abortTile", { uid: t.uid, type: this.type, source: this.id, scope: this.scope }); } unloadTile(t, s) { t.actor && t.actor.send("removeTile", { uid: t.uid, type: this.type, source: this.id, scope: this.scope }), t.destroy(); } hasTransition() { return !1; } afterUpdate() { this._tileWorkers = {}; } cancelTileJSONRequest() { this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null); } } class tn extends i.E { constructor(t, s, h, _) { super(), this.id = t, this.dispatcher = h, this.setEventedParent(_), this.type = "raster", this.minzoom = 0, this.maxzoom = 22, this.roundZoom = !0, this.scheme = "xyz", this.tileSize = 512, this._loaded = !1, this._options = i.l({ type: "raster" }, s), i.l(this, i.ay(s, ["url", "scheme", "tileSize"])); } load(t) { this._loaded = !1, this.fire(new i.z("dataloading", { dataType: "source" })), this._tileJSONRequest = cl(this._options, this.map._requestManager, null, null, (s, h) => { this._tileJSONRequest = null, this._loaded = !0, s ? this.fire(new i.y(s)) : h && (i.l(this, h), h.raster_layers && (this.rasterLayers = h.raster_layers, this.rasterLayerIds = this.rasterLayers.map((_) => _.id)), h.bounds && (this.tileBounds = new Uo(h.bounds, this.minzoom, this.maxzoom)), an(h.tiles), this.fire(new i.z("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new i.z("data", { dataType: "source", sourceDataType: "content" }))), t && t(s); }); } loaded() { return this._loaded; } onAdd(t) { this.map = t, this.load(); } reload() { this.cancelTileJSONRequest(); const t = i.aC(this.id, this.scope); this.load(() => this.map.style.clearSource(t)); } setTiles(t) { return this._options.tiles = t, this.reload(), this; } setUrl(t) { return this.url = t, this._options.url = t, this.reload(), this; } onRemove(t) { this.cancelTileJSONRequest(); } serialize() { return i.l({}, this._options); } hasTile(t) { return !this.tileBounds || this.tileBounds.contains(t.canonical); } loadTile(t, s) { const h = i.q.devicePixelRatio >= 2, _ = this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles, this.scheme), h, this.tileSize); t.request = i.o(this.map._requestManager.transformRequest(_, i.R.Tile), (y, T, z, R) => (delete t.request, t.aborted ? (t.state = "unloaded", s(null)) : y ? (t.state = "errored", s(y)) : T ? (this.map._refreshExpiredTiles && t.setExpiryData({ cacheControl: z, expires: R }), t.setTexture(T, this.map.painter), t.state = "loaded", i.aE(this.dispatcher), void s(null)) : s(null))); } abortTile(t, s) { t.request && (t.request.cancel(), delete t.request), s && s(); } unloadTile(t, s) { t.texture && t.texture instanceof i.T ? (t.destroy(!0), t.texture && t.texture instanceof i.T && this.map.painter.saveTileTexture(t.texture)) : t.destroy(), s && s(); } hasTransition() { return !1; } cancelTileJSONRequest() { this._tileJSONRequest && (this._tileJSONRequest.cancel(), this._tileJSONRequest = null); } } class xn extends tn { constructor(t, s, h, _) { super(t, s, h, _), this.type = "raster-array", this.maxzoom = 22, this._options = i.l({ type: "raster-array" }, s); } triggerRepaint(t) { const s = this.map.painter._terrain, h = this.map.style.getSourceCache(this.id); s && s.enabled && h && s._clearRenderCacheForTile(h.id, t.tileID), this.map.triggerRepaint(); } loadTile(t, s) { const h = this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles, this.scheme), !1, this.tileSize), _ = this.map._requestManager.transformRequest(h, i.R.Tile); t.requestParams = _, t.actor || (t.actor = this.dispatcher.getActor()), t.request = t.fetchHeader(void 0, (y, T, z, R) => { if (delete t.request, t.aborted) return t.state = "unloaded", s(null); if (y) return y.code === 20 ? void 0 : (t.state = "errored", s(y)); this.map._refreshExpiredTiles && t.setExpiryData({ cacheControl: z, expires: R }), t.state = "empty", s(null); }); } unloadTile(t, s) { const h = t.texture; h && h instanceof i.T ? (t.destroy(!0), this.map.painter.saveTileTexture(h)) : (t.destroy(), t.flushQueues(), t._isHeaderLoaded = !1, delete t._mrt, delete t.textureDescriptor), t.fbo && (t.fbo.destroy(), delete t.fbo), delete t.request, delete t.requestParams, delete t.neighboringTiles, t.state = "unloaded"; } prepareTile(t, s, h) { t._isHeaderLoaded && (t.state !== "empty" && (t.state = "reloading"), t.fetchBand(s, h, (_, y) => { if (_) return t.state = "errored", this.fire(new i.y(_)), void this.triggerRepaint(t); y && (t.setTexture(y, this.map.painter), t.state = "loaded", this.triggerRepaint(t)); })); } getInitialBand(t) { if (!this.rasterLayers) return 0; const s = this.rasterLayers.find(({ id: y }) => y === t), h = s && s.fields, _ = h && h.bands && h.bands; return _ ? _[0] : 0; } getTextureDescriptor(t, s, h) { if (!t) return; const _ = s.sourceLayer || this.rasterLayerIds && this.rasterLayerIds[0]; if (!_) return; let y = null; s instanceof i.aH ? y = s.paint.get("raster-array-band") : s instanceof i.aI && (y = s.paint.get("raster-particle-array-band")); const T = y || this.getInitialBand(_); if (T != null) if (t.textureDescriptor) { if (!t.updateNeeded(_, T) || h) return Object.assign({}, t.textureDescriptor, { texture: t.texture }); } else this.prepareTile(t, _, T); } } const no = { vector: jo, raster: tn, "raster-dem": class extends tn { constructor(c, t, s, h) { super(c, t, s, h), this.type = "raster-dem", this.maxzoom = 22, this._options = i.l({ type: "raster-dem" }, t), this.encoding = t.encoding || "mapbox"; } loadTile(c, t) { const s = this.map._requestManager.normalizeTileURL(c.tileID.canonical.url(this.tiles, this.scheme), !1, this.tileSize); function h(_, y) { _ && (c.state = "errored", t(_)), y && (c.dem = y, c.dem.onDeserialize(), c.needsHillshadePrepare = !0, c.needsDEMTextureUpload = !0, c.state = "loaded", t(null)); } c.request = i.o(this.map._requestManager.transformRequest(s, i.R.Tile), (function(_, y, T, z) { if (delete c.request, c.aborted) c.state = "unloaded", t(null); else if (_) c.state = "errored", t(_); else if (y) { this.map._refreshExpiredTiles && c.setExpiryData({ cacheControl: T, expires: z }); const R = ImageBitmap && y instanceof ImageBitmap && i.t(), F = 1 - (y.width - i.aF(y.width)) / 2; F < 1 || c.neighboringTiles || (c.neighboringTiles = this._getNeighboringTiles(c.tileID)); const N = R ? y : i.q.getImageData(y, F), G = { uid: c.uid, coord: c.tileID, source: this.id, scope: this.scope, rawImageData: N, encoding: this.encoding, padding: F }; c.actor && c.state !== "expired" || (c.actor = this.dispatcher.getActor(), c.actor.send("loadDEMTile", G, h.bind(this), void 0, !0)); } }).bind(this)); } _getNeighboringTiles(c) { const t = c.canonical, s = Math.pow(2, t.z), h = (t.x - 1 + s) % s, _ = t.x === 0 ? c.wrap - 1 : c.wrap, y = (t.x + 1 + s) % s, T = t.x + 1 === s ? c.wrap + 1 : c.wrap, z = {}; return z[new i.aG(c.overscaledZ, _, t.z, h, t.y).key] = { backfilled: !1 }, z[new i.aG(c.overscaledZ, T, t.z, y, t.y).key] = { backfilled: !1 }, t.y > 0 && (z[new i.aG(c.overscaledZ, _, t.z, h, t.y - 1).key] = { backfilled: !1 }, z[new i.aG(c.overscaledZ, c.wrap, t.z, t.x, t.y - 1).key] = { backfilled: !1 }, z[new i.aG(c.overscaledZ, T, t.z, y, t.y - 1).key] = { backfilled: !1 }), t.y + 1 < s && (z[new i.aG(c.overscaledZ, _, t.z, h, t.y + 1).key] = { backfilled: !1 }, z[new i.aG(c.overscaledZ, c.wrap, t.z, t.x, t.y + 1).key] = { backfilled: !1 }, z[new i.aG(c.overscaledZ, T, t.z, y, t.y + 1).key] = { backfilled: !1 }), z; } }, "raster-array": xn, geojson: class extends i.E { constructor(c, t, s, h) { super(), this.id = c, this.type = "geojson", this.minzoom = 0, this.maxzoom = 18, this.tileSize = 512, this.isTileClipped = !0, this.reparseOverscaled = !0, this._loaded = !1, this.actor = s.getActor(), this.setEventedParent(h), this._data = t.data, this._options = i.l({}, t), this._collectResourceTiming = t.collectResourceTiming, t.maxzoom !== void 0 && (this.maxzoom = t.maxzoom), t.minzoom !== void 0 && (this.minzoom = t.minzoom), t.type && (this.type = t.type), t.attribution && (this.attribution = t.attribution), this.promoteId = t.promoteId; const _ = i.ag / this.tileSize; this.workerOptions = i.l({ source: this.id, scope: this.scope, cluster: t.cluster || !1, geojsonVtOptions: { buffer: (t.buffer !== void 0 ? t.buffer : 128) * _, tolerance: (t.tolerance !== void 0 ? t.tolerance : 0.375) * _, extent: i.ag, maxZoom: this.maxzoom, lineMetrics: t.lineMetrics || !1, generateId: t.generateId || !1 }, superclusterOptions: { maxZoom: t.clusterMaxZoom !== void 0 ? t.clusterMaxZoom : this.maxzoom - 1, minPoints: Math.max(2, t.clusterMinPoints || 2), extent: i.ag, radius: (t.clusterRadius !== void 0 ? t.clusterRadius : 50) * _, log: !1, generateId: t.generateId || !1 }, clusterProperties: t.clusterProperties, filter: t.filter, dynamic: t.dynamic }, t.workerOptions); } onAdd(c) { this.map = c, this.setData(this._data); } setData(c) { return this._data = c, this._updateWorkerData(), this; } updateData(c) { if (!this._options.dynamic) return this.fire(new i.y(new Error("Can't call updateData on a GeoJSON source with dynamic set to false."))); if (typeof c != "string" && (c.type === "Feature" && (c = { type: "FeatureCollection", features: [c] }), c.type !== "FeatureCollection")) return this.fire(new i.y(new Error("Data to update should be a feature or a feature collection."))); if (this._coalesce && typeof c != "string" && typeof this._data != "string" && this._data.type === "FeatureCollection") { const t = /* @__PURE__ */ new Map(); for (const s of this._data.features) t.set(s.id, s); for (const s of c.features) t.set(s.id, s); this._data.features = [...t.values()]; } else this._data = c; return this._updateWorkerData(!0), this; } getClusterExpansionZoom(c, t) { return this.actor.send("geojson.getClusterExpansionZoom", { clusterId: c, source: this.id, scope: this.scope }, t), this; } getClusterChildren(c, t) { return this.actor.send("geojson.getClusterChildren", { clusterId: c, source: this.id, scope: this.scope }, t), this; } getClusterLeaves(c, t, s, h) { return this.actor.send("geojson.getClusterLeaves", { source: this.id, scope: this.scope, clusterId: c, limit: t, offset: s }, h), this; } _updateWorkerData(c = !1) { if (this._pendingLoad) return void (this._coalesce = !0); this.fire(new i.z("dataloading", { dataType: "source" })), this._loaded = !1; const t = i.l({ append: c }, this.workerOptions); t.scope = this.scope; const s = this._data; typeof s == "string" ? (t.request = this.map._requestManager.transformRequest(i.q.resolveURL(s), i.R.Source), t.request.collectResourceTiming = this._collectResourceTiming) : t.data = JSON.stringify(s), this._pendingLoad = this.actor.send(`${this.type}.loadData`, t, (h, _) => { if (this._loaded = !0, this._pendingLoad = null, h) this.fire(new i.y(h)); else { const y = { dataType: "source", sourceDataType: this._metadataFired ? "content" : "metadata" }; this._collectResourceTiming && _ && _.resourceTiming && _.resourceTiming[this.id] && (y.resourceTiming = _.resourceTiming[this.id]), c && (this._partialReload = !0), this.fire(new i.z("data", y)), this._partialReload = !1, this._metadataFired = !0; } this._coalesce && (this._updateWorkerData(c), this._coalesce = !1); }); } loaded() { return this._loaded; } loadTile(c, t) { const s = c.actor ? "reloadTile" : "loadTile"; c.actor = this.actor; const h = this.map.style ? this.map.style.getLut(this.scope) : null, _ = h ? { image: h.image.clone() } : null, y = this._partialReload, T = { type: this.type, uid: c.uid, tileID: c.tileID, tileZoom: c.tileZoom, zoom: c.tileID.overscaledZ, maxZoom: this.maxzoom, tileSize: this.tileSize, source: this.id, lut: _, scope: this.scope, pixelRatio: i.q.devicePixelRatio, showCollisionBoxes: this.map.showCollisionBoxes, promoteId: this.promoteId, brightness: this.map.style && this.map.style.getBrightness() || 0, scaleFactor: this.map.getScaleFactor(), partial: y }; c.request = this.actor.send(s, T, (z, R) => y && !R ? (c.state = "loaded", t(null)) : (delete c.request, c.destroy(), c.aborted ? t(null) : z ? t(z) : (c.loadVectorData(R, this.map.painter, s === "reloadTile"), t(null))), void 0, s === "loadTile"); } abortTile(c) { c.request && (c.request.cancel(), delete c.request), c.aborted = !0; } unloadTile(c, t) { this.actor.send("removeTile", { uid: c.uid, type: this.type, source: this.id, scope: this.scope }), c.destroy(); } onRemove(c) { this._pendingLoad && this._pendingLoad.cancel(); } serialize() { return i.l({}, this._options, { type: this.type, data: this._data }); } hasTransition() { return !1; } }, video: class extends i.aJ { constructor(c, t, s, h) { super(c, t, s, h), this.roundZoom = !0, this.type = "video", this.options = t; } load() { this._loaded = !1; const c = this.options; this.urls = []; for (const t of c.urls) this.urls.push(this.map._requestManager.transformRequest(t, i.R.Source).url); i.aK(this.urls, (t, s) => { this._loaded = !0, t ? this.fire(new i.y(t)) : s && (this.video = s, 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(c) { if (this.video) { const t = this.video.seekable; c < t.start(0) || c > t.end(0) ? this.fire(new i.y(new i.V(`sources.${this.id}`, null, `Playback for this video can be set only between the ${t.start(0)} and ${t.end(0)}-second mark.`))) : this.video.currentTime = c; } } getVideo() { return this.video; } onAdd(c) { this.map || (this.map = c, this.load(), this.video && (this.video.play(), this.setCoordinates(this.coordinates))); } prepare() { if (Object.keys(this.tiles).length === 0 || this.video.readyState < 2) return; const c = this.map.painter.context, t = c.gl; this.texture ? this.video.paused || (this.texture.bind(t.LINEAR, t.CLAMP_TO_EDGE), t.texSubImage2D(t.TEXTURE_2D, 0, 0, 0, t.RGBA, t.UNSIGNED_BYTE, this.video)) : (this.texture = new i.T(c, this.video, t.RGBA8), this.texture.bind(t.LINEAR, t.CLAMP_TO_EDGE), this.width = this.video.videoWidth, this.height = this.video.videoHeight), this._prepareData(c); } serialize() { return { type: "video", urls: this.urls, coordinates: this.coordinates }; } hasTransition() { return this.video && !this.video.paused; } }, image: i.aJ, model: class extends i.E { constructor(c, t, s, h) { super(), this.id = c, this.type = "model", this.models = [], this._loaded = !1, this._options = t; } load() { const c = []; for (const t in this._options.models) { const s = this._options.models[t], h = i.aM(this.map._requestManager.transformRequest(s.uri, i.R.Model).url).then((_) => { if (!_) return; const y = i.aN(_), T = new i.aO(t, s.position, s.orientation, y); T.computeBoundsAndApplyParent(), this.models.push(T); }).catch((_) => { this.fire(new i.y(new Error(`Could not load model ${t} from ${s.uri}: ${_.message}`))); }); c.push(h); } return Promise.allSettled(c).then(() => { this._loaded = !0, this.fire(new i.z("data", { dataType: "source", sourceDataType: "metadata" })); }).catch((t) => { this.fire(new i.y(new Error(`Could not load models: ${t.message}`))); }); } onAdd(c) { this.map = c, this.load(); } hasTransition() { return !1; } loaded() { return this._loaded; } getModels() { return this.models; } loadTile(c, t) { } serialize() { return { type: "model" }; } }, "batched-model": class extends i.E { constructor(c, t, s, h) { super(), this.type = "batched-model", this.id = c, this.tileSize = 512, this._options = t, this.tiles = this._options.tiles, this.maxzoom = t.maxzoom || 19, this.minzoom = t.minzoom || 0, this.roundZoom = !0, this.usedInConflation = !0, this.dispatcher = s, this.reparseOverscaled = !1, this.scheme = "xyz", this._loaded = !1, this.setEventedParent(h); } onAdd(c) { this.map = c, this.load(); } load(c) { this._loaded = !1, this.fire(new i.z("dataloading", { dataType: "source" })); const t = Array.isArray(this.map._language) ? this.map._language.join() : this.map._language, s = this.map.getWorldview(); this._tileJSONRequest = cl(this._options, this.map._requestManager, t, s, (h, _) => { this._tileJSONRequest = null, this._loaded = !0, h ? (t && console.warn(`Ensure that your requested language string is a valid BCP-47 code or list of codes. Found: ${t}`), s && s.length !== 2 && console.warn(`Requested worldview strings must be a valid ISO alpha-2 code. Found: ${s}`), this.fire(new i.y(h))) : _ && (i.l(this, _), _.bounds && (this.tileBounds = new Uo(_.bounds, this.minzoom, this.maxzoom)), an(_.tiles, this.map._requestManager._customAccessToken), this.fire(new i.z("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new i.z("data", { dataType: "source", sourceDataType: "content" }))), c && c(h); }); } hasTransition() { return !1; } hasTile(c) { return !this.tileBounds || this.tileBounds.contains(c.canonical); } loaded() { return this._loaded; } loadTile(c, t) { const s = this.map._requestManager.normalizeTileURL(c.tileID.canonical.url(this.tiles, this.scheme)), h = { request: this.map._requestManager.transformRequest(s, i.R.Tile), data: void 0, uid: c.uid, tileID: c.tileID, tileZoom: c.tileZoom, zoom: c.tileID.overscaledZ, tileSize: this.tileSize * c.tileID.overscaleFactor(), type: this.type, source: this.id, scope: this.scope, showCollisionBoxes: this.map.showCollisionBoxes, isSymbolTile: c.isSymbolTile, brightness: this.map.style && this.map.style.getBrightness() || 0, lut: null, maxZoom: null, promoteId: null, pixelRatio: null, scaleFactor: null }; if (c.actor && c.state !== "expired") if (c.state === "loading") c.reloadCallback = t; else { if (c.buckets) { const y = Object.values(c.buckets); for (const T of y) T.dirty = !0; return void (c.state = "loaded"); } c.request = c.actor.send("reloadTile", h, _.bind(this)); } else c.actor = this.dispatcher.getActor(), c.request = c.actor.send("loadTile", h, _.bind(this), void 0, !0); function _(y, T) { return c.aborted ? t(null) : y && y.status !== 404 ? t(y) : (this.map._refreshExpiredTiles && T && c.setExpiryData(T), c.loadModelData(T, this.map.painter), c.state = "loaded", void t(null)); } } serialize() { return i.l({}, this._options); } }, canvas: class extends i.aJ { constructor(c, t, s, h) { super(c, t, s, h), t.coordinates ? Array.isArray(t.coordinates) && t.coordinates.length === 4 && !t.coordinates.some((_) => !Array.isArray(_) || _.length !== 2 || _.some((y) => typeof y != "number")) || this.fire(new i.y(new i.V(`sources.${c}`, null, '"coordinates" property must be an array of 4 longitude/latitude array pairs'))) : this.fire(new i.y(new i.V(`sources.${c}`, null, 'missing required property "coordinates"'))), t.animate && typeof t.animate != "boolean" && this.fire(new i.y(new i.V(`sources.${c}`, null, 'optional "animate" property must be a boolean value'))), t.canvas ? typeof t.canvas == "string" || t.canvas instanceof HTMLCanvasElement || this.fire(new i.y(new i.V(`sources.${c}`, 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 i.y(new i.V(`sources.${c}`, null, 'missing required property "canvas"'))), this.options = t, this.animate = t.animate === void 0 || t.animate; } load() { this._loaded = !0, this.canvas || (this.canvas = this.options.canvas instanceof HTMLCanvasElement ? this.options.canvas : document.getElementById(this.options.canvas)), this.width = this.canvas.width, this.height = this.canvas.height, this._hasInvalidDimensions() ? this.fire(new i.y(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(c) { this.map = c, this.load(), this.canvas && this.animate && this.play(); } onRemove(c) { this.pause(); } prepare() { let c = !1; if (this.canvas.width !== this.width && (this.width = this.canvas.width, c = !0), this.canvas.height !== this.height && (this.height = this.canvas.height, c = !0), this._hasInvalidDimensions() || Object.keys(this.tiles).length === 0) return; const t = this.map.painter.context; this.texture ? !c && !this._playing || this.texture instanceof i.aL || this.texture.update(this.canvas, { premultiply: !0 }) : this.texture = new i.T(t, this.canvas, t.gl.RGBA8, { premultiply: !0 }), this._prepareData(t); } serialize() { return { type: "canvas", coordinates: this.coordinates }; } hasTransition() { return this._playing; } _hasInvalidDimensions() { for (const c of [this.canvas.width, this.canvas.height]) if (isNaN(c) || c <= 0) return !0; return !1; } }, custom: class extends i.E { constructor(c, t, s, h) { super(), this.id = c, this.type = "custom", this._dataType = "raster", this._dispatcher = s, this._implementation = t, this.setEventedParent(h), this.scheme = "xyz", this.minzoom = 0, this.maxzoom = 22, this.tileSize = 512, this._loaded = !1, this.roundZoom = !0, this._implementation || this.fire(new i.y(new Error(`Missing implementation for ${this.id} custom source`))), this._implementation.loadTile || this.fire(new i.y(new Error(`Missing loadTile implementation for ${this.id} custom source`))), this._implementation.bounds && (this.tileBounds = new Uo(this._implementation.bounds, this.minzoom, this.maxzoom)), t.update = this._update.bind(this), t.clearTiles = this._clearTiles.bind(this), t.coveringTiles = this._coveringTiles.bind(this), i.l(this, i.ay(t, ["dataType", "scheme", "minzoom", "maxzoom", "tileSize", "attribution", "minTileCacheSize", "maxTileCacheSize"])); } serialize() { return i.ay(this, ["type", "scheme", "minzoom", "maxzoom", "tileSize", "attribution"]); } load() { this._loaded = !0, this.fire(new i.z("data", { dataType: "source", sourceDataType: "metadata" })), this.fire(new i.z("data", { dataType: "source", sourceDataType: "content" })); } loaded() { return this._loaded; } onAdd(c) { this.map = c, this._loaded = !1, this.fire(new i.z("dataloading", { dataType: "source" })), this._implementation.onAdd && this._implementation.onAdd(c), this.load(); } onRemove(c) { this._implementation.onRemove && this._implementation.onRemove(c); } hasTile(c) { if (this._implementation.hasTile) { const { x: t, y: s, z: h } = c.canonical; return this._implementation.hasTile({ x: t, y: s, z: h }); } return !this.tileBounds || this.tileBounds.contains(c.canonical); } loadTile(c, t) { const { x: s, y: h, z: _ } = c.tileID.canonical, y = new AbortController(); c.request = Promise.resolve(this._implementation.loadTile({ x: s, y: h, z: _ }, { signal: y.signal })).then((function(T) { return delete c.request, c.aborted ? (c.state = "unloaded", t(null)) : T === void 0 ? (c.state = "errored", t(null)) : T === null ? (this.loadTileData(c, { width: this.tileSize, height: this.tileSize, data: null }), c.state = "loaded", t(null)) : function(z) { return z instanceof ImageData || z instanceof HTMLCanvasElement || z instanceof ImageBitmap || z instanceof HTMLImageElement; }(T) ? (this.loadTileData(c, T), c.state = "loaded", void t(null)) : (c.state = "errored", t(new Error(`Can't infer data type for ${this.id}, only raster data supported at the moment`))); }).bind(this)).catch((T) => { T.code !== 20 && (c.state = "errored", t(T)); }), c.request.cancel = () => y.abort(); } loadTileData(c, t) { c.setTexture(t, this.map.painter); } unloadTile(c, t) { if (c.texture && c.texture instanceof i.T ? (c.destroy(!0), c.texture && c.texture instanceof i.T && this.map.painter.saveTileTexture(c.texture)) : c.destroy(), this._implementation.unloadTile) { const { x: s, y: h, z: _ } = c.tileID.canonical; this._implementation.unloadTile({ x: s, y: h, z: _ }); } t && t(); } abortTile(c, t) { c.request && c.request.cancel && (c.request.cancel(), delete c.request), t && t(); } hasTransition() { return !1; } _coveringTiles() { return this.map.transform.coveringTiles({ tileSize: this.tileSize, minzoom: this.minzoom, maxzoom: this.maxzoom, roundZoom: this.roundZoom }).map((c) => ({ x: c.canonical.x, y: c.canonical.y, z: c.canonical.z })); } _clearTiles() { const c = i.aC(this.id, this.scope); this.map.style.clearSource(c); } _update() { this.fire(new i.z("data", { dataType: "source", sourceDataType: "content" })); } } }, Go = function(c, t, s, h) { const _ = new no[t.type](c, t, s, h); if (_.id !== c) throw new Error(`Expected Source id to be ${c} instead of ${_.id}`); return i.aP(["load", "abort", "unload", "serialize", "prepare"], _), _; }; function aa(c, t, s, h, _ = !1) { const y = t.sourceCache.transform, T = t.sourceCache.tilesIn(c, t.has3DLayers, _); T.sort(Hn); const z = []; for (const R of T) { const F = R.tile.queryRenderedFeatures(t, R, s, h, y, _); Object.keys(F).length && z.push({ wrappedTileID: R.tile.tileID.wrapped().key, queryResults: F }); } return z.length === 0 ? {} : function(R) { const F = {}, N = {}; for (const G of R) { const Z = G.queryResults, W = G.wrappedTileID, te = N[W] = N[W] || {}; for (const ee in Z) { const se = Z[ee], oe = te[ee] = te[ee] || {}, he = F[ee] = F[ee] || []; for (const _e of se) oe[_e.featureIndex] || (oe[_e.featureIndex] = !0, he.push(_e)); } } return F; }(z); } function Da(c, t, s, h, _) { const y = {}, T = h.queryRenderedSymbols(c), z = []; for (const R of Object.keys(T).map(Number)) z.push(_[R]); z.sort(Hn); for (const R of z) { const F = R.featureIndex.lookupSymbolFeatures(T[R.bucketInstanceId], R.bucketIndex, R.sourceLayerIndex, t, s); for (const N in F) { const G = y[N] = y[N] || [], Z = F[N]; Z.sort((W, te) => { const ee = R.featureSortOrder; if (ee) { const se = ee.indexOf(W.featureIndex); return ee.indexOf(te.featureIndex) - se; } return te.featureIndex - W.featureIndex; }); for (const W of Z) G.push(W); } } return y; } function Vi(c, t) { const s = c.getRenderableIds().map((y) => c.getTileByID(y)), h = [], _ = {}; for (let y = 0; y < s.length; y++) { const T = s[y], z = T.tileID.canonical.key; _[z] || (_[z] = !0, T.querySourceFeatures(h, t)); } return h; } function Hn(c, t) { const s = c.tileID, h = t.tileID; return s.overscaledZ - h.overscaledZ || s.canonical.y - h.canonical.y || s.wrap - h.wrap || s.canonical.x - h.canonical.x; } function hl(c, t) { const s = {}; if (!t) return s; for (const h of c) { const _ = h.layerIds.map((y) => t.getLayer(y)).filter(Boolean); if (_.length !== 0) { h.layers = _, h.stateDependentLayerIds && (h.stateDependentLayers = h.stateDependentLayerIds.map((y) => _.filter((T) => T.id === y)[0])); for (const y of _) s[y.fqid] = h; } } return s; } const Zs = 32, Qn = 33, Pr = new Uint16Array(8184); for (let c = 0; c < 2046; c++) { let t = c + 2, s = 0, h = 0, _ = 0, y = 0, T = 0, z = 0; for (1 & t ? _ = y = T = Zs : s = h = z = Zs; (t >>= 1) > 1; ) { const F = s + _ >> 1, N = h + y >> 1; 1 & t ? (_ = s, y = h, s = T, h = z) : (s = _, h = y, _ = T, y = z), T = F, z = N; } const R = 4 * c; Pr[R + 0] = s, Pr[R + 1] = h, Pr[R + 2] = _, Pr[R + 3] = y; } const nr = new Uint16Array(2178), Ks = new Uint8Array(1089), Yn = new Uint16Array(1089); function $r(c) { return c === 0 ? -0.03125 : c === 32 ? 0.03125 : 0; } const Ar = (() => ({ type: 2, extent: i.ag, loadGeometry: () => [[new i.P(0, 0), new i.P(i.ag + 1, 0), new i.P(i.ag + 1, i.ag + 1), new i.P(0, i.ag + 1), new i.P(0, 0)]] }))(); class Cr { constructor(t, s, h, _, y) { this.tileID = t, this.uid = i.aV(), this.uses = 0, this.tileSize = s, this.tileZoom = h, this.buckets = {}, this.expirationTime = null, this.queryPadding = 0, this.hasSymbolBuckets = !1, this.hasRTLText = !1, this.dependencies = {}, this.isRaster = y, _ && _.style && (this._lastUpdatedBrightness = _.style.getBrightness()), this.expiredRequestCount = 0, this.state = "loading", _ && _.transform && (this.projection = _.transform.projection); } registerFadeDuration(t) { const s = t + this.timeAdded; s < i.q.now() || this.fadeEndTime && s < this.fadeEndTime || (this.fadeEndTime = s); } wasRequested() { return this.state === "errored" || this.state === "loaded" || this.state === "reloading"; } get tileTransform() { return this._tileTransform || (this._tileTransform = i.aQ(this.tileID.canonical, this.projection)), this._tileTransform; } loadVectorData(t, s, h) { 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 = hl(t.buckets, s.style), this.hasSymbolBuckets = !1; for (const _ in this.buckets) { const y = this.buckets[_]; if (y instanceof i.aX) { if (this.hasSymbolBuckets = !0, !h) break; y.justReloaded = !0; } } if (this.hasRTLText = !1, this.hasSymbolBuckets) for (const _ in this.buckets) { const y = this.buckets[_]; if (y instanceof i.aX && y.hasRTLText) { this.hasRTLText = !0, i.aY(); break; } } this.queryPadding = 0; for (const _ in this.buckets) { const y = this.buckets[_], T = s.style.getOwnLayer(_); if (!T) continue; const z = T.queryRadius(y); this.queryPadding = Math.max(this.queryPadding, z); } t.imageAtlas && (this.imageAtlas = t.imageAtlas), t.glyphAtlasImage && (this.glyphAtlasImage = t.glyphAtlasImage), t.lineAtlas && (this.lineAtlas = t.lineAtlas), this._lastUpdatedBrightness = t.brightness; } else this.collisionBoxArray = new i.aW(); } 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"; } } loadModelData(t, s, h) { t && (t.resourceTiming && (this.resourceTiming = t.resourceTiming), this.buckets = { ...this.buckets, ...hl(t.buckets, s.style) }, t.featureIndex && (this.latestFeatureIndex = t.featureIndex)); } getBucket(t) { return this.buckets[t.fqid]; } upload(t) { for (const _ in this.buckets) { const y = this.buckets[_]; y.uploadPending() && y.upload(t); } const s = t.gl, h = this.imageAtlas; if (h && !h.uploaded) { const _ = !!Object.keys(h.patternPositions).length; this.imageAtlasTexture = new i.T(t, h.image, s.RGBA8, { useMipmap: _ }), this.imageAtlas.uploaded = !0; } this.glyphAtlasImage && (this.glyphAtlasTexture = new i.T(t, this.glyphAtlasImage, s.R8), this.glyphAtlasImage = null), this.lineAtlas && !this.lineAtlas.uploaded && (this.lineAtlasTexture = new i.T(t, this.lineAtlas.image, s.R8), this.lineAtlas.uploaded = !0); } prepare(t, s, h) { if (this.imageAtlas && this.imageAtlasTexture && this.imageAtlas.patchUpdatedImages(t, this.imageAtlasTexture, h), !s || !this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData) return; const _ = s.style.getBrightness(); (this._lastUpdatedBrightness || _) && (this._lastUpdatedBrightness && _ && Math.abs(this._lastUpdatedBrightness - _) < 1e-3 || (this.updateBuckets(s, this._lastUpdatedBrightness !== _), this._lastUpdatedBrightness = _)); } queryRenderedFeatures(t, s, h, _, y, T) { if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData && !this.latestFeatureIndex.is3DTile) return {}; const z = function(R, F) { const N = i.ab.mat4.fromScaling([], [0.5 * R.width, 0.5 * -R.height, 1]); return i.ab.mat4.translate(N, N, [1, -1, 0]), i.ab.mat4.multiply(N, N, R.calculateProjMatrix(F.toUnwrapped())), Float32Array.from(N); }(y, this.tileID); return this.latestFeatureIndex.query(t, { tilespaceGeometry: s, pixelPosMatrix: z, transform: _, availableImages: h, tileTransform: this.tileTransform }); } querySourceFeatures(t, s) { const h = this.latestFeatureIndex; if (!h || !h.rawTileData) return; const _ = h.loadVTLayers(), y = s ? s.sourceLayer : "", T = _._geojsonTileLayer || _[y]; if (!T) return; const z = i.aZ(s && s.filter), { z: R, x: F, y: N } = this.tileID.canonical, G = { z: R, x: F, y: N }; for (let Z = 0; Z < T.length; Z++) { const W = T.feature(Z); if (z.needGeometry) { const se = i.a_(W, !0); if (!z.filter(new i.a8(this.tileID.overscaledZ), se, this.tileID.canonical)) continue; } else if (!z.filter(new i.a8(this.tileID.overscaledZ), W)) continue; const te = h.getId(W, y), ee = new i.a$(W, R, F, N, te); ee.tile = G, t.push(ee); } } hasData() { return this.state === "loaded" || this.state === "reloading" || this.state === "expired"; } patternsLoaded() { return !!this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length; } setExpiryData(t) { const s = this.expirationTime; if (t.cacheControl) { const h = i.b0(t.cacheControl); h["max-age"] && (this.expirationTime = Date.now() + 1e3 * h["max-age"]); } else t.expires && (this.expirationTime = new Date(t.expires).getTime()); if (this.expirationTime) { const h = Date.now(); let _ = !1; if (this.expirationTime > h) _ = !1; else if (s) if (this.expirationTime < s) _ = !0; else { const y = this.expirationTime - s; y ? this.expirationTime = h + Math.max(y, 3e4) : _ = !0; } else _ = !0; _ ? (this.expiredRequestCount++, this.state = "expired") : this.expiredRequestCount = 0; } } getExpiryTimeout() { if (this.expirationTime) return this.expiredRequestCount ? 1e3 * (1 << Math.min(this.expiredRequestCount - 1, 31)) : Math.min(this.expirationTime - (/* @__PURE__ */ new Date()).getTime(), Math.pow(2, 31) - 1); } refreshFeatureState(t) { this.latestFeatureIndex && (this.latestFeatureIndex.rawTileData || this.latestFeatureIndex.is3DTile) && t && this.updateBuckets(t); } updateBuckets(t, s) { if (!this.latestFeatureIndex || !t.style) return; const h = this.latestFeatureIndex.loadVTLayers(), _ = t.style.listImages(), y = t.style.getBrightness(); for (const T in this.buckets) { if (!t.style.hasLayer(T)) continue; const z = this.buckets[T], R = z.layers[0], F = R.sourceLayer || "_geojsonTileLayer", N = h[F], G = t.style.getLayerSourceCache(R); let Z = {}; G && (Z = G._state.getState(F, void 0)); const W = this.imageAtlas && this.imageAtlas.patternPositions || {}, te = Object.keys(Z).length > 0 && !s; te && !z.stateDependentLayers.length && !s || z.update(Z, N, _, W, te ? z.stateDependentLayers : z.layers, s, y), (z instanceof i.b1 || z instanceof i.b2) && t._terrain && t._terrain.enabled && G && z.programConfigurations.needsUpload && t._terrain._clearRenderCacheForTile(G.id, this.tileID); const ee = t && t.style && t.style.getOwnLayer(T); ee && (this.queryPadding = Math.max(this.queryPadding, ee.queryRadius(z))); } } holdingForFade() { return this.symbolFadeHoldUntil !== void 0; } symbolFadeFinished() { return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < i.q.now(); } clearFadeHold() { this.symbolFadeHoldUntil = void 0; } setHoldDuration(t) { this.symbolFadeHoldUntil = i.q.now() + t; } setTexture(t, s) { const h = s.context, _ = h.gl; this.texture = this.texture || s.getTileTexture(t.width), this.texture && this.texture instanceof i.T ? this.texture.update(t) : (this.texture = new i.T(h, t, _.RGBA8, { useMipmap: !0 }), this.texture.bind(_.LINEAR, _.CLAMP_TO_EDGE)); } setDependencies(t, s) { const h = {}; for (const _ of s) h[_] = !0; this.dependencies[t] = h; } hasDependency(t, s) { for (const h of t) { const _ = this.dependencies[h]; if (_) { for (const y of s) if (_[y]) return !0; } } return !1; } clearQueryDebugViz() { } _makeDebugTileBoundsBuffers(t, s) { if (!s || s.name === "mercator" || this._tileDebugBuffer) return; const h = i.b3(Ar, this.tileID.canonical, this.tileTransform)[0], _ = new i.b4(), y = new i.b5(); for (let T = 0; T < h.length; T++) { const { x: z, y: R } = h[T]; _.emplaceBack(z, R), y.emplaceBack(T); } y.emplaceBack(0), this._tileDebugIndexBuffer = t.createIndexBuffer(y), this._tileDebugBuffer = t.createVertexBuffer(_, i.b6.members), this._tileDebugSegments = i.b7.simpleSegment(0, 0, _.length, y.length); } _makeTileBoundsBuffers(t, s) { if (this._tileBoundsBuffer || !s || s.name === "mercator") return; const h = i.b3(Ar, this.tileID.canonical, this.tileTransform)[0]; let _, y; if (this.isRaster) { const T = function(z, R) { const F = i.aQ(z, R), N = Math.pow(2, z.z); for (let se = 0; se < Qn; se++) for (let oe = 0; oe < Qn; oe++) { const he = i.aR((z.x + (oe + $r(oe)) / Zs) / N), _e = i.aS((z.y + (se + $r(se)) / Zs) / N), pe = R.project(he, _e), Me = se * Qn + oe; nr[2 * Me + 0] = Math.round((pe.x * F.scale - F.x) * i.ag), nr[2 * Me + 1] = Math.round((pe.y * F.scale - F.y) * i.ag); } Ks.fill(0), Yn.fill(0); for (let se = 2045; se >= 0; se--) { const oe = 4 * se, he = Pr[oe + 0], _e = Pr[oe + 1], pe = Pr[oe + 2], Me = Pr[oe + 3], xe = he + pe >> 1, we = _e + Me >> 1, ve = xe + we - _e, Ae = we + he - xe, Oe = _e * Qn + he, Xe = Me * Qn + pe, He = we * Qn + xe, ke = Math.hypot((nr[2 * Oe + 0] + nr[2 * Xe + 0]) / 2 - nr[2 * He + 0], (nr[2 * Oe + 1] + nr[2 * Xe + 1]) / 2 - nr[2 * He + 1]) >= 16; Ks[He] = Ks[He] || (ke ? 1 : 0), se < 1022 && (Ks[He] = Ks[He] || Ks[(_e + Ae >> 1) * Qn + (he + ve >> 1)] || Ks[(Me + Ae >> 1) * Qn + (pe + ve >> 1)]); } const G = new i.aT(), Z = new i.aU(); let W = 0; function te(se, oe) { const he = oe * Qn + se; return Yn[he] === 0 && (G.emplaceBack(nr[2 * he + 0], nr[2 * he + 1], se * i.ag / Zs, oe * i.ag / Zs), Yn[he] = ++W), Yn[he] - 1; } function ee(se, oe, he, _e, pe, Me) { const xe = se + he >> 1, we = oe + _e >> 1; if (Math.abs(se - pe) + Math.abs(oe - Me) > 1 && Ks[we * Qn + xe]) ee(pe, Me, se, oe, xe, we), ee(he, _e, pe, Me, xe, we); else { const ve = te(se, oe), Ae = te(he, _e), Oe = te(pe, Me); Z.emplaceBack(ve, Ae, Oe); } } return ee(0, 0, Zs, Zs, Zs, 0), ee(Zs, Zs, 0, 0, 0, Zs), { vertices: G, indices: Z }; }(this.tileID.canonical, s); _ = T.vertices, y = T.indices; } else { _ = new i.aT(), y = new i.aU(); for (const { x: z, y: R } of h) _.emplaceBack(z, R, 0, 0); const T = i.b8(_.int16, void 0, 4); for (let z = 0; z < T.length; z += 3) y.emplaceBack(T[z], T[z + 1], T[z + 2]); } this._tileBoundsBuffer = t.createVertexBuffer(_, i.b9.members), this._tileBoundsIndexBuffer = t.createIndexBuffer(y), this._tileBoundsSegments = i.b7.simpleSegment(0, 0, _.length, y.length); } _makeGlobeTileDebugBuffers(t, s) { const h = s.projection; if (!h || h.name !== "globe" || s.freezeTileCoverage) return; const _ = this.tileID.canonical, y = i.ba(_, s), T = i.bb(y), z = i.ae(s.zoom); let R; z > 0 && (R = i.ab.mat4.invert(new Float64Array(16), s.globeMatrix)), this._makeGlobeTileDebugBorderBuffer(t, _, s, T, R, z), this._makeGlobeTileDebugTextBuffer(t, _, s, T, R, z); } _globePoint(t, s, h, _, y, T, z) { let R = i.bc(t, s, h); if (T) { const F = 1 << h.z, N = i.at(_.center.lng), G = i.aA(_.center.lat), Z = (h.x + 0.5) / F - N; let W = 0; Z > 0.5 ? W = -1 : Z < -0.5 && (W = 1); let te = (t / i.ag + h.x) / F + W, ee = (s / i.ag + h.y) / F; te = (te - N) * _._pixelsPerMercatorPixel + N, ee = (ee - G) * _._pixelsPerMercatorPixel + G; const se = [te * _.worldSize, ee * _.worldSize, 0]; i.ab.vec3.transformMat4(se, se, T), R = i.bd(R, se, z); } return i.ab.vec3.transformMat4(R, R, y); } _makeGlobeTileDebugBorderBuffer(t, s, h, _, y, T) { const z = new i.b4(), R = new i.b5(), F = new i.be(), N = (Z, W, te, ee, se) => { const oe = (te - Z) / (se - 1), he = (ee - W) / (se - 1), _e = z.length; for (let pe = 0; pe < se; pe++) { const Me = Z + pe * oe, xe = W + pe * he; z.emplaceBack(Me, xe); const we = this._globePoint(Me, xe, s, h, _, y, T); F.emplaceBack(we[0], we[1], we[2]), R.emplaceBack(_e + pe); } }, G = i.ag; N(0, 0, G, 0, 16), N(G, 0, G, G, 16), N(G, G, 0, G, 16), N(0, G, 0, 0, 16), this._tileDebugIndexBuffer = t.createIndexBuffer(R), this._tileDebugBuffer = t.createVertexBuffer(z, i.b6.members), this._globeTileDebugBorderBuffer = t.createVertexBuffer(F, i.bf.members), this._tileDebugSegments = i.b7.simpleSegment(0, 0, z.length, R.length); } _makeGlobeTileDebugTextBuffer(t, s, h, _, y, T) { const z = i.ag / 4, R = new i.b4(), F = new i.aU(), N = new i.be(), G = 25; F.reserve(32), R.reserve(G), N.reserve(G); const Z = (W, te) => G * W + te; for (let W = 0; W < G; W++) { const te = W * z; for (let ee = 0; ee < G; ee++) { const se = ee * z; R.emplaceBack(se, te); const oe = this._globePoint(se, te, s, h, _, y, T); N.emplaceBack(oe[0], oe[1], oe[2]); } } for (let W = 0; W < 4; W++) for (let te = 0; te < 4; te++) { const ee = Z(W, te), se = Z(W, te + 1), oe = Z(W + 1, te), he = Z(W + 1, te + 1); F.emplaceBack(ee, se, oe), F.emplaceBack(oe, se, he); } this._tileDebugTextIndexBuffer = t.createIndexBuffer(F), this._tileDebugTextBuffer = t.createVertexBuffer(R, i.b6.members), this._globeTileDebugTextBuffer = t.createVertexBuffer(N, i.bf.members), this._tileDebugTextSegments = i.b7.simpleSegment(0, 0, G, 32); } destroy(t = !1) { for (const s in this.buckets) this.buckets[s].destroy(); this.buckets = {}, this.imageAtlas && (this.imageAtlas = null), this.lineAtlas && (this.lineAtlas = null), this.imageAtlasTexture && (this.imageAtlasTexture.destroy(), delete this.imageAtlasTexture), this.glyphAtlasTexture && (this.glyphAtlasTexture.destroy(), delete this.glyphAtlasTexture), this.lineAtlasTexture && (this.lineAtlasTexture.destroy(), delete this.lineAtlasTexture), 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), !t && this.texture && this.texture instanceof i.T && (this.texture.destroy(), delete this.texture), this.hillshadeFBO && (this.hillshadeFBO.destroy(), delete this.hillshadeFBO), this.dem && delete this.dem, this.neighboringTiles && delete this.neighboringTiles, this.demTexture && (this.demTexture.destroy(), delete this.demTexture), this.rasterParticleState && (this.rasterParticleState.destroy(), delete this.rasterParticleState), this.latestFeatureIndex = null, this.state = "unloaded"; } } i.bg.setPbf(i.bh); class ka extends Cr { constructor(t, s, h, _, y) { super(t, s, h, _, y), this._workQueue = [], this._fetchQueue = [], this._isHeaderLoaded = !1; } setTexture(t, s) { const h = s.context, _ = h.gl; this.texture = this.texture || s.getTileTexture(t.width), this.texture && this.texture instanceof i.T ? this.texture.update(t, { premultiply: !1 }) : this.texture = new i.T(h, t, _.RGBA8, { premultiply: !1 }); } flushQueues() { for (; this._workQueue.length; ) this._workQueue.pop()(); for (; this._fetchQueue.length; ) this._fetchQueue.pop()(); } fetchHeader(t = 16384, s) { const h = this._mrt = new i.bg(30), _ = Object.assign({}, this.requestParams, { headers: { Range: "bytes=0-" + (t - 1) } }); return this.entireBuffer = null, this.request = i.bi(_, (y, T, z, R) => { if (y) s(y); else try { const F = h.getHeaderLength(T); if (F > t) return void (this.request = this.fetchHeader(F, s)); h.parseHeader(T), this._isHeaderLoaded = !0; let N = 0; for (const G of Object.values(h.layers)) N = Math.max(N, G.dataIndex[G.dataIndex.length - 1].last_byte); T.byteLength >= N && (this.entireBuffer = T), s(null, this.entireBuffer || T, z, R); } catch (F) { s(F); } }), this.request; } fetchBand(t, s, h) { const _ = this._mrt; if (!this._isHeaderLoaded || !_) return void h(new Error("Tile header is not ready")); const y = this.actor; if (!y) return void h(new Error("Can't fetch tile band without an actor")); let T; const z = (G, Z) => { T.complete(G, Z), G ? h(G) : (this.updateTextureDescriptor(t, s), h(null, this.textureDescriptor && this.textureDescriptor.img)); }, R = (G, Z) => { if (G) return h(G); const W = y.send("decodeRasterArray", { buffer: Z, task: T }, z, void 0, !0); this._workQueue.push(() => { W && W.cancel(), T.cancel(); }); }, F = _.getLayer(t); if (!F) return void h(new Error(`Unknown sourceLayer "${t}"`)); if (F.hasDataForBand(s)) return this.updateTextureDescriptor(t, s), void h(null, this.textureDescriptor ? this.textureDescriptor.img : null); const N = F.getDataRange([s]); if (T = _.createDecodingTask(N), !T || T.tasks.length) if (this.flushQueues(), this.entireBuffer) R(null, this.entireBuffer.slice(N.firstByte, N.lastByte + 1)); else { const G = Object.assign({}, this.requestParams, { headers: { Range: `bytes=${N.firstByte}-${N.lastByte}` } }), Z = i.bi(G, R); this._fetchQueue.push(() => { Z.cancel(), T.cancel(); }); } else h(null); } updateNeeded(t, s) { return (!this.textureDescriptor || this.textureDescriptor.band !== s || this.textureDescriptor.layer !== t) && this.state !== "errored"; } updateTextureDescriptor(t, s) { if (!this._mrt) return; const h = this._mrt.getLayer(t); if (!h || !h.hasBand(s) || !h.hasDataForBand(s)) return; const { bytes: _, tileSize: y, buffer: T, offset: z, scale: R } = h.getBandView(s), F = y + 2 * T, N = { data: _, width: F, height: F }, G = this.texture; G && G instanceof i.T && G.update(N, { premultiply: !1 }), this.textureDescriptor = { layer: t, band: s, img: N, buffer: T, offset: z, tileSize: y, format: h.pixelFormat, mix: [R, 256 * R, 65536 * R, 16777216 * R] }; } } class la { constructor(t, s) { this.max = t, this.onRemove = s, this.reset(); } reset() { for (const t in this.data) for (const s of this.data[t]) s.timeout && clearTimeout(s.timeout), this.onRemove(s.value); return this.data = {}, this.order = [], this; } add(t, s, h) { const _ = t.wrapped().key; this.data[_] === void 0 && (this.data[_] = []); const y = { value: s, timeout: void 0 }; if (h !== void 0 && (y.timeout = setTimeout(() => { this.remove(t, y); }, h)), this.data[_].push(y), this.order.push(_), 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 s = this.data[t].shift(); return s.timeout && clearTimeout(s.timeout), this.data[t].length === 0 && delete this.data[t], this.order.splice(this.order.indexOf(t), 1), s.value; } getByKey(t) { const s = this.data[t]; return s ? s[0].value : null; } get(t) { return this.has(t) ? this.data[t.wrapped().key][0].value : null; } remove(t, s) { if (!this.has(t)) return this; const h = t.wrapped().key, _ = s === void 0 ? 0 : this.data[h].indexOf(s), y = this.data[h][_]; return this.data[h].splice(_, 1), y.timeout && clearTimeout(y.timeout), this.data[h].length === 0 && delete this.data[h], this.onRemove(y.value), this.order.splice(this.order.indexOf(h), 1), this; } setMaxSize(t) { for (this.max = t; this.order.length > this.max; ) { const s = this._getAndRemoveByKey(this.order[0]); s && this.onRemove(s); } return this; } filter(t) { const s = []; for (const h in this.data) for (const _ of this.data[h]) t(_.value) || s.push(_); for (const h of s) this.remove(h.value.tileID, h); } } class Zo { constructor() { this.state = {}, this.stateChanges = {}, this.deletedStates = {}; } updateState(t, s, h) { const _ = String(s); if (this.stateChanges[t] = this.stateChanges[t] || {}, this.stateChanges[t][_] = this.stateChanges[t][_] || {}, i.l(this.stateChanges[t][_], h), this.deletedStates[t] === null) { this.deletedStates[t] = {}; for (const y in this.state[t]) y !== _ && (this.deletedStates[t][y] = null); } else if (this.deletedStates[t] && this.deletedStates[t][_] === null) { this.deletedStates[t][_] = {}; for (const y in this.state[t][_]) h[y] || (this.deletedStates[t][_][y] = null); } else for (const y in h) this.deletedStates[t] && this.deletedStates[t][_] && this.deletedStates[t][_][y] === null && delete this.deletedStates[t][_][y]; } removeFeatureState(t, s, h) { if (this.deletedStates[t] === null) return; const _ = String(s); if (this.deletedStates[t] = this.deletedStates[t] || {}, h && s !== void 0) this.deletedStates[t][_] !== null && (this.deletedStates[t][_] = this.deletedStates[t][_] || {}, this.deletedStates[t][_][h] = null); else if (s !== void 0) if (this.stateChanges[t] && this.stateChanges[t][_]) for (h in this.deletedStates[t][_] = {}, this.stateChanges[t][_]) this.deletedStates[t][_][h] = null; else this.deletedStates[t][_] = null; else this.deletedStates[t] = null; } getState(t, s) { const h = this.state[t] || {}, _ = this.stateChanges[t] || {}, y = this.deletedStates[t]; if (y === null) return {}; if (s !== void 0) { const z = String(s), R = i.l({}, h[z], _[z]); if (y) { const F = y[s]; if (F === null) return {}; for (const N in F) delete R[N]; } return R; } const T = i.l({}, h, _); if (y) for (const z in y) delete T[z]; return T; } initializeTileState(t, s) { t.refreshFeatureState(s); } coalesceChanges(t, s) { const h = {}; for (const _ in this.stateChanges) { this.state[_] = this.state[_] || {}; const y = {}; for (const T in this.stateChanges[_]) this.state[_][T] || (this.state[_][T] = {}), i.l(this.state[_][T], this.stateChanges[_][T]), y[T] = this.state[_][T]; h[_] = y; } for (const _ in this.deletedStates) { this.state[_] = this.state[_] || {}; const y = {}; if (this.deletedStates[_] === null) for (const T in this.state[_]) y[T] = {}, this.state[_][T] = {}; else for (const T in this.deletedStates[_]) { if (this.deletedStates[_][T] === null) this.state[_][T] = {}; else if (this.state[_][T]) for (const z of Object.keys(this.deletedStates[_][T])) delete this.state[_][T][z]; y[T] = this.state[_][T]; } h[_] = h[_] || {}, i.l(h[_], y); } if (this.stateChanges = {}, this.deletedStates = {}, Object.keys(h).length !== 0) for (const _ in t) t[_].refreshFeatureState(s); } } class sr extends i.E { constructor(t, s, h) { super(), this.id = t, this._onlySymbols = h, s.on("data", (_) => { _.dataType === "source" && _.sourceDataType === "metadata" && (this._sourceLoaded = !0), this._sourceLoaded && !this._paused && _.dataType === "source" && _.sourceDataType === "content" && (this.reload(), this.transform && this.update(this.transform)); }), s.on("error", () => { this._sourceErrored = !0; }), this._source = s, this._tiles = {}, this._cache = new la(0, this._unloadTile.bind(this)), this._timers = {}, this._cacheTimers = {}, this._minTileCacheSize = s.minTileCacheSize, this._maxTileCacheSize = s.maxTileCacheSize, this._loadedParentTiles = {}, this.castsShadows = !1, this.tileCoverLift = 0, this._coveredTiles = {}, this._shadowCasterTiles = {}, this._state = new Zo(), this._isRaster = this._source.type === "raster" || this._source.type === "raster-dem" || this._source.type === "raster-array" || this._source.type === "custom" && this._source._dataType === "raster"; } onAdd(t) { this.map = t, this._minTileCacheSize = this._minTileCacheSize === void 0 && t ? t._minTileCacheSize : this._minTileCacheSize, this._maxTileCacheSize = this._maxTileCacheSize === void 0 && t ? t._maxTileCacheSize : this._maxTileCacheSize; } loaded() { if (this._sourceErrored) return !0; if (!this._sourceLoaded || !this._source.loaded()) return !1; for (const t in this._tiles) { const s = this._tiles[t]; if (s.state !== "loaded" && s.state !== "errored") 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, s) { return t.isSymbolTile = this._onlySymbols, t.isExtraShadowCaster = this._shadowCasterTiles[t.tileID.key], this._source.loadTile(t, s); } _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 s in this._tiles) { const h = this._tiles[s]; h.upload(t), h.prepare(this.map.style.imageManager, this.map ? this.map.painter : null, this._source.scope); } } getIds() { return i.bj(this._tiles).map((t) => t.tileID).sort(ca).map((t) => t.key); } getRenderableIds(t, s) { const h = []; for (const _ in this._tiles) this._isIdRenderable(+_, t, s) && h.push(this._tiles[_]); return t ? h.sort((_, y) => { const T = _.tileID, z = y.tileID, R = new i.P(T.canonical.x, T.canonical.y)._rotate(this.transform.angle), F = new i.P(z.canonical.x, z.canonical.y)._rotate(this.transform.angle); return T.overscaledZ - z.overscaledZ || F.y - R.y || F.x - R.x; }).map((_) => _.tileID.key) : h.map((_) => _.tileID).sort(ca).map((_) => _.key); } hasRenderableParent(t) { const s = this.findLoadedParent(t, 0); return !!s && this._isIdRenderable(s.tileID.key); } _isIdRenderable(t, s, h) { return this._tiles[t] && this._tiles[t].hasData() && !this._coveredTiles[t] && (s || !this._tiles[t].holdingForFade()) && (h || !this._shadowCasterTiles[t]); } reload() { if (this._paused) this._shouldReloadOnResume = !0; else { this._cache.reset(); for (const t in this._tiles) this._tiles[t].state !== "errored" && this._reloadTile(+t, "reloading"); } } _reloadTile(t, s) { const h = this._tiles[t]; h && (h.state !== "loading" && (h.state = s), this._loadTile(h, this._tileLoaded.bind(this, h, t, s))); } _tileLoaded(t, s, h, _) { if (_) if (t.state = "errored", _.status !== 404) this._source.fire(new i.y(_, { tile: t })); else { if (this._source.fire(new i.z("data", { dataType: "source", sourceDataType: "error", sourceId: this._source.id, tile: t })), !(t.tileID.key in this._loadedParentTiles)) return; if (this._source.type === "raster-dem" && this.usedForTerrain && this.map.painter.terrain) { const y = this.map.painter.terrain; this.update(this.transform, y.getScaledDemTileSize(), !0), y.resetTileLookupCache(this.id); } else this.update(this.transform); } else t.timeAdded = i.q.now(), h === "expired" && (t.refreshedUponExpiration = !0), this._setTileReloadTimer(s, t), this._source.type === "raster-dem" && t.dem && this._backfillDEM(t), this._state.initializeTileState(t, this.map ? this.map.painter : null), this._source.fire(new i.z("data", { dataType: "source", tile: t, coord: t.tileID, sourceCacheId: this.id })); } _backfillDEM(t) { const s = this.getRenderableIds(); for (let _ = 0; _ < s.length; _++) { const y = s[_]; if (t.neighboringTiles && t.neighboringTiles[y]) { const T = this.getTileByID(y); h(t, T), h(T, t); } } function h(_, y) { if (!_.dem || _.dem.borderReady) return; _.needsHillshadePrepare = !0, _.needsDEMTextureUpload = !0; let T = y.tileID.canonical.x - _.tileID.canonical.x; const z = y.tileID.canonical.y - _.tileID.canonical.y, R = Math.pow(2, _.tileID.canonical.z), F = y.tileID.key; T === 0 && z === 0 || Math.abs(z) > 1 || (Math.abs(T) > 1 && (Math.abs(T + R) === 1 ? T += R : Math.abs(T - R) === 1 && (T -= R)), y.dem && _.dem && (_.dem.backfillBorder(y.dem, T, z), _.neighboringTiles && _.neighboringTiles[F] && (_.neighboringTiles[F].backfilled = !0))); } } getTile(t) { return this.getTileByID(t.key); } getTileByID(t) { return this._tiles[t]; } _retainLoadedChildren(t, s, h, _) { for (const y in this._tiles) { let T = this._tiles[y]; if (_[y] || !T.hasData() || T.tileID.overscaledZ <= s || T.tileID.overscaledZ > h) continue; let z = T.tileID; for (; T && T.tileID.overscaledZ > s + 1; ) { const F = T.tileID.scaledTo(T.tileID.overscaledZ - 1); T = this._tiles[F.key], T && T.hasData() && (z = F); } let R = z; for (; R.overscaledZ > s; ) if (R = R.scaledTo(R.overscaledZ - 1), t[R.key]) { _[z.key] = z; break; } } } findLoadedParent(t, s) { if (t.key in this._loadedParentTiles) { const h = this._loadedParentTiles[t.key]; return h && h.tileID.overscaledZ >= s ? h : null; } for (let h = t.overscaledZ - 1; h >= s; h--) { const _ = t.scaledTo(h), y = this._getLoadedTile(_); if (y) return y; } } _getLoadedTile(t) { const s = this._tiles[t.key]; return s && s.hasData() ? s : this._cache.getByKey(this._source.reparseOverscaled ? t.wrapped().key : t.canonical.key); } updateCacheSize(t, s) { s = s || this._source.tileSize; const h = Math.ceil(t.width / s) + 1, _ = Math.ceil(t.height / s) + 1, y = Math.floor(h * _ * 5), T = typeof this._minTileCacheSize == "number" ? Math.max(this._minTileCacheSize, y) : y, z = typeof this._maxTileCacheSize == "number" ? Math.min(this._maxTileCacheSize, T) : T; this._cache.setMaxSize(z); } handleWrapJump(t) { const s = Math.round((t - (this._prevLng === void 0 ? t : this._prevLng)) / 360); if (this._prevLng = t, s) { const h = {}; for (const _ in this._tiles) { const y = this._tiles[_]; y.tileID = y.tileID.unwrapTo(y.tileID.wrap + s), h[y.tileID.key] = y; } this._tiles = h; for (const _ in this._timers) clearTimeout(this._timers[_]), delete this._timers[_]; for (const _ in this._tiles) this._setTileReloadTimer(+_, this._tiles[_]); } } update(t, s, h, _) { if (this.transform = t, !this._sourceLoaded || this._paused || this.transform.freezeTileCoverage || this.usedForTerrain && !h) return; this.updateCacheSize(t, s), this.transform.projection.name !== "globe" && this.handleWrapJump(this.transform.center.lng), this._shadowCasterTiles = {}, this._coveredTiles = {}; const y = this._source.type === "batched-model"; let T, z = this._source.maxzoom; const R = this.map && this.map.painter ? this.map.painter._terrain : null; if (R && R.sourceCache === this && R.attenuationRange()) { const G = R.attenuationRange()[0], Z = Math.floor(G) - Math.log2(R.getDemUpscale()); z > Z && (z = Z); } if (this.used || this.usedForTerrain) { if (this._source.tileID) T = t.getVisibleUnwrappedCoordinates(this._source.tileID).map((G) => new i.aG(G.canonical.z, G.wrap, G.canonical.z, G.canonical.x, G.canonical.y)); else if (this.tileCoverLift !== 0) { const G = t.clone(); G.tileCoverLift = this.tileCoverLift, T = G.coveringTiles({ tileSize: s || this._source.tileSize, minzoom: this._source.minzoom, maxzoom: z, roundZoom: this._source.roundZoom && !h, reparseOverscaled: this._source.reparseOverscaled, isTerrainDEM: this.usedForTerrain, calculateQuadrantVisibility: y }), this._source.minzoom <= 1 && t.projection.name === "globe" && (T.push(new i.aG(1, 0, 1, 0, 0)), T.push(new i.aG(1, 0, 1, 1, 0)), T.push(new i.aG(1, 0, 1, 0, 1)), T.push(new i.aG(1, 0, 1, 1, 1))); } else if (T = t.coveringTiles({ tileSize: s || this._source.tileSize, minzoom: this._source.minzoom, maxzoom: z, roundZoom: this._source.roundZoom && !h, reparseOverscaled: this._source.reparseOverscaled, isTerrainDEM: this.usedForTerrain, calculateQuadrantVisibility: y }), this._source.hasTile) { const G = this._source.hasTile.bind(this._source); T = T.filter((Z) => G(Z)); } } else T = []; if (T.length > 0 && this.castsShadows && _ && this.transform.projection.name !== "globe" && !this.usedForTerrain && !Ra(this._source.type)) { const G = t.coveringZoomLevel({ tileSize: s || this._source.tileSize, roundZoom: this._source.roundZoom && !h }), Z = Math.min(G, this._source.maxzoom); if (y) { const W = t.extendTileCover(T, Z); for (const te of W) T.push(te); } else { const W = t.extendTileCover(T, Z, _); for (const te of W) this._shadowCasterTiles[te.key] = !0, T.push(te); } } const F = this._updateRetainedTiles(T); if (Ra(this._source.type) && T.length !== 0) { const G = {}, Z = {}, W = Object.keys(F); for (const ee of W) { const se = F[ee], oe = this._tiles[ee]; if (!oe || oe.fadeEndTime && oe.fadeEndTime <= i.q.now()) continue; const he = this.findLoadedParent(se, Math.max(se.overscaledZ - sr.maxOverzooming, this._source.minzoom)); he && (this._addTile(he.tileID), G[he.tileID.key] = he.tileID), Z[ee] = se; } const te = T[T.length - 1].overscaledZ; for (const ee in this._tiles) { const se = this._tiles[ee]; if (F[ee] || !se.hasData()) continue; let oe = se.tileID; for (; oe.overscaledZ > te; ) { oe = oe.scaledTo(oe.overscaledZ - 1); const he = this._tiles[oe.key]; if (he && he.hasData() && Z[oe.key]) { F[ee] = se.tileID; break; } } } for (const ee in G) F[ee] || (this._coveredTiles[ee] = !0, F[ee] = G[ee]); } for (const G in F) this._tiles[G].clearFadeHold(); const N = i.bk(this._tiles, F); for (const G of N) { const Z = this._tiles[G]; Z.hasSymbolBuckets && !Z.holdingForFade() ? Z.setHoldDuration(this.map._fadeDuration) : Z.hasSymbolBuckets && !Z.symbolFadeFinished() || this._removeTile(+G); } 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 s = {}; if (t.length === 0) return s; const h = {}, _ = t.reduce((F, N) => Math.min(F, N.overscaledZ), 1 / 0), y = t[0].overscaledZ, T = Math.max(y - sr.maxOverzooming, this._source.minzoom), z = Math.max(y + sr.maxUnderzooming, this._source.minzoom), R = {}; for (const F of t) { const N = this._addTile(F); s[F.key] = F, N.hasData() || _ < this._source.maxzoom && (R[F.key] = F); } this._retainLoadedChildren(R, _, z, s); for (const F of t) { let N = this._tiles[F.key]; if (N.hasData()) continue; if (F.canonical.z >= this._source.maxzoom) { const Z = F.children(this._source.maxzoom)[0], W = this.getTile(Z); if (W && W.hasData()) { s[Z.key] = Z; continue; } } else { const Z = F.children(this._source.maxzoom); if (s[Z[0].key] && s[Z[1].key] && s[Z[2].key] && s[Z[3].key]) continue; } let G = N.wasRequested(); for (let Z = F.overscaledZ - 1; Z >= T; --Z) { const W = F.scaledTo(Z); if (h[W.key] || (h[W.key] = !0, N = this.getTile(W), !N && G && (N = this._addTile(W)), N && (s[W.key] = W, G = N.wasRequested(), N.hasData()))) break; } } return s; } _updateLoadedParentTileCache() { this._loadedParentTiles = {}; for (const t in this._tiles) { const s = []; let h, _ = this._tiles[t].tileID; for (; _.overscaledZ > 0; ) { if (_.key in this._loadedParentTiles) { h = this._loadedParentTiles[_.key]; break; } s.push(_.key); const y = _.scaledTo(_.overscaledZ - 1); if (h = this._getLoadedTile(y), h) break; _ = y; } for (const y of s) this._loadedParentTiles[y] = h; } } _addTile(t) { let s = this._tiles[t.key]; if (s) return s.isExtraShadowCaster !== !0 || this._shadowCasterTiles[t.key] || this._reloadTile(t.key, "reloading"), s; s = this._cache.getAndRemove(t), s && (this._setTileReloadTimer(t.key, s), s.tileID = t, this._state.initializeTileState(s, this.map ? this.map.painter : null), this._cacheTimers[t.key] && (clearTimeout(this._cacheTimers[t.key]), delete this._cacheTimers[t.key], this._setTileReloadTimer(t.key, s))); const h = !!s; if (!h) { const _ = this.map ? this.map.painter : null, y = this._source.tileSize * t.overscaleFactor(); s = this._source.type === "raster-array" ? new ka(t, y, this.transform.tileZoom, _, this._isRaster) : new Cr(t, y, this.transform.tileZoom, _, this._isRaster), this._loadTile(s, this._tileLoaded.bind(this, s, t.key, s.state)); } return s ? (s.uses++, this._tiles[t.key] = s, h || this._source.fire(new i.z("dataloading", { tile: s, coord: s.tileID, dataType: "source" })), s) : null; } _setTileReloadTimer(t, s) { t in this._timers && (clearTimeout(this._timers[t]), delete this._timers[t]); const h = s.getExpiryTimeout(); h && (this._timers[t] = setTimeout(() => { this._reloadTile(t, "expired"), delete this._timers[t]; }, h)); } _removeTile(t) { const s = this._tiles[t]; s && (s.uses--, delete this._tiles[t], this._timers[t] && (clearTimeout(this._timers[t]), delete this._timers[t]), s.uses > 0 || (s.hasData() && s.state !== "reloading" || s.state === "empty" ? this._cache.add(s.tileID, s, s.getExpiryTimeout()) : (s.aborted = !0, this._abortTile(s), this._unloadTile(s)))); } 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, s, h) { const _ = [], y = this.transform; if (!y) return _; const T = y.projection.name === "globe", z = i.at(y.center.lng); for (const R in this._tiles) { const F = this._tiles[R]; if (h && F.clearQueryDebugViz(), F.holdingForFade()) continue; let N; if (T) { const G = F.tileID.canonical; if (G.z === 0) { const Z = [Math.abs(i.aw(z, ...ki(G, -1)) - z), Math.abs(i.aw(z, ...ki(G, 1)) - z)]; N = [0, 2 * Z.indexOf(Math.min(...Z)) - 1]; } else { const Z = [Math.abs(i.aw(z, ...ki(G, -1)) - z), Math.abs(i.aw(z, ...ki(G, 0)) - z), Math.abs(i.aw(z, ...ki(G, 1)) - z)]; N = [Z.indexOf(Math.min(...Z)) - 1]; } } else N = [0]; for (const G of N) { const Z = t.containsTile(F, y, s, G); Z && _.push(Z); } } return _; } getShadowCasterCoordinates() { return this._getRenderableCoordinates(!1, !0); } getVisibleCoordinates(t) { return this._getRenderableCoordinates(t); } _getRenderableCoordinates(t, s) { const h = this.getRenderableIds(t, s).map((y) => this._tiles[y].tileID), _ = this.transform.projection.name === "globe"; for (const y of h) y.projMatrix = this.transform.calculateProjMatrix(y.toUnwrapped()), y.expandedProjMatrix = _ ? this.transform.calculateProjMatrix(y.toUnwrapped(), !1, !0) : y.projMatrix; return h; } sortCoordinatesByDistance(t) { const s = t.slice(), h = this.transform._camera.position, _ = this.transform._camera.forward(), y = {}; for (const T of s) { const z = 1 / (1 << T.canonical.z); y[T.key] = ((T.canonical.x + 0.5) * z + T.wrap - h[0]) * _[0] + ((T.canonical.y + 0.5) * z - h[1]) * _[1] - h[2] * _[2]; } return s.sort((T, z) => y[T.key] - y[z.key]), s; } hasTransition() { if (this._source.hasTransition()) return !0; if (Ra(this._source.type)) for (const t in this._tiles) { const s = this._tiles[t]; if (s.fadeEndTime !== void 0 && s.fadeEndTime >= i.q.now()) return !0; } return !1; } setFeatureState(t, s, h) { this._state.updateState(t = t || "_geojsonTileLayer", s, h); } removeFeatureState(t, s, h) { this._state.removeFeatureState(t = t || "_geojsonTileLayer", s, h); } getFeatureState(t, s) { return this._state.getState(t = t || "_geojsonTileLayer", s); } setDependencies(t, s, h) { const _ = this._tiles[t]; _ && _.setDependencies(s, h); } reloadTilesForDependencies(t, s) { for (const h in this._tiles) this._tiles[h].hasDependency(t, s) && this._reloadTile(+h, "reloading"); this._cache.filter((h) => !h.hasDependency(t, s)); } _preloadTiles(t, s) { if (!this._sourceLoaded) { const R = () => { this._sourceLoaded && (this._source.off("data", R), this._preloadTiles(t, s)); }; return void this._source.on("data", R); } const h = /* @__PURE__ */ new Map(), _ = Array.isArray(t) ? t : [t], y = this.map.painter.terrain, T = this.usedForTerrain && y ? y.getScaledDemTileSize() : this._source.tileSize; for (const R of _) { const F = R.coveringTiles({ tileSize: T, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: this._source.roundZoom && !this.usedForTerrain, reparseOverscaled: this._source.reparseOverscaled, isTerrainDEM: this.usedForTerrain }); for (const N of F) h.set(N.key, N); this.usedForTerrain && R.updateElevation(!1); } const z = Array.from(h.values()); i.bl(z, (R, F) => { const N = new Cr(R, this._source.tileSize * R.overscaleFactor(), this.transform.tileZoom, this.map.painter, this._isRaster); this._loadTile(N, (G) => { this._source.type === "raster-dem" && N.dem && this._backfillDEM(N), F(G, N); }); }, s); } } function ca(c, t) { const s = Math.abs(2 * c.wrap) - +(c.wrap < 0), h = Math.abs(2 * t.wrap) - +(t.wrap < 0); return c.overscaledZ - t.overscaledZ || h - s || t.canonical.y - c.canonical.y || t.canonical.x - c.canonical.x; } function Ra(c) { return c === "raster" || c === "image" || c === "video" || c === "custom"; } function ki(c, t) { const s = 1 << c.z; return [c.x / s + t, (c.x + 1) / s + t]; } sr.maxOverzooming = 10, sr.maxUnderzooming = 3; class Gl { constructor(t) { this.style = t, this.layersGotHidden = !1, this.layers = []; } processLayersChanged() { this.layers = []; const t = !1, s = !1; for (const h in this.style._mergedLayers) { const _ = this.style._mergedLayers[h]; if (_.type === "fill-extrusion") this.layers.push({ layer: _, visible: t, visibilityChanged: s }); else if (_.type === "model") { const y = this.style.getLayerSource(_); y && y.type === "batched-model" && this.layers.push({ layer: _, visible: t, visibilityChanged: s }); } } } onNewFrame(t) { this.layersGotHidden = !1; for (const s of this.layers) { const h = s.layer; let _ = !1; h.type === "fill-extrusion" ? _ = !h.isHidden(t) && h.paint.get("fill-extrusion-opacity") > 0 : h.type === "model" && (_ = !h.isHidden(t) && h.paint.get("model-opacity").constantOr(1) > 0), this.layersGotHidden = this.layersGotHidden || !_ && s.visible, s.visible = _; } } updateZOffset(t, s) { this.currentBuildingBuckets = []; for (const _ of this.layers) { const y = _.layer, T = this.style.getLayerSourceCache(y); let z = 1; y.type === "fill-extrusion" && (z = _.visible ? y.paint.get("fill-extrusion-vertical-scale") : 0); let R = T ? T.getTile(s) : null; if (!R && T && s.canonical.z > T.getSource().minzoom) { let F = s.scaledTo(Math.min(T.getSource().maxzoom, s.overscaledZ - 1)); for (; F.overscaledZ >= T.getSource().minzoom && (R = T.getTile(F), !R && F.overscaledZ !== 0); ) F = F.scaledTo(F.overscaledZ - 1); } this.currentBuildingBuckets.push({ bucket: R ? R.getBucket(y) : null, tileID: R ? R.tileID : s, verticalScale: z }); } t.hasAnyZOffset = !1; let h = !1; for (let _ = 0; _ < t.symbolInstances.length; _++) { const y = t.symbolInstances.get(_), T = y.zOffset, z = this._getHeightAtTileOffset(s, y.tileAnchorX, y.tileAnchorY); y.zOffset = z !== Number.NEGATIVE_INFINITY ? z : T, h || T === y.zOffset || (h = !0), t.hasAnyZOffset || y.zOffset === 0 || (t.hasAnyZOffset = !0); } h && (t.zOffsetBuffersNeedUpload = !0, t.zOffsetSortDirty = !0); } _mapCoordToOverlappingTile(t, s, h, _) { let y = s, T = h; if (t.canonical.z !== _.canonical.z) { const z = _.canonical, R = 1 / (1 << t.canonical.z - z.z); y = (s + t.canonical.x * i.ag) * R - z.x * i.ag | 0, T = (h + t.canonical.y * i.ag) * R - z.y * i.ag | 0; } return { tileX: y, tileY: T }; } _getHeightAtTileOffset(t, s, h) { let _, y; for (let T = 0; T < this.layers.length; ++T) { if (this.layers[T].layer.type !== "fill-extrusion") continue; const { bucket: z, tileID: R, verticalScale: F } = this.currentBuildingBuckets[T]; if (!z) continue; const { tileX: N, tileY: G } = this._mapCoordToOverlappingTile(t, s, h, R), Z = z.getHeightAtTileCoord(N, G); Z && Z.height !== void 0 && (Z.hidden ? _ = Z.height : y = Math.max(Z.height * F, y || 0)); } if (y !== void 0) return y; for (let T = 0; T < this.layers.length; ++T) { const z = this.layers[T]; if (z.layer.type !== "model" || !z.visible) continue; const { bucket: R, tileID: F } = this.currentBuildingBuckets[T]; if (!R) continue; const { tileX: N, tileY: G } = this._mapCoordToOverlappingTile(t, s, h, F), Z = R.getHeightAtTileCoord(N, G); if (Z && !Z.hidden) return Z.height === void 0 && _ !== void 0 ? Math.min(Z.maxHeight, _) * Z.verticalScale : Z.height ? Z.height * Z.verticalScale : Number.NEGATIVE_INFINITY; } return this.layersGotHidden ? 0 : Number.NEGATIVE_INFINITY; } } function ei(c, t) { const s = {}; for (const h in c) h !== "ref" && (s[h] = c[h]); return i.bm.forEach((h) => { h in t && (s[h] = t[h]); }), s; } function ul(c) { c = c.slice(); const t = /* @__PURE__ */ Object.create(null); for (let s = 0; s < c.length; s++) t[c[s].id] = c[s]; for (let s = 0; s < c.length; s++) "ref" in c[s] && (c[s] = ei(c[s], t[c[s].ref])); return c; } const Oi = { setStyle: "setStyle", addLayer: "addLayer", removeLayer: "removeLayer", setPaintProperty: "setPaintProperty", setLayoutProperty: "setLayoutProperty", setSlot: "setSlot", 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", setSnow: "setSnow", setRain: "setRain", setCamera: "setCamera", setLights: "setLights", setProjection: "setProjection", addImport: "addImport", removeImport: "removeImport", updateImport: "updateImport" }; function Bi(c, t, s) { s.push({ command: Oi.addSource, args: [c, t[c]] }); } function ns(c, t, s) { t.push({ command: Oi.removeSource, args: [c] }), s[c] = !0; } function Cn(c, t, s, h) { ns(c, s, h), Bi(c, t, s); } function ha(c, t, s) { let h; for (h in c[s]) if (c[s].hasOwnProperty(h) && h !== "data" && !i.bn(c[s][h], t[s][h])) return !1; for (h in t[s]) if (t[s].hasOwnProperty(h) && h !== "data" && !i.bn(c[s][h], t[s][h])) return !1; return !0; } function Ot(c, t, s, h, _, y) { let T; for (T in t = t || {}, c = c || {}) c.hasOwnProperty(T) && (i.bn(c[T], t[T]) || s.push({ command: y, args: [h, T, t[T], _] })); for (T in t) t.hasOwnProperty(T) && !c.hasOwnProperty(T) && (i.bn(c[T], t[T]) || s.push({ command: y, args: [h, T, t[T], _] })); } function Fi(c) { return c.id; } function Li(c, t) { return c[t.id] = t, c; } class ms { constructor(t, s) { this.reset(t, s); } reset(t, s) { this.points = t || [], this._distances = [0]; for (let h = 1; h < this.points.length; h++) this._distances[h] = this._distances[h - 1] + this.points[h].dist(this.points[h - 1]); this.length = this._distances[this._distances.length - 1], this.padding = Math.min(s || 0, 0.5 * this.length), this.paddedLength = this.length - 2 * this.padding; } lerp(t) { if (this.points.length === 1) return this.points[0]; t = i.aw(t, 0, 1); let s = 1, h = this._distances[s]; const _ = t * this.paddedLength + this.padding; for (; h < _ && s < this._distances.length; ) h = this._distances[++s]; const y = s - 1, T = this._distances[y], z = h - T, R = z > 0 ? (_ - T) / z : 0; return this.points[y].mult(1 - R).add(this.points[s].mult(R)); } } class bo { constructor(t, s, h) { const _ = this.boxCells = [], y = this.circleCells = []; this.xCellCount = Math.ceil(t / h), this.yCellCount = Math.ceil(s / h); for (let T = 0; T < this.xCellCount * this.yCellCount; T++) _.push([]), y.push([]); this.circleKeys = [], this.boxKeys = [], this.bboxes = [], this.circles = [], this.width = t, this.height = s, this.xScale = this.xCellCount / t, this.yScale = this.yCellCount / s, this.boxUid = 0, this.circleUid = 0; } keysLength() { return this.boxKeys.length + this.circleKeys.length; } insert(t, s, h, _, y) { this._forEachCell(s, h, _, y, this._insertBoxCell, this.boxUid++), this.boxKeys.push(t), this.bboxes.push(s), this.bboxes.push(h), this.bboxes.push(_), this.bboxes.push(y); } insertCircle(t, s, h, _) { this._forEachCell(s - _, h - _, s + _, h + _, this._insertCircleCell, this.circleUid++), this.circleKeys.push(t), this.circles.push(s), this.circles.push(h), this.circles.push(_); } _insertBoxCell(t, s, h, _, y, T) { this.boxCells[y].push(T); } _insertCircleCell(t, s, h, _, y, T) { this.circleCells[y].push(T); } _query(t, s, h, _, y, T) { if (h < 0 || t > this.width || _ < 0 || s > this.height) return !y && []; const z = []; if (t <= 0 && s <= 0 && this.width <= h && this.height <= _) { if (y) return !0; for (let R = 0; R < this.boxKeys.length; R++) z.push({ key: this.boxKeys[R], x1: this.bboxes[4 * R], y1: this.bboxes[4 * R + 1], x2: this.bboxes[4 * R + 2], y2: this.bboxes[4 * R + 3] }); for (let R = 0; R < this.circleKeys.length; R++) { const F = this.circles[3 * R], N = this.circles[3 * R + 1], G = this.circles[3 * R + 2]; z.push({ key: this.circleKeys[R], x1: F - G, y1: N - G, x2: F + G, y2: N + G }); } return T ? z.filter(T) : z; } return this._forEachCell(t, s, h, _, this._queryCell, z, { hitTest: y, seenUids: { box: {}, circle: {} } }, T), y ? z.length > 0 : z; } _queryCircle(t, s, h, _, y) { const T = t - h, z = t + h, R = s - h, F = s + h; if (z < 0 || T > this.width || F < 0 || R > this.height) return !_ && []; const N = []; return this._forEachCell(T, R, z, F, this._queryCellCircle, N, { hitTest: _, circle: { x: t, y: s, radius: h }, seenUids: { box: {}, circle: {} } }, y), _ ? N.length > 0 : N; } query(t, s, h, _, y) { return this._query(t, s, h, _, !1, y); } hitTest(t, s, h, _, y) { return this._query(t, s, h, _, !0, y); } hitTestCircle(t, s, h, _) { return this._queryCircle(t, s, h, !0, _); } _queryCell(t, s, h, _, y, T, z, R) { const F = z.seenUids, N = this.boxCells[y]; if (N !== null) { const Z = this.bboxes; for (const W of N) if (!F.box[W]) { F.box[W] = !0; const te = 4 * W; if (t <= Z[te + 2] && s <= Z[te + 3] && h >= Z[te + 0] && _ >= Z[te + 1] && (!R || R(this.boxKeys[W]))) { if (z.hitTest) return T.push(!0), !0; T.push({ key: this.boxKeys[W], x1: Z[te], y1: Z[te + 1], x2: Z[te + 2], y2: Z[te + 3] }); } } } const G = this.circleCells[y]; if (G !== null) { const Z = this.circles; for (const W of G) if (!F.circle[W]) { F.circle[W] = !0; const te = 3 * W; if (this._circleAndRectCollide(Z[te], Z[te + 1], Z[te + 2], t, s, h, _) && (!R || R(this.circleKeys[W]))) { if (z.hitTest) return T.push(!0), !0; { const ee = Z[te], se = Z[te + 1], oe = Z[te + 2]; T.push({ key: this.circleKeys[W], x1: ee - oe, y1: se - oe, x2: ee + oe, y2: se + oe }); } } } } } _queryCellCircle(t, s, h, _, y, T, z, R) { const F = z.circle, N = z.seenUids, G = this.boxCells[y]; if (G !== null) { const W = this.bboxes; for (const te of G) if (!N.box[te]) { N.box[te] = !0; const ee = 4 * te; if (this._circleAndRectCollide(F.x, F.y, F.radius, W[ee + 0], W[ee + 1], W[ee + 2], W[ee + 3]) && (!R || R(this.boxKeys[te]))) return T.push(!0), !0; } } const Z = this.circleCells[y]; if (Z !== null) { const W = this.circles; for (const te of Z) if (!N.circle[te]) { N.circle[te] = !0; const ee = 3 * te; if (this._circlesCollide(W[ee], W[ee + 1], W[ee + 2], F.x, F.y, F.radius) && (!R || R(this.circleKeys[te]))) return T.push(!0), !0; } } } _forEachCell(t, s, h, _, y, T, z, R) { const F = this._convertToXCellCoord(t), N = this._convertToYCellCoord(s), G = this._convertToXCellCoord(h), Z = this._convertToYCellCoord(_); for (let W = F; W <= G; W++) for (let te = N; te <= Z; te++) if (y.call(this, t, s, h, _, this.xCellCount * te + W, T, z, R)) return; } _convertToXCellCoord(t) { return Math.max(0, Math.min(this.xCellCount - 1, Math.floor(t * this.xScale))); } _convertToYCellCoord(t) { return Math.max(0, Math.min(this.yCellCount - 1, Math.floor(t * this.yScale))); } _circlesCollide(t, s, h, _, y, T) { const z = _ - t, R = y - s, F = h + T; return F * F > z * z + R * R; } _circleAndRectCollide(t, s, h, _, y, T, z) { const R = (T - _) / 2, F = Math.abs(t - (_ + R)); if (F > R + h) return !1; const N = (z - y) / 2, G = Math.abs(s - (y + N)); if (G > N + h) return !1; if (F <= R || G <= N) return !0; const Z = F - R, W = G - N; return Z * Z + W * W <= h * h; } } const Pi = { unknown: 0, flipRequired: 1, flipNotRequired: 2 }, _s = Math.tan(85 * Math.PI / 180); function Js(c, t, s, h, _, y, T) { const z = i.ab.mat4.create(); if (s) if (y.name === "globe") { const R = i.bo(_, t); i.ab.mat4.multiply(z, z, R); } else { const R = i.ab.mat2.invert([], T); z[0] = R[0], z[1] = R[1], z[4] = R[2], z[5] = R[3], h || i.ab.mat4.rotateZ(z, z, _.angle); } else i.ab.mat4.multiply(z, _.labelPlaneMatrix, c); return z; } function Ho(c, t, s, h, _, y, T) { const z = Js(c, t, s, h, _, y, T); return y.name === "globe" && s || (z[2] = z[6] = z[10] = z[14] = 0), z; } function Ss(c, t, s, h, _, y, T) { if (s) { if (y.name === "globe") { const z = Js(c, t, s, h, _, y, T); return i.ab.mat4.invert(z, z), i.ab.mat4.multiply(z, c, z), z; } { const z = i.ab.mat4.clone(c), R = i.ab.mat4.identity([]); return R[0] = T[0], R[1] = T[1], R[4] = T[2], R[5] = T[3], i.ab.mat4.multiply(z, z, R), h || i.ab.mat4.rotateZ(z, z, -_.angle), z; } } return _.glCoordMatrix; } function un(c, t, s, h) { const _ = [c, t, s, 1]; s ? i.ab.vec4.transformMat4(_, _, h) : wo(_, _, h); const y = _[3]; return _[0] /= y, _[1] /= y, _[2] /= y, _; } function Bc(c, t) { return Math.min(0.5 + c / t * 0.5, 1.5); } function ua(c, t) { const s = c[0] / c[3], h = c[1] / c[3]; return s >= -t[0] && s <= t[0] && h >= -t[1] && h <= t[1]; } function Zl(c, t, s, h, _, y, T, z, R, F) { const N = s.transform, G = h ? c.textSizeData : c.iconSizeData, Z = i.bp(G, s.transform.zoom), W = N.projection.name === "globe", te = [256 / s.width * 2 + 1, 256 / s.height * 2 + 1], ee = h ? c.text.dynamicLayoutVertexArray : c.icon.dynamicLayoutVertexArray; ee.clear(); let se = null; W && (se = h ? c.text.globeExtVertexArray : c.icon.globeExtVertexArray); const oe = c.lineVertexArray, he = h ? c.text.placedSymbolArray : c.icon.placedSymbolArray, _e = s.transform.width / s.transform.height; let pe, Me = !1; for (let xe = 0; xe < he.length; xe++) { const we = he.get(xe), { numGlyphs: ve, writingMode: Ae } = we; if (Ae !== i.bq.vertical || Me || pe === i.bq.horizontal || (Me = !0), pe = Ae, (we.hidden || Ae === i.bq.vertical) && !Me) { fa(ve, ee); continue; } Me = !1; const Oe = new i.P(we.tileAnchorX, we.tileAnchorY); let { x: Xe, y: He, z: ke } = N.projection.projectTilePoint(Oe.x, Oe.y, F.canonical); if (R) { const [nt, Lt, bt] = R(Oe); Xe += nt, He += Lt, ke += bt; } const Ne = [Xe, He, ke, 1]; if (i.ab.vec4.transformMat4(Ne, Ne, t), !ua(Ne, te)) { fa(ve, ee); continue; } const st = Ne[3], ut = Bc(s.transform.getCameraToCenterDistance(N.projection), st), xt = i.br(G, Z, we), Ge = T ? xt / ut : xt * ut, lt = un(Xe, He, ke, _); if (lt[3] <= 0) { fa(ve, ee); continue; } let Je = {}; const _t = T ? null : R, ct = dl(we, Ge, !1, z, t, _, y, c.glyphOffsetArray, oe, ee, se, lt, Oe, Je, _e, _t, N.projection, F, T); Me = ct.useVertical, _t && ct.needsFlipping && (Je = {}), (ct.notEnoughRoom || Me || ct.needsFlipping && dl(we, Ge, !0, z, t, _, y, c.glyphOffsetArray, oe, ee, se, lt, Oe, Je, _e, _t, N.projection, F, T).notEnoughRoom) && fa(ve, ee); } h ? (c.text.dynamicLayoutVertexBuffer.updateData(ee), se && c.text.globeExtVertexBuffer && c.text.globeExtVertexBuffer.updateData(se)) : (c.icon.dynamicLayoutVertexBuffer.updateData(ee), se && c.icon.globeExtVertexBuffer && c.icon.globeExtVertexBuffer.updateData(se)); } function da(c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee) { const { lineStartIndex: se, glyphStartIndex: oe, segment: he } = z, _e = oe + z.numGlyphs, pe = se + z.lineLength, Me = t.getoffsetX(oe), xe = t.getoffsetX(_e - 1), we = ss(c * Me, s, h, _, y, T, he, se, pe, R, F, N, G, Z, !0, W, te, ee); if (!we) return null; const ve = ss(c * xe, s, h, _, y, T, he, se, pe, R, F, N, G, Z, !0, W, te, ee); return ve ? { first: we, last: ve } : null; } function nn(c, t, s, h) { return c === i.bq.horizontal && Math.abs(h) > Math.abs(s) ? { useVertical: !0 } : c === i.bq.vertical ? h > 0 ? { needsFlipping: !0 } : null : t !== Pi.unknown && function(_, y) { return _ === 0 || Math.abs(y / _) > _s; }(s, h) ? t === Pi.flipRequired ? { needsFlipping: !0 } : null : s < 0 ? { needsFlipping: !0 } : null; } function dl(c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe, he) { const _e = t / 24, pe = c.lineOffsetX * _e, Me = c.lineOffsetY * _e, { lineStartIndex: xe, glyphStartIndex: we, numGlyphs: ve, segment: Ae, writingMode: Oe, flipState: Xe } = c, He = xe + c.lineLength, ke = (Ne) => { if (N) { const [Ge, lt, Je] = Ne.up, _t = F.length; i.bs(N, _t + 0, Ge, lt, Je), i.bs(N, _t + 1, Ge, lt, Je), i.bs(N, _t + 2, Ge, lt, Je), i.bs(N, _t + 3, Ge, lt, Je); } const [st, ut, xt] = Ne.point; i.bt(F, st, ut, xt, Ne.angle); }; if (ve > 1) { const Ne = da(_e, z, pe, Me, s, G, Z, c, R, y, W, ee, !1, se, oe, he); if (!Ne) return { notEnoughRoom: !0 }; if (h && !s) { let [st, ut, xt] = Ne.first.point, [Ge, lt, Je] = Ne.last.point; [st, ut] = un(st, ut, xt, T), [Ge, lt] = un(Ge, lt, Je, T); const _t = nn(Oe, Xe, (Ge - st) * te, lt - ut); if (c.flipState = _t && _t.needsFlipping ? Pi.flipRequired : Pi.flipNotRequired, _t) return _t; } ke(Ne.first); for (let st = we + 1; st < we + ve - 1; st++) { const ut = ss(_e * z.getoffsetX(st), pe, Me, s, G, Z, Ae, xe, He, R, y, W, ee, !1, !1, se, oe, he); if (!ut) return F.length -= 4 * (st - we), { notEnoughRoom: !0 }; ke(ut); } ke(Ne.last); } else { if (h && !s) { const st = un(Z.x, Z.y, 0, _), ut = xe + Ae + 1, xt = new i.P(R.getx(ut), R.gety(ut)), Ge = un(xt.x, xt.y, 0, _), lt = Ge[3] > 0 ? Ge : rr(Z, xt, st, 1, _, void 0, se, oe.canonical), Je = nn(Oe, Xe, (lt[0] - st[0]) * te, lt[1] - st[1]); if (c.flipState = Je && Je.needsFlipping ? Pi.flipRequired : Pi.flipNotRequired, Je) return Je; } const Ne = ss(_e * z.getoffsetX(we), pe, Me, s, G, Z, Ae, xe, He, R, y, W, ee, !1, !1, se, oe, he); if (!Ne) return { notEnoughRoom: !0 }; ke(Ne); } return {}; } function Dn(c, t, s, h, _) { const { x: y, y: T, z } = h.projectTilePoint(c.x, c.y, t); if (!_) return un(y, T, z, s); const [R, F, N] = _(c); return un(y + R, T + F, z + N, s); } function rr(c, t, s, h, _, y, T, z) { const R = Dn(c.sub(t)._unit()._add(c), z, _, T, y); return i.ab.vec3.sub(R, s, R), i.ab.vec3.normalize(R, R), i.ab.vec3.scaleAndAdd(R, s, R, h); } function ss(c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe) { const he = h ? c - t : c + t; let _e = he > 0 ? 1 : -1, pe = 0; h && (_e *= -1, pe = Math.PI), _e < 0 && (pe += Math.PI); let Me = z + T + (_e > 0 ? 0 : 1) | 0, xe = _, we = _, ve = 0, Ae = 0; const Oe = Math.abs(he), Xe = [], He = []; let ke = y, Ne = ke; const st = () => rr(Ne, ke, we, Oe - ve + 1, N, Z, ee, se.canonical); for (; ve + Ae <= Oe; ) { if (Me += _e, Me < z || Me >= R) return null; if (we = xe, Ne = ke, Xe.push(we), W && He.push(Ne), ke = new i.P(F.getx(Me), F.gety(Me)), xe = G[Me], !xe) { const Lt = Dn(ke, se.canonical, N, ee, Z); xe = Lt[3] > 0 ? G[Me] = Lt : st(); } ve += Ae, Ae = i.ab.vec3.distance(we, xe); } te && Z && (G[Me] && (xe = st(), Ae = i.ab.vec3.distance(we, xe)), G[Me] = xe); const ut = (Oe - ve) / Ae, xt = ke.sub(Ne)._mult(ut)._add(Ne), Ge = i.ab.vec3.sub([], xe, we), lt = i.ab.vec3.scaleAndAdd([], we, Ge, ut); let Je = [0, 0, 1], _t = Ge[0], ct = Ge[1]; if (oe && (Je = ee.upVector(se.canonical, xt.x, xt.y), Je[0] !== 0 || Je[1] !== 0 || Je[2] !== 1)) { const Lt = [Je[2], 0, -Je[0]], bt = i.ab.vec3.cross([], Je, Lt); i.ab.vec3.normalize(Lt, Lt), i.ab.vec3.normalize(bt, bt), _t = i.ab.vec3.dot(Ge, Lt), ct = i.ab.vec3.dot(Ge, bt); } if (s) { const Lt = i.ab.vec3.cross([], Je, Ge); i.ab.vec3.normalize(Lt, Lt), i.ab.vec3.scaleAndAdd(lt, lt, Lt, s * _e); } const nt = pe + Math.atan2(ct, _t); return Xe.push(lt), W && He.push(xt), { point: lt, angle: nt, path: Xe, tilePath: He, up: Je }; } function fa(c, t) { const s = t.length, h = s + 4 * c; t.resize(h), t.float32.fill(-1 / 0, 4 * s, 4 * h); } function wo(c, t, s) { const h = t[0], _ = t[1]; return c[0] = s[0] * h + s[4] * _ + s[12], c[1] = s[1] * h + s[5] * _ + s[13], c[3] = s[3] * h + s[7] * _ + s[15], c; } const vn = 100; class Ir { constructor(t, s, h = new bo(t.width + 200, t.height + 200, 25), _ = new bo(t.width + 200, t.height + 200, 25)) { this.transform = t, this.grid = h, this.ignoredGrid = _, this.pitchfactor = Math.cos(t._pitch) * t.cameraToCenterDistance, this.screenRightBoundary = t.width + vn, this.screenBottomBoundary = t.height + vn, this.gridRightBoundary = t.width + 200, this.gridBottomBoundary = t.height + 200, this.fogState = s; } placeCollisionBox(t, s, h, _, y, T, z, R) { let F = h.projectedAnchorX, N = h.projectedAnchorY, G = h.projectedAnchorZ; const Z = h.elevation, W = h.tileID, te = t.getProjection(); if (Z && W) { const [xe, we, ve] = te.upVector(W.canonical, h.tileAnchorX, h.tileAnchorY), Ae = te.upVectorScale(W.canonical, this.transform.center.lat, this.transform.worldSize).metersToTile; F += xe * Z * Ae, N += we * Z * Ae, G += ve * Z * Ae; } const ee = this.projectAndGetPerspectiveRatio(z, F, N, G, h.tileID, te.name === "globe" || !!Z || this.transform.pitch > 0, te), se = T * ee.perspectiveRatio, oe = (h.x1 * s + _.x - h.padding) * se + ee.point.x, he = (h.y1 * s + _.y - h.padding) * se + ee.point.y, _e = (h.x2 * s + _.x + h.padding) * se + ee.point.x, pe = (h.y2 * s + _.y + h.padding) * se + ee.point.y, Me = ee.perspectiveRatio <= 0.55 || ee.occluded; return !this.isInsideGrid(oe, he, _e, pe) || !y && this.grid.hitTest(oe, he, _e, pe, R) || Me ? { box: [], offscreen: !1, occluded: ee.occluded } : { box: [oe, he, _e, pe], offscreen: this.isOffscreen(oe, he, _e, pe), occluded: !1 }; } placeCollisionCircles(t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee) { const se = [], oe = this.transform.elevation, he = t.getProjection(), _e = oe ? oe.getAtTileOffsetFunc(ee, this.transform.center.lat, this.transform.worldSize, he) : null, pe = new i.P(h.tileAnchorX, h.tileAnchorY); let { x: Me, y: xe, z: we } = he.projectTilePoint(pe.x, pe.y, ee.canonical); if (_e) { const [xt, Ge, lt] = _e(pe); Me += xt, xe += Ge, we += lt; } const ve = he.name === "globe", Ae = this.projectAndGetPerspectiveRatio(z, Me, xe, we, ee, ve || !!oe || this.transform.pitch > 0, he), { perspectiveRatio: Oe } = Ae, Xe = (G ? T / Oe : T * Oe) / i.bw, He = un(Me, xe, we, R), ke = Ae.signedDistanceFromCamera > 0 ? da(Xe, y, h.lineOffsetX * Xe, h.lineOffsetY * Xe, !1, He, pe, h, _, R, {}, oe && !G ? _e : null, G && !!oe, he, ee, G) : null; let Ne = !1, st = !1, ut = !0; if (ke && !Ae.occluded) { const xt = 0.5 * W * Oe + te, Ge = new i.P(-100, -100), lt = new i.P(this.screenRightBoundary, this.screenBottomBoundary), Je = new ms(), { first: _t, last: ct } = ke, nt = _t.path.length; let Lt = []; for (let Bt = nt - 1; Bt >= 1; Bt--) Lt.push(_t.path[Bt]); for (let Bt = 1; Bt < ct.path.length; Bt++) Lt.push(ct.path[Bt]); const bt = 2.5 * xt; F && (Lt = Lt.map(([Bt, oi, $t], Xt) => (_e && !ve && ($t = _e(Xt < nt - 1 ? _t.tilePath[nt - 1 - Xt] : ct.tilePath[Xt - nt + 2])[2]), un(Bt, oi, $t, F))), Lt.some((Bt) => Bt[3] <= 0) && (Lt = [])); let zt = []; if (Lt.length > 0) { let Bt = 1 / 0, oi = -1 / 0, $t = 1 / 0, Xt = -1 / 0; for (const ai of Lt) Bt = Math.min(Bt, ai[0]), $t = Math.min($t, ai[1]), oi = Math.max(oi, ai[0]), Xt = Math.max(Xt, ai[1]); oi >= Ge.x && Bt <= lt.x && Xt >= Ge.y && $t <= lt.y && (zt = [Lt.map((ai) => new i.P(ai[0], ai[1]))], (Bt < Ge.x || oi > lt.x || $t < Ge.y || Xt > lt.y) && (zt = i.bu(zt, Ge.x, Ge.y, lt.x, lt.y))); } for (const Bt of zt) { Je.reset(Bt, 0.25 * xt); let oi = 0; oi = Je.length <= 0.5 * xt ? 1 : Math.ceil(Je.paddedLength / bt) + 1; for (let $t = 0; $t < oi; $t++) { const Xt = $t / Math.max(oi - 1, 1), ai = Je.lerp(Xt), zi = ai.x + vn, wi = ai.y + vn; se.push(zi, wi, xt, 0); const mn = zi - xt, Mn = wi - xt, Xi = zi + xt, sn = wi + xt; if (ut = ut && this.isOffscreen(mn, Mn, Xi, sn), st = st || this.isInsideGrid(mn, Mn, Xi, sn), !s && this.grid.hitTestCircle(zi, wi, xt, Z) && (Ne = !0, !N)) return { circles: [], offscreen: !1, collisionDetected: Ne, occluded: !1 }; } } } return { circles: !N && Ne || !st ? [] : se, offscreen: ut, collisionDetected: Ne, occluded: Ae.occluded }; } queryRenderedSymbols(t) { if (t.length === 0 || this.grid.keysLength() === 0 && this.ignoredGrid.keysLength() === 0) return {}; const s = []; let h = 1 / 0, _ = 1 / 0, y = -1 / 0, T = -1 / 0; for (const N of t) { const G = new i.P(N.x + vn, N.y + vn); h = Math.min(h, G.x), _ = Math.min(_, G.y), y = Math.max(y, G.x), T = Math.max(T, G.y), s.push(G); } const z = this.grid.query(h, _, y, T).concat(this.ignoredGrid.query(h, _, y, T)), R = {}, F = {}; for (const N of z) { const G = N.key; if (R[G.bucketInstanceId] === void 0 && (R[G.bucketInstanceId] = {}), R[G.bucketInstanceId][G.featureIndex]) continue; const Z = [new i.P(N.x1, N.y1), new i.P(N.x2, N.y1), new i.P(N.x2, N.y2), new i.P(N.x1, N.y2)]; i.bv(s, Z) && (R[G.bucketInstanceId][G.featureIndex] = !0, F[G.bucketInstanceId] === void 0 && (F[G.bucketInstanceId] = []), F[G.bucketInstanceId].push(G.featureIndex)); } return F; } insertCollisionBox(t, s, h, _, y) { (s ? this.ignoredGrid : this.grid).insert({ bucketInstanceId: h, featureIndex: _, collisionGroupID: y }, t[0], t[1], t[2], t[3]); } insertCollisionCircles(t, s, h, _, y) { const T = s ? this.ignoredGrid : this.grid, z = { bucketInstanceId: h, featureIndex: _, collisionGroupID: y }; for (let R = 0; R < t.length; R += 4) T.insertCircle(z, t[R], t[R + 1], t[R + 2]); } projectAndGetPerspectiveRatio(t, s, h, _, y, T, z) { const R = [s, h, _, 1]; let F = !1; _ || this.transform.pitch > 0 ? (i.ab.vec4.transformMat4(R, R, t), this.fogState && y && z.name !== "globe" && (F = function(Z, W, te, ee, se, oe) { const he = oe.calculateFogTileMatrix(se), _e = [W, te, ee]; return i.ab.vec3.transformMat4(_e, _e, he), Kt(Z, i.ab.vec3.length(_e), oe.pitch, oe._fov); }(this.fogState, s, h, _, y.toUnwrapped(), this.transform) > 0.9)) : wo(R, R, t); const N = R[3]; return { point: new i.P((R[0] / N + 1) / 2 * this.transform.width + vn, (-R[1] / N + 1) / 2 * this.transform.height + vn), perspectiveRatio: Math.min(0.5 + this.transform.getCameraToCenterDistance(z) / N * 0.5, 1.5), signedDistanceFromCamera: N, occluded: T && R[2] > N || F }; } isOffscreen(t, s, h, _) { return h < vn || t >= this.screenRightBoundary || _ < vn || s > this.screenBottomBoundary; } isInsideGrid(t, s, h, _) { return h >= 0 && t < this.gridRightBoundary && _ >= 0 && s < this.gridBottomBoundary; } getViewportMatrix() { const t = i.ab.mat4.identity([]); return i.ab.mat4.translate(t, t, [-100, -100, 0]), t; } } function Lr(c, t, s) { const h = t.createTileMatrix(c, c.worldSize, s.toUnwrapped()); return i.ab.mat4.multiply(new Float32Array(16), c.projMatrix, h); } function qn(c, t, s) { if (t.projection.name === s.projection.name) return c.projMatrix; const h = s.clone(); return h.setProjection(t.projection), Lr(h, t.getProjection(), c); } function pa(c, t, s) { return t.name === s.projection.name ? c.projMatrix : Lr(s, t, c); } class zr { constructor(t, s, h, _) { this.opacity = t ? Math.max(0, Math.min(1, t.opacity + (t.placed ? s : -s))) : _ && h ? 1 : 0, this.placed = h; } isHidden() { return this.opacity === 0 && !this.placed; } } class Es { constructor(t, s, h, _, y, T = !1) { this.text = new zr(t ? t.text : null, s, h, y), this.icon = new zr(t ? t.icon : null, s, _, y), this.clipped = T; } isHidden() { return this.text.isHidden() && this.icon.isHidden(); } } class Oa { constructor(t, s, h, _ = !1) { this.text = t, this.icon = s, this.skipFade = h, this.clipped = _; } } class qo { constructor() { this.invProjMatrix = i.ab.mat4.create(), this.viewportMatrix = i.ab.mat4.create(), this.circles = []; } } class Wo { constructor(t, s, h, _, y) { this.bucketInstanceId = t, this.featureIndex = s, this.sourceLayerIndex = h, this.bucketIndex = _, this.tileID = y; } } class so { constructor(t) { this.crossSourceCollisions = t, this.maxGroupID = 0, this.collisionGroups = {}; } get(t) { if (this.crossSourceCollisions) return { ID: 0, predicate: null }; if (!this.collisionGroups[t]) { const s = ++this.maxGroupID; this.collisionGroups[t] = { ID: s, predicate: (h) => h.collisionGroupID === s }; } return this.collisionGroups[t]; } } function Nc(c, t, s, h, _) { const { horizontalAlign: y, verticalAlign: T } = i.bD(c), z = -(y - 0.5) * t, R = -(T - 0.5) * s, F = i.bC(c, h); return new i.P(z + F[0] * _, R + F[1] * _); } function Fa(c, t, s, h, _) { const y = new i.P(c, t); return s && y._rotate(h ? _ : -_), y; } class or { constructor(t, s, h, _, y, T) { this.transform = t.clone(), this.projection = t.projection.name, this.collisionIndex = new Ir(this.transform, y), this.buildingIndex = T, this.placements = {}, this.opacities = {}, this.variableOffsets = {}, this.stale = !1, this.commitTime = 0, this.fadeDuration = s, this.retainedQueryData = {}, this.collisionGroups = new so(h), this.collisionCircleArrays = {}, this.prevPlacement = _, _ && (_.prevPlacement = void 0), this.placedOrientations = {}; } getBucketParts(t, s, h, _, y = 1) { const T = h.getBucket(s), z = h.latestFeatureIndex; if (!T || !z || s.fqid !== T.layerIds[0]) return; const R = T.layers[0].layout, F = T.layers[0].paint, N = h.collisionBoxArray, G = Math.pow(2, this.transform.zoom - h.tileID.overscaledZ), Z = h.tileSize / i.ag, W = h.tileID.toUnwrapped(); this.transform.setProjection(T.projection); const te = (ee = h.tileID, se = T.getProjection(), oe = this.transform, se.name === this.projection ? oe.calculateProjMatrix(ee.toUnwrapped()) : Lr(oe, se, ee)); var ee, se, oe; const he = R.get("text-pitch-alignment") === "map", _e = R.get("text-rotation-alignment") === "map"; s.compileFilter(s.options); const pe = s.dynamicFilter(), Me = s.dynamicFilterNeedsFeature(), xe = this.transform.calculatePixelsToTileUnitsMatrix(h), we = Ho(te, h.tileID.canonical, he, _e, this.transform, T.getProjection(), xe); let ve = null; if (he) { const xt = Ss(te, h.tileID.canonical, he, _e, this.transform, T.getProjection(), xe); ve = i.ab.mat4.multiply([], this.transform.labelPlaneMatrix, xt); } let Ae = null; pe && h.latestFeatureIndex && (Ae = { unwrappedTileID: W, dynamicFilter: pe, dynamicFilterNeedsFeature: Me }), this.retainedQueryData[T.bucketInstanceId] = new Wo(T.bucketInstanceId, z, T.sourceLayerIndex, T.index, h.tileID); const [Oe, Xe] = T.layers[0].layout.get("text-size-scale-range"), He = i.aw(y, Oe, Xe), [ke, Ne] = R.get("icon-size-scale-range"), st = i.aw(y, ke, Ne), ut = { bucket: T, layout: R, paint: F, posMatrix: te, textLabelPlaneMatrix: we, labelToScreenMatrix: ve, clippingData: Ae, scale: G, textPixelRatio: Z, holdingForFade: h.holdingForFade(), collisionBoxArray: N, partiallyEvaluatedTextSize: i.bp(T.textSizeData, this.transform.zoom, He), partiallyEvaluatedIconSize: i.bp(T.iconSizeData, this.transform.zoom, st), collisionGroup: this.collisionGroups.get(T.sourceID), latestFeatureIndex: h.latestFeatureIndex }; if (_) for (const xt of T.sortKeyRanges) { const { sortKey: Ge, symbolInstanceStart: lt, symbolInstanceEnd: Je } = xt; t.push({ sortKey: Ge, symbolInstanceStart: lt, symbolInstanceEnd: Je, parameters: ut }); } else t.push({ symbolInstanceStart: 0, symbolInstanceEnd: T.symbolInstances.length, parameters: ut }); } attemptAnchorPlacement(t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe, he) { const { textOffset0: _e, textOffset1: pe, crossTileID: Me } = Z, xe = [_e, pe], we = Nc(t, h, _, xe, y), ve = this.collisionIndex.placeCollisionBox(te, y, s, Fa(we.x, we.y, T, z, this.transform.angle), G, R, F, N.predicate); if (se) { const Ae = te.getSymbolInstanceIconSize(he, this.transform.zoom, Z.placedIconSymbolIndex); if (this.collisionIndex.placeCollisionBox(te, Ae, se, Fa(we.x, we.y, T, z, this.transform.angle), G, R, F, N.predicate).box.length === 0) return; } if (ve.box.length > 0) { let Ae; return this.prevPlacement && this.prevPlacement.variableOffsets[Me] && this.prevPlacement.placements[Me] && this.prevPlacement.placements[Me].text && (Ae = this.prevPlacement.variableOffsets[Me].anchor), this.variableOffsets[Me] = { textOffset: xe, width: h, height: _, anchor: t, textScale: y, prevAnchor: Ae }, this.markUsedJustification(te, t, Z, ee), te.allowVerticalPlacement && (this.markUsedOrientation(te, ee, Z), this.placedOrientations[Me] = ee), { shift: we, placedGlyphBoxes: ve }; } } placeLayerBucketPart(t, s, h, _, y = 1) { const { bucket: T, layout: z, paint: R, posMatrix: F, textLabelPlaneMatrix: N, labelToScreenMatrix: G, clippingData: Z, textPixelRatio: W, holdingForFade: te, collisionBoxArray: ee, partiallyEvaluatedTextSize: se, partiallyEvaluatedIconSize: oe, collisionGroup: he, latestFeatureIndex: _e } = t.parameters, pe = z.get("text-optional"), Me = z.get("icon-optional"), xe = z.get("text-allow-overlap"), we = z.get("icon-allow-overlap"), ve = z.get("text-rotation-alignment") === "map", Ae = z.get("text-pitch-alignment") === "map", Oe = z.get("symbol-z-elevate"), Xe = R.get("symbol-z-offset"), He = z.get("symbol-elevation-reference") === "sea", [ke, Ne] = z.get("text-size-scale-range"), [st, ut] = z.get("icon-size-scale-range"), xt = i.aw(y, ke, Ne), Ge = i.aw(y, st, ut); this.transform.setProjection(T.projection); let lt = xe && (we || !T.hasIconData() || Me), Je = we && (xe || !T.hasTextData() || pe); const _t = !Xe.isConstant(); !T.collisionArrays && ee && T.deserializeCollisionBoxes(ee), h && _ && T.updateCollisionDebugBuffers(this.transform.zoom, ee, xt, Ge); const ct = (nt, Lt, bt) => { const { crossTileID: zt, numVerticalGlyphVertices: Bt } = nt; let oi = null; if (Z && Z.dynamicFilterNeedsFeature || _t) { const dn = this.retainedQueryData[T.bucketInstanceId]; oi = _e.loadFeature({ featureIndex: nt.featureIndex, bucketIndex: dn.bucketIndex, sourceLayerIndex: dn.sourceLayerIndex, layoutVertexArrayOffset: 0 }); } if (Z && !(0, Z.dynamicFilter)({ zoom: this.transform.zoom, pitch: this.transform.pitch }, oi, this.retainedQueryData[T.bucketInstanceId].tileID.canonical, new i.P(nt.tileAnchorX, nt.tileAnchorY), this.transform.calculateDistanceTileData(Z.unwrappedTileID))) return this.placements[zt] = new Oa(!1, !1, !1, !0), void s.add(zt); const $t = Xe.evaluate(oi, {}); if (s.has(zt)) return; if (te) return void (this.placements[zt] = new Oa(!1, !1, !1)); let Xt = !1, ai = !1, zi = !0, wi = !1, mn = !1, Mn = null, Xi = { box: null, offscreen: null, occluded: null }, sn = { box: null, offscreen: null, occluded: null }, _i = null, Jt = null, ji = null, Yi = 0, In = 0, Fs = 0; bt.textFeatureIndex ? Yi = bt.textFeatureIndex : nt.useRuntimeCollisionCircles && (Yi = nt.featureIndex), bt.verticalTextFeatureIndex && (In = bt.verticalTextFeatureIndex); const pr = (dn) => { dn.tileID = this.retainedQueryData[T.bucketInstanceId].tileID; const _n = this.transform.elevation; dn.elevation = He ? $t : $t + (_n ? _n.getAtTileOffset(dn.tileID, dn.tileAnchorX, dn.tileAnchorY) : 0), dn.elevation += nt.zOffset; }, ts = bt.textBox; if (ts) { pr(ts); const dn = (Ri) => { let Gn = i.bq.horizontal; if (T.allowVerticalPlacement && !Ri && this.prevPlacement) { const Bs = this.prevPlacement.placedOrientations[zt]; Bs && (this.placedOrientations[zt] = Bs, Gn = Bs, this.markUsedOrientation(T, Gn, nt)); } return Gn; }, _n = (Ri, Gn) => { if (T.allowVerticalPlacement && Bt > 0 && bt.verticalTextBox) { for (const Bs of T.writingModes) if (Bs === i.bq.vertical ? (Xi = Gn(), sn = Xi) : Xi = Ri(), Xi && Xi.box && Xi.box.length) break; } else Xi = Ri(); }; if (z.get("text-variable-anchor")) { let Ri = z.get("text-variable-anchor"); if (this.prevPlacement && this.prevPlacement.variableOffsets[zt]) { const cn = this.prevPlacement.variableOffsets[zt]; Ri.indexOf(cn.anchor) > 0 && (Ri = Ri.filter((er) => er !== cn.anchor), Ri.unshift(cn.anchor)); } const Gn = (cn, er, eo) => { const Br = T.getSymbolInstanceTextSize(se, nt, this.transform.zoom, Lt), Ma = (cn.x2 - cn.x1) * Br + 2 * cn.padding, mr = (cn.y2 - cn.y1) * Br + 2 * cn.padding, ko = nt.hasIconTextFit && !we ? er : null; ko && pr(ko); let Nr = { box: [], offscreen: !1, occluded: !1 }; const il = xe ? 2 * Ri.length : Ri.length; for (let ia = 0; ia < il; ++ia) { const Ll = this.attemptAnchorPlacement(Ri[ia % Ri.length], cn, Ma, mr, Br, ve, Ae, W, F, he, ia >= Ri.length, nt, Lt, T, eo, ko, se, oe); if (Ll && (Nr = Ll.placedGlyphBoxes, Nr && Nr.box && Nr.box.length)) { Xt = !0, Mn = Ll.shift; break; } } return Nr; }; _n(() => Gn(ts, bt.iconBox, i.bq.horizontal), () => { const cn = bt.verticalTextBox; return cn && pr(cn), T.allowVerticalPlacement && !(Xi && Xi.box && Xi.box.length) && Bt > 0 && cn ? Gn(cn, bt.verticalIconBox, i.bq.vertical) : { box: null, offscreen: null, occluded: null }; }), Xi && (Xt = Xi.box, zi = Xi.offscreen, wi = Xi.occluded); const Bs = dn(!(!Xi || !Xi.box)); if (!Xt && this.prevPlacement) { const cn = this.prevPlacement.variableOffsets[zt]; cn && (this.variableOffsets[zt] = cn, this.markUsedJustification(T, cn.anchor, nt, Bs)); } } else { const Ri = (Gn, Bs) => { const cn = T.getSymbolInstanceTextSize(se, nt, this.transform.zoom, Lt, y), er = this.collisionIndex.placeCollisionBox(T, cn, Gn, new i.P(0, 0), xe, W, F, he.predicate); return er && er.box && er.box.length && (this.markUsedOrientation(T, Bs, nt), this.placedOrientations[zt] = Bs), er; }; _n(() => Ri(ts, i.bq.horizontal), () => { const Gn = bt.verticalTextBox; return T.allowVerticalPlacement && Bt > 0 && Gn ? (pr(Gn), Ri(Gn, i.bq.vertical)) : { box: null, offscreen: null, occluded: null }; }), dn(!!(Xi && Xi.box && Xi.box.length)); } } if (_i = Xi, Xt = _i && _i.box && _i.box.length > 0, zi = _i && _i.offscreen, wi = _i && _i.occluded, nt.useRuntimeCollisionCircles) { const dn = T.text.placedSymbolArray.get(nt.centerJustifiedTextSymbolIndex >= 0 ? nt.centerJustifiedTextSymbolIndex : nt.verticalPlacedTextSymbolIndex), _n = i.br(T.textSizeData, se, dn), Ri = z.get("text-padding"); Jt = this.collisionIndex.placeCollisionCircles(T, xe, dn, T.lineVertexArray, T.glyphOffsetArray, _n, F, N, G, h, Ae, he.predicate, nt.collisionCircleDiameter * _n / i.bw, Ri, this.retainedQueryData[T.bucketInstanceId].tileID), Xt = xe || Jt.circles.length > 0 && !Jt.collisionDetected, zi = zi && Jt.offscreen, wi = Jt.occluded; } if (bt.iconFeatureIndex && (Fs = bt.iconFeatureIndex), bt.iconBox) { const dn = (_n) => { pr(_n); const Ri = nt.hasIconTextFit && Mn ? Fa(Mn.x, Mn.y, ve, Ae, this.transform.angle) : new i.P(0, 0), Gn = T.getSymbolInstanceIconSize(oe, this.transform.zoom, nt.placedIconSymbolIndex); return this.collisionIndex.placeCollisionBox(T, Gn, _n, Ri, we, W, F, he.predicate); }; sn && sn.box && sn.box.length && bt.verticalIconBox ? (ji = dn(bt.verticalIconBox), ai = ji.box.length > 0) : (ji = dn(bt.iconBox), ai = ji.box.length > 0), zi = zi && ji.offscreen, mn = ji.occluded; } const Ps = pe || nt.numHorizontalGlyphVertices === 0 && Bt === 0, Qs = Me || nt.numIconVertices === 0; if (Ps || Qs ? Qs ? Ps || (ai = ai && Xt) : Xt = ai && Xt : ai = Xt = ai && Xt, Xt && _i && _i.box && this.collisionIndex.insertCollisionBox(_i.box, z.get("text-ignore-placement"), T.bucketInstanceId, sn && sn.box && In ? In : Yi, he.ID), ai && ji && this.collisionIndex.insertCollisionBox(ji.box, z.get("icon-ignore-placement"), T.bucketInstanceId, Fs, he.ID), Jt && (Xt && this.collisionIndex.insertCollisionCircles(Jt.circles, z.get("text-ignore-placement"), T.bucketInstanceId, Yi, he.ID), h)) { const dn = T.bucketInstanceId; let _n = this.collisionCircleArrays[dn]; _n === void 0 && (_n = this.collisionCircleArrays[dn] = new qo()); for (let Ri = 0; Ri < Jt.circles.length; Ri += 4) _n.circles.push(Jt.circles[Ri + 0]), _n.circles.push(Jt.circles[Ri + 1]), _n.circles.push(Jt.circles[Ri + 2]), _n.circles.push(Jt.collisionDetected ? 1 : 0); } const jn = T.projection.name !== "globe"; lt = lt && (jn || !wi), Je = Je && (jn || !mn), this.placements[zt] = new Oa(Xt || lt, ai || Je, zi || T.justReloaded), s.add(zt); }; if (Oe && this.buildingIndex && (this.buildingIndex.updateZOffset(T, this.retainedQueryData[T.bucketInstanceId].tileID), T.updateZOffset()), T.sortFeaturesByY) { const nt = T.getSortedSymbolIndexes(this.transform.angle); for (let Lt = nt.length - 1; Lt >= 0; --Lt) { const bt = nt[Lt]; ct(T.symbolInstances.get(bt), bt, T.collisionArrays[bt]); } T.hasAnyZOffset && i.w(`${T.layerIds[0]} layer symbol-z-elevate: symbols are not sorted by elevation if symbol-z-order is evaluated to viewport-y`); } else if (T.hasAnyZOffset) { const nt = T.getSortedIndexesByZOffset(); for (let Lt = 0; Lt < nt.length; ++Lt) { const bt = nt[Lt]; ct(T.symbolInstances.get(bt), bt, T.collisionArrays[bt]); } } else for (let nt = t.symbolInstanceStart; nt < t.symbolInstanceEnd; nt++) ct(T.symbolInstances.get(nt), nt, T.collisionArrays[nt]); if (h && T.bucketInstanceId in this.collisionCircleArrays) { const nt = this.collisionCircleArrays[T.bucketInstanceId]; i.ab.mat4.invert(nt.invProjMatrix, F), nt.viewportMatrix = this.collisionIndex.getViewportMatrix(); } T.justReloaded = !1; } markUsedJustification(t, s, h, _) { const { leftJustifiedTextSymbolIndex: y, centerJustifiedTextSymbolIndex: T, rightJustifiedTextSymbolIndex: z, verticalPlacedTextSymbolIndex: R, crossTileID: F } = h, N = i.bB(s), G = _ === i.bq.vertical ? R : N === "left" ? y : N === "center" ? T : N === "right" ? z : -1; y >= 0 && (t.text.placedSymbolArray.get(y).crossTileID = G >= 0 && y !== G ? 0 : F), T >= 0 && (t.text.placedSymbolArray.get(T).crossTileID = G >= 0 && T !== G ? 0 : F), z >= 0 && (t.text.placedSymbolArray.get(z).crossTileID = G >= 0 && z !== G ? 0 : F), R >= 0 && (t.text.placedSymbolArray.get(R).crossTileID = G >= 0 && R !== G ? 0 : F); } markUsedOrientation(t, s, h) { const _ = s === i.bq.horizontal || s === i.bq.horizontalOnly ? s : 0, y = s === i.bq.vertical ? s : 0, { leftJustifiedTextSymbolIndex: T, centerJustifiedTextSymbolIndex: z, rightJustifiedTextSymbolIndex: R, verticalPlacedTextSymbolIndex: F } = h, N = t.text.placedSymbolArray; T >= 0 && (N.get(T).placedOrientation = _), z >= 0 && (N.get(z).placedOrientation = _), R >= 0 && (N.get(R).placedOrientation = _), F >= 0 && (N.get(F).placedOrientation = y); } commit(t) { this.commitTime = t, this.zoomAtLastRecencyCheck = this.transform.zoom; const s = this.prevPlacement; let h = !1; this.prevZoomAdjustment = s ? s.zoomAdjustment(this.transform.zoom) : 0; const _ = s ? s.symbolFadeChange(t) : 1, y = s ? s.opacities : {}, T = s ? s.variableOffsets : {}, z = s ? s.placedOrientations : {}; for (const R in this.placements) { const F = this.placements[R], N = y[R]; N ? (this.opacities[R] = new Es(N, _, F.text, F.icon, null, F.clipped), h = h || F.text !== N.text.placed || F.icon !== N.icon.placed) : (this.opacities[R] = new Es(null, _, F.text, F.icon, F.skipFade, F.clipped), h = h || F.text || F.icon); } for (const R in y) { const F = y[R]; if (!this.opacities[R]) { const N = new Es(F, _, !1, !1); N.isHidden() || (this.opacities[R] = N, h = h || F.text.placed || F.icon.placed); } } for (const R in T) this.variableOffsets[R] || !this.opacities[R] || this.opacities[R].isHidden() || (this.variableOffsets[R] = T[R]); for (const R in z) this.placedOrientations[R] || !this.opacities[R] || this.opacities[R].isHidden() || (this.placedOrientations[R] = z[R]); h ? this.lastPlacementChangeTime = t : typeof this.lastPlacementChangeTime != "number" && (this.lastPlacementChangeTime = s ? s.lastPlacementChangeTime : t); } updateLayerOpacities(t, s, h, _) { const y = /* @__PURE__ */ new Set(); for (const T of s) { const z = T.getBucket(t); z && T.latestFeatureIndex && t.fqid === z.layerIds[0] && (this.updateBucketOpacities(z, y, T, T.collisionBoxArray, h, _, T.tileID, t.scope), z.layers[0].layout.get("symbol-z-elevate") && this.buildingIndex && (this.buildingIndex.updateZOffset(z, T.tileID), z.updateZOffset())); } } updateBucketOpacities(t, s, h, _, y, T, z, R) { 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 F = t.layers[0].layout, N = t.layers[0].paint, G = !!t.layers[0].dynamicFilter(), Z = new Es(null, 0, !1, !1, !0), W = F.get("text-allow-overlap"), te = F.get("icon-allow-overlap"), ee = F.get("text-variable-anchor"), se = F.get("text-rotation-alignment") === "map", oe = F.get("text-pitch-alignment") === "map", he = N.get("symbol-z-offset"), _e = F.get("symbol-elevation-reference") === "sea", pe = !he.isConstant(), Me = new Es(null, 0, W && (te || !t.hasIconData() || F.get("icon-optional")), te && (W || !t.hasTextData() || F.get("text-optional")), !0); !t.collisionArrays && _ && (t.hasIconCollisionBoxData() || t.hasTextCollisionBoxData()) && t.deserializeCollisionBoxes(_); const xe = (ve, Ae, Oe) => { for (let Xe = 0; Xe < Ae / 4; Xe++) ve.opacityVertexArray.emplaceBack(Oe); }; let we = 0; T && t.updateReplacement(z, T); for (let ve = 0; ve < t.symbolInstances.length; ve++) { const Ae = t.symbolInstances.get(ve), { numHorizontalGlyphVertices: Oe, numVerticalGlyphVertices: Xe, crossTileID: He, numIconVertices: ke, tileAnchorX: Ne, tileAnchorY: st } = Ae; let ut = null; const xt = this.retainedQueryData[t.bucketInstanceId]; pe && Ae && xt && (ut = h.latestFeatureIndex.loadFeature({ featureIndex: Ae.featureIndex, bucketIndex: xt.bucketIndex, sourceLayerIndex: xt.sourceLayerIndex, layoutVertexArrayOffset: 0 })); const Ge = he.evaluate(ut, {}), lt = s.has(He); let Je = this.opacities[He]; lt ? Je = Z : Je || (Je = Me, this.opacities[He] = Je), s.add(He); const _t = Oe > 0 || Xe > 0, ct = ke > 0, nt = this.placedOrientations[He], Lt = nt === i.bq.vertical, bt = nt === i.bq.horizontal || nt === i.bq.horizontalOnly; !_t && !ct || Je.isHidden() || we++; let zt = !1; if ((_t || ct) && T) for (const Bt of t.activeReplacements) { if (i.bx(Bt, y, i.by.Symbol, R) || Bt.min.x > Ne || Ne > Bt.max.x || Bt.min.y > st || st > Bt.max.y) continue; const oi = i.bz(Ne, st, z.canonical, Bt.footprintTileId.canonical); if (zt = i.bA(oi, Bt.footprint), zt) break; } if (_t) { const Bt = zt ? Ds : _l(Je.text); xe(t.text, Oe, Lt ? Ds : Bt), xe(t.text, Xe, bt ? Ds : Bt); const oi = Je.text.isHidden(), { leftJustifiedTextSymbolIndex: $t, centerJustifiedTextSymbolIndex: Xt, rightJustifiedTextSymbolIndex: ai, verticalPlacedTextSymbolIndex: zi } = Ae, wi = t.text.placedSymbolArray, mn = oi || Lt ? 1 : 0; $t >= 0 && (wi.get($t).hidden = mn), Xt >= 0 && (wi.get(Xt).hidden = mn), ai >= 0 && (wi.get(ai).hidden = mn), zi >= 0 && (wi.get(zi).hidden = oi || bt ? 1 : 0); const Mn = this.variableOffsets[He]; Mn && this.markUsedJustification(t, Mn.anchor, Ae, nt); const Xi = this.placedOrientations[He]; Xi && (this.markUsedJustification(t, "left", Ae, Xi), this.markUsedOrientation(t, Xi, Ae)); } if (ct) { const Bt = zt ? Ds : _l(Je.icon), { placedIconSymbolIndex: oi, verticalPlacedIconSymbolIndex: $t } = Ae, Xt = t.icon.placedSymbolArray, ai = Je.icon.isHidden() ? 1 : 0; oi >= 0 && (xe(t.icon, ke, Lt ? Ds : Bt), Xt.get(oi).hidden = ai), $t >= 0 && (xe(t.icon, Ae.numVerticalIconVertices, bt ? Ds : Bt), Xt.get($t).hidden = ai); } if (t.hasIconCollisionBoxData() || t.hasTextCollisionBoxData()) { const Bt = t.collisionArrays[ve]; if (Bt) { let oi = new i.P(0, 0), $t = !0; if (Bt.textBox || Bt.verticalTextBox) { if (ee) { const ai = this.variableOffsets[He]; ai ? (oi = Nc(ai.anchor, ai.width, ai.height, ai.textOffset, ai.textScale), se && oi._rotate(oe ? this.transform.angle : -this.transform.angle)) : $t = !1; } G && ($t = !Je.clipped), Bt.textBox && fl(t.textCollisionBox.collisionVertexArray, Je.text.placed, !$t || Lt, Ge, _e, oi.x, oi.y), Bt.verticalTextBox && fl(t.textCollisionBox.collisionVertexArray, Je.text.placed, !$t || bt, Ge, _e, oi.x, oi.y); } const Xt = $t && !!(!bt && Bt.verticalIconBox); Bt.iconBox && fl(t.iconCollisionBox.collisionVertexArray, Je.icon.placed, Xt, Ge, _e, Ae.hasIconTextFit ? oi.x : 0, Ae.hasIconTextFit ? oi.y : 0), Bt.verticalIconBox && fl(t.iconCollisionBox.collisionVertexArray, Je.icon.placed, !Xt, Ge, _e, Ae.hasIconTextFit ? oi.x : 0, Ae.hasIconTextFit ? oi.y : 0); } } } if (t.fullyClipped = we === 0, 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 ve = this.collisionCircleArrays[t.bucketInstanceId]; t.placementInvProjMatrix = ve.invProjMatrix, t.placementViewportMatrix = ve.viewportMatrix, t.collisionCircleArray = ve.circles, delete this.collisionCircleArrays[t.bucketInstanceId]; } } symbolFadeChange(t) { return this.fadeDuration === 0 ? 1 : (t - this.commitTime) / this.fadeDuration + this.prevZoomAdjustment; } zoomAdjustment(t) { return Math.max(0, (this.transform.zoom - t) / 1.5); } hasTransitions(t) { return this.stale || t - this.lastPlacementChangeTime < this.fadeDuration; } stillRecent(t, s) { const h = this.zoomAtLastRecencyCheck === s ? 1 - this.zoomAdjustment(s) : 1; return this.zoomAtLastRecencyCheck = s, this.commitTime + this.fadeDuration * h > t; } setStale() { this.stale = !0; } } function fl(c, t, s, h, _, y, T) { c.emplaceBack(t ? 1 : 0, s ? 1 : 0, y || 0, T || 0, h, _ ? 1 : 0), c.emplaceBack(t ? 1 : 0, s ? 1 : 0, y || 0, T || 0, h, _ ? 1 : 0), c.emplaceBack(t ? 1 : 0, s ? 1 : 0, y || 0, T || 0, h, _ ? 1 : 0), c.emplaceBack(t ? 1 : 0, s ? 1 : 0, y || 0, T || 0, h, _ ? 1 : 0); } const pl = Math.pow(2, 25), Nh = Math.pow(2, 24), ml = Math.pow(2, 17), Vc = Math.pow(2, 16), Qu = Math.pow(2, 9), Ba = Math.pow(2, 8), Na = Math.pow(2, 1); function _l(c) { if (c.opacity === 0 && !c.placed) return 0; if (c.opacity === 1 && c.placed) return 4294967295; const t = c.placed ? 1 : 0, s = Math.floor(127 * c.opacity); return s * pl + t * Nh + s * ml + t * Vc + s * Qu + t * Ba + s * Na + t; } const Ds = 0; class Vh { constructor(t) { this._sortAcrossTiles = t.layout.get("symbol-z-order") !== "viewport-y" && t.layout.get("symbol-sort-key").constantOr(1) !== void 0, this._currentTileIndex = 0, this._currentPartIndex = 0, this._seenCrossTileIDs = /* @__PURE__ */ new Set(), this._bucketParts = []; } continuePlacement(t, s, h, _, y, T) { const z = this._bucketParts; for (; this._currentTileIndex < t.length; ) if (s.getBucketParts(z, _, t[this._currentTileIndex], this._sortAcrossTiles, T), this._currentTileIndex++, y()) return !0; for (this._sortAcrossTiles && (this._sortAcrossTiles = !1, z.sort((R, F) => R.sortKey - F.sortKey)); this._currentPartIndex < z.length; ) { const R = z[this._currentPartIndex]; if (s.placeLayerBucketPart(R, this._seenCrossTileIDs, h, R.symbolInstanceStart === 0, T), this._currentPartIndex++, y()) return !0; } return !1; } } class $o { constructor(t, s, h, _, y, T, z, R, F) { this.placement = new or(t, y, T, z, R, F), this._currentPlacementIndex = s.length - 1, this._forceFullPlacement = h, this._showCollisionBoxes = _, this._done = !1; } isDone() { return this._done; } continuePlacement(t, s, h, _, y) { const T = i.q.now(), z = () => { const R = i.q.now() - T; return !this._forceFullPlacement && R > 2; }; for (; this._currentPlacementIndex >= 0; ) { const R = s[t[this._currentPlacementIndex]], F = this.placement.collisionIndex.transform.zoom; if (R.type === "symbol" && (!R.minzoom || R.minzoom <= F) && (!R.maxzoom || R.maxzoom > F)) { const N = R, G = N.layout.get("symbol-z-elevate"), Z = N.layout.get("symbol-sort-key").constantOr(1) !== void 0, W = N.layout.get("symbol-z-order"), te = W === "viewport-y" || W === "auto" && !(W !== "viewport-y" && Z), ee = N.layout.get("text-allow-overlap") || N.layout.get("icon-allow-overlap") || N.layout.get("text-ignore-placement") || N.layout.get("icon-ignore-placement"), se = te && ee, oe = this._inProgressLayer = this._inProgressLayer || new Vh(N), he = i.aC(R.source, R.scope); if (oe.continuePlacement(G || se ? _[he] : h[he], this.placement, this._showCollisionBoxes, R, z, y)) return; delete this._inProgressLayer; } this._currentPlacementIndex--; } this._done = !0; } commit(t) { return this.placement.commit(t), this.placement; } } const rs = 512 / i.ag / 2; class Uh { constructor(t, s, h) { this.tileID = t, this.bucketInstanceId = h, this.index = new i.bE(s.length, 16, Int32Array), this.keys = [], this.crossTileIDs = []; const _ = t.canonical.x * i.ag, y = t.canonical.y * i.ag; for (let T = 0; T < s.length; T++) { const { key: z, crossTileID: R, tileAnchorX: F, tileAnchorY: N } = s.get(T), G = Math.floor((_ + F) * rs), Z = Math.floor((y + N) * rs); this.index.add(G, Z), this.keys.push(z), this.crossTileIDs.push(R); } this.index.finish(); } findMatches(t, s, h) { const _ = this.tileID.canonical.z < s.canonical.z ? 1 : Math.pow(2, this.tileID.canonical.z - s.canonical.z), y = rs / Math.pow(2, s.canonical.z - this.tileID.canonical.z), T = s.canonical.x * i.ag, z = s.canonical.y * i.ag; for (let R = 0; R < t.length; R++) { const F = t.get(R); if (F.crossTileID) continue; const { key: N, tileAnchorX: G, tileAnchorY: Z } = F, W = Math.floor((T + G) * y), te = Math.floor((z + Z) * y), ee = this.index.range(W - _, te - _, W + _, te + _); for (const se of ee) { const oe = this.crossTileIDs[se]; if (this.keys[se] === N && !h.has(oe)) { h.add(oe), F.crossTileID = oe; break; } } } } } class jh { constructor() { this.maxCrossTileID = 0; } generate() { return ++this.maxCrossTileID; } } class ed { constructor() { this.indexes = {}, this.usedCrossTileIDs = {}, this.lng = 0; } handleWrapJump(t) { const s = Math.round((t - this.lng) / 360); if (s !== 0) for (const h in this.indexes) { const _ = this.indexes[h], y = {}; for (const T in _) { const z = _[T]; z.tileID = z.tileID.unwrapTo(z.tileID.wrap + s), y[z.tileID.key] = z; } this.indexes[h] = y; } this.lng = t; } addBucket(t, s, h) { if (this.indexes[t.overscaledZ] && this.indexes[t.overscaledZ][t.key]) { if (this.indexes[t.overscaledZ][t.key].bucketInstanceId === s.bucketInstanceId) return !1; this.removeBucketCrossTileIDs(t.overscaledZ, this.indexes[t.overscaledZ][t.key]); } for (let y = 0; y < s.symbolInstances.length; y++) s.symbolInstances.get(y).crossTileID = 0; this.usedCrossTileIDs[t.overscaledZ] || (this.usedCrossTileIDs[t.overscaledZ] = /* @__PURE__ */ new Set()); const _ = this.usedCrossTileIDs[t.overscaledZ]; for (const y in this.indexes) { const T = this.indexes[y]; if (Number(y) > t.overscaledZ) for (const z in T) { const R = T[z]; R.tileID.isChildOf(t) && R.findMatches(s.symbolInstances, t, _); } else { const z = T[t.scaledTo(Number(y)).key]; z && z.findMatches(s.symbolInstances, t, _); } } for (let y = 0; y < s.symbolInstances.length; y++) { const T = s.symbolInstances.get(y); T.crossTileID || (T.crossTileID = h.generate(), _.add(T.crossTileID)); } return this.indexes[t.overscaledZ] === void 0 && (this.indexes[t.overscaledZ] = {}), this.indexes[t.overscaledZ][t.key] = new Uh(t, s.symbolInstances, s.bucketInstanceId), !0; } removeBucketCrossTileIDs(t, s) { for (const h of s.crossTileIDs) this.usedCrossTileIDs[t].delete(h); } removeStaleBuckets(t) { let s = !1; for (const h in this.indexes) { const _ = this.indexes[h]; for (const y in _) t[_[y].bucketInstanceId] || (this.removeBucketCrossTileIDs(h, _[y]), delete _[y], s = !0); } return s; } } class Hl { constructor() { this.layerIndexes = {}, this.crossTileIDs = new jh(), this.maxBucketInstanceId = 0, this.bucketsInCurrentPlacement = {}; } addLayer(t, s, h, _) { let y = this.layerIndexes[t.fqid]; y === void 0 && (y = this.layerIndexes[t.fqid] = new ed()); let T = !1; const z = {}; _.name !== "globe" && y.handleWrapJump(h); for (const R of s) { const F = R.getBucket(t); F && t.fqid === F.layerIds[0] && (F.bucketInstanceId || (F.bucketInstanceId = ++this.maxBucketInstanceId), y.addBucket(R.tileID, F, this.crossTileIDs) && (T = !0), z[F.bucketInstanceId] = !0); } return y.removeStaleBuckets(z) && (T = !0), T; } pruneUnusedLayers(t) { const s = {}; t.forEach((h) => { s[h] = !0; }); for (const h in this.layerIndexes) s[h] || delete this.layerIndexes[h]; } } const Xo = 771; class bi { constructor(t, s, h, _) { this.blendFunction = t, this.blendColor = s, this.mask = h, this.blendEquation = _; } } bi.Replace = [1, 0, 1, 0], bi.disabled = new bi(bi.Replace, i.aj.transparent, [!1, !1, !1, !1]), bi.unblended = new bi(bi.Replace, i.aj.transparent, [!0, !0, !0, !0]), bi.alphaBlended = new bi([1, Xo, 1, Xo], i.aj.transparent, [!0, !0, !0, !0]), bi.alphaBlendedNonPremultiplied = new bi([770, Xo, 770, Xo], i.aj.transparent, [!0, !0, !0, !0]), bi.multiply = new bi([774, 0, 774, 0], i.aj.transparent, [!0, !0, !0, !0]); class Wt { constructor(t, s, h) { this.func = t, this.mask = s, this.range = h; } } Wt.ReadOnly = !1, Wt.ReadWrite = !0, Wt.disabled = new Wt(519, Wt.ReadOnly, [0, 1]); const gl = 7680; class ci { constructor(t, s, h, _, y, T) { this.test = t, this.ref = s, this.mask = h, this.fail = _, this.depthFail = y, this.pass = T; } } ci.disabled = new ci({ func: 519, mask: 0 }, 0, 0, gl, gl, gl); const ar = 1029, lr = 2305; class ti { constructor(t, s, h) { this.enable = t, this.mode = s, this.frontFace = h; } } function Xr(c, t) { const s = i.bG(c, 3); i.ab.mat4.fromQuat(c, t), i.bI(c, 3, s); } function ql(c, t) { const s = i.ab.quat.identity([]); return i.ab.quat.rotateZ(s, s, -t), i.ab.quat.rotateX(s, s, -c), s; } function Yr(c, t) { const s = [c[0], c[1], 0], h = [t[0], t[1], 0]; if (i.ab.vec3.length(s) >= 1e-15) { const T = i.ab.vec3.normalize([], s); i.ab.vec3.scale(h, T, i.ab.vec3.dot(h, T)), t[0] = h[0], t[1] = h[1]; } const _ = i.ab.vec3.cross([], t, c); if (i.ab.vec3.len(_) < 1e-15) return null; const y = Math.atan2(-_[1], _[0]); return ql(Math.atan2(Math.sqrt(c[0] * c[0] + c[1] * c[1]), -c[2]), y); } ti.disabled = new ti(!1, ar, lr), ti.backCCW = new ti(!0, ar, lr), ti.backCW = new ti(!0, ar, 2304), ti.frontCW = new ti(!0, 1028, 2304), ti.frontCCW = new ti(!0, 1028, lr); class Va { constructor(t, s) { this.position = t, this.orientation = s; } get position() { return this._position; } set position(t) { if (t) { const s = t instanceof i.aa ? t : new i.aa(t[0], t[1], t[2]); this._renderWorldCopies && (s.x = i.bF(s.x, 0, 1)), this._position = s; } else this._position = null; } lookAtPoint(t, s) { if (this.orientation = null, !this.position) return; const h = this.position, _ = this._elevation ? this._elevation.getAtPointOrZero(i.aa.fromLngLat(t)) : 0, y = i.aa.fromLngLat(t, _), T = [y.x - h.x, y.y - h.y, y.z - h.z]; s || (s = [0, 0, 1]), s[2] = Math.abs(s[2]), this.orientation = Yr(T, s); } setPitchBearing(t, s) { this.orientation = ql(i.ai(t), i.ai(-s)); } } class To { constructor(t, s) { this._transform = i.ab.mat4.identity([]), this.orientation = s, this.position = t; } get mercatorPosition() { const t = this.position; return new i.aa(t[0], t[1], t[2]); } get position() { const t = i.bG(this._transform, 3); return [t[0], t[1], t[2]]; } set position(t) { var s; t && i.bI(this._transform, 3, [(s = t)[0], s[1], s[2], 1]); } get orientation() { return this._orientation; } set orientation(t) { this._orientation = t || i.ab.quat.identity([]), t && Xr(this._transform, this._orientation); } getPitchBearing() { const t = this.forward(), s = this.right(); return { bearing: Math.atan2(-s[1], s[0]), pitch: Math.atan2(Math.sqrt(t[0] * t[0] + t[1] * t[1]), -t[2]) }; } setPitchBearing(t, s) { this._orientation = ql(t, s), Xr(this._transform, this._orientation); } forward() { const t = i.bG(this._transform, 2); return [-t[0], -t[1], -t[2]]; } up() { const t = i.bG(this._transform, 1); return [-t[0], -t[1], -t[2]]; } right() { const t = i.bG(this._transform, 0); return [t[0], t[1], t[2]]; } getCameraToWorld(t, s) { const h = new Float64Array(16); return i.ab.mat4.invert(h, this.getWorldToCamera(t, s)), h; } getCameraToWorldMercator() { return this._transform; } getWorldToCameraPosition(t, s, h) { const _ = this.position; i.ab.vec3.scale(_, _, -t); const y = new Float64Array(16); return i.ab.mat4.fromScaling(y, [h, h, h]), i.ab.mat4.translate(y, y, _), y[10] *= s, y; } getWorldToCamera(t, s) { const h = new Float64Array(16), _ = new Float64Array(4), y = this.position; return i.ab.quat.conjugate(_, this._orientation), i.ab.vec3.scale(y, y, -t), i.ab.mat4.fromQuat(h, _), i.ab.mat4.translate(h, h, y), h[1] *= -1, h[5] *= -1, h[9] *= -1, h[13] *= -1, h[8] *= s, h[9] *= s, h[10] *= s, h[11] *= s, h; } getCameraToClipPerspective(t, s, h, _) { const y = new Float64Array(16); return i.ab.mat4.perspective(y, t, s, h, _), y; } getCameraToClipOrthographic(t, s, h, _, y, T) { const z = new Float64Array(16); return i.ab.mat4.ortho(z, t, s, h, _, y, T), z; } getDistanceToElevation(t, s = !1) { const h = t === 0 ? 0 : i.bH(t, s ? i.aS(this.position[1]) : this.position[1]), _ = this.forward(); return (h - this.position[2]) / _[2]; } clone() { return new To([...this.position], [...this.orientation]); } } const bs = { BaseColor: 5, MetallicRoughness: 6, Normal: 7, Occlusion: 8, Emission: 9, LUT: 10, ShadowMap0: 11 }; class ks { constructor(t = 0, s = 0, h = 0, _ = 0) { if (isNaN(t) || t < 0 || isNaN(s) || s < 0 || isNaN(h) || h < 0 || isNaN(_) || _ < 0) throw new Error("Invalid value for edge-insets, top, bottom, left and right must all be numbers"); this.top = t, this.bottom = s, this.left = h, this.right = _; } interpolate(t, s, h) { return s.top != null && t.top != null && (this.top = i.af(t.top, s.top, h)), s.bottom != null && t.bottom != null && (this.bottom = i.af(t.bottom, s.bottom, h)), s.left != null && t.left != null && (this.left = i.af(t.left, s.left, h)), s.right != null && t.right != null && (this.right = i.af(t.right, s.right, h)), this; } getCenter(t, s) { const h = i.aw((this.left + t - this.right) / 2, 0, t), _ = i.aw((this.top + s - this.bottom) / 2, 0, s); return new i.P(h, _); } equals(t) { return this.top === t.top && this.bottom === t.bottom && this.left === t.left && this.right === t.right; } clone() { return new ks(this.top, this.bottom, this.left, this.right); } toJSON() { return { top: this.top, bottom: this.bottom, left: this.left, right: this.right }; } } const Wl = (c, t, s) => (1 - s) * c + s * t, Tt = (c) => c * c * c * c * c; class ma { constructor(t, s, h, _, y, T, z) { this.tileSize = 512, this._renderWorldCopies = y === void 0 || y, this._minZoom = t || 0, this._maxZoom = s || 22, this._minPitch = h ?? 0, this._maxPitch = _ ?? 60, this.setProjection(T), this.setMaxBounds(z), this.width = 0, this.height = 0, this._center = new i.bO(0, 0), this.zoom = 0, this.angle = 0, this._fov = 0.6435011087932844, this._pitch = 0, this._nearZ = 0, this._farZ = 0, this._unmodified = !0, this._edgeInsets = new ks(), this._projMatrixCache = {}, this._alignedProjMatrixCache = {}, this._fogTileMatrixCache = {}, this._expandedProjMatrixCache = {}, this._distanceTileDataCache = {}, this._camera = new To(), this._centerAltitude = 0, this._averageElevation = 0, this.cameraElevationReference = "ground", this._pixelsPerMercatorPixel = 1, this.globeRadius = 0, this.globeCenterInViewSpace = [0, 0, 0], this._tileCoverLift = 0, this.freezeTileCoverage = !1, this._horizonShift = 0.1, this._orthographicProjectionAtLowPitch = !1; } clone() { const t = new ma(this._minZoom, this._maxZoom, this._minPitch, this.maxPitch, this._renderWorldCopies, this.getProjection()); return t._elevation = this._elevation, t._centerAltitude = this._centerAltitude, t._centerAltitudeValidForExaggeration = this._centerAltitudeValidForExaggeration, t.tileSize = this.tileSize, t.mercatorFromTransition = this.mercatorFromTransition, t.width = this.width, t.height = this.height, t.cameraElevationReference = this.cameraElevationReference, t._center = this._center, t._setZoom(this.zoom), t._seaLevelZoom = this._seaLevelZoom, t.angle = this.angle, t._fov = this._fov, t._pitch = this._pitch, t._nearZ = this._nearZ, t._farZ = this._farZ, t._averageElevation = this._averageElevation, t._orthographicProjectionAtLowPitch = this._orthographicProjectionAtLowPitch, t._unmodified = this._unmodified, t._edgeInsets = this._edgeInsets.clone(), t._camera = this._camera.clone(), t._calcMatrices(), t.freezeTileCoverage = this.freezeTileCoverage, t.frustumCorners = this.frustumCorners, t; } get isOrthographic() { return this.projection.name !== "globe" && this._orthographicProjectionAtLowPitch && this.pitch < 15; } get elevation() { return this._elevation; } set elevation(t) { this._elevation !== t && (this._elevation = t, this._updateCameraOnTerrain(), this._calcMatrices()); } get depthOcclusionForSymbolsAndCircles() { return this.projection.name !== "globe" && !this.isOrthographic; } updateElevation(t, s = !1) { const h = this._elevation && this._elevation.exaggeration() !== this._centerAltitudeValidForExaggeration; (this._seaLevelZoom == null || h) && this._updateCameraOnTerrain(), (t || h) && this._constrainCamera(s), this._calcMatrices(); } getProjection() { return i.ay(this.projection, ["name", "center", "parallels"]); } setProjection(t) { this.projectionOptions = t || { name: "mercator" }; const s = this.projection ? this.getProjection() : void 0; this.projection = i.bP(this.projectionOptions); const h = this.getProjection(), _ = !i.bn(s, h); return _ && this._calcMatrices(), this.mercatorFromTransition = !1, _; } setOrthographicProjectionAtLowPitch(t) { return this._orthographicProjectionAtLowPitch !== t && (this._orthographicProjectionAtLowPitch = t, this._calcMatrices(), !0); } setMercatorFromTransition() { const t = this.projection.name; this.mercatorFromTransition = !0, this.projectionOptions = { name: "mercator" }, this.projection = i.bP({ name: "mercator" }); const s = t !== this.projection.name; return s && this._calcMatrices(), s; } get minZoom() { return this._minZoom; } set minZoom(t) { this._minZoom !== t && (this._minZoom = t, this.zoom = Math.max(this.zoom, t)); } get maxZoom() { return this._maxZoom; } set maxZoom(t) { this._maxZoom !== t && (this._maxZoom = t, this.zoom = Math.min(this.zoom, t)); } get minPitch() { return this._minPitch; } set minPitch(t) { this._minPitch !== t && (this._minPitch = t, this.pitch = Math.max(this.pitch, t)); } get maxPitch() { return this._maxPitch; } set maxPitch(t) { this._maxPitch !== t && (this._maxPitch = t, this.pitch = Math.min(this.pitch, t)); } get renderWorldCopies() { return this._renderWorldCopies && this.projection.supportsWorldCopies === !0; } set renderWorldCopies(t) { t === void 0 ? t = !0 : t === null && (t = !1), this._renderWorldCopies = t; } get worldSize() { return this.tileSize * this.scale; } get cameraWorldSizeForFog() { const t = Math.max(this._camera.getDistanceToElevation(this._averageElevation), Number.EPSILON); return this._worldSizeFromZoom(this._zoomFromMercatorZ(t)); } get cameraWorldSize() { const t = Math.max(this._camera.getDistanceToElevation(this._averageElevation, !0), Number.EPSILON); return this._worldSizeFromZoom(this._zoomFromMercatorZ(t)); } get pixelsPerMeter() { return this.projection.pixelsPerMeter(this.center.lat, this.worldSize); } get cameraPixelsPerMeter() { return i.bH(1, this.center.lat) * this.cameraWorldSizeForFog; } get centerOffset() { return this.centerPoint._sub(this.size._div(2)); } get size() { return new i.P(this.width, this.height); } get bearing() { return i.bF(this.rotation, -180, 180); } set bearing(t) { this.rotation = t; } get rotation() { return -this.angle / Math.PI * 180; } set rotation(t) { const s = -t * Math.PI / 180; this.angle !== s && (this._unmodified = !1, this.angle = s, this._calcMatrices(), this.rotationMatrix = i.ab.mat2.create(), i.ab.mat2.rotate(this.rotationMatrix, this.rotationMatrix, this.angle)); } get pitch() { return this._pitch / Math.PI * 180; } set pitch(t) { const s = i.aw(t, this.minPitch, this.maxPitch) / 180 * Math.PI; this._pitch !== s && (this._unmodified = !1, this._pitch = s, 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 t = 1 / Math.tan(0.5 * this.fovX); return 2 * Math.atan(1 / this.aspect / t); } set fov(t) { t = Math.max(0.01, Math.min(60, t)), this._fov !== t && (this._unmodified = !1, this._fov = i.ai(t), this._calcMatrices()); } get averageElevation() { return this._averageElevation; } set averageElevation(t) { this._averageElevation = t, this._calcFogMatrices(), this._distanceTileDataCache = {}; } get zoom() { return this._zoom; } set zoom(t) { const s = Math.min(Math.max(t, this.minZoom), this.maxZoom); this._zoom !== s && (this._unmodified = !1, this._setZoom(s), this._updateSeaLevelZoom(), this._constrain(), this._calcMatrices()); } _setZoom(t) { this._zoom = t, this.scale = this.zoomScale(t), this.tileZoom = Math.floor(t), this.zoomFraction = t - this.tileZoom; } get tileCoverLift() { return this._tileCoverLift; } set tileCoverLift(t) { this._tileCoverLift !== t && (this._tileCoverLift = t); } _updateCameraOnTerrain() { const t = this.elevation ? this.elevation.getAtPoint(this.locationCoordinate(this.center), Number.NEGATIVE_INFINITY) : Number.NEGATIVE_INFINITY, s = this.elevation && t === Number.NEGATIVE_INFINITY && this.elevation.visibleDemTiles.length > 0 && this.elevation.exaggeration() > 0 && this._centerAltitudeValidForExaggeration; if (!this._elevation || t === Number.NEGATIVE_INFINITY && (!s || !this._centerAltitude)) return this._centerAltitude = 0, this._seaLevelZoom = null, void (this._centerAltitudeValidForExaggeration = void 0); const h = this._elevation; s || this._centerAltitude && this._centerAltitudeValidForExaggeration && h.exaggeration() && this._centerAltitudeValidForExaggeration !== h.exaggeration() ? (this._centerAltitude = this._centerAltitude / this._centerAltitudeValidForExaggeration * h.exaggeration(), this._centerAltitudeValidForExaggeration = h.exaggeration()) : (this._centerAltitude = t || 0, this._centerAltitudeValidForExaggeration = h.exaggeration()), this._updateSeaLevelZoom(); } _updateSeaLevelZoom() { this._centerAltitudeValidForExaggeration !== void 0 && (this._seaLevelZoom = this._zoomFromMercatorZ((this.pixelsPerMeter * this._centerAltitude + this.cameraToCenterDistance) / this.worldSize)); } sampleAverageElevation() { if (!this._elevation) return 0; const t = this._elevation, s = [[0.5, 0.2], [0.3, 0.5], [0.5, 0.5], [0.7, 0.5], [0.5, 0.8]], h = this.horizonLineFromTop(); let _ = 0, y = 0; for (let T = 0; T < s.length; T++) { const z = new i.P(s[T][0] * this.width, h + s[T][1] * (this.height - h)), R = t.pointCoordinate(z); if (!R) continue; const F = 1 / Math.hypot(R[0] - this._camera.position[0], R[1] - this._camera.position[1]); _ += R[3] * F, y += F; } return y === 0 ? NaN : _ / y; } get center() { return this._center; } set center(t) { t.lat === this._center.lat && t.lng === this._center.lng || (this._unmodified = !1, this._center = t, this._terrainEnabled() && (this.cameraElevationReference === "ground" ? this._updateCameraOnTerrain() : this._updateZoomFromElevation()), this._constrain(), this._calcMatrices()); } _updateZoomFromElevation() { if (this._seaLevelZoom == null || !this._elevation) return; const t = this._seaLevelZoom, s = this._elevation.getAtPointOrZero(this.locationCoordinate(this.center)), h = this.pixelsPerMeter / this.worldSize * s, _ = this._mercatorZfromZoom(t), y = this._mercatorZfromZoom(this._maxZoom), T = Math.max(_ - h, y); this._setZoom(this._zoomFromMercatorZ(T)); } get padding() { return this._edgeInsets.toJSON(); } set padding(t) { this._edgeInsets.equals(t) || (this._unmodified = !1, this._edgeInsets.interpolate(this._edgeInsets, t, 1), this._calcMatrices()); } computeZoomRelativeTo(t) { const s = this.rayIntersectionCoordinate(this.pointRayIntersection(this.centerPoint, t.toAltitude())); let h; h = t.z < this._camera.position[2] ? [s.x, s.y, s.z] : [t.x, t.y, t.z]; const _ = i.ab.vec3.length(i.ab.vec3.sub([], this._camera.position, h)); return i.aw(this._zoomFromMercatorZ(_), this._minZoom, this._maxZoom); } setFreeCameraOptions(t) { if (!this.height || !t.position && !t.orientation) return; this._updateCameraState(); let s = !1; if (t.orientation && !i.ab.quat.exactEquals(t.orientation, this._camera.orientation) && (s = this._setCameraOrientation(t.orientation)), t.position) { const h = [t.position.x, t.position.y, t.position.z]; i.ab.vec3.exactEquals(h, this._camera.position) || (this._setCameraPosition(h), s = !0); } s && (this._updateStateFromCamera(), this.recenterOnTerrain()); } getFreeCameraOptions() { this._updateCameraState(); const t = this._camera.position, s = new Va(); return s.position = new i.aa(t[0], t[1], t[2]), s.orientation = this._camera.orientation, s._elevation = this.elevation, s._renderWorldCopies = this.renderWorldCopies, s; } _setCameraOrientation(t) { if (!i.ab.quat.length(t)) return !1; i.ab.quat.normalize(t, t); const s = i.ab.vec3.transformQuat([], [0, 0, -1], t), h = i.ab.vec3.transformQuat([], [0, -1, 0], t); if (h[2] < 0) return !1; const _ = Yr(s, h); return !!_ && (this._camera.orientation = _, !0); } _setCameraPosition(t) { const s = this.zoomScale(this.minZoom) * this.tileSize, h = this.zoomScale(this.maxZoom) * this.tileSize, _ = this.cameraToCenterDistance; t[2] = i.aw(t[2], _ / h, _ / s), this._camera.position = t; } get centerPoint() { return this._edgeInsets.getCenter(this.width, this.height); } get fovAboveCenter() { return this._fov * (0.5 + this.centerOffset.y / this.height); } isPaddingEqual(t) { return this._edgeInsets.equals(t); } interpolatePadding(t, s, h) { this._unmodified = !1, this._edgeInsets.interpolate(t, s, h), this._constrain(), this._calcMatrices(); } coveringZoomLevel(t) { const s = (t.roundZoom ? Math.round : Math.floor)(this.zoom + this.scaleZoom(this.tileSize / t.tileSize)); return Math.max(0, s); } getVisibleUnwrappedCoordinates(t) { const s = [new i.bQ(0, t)]; if (this.renderWorldCopies) { const h = this.pointCoordinate(new i.P(0, 0)), _ = this.pointCoordinate(new i.P(this.width, 0)), y = this.pointCoordinate(new i.P(this.width, this.height)), T = this.pointCoordinate(new i.P(0, this.height)), z = Math.floor(Math.min(h.x, _.x, y.x, T.x)), R = Math.floor(Math.max(h.x, _.x, y.x, T.x)), F = 1; for (let N = z - F; N <= R + F; N++) N !== 0 && s.push(new i.bQ(N, t)); } return s; } isLODDisabled(t) { return (!t || this.pitch <= 60) && this._edgeInsets.top <= this._edgeInsets.bottom && !this._elevation && !this.projection.isReprojectedInTileSpace; } extendTileCover(t, s, h) { let _ = []; const y = h !== void 0, T = !y; if (T && this.zoom < s || y && h[0] === 0 && h[1] === 0) return _; const z = /* @__PURE__ */ new Set(), R = (N, G, Z, W, te) => { const ee = i.c5(G, N, Z, W, te); z.has(ee) || (_.push(new i.aG(N, G, Z, W, te)), z.add(ee)); }; for (let N = 0; N < t.length; N++) { const G = t[N]; if (T && G.canonical.z !== s) continue; const Z = G.canonical, W = G.overscaledZ, te = G.wrap, ee = 1 << Z.z, se = Z.x + 1 < ee, oe = Z.x > 0, he = Z.y + 1 < ee, _e = Z.y > 0, pe = G.wrap - (oe ? 0 : 1), Me = G.wrap + (se ? 0 : 1), xe = oe ? Z.x - 1 : ee - 1, we = se ? Z.x + 1 : 0; if (y) h[0] < 0 ? (R(W, Me, Z.z, we, Z.y), h[1] < 0 && he && (R(W, te, Z.z, Z.x, Z.y + 1), R(W, Me, Z.z, we, Z.y + 1)), h[1] > 0 && _e && (R(W, te, Z.z, Z.x, Z.y - 1), R(W, Me, Z.z, we, Z.y - 1))) : h[0] > 0 ? (R(W, pe, Z.z, xe, Z.y), h[1] < 0 && he && (R(W, te, Z.z, Z.x, Z.y + 1), R(W, pe, Z.z, xe, Z.y + 1)), h[1] > 0 && _e && (R(W, te, Z.z, Z.x, Z.y - 1), R(W, pe, Z.z, xe, Z.y - 1))) : h[1] < 0 && he ? R(W, te, Z.z, Z.x, Z.y + 1) : _e && R(W, te, Z.z, Z.x, Z.y - 1); else { const ve = G.visibleQuadrants; 1 & ve && (R(W, pe, Z.z, xe, Z.y), _e && (R(W, te, Z.z, Z.x, Z.y - 1), R(W, pe, Z.z, xe, Z.y - 1))), 2 & ve && (R(W, Me, Z.z, we, Z.y), _e && (R(W, te, Z.z, Z.x, Z.y - 1), R(W, Me, Z.z, we, Z.y - 1))), 4 & ve && (R(W, pe, Z.z, xe, Z.y), he && (R(W, te, Z.z, Z.x, Z.y + 1), R(W, pe, Z.z, xe, Z.y + 1))), 8 & ve && (R(W, Me, Z.z, we, Z.y), he && (R(W, te, Z.z, Z.x, Z.y + 1), R(W, Me, Z.z, we, Z.y + 1))); } } const F = []; for (const N of _) _.some((G) => N.isChildOf(G)) || F.push(N); if (_ = F.filter((N) => !t.some((G) => !!(N.overscaledZ < s && G.isChildOf(N)) || N.equals(G) || N.isChildOf(G))), T) { const N = 1 << s, G = this.projection.name === "globe" ? this._camera.mercatorPosition : this.pointCoordinate(this.getCameraPoint()), Z = [N * G.x, N * G.y], W = 4, te = W * W; _ = _.filter((ee) => { const se = ee.canonical.x + 0.5 - Z[0], oe = ee.canonical.y + 0.5 - Z[1]; return se * se + oe * oe < te; }); } return _; } coveringTiles(t) { let s = this.coveringZoomLevel(t); const h = s, _ = this.elevation && this.elevation.exaggeration(), y = _ && !t.isTerrainDEM, T = this.projection.name === "mercator"; if (t.minzoom !== void 0 && s < t.minzoom) return []; t.maxzoom !== void 0 && s > t.maxzoom && (s = t.maxzoom); const z = this.locationCoordinate(this.center), R = this.center.lat, F = 1 << s, N = [F * z.x, F * z.y, 0], G = this.projection.name === "globe", Z = !G, W = i.bR.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, s, Z), te = G ? this._camera.mercatorPosition : this.pointCoordinate(this.getCameraPoint()), ee = F * i.bH(1, this.center.lat), se = this._camera.position[2] / i.bH(1, this.center.lat), oe = [F * te.x, F * te.y, se * (Z ? 1 : ee)], he = G || _, _e = this.cameraToCenterDistance / t.tileSize * (t.roundZoom ? 1 : 0.502), pe = this.isLODDisabled(!0) ? s : 0; let Me; if (this._elevation && t.isTerrainDEM) Me = 1e4 * this._elevation.exaggeration(); else if (this._elevation) { const Ge = this._elevation.getMinMaxForVisibleTiles(); Me = Ge ? Ge.max : this._centerAltitude; } else Me = this._centerAltitude; const xe = t.isTerrainDEM ? -Me : this._elevation ? this._elevation.getMinElevationBelowMSL() : 0, we = this.projection.isReprojectedInTileSpace ? i.bS(this) : 1, ve = (Ge) => { const Je = new i.aa(Ge.x + 25e-6, Ge.y, Ge.z), _t = new i.aa(Ge.x, Ge.y + 25e-6, Ge.z), ct = Ge.toLngLat(), nt = Je.toLngLat(), Lt = _t.toLngLat(), bt = this.locationCoordinate(ct), zt = this.locationCoordinate(nt), Bt = this.locationCoordinate(Lt), oi = Math.hypot(zt.x - bt.x, zt.y - bt.y), $t = Math.hypot(Bt.x - bt.x, Bt.y - bt.y); return Math.sqrt(oi * $t) * we / 25e-6; }, Ae = (Ge) => { const lt = Me, Je = xe; return { aabb: i.bV(this, F, 0, 0, 0, Ge, Je, lt, this.projection), zoom: 0, x: 0, y: 0, minZ: Je, maxZ: lt, wrap: Ge, fullyVisible: !1 }; }, Oe = []; let Xe = []; const He = s, ke = t.reparseOverscaled ? h : s, Ne = (se - this._centerAltitude) * ee, st = (Ge) => { if (!this._elevation || !Ge.tileID || !T) return; const lt = this._elevation.getMinMaxForTile(Ge.tileID), Je = Ge.aabb; lt ? (Je.min[2] = lt.min, Je.max[2] = lt.max, Je.center[2] = (Je.min[2] + Je.max[2]) / 2) : (Ge.shouldSplit = xt(Ge), Ge.shouldSplit || (Je.min[2] = Je.max[2] = Je.center[2] = this._centerAltitude)); }, ut = (Ge, lt) => { if (0.707 * lt < Ge) return 1; const Je = lt / Ge; return Je / (1.4144271570014144 + (Math.pow(1.1, Je - 1.4144271570014144 + 1) - 1) / (1.1 - 1) - 1); }, xt = (Ge) => { if (Ge.zoom < pe) return !0; if (Ge.zoom === He) return !1; if (Ge.shouldSplit != null) return Ge.shouldSplit; const lt = Ge.aabb.distanceX(oe), Je = Ge.aabb.distanceY(oe); let _t = Ne, ct = 1; if (G) { _t = Ge.aabb.distanceZ(oe); const $t = Math.pow(2, Ge.zoom), Xt = i.aS((Ge.y + 1) / $t), ai = i.aS(Ge.y / $t), zi = Math.min(Math.max(R, Xt), ai), wi = i.c9(zi) / i.c9(R); if (ct = zi === R ? 1 / Math.max(1, this._mercatorScaleRatio - 0.3) : Math.min(1, wi / this._mercatorScaleRatio), this.zoom <= i.c6 && Ge.zoom === He - 1 && wi >= 0.9) return !0; } else if (y && (_t = Ge.aabb.distanceZ(oe) * ee), this.projection.isReprojectedInTileSpace && h <= 5) { const $t = Math.pow(2, Ge.zoom), Xt = ve(new i.aa((Ge.x + 0.5) / $t, (Ge.y + 0.5) / $t)); ct = Xt > 0.85 ? 1 : Xt; } if (!T) { const $t = Math.sqrt(lt * lt + Je * Je + _t * _t); let Xt = (1 << He - Ge.zoom) * _e * ct; return Xt *= ut(Math.max(_t, Ne), $t), $t < Xt; } let nt = Number.MAX_VALUE, Lt = 0; const bt = Ge.aabb.getCorners(), zt = []; for (const $t of bt) { i.ab.vec3.sub(zt, $t, oe), G || (y ? zt[2] *= ee : zt[2] = Ne); const Xt = i.ab.vec3.dot(zt, this._camera.forward()); Xt < nt && (nt = Xt, Lt = Math.abs(zt[2])); } let Bt = (1 << He - Ge.zoom) * _e * ct; if (Bt *= ut(Math.max(Lt, Ne), nt), nt < Bt) return !0; const oi = Ge.aabb.closestPoint(N); return oi[0] === N[0] && oi[1] === N[1]; }; if (this.renderWorldCopies) for (let Ge = 1; Ge <= 3; Ge++) Oe.push(Ae(-Ge)), Oe.push(Ae(Ge)); for (Oe.push(Ae(0)); Oe.length > 0; ) { const Ge = Oe.pop(), lt = Ge.x, Je = Ge.y; let _t = Ge.fullyVisible; const ct = () => this.projection.name === "globe" && (Ge.y === 0 || Ge.y === (1 << Ge.zoom) - 1); if (!_t) { let nt = he ? Ge.aabb.intersects(W) : Ge.aabb.intersectsFlat(W); if (nt === 0 && ct()) { const Lt = new i.bT(Ge.zoom, lt, Je); nt = i.bU(this, F, Lt, !0).intersects(W); } if (nt === 0) continue; _t = nt === 2; } if (Ge.zoom !== He && xt(Ge)) for (let nt = 0; nt < 4; nt++) { const Lt = (lt << 1) + nt % 2, bt = (Je << 1) + (nt >> 1), zt = { aabb: T ? Ge.aabb.quadrant(nt) : i.bV(this, F, Ge.zoom + 1, Lt, bt, Ge.wrap, Ge.minZ, Ge.maxZ, this.projection), zoom: Ge.zoom + 1, x: Lt, y: bt, wrap: Ge.wrap, fullyVisible: _t, tileID: void 0, shouldSplit: void 0, minZ: Ge.minZ, maxZ: Ge.maxZ }; y && !G && (zt.tileID = new i.aG(Ge.zoom + 1 === He ? ke : Ge.zoom + 1, Ge.wrap, Ge.zoom + 1, Lt, bt), st(zt)), Oe.push(zt); } else { const nt = Ge.zoom === He ? ke : Ge.zoom; if (t.minzoom && t.minzoom > nt) continue; let Lt = 0; if (!_t) { let oi = he ? Ge.aabb.intersectsPrecise(W) : Ge.aabb.intersectsPreciseFlat(W); if (oi === 0 && ct()) { const $t = new i.bT(Ge.zoom, lt, Je); oi = i.bU(this, F, $t, !0).intersectsPrecise(W); } if (oi === 0) continue; if (t.calculateQuadrantVisibility) if (W.containsPoint(Ge.aabb.center)) Lt = 15; else for (let $t = 0; $t < 4; $t++) Ge.aabb.quadrant($t).intersects(W) !== 0 && (Lt |= 1 << $t); } const bt = N[0] - (0.5 + lt + (Ge.wrap << Ge.zoom)) * (1 << s - Ge.zoom), zt = N[1] - 0.5 - Je, Bt = Ge.tileID ? Ge.tileID : new i.aG(nt, Ge.wrap, Ge.zoom, lt, Je); t.calculateQuadrantVisibility && (Bt.visibleQuadrants = Lt), Xe.push({ tileID: Bt, distanceSq: bt * bt + zt * zt }); } } if (this.fogCullDistSq) { const Ge = this.fogCullDistSq, lt = this.horizonLineFromTop(); Xe = Xe.filter((Je) => { const _t = [0, 0, 0, 1], ct = [i.ag, i.ag, 0, 1], nt = this.calculateFogTileMatrix(Je.tileID.toUnwrapped()); i.ab.vec4.transformMat4(_t, _t, nt), i.ab.vec4.transformMat4(ct, ct, nt); const Lt = i.ab.vec4.min([], _t, ct), bt = i.ab.vec4.max([], _t, ct), zt = i.bW(Lt, bt); if (zt === 0) return !0; let Bt = !1; const oi = this._elevation; if (oi && zt > Ge && lt !== 0) { const $t = this.calculateProjMatrix(Je.tileID.toUnwrapped()); let Xt; t.isTerrainDEM || (Xt = oi.getMinMaxForTile(Je.tileID)), Xt || (Xt = { min: xe, max: Me }); const ai = i.c7(this.rotation), zi = [ai[0] * i.ag, ai[1] * i.ag, Xt.max]; i.ab.vec3.transformMat4(zi, zi, $t), Bt = (1 - zi[1]) * this.height * 0.5 < lt; } return zt < Ge || Bt; }); } return Xe.sort((Ge, lt) => Ge.distanceSq - lt.distanceSq).map((Ge) => Ge.tileID); } resize(t, s) { this.width = t, this.height = s, this.pixelsToGLUnits = [2 / t, -2 / s], this._constrain(), this._calcMatrices(); } get unmodified() { return this._unmodified; } zoomScale(t) { return Math.pow(2, t); } scaleZoom(t) { return Math.log(t) / Math.LN2; } project(t) { const s = i.aw(t.lat, -i.bX, i.bX), h = this.projection.project(t.lng, s); return new i.P(h.x * this.worldSize, h.y * this.worldSize); } unproject(t) { return this.projection.unproject(t.x / this.worldSize, t.y / this.worldSize); } get point() { return this.project(this.center); } get pointMerc() { return this.point._div(this.worldSize); } get pixelsPerMeterRatio() { return this.pixelsPerMeter / i.bH(1, this.center.lat) / this.worldSize; } setLocationAtPoint(t, s) { let h, _; const y = this.centerPoint; if (this.projection.name === "globe") { const z = this.worldSize; h = (s.x - y.x) / z, _ = (s.y - y.y) / z; } else { const z = this.pointCoordinate(s), R = this.pointCoordinate(y); h = z.x - R.x, _ = z.y - R.y; } const T = this.locationCoordinate(t); this.setLocation(new i.aa(T.x - h, T.y - _)); } setLocation(t) { this.center = this.coordinateLocation(t), this.projection.wrap && (this.center = this.center.wrap()); } locationPoint(t) { return this.projection.locationPoint(this, t); } locationPoint3D(t) { return this.projection.locationPoint(this, t, !0); } pointLocation(t) { return this.coordinateLocation(this.pointCoordinate(t)); } pointLocation3D(t) { return this.coordinateLocation(this.pointCoordinate3D(t)); } locationCoordinate(t, s) { const h = s ? i.bH(s, t.lat) : void 0, _ = this.projection.project(t.lng, t.lat); return new i.aa(_.x, _.y, h); } coordinateLocation(t) { return this.projection.unproject(t.x, t.y); } pointRayIntersection(t, s) { const h = s ?? this._centerAltitude, _ = [t.x, t.y, 0, 1], y = [t.x, t.y, 1, 1]; i.ab.vec4.transformMat4(_, _, this.pixelMatrixInverse), i.ab.vec4.transformMat4(y, y, this.pixelMatrixInverse); const T = y[3]; i.ab.vec4.scale(_, _, 1 / _[3]), i.ab.vec4.scale(y, y, 1 / T); const z = _[2], R = y[2]; return { p0: _, p1: y, t: z === R ? 0 : (h - z) / (R - z) }; } screenPointToMercatorRay(t) { const s = [t.x, t.y, 0, 1], h = [t.x, t.y, 1, 1]; return i.ab.vec4.transformMat4(s, s, this.pixelMatrixInverse), i.ab.vec4.transformMat4(h, h, this.pixelMatrixInverse), i.ab.vec4.scale(s, s, 1 / s[3]), i.ab.vec4.scale(h, h, 1 / h[3]), s[2] = i.bH(s[2], this._center.lat) * this.worldSize, h[2] = i.bH(h[2], this._center.lat) * this.worldSize, i.ab.vec4.scale(s, s, 1 / this.worldSize), i.ab.vec4.scale(h, h, 1 / this.worldSize), new i.aq([s[0], s[1], s[2]], i.ab.vec3.normalize([], i.ab.vec3.sub([], h, s))); } rayIntersectionCoordinate(t) { const { p0: s, p1: h, t: _ } = t, y = i.bH(s[2], this._center.lat), T = i.bH(h[2], this._center.lat); return new i.aa(i.af(s[0], h[0], _) / this.worldSize, i.af(s[1], h[1], _) / this.worldSize, i.af(y, T, _)); } pointCoordinate(t, s = this._centerAltitude) { return this.projection.pointCoordinate(this, t.x, t.y, s); } pointCoordinate3D(t) { if (!this.elevation) return this.pointCoordinate(t); let s = this.projection.pointCoordinate3D(this, t.x, t.y); if (s) return new i.aa(s[0], s[1], s[2]); let h = 0, _ = this.horizonLineFromTop(); if (t.y > _) return this.pointCoordinate(t); const y = 0.02 * _, T = t.clone(); for (let z = 0; z < 10 && _ - h > y; z++) { T.y = i.af(h, _, 0.66); const R = this.projection.pointCoordinate3D(this, T.x, T.y); R ? (_ = T.y, s = R) : h = T.y; } return s ? new i.aa(s[0], s[1], s[2]) : this.pointCoordinate(t); } isPointAboveHorizon(t) { return this.projection.isPointAboveHorizon(this, t); } isPointOnSurface(t) { if (t.y < 0 || t.y > this.height || t.x < 0 || t.x > this.width) return !1; if (this.elevation || this.zoom >= i.bY) return !this.isPointAboveHorizon(t); const s = this.pointCoordinate(t); return s.y >= 0 && s.y <= 1; } _coordinatePoint(t, s) { const h = s && this.elevation ? this.elevation.getAtPointOrZero(t, this._centerAltitude) : this._centerAltitude, _ = [t.x * this.worldSize, t.y * this.worldSize, h + t.toAltitude(), 1]; return i.ab.vec4.transformMat4(_, _, this.pixelMatrix), _[3] > 0 ? new i.P(_[0] / _[3], _[1] / _[3]) : new i.P(Number.MAX_VALUE, Number.MAX_VALUE); } _getBoundsNonRectangular() { const { top: t, left: s } = this._edgeInsets, h = this.height - this._edgeInsets.bottom, _ = this.width - this._edgeInsets.right, y = this.pointLocation3D(new i.P(s, t)), T = this.pointLocation3D(new i.P(_, t)), z = this.pointLocation3D(new i.P(_, h)), R = this.pointLocation3D(new i.P(s, h)); let F = Math.min(y.lng, T.lng, z.lng, R.lng), N = Math.max(y.lng, T.lng, z.lng, R.lng), G = Math.min(y.lat, T.lat, z.lat, R.lat), Z = Math.max(y.lat, T.lat, z.lat, R.lat); const W = Math.pow(2, -this.zoom) / 16 * 270, te = this.projection.name === "globe" ? 1 : 4, ee = (se, oe, he, _e, pe) => { const Me = (se + he) / 2, xe = (oe + _e) / 2, we = new i.P(Me, xe), { lng: ve, lat: Ae } = this.pointLocation3D(we), Oe = Math.max(0, F - ve, G - Ae, ve - N, Ae - Z); F = Math.min(F, ve), N = Math.max(N, ve), G = Math.min(G, Ae), Z = Math.max(Z, Ae), (pe < te || Oe > W) && (ee(se, oe, Me, xe, pe + 1), ee(Me, xe, he, _e, pe + 1)); }; if (ee(s, t, _, t, 1), ee(_, t, _, h, 1), ee(_, h, s, h, 1), ee(s, h, s, t, 1), this.projection.name === "globe") { const [se, oe] = i.bZ(this); se ? (Z = 90, N = 180, F = -180) : oe && (G = -90, N = 180, F = -180); } return new i.az(new i.bO(F, G), new i.bO(N, Z)); } _getBoundsRectangular(t, s) { const { top: h, left: _ } = this._edgeInsets, y = this.height - this._edgeInsets.bottom, T = this.width - this._edgeInsets.right, z = new i.P(_, h), R = new i.P(T, h), F = new i.P(T, y), N = new i.P(_, y); let G = this.pointCoordinate(z, t), Z = this.pointCoordinate(R, t); const W = this.pointCoordinate(F, s), te = this.pointCoordinate(N, s), ee = (se, oe) => (oe.y - se.y) / (oe.x - se.x); return G.y > 1 && Z.y >= 0 ? G = new i.aa((1 - te.y) / ee(te, G) + te.x, 1) : G.y < 0 && Z.y <= 1 && (G = new i.aa(-te.y / ee(te, G) + te.x, 0)), Z.y > 1 && G.y >= 0 ? Z = new i.aa((1 - W.y) / ee(W, Z) + W.x, 1) : Z.y < 0 && G.y <= 1 && (Z = new i.aa(-W.y / ee(W, Z) + W.x, 0)), new i.az().extend(this.coordinateLocation(G)).extend(this.coordinateLocation(Z)).extend(this.coordinateLocation(te)).extend(this.coordinateLocation(W)); } _getBoundsRectangularTerrain() { const t = this.elevation; if (!t.visibleDemTiles.length || t.isUsingMockSource()) return this._getBoundsRectangular(0, 0); const s = t.visibleDemTiles.reduce((h, _) => { if (_.dem) { const y = _.dem.tree; h.min = Math.min(h.min, y.minimums[0]), h.max = Math.max(h.max, y.maximums[0]); } return h; }, { min: Number.MAX_VALUE, max: 0 }); return this._getBoundsRectangular(s.min * t.exaggeration(), s.max * t.exaggeration()); } getBounds() { return this.projection.name === "mercator" || this.projection.name === "equirectangular" ? this._terrainEnabled() ? this._getBoundsRectangularTerrain() : this._getBoundsRectangular(0, 0) : this._getBoundsNonRectangular(); } horizonLineFromTop(t = !0) { const s = this.height / 2 / Math.tan(this._fov / 2) / Math.tan(Math.max(this._pitch, 0.1)) - this.centerOffset.y, h = this.height / 2 - s * (1 - this._horizonShift); return t ? Math.max(0, h) : h; } getMaxBounds() { return this.maxBounds; } setMaxBounds(t) { this.maxBounds = t, this.minLat = -i.bX, this.maxLat = i.bX, 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 = i.at(this.minLng) * this.tileSize, this.worldMaxX = i.at(this.maxLng) * this.tileSize, this.worldMinY = i.aA(this.maxLat) * this.tileSize, this.worldMaxY = i.aA(this.minLat) * this.tileSize, this._constrain(); } calculatePosMatrix(t, s) { return this.projection.createTileMatrix(this, s, t); } calculateDistanceTileData(t) { const s = t.key, h = this._distanceTileDataCache; if (h[s]) return h[s]; const _ = t.canonical, y = 1 / this.height, T = this.cameraWorldSize, z = T / this.zoomScale(_.z), R = (_.x + Math.pow(2, _.z) * t.wrap) * z, F = _.y * z, N = this.point; N.x *= T / this.worldSize, N.y *= T / this.worldSize; const G = this.angle, Z = Math.sin(-G), W = -Math.cos(-G); return h[s] = { bearing: [Z, W], center: [(N.x - R) * y, (N.y - F) * y], scale: z / i.ag * y }, h[s]; } calculateFogTileMatrix(t) { const s = t.key, h = this._fogTileMatrixCache; if (h[s]) return h[s]; const _ = this.projection.createTileMatrix(this, this.cameraWorldSizeForFog, t); return i.ab.mat4.multiply(_, this.worldToFogMatrix, _), h[s] = new Float32Array(_), h[s]; } calculateProjMatrix(t, s = !1, h = !1) { const _ = t.key; let y; if (y = h ? this._expandedProjMatrixCache : s ? this._alignedProjMatrixCache : this._projMatrixCache, y[_]) return y[_]; const T = this.calculatePosMatrix(t, this.worldSize); let z; return z = this.projection.isReprojectedInTileSpace ? this.mercatorMatrix : h ? this.expandedFarZProjMatrix : s ? this.alignedProjMatrix : this.projMatrix, i.ab.mat4.multiply(T, z, T), y[_] = new Float32Array(T), y[_]; } calculatePixelsToTileUnitsMatrix(t) { const s = t.tileID.key, h = this._pixelsToTileUnitsCache; if (h[s]) return h[s]; const _ = i.b_(t, this); return h[s] = _, h[s]; } customLayerMatrix() { return this.mercatorMatrix.slice(); } globeToMercatorMatrix() { if (this.projection.name === "globe") { const t = 1 / this.worldSize, s = i.ab.mat4.fromScaling([], [t, t, t]); return i.ab.mat4.multiply(s, s, this.globeMatrix), s; } } recenterOnTerrain() { if (!this._elevation || this.projection.name === "globe") return; const t = this._elevation; this._updateCameraState(); const s = i.bH(1, this._center.lat) * this.worldSize, h = this._computeCameraPosition(s), _ = this._camera.forward(), y = i.bH(1, this._center.lat); h[2] /= y, _[2] /= y, i.ab.vec3.normalize(_, _); const T = t.raycast(h, _, t.exaggeration()); if (T) { const z = i.ab.vec3.scaleAndAdd([], h, _, T), R = new i.aa(z[0], z[1], i.bH(z[2], i.aS(z[1]))), F = (R.z + i.ab.vec3.length([R.x - h[0], R.y - h[1], R.z - h[2] * y])) * this._pixelsPerMercatorPixel; this._seaLevelZoom = this._zoomFromMercatorZ(F), this._centerAltitude = R.toAltitude(), this._center = this.coordinateLocation(R), this._updateZoomFromElevation(), this._constrain(), this._calcMatrices(); } } _constrainCamera(t = !1) { if (!this._elevation) return; const s = this._elevation, h = i.bH(1, this._center.lat) * this.worldSize, _ = this._computeCameraPosition(h), y = s.getAtPointOrZero(new i.aa(..._)), T = this.pixelsPerMeter / this.worldSize * y, z = this._minimumHeightOverTerrain(), R = _[2] - T; if (R <= z) if (R < 0 || t) { const F = this.locationCoordinate(this._center, this._centerAltitude), N = [_[0], _[1], F.z - _[2]], G = i.ab.vec3.length(N); N[2] -= (z - R) / this._pixelsPerMercatorPixel; const Z = i.ab.vec3.length(N); if (Z === 0) return; i.ab.vec3.scale(N, N, G / Z * this._pixelsPerMercatorPixel), this._camera.position = [_[0], _[1], F.z * this._pixelsPerMercatorPixel - N[2]], this._updateStateFromCamera(); } else this._isCameraConstrained = !0; } _constrain() { if (!this.center || !this.width || !this.height || this._constraining) return; this._constraining = !0; const t = this.projection.name === "globe" || this.mercatorFromTransition; if (this.projection.isReprojectedInTileSpace || t) { const Z = this.center; return Z.lat = i.aw(Z.lat, this.minLat, this.maxLat), (this.maxBounds || !this.renderWorldCopies && !t) && (Z.lng = i.aw(Z.lng, this.minLng, this.maxLng)), this.center = Z, void (this._constraining = !1); } const s = this._unmodified, { x: h, y: _ } = this.point; let y = 0, T = h, z = _; const R = this.width / 2, F = this.height / 2, N = this.worldMinY * this.scale, G = this.worldMaxY * this.scale; if (_ - F < N && (z = N + F), _ + F > G && (z = G - F), G - N < this.height && (y = Math.max(y, this.height / (G - N)), z = (G + N) / 2), this.maxBounds || !this._renderWorldCopies || !this.projection.wrap) { const Z = this.worldMinX * this.scale, W = this.worldMaxX * this.scale, te = this.worldSize / 2 - (Z + W) / 2; T = (h + te + this.worldSize) % this.worldSize - te, T - R < Z && (T = Z + R), T + R > W && (T = W - R), W - Z < this.width && (y = Math.max(y, this.width / (W - Z)), T = (W + Z) / 2); } T === h && z === _ || (this.center = this.unproject(new i.P(T, z))), y && (this.zoom += this.scaleZoom(y)), this._constrainCamera(), this._unmodified = s, this._constraining = !1; } _minZoomForBounds() { let t = Math.max(0, this.scaleZoom(this.height / (this.worldMaxY - this.worldMinY))); return this.maxBounds && (t = Math.max(t, this.scaleZoom(this.width / (this.worldMaxX - this.worldMinX)))), t; } _maxCameraBoundsDistance() { return this._mercatorZfromZoom(this._minZoomForBounds()); } _calcMatrices() { if (!this.height) return; const t = this.centerOffset, s = this.projection.name === "globe", h = this.pixelsPerMeter; this.projection.name === "globe" && (this._mercatorScaleRatio = i.bH(1, this.center.lat) / i.bH(1, i.c8)); const _ = i.b$(this.projection, this.zoom, this.width, this.height, 1024); this._pixelsPerMercatorPixel = this.projection.pixelSpaceConversion(this.center.lat, this.worldSize, _), this.cameraToCenterDistance = 0.5 / Math.tan(0.5 * this._fov) * this.height * this._pixelsPerMercatorPixel, this._updateCameraState(), this._farZ = this.projection.farthestPixelDistance(this), this._nearZ = this.height / 50; const y = this.projection.zAxisUnit === "meters" ? h : 1, T = this._camera.getWorldToCamera(this.worldSize, y); let z; const R = this._camera.getCameraToClipPerspective(this._fov, this.width / this.height, this._nearZ, this._farZ); if (R[8] = 2 * -t.x / this.width, R[9] = 2 * t.y / this.height, this.isOrthographic) { let Ae = 0.5 * this.height / Math.tan(this._fov / 2) * 1 * Math.tan(0.5 * this._fov), Oe = Ae * this.aspect, Xe = -Oe, He = -Ae; Oe -= t.x, Xe -= t.x, Ae += t.y, He += t.y, z = this._camera.getCameraToClipOrthographic(Xe, Oe, He, Ae, this._nearZ, this._farZ), ((ke, Ne, st, ut) => { for (let xt = 0; xt < 16; xt++) ke[xt] = Wl(Ne[xt], st[xt], ut); })(z, z, R, Tt(this.pitch >= 15 ? 1 : this.pitch / 15)); } else z = R; const F = i.ab.mat4.mul([], R, T); let N = i.ab.mat4.mul([], z, T); if (this.projection.isReprojectedInTileSpace) { const Ae = this.locationCoordinate(this.center), Oe = i.ab.mat4.identity([]); i.ab.mat4.translate(Oe, Oe, [Ae.x * this.worldSize, Ae.y * this.worldSize, 0]), i.ab.mat4.multiply(Oe, Oe, i.c0(this)), i.ab.mat4.translate(Oe, Oe, [-Ae.x * this.worldSize, -Ae.y * this.worldSize, 0]), i.ab.mat4.multiply(N, N, Oe), i.ab.mat4.multiply(F, F, Oe), this.inverseAdjustmentMatrix = i.c1(this); } else this.inverseAdjustmentMatrix = [1, 0, 0, 1]; if (this.mercatorMatrix = i.ab.mat4.scale([], N, [this.worldSize, this.worldSize, this.worldSize / y, 1]), this.projMatrix = N, this.invProjMatrix = i.ab.mat4.invert(new Float64Array(16), this.projMatrix), s) { const Ae = this._camera.getCameraToClipPerspective(this._fov, this.width / this.height, this._nearZ, 1 / 0); Ae[8] = 2 * -t.x / this.width, Ae[9] = 2 * t.y / this.height, this.expandedFarZProjMatrix = i.ab.mat4.mul([], Ae, T); } else this.expandedFarZProjMatrix = this.projMatrix; const G = i.ab.mat4.invert([], z); this.frustumCorners = i.c2.fromInvProjectionMatrix(G, this.horizonLineFromTop(), this.height), this.cameraFrustum = i.bR.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, 0, !s); const Z = new Float32Array(16); i.ab.mat4.identity(Z), i.ab.mat4.scale(Z, Z, [1, -1, 1]), i.ab.mat4.rotateX(Z, Z, this._pitch), i.ab.mat4.rotateZ(Z, Z, this.angle); const W = i.ab.mat4.perspective(new Float32Array(16), this._fov, this.width / this.height, this._nearZ, this._farZ); this.starsProjMatrix = i.ab.mat4.clone(W); const te = (Math.PI / 2 - this._pitch) * (this.height / this._fov) * this._horizonShift; W[8] = 2 * -t.x / this.width, W[9] = 2 * (t.y + te) / this.height, this.skyboxMatrix = i.ab.mat4.multiply(Z, W, Z); const ee = this.point, se = ee.x, oe = ee.y, he = this.width % 2 / 2, _e = this.height % 2 / 2, pe = Math.cos(this.angle), Me = Math.sin(this.angle), xe = se - Math.round(se) + pe * he + Me * _e, we = oe - Math.round(oe) + pe * _e + Me * he, ve = new Float64Array(N); if (i.ab.mat4.translate(ve, ve, [xe > 0.5 ? xe - 1 : xe, we > 0.5 ? we - 1 : we, 0]), this.alignedProjMatrix = ve, N = i.ab.mat4.create(), i.ab.mat4.scale(N, N, [this.width / 2, -this.height / 2, 1]), i.ab.mat4.translate(N, N, [1, -1, 0]), this.labelPlaneMatrix = N, N = i.ab.mat4.create(), i.ab.mat4.scale(N, N, [1, -1, 1]), i.ab.mat4.translate(N, N, [-1, -1, 0]), i.ab.mat4.scale(N, N, [2 / this.width, 2 / this.height, 1]), this.glCoordMatrix = N, this.pixelMatrix = i.ab.mat4.multiply(new Float64Array(16), this.labelPlaneMatrix, F), this._calcFogMatrices(), this._distanceTileDataCache = {}, N = i.ab.mat4.invert(new Float64Array(16), this.pixelMatrix), !N) throw new Error("failed to invert matrix"); if (this.pixelMatrixInverse = N, this.projection.name === "globe" || this.mercatorFromTransition) { this.globeMatrix = i.c3(this); const Ae = [this.globeMatrix[12], this.globeMatrix[13], this.globeMatrix[14]]; this.globeCenterInViewSpace = i.ab.vec3.transformMat4(Ae, Ae, T), this.globeRadius = this.worldSize / 2 / Math.PI - 1; } else this.globeMatrix = N; this._projMatrixCache = {}, this._alignedProjMatrixCache = {}, this._pixelsToTileUnitsCache = {}, this._expandedProjMatrixCache = {}; } _calcFogMatrices() { this._fogTileMatrixCache = {}; const t = this.cameraWorldSizeForFog, s = this.cameraPixelsPerMeter, h = this._camera.position, _ = 1 / this.height / this._pixelsPerMercatorPixel, y = [t, t, s]; i.ab.vec3.scale(y, y, _), i.ab.vec3.scale(h, h, -1), i.ab.vec3.multiply(h, h, y); const T = i.ab.mat4.create(); i.ab.mat4.translate(T, T, h), i.ab.mat4.scale(T, T, y), this.mercatorFogMatrix = T, this.worldToFogMatrix = this._camera.getWorldToCameraPosition(t, s, _); } _computeCameraPosition(t) { const s = (t = t || this.pixelsPerMeter) / this.pixelsPerMeter, h = this._camera.forward(), _ = this.point, y = this._mercatorZfromZoom(this._seaLevelZoom ? this._seaLevelZoom : this._zoom) * s - t / this.worldSize * this._centerAltitude; return [_.x / this.worldSize - h[0] * y, _.y / this.worldSize - h[1] * y, t / this.worldSize * this._centerAltitude - h[2] * y]; } _updateCameraState() { this.height && (this._camera.setPitchBearing(this._pitch, this.angle), this._camera.position = this._computeCameraPosition()); } _translateCameraConstrained(t) { const s = this._maxCameraBoundsDistance() * Math.cos(this._pitch), h = this._camera.position[2], _ = t[2]; let y = 1; this.projection.wrap && (this.center = this.center.wrap()), _ > 0 && (y = Math.min((s - h) / _, 1)), this._camera.position = i.ab.vec3.scaleAndAdd([], this._camera.position, t, y), this._updateStateFromCamera(); } _updateStateFromCamera() { const t = this._camera.position, s = this._camera.forward(), { pitch: h, bearing: _ } = this._camera.getPitchBearing(), y = i.bH(this._centerAltitude, this.center.lat) * this._pixelsPerMercatorPixel, T = this._mercatorZfromZoom(this._maxZoom) * Math.cos(i.ai(this._maxPitch)), z = Math.max((t[2] - y) / Math.cos(h), T), R = this._zoomFromMercatorZ(z); i.ab.vec3.scaleAndAdd(t, t, s, z), this._pitch = i.aw(h, i.ai(this.minPitch), i.ai(this.maxPitch)), this.angle = i.bF(_, -Math.PI, Math.PI), this._setZoom(i.aw(R, this._minZoom, this._maxZoom)), this._updateSeaLevelZoom(), this._center = this.coordinateLocation(new i.aa(t[0], t[1], t[2])), this._unmodified = !1, this._constrain(), this._calcMatrices(); } _worldSizeFromZoom(t) { return Math.pow(2, t) * this.tileSize; } _mercatorZfromZoom(t) { return this.cameraToCenterDistance / this._worldSizeFromZoom(t); } _minimumHeightOverTerrain() { const t = Math.min(this._seaLevelZoom != null ? this._seaLevelZoom : this._zoom, this._maxZoom) + 4; return this._mercatorZfromZoom(t); } _zoomFromMercatorZ(t) { return this.scaleZoom(this.cameraToCenterDistance / (t * this.tileSize)); } zoomFromMercatorZAdjusted(t) { let s = 0, h = i.bY, _ = 0, y = 1 / 0; for (; h - s > 1e-6 && h > s; ) { const T = s + 0.5 * (h - s), z = this.tileSize * Math.pow(2, T), R = this.getCameraToCenterDistance(this.projection, T, z), F = this.scaleZoom(R / (t * this.tileSize)), N = Math.abs(T - F); N < y && (y = N, _ = T), T < F ? s = T : h = T; } return _; } _terrainEnabled() { return !(!this._elevation || !this.projection.supportsTerrain && (i.w("Terrain is not yet supported with alternate projections. Use mercator or globe to enable terrain."), 1)); } anyCornerOffEdge(t, s) { const h = Math.min(t.x, s.x), _ = Math.max(t.x, s.x), y = Math.min(t.y, s.y), T = Math.max(t.y, s.y); if (y < this.horizonLineFromTop(!1)) return !0; if (this.projection.name !== "mercator") return !1; const z = [new i.P(h, y), new i.P(_, T), new i.P(h, T), new i.P(_, y)], R = this.renderWorldCopies ? -3 : 0, F = this.renderWorldCopies ? 4 : 1; for (const N of z) { const G = this.pointRayIntersection(N); if (G.t < 0) return !0; const Z = this.rayIntersectionCoordinate(G); if (Z.x < R || Z.y < 0 || Z.x > F || Z.y > 1) return !0; } return !1; } isHorizonVisible() { return this.pitch + i.c4(this.fovAboveCenter) > 88 || this.anyCornerOffEdge(new i.P(0, 0), new i.P(this.width, this.height)); } zoomDeltaToMovement(t, s) { const h = i.ab.vec3.length(i.ab.vec3.sub([], this._camera.position, t)), _ = this._zoomFromMercatorZ(h) + s; return h - this._mercatorZfromZoom(_); } getCameraPoint() { if (this.projection.name === "globe") { const t = function([s, h, _], y) { const T = [s, h, _, 1]; i.ab.vec4.transformMat4(T, T, y); const z = T[3] = Math.max(T[3], 1e-6); return T[0] /= z, T[1] /= z, T[2] /= z, T; }([this.globeMatrix[12], this.globeMatrix[13], this.globeMatrix[14]], this.pixelMatrix); return new i.P(t[0], t[1]); } { const t = Math.tan(this._pitch) * (this.cameraToCenterDistance || 1); return this.centerPoint.add(new i.P(0, t)); } } getCameraToCenterDistance(t, s = this.zoom, h = this.worldSize) { const _ = i.b$(t, s, this.width, this.height, 1024), y = t.pixelSpaceConversion(this.center.lat, h, _); let T = 0.5 / Math.tan(0.5 * this._fov) * this.height * y; return this.isOrthographic && (T = Wl(1, T, Tt(this.pitch >= 15 ? 1 : this.pitch / 15))), T; } getWorldToCameraMatrix() { const t = this._camera.getWorldToCamera(this.worldSize, this.projection.zAxisUnit === "meters" ? this.pixelsPerMeter : 1); return this.projection.name === "globe" && i.ab.mat4.multiply(t, t, this.globeMatrix), t; } getFrustum(t) { return i.bR.fromInvProjectionMatrix(this.invProjMatrix, this.worldSize, t, this.projection.zAxisUnit === "meters"); } } const Mo = (c, t) => { if (t > 0 && c.terrain && i.w("Cutoff is currently disabled on terrain"), t <= 0 || c.terrain) return { shouldRenderCutoff: !1, uniformValues: { u_cutoff_params: [0, 0, 0, 1] } }; const s = c.transform, h = Math.max(Math.abs(s._zoom - (c.minCutoffZoom - 1)), 1), _ = s.isLODDisabled(!1) ? i.ac(60, 45, s.pitch) : i.ac(30, 15, s.pitch), y = s._farZ - s._nearZ, T = t * s.height, z = ((1 - (R = _)) * s.cameraToCenterDistance + R * (s._farZ + T)) * h; var R; return { shouldRenderCutoff: _ < 1, uniformValues: { u_cutoff_params: [s._nearZ, s._farZ, (z - s._nearZ) / y, (z - T - s._nearZ) / y] } }; }, gs = { cascadeCount: 2, normalOffset: 3, shadowMapResolution: 2048 }; class Gh { constructor(t, s) { this.aabb = t, this.lastCascade = s; } } class Dr { add(t, s) { const h = this.receivers[t.key]; h !== void 0 ? (h.aabb.min[0] = Math.min(h.aabb.min[0], s.min[0]), h.aabb.min[1] = Math.min(h.aabb.min[1], s.min[1]), h.aabb.min[2] = Math.min(h.aabb.min[2], s.min[2]), h.aabb.max[0] = Math.max(h.aabb.max[0], s.max[0]), h.aabb.max[1] = Math.max(h.aabb.max[1], s.max[1]), h.aabb.max[2] = Math.max(h.aabb.max[2], s.max[2])) : this.receivers[t.key] = new Gh(s, null); } clear() { this.receivers = {}; } get(t) { return this.receivers[t.key]; } computeRequiredCascades(t, s, h) { const _ = i.cd.fromPoints(t.points); let y = 0; for (const T in this.receivers) { const z = this.receivers[T]; if (!z || !_.intersectsAabb(z.aabb)) continue; z.aabb.min = _.closestPoint(z.aabb.min), z.aabb.max = _.closestPoint(z.aabb.max); const R = z.aabb.getCorners(); for (let F = 0; F < h.length; F++) { let N = !0; for (const G of R) { const Z = [G[0] * s, G[1] * s, G[2]]; if (i.ab.vec3.transformMat4(Z, Z, h[F].matrix), Z[0] < -1 || Z[0] > 1 || Z[1] < -1 || Z[1] > 1) { N = !1; break; } } if (z.lastCascade = F, y = Math.max(y, F), N) break; } } return y + 1; } } class So { constructor(t) { this.painter = t, this._enabled = !1, this._shadowLayerCount = 0, this._numCascadesToRender = 0, this._cascades = [], this._groundShadowTiles = [], this._receivers = new Dr(), this._depthMode = new Wt(t.context.gl.LEQUAL, Wt.ReadWrite, [0, 1]), this._uniformValues = { u_light_matrix_0: new Float32Array(16), u_light_matrix_1: new Float32Array(16), u_shadow_intensity: 0, u_fade_range: [0, 0], u_shadow_normal_offset: [1, 1, 1], u_shadow_texel_size: 1, u_shadow_map_resolution: 1, u_shadow_direction: [0, 0, 1], u_shadow_bias: [36e-5, 12e-4, 0.012], u_shadowmap_0: 0, u_shadowmap_1: 0 }, this._forceDisable = !1, this.useNormalOffset = !1, t.tp.registerParameter(this, ["Shadows"], "_forceDisable", { label: "forceDisable" }, () => { this.painter.style.map.triggerRepaint(); }), t.tp.registerParameter(gs, ["Shadows"], "cascadeCount", { min: 1, max: 2, step: 1 }), t.tp.registerParameter(gs, ["Shadows"], "normalOffset", { min: 0, max: 10, step: 0.05 }), t.tp.registerParameter(gs, ["Shadows"], "shadowMapResolution", { min: 32, max: 2048, step: 32 }), t.tp.registerBinding(this, ["Shadows"], "_numCascadesToRender", { readonly: !0, label: "numCascadesToRender" }); } destroy() { for (const t of this._cascades) t.texture.destroy(), t.framebuffer.destroy(); this._cascades = []; } updateShadowParameters(t, s) { const h = this.painter; if (this._enabled = !1, this._shadowLayerCount = 0, this._receivers.clear(), !s || !s.properties) return; const _ = s.properties.get("shadow-intensity"); if (!s.shadowsEnabled() || _ <= 0 || (this._shadowLayerCount = h.style.order.reduce((te, ee) => { const se = h.style._mergedLayers[ee]; return te + (se.hasShadowPass() && !se.isHidden(t.zoom) ? 1 : 0); }, 0), this._enabled = this._shadowLayerCount > 0, !this.enabled)) return; const y = h.context, T = gs.shadowMapResolution, z = gs.shadowMapResolution; if (this._cascades.length === 0 || gs.shadowMapResolution !== this._cascades[0].texture.size[0]) { this._cascades = []; for (let te = 0; te < gs.cascadeCount; ++te) { const ee = h._shadowMapDebug, se = y.gl, oe = y.createFramebuffer(T, z, ee, "texture"), he = new i.T(y, { width: T, height: z, data: null }, se.DEPTH_COMPONENT16); if (oe.depthAttachment.set(he.texture), ee) { const _e = new i.T(y, { width: T, height: z, data: null }, se.RGBA8); oe.colorAttachment.set(_e.texture); } this._cascades.push({ framebuffer: oe, texture: he, matrix: [], far: 0, boundingSphereRadius: 0, frustum: new i.bR(), scale: 0 }); } } this.shadowDirection = Yo(s); let R = 0; if (t.elevation) { const te = t.elevation, ee = [1e4, -1e4]; te.visibleDemTiles.filter((se) => se.dem).forEach((se) => { const oe = se.dem.tree; ee[0] = Math.min(ee[0], oe.minimums[0]), ee[1] = Math.max(ee[1], oe.maximums[0]); }), ee[0] !== 1e4 && (R = (ee[1] - ee[0]) * te.exaggeration()); } const F = 1.5 * t.cameraToCenterDistance, N = 3 * F, G = new Float64Array(16); for (let te = 0; te < this._cascades.length; ++te) { const ee = this._cascades[te]; let se = t.height / 50, oe = 1; gs.cascadeCount === 1 ? oe = N : te === 0 ? oe = F : (se = F, oe = N); const [he, _e] = Eo(t, this.shadowDirection, se, oe, gs.shadowMapResolution, R); ee.scale = t.scale, ee.matrix = he, ee.boundingSphereRadius = _e, i.ab.mat4.invert(G, ee.matrix), ee.frustum = i.bR.fromInvProjectionMatrix(G, 1, 0, !0), ee.far = oe; } const Z = this._cascades.length - 1; this._uniformValues.u_fade_range = [0.75 * this._cascades[Z].far, this._cascades[Z].far], this._uniformValues.u_shadow_intensity = _, this._uniformValues.u_shadow_direction = [this.shadowDirection[0], this.shadowDirection[1], this.shadowDirection[2]], this._uniformValues.u_shadow_texel_size = 1 / gs.shadowMapResolution, this._uniformValues.u_shadow_map_resolution = gs.shadowMapResolution, this._uniformValues.u_shadowmap_0 = bs.ShadowMap0, this._uniformValues.u_shadowmap_1 = bs.ShadowMap0 + 1, this._groundShadowTiles = h.transform.coveringTiles({ tileSize: 512, renderWorldCopies: !0 }); const W = h.transform.elevation; for (const te of this._groundShadowTiles) { let ee = { min: 0, max: 0 }; if (W) { const se = W.getMinMaxForTile(te); se && (ee = se); } this.addShadowReceiver(te.toUnwrapped(), ee.min, ee.max); } } get enabled() { return this._enabled && !this._forceDisable; } set enabled(t) { this._enabled = t; } drawShadowPass(t, s) { if (!this.enabled) return; const h = this.painter, _ = h.context; this._numCascadesToRender = this._receivers.computeRequiredCascades(h.transform.getFrustum(0), h.transform.worldSize, this._cascades), _.viewport.set([0, 0, gs.shadowMapResolution, gs.shadowMapResolution]); for (let y = 0; y < this._numCascadesToRender; ++y) { h.currentShadowCascade = y, _.bindFramebuffer.set(this._cascades[y].framebuffer.framebuffer), _.clear({ color: i.aj.white, depth: 1 }); for (const T of t.order) { const z = t._mergedLayers[T]; if (!z.hasShadowPass() || z.isHidden(h.transform.zoom)) continue; const R = t.getLayerSourceCache(z), F = R ? s[R.id] : void 0; (z.type === "model" || F && F.length) && h.renderLayer(h, R, z, F); } } h.currentShadowCascade = 0; } drawGroundShadows() { if (!this.enabled) return; const t = this.painter, s = t.style, h = t.context, _ = s.directionalLight, y = s.ambientLight; if (!_ || !y) return; const T = [], z = Mo(t, t.longestCutoffRange); z.shouldRenderCutoff && T.push("RENDER_CUTOFF"), T.push("RENDER_SHADOWS", "DEPTH_TEXTURE"), this.useNormalOffset && T.push("NORMAL_OFFSET"); const R = cr(s, _, y), F = new Wt(h.gl.LEQUAL, Wt.ReadOnly, t.depthRangeFor3D); for (const N of this._groundShadowTiles) { const G = N.toUnwrapped(), Z = t.isTileAffectedByFog(N), W = t.getOrCreateProgram("groundShadow", { defines: T, overrideFog: Z }); this.setupShadows(G, W), t.uploadCommonUniforms(h, W, G, null, z); const te = { u_matrix: t.transform.calculateProjMatrix(G), u_ground_shadow_factor: R }; W.draw(t, h.gl.TRIANGLES, F, ci.disabled, bi.multiply, ti.disabled, te, "ground_shadow", t.tileExtentBuffer, t.quadTriangleIndexBuffer, t.tileExtentSegments, {}, t.transform.zoom, null, null); } } getShadowPassColorMode() { return this.painter._shadowMapDebug ? bi.unblended : bi.disabled; } getShadowPassDepthMode() { return this._depthMode; } getShadowCastingLayerCount() { return this._shadowLayerCount; } calculateShadowPassMatrixFromTile(t) { const s = this.painter.transform, h = s.calculatePosMatrix(t, s.worldSize); return i.ab.mat4.multiply(h, this._cascades[this.painter.currentShadowCascade].matrix, h), Float32Array.from(h); } calculateShadowPassMatrixFromMatrix(t) { return i.ab.mat4.multiply(t, this._cascades[this.painter.currentShadowCascade].matrix, t), Float32Array.from(t); } setupShadows(t, s, h, _ = 0) { if (!this.enabled) return; const y = this.painter.transform, T = this.painter.context, z = T.gl, R = this._uniformValues, F = new Float64Array(16), N = y.calculatePosMatrix(t, y.worldSize); for (let G = 0; G < this._cascades.length; G++) i.ab.mat4.multiply(F, this._cascades[G].matrix, N), R[G === 0 ? "u_light_matrix_0" : "u_light_matrix_1"] = Float32Array.from(F), T.activeTexture.set(z.TEXTURE0 + bs.ShadowMap0 + G), this._cascades[G].texture.bind(z.NEAREST, z.CLAMP_TO_EDGE); if (this.useNormalOffset = !!h, this.useNormalOffset) { const G = i.cc(t.canonical), Z = 2 / y.tileSize * i.ag / gs.shadowMapResolution, W = Z * this._cascades[0].boundingSphereRadius, te = Z * this._cascades[this._cascades.length - 1].boundingSphereRadius, ee = (h === "vector-tile" ? 1 : 3) / Math.pow(2, _ - t.canonical.z - (1 - y.zoom + Math.floor(y.zoom))); R.u_shadow_normal_offset = [G, W * ee, te * ee], R.u_shadow_bias = [6e-5, 12e-4, 0.012]; } else R.u_shadow_bias = [36e-5, 12e-4, 0.012]; s.setShadowUniformValues(T, R); } setupShadowsFromMatrix(t, s, h = !1) { if (!this.enabled) return; const _ = this.painter.context, y = _.gl, T = this._uniformValues, z = new Float64Array(16); for (let R = 0; R < gs.cascadeCount; R++) i.ab.mat4.multiply(z, this._cascades[R].matrix, t), T[R === 0 ? "u_light_matrix_0" : "u_light_matrix_1"] = Float32Array.from(z), _.activeTexture.set(y.TEXTURE0 + bs.ShadowMap0 + R), this._cascades[R].texture.bind(y.NEAREST, y.CLAMP_TO_EDGE); if (this.useNormalOffset = h, h) { const R = gs.normalOffset; T.u_shadow_normal_offset = [1, R, R], T.u_shadow_bias = [6e-5, 12e-4, 0.012]; } else T.u_shadow_bias = [36e-5, 12e-4, 0.012]; s.setShadowUniformValues(_, T); } getShadowUniformValues() { return this._uniformValues; } getCurrentCascadeFrustum() { return this._cascades[this.painter.currentShadowCascade].frustum; } computeSimplifiedTileShadowVolume(t, s, h, _) { if (_[2] >= 0) return {}; const y = function(R, F, N) { const G = N / (1 << R.canonical.z); return new i.cd([R.canonical.x * G + R.wrap * N, R.canonical.y * G + R.wrap * N, 0], [(R.canonical.x + 1) * G + R.wrap * N, (R.canonical.y + 1) * G + R.wrap * N, F]); }(t, s, h).getCorners(), T = s / -_[2]; _[0] < 0 ? (i.ab.vec3.add(y[0], y[0], [_[0] * T, 0, 0]), i.ab.vec3.add(y[3], y[3], [_[0] * T, 0, 0])) : _[0] > 0 && (i.ab.vec3.add(y[1], y[1], [_[0] * T, 0, 0]), i.ab.vec3.add(y[2], y[2], [_[0] * T, 0, 0])), _[1] < 0 ? (i.ab.vec3.add(y[0], y[0], [0, _[1] * T, 0]), i.ab.vec3.add(y[1], y[1], [0, _[1] * T, 0])) : _[1] > 0 && (i.ab.vec3.add(y[2], y[2], [0, _[1] * T, 0]), i.ab.vec3.add(y[3], y[3], [0, _[1] * T, 0])); const z = {}; return z.vertices = y, z.planes = [Kr(y[1], y[0], y[4]), Kr(y[2], y[1], y[5]), Kr(y[3], y[2], y[6]), Kr(y[0], y[3], y[7])], z; } addShadowReceiver(t, s, h) { this._receivers.add(t, i.cd.fromTileIdAndHeight(t, s, h)); } getMaxCascadeForTile(t) { const s = this._receivers.get(t); return s && s.lastCascade ? s.lastCascade : 0; } } function Kr(c, t, s) { const h = i.ab.vec3.sub([], s, t), _ = i.ab.vec3.sub([], c, t), y = i.ab.vec3.cross([], h, _), T = i.ab.vec3.length(y); return T === 0 ? [0, 0, 1, 0] : (i.ab.vec3.scale(y, y, 1 / T), [y[0], y[1], y[2], -i.ab.vec3.dot(y, t)]); } function Yo(c) { const t = c.properties.get("direction"), s = i.cb(t.x, t.y, t.z); s[2] = i.aw(s[2], 0, 75); const h = i.ce([s[0], s[1], s[2]]); return i.ab.vec3.fromValues(h.x, h.y, h.z); } function cr(c, t, s) { const h = t.properties.get("color-use-theme") === "none", _ = t.properties.get("color"), y = t.properties.get("intensity"), T = t.properties.get("direction"), z = [T.x, T.y, T.z], R = s.properties.get("color-use-theme") === "none", F = s.properties.get("color"), N = s.properties.get("intensity"), G = Math.max(i.ab.vec3.dot([0, 0, 1], z), 0), Z = [0, 0, 0]; i.ab.vec3.scale(Z, F.toRenderColor(R ? null : c.getLut(t.scope)).toArray01Linear().slice(0, 3), N); const W = [0, 0, 0]; return i.ab.vec3.scale(W, _.toRenderColor(h ? null : c.getLut(s.scope)).toArray01Linear().slice(0, 3), G * y), i.cf([Z[0] > 0 ? Z[0] / (Z[0] + W[0]) : 0, Z[1] > 0 ? Z[1] / (Z[1] + W[1]) : 0, Z[2] > 0 ? Z[2] / (Z[2] + W[2]) : 0]); } function Eo(c, t, s, h, _, y) { const T = c.zoom, z = c.scale, R = c.worldSize, F = 1 / R, N = c.aspect, G = Math.sqrt(1 + N * N) * Math.tan(0.5 * c.fovX), Z = G * G, W = h - s, te = h + s; let ee, se; Z > W / te ? (ee = h, se = h * G) : (ee = 0.5 * te * (1 + Z), se = 0.5 * Math.sqrt(W * W + 2 * (h * h + s * s) * Z + te * te * Z * Z)); const oe = c.projection.pixelsPerMeter(c.center.lat, R), he = c._camera.getCameraToWorldMercator(), _e = [0, 0, -ee * F]; i.ab.vec3.transformMat4(_e, _e, he); let pe = se * F; const Me = c._edgeInsets; if (!(Me.left === 0 && Me.top === 0 && Me.right === 0 && Me.bottom === 0 || Me.left === Me.right && Me.top === Me.bottom)) { const _t = c._camera.getWorldToCamera(c.worldSize, c.projection.zAxisUnit === "meters" ? oe : 1), ct = c._camera.getCameraToClipPerspective(c._fov, c.width / c.height, s, h); ct[8] = 2 * -c.centerOffset.x / c.width, ct[9] = 2 * c.centerOffset.y / c.height; const nt = new Float64Array(16); i.ab.mat4.mul(nt, ct, _t); const Lt = new Float64Array(16); i.ab.mat4.invert(Lt, nt); const bt = i.bR.fromInvProjectionMatrix(Lt, R, T, !0); for (const zt of bt.points) { const Bt = ((xe = zt)[0] /= z, xe[1] /= z, xe[2] = i.bH(xe[2], c._center.lat), xe); pe = Math.max(pe, i.ab.vec3.len(i.ab.vec3.subtract([], _e, Bt))); } } var xe; pe *= _ / (_ - 1); const we = Math.acos(t[2]), ve = Math.atan2(-t[0], -t[1]), Ae = new To(); Ae.position = _e, Ae.setPitchBearing(we, ve); const Oe = Ae.getWorldToCamera(R, oe), Xe = pe * R, He = Math.min(c._mercatorZfromZoom(17) * R * -2, -2 * Xe), ke = Ae.getCameraToClipOrthographic(-Xe, Xe, -Xe, Xe, He, (Xe + y * oe) / t[2]), Ne = new Float64Array(16); i.ab.mat4.multiply(Ne, ke, Oe); const st = i.ab.vec3.fromValues(Math.floor(1e6 * _e[0]) / 1e6 * R, Math.floor(1e6 * _e[1]) / 1e6 * R, 0), ut = 0.5 * _, xt = [0, 0, 0]; i.ab.vec3.transformMat4(xt, st, Ne), i.ab.vec3.scale(xt, xt, ut); const Ge = [Math.floor(xt[0]), Math.floor(xt[1]), Math.floor(xt[2])], lt = [0, 0, 0]; i.ab.vec3.sub(lt, xt, Ge), i.ab.vec3.scale(lt, lt, -1 / ut); const Je = new Float64Array(16); return i.ab.mat4.identity(Je), i.ab.mat4.translate(Je, Je, lt), i.ab.mat4.multiply(Ne, Je, Ne), [Ne, Xe]; } class Zh extends i.E { constructor(t) { super(), this.requestManager = t, this.models = { "": {} }, this.numModelsLoading = {}; } loadModel(t, s) { return i.aM(this.requestManager.transformRequest(s, i.R.Model).url).then((h) => { if (!h) return; const _ = i.aN(h), y = new i.aO(t, void 0, void 0, _); return y.computeBoundsAndApplyParent(), y; }).catch((h) => { if (h && h.status === 404) return null; this.fire(new i.y(new Error(`Could not load model ${t} from ${s}: ${h.message}`))); }); } load(t, s) { this.models[s] || (this.models[s] = {}); const h = Object.keys(t); this.numModelsLoading[s] = (this.numModelsLoading[s] || 0) + h.length; const _ = []; for (const y of h) _.push(this.loadModel(y, t[y])); Promise.allSettled(_).then((y) => { for (let T = 0; T < y.length; T++) { const { status: z, value: R } = y[T]; z === "fulfilled" && R && (this.models[s][h[T]] = { model: R, numReferences: 1 }); } this.numModelsLoading[s] -= h.length, this.fire(new i.z("data", { dataType: "style" })); }).catch((y) => { this.fire(new i.y(new Error(`Could not load models: ${y.message}`))); }); } isLoaded() { for (const t in this.numModelsLoading) if (this.numModelsLoading[t] > 0) return !1; return !0; } hasModel(t, s) { return !!this.getModel(t, s); } getModel(t, s) { return this.models[s] || (this.models[s] = {}), this.models[s][t] ? this.models[s][t].model : void 0; } addModel(t, s, h) { this.models[h] || (this.models[h] = {}), this.hasModel(t, h) && this.models[h][t].numReferences++, this.load({ [t]: this.requestManager.normalizeModelURL(s) }, h); } addModels(t, s) { this.models[s] || (this.models[s] = {}); const h = {}; for (const _ in t) this.models[s][_] = {}, h[_] = this.requestManager.normalizeModelURL(t[_]); this.load(h, s); } addModelsFromBucket(t, s) { this.models[s] || (this.models[s] = {}); const h = {}; for (const _ of t) this.hasModel(_, s) ? this.models[s][_].numReferences++ : h[_] = this.requestManager.normalizeModelURL(_); this.load(h, s); } removeModel(t, s) { if (this.models[s] && this.models[s][t] && (this.models[s][t].numReferences--, this.models[s][t].numReferences === 0)) { const h = this.models[s][t].model; delete this.models[s][t], h.destroy(); } } listModels(t) { return this.models[t] || (this.models[t] = {}), Object.keys(this.models[t]); } upload(t, s) { this.models[s] || (this.models[s] = {}); for (const h in this.models[s]) this.models[s][h].model && this.models[s][h].model.upload(t.context); } } const Uc = new i.a5({ data: new i.a6(i.a3.colorTheme.data) }), Ua = { "mbx-indoor-active-floorplans": { default: ["literal", []] }, "mbx-indoor-underground": { default: ["literal", !1] }, "mbx-indoor-loaded-levels": { default: ["literal", []] }, "mbx-indoor-level-height": { default: ["literal", {}] }, "mbx-indoor-level-base": { default: ["literal", {}] }, "mbx-indoor-level-selected": { default: ["literal", {}] }, "mbx-indoor-level-overlapped": { default: ["literal", {}] } }; function $l(c) { return c = c || {}, Object.assign(c, Ua); } class yl extends i.E { constructor(t) { super(), this.mergeFloors = !0, this._scope = void 0, this._queryFeatureSetId = void 0, this._buildingEntryFeatureSetId = void 0, this._selectedFloorplan = void 0, this._indoorData = void 0, this._selectedLevel = void 0, this._floorplanStates = {}, i.aP(["_onLoad", "_onMove", "_checkFloorplanVisible"], this), this._map = t, this._checkFloorplanVisible(!0), this._map.on("load", this._onLoad), this._map.on("move", this._onMove); } destroy() { this._map.indoor.off("load", this._onLoad), this._map.indoor.off("move", this._onMove), this._map = void 0; } _onLoad() { this._map.style.forEachFragmentStyle((t) => { t.stylesheet.indoor && (this._queryFeatureSetId ? this.fire(new i.y(new Error("Multiple indoor map styles detected, simultaneous usage is not allowed currently."))) : (this._queryFeatureSetId = t.stylesheet.indoor.floorplanFeaturesetId, this._buildingEntryFeatureSetId = t.stylesheet.indoor.buildingFeaturesetId, this._scope = t.scope)); }), this._queryFeatureSetId && this._buildingEntryFeatureSetId && this._map.addInteraction("mbx-indoor-buildingclick", { type: "click", target: { featuresetId: this._buildingEntryFeatureSetId, importId: this._scope }, handler: (t) => (t.feature && t.feature.properties.floorplan && this.selectFloorplan(t.feature.properties.floorplan), !0) }), this._checkFloorplanVisible(!0); } _onMove() { this._checkFloorplanVisible(!1); } _checkFloorplanVisible(t) { if (!this._queryFeatureSetId || !this._map.isStyleLoaded() || this._map.transform.zoom < 13) return; this._indoorData && !function(T, z) { const [R, F] = T, { center: N, radius: G } = z, [Z, W] = N, te = Math.abs(R - Z); return Math.sqrt((te > 180 ? 360 - te : te) ** 2 + (F - W) ** 2) <= G; }([this._map.getCenter().lng, this._map.getCenter().lat], this._indoorData.circumCircle) && (this._indoorData = void 0, this._selectedFloorplan = void 0, this._map.setConfigProperty(this._scope, "mbx-indoor-underground", !1), this._map.setConfigProperty(this._scope, "mbx-indoor-active-floorplans", ["literal", []]), this.fire(new i.z("floorplangone"))); const s = { target: { featuresetId: this._queryFeatureSetId, importId: this._scope } }, h = new i.P(this._map.transform.width / 2, this._map.transform.height / 2), _ = [new i.P(0, 0), new i.P(this._map.transform.width, this._map.transform.height)], y = this._map.queryRenderedFeatures(t ? _ : h, s); y.length > 0 && (this._selectedFloorplan && y[0].properties.id === this._selectedFloorplan.properties.id || (this._selectedFloorplan = y[0], this._floorplanSelected(!1))); } _floorplanSelected(t) { this._indoorData = JSON.parse(this._selectedFloorplan.properties["indoor-data"]), this._indoorData.id = this._selectedFloorplan.properties.id, this._indoorData.circumCircle = function(y) { const [[T, z], [R, F]] = y, N = (R - T + 360) % 360, G = N > 180 ? 360 - N : N; return { center: [(T + G / 2 + 360) % 360, (z + F) / 2], radius: Math.sqrt(G ** 2 + (F - z) ** 2) / 2 }; }(this._indoorData.extent), this._floorplanStates[this._indoorData.id] || (this._floorplanStates[this._indoorData.id] = {}); const s = this._floorplanStates[this._indoorData.id].selectedBuilding, h = this._floorplanStates[this._indoorData.id].selectedLevel; let _; if (this._map.setConfigProperty(this._scope, "mbx-indoor-active-floorplans", this._indoorData.floorplanIDs), this._selectedLevel) for (const y of this._indoorData.levels) y.id === this._selectedLevel.id && (_ = y.id); if (this.fire(new i.z("floorplanselected", { buildings: this._indoorData.buildings, levels: this._indoorData.levels, selectedLevelId: _ })), s) { const y = this._indoorData.buildings.find((T) => T.id === s); this._buildingSelected(y, !1); } else this._indoorData.buildings.length > 0 && this._buildingSelected(this._indoorData.buildings[0], !1); if (h) { const y = this._indoorData.levels.find((T) => T.id === h); this._updateLevels(y, t); } else t && this._indoorData["default-levels"].length > 0 && this.selectLevel(this._indoorData["default-levels"][0]); } _buildingSelected(t, s) { s && t && t.extent && this._map.fitBounds(t.extent, { pitch: this._map.getPitch(), bearing: this._map.getBearing() }), this._floorplanStates[this._indoorData.id].selectedBuilding = t ? t.id : void 0; const h = this._indoorData.levels.filter((_) => t.levels.includes(_.id)); this.fire(new i.z("buildingselected", { buildingId: t.id, levels: h })); } _levelSelected(t) { if (t === "overview") this._updateLevels(void 0, !0); else { const s = this._indoorData.levels.find((h) => h.id === t); this._updateLevels(s, !0); } this.fire(new i.z("levelselected", { levelId: t === "overview" ? void 0 : t })); } _updateLevels(t, s) { if (!t) return this._map.setConfigProperty(this._scope, "mbx-indoor-loaded-levels", ["literal", []]), this._map.setConfigProperty(this._scope, "mbx-indoor-underground", !1), this._floorplanStates[this._indoorData.id].selectedLevel = void 0, void (s && this._indoorData.extent && this._map.fitBounds(this._indoorData.extent, { pitch: this._map.getPitch(), bearing: this._map.getBearing() })); function h(F) { const N = F.indexOf("/floor/"); if (N === -1) return F; const G = N + 7, Z = F.indexOf("/", G); return Z === -1 ? F.slice(G) : F.slice(G, Z); } this._selectedLevel = t, this._floorplanStates[this._indoorData.id].selectedLevel = t ? t.id : void 0; const _ = [], y = {}, T = {}, z = {}, R = {}; for (const F of this._indoorData.levels) if (_.push(F.id), y[F.id] = F.height, T[F.id] = F.base, t) { if (this.mergeFloors) { const N = h(t.id), G = h(F.id); z[F.id] = G === N ? "true" : "false"; } else z[F.id] = F.id === t.id ? "true" : "false"; R[F.id] = F.base < t.base ? "true" : "false"; } else R[F.id] = !0; if (this._map.setConfigProperty(this._scope, "mbx-indoor-loaded-levels", ["literal", _]), this._map.setConfigProperty(this._scope, "mbx-indoor-level-height", ["literal", y]), this._map.setConfigProperty(this._scope, "mbx-indoor-level-base", ["literal", T]), this._map.setConfigProperty(this._scope, "mbx-indoor-level-selected", ["literal", z]), this._map.setConfigProperty(this._scope, "mbx-indoor-level-overlapped", ["literal", R]), t && (this._map.setConfigProperty(this._scope, "mbx-indoor-underground", !!t.isUnderground), s && t.extent)) { const F = this._map.cameraForBounds(t.extent, { pitch: this._map.getPitch(), bearing: this._map.getBearing() }), N = this._map.getZoom(), G = F.zoom ? Math.abs(N - F.zoom) : 0; this._map.fitBounds(t.extent, G >= 1 ? { pitch: this._map.getPitch(), bearing: this._map.getBearing() } : { pitch: this._map.getPitch(), bearing: this._map.getBearing(), zoom: N }); } } selectFloorplan(t) { const s = { target: { featuresetId: this._queryFeatureSetId, importId: this._scope } }, h = [new i.P(0, 0), new i.P(this._map.transform.width, this._map.transform.height)], _ = this._map.queryRenderedFeatures(h, s); if (_.length > 0) { for (const y of _) if (JSON.parse(y.properties["indoor-data"]).floorplanIDs.includes(t)) { this._selectedFloorplan = y, this._floorplanSelected(!0); break; } } } selectBuilding(t) { const s = this._indoorData.buildings.find((h) => h.id === t); this._buildingSelected(s, !0); } selectLevel(t) { this._levelSelected(t); } } function _a(c) { if (!c.metadata || !c.metadata.content_area) return; const t = i.q.devicePixelRatio, { left: s, top: h, width: _, height: y } = c.metadata.content_area, T = s * t, z = h * t; return [T, z, T + _ * t, z + y * t]; } function ga(c) { if (c) return c.map(([t, s]) => [t * i.q.devicePixelRatio, s * i.q.devicePixelRatio]); } const Po = (c, t) => Pe(c, t && t.filter((s) => s.identifier !== "source.canvas")), Hh = i.ay(Oi, ["addLayer", "removeLayer", "setLights", "setPaintProperty", "setLayoutProperty", "setSlot", "setFilter", "addSource", "removeSource", "setLayerZoomRange", "setLight", "setTransition", "setGeoJSONSourceData", "setTerrain", "setFog", "setSnow", "setRain", "setProjection", "setCamera", "addImport", "removeImport", "updateImport"]), td = i.ay(Oi, ["setCenter", "setZoom", "setBearing", "setPitch"]), ja = /* @__PURE__ */ new Set(["background", "sky", "slot", "custom"]), jc = { version: 8, layers: [], sources: {} }, Gc = { duration: 300, delay: 0 }; class hr extends i.E { constructor(t, s = {}) { super(), this.map = t, this.scope = s.scope || "", this.globalId = null, this.fragments = [], this.importDepth = s.importDepth || 0, this.importsCache = s.importsCache || /* @__PURE__ */ new Map(), this.resolvedImports = s.resolvedImports || /* @__PURE__ */ new Set(), this.transition = i.l({}, Gc), this._buildingIndex = new Gl(this), this.crossTileSymbolIndex = new Hl(), this._mergedOrder = [], this._drapedFirstOrder = [], this._mergedLayers = {}, this._mergedSourceCaches = {}, this._mergedOtherSourceCaches = {}, this._mergedSymbolSourceCaches = {}, this._clipLayerPresent = !1, this._has3DLayers = !1, this._hasCircleLayers = !1, this._hasSymbolLayers = !1, this._changes = s.styleChanges || new Zr(), this.dispatcher = s.dispatcher ? s.dispatcher : new i.D(i.ci(), this), s.imageManager ? this.imageManager = s.imageManager : (this.imageManager = new Ws(this.map._spriteFormat), this.imageManager.setEventedParent(this)), this.imageManager.createScope(this.scope), this.glyphManager = s.glyphManager ? s.glyphManager : new i.cj(t._requestManager, s.localFontFamily ? i.ck.all : s.localIdeographFontFamily ? i.ck.ideographs : i.ck.none, s.localFontFamily || s.localIdeographFontFamily), s.modelManager ? this.modelManager = s.modelManager : (this.modelManager = new Zh(t._requestManager), this.modelManager.setEventedParent(this)), this._layers = {}, this._sourceCaches = {}, this._otherSourceCaches = {}, this._symbolSourceCaches = {}, this._loaded = !1, this._precompileDone = !1, this._shouldPrecompile = !1, this._availableImages = [], this._order = [], this._markersNeedUpdate = !1, this.options = s.configOptions ? s.configOptions : /* @__PURE__ */ new Map(), this._configDependentLayers = s.configDependentLayers ? s.configDependentLayers : /* @__PURE__ */ new Set(), this._config = s.config, this._styleColorTheme = { lut: null, lutLoading: !1, lutLoadingCorrelationID: 0, colorTheme: null, colorThemeOverride: s.colorThemeOverride }, this._styleColorThemeForScope = {}, this._initialConfig = s.initialConfig, this.dispatcher.broadcast("setReferrer", i.cl()); const h = this; this._rtlTextPluginCallback = hr.registerForPluginStateChange((_) => { h.dispatcher.broadcast("syncRTLPluginState", { pluginStatus: _.pluginStatus, pluginURL: _.pluginURL }, (y, T) => { if (i.cm(y), T && T.every((z) => z)) for (const z in h._sourceCaches) { const R = h._sourceCaches[z], F = R.getSource().type; F !== "vector" && F !== "geojson" || R.reload(); } }); }), this.on("data", (_) => { if (_.dataType !== "source" || _.sourceDataType !== "metadata") return; const y = this.getOwnSource(_.sourceId); if (y && y.vectorLayerIds) for (const T in this._layers) { const z = this._layers[T]; z.source === y.id && this._validateLayer(z); } }); } load(t) { return t ? (typeof t == "string" ? this.loadURL(t) : this.loadJSON(t), this) : this; } _getGlobalId(t) { if (!t) return null; if (typeof t == "string") { if (i.f(t)) return t; const s = i.cn(t); if (!s.startsWith("http")) try { return new URL(s, location.href).toString(); } catch { return s; } return s; } return `json://${i.co(JSON.stringify(t))}`; } _diffStyle(t, s, h) { this.globalId = this._getGlobalId(t); const _ = (y, T) => { try { T(null, this.setState(y, h)); } catch (z) { T(z, !1); } }; if (typeof t == "string") { const y = this.map._requestManager.normalizeStyleURL(t), T = this.map._requestManager.transformRequest(y, i.R.Style); i.n(T, (z, R) => { z ? this.fire(new i.y(z)) : R && _(R, s); }); } else typeof t == "object" && _(t, s); } loadURL(t, s = {}) { this.fire(new i.z("dataloading", { dataType: "style" })); const h = typeof s.validate == "boolean" ? s.validate : !i.f(t); this.globalId = this._getGlobalId(t), t = this.map._requestManager.normalizeStyleURL(t, s.accessToken), this.resolvedImports.add(t); const _ = this.importsCache.get(t); if (_) return this._load(_, h); const y = this.map._requestManager.transformRequest(t, i.R.Style); this._request = i.n(y, (T, z) => { if (this._request = null, T) this.fire(new i.y(T)); else if (z) return this.importsCache.set(t, z), this._load(z, h); }); } loadJSON(t, s = {}) { this.fire(new i.z("dataloading", { dataType: "style" })), this.globalId = this._getGlobalId(t), this._request = i.q.frame(() => { this._request = null, this._load(t, s.validate !== !1); }); } loadEmpty() { this.fire(new i.z("dataloading", { dataType: "style" })), this._load(jc, !1); } _loadImports(t, s, h) { if (this.importDepth >= 4) return i.w("Style doesn't support nesting deeper than 5"), Promise.resolve(); const _ = []; for (const y of t) { const T = this._createFragmentStyle(y), z = new Promise((N) => { T.once("style.import.load", N), T.once("error", N); }).then(() => this.mergeAll()); if (_.push(z), this.resolvedImports.has(y.url)) { T.loadEmpty(); continue; } const R = y.data || this.importsCache.get(y.url); R ? (T.loadJSON(R, { validate: s }), this._isInternalStyle(R) && (T.globalId = null)) : y.url ? T.loadURL(y.url, { validate: s }) : T.loadEmpty(); const F = { style: T, id: y.id, config: y.config }; if (h) { const N = this.fragments.findIndex(({ id: G }) => G === h); this.fragments = this.fragments.slice(0, N).concat(F).concat(this.fragments.slice(N)); } else this.fragments.push(F); } return Promise.allSettled(_); } getImportGlobalIds(t = this, s = /* @__PURE__ */ new Set()) { for (const h of t.fragments) h.style.globalId && s.add(h.style.globalId), this.getImportGlobalIds(h.style, s); return [...s.values()]; } _createFragmentStyle(t) { const s = this.scope ? i.aC(t.id, this.scope) : t.id; let h; const _ = this._initialConfig && this._initialConfig[s]; (t.config || _) && (h = i.l({}, t.config, _)); const y = new hr(this.map, { scope: s, styleChanges: this._changes, importDepth: this.importDepth + 1, importsCache: this.importsCache, resolvedImports: new Set(this.resolvedImports), dispatcher: this.dispatcher, imageManager: this.imageManager, glyphManager: this.glyphManager, modelManager: this.modelManager, config: h, configOptions: this.options, colorThemeOverride: t["color-theme"], configDependentLayers: this._configDependentLayers }); return y.setEventedParent(this.map, { style: y }), y; } _reloadImports() { this.mergeAll(), this._updateMapProjection(), this.updateConfigDependencies(), this.map._triggerCameraUpdate(this.camera), this.dispatcher.broadcast("setLayers", { layers: this._serializeLayers(this._order), scope: this.scope, options: this.options }), this._shouldPrecompile = this.map._precompilePrograms && this.isRootStyle(); } _isInternalStyle(t) { return this.isRootStyle() && (t.fragment || !!t.schema && t.fragment !== !1); } _load(t, s) { const h = t.indoor ? $l(t.schema) : t.schema; if (this._isInternalStyle(t)) { const T = i.l({}, jc, { imports: [{ id: "basemap", data: t, url: "" }] }); return void this._load(T, s); } if (this.updateConfig(this._config, h), s && Po(this, Zi(t))) return; this._loaded = !0, this.stylesheet = i.cp(t); const _ = () => { for (const F in t.sources) this.addSource(F, t.sources[F], { validate: !1, isInitialLoad: !0 }); t.sprite ? this._loadIconset(t.sprite) : (this.imageManager.setLoaded(!0, this.scope), this.dispatcher.broadcast("spriteLoaded", { scope: this.scope, isLoaded: !0 })), this.glyphManager.setURL(t.glyphs, this.scope); const T = ul(this.stylesheet.layers); if (this._order = T.map((F) => F.id), this.stylesheet.light && i.w("The `light` root property is deprecated, prefer using `lights` with `flat` light type instead."), this.stylesheet.lights) if (this.stylesheet.lights.length === 1 && this.stylesheet.lights[0].type === "flat") { const F = this.stylesheet.lights[0]; this.light = new Qe(F.properties, F.id); } else this.setLights(this.stylesheet.lights); this.light || (this.light = new Qe(this.stylesheet.light)), this._layers = {}; for (const F of T) { const N = i.cu(F, this.scope, this._styleColorTheme.lut, this.options); N.configDependencies.size !== 0 && this._configDependentLayers.add(N.fqid), N.setEventedParent(this, { layer: { id: N.id } }), this._layers[N.id] = N; const G = this.getOwnLayerSourceCache(N), Z = !!this.directionalLight && this.directionalLight.shadowsEnabled(); G && N.canCastShadows() && Z && (G.castsShadows = !0); } this.stylesheet.featuresets && this.setFeaturesetSelectors(this.stylesheet.featuresets), this.stylesheet.models && this.modelManager.addModels(this.stylesheet.models, this.scope); const z = this.stylesheet.terrain; z && (this.checkCanvasFingerprintNoise(), this.disableElevatedTerrain || this.terrainSetForDrapingOnly() || this._createTerrain(z, 1)), this.stylesheet.fog && this._createFog(this.stylesheet.fog), this.stylesheet.snow && this._createSnow(this.stylesheet.snow), this.stylesheet.rain && this._createRain(this.stylesheet.rain), this.stylesheet.transition && this.setTransition(this.stylesheet.transition), this.fire(new i.z("data", { dataType: "style" })); const R = this.isRootStyle(); t.imports ? this._loadImports(t.imports, s).then(() => { this._reloadImports(), this.fire(new i.z(R ? "style.load" : "style.import.load")); }) : (this._reloadImports(), this.fire(new i.z(R ? "style.load" : "style.import.load"))); }; this._styleColorTheme.colorTheme = this.stylesheet["color-theme"]; const y = this._styleColorTheme.colorThemeOverride ? this._styleColorTheme.colorThemeOverride : this._styleColorTheme.colorTheme; if (y) { const T = this._evaluateColorThemeData(y); this._loadColorTheme(T).then(() => { _(); }).catch((z) => { i.w(`Couldn't load color theme from the stylesheet: ${z}`), _(); }); } else this._styleColorTheme.lut = null, _(); } isRootStyle() { return this.importDepth === 0; } mergeAll() { let t, s, h, _, y, T, z, R, F, N; const G = {}; this.terrain && this.terrain.scope !== this.scope && delete this.terrain, this.forEachFragmentStyle((Z) => { if (Z.stylesheet) { if (Z.light != null && (t = Z.light), Z.stylesheet.lights) for (const W of Z.stylesheet.lights) W.type === "ambient" && Z.ambientLight != null && (s = Z.ambientLight), W.type === "directional" && Z.directionalLight != null && (h = Z.directionalLight); _ = this._prioritizeTerrain(_, Z.terrain, Z.stylesheet.terrain), Z.stylesheet.fog && Z.fog != null && (y = Z.fog), Z.stylesheet.snow && Z.snow != null && (T = Z.snow), Z.stylesheet.rain && Z.rain != null && (z = Z.rain), Z.stylesheet.camera != null && (N = Z.stylesheet.camera), Z.stylesheet.projection != null && (R = Z.stylesheet.projection), Z.stylesheet.transition != null && (F = Z.stylesheet.transition), G[Z.scope] = Z._styleColorTheme; } }), this.light = t, this.ambientLight = s, this.directionalLight = h, this.fog = y, this.snow = T, this.rain = z, this._styleColorThemeForScope = G, _ === null ? delete this.terrain : this.terrain = _, this.camera = N || { "camera-projection": "perspective" }, this.projection = R || { name: "mercator" }, this.transition = i.l({}, Gc, F), this.mergeSources(), this.mergeLayers(); } forEachFragmentStyle(t) { const s = (h) => { for (const _ of h.fragments) s(_.style); t(h); }; s(this); } _prioritizeTerrain(t, s, h) { const _ = t && t.drapeRenderMode === 0; return h === null ? s && s.drapeRenderMode === 0 ? s : _ ? t : null : s != null && (!t || _ || s && s.drapeRenderMode === 1) ? s : t; } mergeTerrain() { let t; this.terrain && this.terrain.scope !== this.scope && delete this.terrain, this.forEachFragmentStyle((s) => { t = this._prioritizeTerrain(t, s.terrain, s.stylesheet.terrain); }), t === null ? delete this.terrain : this.terrain = t; } mergeProjection() { let t; this.forEachFragmentStyle((s) => { s.stylesheet.projection != null && (t = s.stylesheet.projection); }), this.projection = t || { name: "mercator" }; } mergeSources() { const t = {}, s = {}, h = {}; this.forEachFragmentStyle((_) => { for (const y in _._sourceCaches) { const T = i.aC(y, _.scope); t[T] = _._sourceCaches[y]; } for (const y in _._otherSourceCaches) { const T = i.aC(y, _.scope); s[T] = _._otherSourceCaches[y]; } for (const y in _._symbolSourceCaches) { const T = i.aC(y, _.scope); h[T] = _._symbolSourceCaches[y]; } }), this._mergedSourceCaches = t, this._mergedOtherSourceCaches = s, this._mergedSymbolSourceCaches = h; } mergeLayers() { const t = {}, s = [], h = {}; this._mergedSlots = [], this._has3DLayers = !1, this._hasCircleLayers = !1, this._hasSymbolLayers = !1, this.forEachFragmentStyle((y) => { for (const T of y._order) { const z = y._layers[T]; if (z.type === "slot") { const R = i.cq(T); if (t[R]) continue; t[R] = []; } z.slot && t[z.slot] ? t[z.slot].push(z) : s.push(z); } }), this._mergedOrder = []; const _ = (y = []) => { for (const T of y) if (T.type === "slot") { const z = i.cq(T.id); t[z] && _(t[z]), this._mergedSlots.push(z); } else { const z = i.aC(T.id, T.scope); this._mergedOrder.push(z), h[z] = T, T.is3D() && (this._has3DLayers = !0), T.type === "circle" && (this._hasCircleLayers = !0), T.type === "symbol" && (this._hasSymbolLayers = !0), T.type === "clip" && (this._clipLayerPresent = !0); } }; _(s), this._mergedOrder.sort((y, T) => { const z = h[y], R = h[T]; return z.hasInitialOcclusionOpacityProperties ? R.is3D() ? 1 : 0 : z.is3D() && R.hasInitialOcclusionOpacityProperties ? -1 : 0; }), this._mergedLayers = h, this.updateDrapeFirstLayers(), this._buildingIndex.processLayersChanged(); } terrainSetForDrapingOnly() { return !!this.terrain && this.terrain.drapeRenderMode === 0; } getCamera() { return this.stylesheet.camera; } setCamera(t) { return this.stylesheet.camera = i.l({}, this.stylesheet.camera, t), this.camera = this.stylesheet.camera, this; } _evaluateColorThemeData(t) { return t.data ? function(s, h, _) { const y = i.l({}, h); for (const z of Object.keys(i.a3.colorTheme)) y[z] === void 0 && (y[z] = i.a3.colorTheme[z].default); const T = new i.a4(Uc, s, new Map(_)); return T.setTransitionOrValue(y, _), T.untransitioned().possiblyEvaluate(new i.a8(0)); }(this.scope, t, this.options).get("data") : null; } _loadColorTheme(t) { this._styleColorTheme.lutLoading = !0, this._styleColorTheme.lutLoadingCorrelationID += 1; const s = this._styleColorTheme.lutLoadingCorrelationID; return new Promise((h, _) => { const y = "data:image/png;base64,"; if (!t || t.length === 0) return this._styleColorTheme.lut = null, this._styleColorTheme.lutLoading = !1, void h(); let T = t; T.startsWith(y) || (T = y + T); const z = "mapbox-reserved-lut", R = new Image(); R.src = T, R.onerror = () => { this._styleColorTheme.lutLoading = !1, _(new Error("Failed to load image data")); }, R.onload = () => { if (this._styleColorTheme.lutLoadingCorrelationID !== s) return void h(); this._styleColorTheme.lutLoading = !1; const { width: F, height: N, data: G } = i.q.getImageData(R); if (N > 32) return void _(new Error("The height of the image must be less than or equal to 32 pixels.")); if (F !== N * N) return void _(new Error("The width of the image must be equal to the height squared.")); this.getImage(z) && this.removeImage(z), this.addImage(z, { data: new i.r({ width: F, height: N }, G), pixelRatio: 1, sdf: !1, usvg: !1, version: 0 }); const Z = this.imageManager.getImage(z, this.scope); Z ? (this._styleColorTheme.lut = { image: Z.data, data: t }, h()) : _(new Error("Missing LUT image.")); }; }); } getLut(t) { const s = this._styleColorThemeForScope[t]; return s ? s.lut : null; } setProjection(t) { t ? this.stylesheet.projection = t : delete this.stylesheet.projection, this.mergeProjection(), this._updateMapProjection(); } applyProjectionUpdate() { this._loaded && (this.dispatcher.broadcast("setProjection", this.map.transform.projectionOptions), this.map.transform.projection.requiresDraping ? (this.getTerrain() || this.stylesheet.terrain) && !this.disableElevatedTerrain || this.setTerrainForDraping() : this.terrainSetForDrapingOnly() && this.setTerrain(null, 0)); } _updateMapProjection() { this.isRootStyle() && (this.map._useExplicitProjection ? this.applyProjectionUpdate() : this.map._prioritizeAndUpdateProjection(null, this.projection)); } _loadSprite(t) { this._spriteRequest = function(s, h, _) { let y, T, z; const R = i.q.devicePixelRatio > 1 ? "@2x" : ""; let F = i.n(h.transformRequest(h.normalizeSpriteURL(s, R, ".json"), i.R.SpriteJSON), (Z, W) => { F = null, z || (z = Z, y = W, G()); }), N = i.o(h.transformRequest(h.normalizeSpriteURL(s, R, ".png"), i.R.SpriteImage), (Z, W) => { N = null, z || (z = Z, T = W, G()); }); function G() { if (z) _(z); else if (y && T) { const Z = i.q.getImageData(T), W = {}; for (const te in y) { const { width: ee, height: se, x: oe, y: he, sdf: _e, pixelRatio: pe, stretchX: Me, stretchY: xe, content: we } = y[te], ve = new i.r({ width: ee, height: se }); i.r.copy(Z, ve, { x: oe, y: he }, { x: 0, y: 0 }, { width: ee, height: se }, null), W[te] = { data: ve, pixelRatio: pe, sdf: _e, stretchX: Me, stretchY: xe, content: we, usvg: !1 }; } _(null, W); } } return { cancel() { F && (F.cancel(), F = null), N && (N.cancel(), N = null); } }; }(t, this.map._requestManager, (s, h) => { if (this._spriteRequest = null, s) this.fire(new i.y(s)); else if (h) for (const _ in h) this.imageManager.addImage(_, this.scope, h[_]); this.imageManager.setLoaded(!0, this.scope), this._availableImages = this.imageManager.listImages(this.scope), this.dispatcher.broadcast("setImages", { scope: this.scope, images: this._availableImages }), this.dispatcher.broadcast("spriteLoaded", { scope: this.scope, isLoaded: !0 }), this.fire(new i.z("data", { dataType: "style" })); }); } _loadIconset(t) { if (!i.f(t) && this.map._spriteFormat !== "icon_set" || this.map._spriteFormat === "raster") return void this._loadSprite(t); const s = this.map._spriteFormat === "auto"; var h, _; this._spriteRequest = (_ = (y, T) => { if (this._spriteRequest = null, y) s ? this._loadSprite(t) : this.fire(new i.y(y)); else if (T) for (const z in T) this.imageManager.addImage(z, this.scope, T[z]); this.imageManager.setLoaded(!0, this.scope), this._availableImages = this.imageManager.listImages(this.scope), this.dispatcher.broadcast("setImages", { scope: this.scope, images: this._availableImages }), this.dispatcher.broadcast("spriteLoaded", { scope: this.scope, isLoaded: !0 }), this.fire(new i.z("data", { dataType: "style" })); }, i.bi((h = this.map._requestManager).transformRequest(h.normalizeIconsetURL(t), i.R.Iconset), (y, T) => { if (y) return void _(y); const z = {}, R = i.cg(new i.bh(T)); for (const F of R.icons) { const N = { version: 1, pixelRatio: i.q.devicePixelRatio, content: _a(F), stretchX: F.metadata ? ga(F.metadata.stretch_x_areas) : void 0, stretchY: F.metadata ? ga(F.metadata.stretch_y_areas) : void 0, sdf: !1, usvg: !0, icon: F }; z[F.name] = N; } _(null, z); })); } _validateLayer(t) { const s = this.getOwnSource(t.source); if (!s) return; const h = t.sourceLayer; h && (s.type === "geojson" || s.vectorLayerIds && s.vectorLayerIds.indexOf(h) === -1) && this.fire(new i.y(new Error(`Source layer "${h}" does not exist on source "${s.id}" as specified by style layer "${t.id}"`))); } loaded() { if (!this._loaded || Object.keys(this._changes.getUpdatedSourceCaches()).length) return !1; for (const t in this._sourceCaches) if (!this._sourceCaches[t].loaded()) return !1; if (!this.imageManager.isLoaded() || !this.modelManager.isLoaded() || this._styleColorTheme.lutLoading) return !1; for (const { style: t } of this.fragments) if (!t.loaded()) return !1; return !0; } _serializeImports() { if (this.stylesheet.imports) return this.stylesheet.imports.map((t, s) => { const h = this.fragments[s]; return h && h.style && (t.data = h.style.serialize()), t; }); } _serializeSources() { const t = {}; for (const s in this._sourceCaches) { const h = this._sourceCaches[s].getSource(); t[h.id] || (t[h.id] = h.serialize()); } return t; } _serializeLayers(t) { const s = []; for (const h of t) { const _ = this._layers[h]; _ && _.type !== "custom" && s.push(_.serialize()); } return s; } hasLightTransitions() { return !(!this.light || !this.light.hasTransition()) || !(!this.ambientLight || !this.ambientLight.hasTransition()) || !(!this.directionalLight || !this.directionalLight.hasTransition()); } hasFogTransition() { return !!this.fog && this.fog.hasTransition(); } hasSnowTransition() { return !!this.snow && this.snow.hasTransition(); } hasRainTransition() { return !!this.rain && this.rain.hasTransition(); } hasTransitions() { if (this.hasLightTransitions() || this.hasFogTransition() || this.hasSnowTransition() || this.hasRainTransition()) return !0; for (const t in this._sourceCaches) if (this._sourceCaches[t].hasTransition()) return !0; for (const t in this._layers) if (this._layers[t].hasTransition()) return !0; return !1; } get order() { return this.terrain ? this._drapedFirstOrder : this._mergedOrder; } _getOrder(t) { return t ? this.order : this._mergedOrder; } isLayerDraped(t) { return !!this.terrain && t.isDraped(this.getLayerSourceCache(t)); } _checkLoaded() { if (!this._loaded) throw new Error("Style is not done loading"); } _checkLayer(t) { const s = this.getOwnLayer(t); if (s) return s; this.fire(new i.y(new Error(`The layer '${t}' does not exist in the map's style.`))); } _checkSource(t) { const s = this.getOwnSource(t); if (s) return s; this.fire(new i.y(new Error(`The source '${t}' does not exist in the map's style.`))); } precompilePrograms(t, s) { const h = this.map.painter; if (h) for (let _ = t.minzoom || 0; _ < (t.maxzoom || 25.5); _++) { const y = t.getProgramIds(); if (y) for (const T of y) { const z = t.getDefaultProgramParams(T, s.zoom, this._styleColorTheme.lut); z && (h.style = this, this.fog && (h._fogVisible = !0, z.overrideFog = !0, h.getOrCreateProgram(T, z)), h._fogVisible = !1, z.overrideFog = !1, h.getOrCreateProgram(T, z), (this.stylesheet.terrain || this.stylesheet.projection && this.stylesheet.projection.name === "globe") && (z.overrideRtt = !0, h.getOrCreateProgram(T, z))); } } } update(t) { if (!this._loaded) return; this.ambientLight && this.ambientLight.recalculate(t), this.directionalLight && this.directionalLight.recalculate(t); const s = this.calculateLightsBrightness(); t.brightness = s || 0, s !== this._brightness && (this._brightness = s, this.dispatcher.broadcast("setBrightness", s)); const h = this._changes.isDirty(); let _ = !1; if (this._changes.isDirty()) { const T = this._changes.getLayerUpdatesByScope(); for (const z in T) { const { updatedIds: R, removedIds: F } = T[z]; (R || F) && (this._updateWorkerLayers(z, R, F), _ = !0); } this.updateSourceCaches(), this._updateTilesForChangedImages(), this.updateLayers(t), this.light && this.light.updateTransitions(t), this.ambientLight && this.ambientLight.updateTransitions(t), this.directionalLight && this.directionalLight.updateTransitions(t), this.fog && this.fog.updateTransitions(t), this.snow && this.snow.updateTransitions(t), this.rain && this.rain.updateTransitions(t), this._changes.reset(); } const y = {}; for (const T in this._mergedSourceCaches) { const z = this._mergedSourceCaches[T]; y[T] = z.used, z.used = !1, z.tileCoverLift = 0; } for (const T of this._mergedOrder) { const z = this._mergedLayers[T]; if (z.recalculate(t, this._availableImages), !z.isHidden(t.zoom)) { const R = this.getLayerSourceCache(z); R && (R.used = !0, R.tileCoverLift = Math.max(R.tileCoverLift, z.tileCoverLift())); } !this._precompileDone && this._shouldPrecompile && ("requestIdleCallback" in window ? requestIdleCallback(() => { this.precompilePrograms(z, t); }) : this.precompilePrograms(z, t)); } this._shouldPrecompile && (this._precompileDone = !0), this.terrain && _ && this.mergeLayers(); for (const T in y) { const z = this._mergedSourceCaches[T]; y[T] !== z.used && z.getSource().fire(new i.z("data", { sourceDataType: "visibility", dataType: "source", sourceId: z.getSource().id })); } this.light && this.light.recalculate(t), this.terrain && this.terrain.recalculate(t), this.fog && this.fog.recalculate(t), this.snow && this.snow.recalculate(t), this.rain && this.rain.recalculate(t), this.z = t.zoom, this._markersNeedUpdate && (this._updateMarkersOpacity(), this._markersNeedUpdate = !1), h && this.fire(new i.z("data", { dataType: "style" })); } _updateTilesForChangedImages() { const t = this._changes.getUpdatedImages(); if (t.length) { for (const s in this._sourceCaches) this._sourceCaches[s].reloadTilesForDependencies(["icons", "patterns"], t); this._changes.resetUpdatedImages(); } } _updateWorkerLayers(t, s, h) { const _ = this.getFragmentStyle(t); _ && this.dispatcher.broadcast("updateLayers", { layers: s ? _._serializeLayers(s) : [], scope: t, removedIds: h || [], options: _.options }); } setState(t, s) { if (this._checkLoaded(), Po(this, Zi(t))) return !1; (t = i.cp(t)).layers = ul(t.layers); const h = function(T, z) { if (!T) return [{ command: Oi.setStyle, args: [z] }]; let R = []; try { if (!i.bn(T.version, z.version)) return [{ command: Oi.setStyle, args: [z] }]; if (i.bn(T.center, z.center) || R.push({ command: Oi.setCenter, args: [z.center] }), i.bn(T.zoom, z.zoom) || R.push({ command: Oi.setZoom, args: [z.zoom] }), i.bn(T.bearing, z.bearing) || R.push({ command: Oi.setBearing, args: [z.bearing] }), i.bn(T.pitch, z.pitch) || R.push({ command: Oi.setPitch, args: [z.pitch] }), i.bn(T.sprite, z.sprite) || R.push({ command: Oi.setSprite, args: [z.sprite] }), i.bn(T.glyphs, z.glyphs) || R.push({ command: Oi.setGlyphs, args: [z.glyphs] }), i.bn(T.imports, z.imports) || function(W = [], te = [], ee) { te = te || []; const se = (W = W || []).map(Fi), oe = te.map(Fi), he = W.reduce(Li, {}), _e = te.reduce(Li, {}), pe = se.slice(); let Me, xe, we, ve; for (Me = 0, xe = 0; Me < se.length; Me++) we = se[Me], _e.hasOwnProperty(we) ? xe++ : (ee.push({ command: Oi.removeImport, args: [we] }), pe.splice(pe.indexOf(we, xe), 1)); for (Me = 0, xe = 0; Me < oe.length; Me++) we = oe[oe.length - 1 - Me], pe[pe.length - 1 - Me] !== we && (he.hasOwnProperty(we) ? (ee.push({ command: Oi.removeImport, args: [we] }), pe.splice(pe.lastIndexOf(we, pe.length - xe), 1)) : xe++, ve = pe[pe.length - Me], ee.push({ command: Oi.addImport, args: [_e[we], ve] }), pe.splice(pe.length - Me, 0, we)); for (const Ae of te) { const Oe = he[Ae.id]; Oe && !i.bn(Oe, Ae) && ee.push({ command: Oi.updateImport, args: [Ae.id, Ae] }); } }(T.imports, z.imports, R), i.bn(T.transition, z.transition) || R.push({ command: Oi.setTransition, args: [z.transition] }), i.bn(T.light, z.light) || R.push({ command: Oi.setLight, args: [z.light] }), i.bn(T.fog, z.fog) || R.push({ command: Oi.setFog, args: [z.fog] }), i.bn(T.snow, z.snow) || R.push({ command: Oi.setSnow, args: [z.snow] }), i.bn(T.rain, z.rain) || R.push({ command: Oi.setRain, args: [z.rain] }), i.bn(T.projection, z.projection) || R.push({ command: Oi.setProjection, args: [z.projection] }), i.bn(T.lights, z.lights) || R.push({ command: Oi.setLights, args: [z.lights] }), i.bn(T.camera, z.camera) || R.push({ command: Oi.setCamera, args: [z.camera] }), !i.bn(T["color-theme"], z["color-theme"])) return [{ command: Oi.setStyle, args: [z] }]; const F = {}, N = []; (function(W, te, ee, se) { let oe; for (oe in te = te || {}, W = W || {}) W.hasOwnProperty(oe) && (te.hasOwnProperty(oe) || ns(oe, ee, se)); for (oe in te) { if (!te.hasOwnProperty(oe)) continue; const he = te[oe]; W.hasOwnProperty(oe) ? i.bn(W[oe], he) || (W[oe].type === "geojson" && he.type === "geojson" && ha(W, te, oe) ? ee.push({ command: Oi.setGeoJSONSourceData, args: [oe, he.data] }) : Cn(oe, te, ee, se)) : Bi(oe, te, ee); } })(T.sources, z.sources, N, F); const G = []; T.layers && T.layers.forEach((W) => { W.source && F[W.source] ? R.push({ command: Oi.removeLayer, args: [W.id] }) : G.push(W); }); let Z = T.terrain; Z && F[Z.source] && (R.push({ command: Oi.setTerrain, args: [void 0] }), Z = void 0), R = R.concat(N), i.bn(Z, z.terrain) || R.push({ command: Oi.setTerrain, args: [z.terrain] }), function(W, te, ee) { te = te || []; const se = (W = W || []).map(Fi), oe = te.map(Fi), he = W.reduce(Li, {}), _e = te.reduce(Li, {}), pe = se.slice(), Me = /* @__PURE__ */ Object.create(null); let xe, we, ve, Ae, Oe, Xe, He; for (xe = 0, we = 0; xe < se.length; xe++) ve = se[xe], _e.hasOwnProperty(ve) ? we++ : (ee.push({ command: Oi.removeLayer, args: [ve] }), pe.splice(pe.indexOf(ve, we), 1)); for (xe = 0, we = 0; xe < oe.length; xe++) ve = oe[oe.length - 1 - xe], pe[pe.length - 1 - xe] !== ve && (he.hasOwnProperty(ve) ? (ee.push({ command: Oi.removeLayer, args: [ve] }), pe.splice(pe.lastIndexOf(ve, pe.length - we), 1)) : we++, Xe = pe[pe.length - xe], ee.push({ command: Oi.addLayer, args: [_e[ve], Xe] }), pe.splice(pe.length - xe, 0, ve), Me[ve] = !0); for (xe = 0; xe < oe.length; xe++) if (ve = oe[xe], Ae = he[ve], Oe = _e[ve], !Me[ve] && !i.bn(Ae, Oe)) if (i.bn(Ae.source, Oe.source) && i.bn(Ae["source-layer"], Oe["source-layer"]) && i.bn(Ae.type, Oe.type)) { for (He in Ot(Ae.layout, Oe.layout, ee, ve, null, Oi.setLayoutProperty), Ot(Ae.paint, Oe.paint, ee, ve, null, Oi.setPaintProperty), i.bn(Ae.slot, Oe.slot) || ee.push({ command: Oi.setSlot, args: [ve, Oe.slot] }), i.bn(Ae.filter, Oe.filter) || ee.push({ command: Oi.setFilter, args: [ve, Oe.filter] }), i.bn(Ae.minzoom, Oe.minzoom) && i.bn(Ae.maxzoom, Oe.maxzoom) || ee.push({ command: Oi.setLayerZoomRange, args: [ve, Oe.minzoom, Oe.maxzoom] }), Ae) Ae.hasOwnProperty(He) && He !== "layout" && He !== "paint" && He !== "filter" && He !== "metadata" && He !== "minzoom" && He !== "maxzoom" && He !== "slot" && (He.indexOf("paint.") === 0 ? Ot(Ae[He], Oe[He], ee, ve, He.slice(6), Oi.setPaintProperty) : i.bn(Ae[He], Oe[He]) || ee.push({ command: Oi.setLayerProperty, args: [ve, He, Oe[He]] })); for (He in Oe) Oe.hasOwnProperty(He) && !Ae.hasOwnProperty(He) && He !== "layout" && He !== "paint" && He !== "filter" && He !== "metadata" && He !== "minzoom" && He !== "maxzoom" && He !== "slot" && (He.indexOf("paint.") === 0 ? Ot(Ae[He], Oe[He], ee, ve, He.slice(6), Oi.setPaintProperty) : i.bn(Ae[He], Oe[He]) || ee.push({ command: Oi.setLayerProperty, args: [ve, He, Oe[He]] })); } else ee.push({ command: Oi.removeLayer, args: [ve] }), Xe = pe[pe.lastIndexOf(ve) + 1], ee.push({ command: Oi.addLayer, args: [Oe, Xe] }); }(G, z.layers, R); } catch (F) { console.warn("Unable to compute style diff:", F), R = [{ command: Oi.setStyle, args: [z] }]; } return R; }(this.serialize(), t).filter((T) => !(T.command in td)); if (h.length === 0) return !1; const _ = h.filter((T) => !(T.command in Hh)); if (_.length > 0) throw new Error(`Unimplemented: ${_.map((T) => T.command).join(", ")}.`); const y = []; return h.forEach((T) => { y.push(this[T.command].apply(this, T.args)); }), s && Promise.all(y).then(s), this.stylesheet = t, this.mergeAll(), this.dispatcher.broadcast("setLayers", { layers: this._serializeLayers(this._order), scope: this.scope, options: this.options }), !0; } addImage(t, s) { return this.getImage(t) ? this.fire(new i.y(new Error("An image with this name already exists."))) : (this.imageManager.addImage(t, this.scope, s), this._afterImageUpdated(t), this); } updateImage(t, s, h = !1) { this.imageManager.updateImage(t, this.scope, s), h && this._afterImageUpdated(t); } getImage(t) { return this.imageManager.getImage(t, this.scope); } removeImage(t) { return this.getImage(t) ? (this.imageManager.removeImage(t, this.scope), this._afterImageUpdated(t), this) : this.fire(new i.y(new Error("No image with this name exists."))); } _afterImageUpdated(t) { this._availableImages = this.imageManager.listImages(this.scope), this._changes.updateImage(t), this.dispatcher.broadcast("setImages", { scope: this.scope, images: this._availableImages }), this.fire(new i.z("data", { dataType: "style" })); } listImages() { return this._checkLoaded(), this._availableImages.slice(); } addModel(t, s, h = {}) { return this._checkLoaded(), this._validate(Be, `models.${t}`, s, null, h) || (this.modelManager.addModel(t, s, this.scope), this._changes.setDirty()), this; } hasModel(t) { return this.modelManager.hasModel(t, this.scope); } removeModel(t) { return this.hasModel(t) ? (this.modelManager.removeModel(t, this.scope), this) : this.fire(new i.y(new Error("No model with this ID exists."))); } listModels() { return this._checkLoaded(), this.modelManager.listModels(this.scope); } addSource(t, s, h = {}) { if (this._checkLoaded(), this.getOwnSource(t) !== void 0) throw new Error(`There is already a source with ID "${t}".`); if (!s.type) throw new Error(`The type property must be defined, but only the following properties were given: ${Object.keys(s).join(", ")}.`); if (["vector", "raster", "geojson", "video", "image"].indexOf(s.type) >= 0 && this._validate(Jn, `sources.${t}`, s, null, h)) return; this.map && this.map._collectResourceTiming && (s.collectResourceTiming = !0); const _ = Go(t, s, this.dispatcher, this); _.scope = this.scope, _.setEventedParent(this, () => ({ isSourceLoaded: this._isSourceCacheLoaded(_.id), source: _.serialize(), sourceId: _.id })); const y = (T) => { const z = (T ? "symbol:" : "other:") + _.id, R = i.aC(z, this.scope), F = this._sourceCaches[z] = new sr(R, _, T); (T ? this._symbolSourceCaches : this._otherSourceCaches)[_.id] = F, F.onAdd(this.map); }; y(!1), s.type !== "vector" && s.type !== "geojson" || y(!0), _.onAdd && _.onAdd(this.map), h.isInitialLoad || (this.mergeSources(), this._changes.setDirty()); } removeSource(t) { this._checkLoaded(); const s = this.getOwnSource(t); if (!s) throw new Error("There is no source with this ID"); for (const _ in this._layers) if (this._layers[_].source === t) return this.fire(new i.y(new Error(`Source "${t}" cannot be removed while layer "${_}" is using it.`))); if (this.terrain && this.terrain.scope === this.scope && this.terrain.get().source === t) return this.fire(new i.y(new Error(`Source "${t}" cannot be removed while terrain is using it.`))); const h = this.getOwnSourceCaches(t); for (const _ of h) { const y = i.cq(_.id); delete this._sourceCaches[y], this._changes.discardSourceCacheUpdate(_.id), _.fire(new i.z("data", { sourceDataType: "metadata", dataType: "source", sourceId: _.getSource().id })), _.setEventedParent(null), _.clearTiles(); } return delete this._otherSourceCaches[t], delete this._symbolSourceCaches[t], this.mergeSources(), s.setEventedParent(null), s.onRemove && s.onRemove(this.map), this._changes.setDirty(), this; } setGeoJSONSourceData(t, s) { this._checkLoaded(), this.getOwnSource(t).setData(s), this._changes.setDirty(); } getOwnSource(t) { const s = this.getOwnSourceCache(t); return s && s.getSource(); } getOwnSources() { const t = []; for (const s in this._otherSourceCaches) { const h = this.getOwnSourceCache(s); h && t.push(h.getSource()); } return t; } areTilesLoaded() { const t = this._mergedSourceCaches; for (const s in t) { const h = t[s]._tiles; for (const _ in h) { const y = h[_]; if (y.state !== "loaded" && y.state !== "errored") return !1; } } return !0; } setLights(t) { if (this._checkLoaded(), !t) return delete this.ambientLight, void delete this.directionalLight; const s = this._getTransitionParameters(); for (const _ of t) { if (this._validate(Ls, "lights", _)) return; switch (_.type) { case "ambient": if (this.ambientLight) { const y = this.ambientLight; y.set(_), y.updateTransitions(s); } else this.ambientLight = new ps(_, $i || ($i = new i.a5({ color: new i.a6(i.a3.properties_light_ambient.color), "color-use-theme": new i.a6({ type: "string", default: "default", "property-type": "data-constant" }), intensity: new i.a6(i.a3.properties_light_ambient.intensity) })), this.scope, this.options); break; case "directional": if (this.directionalLight) { const y = this.directionalLight; y.set(_), y.updateTransitions(s); } else this.directionalLight = new ps(_, Hi || (Hi = new i.a5({ direction: new i.ak(i.a3.properties_light_directional.direction), color: new i.a6(i.a3.properties_light_directional.color), "color-use-theme": new i.a6({ type: "string", default: "default", "property-type": "data-constant" }), intensity: new i.a6(i.a3.properties_light_directional.intensity), "cast-shadows": new i.a6(i.a3.properties_light_directional["cast-shadows"]), "shadow-quality": new i.a6(i.a3.properties_light_directional["shadow-quality"]), "shadow-intensity": new i.a6(i.a3.properties_light_directional["shadow-intensity"]) })), this.scope, this.options); } } const h = new i.a8(this.z || 0, s); this.ambientLight && this.ambientLight.recalculate(h), this.directionalLight && this.directionalLight.recalculate(h), this._brightness = this.calculateLightsBrightness(), this.dispatcher.broadcast("setBrightness", this._brightness); } calculateLightsBrightness() { const t = this.directionalLight, s = this.ambientLight; if (!t || !s) return; const h = (Z) => 0.2126 * (Z[0] <= 0.03928 ? Z[0] / 12.92 : Math.pow((Z[0] + 0.055) / 1.055, 2.4)) + 0.7152 * (Z[1] <= 0.03928 ? Z[1] / 12.92 : Math.pow((Z[1] + 0.055) / 1.055, 2.4)) + 0.0722 * (Z[2] <= 0.03928 ? Z[2] / 12.92 : Math.pow((Z[2] + 0.055) / 1.055, 2.4)), _ = t.properties.get("color").toRenderColor(null).toArray01(), y = t.properties.get("intensity"), T = t.properties.get("direction"), z = 1 - i.cb(T.x, T.y, T.z)[2] / 90, R = h(_) * y * z, F = s.properties.get("color").toRenderColor(null).toArray01(), N = s.properties.get("intensity"), G = h(F) * N; return Number(((R + G) / 2).toFixed(6)); } getBrightness() { return this._brightness; } getLights() { if (!this.enable3dLights()) return null; const t = []; return this.directionalLight && t.push(this.directionalLight.get()), this.ambientLight && t.push(this.ambientLight.get()), t; } enable3dLights() { return !!this.ambientLight && !!this.directionalLight; } getFragmentStyle(t) { if (!t) return this; if (i.cr(t)) { const s = i.cs(t), h = this.fragments.find(({ id: y }) => y === s); if (!h) throw new Error(`Style import '${t}' not found`); const _ = i.cq(t); return h.style.getFragmentStyle(_); } { const s = this.fragments.find(({ id: h }) => h === t); if (!s) throw new Error(`Style import '${t}' not found`); return s.style; } } setFeaturesetSelectors(t) { if (!t) return; const s = {}, h = (_, y = "") => `${_}::${y}`; this.featuresetSelectors = {}; for (const _ in t) { const y = this.featuresetSelectors[_] = []; for (const T of t[_].selectors) { if (T.featureNamespace) { const R = this.getOwnLayer(T.layer); if (!R) { i.w(`Layer is undefined for selector: ${T.layer}`); continue; } const F = h(R.source, R.sourceLayer); if (F in s && s[F] !== T.featureNamespace) { i.w(`"featureNamespace ${T.featureNamespace} of featureset ${_}'s selector is not associated to the same source, skip this selector`); continue; } s[F] = T.featureNamespace; } let z; if (T.properties) for (const R in T.properties) { const F = i.U(T.properties[R]); F.result === "success" && (z = z || {}, z[R] = F.value); } y.push({ layerId: T.layer, namespace: T.featureNamespace, properties: z }); } } } getFeaturesetDescriptors(t) { const s = this.getFragmentStyle(t); if (!s || !s.stylesheet.featuresets) return []; const h = []; for (const _ in s.stylesheet.featuresets) h.push({ featuresetId: _, importId: s.scope ? s.scope : void 0 }); return h; } getFeaturesetLayers(t, s) { const h = this.getFragmentStyle(s), _ = h.stylesheet.featuresets; if (!_ || !_[t]) return this.fire(new i.y(new Error(`The featureset '${t}' does not exist in the map's style and cannot be queried.`))), []; const y = []; for (const T of _[t].selectors) { const z = h.getOwnLayer(T.layer); z && y.push(z); } return y; } getConfigProperty(t, s) { const h = this.getFragmentStyle(t); if (!h) return null; const _ = i.aC(s, h.scope), y = h.options.get(_), T = y ? y.value || y.default : null; return T ? T.serialize() : null; } setConfigProperty(t, s, h) { const _ = this.getFragmentStyle(t); if (!_) return; const y = _.stylesheet.indoor ? $l(_.stylesheet.schema) : _.stylesheet.schema; if (!y || !y[s]) return; const T = i.U(h); if (T.result !== "success") return void Po(this, T.value); const z = T.value.expression, R = i.aC(s, _.scope), F = _.options.get(R); if (!F) return; let N; const { minValue: G, maxValue: Z, stepValue: W, type: te, values: ee } = y[s], se = i.U(y[s].default); se.result === "success" && (N = se.value.expression), N ? (this.options.set(R, { ...F, value: z, default: N, minValue: G, maxValue: Z, stepValue: W, type: te, values: ee }), this.updateConfigDependencies(s)) : this.fire(new i.y(new Error(`No schema defined for the config option "${s}" in the "${t}" fragment.`))); } getConfig(t) { const s = this.getFragmentStyle(t); if (!s) return null; const h = s.stylesheet.schema; if (!h) return null; const _ = {}; for (const y in h) { const T = i.aC(y, s.scope), z = s.options.get(T), R = z ? z.value || z.default : null; _[y] = R ? R.serialize() : null; } return _; } setConfig(t, s) { const h = this.getFragmentStyle(t); h && (h.updateConfig(s, h.stylesheet.schema), this.updateConfigDependencies()); } getSchema(t) { const s = this.getFragmentStyle(t); return s ? s.stylesheet.schema : null; } setSchema(t, s) { const h = this.getFragmentStyle(t); h && (h.stylesheet.schema = s, h.updateConfig(h._config, s), this.updateConfigDependencies()); } updateConfig(t, s) { if (this._config = t, t || s) if (s) for (const h in s) { let _, y; const T = i.U(s[h].default); if (T.result === "success" && (_ = T.value.expression), t && t[h] !== void 0) { const Z = i.U(t[h]); Z.result === "success" && (y = Z.value.expression); } const { minValue: z, maxValue: R, stepValue: F, type: N, values: G } = s[h]; if (_) { const Z = i.aC(h, this.scope); this.options.set(Z, { default: _, value: y, minValue: z, maxValue: R, stepValue: F, type: N, values: G }); } else this.fire(new i.y(new Error(`No schema defined for config option "${h}".`))); } else this.fire(new i.y(new Error("Attempting to set config for a style without schema."))); } updateConfigDependencies(t) { for (const s of this._configDependentLayers) { const h = this.getLayer(s); if (h) { if (t && !h.configDependencies.has(t)) continue; h.possiblyEvaluateVisibility(), this._updateLayer(h); } } this.ambientLight && this.ambientLight.updateConfig(this.options), this.directionalLight && this.directionalLight.updateConfig(this.options), this.fog && this.fog.updateConfig(this.options), this.snow && this.snow.updateConfig(this.options), this.rain && this.rain.updateConfig(this.options), this.forEachFragmentStyle((s) => { const h = s._styleColorTheme.colorThemeOverride ? s._styleColorTheme.colorThemeOverride : s._styleColorTheme.colorTheme; if (h) { const _ = s._evaluateColorThemeData(h); (!s._styleColorTheme.lut && _ !== "" || s._styleColorTheme.lut && _ !== s._styleColorTheme.lut.data) && s.setColorTheme(h); } }), this._changes.setDirty(); } addLayer(t, s, h = {}) { this._checkLoaded(); const _ = t.id; if (this._layers[_]) return void this.fire(new i.y(new Error(`Layer with id "${_}" already exists on this map`))); let y; if (t.type === "custom") { if (Po(this, i.ct(t))) return; y = i.cu(t, this.scope, this._styleColorTheme.lut, this.options); } else { if (typeof t.source == "object" && (this.addSource(_, t.source), t = i.cp(t), t = i.l(t, { source: _ })), this._validate(le, `layers.${_}`, t, { arrayIndex: -1 }, h)) return; y = i.cu(t, this.scope, this._styleColorTheme.lut, this.options), this._validateLayer(y), y.setEventedParent(this, { layer: { id: _ } }); } y.configDependencies.size !== 0 && this._configDependentLayers.add(y.fqid); let T = this._order.length; if (s) { const N = this._order.indexOf(s); if (N === -1) return void this.fire(new i.y(new Error(`Layer with id "${s}" does not exist on this map.`))); y.slot === this._layers[s].slot ? T = N : i.w(`Layer with id "${s}" has a different slot. Layers can only be rearranged within the same slot.`); } this._order.splice(T, 0, _), this._layerOrderChanged = !0, this._layers[_] = y; const z = this.getOwnLayerSourceCache(y), R = !!this.directionalLight && this.directionalLight.shadowsEnabled(); z && y.canCastShadows() && R && (z.castsShadows = !0); const F = this._changes.getRemovedLayer(y); if (F && y.source && z && y.type !== "custom") { this._changes.discardLayerRemoval(y); const N = i.aC(y.source, y.scope); F.type !== y.type ? this._changes.updateSourceCache(N, "clear") : (this._changes.updateSourceCache(N, "reload"), z.pause()); } this._updateLayer(y), y.onAdd && y.onAdd(this.map), y.scope = this.scope, this.mergeLayers(); } moveLayer(t, s) { this._checkLoaded(); const h = this._checkLayer(t); if (!h || t === s) return; const _ = this._order.indexOf(t); this._order.splice(_, 1); let y = this._order.length; if (s) { const T = this._order.indexOf(s); if (T === -1) return void this.fire(new i.y(new Error(`Layer with id "${s}" does not exist on this map.`))); h.slot === this._layers[s].slot ? y = T : i.w(`Layer with id "${s}" has a different slot. Layers can only be rearranged within the same slot.`); } this._order.splice(y, 0, t), this._changes.setDirty(), this._layerOrderChanged = !0, this.mergeLayers(); } removeLayer(t) { this._checkLoaded(); const s = this._checkLayer(t); if (!s) return; s.setEventedParent(null); const h = this._order.indexOf(t); this._order.splice(h, 1), delete this._layers[t], this._changes.setDirty(), this._layerOrderChanged = !0, this._configDependentLayers.delete(s.fqid), this._changes.removeLayer(s); const _ = this.getOwnLayerSourceCache(s); if (_ && _.castsShadows) { let y = !1; for (const T in this._layers) if (this._layers[T].source === s.source && this._layers[T].canCastShadows()) { y = !0; break; } _.castsShadows = y; } s.onRemove && s.onRemove(this.map), this.mergeLayers(); } getOwnLayer(t) { return this._layers[t]; } hasLayer(t) { return t in this._mergedLayers; } hasLayerType(t) { for (const s in this._layers) if (this._layers[s].type === t) return !0; return !1; } setLayerZoomRange(t, s, h) { this._checkLoaded(); const _ = this._checkLayer(t); _ && (_.minzoom === s && _.maxzoom === h || (s != null && (_.minzoom = s), h != null && (_.maxzoom = h), this._updateLayer(_))); } getSlots() { return this._checkLoaded(), this._mergedSlots; } setSlot(t, s) { this._checkLoaded(); const h = this._checkLayer(t); h && h.slot !== s && (h.slot = s, this._updateLayer(h)); } setFilter(t, s, h = {}) { this._checkLoaded(); const _ = this._checkLayer(t); if (_ && !i.bn(_.filter, s)) return s == null ? (_.filter = void 0, void this._updateLayer(_)) : void (this._validate(ge, `layers.${_.id}.filter`, s, { layerType: _.type }, h) || (_.filter = i.cp(s), this._updateLayer(_))); } getFilter(t) { const s = this._checkLayer(t); if (s) return i.cp(s.filter); } setLayoutProperty(t, s, h, _ = {}) { this._checkLoaded(); const y = this._checkLayer(t); if (y && !i.bn(y.getLayoutProperty(s), h)) { if (h != null && (!_ || _.validate !== !1) && Po(y, Ce.call(Zi, { key: `layers.${t}.layout.${s}`, layerType: y.type, objectKey: s, value: h, styleSpec: i.a3, style: { glyphs: !0, sprite: !0 } }))) return; y.setLayoutProperty(s, h), y.configDependencies.size !== 0 && this._configDependentLayers.add(y.fqid), this._updateLayer(y); } } getLayoutProperty(t, s) { const h = this._checkLayer(t); if (h) return h.getLayoutProperty(s); } setPaintProperty(t, s, h, _ = {}) { this._checkLoaded(); const y = this._checkLayer(t); if (!y || i.bn(y.getPaintProperty(s), h) || h != null && (!_ || _.validate !== !1) && Po(y, Le.call(Zi, { key: `layers.${t}.paint.${s}`, layerType: y.type, objectKey: s, value: h, styleSpec: i.a3 }))) return; const T = y.setPaintProperty(s, h); y.configDependencies.size !== 0 && this._configDependentLayers.add(y.fqid), T && this._updateLayer(y), this._changes.updatePaintProperties(y); } getPaintProperty(t, s) { const h = this._checkLayer(t); if (h) return h.getPaintProperty(s); } setFeatureState(t, s) { if (this._checkLoaded(), "target" in t) { if ("featuresetId" in t.target) { const { featuresetId: R, importId: F } = t.target, N = this.getFragmentStyle(F), G = N.getFeaturesetLayers(R); for (const { source: Z, sourceLayer: W } of G) N.setFeatureState({ id: t.id, source: Z, sourceLayer: W }, s); } else if ("layerId" in t.target) { const { layerId: R } = t.target, F = this.getLayer(R); this.setFeatureState({ id: t.id, source: F.source, sourceLayer: F.sourceLayer }, s); } return; } const h = t.source, _ = t.sourceLayer, y = this._checkSource(h); if (!y) return; const T = y.type; if (T === "geojson" && _) return void this.fire(new i.y(new Error("GeoJSON sources cannot have a sourceLayer parameter."))); if (T === "vector" && !_) return void this.fire(new i.y(new Error("The sourceLayer parameter must be provided for vector source types."))); t.id === void 0 && this.fire(new i.y(new Error("The feature id parameter must be provided."))); const z = this.getOwnSourceCaches(h); for (const R of z) R.setFeatureState(_, t.id, s); } removeFeatureState(t, s) { if (this._checkLoaded(), "target" in t) { if ("featuresetId" in t.target) { const { featuresetId: R, importId: F } = t.target, N = this.getFragmentStyle(F), G = N.getFeaturesetLayers(R); for (const { source: Z, sourceLayer: W } of G) N.removeFeatureState({ id: t.id, source: Z, sourceLayer: W }, s); } else if ("layerId" in t.target) { const { layerId: R } = t.target, F = this.getLayer(R); this.removeFeatureState({ id: t.id, source: F.source, sourceLayer: F.sourceLayer }, s); } return; } const h = t.source, _ = this._checkSource(h); if (!_) return; const y = _.type, T = y === "vector" ? t.sourceLayer : void 0; if (y === "vector" && !T) return void this.fire(new i.y(new Error("The sourceLayer parameter must be provided for vector source types."))); if (s && typeof t.id != "string" && typeof t.id != "number") return void this.fire(new i.y(new Error("A feature id is required to remove its specific state property."))); const z = this.getOwnSourceCaches(h); for (const R of z) R.removeFeatureState(T, t.id, s); } getFeatureState(t) { if (this._checkLoaded(), "target" in t) { let y; if ("featuresetId" in t.target) { const { featuresetId: T, importId: z } = t.target, R = this.getFragmentStyle(z), F = R.getFeaturesetLayers(T); for (const { source: N, sourceLayer: G } of F) { const Z = R.getFeatureState({ id: t.id, source: N, sourceLayer: G }); if (Z && !y) y = Z; else if (!i.bn(y, Z)) return void this.fire(new i.y(new Error("The same feature id exists in multiple sources in the featureset, but their feature states are not consistent through the sources."))); } } else if ("layerId" in t.target) { const { layerId: T } = t.target, z = this.getLayer(T); y = this.getFeatureState({ id: t.id, source: z.source, sourceLayer: z.sourceLayer }); } return y; } const s = t.source, h = t.sourceLayer, _ = this._checkSource(s); if (_) { if (_.type !== "vector" || h) return t.id === void 0 && this.fire(new i.y(new Error("The feature id parameter must be provided."))), this.getOwnSourceCaches(s)[0].getFeatureState(h, t.id); this.fire(new i.y(new Error("The sourceLayer parameter must be provided for vector source types."))); } } setTransition(t) { return this.stylesheet.transition = i.l({}, this.stylesheet.transition, t), this.transition = this.stylesheet.transition, this; } getTransition() { return i.l({}, this.stylesheet.transition); } serialize() { this._checkLoaded(); const t = this.getTerrain(), s = t && this.terrain && this.terrain.scope === this.scope ? t : this.stylesheet.terrain; return i.cv({ version: this.stylesheet.version, name: this.stylesheet.name, metadata: this.stylesheet.metadata, fragment: this.stylesheet.fragment, imports: this._serializeImports(), schema: this.stylesheet.schema, camera: this.stylesheet.camera, light: this.stylesheet.light, lights: this.stylesheet.lights, terrain: s, fog: this.stylesheet.fog, snow: this.stylesheet.snow, rain: this.stylesheet.rain, center: this.stylesheet.center, "color-theme": this.stylesheet["color-theme"], 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: this._serializeSources(), layers: this._serializeLayers(this._order) }, (h) => h !== void 0); } _updateFilteredLayers(t) { for (const s of Object.values(this._mergedLayers)) t(s) && this._updateLayer(s); } _updateLayer(t) { this._changes.updateLayer(t); const s = this.getLayerSourceCache(t), h = i.aC(t.source, t.scope), _ = this._changes.getUpdatedSourceCaches(); t.source && !_[h] && s && s.getSource().type !== "raster" && (this._changes.updateSourceCache(h, "reload"), s.pause()), t.invalidateCompiledFilter(); } _flattenAndSortRenderedFeatures(t) { const s = (z) => this._mergedLayers[z].is3D(), h = this.order, _ = {}, y = []; for (let z = h.length - 1; z >= 0; z--) { const R = h[z]; if (s(R)) { _[R] = z; for (const F of t) { const N = F[R]; if (N) for (const G of N) y.push(G); } } } y.sort((z, R) => R.intersectionZ - z.intersectionZ); const T = []; for (let z = h.length - 1; z >= 0; z--) { const R = h[z]; if (s(R)) for (let F = y.length - 1; F >= 0; F--) { const N = y[F].feature; if (N.layer && _[N.layer.id] < z) break; T.push(N), y.pop(); } else for (const F of t) { const N = F[R]; if (N) for (const G of N) T.push(G.feature); } } return T; } queryRenderedFeatures(t, s, h) { let _; s && !Array.isArray(s) && s.filter && (this._validate(ge, "queryRenderedFeatures.filter", s.filter, null, s), _ = i.aZ(s.filter)); const y = {}, T = (N) => { if (ja.has(N.type)) return; const G = this.getOwnLayerSourceCache(N), Z = y[G.id] = y[G.id] || { sourceCache: G, layers: {}, has3DLayers: !1 }; N.is3D() && (Z.has3DLayers = !0), Z.layers[N.fqid] = Z.layers[N.fqid] || { styleLayer: N, targets: [] }, Z.layers[N.fqid].targets.push({ filter: _ }); }; if (s && s.layers) { if (!Array.isArray(s.layers)) return this.fire(new i.y(new Error("parameters.layers must be an Array."))), []; for (const N of s.layers) { const G = this._layers[N]; if (!G) return this.fire(new i.y(new Error(`The layer '${N}' does not exist in the map's style and cannot be queried for features.`))), []; T(G); } } else for (const N in this._layers) T(this._layers[N]); const z = this._queryRenderedFeatures(t, y, h), R = this._flattenAndSortRenderedFeatures(z), F = []; for (const N of R) i.cs(N.layer.id) === this.scope && F.push(N); return F; } queryRenderedFeatureset(t, s, h) { let _; s && !Array.isArray(s) && s.filter && (this._validate(ge, "queryRenderedFeatures.filter", s.filter, null, s), _ = i.aZ(s.filter)); const y = "mock", T = []; if (s && s.target) T.push({ ...s, targetId: y, filter: _ }); else { const F = this.getFeaturesetDescriptors(); for (const N of F) T.push({ targetId: y, filter: _, target: N }); for (const { style: N } of this.fragments) { const G = N.getFeaturesetDescriptors(); for (const Z of G) T.push({ targetId: y, filter: _, target: Z }); } } const z = this.queryRenderedTargets(t, T, h), R = []; for (const F of z) for (const N of F.variants[y]) R.push(new i.cw(F, N)); return R; } queryRenderedTargets(t, s, h) { const _ = {}, y = (z, R, F, N) => { const G = _[R.id] = _[R.id] || { sourceCache: R, layers: {}, has3DLayers: !1 }; G.layers[z.fqid] = G.layers[z.fqid] || { styleLayer: z, targets: [] }, z.is3D() && (G.has3DLayers = !0), G.layers[z.fqid].targets.push(N ? { ...F, namespace: N.namespace, properties: N.properties } : F); }; for (const z of s) if ("featuresetId" in z.target) { const { featuresetId: R, importId: F } = z.target, N = this.getFragmentStyle(F), G = N.featuresetSelectors[R]; if (!G) { this.fire(new i.y(new Error(`The featureset '${R}' does not exist in the map's style and cannot be queried for features.`))); continue; } for (const Z of G) { const W = N.getOwnLayer(Z.layerId); W && !ja.has(W.type) && y(W, N.getOwnLayerSourceCache(W), z, Z); } } else if ("layerId" in z.target) { const { layerId: R } = z.target, F = this.getLayer(R); if (!F || ja.has(F.type)) continue; y(F, this.getLayerSourceCache(F), z); } const T = this._queryRenderedFeatures(t, _, h); return this._flattenAndSortRenderedFeatures(T); } _queryRenderedFeatures(t, s, h) { const _ = [], y = !!this.map._showQueryGeometry, T = vs.createFromScreenPoints(t, h); for (const z in s) { const R = aa(T, s[z], this._availableImages, h, y); Object.keys(R).length && _.push(R); } if (this.placement) for (const z in s) { if (!s[z].sourceCache._onlySymbols) continue; const R = Da(T.screenGeometry, s[z], this._availableImages, this.placement.collisionIndex, this.placement.retainedQueryData); Object.keys(R).length && _.push(R); } return _; } querySourceFeatures(t, s) { const h = s && s.filter; h && this._validate(ge, "querySourceFeatures.filter", h, null, s); let _ = []; const y = this.getOwnSourceCaches(t); for (const T of y) _ = _.concat(Vi(T, s)); return _; } addSourceType(t, s, h) { return hr.getSourceType(t) ? h(new Error(`A source type called "${t}" already exists.`)) : (hr.setSourceType(t, s), s.workerSourceURL ? void this.dispatcher.broadcast("loadWorkerSource", { name: t, url: s.workerSourceURL }, h) : h(null, null)); } getFlatLight() { return this.light.getLight(); } setFlatLight(t, s, h = {}) { this._checkLoaded(); const _ = this.light.getLight(); let y = !1; for (const z in t) if (!i.bn(t[z], _[z])) { y = !0; break; } if (!y) return; const T = this._getTransitionParameters(); this.light.setLight(t, s, h), this.light.updateTransitions(T); } getTerrain() { return this.terrain && this.terrain.drapeRenderMode === 1 ? this.terrain.get() : null; } setTerrainForDraping() { this.setTerrain({ source: "", exaggeration: 0 }, 0); } checkCanvasFingerprintNoise() { this.disableElevatedTerrain === void 0 && (this.disableElevatedTerrain = i.q.hasCanvasFingerprintNoise(), this.disableElevatedTerrain && i.w("Terrain and hillshade are disabled because of Canvas2D limitations when fingerprinting protection is enabled (e.g. in private browsing mode).")); } setTerrain(t, s = 1) { if (this._checkLoaded(), !t) return this.terrainSetForDrapingOnly() || (delete this.terrain, this.map.transform.projection.requiresDraping && this.setTerrainForDraping()), s === 0 && delete this.terrain, t === null ? this.stylesheet.terrain = null : delete this.stylesheet.terrain, this._force3DLayerUpdate(), void (this._markersNeedUpdate = !0); this.checkCanvasFingerprintNoise(); let h = t; const _ = t.source == null; if (s === 1) { if (this.disableElevatedTerrain) return; if (typeof h.source == "object") { const z = "terrain-dem-src"; this.addSource(z, h.source), h = i.cp(h), h = i.l(h, { source: z }); } const y = i.l({}, h), T = {}; if (this.terrain && _) { y.source = this.terrain.get().source; const z = this.terrain ? this.getFragmentStyle(this.terrain.scope) : null; z && (T.style = z.serialize()); } if (this._validate(zs, "terrain", y, T)) return; } if (!this.terrain || this.terrain.scope !== this.scope && !_ || this.terrain && s !== this.terrain.drapeRenderMode) { if (!h) return; this._createTerrain(h, s), this.fire(new i.z("data", { dataType: "style" })); } else { const y = this.terrain, T = y.get(); for (const z of Object.keys(i.a3.terrain)) !h.hasOwnProperty(z) && i.a3.terrain[z].default && (h[z] = i.a3.terrain[z].default); for (const z in t) if (!i.bn(t[z], T[z])) { y.set(t, this.options), this.stylesheet.terrain = t; const R = this._getTransitionParameters({ duration: 0 }); y.updateTransitions(R), this.fire(new i.z("data", { dataType: "style" })); break; } } this.mergeTerrain(), this.updateDrapeFirstLayers(), this._markersNeedUpdate = !0; } _createFog(t) { const s = this.fog = new Ki(t, this.map.transform, this.scope, this.options); this.stylesheet.fog = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } _createSnow(t) { const s = this.snow = new Xn(t, this.map.transform, this.scope, this.options); this.stylesheet.snow = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } _createRain(t) { const s = this.rain = new Gs(t, this.map.transform, this.scope, this.options); this.stylesheet.rain = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } _updateMarkersOpacity() { this.map._markers.length !== 0 && this.map._requestDomTask(() => { for (const t of this.map._markers) t._evaluateOpacity(); }); } getFog() { return this.fog ? this.fog.get() : null; } setFog(t) { if (this._checkLoaded(), !t) return delete this.fog, delete this.stylesheet.fog, void (this._markersNeedUpdate = !0); if (this.fog) { const s = this.fog; if (!i.bn(s.get(), t)) { s.set(t, this.options), this.stylesheet.fog = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } } else this._createFog(t); this._markersNeedUpdate = !0; } getSnow() { return this.snow ? this.snow.get() : null; } setSnow(t) { if (this._checkLoaded(), !t) return delete this.snow, void delete this.stylesheet.snow; if (this.snow) { const s = this.snow; if (!i.bn(s.get(), t)) { s.set(t, this.options), this.stylesheet.snow = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } } else this._createSnow(t); this._markersNeedUpdate = !0; } getRain() { return this.rain ? this.rain.get() : null; } setRain(t) { if (this._checkLoaded(), !t) return delete this.rain, void delete this.stylesheet.rain; if (this.rain) { const s = this.rain; if (!i.bn(s.get(), t)) { s.set(t, this.options), this.stylesheet.rain = s.get(); const h = this._getTransitionParameters({ duration: 0 }); s.updateTransitions(h); } } else this._createRain(t); this._markersNeedUpdate = !0; } _reloadColorTheme() { const t = () => { for (const _ in this._layers) this._layers[_].lut = this._styleColorTheme.lut; for (const _ in this._sourceCaches) this._sourceCaches[_].clearTiles(); }, s = this._styleColorTheme.colorThemeOverride ? this._styleColorTheme.colorThemeOverride : this._styleColorTheme.colorTheme; if (!s) return this._styleColorTheme.lut = null, void t(); const h = this._evaluateColorThemeData(s); this._loadColorTheme(h).then(() => { this.fire(new i.z("colorthemeset")), t(); }).catch((_) => { i.w(`Couldn't set color theme: ${_}`); }); } setColorTheme(t) { this._checkLoaded(), this._styleColorTheme.colorThemeOverride && i.w("Note: setColorTheme is called on a style with a color-theme override, the passed color-theme won't be visible."), this._styleColorTheme.colorTheme = t, this._reloadColorTheme(); } setImportColorTheme(t, s) { const h = this.getFragmentStyle(t); h && (h._styleColorTheme.colorThemeOverride = s, h._reloadColorTheme()); } _getTransitionParameters(t) { return { now: i.q.now(), transition: i.l(this.transition, t) }; } updateDrapeFirstLayers() { if (!this.terrain) return; const t = [], s = []; for (const h of this._mergedOrder) this.isLayerDraped(this._mergedLayers[h]) ? t.push(h) : s.push(h); this._drapedFirstOrder = [], this._drapedFirstOrder.push(...t), this._drapedFirstOrder.push(...s); } _createTerrain(t, s) { const h = this.terrain = new it(t, s, this.scope, this.options); s === 1 && (this.stylesheet.terrain = t), this.mergeTerrain(), this.updateDrapeFirstLayers(), this._force3DLayerUpdate(); const _ = this._getTransitionParameters({ duration: 0 }); h.updateTransitions(_); } _force3DLayerUpdate() { for (const t in this._layers) { const s = this._layers[t]; s.type === "fill-extrusion" && this._updateLayer(s); } } _forceSymbolLayerUpdate() { for (const t in this._layers) { const s = this._layers[t]; s.type === "symbol" && this._updateLayer(s); } } _validate(t, s, h, _, y = {}) { if (y && y.validate === !1) return !1; const T = i.l({}, this.serialize()); return Po(this, t.call(Zi, i.l({ key: s, style: T, value: h, styleSpec: i.a3 }, _))); } _remove() { this._request && (this._request.cancel(), this._request = null), this._spriteRequest && (this._spriteRequest.cancel(), this._spriteRequest = null), i.cx.off("pluginStateChange", this._rtlTextPluginCallback); for (const t in this._mergedLayers) this._mergedLayers[t].setEventedParent(null); for (const t in this._mergedSourceCaches) this._mergedSourceCaches[t].clearTiles(), this._mergedSourceCaches[t].setEventedParent(null); this.setEventedParent(null), delete this.fog, delete this.snow, delete this.rain, delete this.terrain, delete this.ambientLight, delete this.directionalLight, this.isRootStyle() && (this.imageManager.setEventedParent(null), this.modelManager.setEventedParent(null), this.dispatcher.remove()); } clearSource(t) { const s = this.getSourceCaches(t); for (const h of s) h.clearTiles(); } clearSources() { for (const t in this._mergedSourceCaches) this._mergedSourceCaches[t].clearTiles(); } reloadSource(t) { const s = this.getSourceCaches(t); for (const h of s) h.resume(), h.reload(); } reloadSources() { for (const t of this.getSources()) t.reload && t.reload(); } updateSources(t) { let s; this.directionalLight && (s = Yo(this.directionalLight)); for (const h in this._mergedSourceCaches) this._mergedSourceCaches[h].update(t, void 0, void 0, s); } _generateCollisionBoxes() { for (const t in this._sourceCaches) { const s = this._sourceCaches[t]; s.resume(), s.reload(); } } _updatePlacement(t, s, h, _, y, T, z = !1) { let R = !1, F = !1; const N = {}, G = {}; for (const Z of this._mergedOrder) { const W = this._mergedLayers[Z]; if (W.type !== "symbol") continue; const te = i.aC(W.source, W.scope); let ee = N[te]; if (!ee) { const oe = this.getLayerSourceCache(W); if (!oe) continue; const he = oe.getRenderableIds(!0).map((_e) => oe.getTileByID(_e)); G[te] = he.slice(), ee = N[te] = he.sort((_e, pe) => pe.tileID.overscaledZ - _e.tileID.overscaledZ || (_e.tileID.isLessThan(pe.tileID) ? -1 : 1)); } const se = this.crossTileSymbolIndex.addLayer(W, ee, s.center.lng, s.projection); R = R || se; } if (this.crossTileSymbolIndex.pruneUnusedLayers(this._mergedOrder), z = z || this._layerOrderChanged || _ === 0, this._layerOrderChanged && this.fire(new i.z("neworder")), (z || !this.pauseablePlacement || this.pauseablePlacement.isDone() && !this.placement.stillRecent(i.q.now(), s.zoom)) && (this.pauseablePlacement = new $o(s, this._mergedOrder, z, h, _, y, this.placement, this.fog && s.projection.supportsFog ? this.fog.state : null, this._buildingIndex), this._layerOrderChanged = !1), this.pauseablePlacement.isDone() ? this.placement.setStale() : (this.pauseablePlacement.continuePlacement(this._mergedOrder, this._mergedLayers, N, G, this.map.painter.scaleFactor), this.pauseablePlacement.isDone() && (this.placement = this.pauseablePlacement.commit(i.q.now()), F = !0), R && this.pauseablePlacement.placement.setStale()), F || R) { this._buildingIndex.onNewFrame(s.zoom); for (let Z = 0; Z < this._mergedOrder.length; Z++) { const W = this._mergedLayers[this._mergedOrder[Z]]; if (W.type !== "symbol") continue; const te = this.isLayerClipped(W); this.placement.updateLayerOpacities(W, N[i.aC(W.source, W.scope)], Z, te ? T : null); } } return { needsRerender: !this.pauseablePlacement.isDone() || this.placement.hasTransitions(i.q.now()) }; } _releaseSymbolFadeTiles() { for (const t in this._sourceCaches) this._sourceCaches[t].releaseSymbolFadeTiles(); } addImport(t, s) { this._checkLoaded(); const h = this.stylesheet.imports = this.stylesheet.imports || []; if (h.findIndex(({ id: y }) => y === t.id) !== -1) return void this.fire(new i.y(new Error(`Import with id '${t.id}' already exists in the map's style.`))); if (!s) return h.push(t), this._loadImports([t], !0); const _ = h.findIndex(({ id: y }) => y === s); return _ === -1 && this.fire(new i.y(new Error(`Import with id "${s}" does not exist on this map.`))), this.stylesheet.imports = h.slice(0, _).concat(t).concat(h.slice(_)), this._loadImports([t], !0, s); } updateImport(t, s) { this._checkLoaded(); const h = this.stylesheet.imports || [], _ = this.getImportIndex(t); return _ === -1 ? this : typeof s == "string" ? (this.setImportUrl(t, s), this) : (s.url && s.url !== h[_].url && this.setImportUrl(t, s.url), i.bn(s.config, h[_].config) || this.setImportConfig(t, s.config), i.bn(s.data, h[_].data) || this.setImportData(t, s.data), this); } moveImport(t, s) { this._checkLoaded(); let h = this.stylesheet.imports || []; const _ = this.getImportIndex(t); if (_ === -1) return this; const y = this.getImportIndex(s); if (y === -1) return this; const T = h[_], z = this.fragments[_]; return h = h.filter(({ id: R }) => R !== t), this.fragments = this.fragments.filter(({ id: R }) => R !== t), this.stylesheet.imports = h.slice(0, y).concat(T).concat(h.slice(y)), this.fragments = this.fragments.slice(0, y).concat(z).concat(this.fragments.slice(y)), this.mergeLayers(), this; } setImportUrl(t, s) { this._checkLoaded(); const h = this.stylesheet.imports || [], _ = this.getImportIndex(t); if (_ === -1) return this; h[_].url = s; const y = this.fragments[_]; return y.style = this._createFragmentStyle(h[_]), y.style.on("style.import.load", () => this.mergeAll()), y.style.loadURL(s), this; } setImportData(t, s) { this._checkLoaded(); const h = this.getImportIndex(t), _ = this.stylesheet.imports || []; return h === -1 ? this : s ? (this.fragments[h].style.setState(s), this._reloadImports(), this) : (delete _[h].data, this.setImportUrl(t, _[h].url)); } setImportConfig(t, s) { this._checkLoaded(); const h = this.getImportIndex(t), _ = this.stylesheet.imports || []; if (h === -1) return this; s ? _[h].config = s : delete _[h].config; const y = this.fragments[h], T = y.style.stylesheet && y.style.stylesheet.schema; return y.config = s, y.style.updateConfig(s, T), this.updateConfigDependencies(), this; } removeImport(t) { this._checkLoaded(); const s = this.stylesheet.imports || [], h = this.getImportIndex(t); h !== -1 && (s.splice(h, 1), this.fragments[h].style._remove(), this.fragments.splice(h, 1), this._reloadImports()); } getImportIndex(t) { const s = (this.stylesheet.imports || []).findIndex((h) => h.id === t); return s === -1 && this.fire(new i.y(new Error(`Import '${t}' does not exist in the map's style and cannot be updated.`))), s; } getLayer(t) { return this._mergedLayers[t]; } getSources() { const t = []; for (const s in this._mergedOtherSourceCaches) { const h = this._mergedOtherSourceCaches[s]; h && t.push(h.getSource()); } return t; } getSource(t, s) { const h = this.getSourceCache(t, s); return h && h.getSource(); } getLayerSource(t) { const s = this.getLayerSourceCache(t); return s && s.getSource(); } getSourceCache(t, s) { const h = i.aC(t, s); return this._mergedOtherSourceCaches[h]; } getLayerSourceCache(t) { const s = i.aC(t.source, t.scope); return t.type === "symbol" ? this._mergedSymbolSourceCaches[s] : this._mergedOtherSourceCaches[s]; } getSourceCaches(t) { if (t == null) return Object.values(this._mergedSourceCaches); const s = []; return this._mergedOtherSourceCaches[t] && s.push(this._mergedOtherSourceCaches[t]), this._mergedSymbolSourceCaches[t] && s.push(this._mergedSymbolSourceCaches[t]), s; } updateSourceCaches() { const t = this._changes.getUpdatedSourceCaches(); for (const s in t) { const h = t[s]; h === "reload" ? this.reloadSource(s) : h === "clear" && this.clearSource(s); } } updateLayers(t) { const s = this._changes.getUpdatedPaintProperties(); for (const h of s) { const _ = this.getLayer(h); _ && _.updateTransitions(t); } } getImages(t, s, h) { this.imageManager.getImages(s.icons, s.scope, h), this._updateTilesForChangedImages(); const _ = (y) => { y && y.setDependencies(s.tileID.key, s.type, s.icons); }; _(this._otherSourceCaches[s.source]), _(this._symbolSourceCaches[s.source]); } rasterizeImages(t, s, h) { this.imageManager.rasterizeImages(s, h); } getGlyphs(t, s, h) { this.glyphManager.getGlyphs(s.stacks, s.scope, h); } getResource(t, s, h) { return i.cy(s, h); } getOwnSourceCache(t) { return this._otherSourceCaches[t]; } getOwnLayerSourceCache(t) { return t.type === "symbol" ? this._symbolSourceCaches[t.source] : this._otherSourceCaches[t.source]; } getOwnSourceCaches(t) { const s = []; return this._otherSourceCaches[t] && s.push(this._otherSourceCaches[t]), this._symbolSourceCaches[t] && s.push(this._symbolSourceCaches[t]), s; } _isSourceCacheLoaded(t) { const s = this.getOwnSourceCaches(t); return s.length === 0 ? (this.fire(new i.y(new Error(`There is no source with ID '${t}'`))), !1) : s.every((h) => h.loaded()); } has3DLayers() { return this._has3DLayers; } hasSymbolLayers() { return this._hasSymbolLayers; } hasCircleLayers() { return this._hasCircleLayers; } isLayerClipped(t, s) { if (!this._clipLayerPresent && t.type !== "fill-extrusion") return !1; const h = t.type === "fill-extrusion" && t.sourceLayer === "building"; if (t.is3D()) { if (h || s && s.type === "batched-model" || t.type === "model") return !0; } else if (t.type === "symbol") return !0; return !1; } _clearWorkerCaches() { this.dispatcher.broadcast("clearCaches"); } destroy() { this._clearWorkerCaches(), this.fragments.forEach((t) => { t.style._remove(); }), this.terrainSetForDrapingOnly() && (delete this.terrain, delete this.stylesheet.terrain); } } hr.getSourceType = function(c) { return no[c]; }, hr.setSourceType = function(c, t) { no[c] = t; }, hr.registerForPluginStateChange = i.ch; var Zc = ` #define EPSILON 0.0000001 #define PI 3.141592653589793 #ifdef RENDER_CUTOFF float cutoff_opacity(vec4 cutoff_params,float depth) {float near=cutoff_params.x;float far=cutoff_params.y;float cutoffStart=cutoff_params.z;float cutoffEnd=cutoff_params.w;float linearDepth=(depth-near)/(far-near);return clamp((linearDepth-cutoffStart)/(cutoffEnd-cutoffStart),0.0,1.0);} #endif`, Hc = ` out vec4 glFragColor;highp float unpack_depth(highp vec4 rgba_depth) {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;} #ifdef INDICATOR_CUTOUT uniform vec3 u_indicator_cutout_centers;uniform vec4 u_indicator_cutout_params; #endif vec4 applyCutout(vec4 color,float height) { #ifdef INDICATOR_CUTOUT float verticalFadeRange=u_indicator_cutout_centers.z*0.25;float holeMinOpacity=mix(1.0,u_indicator_cutout_params.x,smoothstep(u_indicator_cutout_centers.z,u_indicator_cutout_centers.z+verticalFadeRange,height));float holeRadius=max(u_indicator_cutout_params.y,0.0);float holeAspectRatio=u_indicator_cutout_params.z;float fadeStart=u_indicator_cutout_params.w;float distA=distance(vec2(gl_FragCoord.x,gl_FragCoord.y*holeAspectRatio),vec2(u_indicator_cutout_centers[0],u_indicator_cutout_centers[1]*holeAspectRatio));return color*min(smoothstep(fadeStart,holeRadius,distA)+holeMinOpacity,1.0); #else return color; #endif } #ifdef DEBUG_WIREFRAME #define HANDLE_WIREFRAME_DEBUG \\ glFragColor=vec4(0.7,0.0,0.0,0.7); \\ gl_FragDepth=gl_FragCoord.z-0.0001; #else #define HANDLE_WIREFRAME_DEBUG #endif #ifdef RENDER_CUTOFF uniform highp vec4 u_cutoff_params;in float v_cutoff_opacity; #endif vec4 textureLodCustom(sampler2D image,highp vec2 pos,highp vec2 lod_coord) {highp vec2 size=vec2(textureSize(image,0));highp vec2 dx=dFdx(lod_coord.xy*size);highp vec2 dy=dFdy(lod_coord.xy*size);highp float delta_max_sqr=max(dot(dx,dx),dot(dy,dy));highp float lod=0.5*log2(delta_max_sqr);return textureLod(image,pos,lod);}vec4 applyLUT(highp sampler3D lut,vec4 col) {vec3 size=vec3(textureSize(lut,0));vec3 uvw=(col.rbg*float(size-1.0)+0.5)/size;return vec4(texture(lut,uvw).rgb,col.a);}vec3 applyLUT(highp sampler3D lut,vec3 col) {return applyLUT(lut,vec4(col,1.0)).rgb;}`, xr = ` #define EXTENT 8192.0 #define RAD_TO_DEG 180.0/PI #define DEG_TO_RAD PI/180.0 #define GLOBE_RADIUS EXTENT/PI/2.0 float 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;} #ifdef PROJECTION_GLOBE_VIEW vec3 mercator_tile_position(mat4 matrix,vec2 tile_anchor,vec3 tile_id,vec2 mercator_center) { #ifndef PROJECTED_POS_ON_VIEWPORT float 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; #else return vec3(0.0); #endif }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);} #endif vec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec2 unpack_opacity(const float packedOpacity) {int intOpacity=int(packedOpacity)/2;return vec2(float(intOpacity)/127.0,mod(packedOpacity,2.0));}vec4 decode_color(const vec2 encodedColor) {return vec4( unpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0 );}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 vec2 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 (units_to_pixels*pos+offset)/pattern_size;}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) {return get_pattern_pos(pixel_coord_upper,pixel_coord_lower,pattern_size,vec2(tile_units_to_pixels),pos);}float mercatorXfromLng(float lng) {return (180.0+lng)/360.0;}float mercatorYfromLat(float lat) {return (180.0-(RAD_TO_DEG*log(tan(PI/4.0+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);} #ifdef RENDER_CUTOFF uniform vec4 u_cutoff_params;out float v_cutoff_opacity; #endif const vec4 AWAY=vec4(-1000.0,-1000.0,-1000.0,1);const float skirtOffset=24575.0;vec3 decomposeToPosAndSkirt(vec2 posWithComposedSkirt) {float skirt=float(posWithComposedSkirt.x >=skirtOffset);vec2 pos=posWithComposedSkirt-vec2(skirt*skirtOffset,0.0);return vec3(pos,skirt);}`, Ko = "in highp vec3 a_pos_3f;uniform lowp mat4 u_matrix;out 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;}", Xl = ` #define ELEVATION_SCALE 7.0 #define ELEVATION_OFFSET 450.0 #ifdef PROJECTION_GLOBE_VIEW uniform 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( mix(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;} #else vec3 elevationVector(vec2 pos) { return vec3(0,0,1); } #endif #ifdef TERRAIN uniform highp sampler2D u_dem;uniform highp sampler2D u_dem_prev;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;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 currentElevation(vec2 apos) { #ifdef TERRAIN_DEM_FLOAT_FORMAT vec2 pos=(u_dem_size*(apos/8192.0*u_dem_scale+u_dem_tl)+1.5)/(u_dem_size+2.0);return u_exaggeration*texture(u_dem,pos).r; #else float 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=texture(u_dem,pos).r;float tr=texture(u_dem,pos+vec2(dd,0)).r;float bl=texture(u_dem,pos+vec2(0,dd)).r;float br=texture(u_dem,pos+vec2(dd,dd)).r;return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y); #endif }float prevElevation(vec2 apos) { #ifdef TERRAIN_DEM_FLOAT_FORMAT vec2 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*texture(u_dem_prev,pos).r; #else float 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=texture(u_dem_prev,pos).r;float tr=texture(u_dem_prev,pos+vec2(dd,0)).r;float bl=texture(u_dem_prev,pos+vec2(0,dd)).r;float br=texture(u_dem_prev,pos+vec2(dd,dd)).r;return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y); #endif } #ifdef TERRAIN_VERTEX_MORPHING float elevation(vec2 apos) { #ifdef ZERO_EXAGGERATION return 0.0; #endif float nextElevation=currentElevation(apos);float prevElevation=prevElevation(apos);return mix(prevElevation,nextElevation,u_dem_lerp);} #else float elevation(vec2 apos) { #ifdef ZERO_EXAGGERATION return 0.0; #endif return currentElevation(apos);} #endif vec4 fourSample(vec2 pos,vec2 off) {float tl=texture(u_dem,pos).r;float tr=texture(u_dem,pos+vec2(off.x,0.0)).r;float bl=texture(u_dem,pos+vec2(0.0,off.y)).r;float br=texture(u_dem,pos+off).r;return 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);} #else float elevation(vec2 pos) { return 0.0; } #endif #ifdef DEPTH_OCCLUSION uniform highp sampler2D u_depth;uniform highp vec2 u_depth_size_inv;uniform highp vec2 u_depth_range_unpack;uniform highp float u_occluder_half_size;uniform highp float u_occlusion_depth_offset; #ifdef DEPTH_D24 float unpack_depth(float depth) {return depth*u_depth_range_unpack.x+u_depth_range_unpack.y;}vec4 unpack_depth4(vec4 depth) {return depth*u_depth_range_unpack.x+vec4(u_depth_range_unpack.y);} #else highp float unpack_depth_rgba(vec4 rgba_depth) {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;} #endif bool isOccluded(vec4 frag) {vec3 coord=frag.xyz/frag.w; #ifdef DEPTH_D24 float depth=unpack_depth(texture(u_depth,(coord.xy+1.0)*0.5).r); #else float depth=unpack_depth_rgba(texture(u_depth,(coord.xy+1.0)*0.5)); #endif return coord.z+u_occlusion_depth_offset > depth;}highp vec4 getCornerDepths(vec2 coord) {highp vec3 df=vec3(u_occluder_half_size*u_depth_size_inv,0.0);highp vec2 uv=0.5*coord.xy+0.5; #ifdef DEPTH_D24 highp vec4 depth=vec4( texture(u_depth,uv-df.xz).r,texture(u_depth,uv+df.xz).r,texture(u_depth,uv-df.zy).r,texture(u_depth,uv+df.zy).r );depth=unpack_depth4(depth); #else highp vec4 depth=vec4( unpack_depth_rgba(texture(u_depth,uv-df.xz)),unpack_depth_rgba(texture(u_depth,uv+df.xz)),unpack_depth_rgba(texture(u_depth,uv-df.zy)),unpack_depth_rgba(texture(u_depth,uv+df.zy)) ); #endif return depth;}highp float occlusionFadeMultiSample(vec4 frag) {highp vec3 coord=frag.xyz/frag.w;highp vec2 uv=0.5*coord.xy+0.5;int NX=3;int NY=4;highp vec2 df=u_occluder_half_size*u_depth_size_inv;highp vec2 oneStep=2.0*u_occluder_half_size*u_depth_size_inv/vec2(NX-1,NY-1);highp float res=0.0;for (int y=0; y < NY;++y) {for (int x=0; x < NX;++x) { #ifdef DEPTH_D24 highp float depth=unpack_depth(texture(u_depth,uv-df+vec2(float(x)*oneStep.x,float(y)*oneStep.y)).r); #else highp float depth=unpack_depth_rgba(texture(u_depth,uv-df+vec2(float(x)*oneStep.x,float(y)*oneStep.y))); #endif res+=1.0-clamp(300.0*(coord.z+u_occlusion_depth_offset-depth),0.0,1.0);}}res=clamp(2.0*res/float(NX*NY)-0.5,0.0,1.0);return res;}highp float occlusionFade(vec4 frag) {highp vec3 coord=frag.xyz/frag.w;highp vec4 depth=getCornerDepths(coord.xy);return dot(vec4(0.25),vec4(1.0)-clamp(300.0*(vec4(coord.z+u_occlusion_depth_offset)-depth),0.0,1.0));} #else bool isOccluded(vec4 frag) { return false; }highp float occlusionFade(vec4 frag) { return 1.0; }highp float occlusionFadeMultiSample(vec4 frag) { return 1.0; } #endif//DEPTH_OCCLUSION`, Jr = `#ifdef FOG uniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump mat4 u_fog_matrix;out 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);} #endif`, Yl = `highp 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;} #ifdef FOG uniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump vec2 u_fog_vertical_limit;uniform mediump float u_fog_temporal_offset;in 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( mix(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 opacity_limit) {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,min(opacity,opacity_limit));}vec3 fog_apply(vec3 color,vec3 pos) {return fog_apply(color,pos,1.0);}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;}vec4 fog_apply_premultiplied(vec4 color,vec3 pos,float heightMeters) {float verticalProgress=(u_fog_vertical_limit.x > 0.0 || u_fog_vertical_limit.y > 0.0) ? smoothstep(u_fog_vertical_limit.x,u_fog_vertical_limit.y,heightMeters) : 0.0;float opacityLimit=1.0-smoothstep(0.9,1.0,fog_opacity(pos));return mix(fog_apply_premultiplied(color,pos),color,min(verticalProgress,opacityLimit));}vec3 fog_dither(vec3 color) { #ifdef FOG_DITHERING vec2 dither_seed=gl_FragCoord.xy+u_fog_temporal_offset;return dither(color,dither_seed); #else return color; #endif }vec4 fog_dither(vec4 color) {return vec4(fog_dither(color.rgb),color.a);} #endif`, Kl = `#ifdef RASTER_ARRAY uniform highp sampler2D u_image0;uniform sampler2D u_image1;const vec4 NODATA=vec4(1);ivec4 _raTexLinearCoord(highp vec2 texCoord,highp vec2 texResolution,out highp vec2 fxy) {texCoord=texCoord*texResolution-0.5;fxy=fract(texCoord);texCoord-=fxy;return ivec4(texCoord.xxyy+vec2(1.5,0.5).xyxy);}vec2 _raTexLinearMix(highp vec2 fxy,highp vec4 colorMix,highp float colorOffset,highp vec4 t00,highp vec4 t10,highp vec4 t01,highp vec4 t11) {vec2 c00=t00==NODATA ? vec2(0) : vec2(colorOffset+dot(t00,colorMix),1);vec2 c10=t10==NODATA ? vec2(0) : vec2(colorOffset+dot(t10,colorMix),1);vec2 c01=t01==NODATA ? vec2(0) : vec2(colorOffset+dot(t01,colorMix),1);vec2 c11=t11==NODATA ? vec2(0) : vec2(colorOffset+dot(t11,colorMix),1);return mix(mix(c01,c11,fxy.x),mix(c00,c10,fxy.x),fxy.y);}vec2 raTexture2D_image0_linear(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec2 fxy;ivec4 c=_raTexLinearCoord(texCoord,texResolution,fxy);return _raTexLinearMix(fxy,colorMix,colorOffset,texelFetch(u_image0,c.yz,0),texelFetch(u_image0,c.xz,0),texelFetch(u_image0,c.yw,0),texelFetch(u_image0,c.xw,0) );}vec2 raTexture2D_image1_linear(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec2 fxy;ivec4 c=_raTexLinearCoord(texCoord,texResolution,fxy);return _raTexLinearMix(fxy,colorMix,colorOffset,texelFetch(u_image1,c.yz,0),texelFetch(u_image1,c.xz,0),texelFetch(u_image1,c.yw,0),texelFetch(u_image1,c.xw,0) );}vec2 raTexture2D_image0_nearest(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec4 t=texelFetch(u_image0,ivec2(texCoord*texResolution),0);return t==NODATA ? vec2(0) : vec2(colorOffset+dot(t,colorMix),1);}vec2 raTexture2D_image1_nearest(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec4 t=texelFetch(u_image1,ivec2(texCoord*texResolution),0);return t==NODATA ? vec2(0) : vec2(colorOffset+dot(t,colorMix),1);} #endif`, ya = `#ifdef RASTER_ARRAY uniform sampler2D u_velocity;uniform mediump vec2 u_velocity_res;uniform mediump float u_max_speed;const vec4 NO_DATA=vec4(1);const vec2 INVALID_VELOCITY=vec2(-1);uniform highp vec2 u_uv_offset;uniform highp float u_data_offset;uniform highp vec2 u_data_scale;ivec4 rasterArrayLinearCoord(highp vec2 texCoord,highp vec2 texResolution,out highp vec2 fxy) {texCoord=texCoord*texResolution-0.5;fxy=fract(texCoord);texCoord-=fxy;return ivec4(texCoord.xxyy+vec2(1.5,0.5).xyxy);}highp vec2 lookup_velocity(highp vec2 uv) {uv=u_uv_offset.x+u_uv_offset.y*uv;highp vec2 fxy;ivec4 c=rasterArrayLinearCoord(uv,u_velocity_res,fxy);highp vec4 tl=texelFetch(u_velocity,c.yz,0);highp vec4 tr=texelFetch(u_velocity,c.xz,0);highp vec4 bl=texelFetch(u_velocity,c.yw,0);highp vec4 br=texelFetch(u_velocity,c.xw,0);if (tl==NO_DATA) {return INVALID_VELOCITY;}if (tr==NO_DATA) {return INVALID_VELOCITY;}if (bl==NO_DATA) {return INVALID_VELOCITY;}if (br==NO_DATA) {return INVALID_VELOCITY;}highp vec4 t=mix(mix(bl,br,fxy.x),mix(tl,tr,fxy.x),fxy.y);highp vec2 velocity=u_data_offset+vec2(dot(t.rg,u_data_scale),dot(t.ba,u_data_scale));velocity.y=-velocity.y;velocity/=max(u_max_speed,length(velocity));return velocity;} #endif uniform highp float u_particle_pos_scale;uniform highp vec2 u_particle_pos_offset;highp vec4 pack_pos_to_rgba(highp vec2 p) {highp vec2 v=(p+u_particle_pos_offset)/u_particle_pos_scale;highp vec4 r=vec4(v.x,fract(v.x*255.0),v.y,fract(v.y*255.0));return vec4(r.x-r.y/255.0,r.y,r.z-r.w/255.0,r.w);}highp vec2 unpack_pos_from_rgba(highp vec4 v) {v=floor(v*255.0+0.5)/255.0;highp vec2 p=vec2(v.x+(v.y/255.0),v.z+(v.w/255.0));return u_particle_pos_scale*p-u_particle_pos_offset;}`, ro = `#ifdef RENDER_SHADOWS uniform mediump vec3 u_shadow_direction;uniform highp vec3 u_shadow_normal_offset;vec3 shadow_normal_offset(vec3 normal) {float tileInMeters=u_shadow_normal_offset[0];vec3 n=vec3(-normal.xy,tileInMeters*normal.z);float dotScale=min(1.0-dot(normal,u_shadow_direction),1.0)*0.5+0.5;return n*dotScale;}vec3 shadow_normal_offset_model(vec3 normal) {vec3 transformed_normal=vec3(-normal.xy,normal.z);float NDotL=dot(normalize(transformed_normal),u_shadow_direction);float dotScale=min(1.0-NDotL,1.0)*0.5+0.5;return normal*dotScale;}float shadow_normal_offset_multiplier0() {return u_shadow_normal_offset[1];}float shadow_normal_offset_multiplier1() {return u_shadow_normal_offset[2];} #endif//RENDER_SHADOWS`, xl = `#ifdef RENDER_SHADOWS #ifdef DEPTH_TEXTURE uniform highp sampler2D u_shadowmap_0;uniform highp sampler2D u_shadowmap_1; #else uniform sampler2D u_shadowmap_0;uniform sampler2D u_shadowmap_1; #endif uniform float u_shadow_intensity;uniform float u_shadow_map_resolution;uniform float u_shadow_texel_size;uniform highp vec3 u_shadow_normal_offset;uniform vec2 u_fade_range;uniform mediump vec3 u_shadow_direction;uniform highp vec3 u_shadow_bias;highp float shadow_sample_1(highp vec2 uv,highp float compare) {highp float shadow_depth; #ifdef DEPTH_TEXTURE shadow_depth=texture(u_shadowmap_1,uv).r; #else shadow_depth=unpack_depth(texture(u_shadowmap_1,uv))*0.5+0.5; #endif return step(shadow_depth,compare);}highp float shadow_sample_0(highp vec2 uv,highp float compare) {highp float shadow_depth; #ifdef DEPTH_TEXTURE shadow_depth=texture(u_shadowmap_0,uv).r; #else shadow_depth=unpack_depth(texture(u_shadowmap_0,uv))*0.5+0.5; #endif return step(shadow_depth,compare);}float shadow_occlusion_1(highp vec4 pos,highp float bias) {highp vec2 uv=pos.xy;return shadow_sample_1(uv,pos.z-bias);}float shadow_occlusion_0(highp vec4 pos,highp float bias) {highp float compare0=pos.z-bias; #ifdef TEXTURE_GATHER highp vec2 uv=pos.xy;highp vec4 samples=textureGather(u_shadowmap_0,uv,0);lowp vec4 stepSamples=step(samples,vec4(compare0)); #else highp vec2 uv00=pos.xy-vec2(0.5*u_shadow_texel_size);highp vec2 uv10=uv00+vec2(u_shadow_texel_size,0.0);highp vec2 uv01=uv00+vec2(0.0,u_shadow_texel_size);highp vec2 uv11=uv01+vec2(u_shadow_texel_size,0.0);lowp vec4 stepSamples=vec4( shadow_sample_0(uv01,compare0),shadow_sample_0(uv11,compare0),shadow_sample_0(uv10,compare0),shadow_sample_0(uv00,compare0) ); #endif vec2 f=fract(pos.xy*u_shadow_map_resolution-vec2(0.5));lowp vec2 lerpx=mix(stepSamples.wx,stepSamples.zy,f.xx);return mix(lerpx.x,lerpx.y,f.y);}float shadow_occlusion(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth,highp float bias) { #ifdef SHADOWS_SINGLE_CASCADE light_view_pos0.xyz/=light_view_pos0.w;vec2 abs_bounds=abs(light_view_pos0.xy);if (abs_bounds.x >=1.0 || abs_bounds.y >=1.0) {return 0.0;}light_view_pos0.xyz=light_view_pos0.xyz*0.5+0.5;return shadow_occlusion_0(light_view_pos0,bias); #else light_view_pos0.xyz/=light_view_pos0.w;light_view_pos1.xyz/=light_view_pos1.w;vec4 uv=vec4(light_view_pos0.xy,light_view_pos1.xy);vec4 abs_bounds=abs(uv);if (abs_bounds.x < 1.0 && abs_bounds.y < 1.0) {light_view_pos0.xyz=light_view_pos0.xyz*0.5+0.5;return shadow_occlusion_0(light_view_pos0,bias);}if (abs_bounds.z >=1.0 || abs_bounds.w >=1.0) {return 0.0;}light_view_pos1.xyz=light_view_pos1.xyz*0.5+0.5;float occlusion1=shadow_occlusion_1(light_view_pos1,bias);return mix(occlusion1,0.0,smoothstep(u_fade_range.x,u_fade_range.y,view_depth)); #endif }highp float calculate_shadow_bias(float NDotL) { #ifdef NORMAL_OFFSET return 0.5*u_shadow_bias.x; #else return 0.5*(u_shadow_bias.x+clamp(u_shadow_bias.y*tan(acos(NDotL)),0.0,u_shadow_bias.z)); #endif }float shadowed_light_factor_normal(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float NDotL=dot(N,u_shadow_direction);float bias=calculate_shadow_bias(NDotL);float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}float shadowed_light_factor_normal_opacity(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth,float shadow_opacity) {float NDotL=dot(N,u_shadow_direction);float bias=calculate_shadow_bias(NDotL);float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias)*shadow_opacity;return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}float shadowed_light_factor_normal_unbiased(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float NDotL=dot(N,u_shadow_direction);float bias=0.0;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}highp vec2 compute_receiver_plane_depth_bias(highp vec3 pos_dx,highp vec3 pos_dy) {highp vec2 biasUV=vec2( pos_dy.y*pos_dx.z-pos_dx.y*pos_dy.z,pos_dx.x*pos_dy.z-pos_dy.x*pos_dx.z);biasUV*=1.0/((pos_dx.x*pos_dy.y)-(pos_dx.y*pos_dy.x));return biasUV;}float shadowed_light_factor_plane_bias(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {highp vec3 light_view_pos0_xyz=light_view_pos0.xyz/light_view_pos0.w*0.5+0.5;highp vec3 light_view_pos0_ddx=dFdx(light_view_pos0_xyz);highp vec3 light_view_pos0_ddy=dFdy(light_view_pos0_xyz);highp vec2 plane_depth_bias=compute_receiver_plane_depth_bias(light_view_pos0_ddx,light_view_pos0_ddy);highp float bias=dot(vec2(u_shadow_texel_size,u_shadow_texel_size),plane_depth_bias)+0.0001;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return 1.0-(u_shadow_intensity*occlusion);}float shadowed_light_factor(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float bias=0.0;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return 1.0-(u_shadow_intensity*occlusion);}float shadow_occlusion(float ndotl,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float bias=calculate_shadow_bias(ndotl);return shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);} #endif`; const kr = []; ao(Zc, kr), ao(xr, kr), ao(Hc, kr); const oo = { "_prelude_fog.vertex.glsl": Jr, "_prelude_terrain.vertex.glsl": Xl, "_prelude_shadow.vertex.glsl": ro, "_prelude_fog.fragment.glsl": Yl, "_prelude_shadow.fragment.glsl": xl, "_prelude_lighting.glsl": ` #ifdef LIGHTING_3D_MODE uniform mediump vec3 u_lighting_ambient_color;uniform mediump vec3 u_lighting_directional_dir;uniform mediump vec3 u_lighting_directional_color;uniform mediump vec3 u_ground_radiance;float calculate_ambient_directional_factor(vec3 normal) {float NdotL=dot(normal,u_lighting_directional_dir);const float factor_reduction_max=0.3;float dir_luminance=dot(u_lighting_directional_color,vec3(0.2126,0.7152,0.0722));float directional_factor_min=1.0-factor_reduction_max*min(dir_luminance,1.0);float ambient_directional_factor=mix(directional_factor_min,1.0,min((NdotL+1.0),1.0));const float vertical_factor_min=0.92;float vertical_factor=mix(vertical_factor_min,1.0,normal.z*0.5+0.5);return vertical_factor*ambient_directional_factor;}vec3 linearProduct(vec3 srgbIn,vec3 k) {return srgbIn*pow(k,vec3(1./2.2));}vec3 apply_lighting(vec3 color,vec3 normal,float dir_factor) {float ambient_directional_factor=calculate_ambient_directional_factor(normal);vec3 ambient_contrib=ambient_directional_factor*u_lighting_ambient_color;vec3 directional_contrib=u_lighting_directional_color*dir_factor;return linearProduct(color,ambient_contrib+directional_contrib);}vec4 apply_lighting(vec4 color,vec3 normal,float dir_factor) {return vec4(apply_lighting(color.rgb,normal,dir_factor),color.a);}vec3 apply_lighting(vec3 color,vec3 normal) {float dir_factor=max(dot(normal,u_lighting_directional_dir),0.0);return apply_lighting(color.rgb,normal,dir_factor);}vec4 apply_lighting(vec4 color,vec3 normal) {float dir_factor=max(dot(normal,u_lighting_directional_dir),0.0);return vec4(apply_lighting(color.rgb,normal,dir_factor),color.a);}vec3 apply_lighting_ground(vec3 color) {return color*u_ground_radiance;}vec4 apply_lighting_ground(vec4 color) {return vec4(apply_lighting_ground(color.rgb),color.a);}float calculate_NdotL(vec3 normal) {const float ext=0.70710678118;return (clamp(dot(normal,u_lighting_directional_dir),-ext,1.0)+ext)/(1.0+ext);}vec4 apply_lighting_with_emission_ground(vec4 color,float emissive_strength) {return mix(apply_lighting_ground(color),color,emissive_strength);}vec3 compute_flood_lighting(vec3 flood_light_color,float fully_occluded_factor,float occlusion,vec3 ground_shadow_factor) {vec3 fully_occluded_color=flood_light_color*mix(ground_shadow_factor,vec3(1.0),fully_occluded_factor);float occlusion_ramp=smoothstep(0.0,0.2,1.0-occlusion);return mix(fully_occluded_color,flood_light_color,occlusion_ramp);}vec3 compute_emissive_draped(vec3 unlit_color,float fully_occluded_factor,float occlusion,vec3 ground_shadow_factor) {vec3 fully_occluded_color=unlit_color*mix(ground_shadow_factor,vec3(1.0),fully_occluded_factor);return mix(fully_occluded_color,unlit_color,1.0-occlusion);} #endif//LIGHTING_3D_MODE`, "_prelude_raster_array.glsl": Kl, "_prelude_raster_particle.glsl": ya }, Jo = {}; Ti("", Xl), Ti(Yl, Jr), Ti(xl, ro), Ti(Kl, ""), Ti(ya, ""); const Jl = Ti(Hc, xr), Qr = Zc; var vl = { background: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform vec4 u_color;uniform float u_opacity; #ifdef LIGHTING_3D_MODE in vec4 v_color; #endif void main() {vec4 out_color; #ifdef LIGHTING_3D_MODE out_color=v_color; #else out_color=u_color; #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif glFragColor=out_color*u_opacity; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_lighting.glsl" in vec2 a_pos;uniform mat4 u_matrix; #ifdef LIGHTING_3D_MODE uniform mediump vec4 u_color;out vec4 v_color;uniform float u_emissive_strength; #endif void main() {gl_Position=u_matrix*vec4(a_pos,0,1); #ifdef LIGHTING_3D_MODE v_color=apply_lighting_with_emission_ground(u_color,u_emissive_strength); #endif #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), backgroundPattern: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform vec2 u_pattern_tl;uniform vec2 u_pattern_br;uniform vec2 u_texsize;uniform float u_opacity;uniform float u_emissive_strength;uniform sampler2D u_image;in highp vec2 v_pos;void main() {highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(u_pattern_tl/u_texsize,u_pattern_br/u_texsize,imagecoord);vec4 out_color=textureLodCustom(u_image,pos,v_pos); #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif glFragColor=out_color*u_opacity; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;uniform vec2 u_pattern_size;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec2 u_pattern_units_to_pixels;in vec2 a_pos;out highp 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_pattern_units_to_pixels,a_pos); #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), circle: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" in vec3 v_data;in float v_visibility; #pragma mapbox: define highp vec4 color #pragma mapbox: define mediump float radius #pragma mapbox: define lowp float blur #pragma mapbox: define lowp float opacity #pragma mapbox: define highp vec4 stroke_color #pragma mapbox: define mediump float stroke_width #pragma mapbox: define lowp float stroke_opacity uniform float u_emissive_strength;void main() { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize mediump float radius #pragma mapbox: initialize lowp float blur #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize highp vec4 stroke_color #pragma mapbox: initialize mediump float stroke_width #pragma mapbox: initialize lowp float stroke_opacity vec2 extrude=v_data.xy;float blur_positive=blur < 0.0 ? 0.0 : 1.0;lowp float antialiasblur=v_data.z;float extrude_length=length(extrude)+antialiasblur*(1.0-blur_positive);float antialiased_blur=-max(abs(blur),antialiasblur);float opacity_t=smoothstep((1.0-blur_positive)*antialiased_blur,blur_positive*antialiased_blur,extrude_length-1.0)-smoothstep(0.0,antialiasblur,extrude_length-1.0);float color_t=stroke_width < 0.01 ? 0.0 : smoothstep( antialiased_blur,0.0,extrude_length-radius/(radius+stroke_width) );vec4 out_color=mix(color*opacity,stroke_color*stroke_opacity,color_t); #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #endif #ifdef FOG out_color=fog_apply_premultiplied(out_color,v_fog_pos); #endif glFragColor=out_color*(v_visibility*opacity_t); #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif }`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_terrain.vertex.glsl" #define NUM_VISIBILITY_RINGS 2 #define INV_SQRT2 0.70710678 #define ELEVATION_BIAS 0.0001 #define NUM_SAMPLES_PER_RING 16 uniform mat4 u_matrix;uniform mat2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;in vec2 a_pos; #ifdef PROJECTION_GLOBE_VIEW in vec3 a_pos_3;in 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; #endif out vec3 v_data;out float v_visibility; #pragma mapbox: define highp vec4 color #pragma mapbox: define mediump float radius #pragma mapbox: define lowp float blur #pragma mapbox: define lowp float opacity #pragma mapbox: define highp vec4 stroke_color #pragma mapbox: define mediump float stroke_width #pragma mapbox: define lowp float stroke_opacity vec2 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) { #if defined(TERRAIN) return elevation(pos)+ELEVATION_BIAS; #else return 0.0; #endif }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); #ifdef PITCH_WITH_MAP #ifdef PROJECTION_GLOBE_VIEW return u_matrix*( world_center+vec4(sample_offset.x*surface_vectors[0]+sample_offset.y*surface_vectors[1],0) ); #else return u_matrix*( world_center+vec4(sample_offset,0,0) ); #endif #else return projected_center+vec4(sample_offset,0,0); #endif }float get_sample_step() { #ifdef PITCH_WITH_MAP return 2.0*PI/float(NUM_SAMPLES_PER_RING); #else return PI/float(NUM_SAMPLES_PER_RING); #endif }void main(void) { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize mediump float radius #pragma mapbox: initialize lowp float blur #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize highp vec4 stroke_color #pragma mapbox: initialize mediump float stroke_width #pragma mapbox: initialize lowp float stroke_opacity vec2 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; #ifdef PROJECTION_GLOBE_VIEW vec3 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); #else surface_vectors=mat3(1.0);float height=circle_elevation(circle_center);world_center=vec4(circle_center,height,1); #endif vec4 projected_center=u_matrix*world_center;float view_scale=0.0; #ifdef PITCH_WITH_MAP #ifdef SCALE_WITH_MAP view_scale=1.0; #else view_scale=projected_center.w/u_camera_to_center_distance; #endif #else #ifdef SCALE_WITH_MAP view_scale=u_camera_to_center_distance; #else view_scale=projected_center.w; #endif #endif gl_Position=project_vertex(extrude,world_center,projected_center,radius,stroke_width,view_scale,surface_vectors);float visibility=0.0; #ifdef TERRAIN float step=get_sample_step();vec4 occlusion_world_center;vec4 occlusion_projected_center; #ifdef PITCH_WITH_MAP float 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; #else occlusion_world_center=world_center;occlusion_projected_center=projected_center; #endif for(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); #else visibility=1.0; #endif #ifdef PROJECTION_GLOBE_VIEW visibility=1.0; #endif v_visibility=visibility;lowp float antialiasblur=1.0/u_device_pixel_ratio/(radius+stroke_width);v_data=vec3(extrude.x,extrude.y,antialiasblur); #ifdef FOG v_fog_pos=fog_position(world_center.xyz); #endif }`), clippingMask: Ti("void main() {glFragColor=vec4(1.0);}", "in vec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}"), heatmap: Ti(`#include "_prelude_fog.fragment.glsl" uniform highp float u_intensity;in vec2 v_extrude; #pragma mapbox: define highp float weight #define GAUSS_COEF 0.3989422804014327 void main() { #pragma mapbox: initialize highp float weight float d=-0.5*3.0*3.0*dot(v_extrude,v_extrude);float val=weight*u_intensity*GAUSS_COEF*exp(d);glFragColor=vec4(val,1.0,1.0,1.0); #ifdef FOG if (u_is_globe==0) {glFragColor.r*=pow(1.0-fog_opacity(v_fog_pos),2.0);} #endif #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_terrain.vertex.glsl" #include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;uniform float u_extrude_scale;uniform float u_opacity;uniform float u_intensity;in vec2 a_pos; #ifdef PROJECTION_GLOBE_VIEW in vec3 a_pos_3;in 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; #endif out vec2 v_extrude; #pragma mapbox: define highp float weight #pragma mapbox: define mediump float radius const highp float ZERO=1.0/255.0/16.0; #define GAUSS_COEF 0.3989422804014327 void main(void) { #pragma mapbox: initialize highp float weight #pragma mapbox: initialize mediump float radius vec2 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; #ifdef PROJECTION_GLOBE_VIEW vec3 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); #else pos=vec3(tilePos+extrude,elevation(tilePos)); #endif gl_Position=u_matrix*vec4(pos,1); #ifdef FOG v_fog_pos=fog_position(pos); #endif }`), heatmapTexture: Ti(`uniform sampler2D u_image;uniform sampler2D u_color_ramp;uniform float u_opacity;in vec2 v_pos;void main() {float t=texture(u_image,v_pos).r;vec4 color=texture(u_color_ramp,vec2(t,0.5));glFragColor=color*u_opacity; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(0.0); #endif HANDLE_WIREFRAME_DEBUG;}`, "in vec2 a_pos;out vec2 v_pos;void main() {gl_Position=vec4(a_pos,0,1);v_pos=a_pos*0.5+0.5;}"), collisionBox: Ti("in float v_placed;in 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);glFragColor =mix(red,blue,step(0.5,v_placed))*0.5;glFragColor*=mix(1.0,0.1,step(0.5,v_notUsed));}", `#include "_prelude_terrain.vertex.glsl" in vec3 a_pos;in vec2 a_anchor_pos;in vec2 a_extrude;in vec2 a_placed;in vec2 a_shift;in vec2 a_elevation_from_sea;in float a_size_scale;in vec2 a_padding;in float a_auto_z_offset;uniform mat4 u_matrix;uniform vec2 u_extrude_scale;uniform float u_camera_to_center_distance;out float v_placed;out float v_notUsed;void main() {float feature_elevation=a_elevation_from_sea.x+a_auto_z_offset;float terrain_elevation=(a_elevation_from_sea.y==1.0 ? 0.0 : elevation(a_anchor_pos));vec4 projectedPoint=u_matrix*vec4(a_pos+elevationVector(a_anchor_pos)*(feature_elevation+terrain_elevation),1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp( 0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,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: Ti("in float v_radius;in vec2 v_extrude;in float v_perspective_ratio;in 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);glFragColor=color*alpha*opacity_t;}", `in vec2 a_pos_2f;in float a_radius;in vec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;out float v_radius;out vec2 v_extrude;out float v_perspective_ratio;out 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( mix(-1.0,1.0,float(vertexIdx >=2.0)),mix(-1.0,1.0,float(vertexIdx >=1.0 && vertexIdx <=2.0)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp( 0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=collision;gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}`), debug: Ti("uniform highp vec4 u_color;uniform sampler2D u_overlay;in vec2 v_uv;void main() {vec4 overlay_color=texture(u_overlay,v_uv);glFragColor=mix(u_color,overlay_color,overlay_color.a);}", `#include "_prelude_terrain.vertex.glsl" in vec2 a_pos; #ifdef PROJECTION_GLOBE_VIEW in vec3 a_pos_3; #endif out 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; #ifdef PROJECTION_GLOBE_VIEW gl_Position=u_matrix*vec4(a_pos_3+elevationVector(a_pos)*h,1); #else gl_Position=u_matrix*vec4(a_pos*u_overlay_scale,h,1); #endif }`), fill: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" #pragma mapbox: define highp vec4 color #pragma mapbox: define lowp float opacity uniform float u_emissive_strength; #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif #ifdef INDICATOR_CUTOUT in highp float v_z_offset; #endif void main() { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize lowp float opacity vec4 out_color=color; #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif out_color*=opacity; #ifdef INDICATOR_CUTOUT out_color=applyCutout(out_color,v_z_offset); #endif glFragColor=out_color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" in vec2 a_pos; #ifdef ELEVATED_ROADS in float a_road_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif #ifdef INDICATOR_CUTOUT out highp float v_z_offset; #endif uniform mat4 u_matrix; #pragma mapbox: define highp vec4 color #pragma mapbox: define lowp float opacity #pragma mapbox: define highp float z_offset void main() { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize highp float z_offset #ifdef ELEVATED_ROADS z_offset+=a_road_z_offset; #endif float hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden); #ifdef RENDER_SHADOWS vec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset); #ifdef NORMAL_OFFSET vec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #ifdef FOG v_fog_pos=fog_position(a_pos); #endif #ifdef INDICATOR_CUTOUT v_z_offset=z_offset; #endif }`), fillOutline: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" in highp vec2 v_pos;uniform float u_emissive_strength; #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif #pragma mapbox: define highp vec4 outline_color #pragma mapbox: define lowp float opacity void main() { #pragma mapbox: initialize highp vec4 outline_color #pragma mapbox: initialize lowp float opacity float dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);vec4 out_color=outline_color; #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif glFragColor=out_color*(alpha*opacity); #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" in vec2 a_pos; #ifdef ELEVATED_ROADS in float a_road_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif uniform mat4 u_matrix;uniform vec2 u_world;out highp vec2 v_pos; #pragma mapbox: define highp vec4 outline_color #pragma mapbox: define lowp float opacity #pragma mapbox: define highp float z_offset void main() { #pragma mapbox: initialize highp vec4 outline_color #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize highp float z_offset #ifdef ELEVATED_ROADS z_offset+=a_road_z_offset; #endif float hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden);v_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world; #ifdef RENDER_SHADOWS vec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset); #ifdef NORMAL_OFFSET vec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), fillOutlinePattern: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" uniform vec2 u_texsize;uniform sampler2D u_image;uniform float u_emissive_strength; #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif in highp vec2 v_pos;in highp vec2 v_pos_world; #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp vec4 pattern void main() { #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize mediump vec4 pattern vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);float dist=length(v_pos_world-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);vec4 out_color=textureLodCustom(u_image,pos,lod_pos); #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif glFragColor=out_color*(alpha*opacity); #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" 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;in vec2 a_pos; #ifdef ELEVATED_ROADS in float a_road_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif out highp vec2 v_pos;out highp vec2 v_pos_world; #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp vec4 pattern #pragma mapbox: define lowp float pixel_ratio #pragma mapbox: define highp float z_offset void main() { #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize lowp float pixel_ratio #pragma mapbox: initialize highp float z_offset vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw; #ifdef ELEVATED_ROADS z_offset+=a_road_z_offset; #endif float hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden);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; #ifdef RENDER_SHADOWS vec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset); #ifdef NORMAL_OFFSET vec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), fillPattern: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" uniform vec2 u_texsize;uniform sampler2D u_image;in highp vec2 v_pos;uniform float u_emissive_strength; #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp vec4 pattern void main() { #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize mediump vec4 pattern vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);vec4 out_color=textureLodCustom(u_image,pos,lod_pos); #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif glFragColor=out_color*opacity; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" uniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_tile_units_to_pixels;in vec2 a_pos; #ifdef ELEVATED_ROADS in float a_road_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif out highp vec2 v_pos; #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp vec4 pattern #pragma mapbox: define lowp float pixel_ratio #pragma mapbox: define highp float z_offset void main() { #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize lowp float pixel_ratio #pragma mapbox: initialize highp float z_offset vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio; #ifdef ELEVATED_ROADS z_offset+=a_road_z_offset; #endif float hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,a_pos); #ifdef RENDER_SHADOWS vec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset); #ifdef NORMAL_OFFSET vec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), fillExtrusion: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_shadow.fragment.glsl" #include "_prelude_lighting.glsl" in vec4 v_color;in vec4 v_flat; #ifdef RENDER_SHADOWS in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1; #endif uniform lowp float u_opacity; #ifdef FAUX_AO uniform lowp vec2 u_ao;in vec2 v_ao; #endif #if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE) in vec4 v_roof_color; #endif #if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE) in highp vec3 v_normal; #endif uniform vec3 u_flood_light_color;uniform highp float u_vertical_scale;uniform float u_flood_light_intensity;uniform vec3 u_ground_shadow_factor; #if defined(LIGHTING_3D_MODE) && defined(FLOOD_LIGHT) in float v_flood_radius;in float v_has_floodlight; #endif in float v_height; #pragma mapbox: define highp float emissive_strength void main() { #pragma mapbox: initialize highp float emissive_strength #if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE) vec3 normal=normalize(v_normal); #endif float z;vec4 color=v_color; #ifdef ZERO_ROOF_RADIUS z=float(normal.z > 0.00001); #ifdef LIGHTING_3D_MODE normal=mix(normal,vec3(0.0,0.0,1.0),z); #else color=mix(v_color,v_roof_color,z); #endif #endif float h=max(0.0,v_height);float ao_shade=1.0; #ifdef FAUX_AO float intensity=u_ao[0];float h_floors=h/(u_ao[1]*u_vertical_scale);float y_shade=1.0-0.9*intensity*min(v_ao.y,1.0);ao_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; #ifdef ZERO_ROOF_RADIUS concave*=(1.0-z); #endif 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);ao_shade*=mix(1.0,x_shade*x_shade*x_shade,concave); #ifdef LIGHTING_3D_MODE #ifdef FLOOD_LIGHT color.rgb*=mix(ao_shade,1.0,v_has_floodlight); #else color.rgb*=ao_shade; #endif #else color.rgb*=ao_shade; #endif #endif #ifdef LIGHTING_3D_MODE float flood_radiance=0.0; #ifdef FLOOD_LIGHT flood_radiance=(1.0-min(h/v_flood_radius,1.0))*u_flood_light_intensity*v_has_floodlight; #endif #ifdef RENDER_SHADOWS #ifdef FLOOD_LIGHT float ndotl_unclamped=dot(normal,u_shadow_direction);float ndotl=max(0.0,ndotl_unclamped);float occlusion=ndotl_unclamped < 0.0 ? 1.0 : shadow_occlusion(ndotl,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);vec3 litColor=apply_lighting(color.rgb,normal,(1.0-u_shadow_intensity*occlusion)*ndotl);vec3 floodLitColor=compute_flood_lighting(u_flood_light_color*u_opacity,1.0-u_shadow_intensity,occlusion,u_ground_shadow_factor);color.rgb=mix(litColor,floodLitColor,flood_radiance); #else float shadowed_lighting_factor; #ifdef RENDER_CUTOFF shadowed_lighting_factor=shadowed_light_factor_normal_opacity(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w,v_cutoff_opacity);if (v_cutoff_opacity==0.0) {discard;} #else shadowed_lighting_factor=shadowed_light_factor_normal(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w); #endif color.rgb=apply_lighting(color.rgb,normal,shadowed_lighting_factor); #endif #else color.rgb=apply_lighting(color.rgb,normal); #ifdef FLOOD_LIGHT color.rgb=mix(color.rgb,u_flood_light_color*u_opacity,flood_radiance); #endif #endif color.rgb=mix(color.rgb,v_flat.rgb,emissive_strength);color*=u_opacity; #endif #ifdef FOG color=fog_dither(fog_apply_premultiplied(color,v_fog_pos,h)); #endif #ifdef INDICATOR_CUTOUT color=applyCutout(color,h); #endif glFragColor=color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_terrain.vertex.glsl" #include "_prelude_shadow.vertex.glsl" #include "_prelude_lighting.glsl" 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;uniform float u_width_scale;in vec4 a_pos_normal_ed;in vec2 a_centroid_pos; #ifdef RENDER_WALL_MODE in vec3 a_join_normal_inside; #endif #ifdef PROJECTION_GLOBE_VIEW in vec3 a_pos_3;in 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; #endif #ifdef TERRAIN uniform int u_height_type;uniform int u_base_type; #endif uniform highp float u_vertical_scale;out vec4 v_color;out vec4 v_flat; #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1; #endif #if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE) out vec4 v_roof_color; #endif #if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE) out highp vec3 v_normal; #endif #ifdef FAUX_AO uniform lowp vec2 u_ao;out vec2 v_ao; #endif #if defined(LIGHTING_3D_MODE) && defined(FLOOD_LIGHT) out float v_flood_radius;out float v_has_floodlight; #endif out float v_height;vec3 linearTosRGB(vec3 color) {return pow(color,vec3(1./2.2));}vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));} #pragma mapbox: define highp float base #pragma mapbox: define highp float height #pragma mapbox: define highp vec4 color #pragma mapbox: define highp float flood_light_wall_radius #pragma mapbox: define highp float line_width #pragma mapbox: define highp float emissive_strength void main() { #pragma mapbox: initialize highp float base #pragma mapbox: initialize highp float height #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize highp float flood_light_wall_radius #pragma mapbox: initialize highp float line_width #pragma mapbox: initialize highp float emissive_strength base*=u_vertical_scale;height*=u_vertical_scale;vec4 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)); #if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE) v_normal=normal; #endif base=max(0.0,base);float attr_height=height;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); #if defined(HAS_CENTROID) || defined(TERRAIN) centroid_pos=a_centroid_pos; #endif float ele=0.0;float h=0.0;float c_ele=0.0;vec3 pos; #ifdef TERRAIN bool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;ele=elevation(pos_nx.xy);c_ele=is_flat_height || is_flat_base ? (centroid_pos.y==0.0 ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);h=t > 0.0 ? max(h_base,h_height) : h_base;pos=vec3(pos_nx.xy,h); #else h=t > 0.0 ? height : base;pos=vec3(pos_nx.xy,h); #endif #ifdef PROJECTION_GLOBE_VIEW float 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); #endif float cutoff=1.0;vec3 scaled_pos=pos; #ifdef RENDER_CUTOFF vec3 centroid_random=vec3(centroid_pos.xy,centroid_pos.x+centroid_pos.y+1.0);vec3 ground_pos=centroid_pos.x==0.0 ? pos.xyz : (centroid_random/8.0);vec4 ground=u_matrix*vec4(ground_pos.xy,ele,1.0);cutoff=cutoff_opacity(u_cutoff_params,ground.z);if (centroid_pos.y !=0.0 && centroid_pos.x !=0.0) {vec3 g=floor(ground_pos);vec3 mod_=centroid_random-g*8.0;float seed=min(1.0,0.1*(min(3.5,max(mod_.x+mod_.y,0.2*attr_height))*0.35+mod_.z));if (cutoff < 0.8-seed) {cutoff=0.0;}}float cutoff_scale=cutoff;v_cutoff_opacity=cutoff;scaled_pos.z=mix(c_ele,h,cutoff_scale); #endif float hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (cutoff==0.0 && centroid_pos.x !=0.0) || (color.a==0.0)); #ifdef RENDER_WALL_MODE vec2 wall_offset=u_width_scale*line_width*(a_join_normal_inside.xy/EXTENT);scaled_pos.xy+=(1.0-a_join_normal_inside.z)*wall_offset*0.5;scaled_pos.xy-=a_join_normal_inside.z*wall_offset*0.5; #endif gl_Position=mix(u_matrix*vec4(scaled_pos,1),AWAY,hidden);h=h-ele;v_height=h; #ifdef RENDER_SHADOWS vec3 shd_pos0=pos;vec3 shd_pos1=pos; #ifdef NORMAL_OFFSET vec3 offset=shadow_normal_offset(normal);shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1); #endif float NdotL=0.0;float colorvalue=0.0; #ifndef LIGHTING_3D_MODE colorvalue=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);if (normal.y !=0.0) {float r=0.84;r=mix(0.7,0.98,1.0-u_lightintensity);NdotL*=( (1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));} #endif #ifdef FAUX_AO float 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; #ifdef TERRAIN top_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); #endif v_ao=vec2(mix(concave,-concave,start),y_ground);NdotL*=(1.0+0.05*(1.0-top_up_ny.y)*u_ao[0]); #ifdef PROJECTION_GLOBE_VIEW top_height+=u_height_lift; #endif gl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w; #endif #ifdef LIGHTING_3D_MODE #ifdef FLOOD_LIGHT float is_wall=1.0-float(t > 0.0 && top_up_ny.y > 0.0);v_has_floodlight=float(flood_light_wall_radius > 0.0 && is_wall > 0.0);v_flood_radius=flood_light_wall_radius*u_vertical_scale; #endif v_color=vec4(color.rgb,1.0);float ndotl=calculate_NdotL(normal);v_flat.rgb=sRGBToLinear(color.rgb);v_flat.rgb=v_flat.rgb*(ndotl+(1.0-min(ndotl*57.29,1.0))*emissive_strength);v_flat=vec4(linearTosRGB(v_flat.rgb),1.0); #else v_color=vec4(0.0,0.0,0.0,1.0);v_color.rgb+=clamp(color.rgb*NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_color*=u_opacity; #endif #if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE) float 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=vec4(0.0,0.0,0.0,1.0);v_roof_color.rgb+=clamp(color.rgb*roofNdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_roof_color*=u_opacity; #endif #ifdef FOG v_fog_pos=fog_position(pos); #endif }`), fillExtrusionDepth: Ti(`in highp float v_depth;void main() { #ifndef DEPTH_TEXTURE glFragColor=pack_depth(v_depth); #endif }`, `#include "_prelude_terrain.vertex.glsl" uniform mat4 u_matrix;uniform float u_edge_radius;uniform float u_width_scale;uniform float u_vertical_scale; #ifdef TERRAIN uniform int u_height_type;uniform int u_base_type; #endif in vec4 a_pos_normal_ed;in vec2 a_centroid_pos; #ifdef RENDER_WALL_MODE in vec3 a_join_normal_inside; #endif #pragma mapbox: define highp float base #pragma mapbox: define highp float height #pragma mapbox: define highp float line_width #pragma mapbox: define highp vec4 color out highp float v_depth;void main() { #pragma mapbox: initialize highp float base #pragma mapbox: initialize highp float height #pragma mapbox: initialize highp float line_width #pragma mapbox: initialize highp vec4 color base*=u_vertical_scale;height*=u_vertical_scale;vec3 pos_nx=floor(a_pos_normal_ed.xyz*0.5);mediump vec3 top_up_ny=a_pos_normal_ed.xyz-2.0*pos_nx;base=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); #if defined(HAS_CENTROID) || defined(TERRAIN) centroid_pos=a_centroid_pos; #endif vec3 pos; #ifdef TERRAIN bool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;float ele=elevation(pos_nx.xy);float c_ele=is_flat_height || is_flat_base ? (centroid_pos.y==0.0 ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);float h=t > 0.0 ? max(h_base,h_height) : h_base;pos=vec3(pos_nx.xy,h); #else pos=vec3(pos_nx.xy,t > 0.0 ? height : base); #endif #ifdef RENDER_WALL_MODE vec2 wall_offset=u_width_scale*line_width*(a_join_normal_inside.xy/EXTENT);pos.xy+=(1.0-a_join_normal_inside.z)*wall_offset*0.5;pos.xy-=a_join_normal_inside.z*wall_offset*0.5; #endif float hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (color.a==0.0));gl_Position=mix(u_matrix*vec4(pos,1),AWAY,hidden);v_depth=gl_Position.z/gl_Position.w;}`), fillExtrusionPattern: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform vec2 u_texsize;uniform sampler2D u_image; #ifdef FAUX_AO uniform lowp vec2 u_ao;in vec3 v_ao; #endif #ifdef LIGHTING_3D_MODE in vec3 v_normal; #endif in highp vec2 v_pos;in vec4 v_lighting;uniform lowp float u_opacity; #pragma mapbox: define highp float base #pragma mapbox: define highp float height #pragma mapbox: define mediump vec4 pattern #pragma mapbox: define highp float pixel_ratio void main() { #pragma mapbox: initialize highp float base #pragma mapbox: initialize highp float height #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize highp float pixel_ratio vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);vec4 out_color=textureLodCustom(u_image,pos,lod_pos); #ifdef LIGHTING_3D_MODE out_color=apply_lighting(out_color,normalize(v_normal))*u_opacity; #else out_color=out_color*v_lighting; #endif #ifdef FAUX_AO float 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; #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif #ifdef INDICATOR_CUTOUT out_color=applyCutout(out_color,height); #endif glFragColor=out_color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_terrain.vertex.glsl" #include "_prelude_lighting.glsl" 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 float u_width_scale;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;in vec4 a_pos_normal_ed;in vec2 a_centroid_pos; #ifdef RENDER_WALL_MODE in vec3 a_join_normal_inside; #endif #ifdef PROJECTION_GLOBE_VIEW in vec3 a_pos_3;in 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; #endif #ifdef TERRAIN uniform int u_height_type;uniform int u_base_type; #endif out highp vec2 v_pos;out vec4 v_lighting; #ifdef FAUX_AO uniform lowp vec2 u_ao;out vec3 v_ao; #endif #ifdef LIGHTING_3D_MODE out vec3 v_normal; #endif #pragma mapbox: define highp float base #pragma mapbox: define highp float height #pragma mapbox: define highp vec4 color #pragma mapbox: define mediump vec4 pattern #pragma mapbox: define highp float pixel_ratio #pragma mapbox: define highp float line_width void main() { #pragma mapbox: initialize highp float base #pragma mapbox: initialize highp float height #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize highp float pixel_ratio #pragma mapbox: initialize highp float line_width vec2 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); #if defined(HAS_CENTROID) || defined(TERRAIN) centroid_pos=a_centroid_pos; #endif float ele=0.0;float h=z;vec3 p;float c_ele; #ifdef TERRAIN bool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;ele=elevation(pos_nx.xy);c_ele=is_flat_height || is_flat_base ? (centroid_pos.y==0.0 ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);h=t > 0.0 ? max(h_base,h_height) : h_base;p=vec3(pos_nx.xy,h); #else p=vec3(pos_nx.xy,z); #endif #ifdef PROJECTION_GLOBE_VIEW float 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); #endif #ifdef RENDER_WALL_MODE vec2 wall_offset=u_width_scale*line_width*(a_join_normal_inside.xy/EXTENT);p.xy+=(1.0-a_join_normal_inside.z)*wall_offset*0.5;p.xy-=a_join_normal_inside.z*wall_offset*0.5; #endif float hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (color.a==0.0));gl_Position=mix(u_matrix*vec4(p,1),AWAY,hidden);vec2 pos=normal.z==1.0 ? pos_nx.xy : 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; #ifdef LIGHTING_3D_MODE NdotL=calculate_NdotL(normal); #else NdotL=clamp(dot(normal,u_lightpos),0.0,1.0);NdotL=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),NdotL); #endif if (normal.y !=0.0) {float r=0.84; #ifndef LIGHTING_3D_MODE r=mix(0.7,0.98,1.0-u_lightintensity); #endif NdotL*=( (1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));} #ifdef FAUX_AO float 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; #ifdef TERRAIN top_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); #endif v_ao=vec3(mix(concave,-concave,start),y_ground,h-ele);NdotL*=(1.0+0.05*(1.0-top_up_ny.y)*u_ao[0]); #ifdef PROJECTION_GLOBE_VIEW top_height+=u_height_lift; #endif gl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w; #endif #ifdef LIGHTING_3D_MODE v_normal=normal; #else v_lighting.rgb+=clamp(NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity; #endif #ifdef FOG v_fog_pos=fog_position(p); #endif }`), groundShadow: Ti(`#include "_prelude_shadow.fragment.glsl" precision highp float;uniform vec3 u_ground_shadow_factor;in vec4 v_pos_light_view_0;in vec4 v_pos_light_view_1; #ifdef FOG in float v_fog_opacity; #endif void main() {float light=shadowed_light_factor_plane_bias(v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);vec3 shadow=mix(u_ground_shadow_factor,vec3(1.0),light); #ifdef RENDER_CUTOFF shadow=mix(vec3(1.0),shadow,cutoff_opacity(u_cutoff_params,1.0/gl_FragCoord.w)); #endif #ifdef FOG shadow=mix(shadow,vec3(1.0),v_fog_opacity); #endif #ifdef INDICATOR_CUTOUT shadow=mix(shadow,vec3(1.0),1.0-applyCutout(vec4(1.0),0.0).r); #endif glFragColor=vec4(shadow,1.0);}`, `#include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;in vec2 a_pos;out vec4 v_pos_light_view_0;out vec4 v_pos_light_view_1; #ifdef FOG out float v_fog_opacity; #endif void main() {gl_Position=u_matrix*vec4(a_pos,0.0,1.0);v_pos_light_view_0=u_light_matrix_0*vec4(a_pos,0.0,1.0);v_pos_light_view_1=u_light_matrix_1*vec4(a_pos,0.0,1.0); #ifdef FOG v_fog_pos=fog_position(a_pos);v_fog_opacity=fog(v_fog_pos); #endif }`), fillExtrusionGroundEffect: Ti(`uniform highp float u_ao_pass;uniform highp float u_opacity;uniform highp float u_flood_light_intensity;uniform highp vec3 u_flood_light_color;uniform highp float u_attenuation;uniform sampler2D u_fb;uniform float u_fb_size; #ifdef SDF_SUBPASS in highp vec2 v_pos;in highp vec4 v_line_segment;in highp float v_flood_light_radius_tile;in highp vec2 v_ao;float line_df(highp vec2 a,highp vec2 b,highp vec2 p) {highp vec2 ba=b-a;highp vec2 pa=p-a;highp float r=clamp(dot(pa,ba)/dot(ba,ba),0.0,1.0);return length(pa-r*ba);} #ifdef FOG in highp float v_fog; #endif #endif void main() { #ifdef CLEAR_SUBPASS vec4 color=vec4(1.0); #ifdef CLEAR_FROM_TEXTURE color=texture(u_fb,gl_FragCoord.xy/vec2(u_fb_size)); #endif glFragColor=color; #else #ifdef SDF_SUBPASS highp float d=line_df(v_line_segment.xy,v_line_segment.zw,v_pos);highp float effect_radius=mix(v_flood_light_radius_tile,v_ao.y,u_ao_pass);d/=effect_radius;d=min(d,1.0);d=1.0-pow(1.0-d,u_attenuation);highp float effect_intensity=mix(u_flood_light_intensity,v_ao.x,u_ao_pass);highp float fog=1.0; #ifdef FOG fog=v_fog; #endif #ifdef RENDER_CUTOFF fog*=v_cutoff_opacity; #endif glFragColor=vec4(vec3(0.0),mix(1.0,d,effect_intensity*u_opacity*fog)); #else vec4 color=mix(vec4(u_flood_light_color,1.0),vec4(vec3(0.0),1.0),u_ao_pass); #ifdef OVERDRAW_INSPECTOR color=vec4(1.0); #endif glFragColor=color; #endif HANDLE_WIREFRAME_DEBUG; #endif }`, `#include "_prelude_fog.vertex.glsl" in highp vec4 a_pos_end;in highp float a_angular_offset_factor;in highp float a_hidden_by_landmark; #ifdef SDF_SUBPASS out highp vec2 v_pos;out highp vec4 v_line_segment;out highp float v_flood_light_radius_tile;out highp vec2 v_ao; #ifdef FOG out highp float v_fog; #endif #endif uniform highp float u_flood_light_intensity;uniform highp mat4 u_matrix;uniform highp float u_ao_pass;uniform highp float u_meter_to_tile;uniform highp float u_edge_radius;uniform highp float u_dynamic_offset;uniform highp vec2 u_ao; #pragma mapbox: define highp float flood_light_ground_radius const float TANGENT_CUTOFF=4.0;const float NORM=32767.0;void main() { #pragma mapbox: initialize highp float flood_light_ground_radius vec2 p=a_pos_end.xy;vec2 q=floor(a_pos_end.zw*0.5);vec2 start_bottom=a_pos_end.zw-q*2.0;float fl_ground_radius=flood_light_ground_radius;fl_ground_radius=abs(flood_light_ground_radius);float direction=flood_light_ground_radius < 0.0 ?-1.0 : 1.0;float flood_radius_tile=fl_ground_radius*u_meter_to_tile;vec2 v=normalize(q-p);float ao_radius=u_ao.y/3.5;float effect_radius=mix(flood_radius_tile,ao_radius,u_ao_pass)+u_edge_radius;float angular_offset_factor=a_angular_offset_factor/NORM*TANGENT_CUTOFF;float angular_offset=direction*angular_offset_factor*effect_radius;float top=1.0-start_bottom.y;float side=(0.5-start_bottom.x)*2.0;vec2 extrusion_parallel=v*side*mix(u_dynamic_offset,angular_offset,top);vec2 perp=vec2(v.y,-v.x);vec2 extrusion_perp=direction*perp*effect_radius*top;vec3 pos=vec3(mix(q,p,start_bottom.x),0.0);pos.xy+=extrusion_parallel+extrusion_perp; #ifdef SDF_SUBPASS v_pos=pos.xy;v_line_segment=vec4(p,q)+perp.xyxy*u_edge_radius;v_flood_light_radius_tile=flood_radius_tile;v_ao=vec2(u_ao.x,ao_radius); #ifdef FOG v_fog_pos=fog_position(pos);v_fog=1.0-fog(v_fog_pos); #endif #endif float hidden_by_landmark=0.0; #ifdef HAS_CENTROID hidden_by_landmark=a_hidden_by_landmark; #endif float isFloodlit=float(fl_ground_radius > 0.0 && u_flood_light_intensity > 0.0);float hidden=mix(1.0-isFloodlit,isFloodlit,u_ao_pass);hidden+=hidden_by_landmark;gl_Position=mix(u_matrix*vec4(pos,1.0),AWAY,float(hidden > 0.0)); #ifdef RENDER_CUTOFF v_cutoff_opacity=cutoff_opacity(u_cutoff_params,gl_Position.z); #endif }`), hillshadePrepare: Ti(`precision highp float;uniform sampler2D u_image;in vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;float getElevation(vec2 coord) {return texture(u_image,coord).r/4.0;}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( (c+e+e+h)-(a+d+d+f),(f+g+g+h)-(a+b+b+c) )/pow(2.0,exaggeration+(19.2562-u_zoom));glFragColor=clamp(vec4( deriv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);}`, "uniform mat4 u_matrix;uniform vec2 u_dimension;in vec2 a_pos;in vec2 a_texture_pos;out 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: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform sampler2D u_image;in vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;uniform float u_emissive_strength;void main() {vec4 pixel=texture(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);glFragColor=accent_color*(1.0-shade_color.a)+shade_color; #ifdef LIGHTING_3D_MODE glFragColor=apply_lighting_with_emission_ground(glFragColor,u_emissive_strength); #endif #ifdef FOG glFragColor=fog_dither(fog_apply_premultiplied(glFragColor,v_fog_pos)); #endif #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;in vec2 a_pos;in vec2 a_texture_pos;out vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=a_texture_pos/8192.0; #ifdef FOG v_fog_pos=fog_position(a_pos); #endif }`), line: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" uniform lowp float u_device_pixel_ratio;uniform highp float u_width_scale;uniform highp float u_floor_width_scale;uniform float u_alpha_discard_threshold;uniform highp vec2 u_trim_offset;uniform highp vec2 u_trim_fade_range;uniform lowp vec4 u_trim_color;in vec2 v_width2;in vec2 v_normal;in float v_gamma_scale;in highp vec4 v_uv; #ifdef ELEVATED_ROADS in highp float v_road_z_offset; #endif #ifdef RENDER_LINE_DASH uniform sampler2D u_dash_image;in vec2 v_tex; #endif #ifdef RENDER_LINE_GRADIENT uniform sampler2D u_gradient_image; #endif #ifdef INDICATOR_CUTOUT in highp float v_z_offset; #endif #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif float luminance(vec3 c) {return (c.r+c.r+c.b+c.g+c.g+c.g)*0.1667;}uniform float u_emissive_strength; #pragma mapbox: define highp vec4 color #pragma mapbox: define lowp float floorwidth #pragma mapbox: define lowp vec4 dash #pragma mapbox: define lowp float blur #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp float border_width #pragma mapbox: define lowp vec4 border_color float linearstep(float edge0,float edge1,float x) {return clamp((x-edge0)/(edge1-edge0),0.0,1.0);}void main() { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize lowp float floorwidth #pragma mapbox: initialize lowp vec4 dash #pragma mapbox: initialize lowp float blur #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize lowp float border_width #pragma mapbox: initialize lowp vec4 border_color float dist=length(v_normal)*v_width2.s;float blur2=(u_width_scale*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); #ifdef RENDER_LINE_DASH float sdfdist=texture(u_dash_image,v_tex).r;float sdfgamma=1.0/(2.0*u_device_pixel_ratio)/dash.z;float scaled_floorwidth=(floorwidth*u_floor_width_scale);alpha*=linearstep(0.5-sdfgamma/scaled_floorwidth,0.5+sdfgamma/scaled_floorwidth,sdfdist); #endif highp vec4 out_color; #ifdef RENDER_LINE_GRADIENT out_color=texture(u_gradient_image,v_uv.xy); #else out_color=color; #endif float trim_alpha=1.0; #ifdef RENDER_LINE_TRIM_OFFSET highp 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) {highp float start_transition=max(0.0,min(1.0,(line_progress-trim_start)/max(u_trim_fade_range[0],1.0e-9)));highp float end_transition=max(0.0,min(1.0,(trim_end-line_progress)/max(u_trim_fade_range[1],1.0e-9)));highp float transition_factor=min(start_transition,end_transition);out_color=mix(out_color,u_trim_color,transition_factor);trim_alpha=1.0-transition_factor;} #endif if (u_alpha_discard_threshold !=0.0) {if (alpha < u_alpha_discard_threshold) {discard;}} #ifdef RENDER_LINE_BORDER float edgeBlur=((border_width*u_width_scale)+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);if (border_color.a==0.0) {float 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);}} else {out_color=mix(border_color*trim_alpha,out_color,smoothAlpha);}} #endif #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth); #ifdef ELEVATED_ROADS out_color.rgb*=mix(v_road_z_offset > 0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light); #else out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #endif #ifdef FOG out_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos)); #endif out_color*=(alpha*opacity); #ifdef INDICATOR_CUTOUT out_color=applyCutout(out_color,v_z_offset); #endif glFragColor=out_color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" #include "_prelude_terrain.vertex.glsl" #define EXTRUDE_SCALE 0.015873016 in vec2 a_pos_normal;in vec4 a_data; #if defined(ELEVATED) || defined(ELEVATED_ROADS) || defined(VARIABLE_LINE_WIDTH) in vec2 a_z_offset_width; #endif #if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET) in highp vec4 a_packed; #endif #ifdef RENDER_LINE_DASH in float a_linesofar; #endif uniform mat4 u_matrix;uniform mat2 u_pixels_to_tile_units;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;uniform float u_width_scale;uniform highp float u_floor_width_scale; #ifdef ELEVATED uniform lowp float u_zbias_factor;uniform lowp float u_tile_to_meter;float sample_elevation(vec2 apos) { #ifdef ELEVATION_REFERENCE_SEA return 0.0; #else return elevation(apos); #endif } #endif out vec2 v_normal;out vec2 v_width2;out float v_gamma_scale;out highp vec4 v_uv; #ifdef ELEVATED_ROADS out highp float v_road_z_offset; #endif #ifdef RENDER_LINE_DASH uniform vec2 u_texsize;uniform float u_tile_units_to_pixels;out vec2 v_tex; #endif #ifdef RENDER_LINE_GRADIENT uniform float u_image_height; #endif #ifdef INDICATOR_CUTOUT out highp float v_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif #pragma mapbox: define highp vec4 color #pragma mapbox: define lowp float floorwidth #pragma mapbox: define lowp vec4 dash #pragma mapbox: define lowp float blur #pragma mapbox: define lowp float opacity #pragma mapbox: define mediump float gapwidth #pragma mapbox: define lowp float offset #pragma mapbox: define mediump float width #pragma mapbox: define lowp float border_width #pragma mapbox: define lowp vec4 border_color void main() { #pragma mapbox: initialize highp vec4 color #pragma mapbox: initialize lowp float floorwidth #pragma mapbox: initialize lowp vec4 dash #pragma mapbox: initialize lowp float blur #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize mediump float gapwidth #pragma mapbox: initialize lowp float offset #pragma mapbox: initialize mediump float width #pragma mapbox: initialize lowp float border_width #pragma mapbox: initialize lowp vec4 border_color float a_z_offset; #if defined(ELEVATED) || defined(ELEVATED_ROADS) a_z_offset=a_z_offset_width.x; #endif float 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; #ifdef VARIABLE_LINE_WIDTH halfwidth=(u_width_scale*a_z_offset_width.y)/2.0; #else halfwidth=(u_width_scale*width)/2.0; #endif offset=-1.0*offset*u_width_scale;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);float hidden=float(opacity==0.0);vec2 extrude=dist*u_pixels_to_tile_units;vec4 projected_extrude=u_matrix*vec4(extrude,0.0,0.0);vec2 projected_extrude_xy=projected_extrude.xy; #ifdef ELEVATED_ROADS v_road_z_offset=a_z_offset;gl_Position=u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,a_z_offset+0.01*step(0.01,a_z_offset),1.0)+projected_extrude; #else #ifdef ELEVATED vec2 offsetTile=offset2*u_pixels_to_tile_units;vec2 offset_pos=pos+offsetTile;float ele=0.0; #ifdef CROSS_SLOPE_VERTICAL float top=a_pos_normal.y-2.0*floor(a_pos_normal.y*0.5);float line_height=2.0*u_tile_to_meter*outset*top*u_pixels_to_tile_units[1][1]+a_z_offset;ele=sample_elevation(offset_pos)+line_height;projected_extrude=vec4(0); #else #ifdef CROSS_SLOPE_HORIZONTAL float ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,max(ele1,ele2));ele=ele_max+a_z_offset; #else float ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,0.5*(ele1+ele2));ele=ele_max-ele0+ele1+a_z_offset; #endif #endif gl_Position=u_matrix*vec4(offset_pos,ele,1.0)+projected_extrude;float z=clamp(gl_Position.z/gl_Position.w,0.5,1.0);float zbias=max(0.00005,(pow(z,0.8)-z)*u_zbias_factor*u_exaggeration);gl_Position.z-=(gl_Position.w*zbias);gl_Position=mix(gl_Position,AWAY,hidden); #else gl_Position=mix(u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,0.0,1.0)+projected_extrude,AWAY,hidden); #endif #endif #ifdef ELEVATED_ROADS #ifdef RENDER_SHADOWS vec3 shd_pos=vec3(pos+(offset2+dist)*u_pixels_to_tile_units,a_z_offset);vec3 shd_pos0=shd_pos;vec3 shd_pos1=shd_pos; #ifdef NORMAL_OFFSET vec3 shd_pos_offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=shd_pos_offset*shadow_normal_offset_multiplier0();shd_pos1+=shd_pos_offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #endif #ifndef RENDER_TO_TEXTURE float 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=mix(extrude_length_without_perspective/extrude_length_with_perspective,1.0,step(0.01,blur)); #else v_gamma_scale=1.0; #endif #if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET) float 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]; #ifdef RENDER_LINE_GRADIENT highp 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); #else v_uv=vec4(a_uv_x,0.0,a_clip_start,a_clip_end); #endif #endif #ifdef RENDER_LINE_DASH float 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*u_floor_width_scale),(-normal.y*height+dash.x+0.5)/u_texsize.y); #endif v_width2=vec2(outset,inset); #ifdef FOG v_fog_pos=fog_position(pos); #endif #ifdef INDICATOR_CUTOUT v_z_offset=a_z_offset; #endif }`), linePattern: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_shadow.fragment.glsl" uniform highp float u_device_pixel_ratio;uniform highp float u_width_scale;uniform highp float u_alpha_discard_threshold;uniform highp vec2 u_texsize;uniform highp float u_tile_units_to_pixels;uniform highp vec2 u_trim_offset;uniform highp vec2 u_trim_fade_range;uniform lowp vec4 u_trim_color;uniform sampler2D u_image;in vec2 v_normal;in vec2 v_width2;in highp float v_linesofar;in float v_gamma_scale;in float v_width; #ifdef RENDER_LINE_TRIM_OFFSET in highp vec4 v_uv; #endif #ifdef ELEVATED_ROADS in highp float v_road_z_offset; #endif #ifdef LINE_JOIN_NONE in vec2 v_pattern_data; #endif #ifdef INDICATOR_CUTOUT in highp float v_z_offset; #endif #ifdef RENDER_SHADOWS uniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth; #endif uniform float u_emissive_strength; #pragma mapbox: define mediump vec4 pattern #pragma mapbox: define mediump float pixel_ratio #pragma mapbox: define mediump float blur #pragma mapbox: define mediump float opacity void main() { #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize mediump float pixel_ratio #pragma mapbox: initialize mediump float blur #pragma mapbox: initialize mediump float opacity vec2 pattern_tl=pattern.xy;vec2 pattern_br=pattern.zw;vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;highp float pattern_size=display_size.x/u_tile_units_to_pixels;float aspect=display_size.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(u_width_scale*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);highp float pattern_x=v_linesofar/pattern_size*aspect;highp float x=mod(pattern_x,1.0);highp float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;highp vec2 pos=mix(pattern_tl*texel_size-texel_size,pattern_br*texel_size+texel_size,vec2(x,y));highp vec2 lod_pos=mix(pattern_tl*texel_size-texel_size,pattern_br*texel_size+texel_size,vec2(pattern_x,y));vec4 color=textureLodCustom(u_image,pos,lod_pos); #ifdef RENDER_LINE_TRIM_OFFSET highp 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) {highp float start_transition=max(0.0,min(1.0,(line_progress-trim_start)/max(u_trim_fade_range[0],1.0e-9)));highp float end_transition=max(0.0,min(1.0,(trim_end-line_progress)/max(u_trim_fade_range[1],1.0e-9)));highp float transition_factor=min(start_transition,end_transition);color=mix(color,color.a*u_trim_color,transition_factor);} #endif #ifdef LINE_JOIN_NONE highp float pattern_len=pattern_size/aspect;highp float segment_phase=pattern_len-mod(v_linesofar-v_pattern_data.x+pattern_len,pattern_len);highp float visible_start=segment_phase-step(pattern_len*0.5,segment_phase)*pattern_len;highp float visible_end=floor((v_pattern_data.y-segment_phase)/pattern_len)*pattern_len+segment_phase;visible_end+=step(pattern_len*0.5,v_pattern_data.y-visible_end)*pattern_len;if (v_pattern_data.x < visible_start || v_pattern_data.x >=visible_end) {color=vec4(0.0);} #endif #ifdef LIGHTING_3D_MODE color=apply_lighting_with_emission_ground(color,u_emissive_strength); #ifdef RENDER_SHADOWS float light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth); #ifdef ELEVATED_ROADS color.rgb*=mix(v_road_z_offset > 0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light); #else color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light); #endif #endif #endif #ifdef FOG color=fog_dither(fog_apply_premultiplied(color,v_fog_pos)); #endif color*=(alpha*opacity);if (u_alpha_discard_threshold !=0.0) {if (color.a < u_alpha_discard_threshold) {discard;}} #ifdef INDICATOR_CUTOUT color=applyCutout(color,v_z_offset); #endif glFragColor=color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" #include "_prelude_terrain.vertex.glsl" #define scale 0.015873016 in vec2 a_pos_normal;in vec4 a_data; #if defined(ELEVATED) || defined(ELEVATED_ROADS) in vec2 a_z_offset_width; #endif #ifdef RENDER_LINE_TRIM_OFFSET in highp vec4 a_packed; #endif in highp float a_linesofar; #ifdef LINE_JOIN_NONE in highp vec3 a_pattern_data;out vec2 v_pattern_data; #endif #ifdef INDICATOR_CUTOUT out highp float v_z_offset; #endif uniform mat4 u_matrix;uniform float u_tile_units_to_pixels;uniform vec2 u_units_to_pixels;uniform mat2 u_pixels_to_tile_units;uniform float u_device_pixel_ratio;uniform float u_width_scale;uniform float u_floor_width_scale; #ifdef ELEVATED uniform lowp float u_zbias_factor;uniform lowp float u_tile_to_meter;float sample_elevation(vec2 apos) { #ifdef ELEVATION_REFERENCE_SEA return 0.0; #else return elevation(apos); #endif } #endif out vec2 v_normal;out vec2 v_width2;out highp float v_linesofar;out float v_gamma_scale;out float v_width; #ifdef RENDER_LINE_TRIM_OFFSET out highp vec4 v_uv; #endif #ifdef ELEVATED_ROADS out highp float v_road_z_offset; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth; #endif #pragma mapbox: define mediump float blur #pragma mapbox: define mediump float opacity #pragma mapbox: define mediump float offset #pragma mapbox: define mediump float gapwidth #pragma mapbox: define mediump float width #pragma mapbox: define mediump float floorwidth #pragma mapbox: define mediump vec4 pattern #pragma mapbox: define mediump float pixel_ratio void main() { #pragma mapbox: initialize mediump float blur #pragma mapbox: initialize mediump float opacity #pragma mapbox: initialize mediump float offset #pragma mapbox: initialize mediump float gapwidth #pragma mapbox: initialize mediump float width #pragma mapbox: initialize mediump float floorwidth #pragma mapbox: initialize mediump vec4 pattern #pragma mapbox: initialize mediump float pixel_ratio float a_z_offset; #if defined(ELEVATED) || defined(ELEVATED_ROADS) a_z_offset=a_z_offset_width.x; #endif float 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);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=(u_width_scale*width)/2.0;offset=-1.0*offset*u_width_scale;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);vec2 dist=outset*a_extrude*scale;float u=0.5*a_direction;float t=1.0-abs(u);vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);float hidden=float(opacity==0.0);vec2 extrude=dist*u_pixels_to_tile_units;vec4 projected_extrude=u_matrix*vec4(extrude,0.0,0.0);vec2 projected_extrude_xy=projected_extrude.xy; #ifdef ELEVATED_ROADS v_road_z_offset=a_z_offset;gl_Position=u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,a_z_offset+0.01*step(0.01,a_z_offset),1.0)+projected_extrude; #else #ifdef ELEVATED vec2 offsetTile=offset2*u_pixels_to_tile_units;vec2 offset_pos=pos+offsetTile;float ele=0.0; #ifdef CROSS_SLOPE_VERTICAL float top=a_pos_normal.y-2.0*floor(a_pos_normal.y*0.5);float line_height=2.0*u_tile_to_meter*outset*top*u_pixels_to_tile_units[1][1]+a_z_offset;ele=sample_elevation(offset_pos)+line_height;projected_extrude=vec4(0); #else #ifdef CROSS_SLOPE_HORIZONTAL float ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,max(ele1,ele2));ele=ele_max+a_z_offset; #else float ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,0.5*(ele1+ele2));ele=ele_max-ele0+ele1+a_z_offset; #endif #endif gl_Position=u_matrix*vec4(offset_pos,ele,1.0)+projected_extrude;float z=clamp(gl_Position.z/gl_Position.w,0.5,1.0);float zbias=max(0.00005,(pow(z,0.8)-z)*u_zbias_factor*u_exaggeration);gl_Position.z-=(gl_Position.w*zbias);gl_Position=mix(gl_Position,AWAY,hidden); #else gl_Position=mix(u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,0.0,1.0)+projected_extrude,AWAY,hidden); #endif #endif #ifdef ELEVATED_ROADS #ifdef RENDER_SHADOWS vec3 shd_pos=vec3(pos+(offset2+dist)*u_pixels_to_tile_units,a_z_offset);vec3 shd_pos0=shd_pos;vec3 shd_pos1=shd_pos; #ifdef NORMAL_OFFSET vec3 shd_pos_offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=shd_pos_offset*shadow_normal_offset_multiplier0();shd_pos1+=shd_pos_offset*shadow_normal_offset_multiplier1(); #endif v_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w; #endif #endif #ifndef RENDER_TO_TEXTURE float 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=mix(extrude_length_without_perspective/extrude_length_with_perspective,1.0,step(0.01,blur)); #else v_gamma_scale=1.0; #endif #ifdef RENDER_LINE_TRIM_OFFSET float a_uv_x=a_packed[0];highp float a_clip_start=a_packed[2];highp float a_clip_end=a_packed[3];v_uv=vec4(a_uv_x,0.0,a_clip_start,a_clip_end); #endif v_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=(floorwidth*u_floor_width_scale); #ifdef LINE_JOIN_NONE v_width=(floorwidth*u_floor_width_scale)+ANTIALIASING;mediump float pixels_to_tile_units=1.0/u_tile_units_to_pixels;mediump float pixel_ratio_inverse=1.0/pixel_ratio;mediump float aspect=v_width/((pattern.w-pattern.y)*pixel_ratio_inverse);highp float subt_multiple=(pattern.z-pattern.x)*pixel_ratio_inverse*pixels_to_tile_units*aspect*32.0;highp float subt=floor(a_pattern_data.z/subt_multiple)*subt_multiple;float offset_sign=(fract(a_pattern_data.x)-0.5)*4.0;float line_progress_offset=offset_sign*v_width*0.5*pixels_to_tile_units;v_linesofar=(a_pattern_data.z-subt)+a_linesofar+line_progress_offset;v_pattern_data=vec2(a_pattern_data.x+line_progress_offset,a_pattern_data.y); #endif #ifdef FOG v_fog_pos=fog_position(pos); #endif #ifdef INDICATOR_CUTOUT v_z_offset=a_z_offset; #endif }`), raster: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" #include "_prelude_raster_array.glsl" uniform float u_fade_t;uniform float u_opacity;uniform highp float u_raster_elevation;uniform highp float u_zoom_transition;in vec2 v_pos0;in vec2 v_pos1;in float v_depth; #ifdef PROJECTION_GLOBE_VIEW in float v_split_fade; #endif 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;uniform float u_emissive_strength; #ifndef RASTER_ARRAY uniform highp sampler2D u_image0;uniform sampler2D u_image1; #endif #ifdef RASTER_COLOR uniform sampler2D u_color_ramp;uniform highp vec4 u_colorization_mix;uniform highp float u_colorization_offset;uniform vec2 u_texture_res; #endif void main() {vec4 color0,color1,color;vec2 value; #ifdef RASTER_COLOR #ifdef RASTER_ARRAY #ifdef RASTER_ARRAY_LINEAR value=mix( raTexture2D_image0_linear(v_pos0,u_texture_res,u_colorization_mix,u_colorization_offset),raTexture2D_image1_linear(v_pos1,u_texture_res,u_colorization_mix,u_colorization_offset),u_fade_t ); #else value=mix( raTexture2D_image0_nearest(v_pos0,u_texture_res,u_colorization_mix,u_colorization_offset),raTexture2D_image1_nearest(v_pos1,u_texture_res,u_colorization_mix,u_colorization_offset),u_fade_t ); #endif if (value.y > 0.0) value.x/=value.y; #else color=mix(texture(u_image0,v_pos0),texture(u_image1,v_pos1),u_fade_t);value=vec2(u_colorization_offset+dot(color.rgb,u_colorization_mix.rgb),color.a); #endif color=texture(u_color_ramp,vec2(value.x,0.5));if (color.a > 0.0) color.rgb/=color.a;color.a*=value.y; #else color0=texture(u_image0,v_pos0);color1=texture(u_image1,v_pos1);if (color0.a > 0.0) color0.rgb/=color0.a;if (color1.a > 0.0) color1.rgb/=color1.a;color=mix(color0,color1,u_fade_t); #endif color.a*=u_opacity; #ifdef GLOBE_POLES color.a*=1.0-smoothstep(0.0,0.05,u_zoom_transition); #endif vec3 rgb=color.rgb;rgb=vec3( dot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);vec3 out_color=mix(u_high_vec,u_low_vec,rgb); #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(vec4(out_color,1.0),u_emissive_strength).rgb; #endif #ifdef FOG highp float fog_limit_high_meters=1000000.0;highp float fog_limit_low_meters=600000.0;float fog_limit=1.0-smoothstep(fog_limit_low_meters,fog_limit_high_meters,u_raster_elevation);out_color=fog_dither(fog_apply(out_color,v_fog_pos,fog_limit)); #endif glFragColor=vec4(out_color*color.a,color.a); #ifdef PROJECTION_GLOBE_VIEW glFragColor*=mix(1.0,1.0-smoothstep(0.0,0.05,u_zoom_transition),smoothstep(0.8,0.9,v_split_fade)); #endif #ifdef RENDER_CUTOFF glFragColor=glFragColor*cutoff_opacity(u_cutoff_params,v_depth); #endif #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform mat3 u_grid_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform vec2 u_perspective_transform;uniform vec2 u_texture_offset;uniform float u_raster_elevation;uniform float u_zoom_transition;uniform vec2 u_merc_center; #define GLOBE_UPSCALE GLOBE_RADIUS/6371008.8 #ifdef GLOBE_POLES in vec3 a_globe_pos;in vec2 a_uv; #else in vec2 a_pos;in vec2 a_texture_pos; #endif out vec2 v_pos0;out vec2 v_pos1;out float v_depth; #ifdef PROJECTION_GLOBE_VIEW out float v_split_fade; #endif void main() {vec2 uv; #ifdef GLOBE_POLES vec3 globe_pos=a_globe_pos;globe_pos+=normalize(globe_pos)*u_raster_elevation*GLOBE_UPSCALE;gl_Position=u_matrix*u_globe_matrix*vec4(globe_pos ,1.0);uv=a_uv; #ifdef FOG v_fog_pos=fog_position((u_normalize_matrix*vec4(a_globe_pos,1.0)).xyz); #endif #else float w=1.0+dot(a_texture_pos,u_perspective_transform);uv=a_texture_pos/8192.0; #ifdef PROJECTION_GLOBE_VIEW vec3 decomposed_pos_and_skirt=decomposeToPosAndSkirt(a_pos);vec3 latLng=u_grid_matrix*vec3(decomposed_pos_and_skirt.xy,1.0);vec3 globe_pos=latLngToECEF(latLng.xy);globe_pos+=normalize(globe_pos)*u_raster_elevation*GLOBE_UPSCALE;vec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);vec4 merc_world_pos=vec4(0.0);float mercatorY=mercatorYfromLat(latLng[0]);float mercatorX=mercatorXfromLng(latLng[1]); v_split_fade=0.0;if (u_zoom_transition > 0.0) {vec2 merc_pos=vec2(mercatorX,mercatorY);merc_world_pos=vec4(merc_pos,u_raster_elevation,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;float opposite_merc_center=mod(u_merc_center.x+0.5,1.0);float dist_from_poles=(abs(mercatorY-0.5)*2.0);float range=0.1;v_split_fade=abs(opposite_merc_center-mercatorX);v_split_fade=clamp(1.0-v_split_fade,0.0,1.0);v_split_fade=max(smoothstep(1.0-range,1.0,dist_from_poles),max(smoothstep(1.0-range,1.0,v_split_fade),smoothstep(1.0-range,1.0,1.0-v_split_fade)));}float tiles=u_grid_matrix[0][2];if (tiles > 0.0) {float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];float uvY=mercatorY*tiles-idy;float uvX=mercatorX*tiles-idx;uv=vec2(uvX,uvY);}vec4 interpolated_pos=vec4(mix(globe_world_pos.xyz,merc_world_pos.xyz,u_zoom_transition)*w,w);gl_Position=u_matrix*interpolated_pos; #ifdef FOG v_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz); #endif #else gl_Position=u_matrix*vec4(a_pos*w,u_raster_elevation*w,w); #ifdef FOG v_fog_pos=fog_position(a_pos); #endif #endif #endif v_pos0=uv;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;v_pos0=u_texture_offset.x+u_texture_offset.y*v_pos0;v_pos1=u_texture_offset.x+u_texture_offset.y*v_pos1; #ifdef RENDER_CUTOFF v_depth=gl_Position.z; #endif }`), rasterParticle: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform float u_fade_t;uniform float u_opacity;uniform highp float u_raster_elevation;in vec2 v_pos0;in vec2 v_pos1;uniform sampler2D u_image0;uniform sampler2D u_image1;void main() {vec4 color0,color1,color;color0=texture(u_image0,v_pos0);color1=texture(u_image1,v_pos1);if (color0.a > 0.0) color0.rgb/=color0.a;if (color1.a > 0.0) color1.rgb/=color1.a;color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 out_color=color.rgb; #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(vec4(out_color,1.0),0.0).rgb; #endif #ifdef FOG highp float fog_limit_high_meters=1000000.0;highp float fog_limit_low_meters=600000.0;float fog_limit=1.0-smoothstep(fog_limit_low_meters,fog_limit_high_meters,u_raster_elevation);out_color=fog_dither(fog_apply(out_color,v_fog_pos,fog_limit)); #endif glFragColor=vec4(out_color*color.a,color.a); #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" uniform mat4 u_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform mat3 u_grid_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_raster_elevation;uniform float u_zoom_transition;uniform vec2 u_merc_center; #define GLOBE_UPSCALE GLOBE_RADIUS/6371008.8 in vec2 a_pos;in vec2 a_texture_pos;out vec2 v_pos0;out vec2 v_pos1;void main() {float w=1.0;vec2 uv; #ifdef PROJECTION_GLOBE_VIEW 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 mercatorX=mercatorXfromLng(latLng[1]);float tiles=u_grid_matrix[0][2];float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];float uvX=mercatorX*tiles-idx;float uvY=mercatorY*tiles-idy;uv=vec2(uvX,uvY);vec3 globe_pos=latLngToECEF(latLng.xy);globe_pos+=normalize(globe_pos)*u_raster_elevation*GLOBE_UPSCALE;vec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);vec4 merc_world_pos=vec4(0.0);if (u_zoom_transition > 0.0) {vec2 merc_pos=vec2(mercatorX,mercatorY);merc_world_pos=vec4(merc_pos,u_raster_elevation,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)*w,w);gl_Position=u_matrix*interpolated_pos; #ifdef FOG v_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz); #endif #else uv=a_texture_pos/8192.0;gl_Position=u_matrix*vec4(a_pos*w,u_raster_elevation*w,w); #ifdef FOG v_fog_pos=fog_position(a_pos); #endif #endif v_pos0=uv;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}`), rasterParticleDraw: Ti("uniform sampler2D u_color_ramp;in float v_particle_speed;void main() {glFragColor=texture(u_color_ramp,vec2(v_particle_speed,0.5));}", `#include "_prelude_raster_particle.glsl" in float a_index;uniform sampler2D u_particle_texture;uniform float u_particle_texture_side_len;uniform vec2 u_tile_offset;out float v_particle_speed;void main() {ivec2 pixel_coord=ivec2( mod(a_index,u_particle_texture_side_len),a_index/u_particle_texture_side_len);vec4 pixel=texelFetch(u_particle_texture,pixel_coord,0);vec2 pos=unpack_pos_from_rgba(pixel)+u_tile_offset;vec2 tex_coord=fract(pos);vec2 velocity=lookup_velocity(tex_coord);if (velocity==INVALID_VELOCITY) {gl_Position=AWAY;v_particle_speed=0.0;} else {gl_Position=vec4(2.0*pos-1.0,0,1);v_particle_speed=length(velocity);}gl_PointSize=1.0;}`), rasterParticleTexture: Ti("uniform sampler2D u_texture;uniform float u_opacity;in vec2 v_tex_pos;void main() {vec4 color=texture(u_texture,v_tex_pos);glFragColor=vec4(floor(255.0*color*u_opacity)/255.0);}", "in vec2 a_pos;out vec2 v_tex_pos;void main() {vec2 uv=0.5*a_pos+vec2(0.5);v_tex_pos=uv;gl_Position=vec4(a_pos,0.0,1.0);}"), rasterParticleUpdate: Ti(`#include "_prelude_raster_particle.glsl" uniform sampler2D u_particle_texture;uniform mediump float u_particle_texture_side_len;uniform mediump float u_speed_factor;uniform highp float u_reset_rate;uniform highp float u_rand_seed;in highp vec2 v_tex_coord;vec2 linearstep(vec2 edge0,vec2 edge1,vec2 x) {return clamp((x-edge0)/(edge1-edge0),vec2(0),vec2(1));}const highp vec3 rand_constants=vec3(12.9898,78.233,4375.85453);highp float rand(const highp vec2 co) {highp float t=dot(rand_constants.xy,co);return fract(sin(t)*(rand_constants.z+t));}void main() {ivec2 pixel_coord=ivec2(v_tex_coord*u_particle_texture_side_len);highp vec4 pixel=texelFetch(u_particle_texture,pixel_coord,0);highp vec2 pos=unpack_pos_from_rgba(pixel);highp vec2 velocity=lookup_velocity(clamp(pos,0.0,1.0));highp vec2 dp=velocity==INVALID_VELOCITY ? vec2(0) : velocity*u_speed_factor;pos=pos+dp;highp vec2 seed=(pos+v_tex_coord)*u_rand_seed;highp vec2 random_pos=vec2(rand(seed+1.3),rand(seed+2.1));highp vec2 persist_rate=pow( linearstep(vec2(-u_particle_pos_offset),vec2(0),pos)*linearstep(vec2(1.0+u_particle_pos_offset),vec2(1),pos),vec2(4) );highp vec2 per_frame_persist=pow(persist_rate,abs(dp)/u_particle_pos_offset);highp float drop_rate=1.0-per_frame_persist.x*per_frame_persist.y;drop_rate=any(greaterThanEqual(abs(pos-0.5),vec2(0.5+u_particle_pos_offset))) ? 1.0 : drop_rate;highp float drop=step(1.0-drop_rate-u_reset_rate,rand(seed));highp vec2 next_pos=mix(pos,random_pos,drop);glFragColor=pack_pos_to_rgba(next_pos);}`, "in vec2 a_pos;out vec2 v_tex_coord;void main() {v_tex_coord=0.5*(a_pos+vec2(1.0));gl_Position=vec4(a_pos,0.0,1.0);}"), symbol: Ti(`#include "_prelude_lighting.glsl" #define SDF_PX 8.0 #define SDF 1.0 #define ICON 0.0 uniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;uniform bool u_is_halo;uniform lowp float u_scale_factor; #ifdef ICON_TRANSITION uniform float u_icon_transition; #endif #ifdef COLOR_ADJUSTMENT uniform mat4 u_color_adj_mat; #endif #ifdef INDICATOR_CUTOUT in highp float v_z_offset; #endif in vec2 v_tex_a; #ifdef ICON_TRANSITION in vec2 v_tex_b; #endif in float v_draw_halo;in vec3 v_gamma_scale_size_fade_opacity; #ifdef RENDER_TEXT_AND_SYMBOL in float is_sdf;in vec2 v_tex_a_icon; #endif #pragma mapbox: define highp vec4 fill_color #pragma mapbox: define highp vec4 halo_color #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp float halo_width #pragma mapbox: define lowp float halo_blur #pragma mapbox: define lowp float emissive_strength void main() { #pragma mapbox: initialize highp vec4 fill_color #pragma mapbox: initialize highp vec4 halo_color #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize lowp float halo_width #pragma mapbox: initialize lowp float halo_blur #pragma mapbox: initialize lowp float emissive_strength vec4 out_color;float fade_opacity=v_gamma_scale_size_fade_opacity[2]; #ifdef RENDER_TEXT_AND_SYMBOL if (is_sdf==ICON) {vec2 tex_icon=v_tex_a_icon;lowp float alpha=opacity*fade_opacity;glFragColor=texture(u_texture_icon,tex_icon)*alpha; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif return;} #endif #ifdef RENDER_SDF float EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_gamma_scale_size_fade_opacity.x;float size=v_gamma_scale_size_fade_opacity.y;float fontScale=u_is_text ? size/24.0 : size;out_color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;bool draw_halo=v_draw_halo > 0.0;if (draw_halo) {out_color=halo_color;gamma=(halo_blur*u_scale_factor*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width*u_scale_factor/fontScale)/SDF_PX;}lowp float dist=texture(u_texture,v_tex_a).r;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);out_color*=alpha; #else #ifdef ICON_TRANSITION vec4 a=texture(u_texture,v_tex_a)*(1.0-u_icon_transition);vec4 b=texture(u_texture,v_tex_b)*u_icon_transition;out_color=(a+b); #else out_color=texture(u_texture,v_tex_a); #endif #ifdef COLOR_ADJUSTMENT out_color=u_color_adj_mat*out_color; #endif #endif out_color*=opacity*fade_opacity; #ifdef LIGHTING_3D_MODE out_color=apply_lighting_with_emission_ground(out_color,emissive_strength); #endif #ifdef INDICATOR_CUTOUT out_color=applyCutout(out_color,v_z_offset); #endif glFragColor=out_color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_terrain.vertex.glsl" in vec4 a_pos_offset;in vec4 a_tex_size;in vec4 a_pixeloffset;in vec4 a_projected_pos;in float a_fade_opacity; #ifdef Z_OFFSET in float a_auto_z_offset; #endif #ifdef PROJECTION_GLOBE_VIEW in vec3 a_globe_anchor;in vec3 a_globe_normal; #endif #ifdef ICON_TRANSITION in vec2 a_texb; #endif #ifdef OCCLUSION_QUERIES in float a_occlusion_query_opacity; #endif #ifdef INDICATOR_CUTOUT out highp float v_z_offset; #endif uniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_elevation_from_sea;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;uniform bool u_is_halo; #ifdef PROJECTION_GLOBE_VIEW uniform 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; #endif out vec2 v_tex_a; #ifdef ICON_TRANSITION out vec2 v_tex_b; #endif out float v_draw_halo;out vec3 v_gamma_scale_size_fade_opacity; #ifdef RENDER_TEXT_AND_SYMBOL out float is_sdf;out vec2 v_tex_a_icon; #endif #pragma mapbox: define highp vec4 fill_color #pragma mapbox: define highp vec4 halo_color #pragma mapbox: define lowp float opacity #pragma mapbox: define lowp float halo_width #pragma mapbox: define lowp float halo_blur #pragma mapbox: define lowp float emissive_strength #pragma mapbox: define lowp float occlusion_opacity #pragma mapbox: define lowp float z_offset void main() { #pragma mapbox: initialize highp vec4 fill_color #pragma mapbox: initialize highp vec4 halo_color #pragma mapbox: initialize lowp float opacity #pragma mapbox: initialize lowp float halo_width #pragma mapbox: initialize lowp float halo_blur #pragma mapbox: initialize lowp float emissive_strength #pragma mapbox: initialize lowp float occlusion_opacity #pragma mapbox: initialize lowp float z_offset vec2 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;float e=u_elevation_from_sea ? z_offset : z_offset+elevation(tile_anchor); #ifdef Z_OFFSET e+=a_auto_z_offset; #endif vec3 h=elevationVector(tile_anchor)*e;float globe_occlusion_fade;vec3 world_pos;vec3 mercator_pos;vec3 world_pos_globe; #ifdef PROJECTION_GLOBE_VIEW mercator_pos=mercator_tile_position(u_inv_rot_matrix,tile_anchor,u_tile_id,u_merc_center);world_pos_globe=a_globe_anchor+h;world_pos=mix_globe_mercator(world_pos_globe,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; #else world_pos=vec3(tile_anchor,0)+h;globe_occlusion_fade=1.0; #endif vec4 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 ? camera_to_anchor_distance/u_camera_to_center_distance : u_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp( 0.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;vec2 a; #ifdef PROJECTION_GLOBE_VIEW vec3 displacement=vec3(a_globe_normal.z,0,-a_globe_normal.x);offsetprojected_point=u_matrix*vec4(a_globe_anchor+displacement,1);vec4 projected_point_globe=u_matrix*vec4(world_pos_globe,1);a=projected_point_globe.xy/projected_point_globe.w; #else offsetprojected_point=u_matrix*vec4(tile_anchor+vec2(1,0),0,1);a=projected_point.xy/projected_point.w; #endif 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; #ifdef PROJECTION_GLOBE_VIEW vec3 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); #else projected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,h.z,1.0); #endif highp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);float z=0.0;vec2 offset=rotation_matrix*(a_offset/32.0*max(a_min_font_scale,font_scale)+a_pxoffset/16.0); #ifdef TERRAIN #ifdef PITCH_WITH_MAP_TERRAIN vec4 tile_pos=u_label_plane_matrix_inv*vec4(a_projected_pos.xy+offset,0.0,1.0);z=elevation(tile_pos.xy); #endif #endif #ifdef Z_OFFSET z+=u_pitch_with_map ? a_auto_z_offset+(u_elevation_from_sea ? z_offset : z_offset) : 0.0; #else z+=u_pitch_with_map ? (u_elevation_from_sea ? z_offset : z_offset) : 0.0; #endif float occlusion_fade=globe_occlusion_fade;float projection_transition_fade=1.0; #if defined(PROJECTED_POS_ON_VIEWPORT) && defined(PROJECTION_GLOBE_VIEW) projection_transition_fade=1.0-step(EPSILON,u_zoom_transition); #endif 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 out_fade_opacity=interpolated_fade_opacity*projection_transition_fade; #ifdef DEPTH_OCCLUSION float depth_occlusion=occlusionFadeMultiSample(projected_point);float depth_occlusion_multplier=mix(occlusion_opacity,1.0,depth_occlusion);out_fade_opacity*=depth_occlusion_multplier; #endif #ifdef OCCLUSION_QUERIES float occludedFadeMultiplier=mix(occlusion_opacity,1.0,a_occlusion_query_opacity);out_fade_opacity*=occludedFadeMultiplier; #endif float alpha=opacity*out_fade_opacity;float hidden=float(alpha==0.0 || projected_point.w <=0.0 || occlusion_fade==0.0); #ifdef PROJECTION_GLOBE_VIEW vec3 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,hidden); #else gl_Position=mix(u_coord_matrix*vec4(projected_pos.xy/projected_pos.w+offset,z,1.0),AWAY,hidden); #endif float gamma_scale=gl_Position.w;v_draw_halo=(u_is_halo && float(gl_InstanceID)==0.0) ? 1.0 : 0.0;v_gamma_scale_size_fade_opacity=vec3(gamma_scale,size,out_fade_opacity);v_tex_a=a_tex/u_texsize; #ifdef RENDER_TEXT_AND_SYMBOL is_sdf=a_size[0]-2.0*a_size_min;v_tex_a_icon=a_tex/u_texsize_icon; #endif #ifdef ICON_TRANSITION v_tex_b=a_texb/u_texsize; #endif #ifdef INDICATOR_CUTOUT v_z_offset=e; #endif }`), terrainRaster: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_shadow.fragment.glsl" #include "_prelude_lighting.glsl" uniform sampler2D u_image0;in vec2 v_pos0; #ifdef FOG in float v_fog_opacity; #endif #ifdef RENDER_SHADOWS in vec4 v_pos_light_view_0;in vec4 v_pos_light_view_1; #endif uniform vec3 u_ground_shadow_factor;void main() {vec4 image_color=texture(u_image0,v_pos0);vec4 color; #ifdef LIGHTING_3D_MODE const vec3 normal=vec3(0.0,0.0,1.0); #ifdef RENDER_SHADOWS float cutoffOpacity=1.0; #ifdef RENDER_CUTOFF cutoffOpacity=cutoff_opacity(u_cutoff_params,1.0/gl_FragCoord.w); #endif #ifdef LIGHTING_3D_ALPHA_EMISSIVENESS vec3 unlit_base=image_color.rgb*(1.0-image_color.a);vec3 emissive_base=image_color.rgb*image_color.a;float ndotl=u_shadow_direction.z;float occlusion=ndotl < 0.0 ? 1.0 : shadow_occlusion(v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w,0.0);ndotl=max(0.0,ndotl);vec3 lit=apply_lighting(unlit_base,normal,mix(1.0,(1.0-(u_shadow_intensity*occlusion))*ndotl,cutoffOpacity));vec3 emissive=compute_emissive_draped(emissive_base,1.0-u_shadow_intensity,occlusion,u_ground_shadow_factor);color.rgb=lit+emissive;color.a=1.0; #else float lighting_factor=shadowed_light_factor_normal_unbiased(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);color=apply_lighting(image_color,normal,mix(1.0,lighting_factor,cutoffOpacity)); #endif #else float lighting_factor=u_lighting_directional_dir.z;color=apply_lighting(image_color,normal,lighting_factor); #ifdef LIGHTING_3D_ALPHA_EMISSIVENESS color.rgb=mix(color.rgb,image_color.rgb,image_color.a);color.a=1.0; #endif #endif #else color=image_color; #endif #ifdef FOG #ifdef ZERO_EXAGGERATION color=fog_dither(fog_apply_premultiplied(color,v_fog_pos)); #else color=fog_dither(fog_apply_from_vert(color,v_fog_opacity)); #endif #endif glFragColor=color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_terrain.vertex.glsl" uniform mat4 u_matrix;uniform float u_skirt_height;in vec2 a_pos;out vec2 v_pos0; #ifdef FOG out float v_fog_opacity; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out vec4 v_pos_light_view_0;out vec4 v_pos_light_view_1;out float v_depth; #endif void main() {vec3 decomposedPosAndSkirt=decomposeToPosAndSkirt(a_pos);float skirt=decomposedPosAndSkirt.z;vec2 decodedPos=decomposedPosAndSkirt.xy;float elevation=elevation(decodedPos)-skirt*u_skirt_height;v_pos0=decodedPos/8192.0;gl_Position=u_matrix*vec4(decodedPos,elevation,1.0); #ifdef FOG #ifdef ZERO_EXAGGERATION v_fog_pos=fog_position(decodedPos); #else v_fog_opacity=fog(fog_position(vec3(decodedPos,elevation))); #endif #endif #ifdef RENDER_SHADOWS vec3 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.); #endif }`), terrainDepth: Ti("precision highp float;in float v_depth;void main() {glFragColor=pack_depth(v_depth);}", `#include "_prelude_terrain.vertex.glsl" uniform mat4 u_matrix;in vec2 a_pos;out 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: Ti(`#include "_prelude_fog.fragment.glsl" in 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( cos_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=texture(u_cubemap,uv).rgb; #ifdef FOG sky_color=fog_apply_sky_gradient(v_uv.xzy,sky_color); #endif sky_color.rgb=dither(sky_color.rgb,gl_FragCoord.xy+u_temporal_offset);sky_color+=0.1*sun_disk(v_uv,u_sun_direction);glFragColor=vec4(sky_color*u_opacity,u_opacity); #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif }`, Ko), skyboxGradient: Ti(`#include "_prelude_fog.fragment.glsl" in 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=texture(u_color_ramp,vec2(progress,0.5)); #ifdef FOG color.rgb=fog_apply_sky_gradient(v_uv.xzy,color.rgb/color.a)*color.a; #endif color*=u_opacity;color.rgb=dither(color.rgb,gl_FragCoord.xy+u_temporal_offset);glFragColor=color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif }`, Ko), skyboxCapture: Ti(` in 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;precision highp float; #define BETA_R vec3(5.5e-6,13.0e-6,22.4e-6) #define BETA_M vec3(21e-6,21e-6,21e-6) #define MIE_G 0.76 #define DENSITY_HEIGHT_SCALE_R 8000.0 #define DENSITY_HEIGHT_SCALE_M 1200.0 #define PLANET_RADIUS 6360e3 #define ATMOSPHERE_RADIUS 6420e3 #define SAMPLE_STEPS 10 #define DENSITY_STEPS 4 float 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;glFragColor=vec4(color,1.0);}`, "in highp vec3 a_pos_3f;uniform mat3 u_matrix_3f;out 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: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_lighting.glsl" uniform sampler2D u_image0;uniform float u_far_z_cutoff;in vec2 v_pos0; #ifndef FOG 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 vec2 u_viewport; #endif void main() {vec4 color; #ifdef CUSTOM_ANTIALIASING vec2 uv=gl_FragCoord.xy/u_viewport;highp vec3 ray_dir=mix( mix(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=texture(u_image0,v_pos0); #ifdef LIGHTING_3D_MODE #ifdef LIGHTING_3D_ALPHA_EMISSIVENESS raster=apply_lighting_with_emission_ground(raster,raster.a);color=vec4(raster.rgb*antialias,antialias); #else raster=apply_lighting_ground(raster);color=vec4(raster.rgb*antialias,raster.a*antialias); #endif #else color=vec4(raster.rgb*antialias,raster.a*antialias); #endif #else color=texture(u_image0,v_pos0); #ifdef LIGHTING_3D_MODE #ifdef LIGHTING_3D_ALPHA_EMISSIVENESS color=apply_lighting_with_emission_ground(color,color.a);color.a=1.0; #else color=apply_lighting_ground(color); #endif #endif #endif #ifdef FOG color=fog_dither(fog_apply_premultiplied(color,v_fog_pos)); #endif color*=1.0-step(u_far_z_cutoff,1.0/gl_FragCoord.w);glFragColor=color; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_terrain.vertex.glsl" 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; #ifdef GLOBE_POLES in vec3 a_globe_pos;in vec2 a_uv; #else in vec2 a_pos; #endif out vec2 v_pos0;void main() { #ifdef GLOBE_POLES vec3 globe_pos=a_globe_pos;vec2 uv=a_uv; #else float 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); #endif v_pos0=uv;vec2 tile_pos=uv*EXTENT;vec3 globe_derived_up_vector=normalize(globe_pos)*u_tile_up_scale; #ifdef GLOBE_POLES vec3 up_vector=globe_derived_up_vector; #else vec3 up_vector=elevationVector(tile_pos); #endif float height=elevation(tile_pos);globe_pos+=up_vector*height; #ifndef GLOBE_POLES globe_pos-=globe_derived_up_vector*u_skirt_height*decomposed_pos_and_skirt.z; #endif #ifdef GLOBE_POLES vec4 interpolated_pos=u_globe_matrix*vec4(globe_pos,1.0); #else vec4 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); #endif gl_Position=u_proj_matrix*interpolated_pos; #ifdef FOG v_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz); #endif }`), globeAtmosphere: Ti(`#include "_prelude_fog.fragment.glsl" uniform float u_transition;uniform highp float u_fadeout_range;uniform highp float u_temporal_offset;uniform vec4 u_color;uniform vec4 u_high_color;uniform vec4 u_space_color;uniform float u_horizon_angle;in highp vec3 v_ray_dir;in highp vec3 v_horizon_dir;void main() {highp vec3 dir=normalize(v_ray_dir);float globe_pos_dot_dir; #ifdef PROJECTION_GLOBE_VIEW globe_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) { #ifdef ALPHA_PASS glFragColor=vec4(0,0,0,0);return; #else #ifdef NATIVE glFragColor=vec4(1,1,1,1); #else glFragColor=vec4(0,0,0,1); #endif return; #endif } #endif highp vec3 horizon_dir=normalize(v_horizon_dir);float horizon_angle_mercator=dir.y < horizon_dir.y ? 0.0 : max(acos(clamp(dot(dir,horizon_dir),-1.0,1.0)),0.0);float horizon_angle; #ifdef PROJECTION_GLOBE_VIEW highp vec3 closest_point=globe_pos_dot_dir*dir;highp float closest_point_to_center=length(closest_point-u_globe_pos);highp float theta=asin(clamp(closest_point_to_center/length(u_globe_pos),-1.0,1.0));horizon_angle=globe_pos_dot_dir < 0.0 ? PI-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); #else horizon_angle=horizon_angle_mercator; #endif horizon_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; #ifdef ALPHA_PASS 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);glFragColor=vec4(1.0,1.0,1.0,a); #else 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=c2; #ifndef NATIVE c=dither(c,gl_FragCoord.xy+u_temporal_offset); #endif glFragColor=vec4(c*t,t); #endif }`, `in vec3 a_pos;in 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;out highp vec3 v_ray_dir;out highp vec3 v_horizon_dir;void main() {v_ray_dir=mix( mix(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( mix(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);}`), model: Ti(`#include "_prelude_fog.fragment.glsl" #include "_prelude_shadow.fragment.glsl" #include "_prelude_lighting.glsl" uniform float u_opacity;uniform vec3 u_lightcolor;uniform vec3 u_lightpos;uniform float u_lightintensity;uniform vec4 u_baseColorFactor;uniform vec4 u_emissiveFactor;uniform float u_metallicFactor;uniform float u_roughnessFactor;uniform float u_emissive_strength;in highp vec4 v_position_height;in lowp vec4 v_color_mix; #ifdef RENDER_SHADOWS in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in float v_depth_shadows; #endif #ifdef OCCLUSION_TEXTURE_TRANSFORM uniform vec4 u_occlusionTextureTransform; #endif #pragma mapbox: define-attribute highp vec3 normal_3f #pragma mapbox: define-attribute highp vec3 color_3f #pragma mapbox: define-attribute highp vec4 color_4f #pragma mapbox: define-attribute highp vec2 uv_2f #pragma mapbox: initialize-attribute highp vec3 normal_3f #pragma mapbox: initialize-attribute highp vec3 color_3f #pragma mapbox: initialize-attribute highp vec4 color_4f #pragma mapbox: initialize-attribute highp vec2 uv_2f #ifdef HAS_ATTRIBUTE_a_pbr in lowp vec4 v_roughness_metallic_emissive_alpha;in mediump vec4 v_height_based_emission_params; #endif #ifdef HAS_TEXTURE_u_baseColorTexture uniform sampler2D u_baseColorTexture;uniform bool u_baseTextureIsAlpha;uniform bool u_alphaMask;uniform float u_alphaCutoff; #endif #ifdef HAS_TEXTURE_u_metallicRoughnessTexture uniform sampler2D u_metallicRoughnessTexture; #endif #ifdef HAS_TEXTURE_u_occlusionTexture uniform sampler2D u_occlusionTexture;uniform float u_aoIntensity; #endif #ifdef HAS_TEXTURE_u_normalTexture uniform sampler2D u_normalTexture; #endif #ifdef HAS_TEXTURE_u_emissionTexture uniform sampler2D u_emissionTexture; #endif #ifdef APPLY_LUT_ON_GPU uniform highp sampler3D u_lutTexture; #endif #ifdef TERRAIN_FRAGMENT_OCCLUSION in highp float v_depth;uniform highp sampler2D u_depthTexture;uniform highp vec2 u_inv_depth_size;uniform highp vec2 u_depth_range_unpack; #ifdef DEPTH_D24 highp float unpack_depth(highp float depth) {return depth*u_depth_range_unpack.x+u_depth_range_unpack.y;} #else highp float unpack_depth_rgba(highp vec4 rgba_depth) {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;} #endif bool isOccluded() {highp vec2 coord=gl_FragCoord.xy*u_inv_depth_size; #ifdef DEPTH_D24 highp float depth=unpack_depth(texture(u_depthTexture,coord).r); #else highp float depth=unpack_depth_rgba(texture(u_depthTexture,coord)); #endif return v_depth > depth+0.0005;} #endif #define saturate(_x) clamp(_x,0.,1.) vec3 linearTosRGB(vec3 color) {return pow(color,vec3(1./2.2));}vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}float calculate_NdotL(vec3 normal,vec3 lightDir) {const float ext=0.70710678118;return (clamp(dot(normal,lightDir),-ext,1.0)+ext)/(1.0+ext);}vec3 getDiffuseShadedColor(vec3 albedo,vec3 normal,vec3 lightDir,vec3 lightColor) { #ifdef LIGHTING_3D_MODE vec3 transformed_normal=vec3(-normal.xy,normal.z);float lighting_factor; #ifdef RENDER_SHADOWS lighting_factor=shadowed_light_factor_normal(transformed_normal,v_pos_light_view_0,v_pos_light_view_1,v_depth_shadows); #else lighting_factor=saturate(dot(transformed_normal,u_lighting_directional_dir)); #endif return apply_lighting(albedo,transformed_normal,lighting_factor); #else vec3 n=normal;float colorvalue=((albedo.x*0.2126)+(albedo.y*0.7152))+(albedo.z*0.0722);vec3 c=vec3(0.03,0.03,0.03);float directional=clamp(dot(n,vec3(lightDir)),0.0,1.0);directional=mix(1.0-u_lightintensity,max((1.0-colorvalue)+u_lightintensity,1.0),directional);vec3 c3=c+clamp((albedo*directional)*lightColor,mix(vec3(0.0),vec3(0.3),vec3(1.0)-lightColor),vec3(1.0));return c3; #endif }vec4 getBaseColor() {vec4 albedo=u_baseColorFactor; #ifdef HAS_ATTRIBUTE_a_color_3f albedo*=vec4(color_3f,1.0); #endif #ifdef HAS_ATTRIBUTE_a_pbr #else #ifdef HAS_ATTRIBUTE_a_color_4f albedo*=color_4f; #endif #endif #if defined (HAS_TEXTURE_u_baseColorTexture) && defined (HAS_ATTRIBUTE_a_uv_2f) vec4 texColor=texture(u_baseColorTexture,uv_2f);if(u_alphaMask) {if (texColor.w < u_alphaCutoff) {discard;}} #ifdef UNPREMULT_TEXTURE_IN_SHADER if(texColor.w > 0.0) {texColor.rgb/=texColor.w;}texColor.w=1.0; #endif if(u_baseTextureIsAlpha) {if (texColor.r < 0.5) {discard;}} else {texColor.rgb=sRGBToLinear(texColor.rgb);albedo*=texColor;} #endif vec4 color=vec4(mix(albedo.rgb,v_color_mix.rgb,v_color_mix.a),albedo.a); #ifdef APPLY_LUT_ON_GPU color=applyLUT(u_lutTexture,color); #endif return color;}highp mat3 cotangentFrame(highp vec3 N,highp vec3 p,highp vec2 uv ) { #ifdef HAS_TEXTURE_u_normalTexture highp vec3 dp1=vec3(dFdx(p.x),dFdx(p.y),dFdx(p.z));highp vec3 dp2=vec3(dFdy(p.x),dFdy(p.y),dFdy(p.z));highp vec2 duv1=vec2(dFdx(uv.x),dFdx(uv.y));highp vec2 duv2=vec2(dFdy(uv.x),dFdy(uv.y));highp vec3 dp2perp=cross( dp2,N );highp vec3 dp1perp=cross( N,dp1 );highp vec3 T=dp2perp*duv1.x+dp1perp*duv2.x;highp vec3 B=dp2perp*duv1.y+dp1perp*duv2.y;highp float lengthT=dot(T,T);highp float lengthB=dot(B,B);highp float maxLength=max(lengthT,lengthB);highp float invmax=inversesqrt( maxLength );highp mat3 res=mat3( T*invmax,B*invmax,N );return res; #else return mat3(1.0); #endif }highp vec3 getNormal(){highp vec3 n; #ifdef HAS_ATTRIBUTE_a_normal_3f n=normalize(normal_3f); #else highp vec3 fdx=vec3(dFdx(v_position_height.x),dFdx(v_position_height.y),dFdx(v_position_height.z));highp vec3 fdy=vec3(dFdy(v_position_height.x),dFdy(v_position_height.y),dFdy(v_position_height.z));n=normalize(cross(fdx,fdy))*-1.0; #endif #if defined(HAS_TEXTURE_u_normalTexture) && defined(HAS_ATTRIBUTE_a_uv_2f) vec3 nMap=texture( u_normalTexture,uv_2f).xyz;nMap=normalize(2.0*nMap-vec3(1.0));highp vec3 v=normalize(-v_position_height.xyz);highp mat3 TBN=cotangentFrame(n,v,uv_2f);n=normalize(TBN*nMap); #endif return n;}struct Material {float perceptualRoughness;float alphaRoughness;float metallic;vec3 f90;vec4 baseColor;vec3 diffuseColor;vec3 specularColor;highp vec3 normal;};Material getPBRMaterial() {Material mat;mat.baseColor=getBaseColor();mat.perceptualRoughness=u_roughnessFactor;mat.metallic=u_metallicFactor; #ifdef HAS_ATTRIBUTE_a_pbr mat.perceptualRoughness=v_roughness_metallic_emissive_alpha.x;mat.metallic=v_roughness_metallic_emissive_alpha.y;mat.baseColor.w*=v_roughness_metallic_emissive_alpha.w; #endif #if defined(HAS_TEXTURE_u_metallicRoughnessTexture) && defined(HAS_ATTRIBUTE_a_uv_2f) vec4 mrSample=texture(u_metallicRoughnessTexture,uv_2f);mat.perceptualRoughness*=mrSample.g;mat.metallic*=mrSample.b; #endif const float c_minRoughness=0.04;mat.perceptualRoughness=clamp(mat.perceptualRoughness,c_minRoughness,1.0);mat.metallic=saturate(mat.metallic);mat.alphaRoughness=mat.perceptualRoughness*mat.perceptualRoughness;const vec3 f0=vec3(0.04);mat.diffuseColor=mat.baseColor.rgb*(vec3(1.0)-f0);mat.diffuseColor*=1.0-mat.metallic;mat.specularColor=mix(f0,mat.baseColor.rgb,mat.metallic);highp float reflectance=max(max(mat.specularColor.r,mat.specularColor.g),mat.specularColor.b);highp float reflectance90=saturate(reflectance*25.0);mat.f90=vec3(reflectance90);mat.normal=getNormal();return mat;}float V_GGX(float NdotL,float NdotV,float roughness) {float a2=roughness*roughness;float GGXV=NdotL*sqrt(NdotV*NdotV*(1.0-a2)+a2);float GGXL=NdotV*sqrt(NdotL*NdotL*(1.0-a2)+a2);return 0.5/(GGXV+GGXL);}float V_GGXFast(float NdotL,float NdotV,float roughness) {float a=roughness;float GGXV=NdotL*(NdotV*(1.0-a)+a);float GGXL=NdotV*(NdotL*(1.0-a)+a);return 0.5/(GGXV+GGXL);}vec3 F_Schlick(vec3 specularColor,vec3 f90,float VdotH) {return specularColor+(f90-specularColor)*pow(clamp(1.0-VdotH,0.0,1.0),5.0);}vec3 F_SchlickFast(vec3 specularColor,float VdotH) {float x=1.0-VdotH;float x4=x*x*x*x;return specularColor+(1.0-specularColor)*x4*x;}float D_GGX(highp float NdotH,float alphaRoughness) {highp float a4=alphaRoughness*alphaRoughness;highp float f=(NdotH*a4-NdotH)*NdotH+1.0;return a4/(PI*f*f);}vec3 diffuseBurley(Material mat,float LdotH,float NdotL,float NdotV) {float f90=2.0*LdotH*LdotH*mat.alphaRoughness-0.5;return (mat.diffuseColor/PI)*(1.0+f90*pow((1.0-NdotL),5.0))*(1.0+f90*pow((1.0-NdotV),5.0));}vec3 diffuseLambertian(Material mat) { #ifdef LIGHTING_3D_MODE return mat.diffuseColor; #else return mat.diffuseColor/PI; #endif }vec3 EnvBRDFApprox(vec3 specularColor,float roughness,highp float NdotV) {vec4 c0=vec4(-1,-0.0275,-0.572,0.022);vec4 c1=vec4(1,0.0425,1.04,-0.04);highp vec4 r=roughness*c0+c1;highp float a004=min(r.x*r.x,exp2(-9.28*NdotV))*r.x+r.y;vec2 AB=vec2(-1.04,1.04)*a004+r.zw;return specularColor*AB.x+AB.y;}vec3 computeIndirectLightContribution(Material mat,float NdotV,vec3 normal) {vec3 env_light=vec3(0.65,0.65,0.65); #ifdef LIGHTING_3D_MODE float ambient_factor=calculate_ambient_directional_factor(normal);env_light=u_lighting_ambient_color*ambient_factor; #endif vec3 envBRDF=EnvBRDFApprox(mat.specularColor,mat.perceptualRoughness,NdotV);vec3 indirectSpecular= envBRDF*env_light;vec3 indirectDiffuse=mat.diffuseColor*env_light;return indirectSpecular+indirectDiffuse;}vec3 computeLightContribution(Material mat,vec3 lightPosition,vec3 lightColor) {highp vec3 n=mat.normal;highp vec3 v=normalize(-v_position_height.xyz);highp vec3 l=normalize(lightPosition);highp vec3 h=normalize(v+l);float NdotV=clamp(abs(dot(n,v)),0.001,1.0);float NdotL=saturate(dot(n,l));highp float NdotH=saturate(dot(n,h));float VdotH=saturate(dot(v,h));vec3 f=F_SchlickFast(mat.specularColor,VdotH);float g=V_GGXFast(NdotL,NdotV,mat.alphaRoughness);float d=D_GGX(NdotH,mat.alphaRoughness);vec3 diffuseTerm=(1.0-f)*diffuseLambertian(mat);vec3 specularTerm=f*g*d;vec3 transformed_normal=vec3(-n.xy,n.z);float lighting_factor; #ifdef RENDER_SHADOWS lighting_factor=shadowed_light_factor_normal(transformed_normal,v_pos_light_view_0,v_pos_light_view_1,v_depth_shadows); #else lighting_factor=NdotL; #endif vec3 directLightColor=(specularTerm+diffuseTerm)*lighting_factor*lightColor;vec3 indirectLightColor=computeIndirectLightContribution(mat,NdotV,transformed_normal);vec3 color=(saturate(directLightColor)+indirectLightColor);float intensityFactor=1.0; #if !defined(LIGHTING_3D_MODE) const vec3 luminosityFactor=vec3(0.2126,0.7152,0.0722);float luminance=dot(diffuseTerm,luminosityFactor);intensityFactor=mix((1.0-u_lightintensity),max((1.0-luminance+u_lightintensity),1.0),NdotL); #endif color*=intensityFactor;return color;}void main() { #ifdef TERRAIN_FRAGMENT_OCCLUSION if (isOccluded()) {discard;} #endif vec3 lightDir=u_lightpos;vec3 lightColor=u_lightcolor; #ifdef LIGHTING_3D_MODE lightDir=u_lighting_directional_dir;lightDir.xy=-lightDir.xy;lightColor=u_lighting_directional_color; #endif vec4 finalColor; #ifdef DIFFUSE_SHADED vec3 N=getNormal();vec3 baseColor=getBaseColor().rgb;vec3 diffuse=getDiffuseShadedColor(baseColor,N,lightDir,lightColor); #ifdef HAS_TEXTURE_u_occlusionTexture float ao=(texture(u_occlusionTexture,uv_2f).r-1.0)*u_aoIntensity+1.0;diffuse*=ao; #endif finalColor=vec4(mix(diffuse,baseColor,u_emissive_strength),1.0)*u_opacity; #else Material mat=getPBRMaterial();vec3 color=computeLightContribution(mat,lightDir,lightColor);float ao=1.0; #if defined (HAS_TEXTURE_u_occlusionTexture) && defined(HAS_ATTRIBUTE_a_uv_2f) #ifdef OCCLUSION_TEXTURE_TRANSFORM vec2 uv=uv_2f.xy*u_occlusionTextureTransform.zw+u_occlusionTextureTransform.xy; #else vec2 uv=uv_2f; #endif ao=(texture(u_occlusionTexture,uv).x-1.0)*u_aoIntensity+1.0;color*=ao; #endif vec4 emissive=u_emissiveFactor; #if defined(HAS_TEXTURE_u_emissionTexture) && defined(HAS_ATTRIBUTE_a_uv_2f) emissive.rgb*=sRGBToLinear(texture(u_emissionTexture,uv_2f).rgb); #endif #ifdef APPLY_LUT_ON_GPU float emissiveFactorLength=max(length(u_emissiveFactor.rgb),0.001);emissive.rgb=sRGBToLinear(applyLUT(u_lutTexture,linearTosRGB(emissive.rgb/emissiveFactorLength).rbg))*emissiveFactorLength; #endif color+=emissive.rgb;float opacity=mat.baseColor.w*u_opacity; #ifdef HAS_ATTRIBUTE_a_pbr float resEmission=v_roughness_metallic_emissive_alpha.z;resEmission*=v_height_based_emission_params.z+v_height_based_emission_params.w*pow(clamp(v_height_based_emission_params.x,0.0,1.0),v_height_based_emission_params.y);vec3 color_mix=v_color_mix.rgb; #ifdef APPLY_LUT_ON_GPU color_mix=applyLUT(u_lutTexture,color_mix); #endif color=mix(color,color_mix,min(1.0,resEmission)); #ifdef HAS_ATTRIBUTE_a_color_4f float distance=length(vec2(1.3*max(0.0,abs(color_4f.x)-color_4f.z),color_4f.y));distance+= mix(0.5,0.0,clamp(resEmission-1.0,0.0,1.0));opacity*=v_roughness_metallic_emissive_alpha.w*saturate(1.0-distance*distance); #endif #endif vec3 unlitColor=mat.baseColor.rgb*ao+emissive.rgb;color=mix(color,unlitColor,u_emissive_strength);color=linearTosRGB(color);color*=opacity;finalColor=vec4(color,opacity); #endif #ifdef FOG finalColor=fog_dither(fog_apply_premultiplied(finalColor,v_fog_pos,v_position_height.w)); #endif #ifdef RENDER_CUTOFF finalColor*=v_cutoff_opacity; #endif #ifdef INDICATOR_CUTOUT finalColor=applyCutout(finalColor,v_position_height.w); #endif glFragColor=finalColor; #ifdef OVERDRAW_INSPECTOR glFragColor=vec4(1.0); #endif HANDLE_WIREFRAME_DEBUG;}`, `#include "_prelude_fog.vertex.glsl" #include "_prelude_shadow.vertex.glsl" in vec3 a_pos_3f; #pragma mapbox: define-attribute highp vec3 normal_3f #pragma mapbox: define-attribute highp vec2 uv_2f #pragma mapbox: define-attribute highp vec3 color_3f #pragma mapbox: define-attribute highp vec4 color_4f #pragma mapbox: define-attribute-vertex-shader-only highp vec4 pbr #pragma mapbox: define-attribute-vertex-shader-only highp vec3 heightBasedEmissiveStrength uniform mat4 u_matrix;uniform mat4 u_node_matrix;uniform mat4 u_lighting_matrix;uniform vec3 u_camera_pos;uniform vec4 u_color_mix; #ifdef INSTANCED_ARRAYS in vec4 a_normal_matrix0;in vec4 a_normal_matrix1;in vec4 a_normal_matrix2;in vec4 a_normal_matrix3; #else uniform highp mat4 u_normal_matrix; #endif #ifdef RENDER_SHADOWS uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out float v_depth_shadows; #endif out vec4 v_position_height;out lowp vec4 v_color_mix; #ifdef TERRAIN_FRAGMENT_OCCLUSION out highp float v_depth; #endif #ifdef HAS_ATTRIBUTE_a_pbr out lowp vec4 v_roughness_metallic_emissive_alpha;out mediump vec4 v_height_based_emission_params; #endif vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}void main() { #pragma mapbox: initialize-attribute highp vec3 normal_3f #pragma mapbox: initialize-attribute highp vec2 uv_2f #pragma mapbox: initialize-attribute highp vec3 color_3f #pragma mapbox: initialize-attribute highp vec4 color_4f #pragma mapbox: initialize-attribute-custom highp vec4 pbr #pragma mapbox: initialize-attribute-custom highp vec3 heightBasedEmissiveStrength highp mat4 normal_matrix; #ifdef INSTANCED_ARRAYS normal_matrix=mat4(a_normal_matrix0,a_normal_matrix1,a_normal_matrix2,a_normal_matrix3); #else normal_matrix=u_normal_matrix; #endif vec3 local_pos;mat3 rs; #ifdef MODEL_POSITION_ON_GPU vec3 pos_color=normal_matrix[0].xyz;vec4 translate=normal_matrix[1];vec3 pos_a=floor(pos_color);vec3 rgb=1.05*(pos_color-pos_a);float hidden=float(pos_a.x > EXTENT);float color_mix=pos_a.z/100.0;v_color_mix=vec4(sRGBToLinear(rgb),color_mix);float meter_to_tile=normal_matrix[0].w;vec4 pos=vec4(pos_a.xy,translate.z,1.0);rs[0].x=normal_matrix[1].w;rs[0].yz=normal_matrix[2].xy;rs[1].xy=normal_matrix[2].zw;rs[1].z=normal_matrix[3].x;rs[2].xyz=normal_matrix[3].yzw;vec4 pos_node=u_lighting_matrix*vec4(a_pos_3f,1.0);vec3 rotated_pos_node=rs*pos_node.xyz;vec3 pos_model_tile=(rotated_pos_node+vec3(translate.xy,0.0))*vec3(meter_to_tile,meter_to_tile,1.0);pos.xyz+=pos_model_tile;local_pos=pos.xyz;gl_Position=mix(u_matrix*pos,AWAY,hidden);pos.z*=meter_to_tile;v_position_height.xyz=pos.xyz-u_camera_pos; #else local_pos=a_pos_3f;gl_Position=u_matrix*vec4(a_pos_3f,1);v_position_height.xyz=vec3(u_lighting_matrix*vec4(a_pos_3f,1));v_color_mix=vec4(sRGBToLinear(u_color_mix.rgb),u_color_mix.a); #endif v_position_height.w=a_pos_3f.z; #ifdef HAS_ATTRIBUTE_a_pbr vec4 albedo_c=decode_color(pbr.xy);vec2 e_r_m=unpack_float(pbr.z);vec2 r_m= unpack_float(e_r_m.y*16.0);r_m.r=r_m.r*16.0;v_color_mix=vec4(albedo_c.rgb,1.0);v_roughness_metallic_emissive_alpha=vec4(vec3(r_m,e_r_m.x)/255.0,albedo_c.a);v_roughness_metallic_emissive_alpha.z*=2.0;float heightBasedRelativeIntepolation=a_pos_3f.z*heightBasedEmissiveStrength.x+heightBasedEmissiveStrength.y;v_height_based_emission_params.x=heightBasedRelativeIntepolation;v_height_based_emission_params.y=heightBasedEmissiveStrength.z;vec2 emissionMultiplierValues=unpack_float(pbr.w)/256.0;v_height_based_emission_params.z=emissionMultiplierValues.x;v_height_based_emission_params.w=emissionMultiplierValues.y-emissionMultiplierValues.x; #endif #ifdef FOG v_fog_pos=fog_position(local_pos); #endif #ifdef RENDER_CUTOFF v_cutoff_opacity=cutoff_opacity(u_cutoff_params,gl_Position.z); #endif #ifdef TERRAIN_FRAGMENT_OCCLUSION v_depth=gl_Position.z/gl_Position.w; #endif #ifdef HAS_ATTRIBUTE_a_normal_3f #ifdef MODEL_POSITION_ON_GPU float x_squared_scale=dot(rs[0],rs[0]);float y_squared_scale=dot(rs[1],rs[1]);float z_squared_scale=dot(rs[2],rs[2]);vec3 squared_scale=vec3(x_squared_scale,y_squared_scale,z_squared_scale);normal_3f=rs*((u_lighting_matrix*vec4(normal_3f,0.0)).xyz/squared_scale);normal_3f=normalize(normal_3f); #else normal_3f=vec3(normal_matrix*vec4(normal_3f,0)); #endif #endif #ifdef HAS_ATTRIBUTE_a_pbr #ifdef HAS_ATTRIBUTE_a_color_4f v_roughness_metallic_emissive_alpha.w=clamp(color_4f.a*v_roughness_metallic_emissive_alpha.w*(v_roughness_metallic_emissive_alpha.z-1.0),0.0,1.0); #endif #endif #ifdef RENDER_SHADOWS vec4 shadow_pos=u_node_matrix*vec4(local_pos,1.0); #ifdef NORMAL_OFFSET #ifdef HAS_ATTRIBUTE_a_normal_3f #ifdef MODEL_POSITION_ON_GPU vec3 offset=shadow_normal_offset(vec3(-normal_3f.xy,normal_3f.z));shadow_pos.xyz+=offset*shadow_normal_offset_multiplier0(); #else vec3 offset=shadow_normal_offset_model(normal_3f);shadow_pos.xyz+=offset*shadow_normal_offset_multiplier0(); #endif #endif #endif v_pos_light_view_0=u_light_matrix_0*shadow_pos;v_pos_light_view_1=u_light_matrix_1*shadow_pos;v_depth_shadows=gl_Position.w; #endif }`), modelDepth: Ti(`in highp float v_depth;void main() { #ifndef DEPTH_TEXTURE glFragColor=pack_depth(v_depth); #endif }`, `in vec3 a_pos_3f;uniform mat4 u_matrix;out highp float v_depth; #ifdef MODEL_POSITION_ON_GPU #ifdef INSTANCED_ARRAYS in vec4 a_normal_matrix0;in vec4 a_normal_matrix1;in vec4 a_normal_matrix2;in vec4 a_normal_matrix3; #else uniform highp mat4 u_instance; #endif uniform highp mat4 u_node_matrix; #endif void main() { #ifdef MODEL_POSITION_ON_GPU highp mat4 instance; #ifdef INSTANCED_ARRAYS instance=mat4(a_normal_matrix0,a_normal_matrix1,a_normal_matrix2,a_normal_matrix3); #else instance=u_instance; #endif vec3 pos_color=instance[0].xyz;vec4 translate=instance[1];vec3 pos_a=floor(pos_color);float hidden=float(pos_a.x > EXTENT);float meter_to_tile=instance[0].w;vec4 pos=vec4(pos_a.xy,translate.z,1.0);mat3 rs;rs[0].x=instance[1].w;rs[0].yz=instance[2].xy;rs[1].xy=instance[2].zw;rs[1].z=instance[3].x;rs[2].xyz=instance[3].yzw;vec4 pos_node=u_node_matrix*vec4(a_pos_3f,1.0);vec3 rotated_pos_node=rs*pos_node.xyz;vec3 pos_model_tile=(rotated_pos_node+vec3(translate.xy,0.0))*vec3(meter_to_tile,meter_to_tile,1.0);pos.xyz+=pos_model_tile;gl_Position=mix(u_matrix*pos,AWAY,hidden); #else gl_Position=u_matrix*vec4(a_pos_3f,1); #endif v_depth=gl_Position.z/gl_Position.w;}`), stars: Ti(`in highp vec2 v_uv;in mediump float v_intensity;float shapeCircle(in vec2 uv) {float beginFade=0.6;float lengthFromCenter=length(v_uv);return 1.0-clamp((lengthFromCenter-beginFade)/(1.0-beginFade),0.0,1.0);}void main() {float alpha=shapeCircle(v_uv);vec3 color=vec3(1.0,1.0,1.0);alpha*=v_intensity;glFragColor=vec4(color*alpha,alpha);HANDLE_WIREFRAME_DEBUG;}`, ` in vec3 a_pos_3f;in vec2 a_uv;in float a_size_scale;in float a_fade_opacity;uniform mat4 u_matrix;uniform vec3 u_up;uniform vec3 u_right;uniform float u_intensity_multiplier;out highp vec2 v_uv;out mediump float v_intensity;void main() {v_uv=a_uv;v_intensity=a_fade_opacity*u_intensity_multiplier;vec3 pos=a_pos_3f;pos+=a_uv.x*u_right*a_size_scale;pos+=a_uv.y*u_up*a_size_scale;gl_Position=u_matrix*vec4(pos,1.0);}`), snowParticle: Ti("in highp vec2 uv;in highp float alphaMultiplier;uniform vec4 u_particleColor;uniform vec2 u_simpleShapeParameters;void main() {float t=clamp((length(uv)-u_simpleShapeParameters.x)/(1.0-u_simpleShapeParameters.x),0.0,1.0);float alpha=1.0-pow(t,pow(10.0,u_simpleShapeParameters.y));alpha*=alphaMultiplier;alpha*=u_particleColor.a;vec3 color=u_particleColor.rgb*alpha;glFragColor=vec4(color,alpha) ;HANDLE_WIREFRAME_DEBUG;}", ` in highp vec3 a_pos_3f;in highp vec2 a_uv;in highp vec4 a_snowParticleData;in highp vec4 a_snowParticleDataHorizontalOscillation;uniform mat4 u_modelview;uniform mat4 u_projection;uniform vec3 u_cam_pos;uniform vec2 u_screenSize;uniform float u_time;uniform float u_boxSize;uniform float u_velocityConeAperture; uniform float u_velocity;uniform vec3 u_direction;uniform float u_horizontalOscillationRadius; uniform float u_horizontalOscillationRate; uniform float u_billboardSize;uniform vec2 u_thinningCenterPos;uniform vec3 u_thinningShape;uniform float u_thinningAffectedRatio;uniform float u_thinningParticleOffset;out highp vec2 uv;out highp float alphaMultiplier;void main() {vec3 pos=a_pos_3f;float halfBoxSize=0.5*u_boxSize;pos.xyz*=halfBoxSize;pos+=u_cam_pos;float velocityConeApertureRad=radians(u_velocityConeAperture*0.5);float coneAnglePichRad=velocityConeApertureRad*a_snowParticleData.z;float coneAngleHeadingRad=a_snowParticleData.w*radians(360.0);vec3 localZ=normalize(u_direction);vec3 localX=normalize(cross(localZ,vec3(1,0,0)));vec3 localY=normalize(cross(localZ,localX));vec3 direction;direction.x=cos(coneAngleHeadingRad)*sin(coneAnglePichRad);direction.y=sin(coneAngleHeadingRad)*sin(coneAnglePichRad);direction.z=cos(coneAnglePichRad);direction=normalize(direction);vec3 simPosLocal=vec3(0,0,0);float velocityScale=(1.0+3.0*a_snowParticleData.y)*u_velocity;simPosLocal+=direction*velocityScale*u_time;float horizontalOscillationRadius=u_horizontalOscillationRadius*a_snowParticleDataHorizontalOscillation.x;float horizontalOscillationAngle=u_horizontalOscillationRate*u_time*(-1.0+2.0*a_snowParticleDataHorizontalOscillation.y);simPosLocal.xy+=horizontalOscillationRadius*vec2(cos(horizontalOscillationAngle),sin(horizontalOscillationAngle));vec3 simPos=localX*simPosLocal.x+ localY*simPosLocal.y+localZ*simPosLocal.z;pos+=simPos;pos=fract((pos+vec3(halfBoxSize))/vec3(u_boxSize))*u_boxSize-vec3(halfBoxSize);float clipZ=-u_cam_pos.z+pos.z;vec4 posView=u_modelview*vec4(pos,1.0);float size=u_billboardSize;alphaMultiplier=1.0;vec4 posScreen=u_projection*posView;posScreen/=posScreen.w;posScreen.xy=vec2(0.5)+posScreen.xy*0.5;posScreen.xy*=u_screenSize;vec2 thinningCenterPos=u_thinningCenterPos.xy;thinningCenterPos.y=u_screenSize.y-thinningCenterPos.y;float screenDist=length((thinningCenterPos-posScreen.xy)/(0.5*u_screenSize));screenDist+=a_snowParticleData.x*u_thinningParticleOffset;float scaleFactorMode=0.0;float thinningShapeDist=u_thinningShape.x+u_thinningShape.y;if (screenDist < thinningShapeDist) {float thinningFadeRatio=clamp((screenDist-u_thinningShape.x)/u_thinningShape.y,0.0,1.0);thinningFadeRatio=pow(thinningFadeRatio,u_thinningShape.z);if (a_snowParticleData.x < u_thinningAffectedRatio) {scaleFactorMode=1.0-thinningFadeRatio;alphaMultiplier=thinningFadeRatio;}}vec4 posScreen1=u_projection*vec4(posView.x-size,posView.yzw);posScreen1/=posScreen1.w;vec4 posScreen2=u_projection*vec4(posView.x+size,posView.yzw);posScreen2/=posScreen2.w;posScreen1.xy=vec2(0.5)+posScreen1.xy*0.5;posScreen1.xy*=u_screenSize;posScreen2.xy=vec2(0.5)+posScreen2.xy*0.5;posScreen2.xy*=u_screenSize;float screenLength=length(posScreen1.xy-posScreen2.xy);float screenEpsilon=3.0;float scaleFactor=1.0;if (screenLength < screenEpsilon) {scaleFactor=screenEpsilon/max(screenLength,0.01);scaleFactor=mix(scaleFactor,1.0,scaleFactorMode);}float screenEpsilon2=15.0;if (screenLength > screenEpsilon2) {scaleFactor=screenEpsilon2/max(screenLength,0.01);}size*=scaleFactor;vec2 right=size*vec2(1,0);vec2 up=size*vec2(0,1);posView.xy+=right*a_uv.x;posView.xy+=up*a_uv.y;uv=a_uv;gl_Position=u_projection*posView;}`), rainParticle: Ti("in highp vec2 uv;in highp float particleRandomValue;uniform sampler2D u_texScreen;uniform float u_distortionStrength;uniform vec4 u_color;uniform vec2 u_thinningCenterPos;uniform vec3 u_thinningShape;uniform float u_thinningAffectedRatio;uniform float u_thinningParticleOffset;uniform float u_shapeDirectionalPower;uniform float u_mode;void main() {vec2 st=uv*0.5+vec2(0.5);vec2 uvm=uv;uvm.y=-1.0+2.0*pow(st.y,u_shapeDirectionalPower);float shape=clamp(1.0-length(uvm),0.0,1.0);float alpha=abs(shape)*u_color.a;vec2 screenSize=vec2(textureSize(u_texScreen,0));vec2 thinningCenterPos=u_thinningCenterPos.xy;thinningCenterPos.y=screenSize.y-thinningCenterPos.y;float screenDist=length((thinningCenterPos-gl_FragCoord.xy)/(0.5*screenSize));screenDist+=(0.5+0.5*particleRandomValue)*u_thinningParticleOffset;float thinningShapeDist=u_thinningShape.x+u_thinningShape.y;float thinningAlpha=1.0;if (screenDist < thinningShapeDist) {float thinningFadeRatio=clamp((screenDist-u_thinningShape.x)/u_thinningShape.y,0.0,1.0);thinningFadeRatio=pow(thinningFadeRatio,u_thinningShape.z);thinningAlpha*=thinningFadeRatio;}vec2 offsetXY=normalize(uvm)*abs(shape);vec2 stScreen=(gl_FragCoord.xy+offsetXY*u_distortionStrength*thinningAlpha)/screenSize;vec3 colorScreen=texture(u_texScreen,stScreen).rgb;alpha*=thinningAlpha;glFragColor=mix(vec4(colorScreen,1.0),vec4(u_color.rgb*alpha,alpha),u_mode);HANDLE_WIREFRAME_DEBUG;}", ` in highp vec3 a_pos_3f;in highp vec2 a_uv;in highp vec4 a_rainParticleData;uniform mat4 u_modelview;uniform mat4 u_projection;uniform vec3 u_cam_pos;uniform float u_time;uniform float u_boxSize;uniform float u_velocityConeAperture; uniform float u_velocity; uniform vec2 u_rainDropletSize;uniform vec3 u_rainDirection;out highp vec2 uv;out highp float particleRandomValue;void main() {vec3 pos=a_pos_3f;float halfBoxSize=0.5*u_boxSize;pos*=halfBoxSize; pos+=u_cam_pos;float velocityConeApertureRad=radians(u_velocityConeAperture*0.5);float coneAnglePichRad=velocityConeApertureRad*a_rainParticleData.z;float coneAngleHeadingRad=a_rainParticleData.w*radians(360.0);vec3 localZ=normalize(u_rainDirection);vec3 localX=normalize(cross(localZ,vec3(1,0,0)));vec3 localY=normalize(cross(localZ,localX));vec3 directionLocal;directionLocal.x=cos(coneAngleHeadingRad)*sin(coneAnglePichRad);directionLocal.y=sin(coneAngleHeadingRad)*sin(coneAnglePichRad);directionLocal.z=cos(coneAnglePichRad);directionLocal=normalize(directionLocal);vec3 directionWorld=localX*directionLocal.x+localY*directionLocal.y+localZ*directionLocal.z;float velocityScale=(1.0+3.0*a_rainParticleData.y)*u_velocity;vec3 simPosLocal=vec3(0,0,0);simPosLocal+=directionLocal*velocityScale*u_time;vec3 simPos=localX*simPosLocal.x+ localY*simPosLocal.y+localZ*simPosLocal.z;pos+=simPos;pos=fract((pos+vec3(halfBoxSize))/vec3(u_boxSize))*u_boxSize-vec3(halfBoxSize);vec4 posView=u_modelview*vec4(pos,1.0);vec3 directionView=normalize((u_modelview*vec4(directionWorld,0.0)).xyz);vec3 side=cross(directionView,normalize(posView.xyz));posView.xyz+=side*a_uv.x*u_rainDropletSize.x;posView.xyz+=directionView*a_uv.y*u_rainDropletSize.y;uv=a_uv;particleRandomValue=a_rainParticleData.x;gl_Position=u_projection*posView;}`), vignette: Ti("uniform vec3 u_vignetteShape;uniform vec4 u_vignetteColor;in vec2 st;void main() {float screenDist=length(st);float alpha=clamp((screenDist-u_vignetteShape.x)/u_vignetteShape.y,0.0,1.0);alpha=pow(alpha,u_vignetteShape.z)*u_vignetteColor.a;vec3 color=u_vignetteColor.rgb;glFragColor=vec4(color*alpha,alpha) ;}", "in vec2 a_pos_2f;out vec2 st;void main() {st=a_pos_2f;gl_Position=vec4(a_pos_2f,0,1);}"), occlusion: Ti("uniform vec4 u_color;void main() {glFragColor=u_color;}", `#include "_prelude_terrain.vertex.glsl" in highp vec2 a_offset_xy;uniform highp vec3 u_anchorPos;uniform mat4 u_matrix;uniform vec2 u_screenSizePx;uniform vec2 u_occluderSizePx;void main() {vec3 world_pos=u_anchorPos; #ifdef TERRAIN float e=elevation(world_pos.xy);world_pos.z+=e; #endif vec4 projected_point=u_matrix*vec4(world_pos,1.0);projected_point.xy+=projected_point.w*a_offset_xy*0.5*u_occluderSizePx/u_screenSizePx;gl_Position=projected_point;}`) }; function ao(c, t) { const s = c.replace(/\s*\/\/[^\n]*\n/g, ` `).split(` `); for (let h of s) if (h = h.trim(), h[0] === "#" && h.includes("if") && !h.includes("endif")) { h = h.replace("#", "").replace(/ifdef|ifndef|elif|if/g, "").replace(/!|defined|\(|\)|\|\||&&/g, "").replace(/\s+/g, " ").trim(); const _ = h.split(" "); for (const y of _) t.includes(y) || t.push(y); } } function Ti(c, t) { const s = /#include\s+"([^"]+)"/g, h = /#pragma mapbox: ([\w\-]+) ([\w]+) ([\w]+) ([\w]+)/g; let _ = t.match(/(attribute(\S*)|(^\s*|;)in) (highp |mediump |lowp )?([\w]+) ([\w]+)/gm); _ && (_ = _.map((F) => { const N = F.split(" "); return N[N.length - 1]; }), _ = [...new Set(_)]); const y = {}, T = [], z = []; if (c = c.replace(s, (F, N) => (z.push(N), "")), (t = t.replace(s, (F, N) => (T.push(N), ""))).includes("flat out")) return void console.error('The usage of "flat" qualifier is disallowed, see: https://bugs.webkit.org/show_bug.cgi?id=268071'); let R = [...kr]; ao(c, R), ao(t, R); for (const F of [...T, ...z]) oo[F] || console.error(`Undefined include: ${F}`), Jo[F] || (Jo[F] = [], ao(oo[F], Jo[F])), R = [...R, ...Jo[F]]; return { fragmentSource: c = c.replace(h, (F, N, G, Z, W) => (y[W] = !0, N === "define" ? ` #ifndef HAS_UNIFORM_u_${W} in ${G} ${Z} ${W}; #else uniform ${G} ${Z} u_${W}; #endif ` : N === "initialize" ? ` #ifdef HAS_UNIFORM_u_${W} ${G} ${Z} ${W} = u_${W}; #endif ` : N === "define-attribute" ? ` #ifdef HAS_ATTRIBUTE_a_${W} in ${G} ${Z} ${W}; #endif ` : N === "initialize-attribute" ? "" : void 0)), vertexSource: t = t.replace(h, (F, N, G, Z, W) => { const te = Z === "float" ? "vec2" : Z, ee = W.match(/color/) ? "color" : te; return N === "define-attribute-vertex-shader-only" ? ` #ifdef HAS_ATTRIBUTE_a_${W} in ${G} ${Z} a_${W}; #endif ` : y[W] ? N === "define" ? ` #ifndef HAS_UNIFORM_u_${W} uniform lowp float u_${W}_t; in ${G} ${te} a_${W}; out ${G} ${Z} ${W}; #else uniform ${G} ${Z} u_${W}; #endif ` : N === "initialize" ? ee === "vec4" ? ` #ifndef HAS_UNIFORM_u_${W} ${W} = a_${W}; #else ${G} ${Z} ${W} = u_${W}; #endif ` : ` #ifndef HAS_UNIFORM_u_${W} ${W} = unpack_mix_${ee}(a_${W}, u_${W}_t); #else ${G} ${Z} ${W} = u_${W}; #endif ` : N === "define-attribute" ? ` #ifdef HAS_ATTRIBUTE_a_${W} in ${G} ${Z} a_${W}; out ${G} ${Z} ${W}; #endif ` : N === "initialize-attribute" ? ` #ifdef HAS_ATTRIBUTE_a_${W} ${W} = a_${W}; #endif ` : void 0 : N === "define" ? ` #ifndef HAS_UNIFORM_u_${W} uniform lowp float u_${W}_t; in ${G} ${te} a_${W}; #else uniform ${G} ${Z} u_${W}; #endif ` : N === "define-instanced" ? ee === "mat4" ? ` #ifdef INSTANCED_ARRAYS in vec4 a_${W}0; in vec4 a_${W}1; in vec4 a_${W}2; in vec4 a_${W}3; #else uniform ${G} ${Z} u_${W}; #endif ` : ` #ifdef INSTANCED_ARRAYS in ${G} ${te} a_${W}; #else uniform ${G} ${Z} u_${W}; #endif ` : N === "initialize-attribute-custom" ? ` #ifdef HAS_ATTRIBUTE_a_${W} ${G} ${Z} ${W} = a_${W}; #endif ` : ee === "vec4" ? ` #ifndef HAS_UNIFORM_u_${W} ${G} ${Z} ${W} = a_${W}; #else ${G} ${Z} ${W} = u_${W}; #endif ` : ` #ifndef HAS_UNIFORM_u_${W} ${G} ${Z} ${W} = unpack_mix_${ee}(a_${W}, u_${W}_t); #else ${G} ${Z} ${W} = u_${W}; #endif `; }), staticAttributes: _, usedDefines: R, vertexIncludes: T, fragmentIncludes: z }; } class qh { constructor() { this.boundProgram = null, this.boundLayoutVertexBuffer = null, this.boundPaintVertexBuffers = [], this.boundIndexBuffer = null, this.boundVertexOffset = null, this.boundDynamicVertexBuffers = [], this.vao = null; } bind(t, s, h, _, y, T, z, R) { this.context = t; let F = this.boundPaintVertexBuffers.length !== _.length; for (let G = 0; !F && G < _.length; G++) this.boundPaintVertexBuffers[G] !== _[G] && (F = !0); let N = this.boundDynamicVertexBuffers.length !== z.length; for (let G = 0; !N && G < z.length; G++) this.boundDynamicVertexBuffers[G] !== z[G] && (N = !0); if (!this.vao || this.boundProgram !== s || this.boundLayoutVertexBuffer !== h || F || N || this.boundIndexBuffer !== y || this.boundVertexOffset !== T) this.freshBind(s, h, _, y, T, z, R); else { t.bindVertexArrayOES.set(this.vao); for (const G of z) G && (G.bind(), R && G.instanceCount && G.setVertexAttribDivisor(t.gl, s, R)); y && y.dynamicDraw && y.bind(); } } freshBind(t, s, h, _, y, T, z) { const R = t.numAttributes, F = this.context, N = F.gl; this.vao && this.destroy(), this.vao = F.gl.createVertexArray(), F.bindVertexArrayOES.set(this.vao), this.boundProgram = t, this.boundLayoutVertexBuffer = s, this.boundPaintVertexBuffers = h, this.boundIndexBuffer = _, this.boundVertexOffset = y, this.boundDynamicVertexBuffers = T, s.enableAttributes(N, t), s.bind(), s.setVertexAttribPointers(N, t, y); for (const G of h) G.enableAttributes(N, t), G.bind(), G.setVertexAttribPointers(N, t, y); for (const G of T) G && (G.enableAttributes(N, t), G.bind(), G.setVertexAttribPointers(N, t, y), z && G.instanceCount && G.setVertexAttribDivisor(N, t, z)); _ && _.bind(), F.currentNumAttributes = R; } destroy() { this.vao && (this.context.gl.deleteVertexArray(this.vao), this.vao = null); } } function bl(c, t) { const s = Math.pow(2, t.canonical.z), h = t.canonical.y; return [new i.aa(0, h / s).toLngLat().lat, new i.aa(0, (h + 1) / s).toLngLat().lat]; } function Ga(c, t, s, h, _, y, T) { const z = c.context, R = z.gl, F = s.hillshadeFBO; if (!F) return; c.prepareDrawTile(); const N = c.isTileAffectedByFog(t), G = c.getOrCreateProgram("hillshade", { overrideFog: N }); z.activeTexture.set(R.TEXTURE0), R.bindTexture(R.TEXTURE_2D, F.colorAttachment.get()); const Z = ((se, oe, he, _e) => { const pe = he.paint.get("hillshade-shadow-color"), Me = he.paint.get("hillshade-shadow-color-use-theme").constantOr("default") === "none", xe = he.paint.get("hillshade-highlight-color"), we = he.paint.get("hillshade-highlight-color-use-theme").constantOr("default") === "none", ve = he.paint.get("hillshade-accent-color"), Ae = he.paint.get("hillshade-accent-color-use-theme").constantOr("default") === "none", Oe = he.paint.get("hillshade-emissive-strength"); let Xe = i.ai(he.paint.get("hillshade-illumination-direction")); if (he.paint.get("hillshade-illumination-anchor") === "viewport") Xe -= se.transform.angle; else if (se.style && se.style.enable3dLights() && se.style.directionalLight) { const ke = se.style.directionalLight.properties.get("direction"), Ne = i.cb(ke.x, ke.y, ke.z); Xe = i.ai(Ne[1]); } const He = !se.options.moving; return { u_matrix: _e || se.transform.calculateProjMatrix(oe.tileID.toUnwrapped(), He), u_image: 0, u_latrange: bl(0, oe.tileID), u_light: [he.paint.get("hillshade-exaggeration"), Xe], u_shadow: pe.toRenderColor(Me ? null : he.lut), u_highlight: xe.toRenderColor(we ? null : he.lut), u_emissive_strength: Oe, u_accent: ve.toRenderColor(Ae ? null : he.lut) }; })(c, s, h, c.terrain ? t.projMatrix : null); c.uploadCommonUniforms(z, G, t.toUnwrapped()); const { tileBoundsBuffer: W, tileBoundsIndexBuffer: te, tileBoundsSegments: ee } = c.getTileBoundsBuffers(s); G.draw(c, R.TRIANGLES, _, y, T, ti.disabled, Z, h.id, W, te, ee); } function Qo(c, t, s) { if (!t.needsDEMTextureUpload) return; const h = c.context, _ = h.gl; h.pixelStoreUnpackPremultiplyAlpha.set(!1), t.demTexture = t.demTexture || c.getTileTexture(s.stride); const y = s.getPixels(); t.demTexture ? t.demTexture.update(y, { premultiply: !1 }) : t.demTexture = new i.T(h, y, _.R32F, { premultiply: !1 }), t.needsDEMTextureUpload = !1; } function qc(c, t, s) { const h = c.context, _ = h.gl; if (!t.dem) return; const y = t.dem; if (h.activeTexture.set(_.TEXTURE1), Qo(c, t, y), !t.demTexture) return; t.demTexture.bind(_.NEAREST, _.CLAMP_TO_EDGE); const T = y.dim; h.activeTexture.set(_.TEXTURE0); let z = t.hillshadeFBO; if (!z) { const Z = new i.T(h, { width: T, height: T, data: null }, _.RGBA8); Z.bind(_.LINEAR, _.CLAMP_TO_EDGE), z = t.hillshadeFBO = h.createFramebuffer(T, T, !0, "renderbuffer"), z.colorAttachment.set(Z.texture); } h.bindFramebuffer.set(z.framebuffer), h.viewport.set([0, 0, T, T]); const { tileBoundsBuffer: R, tileBoundsIndexBuffer: F, tileBoundsSegments: N } = c.getMercatorTileBoundsBuffers(), G = []; c.linearFloatFilteringSupported() && G.push("TERRAIN_DEM_FLOAT_FORMAT"), c.getOrCreateProgram("hillshadePrepare", { defines: G }).draw(c, _.TRIANGLES, Wt.disabled, ci.disabled, bi.unblended, ti.disabled, ((Z, W) => { const te = W.stride, ee = i.ab.mat4.create(); return i.ab.mat4.ortho(ee, 0, i.ag, -i.ag, 0, 0, 1), i.ab.mat4.translate(ee, ee, [0, -i.ag, 0]), { u_matrix: ee, u_image: 1, u_dimension: [te, te], u_zoom: Z.overscaledZ }; })(t.tileID, y), s.id, R, F, N), t.needsHillshadePrepare = !1; } class gn { constructor(t) { this.gl = t.gl, this.default = this.getDefault(), this.current = this.default, this.dirty = !1; } get() { return this.current; } set(t) { } getDefault() { return this.default; } setDefault() { this.set(this.default); } } class Wh extends gn { getDefault() { return i.aj.transparent; } set(t) { const s = this.current; (t.r !== s.r || t.g !== s.g || t.b !== s.b || t.a !== s.a || this.dirty) && (this.gl.clearColor(t.r, t.g, t.b, t.a), this.current = t, this.dirty = !1); } } class $h extends gn { getDefault() { return 1; } set(t) { (t !== this.current || this.dirty) && (this.gl.clearDepth(t), this.current = t, this.dirty = !1); } } class Ql extends gn { getDefault() { return 0; } set(t) { (t !== this.current || this.dirty) && (this.gl.clearStencil(t), this.current = t, this.dirty = !1); } } class ec extends gn { getDefault() { return [!0, !0, !0, !0]; } set(t) { const s = this.current; (t[0] !== s[0] || t[1] !== s[1] || t[2] !== s[2] || t[3] !== s[3] || this.dirty) && (this.gl.colorMask(t[0], t[1], t[2], t[3]), this.current = t, this.dirty = !1); } } class tc extends gn { getDefault() { return !0; } set(t) { (t !== this.current || this.dirty) && (this.gl.depthMask(t), this.current = t, this.dirty = !1); } } class Wc extends gn { getDefault() { return 255; } set(t) { (t !== this.current || this.dirty) && (this.gl.stencilMask(t), this.current = t, this.dirty = !1); } } class $c extends gn { getDefault() { return { func: this.gl.ALWAYS, ref: 0, mask: 255 }; } set(t) { const s = this.current; (t.func !== s.func || t.ref !== s.ref || t.mask !== s.mask || this.dirty) && (this.gl.stencilFunc(t.func, t.ref, t.mask), this.current = t, this.dirty = !1); } } class Xc extends gn { getDefault() { const t = this.gl; return [t.KEEP, t.KEEP, t.KEEP]; } set(t) { const s = this.current; (t[0] !== s[0] || t[1] !== s[1] || t[2] !== s[2] || this.dirty) && (this.gl.stencilOp(t[0], t[1], t[2]), this.current = t, this.dirty = !1); } } class id extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; t ? s.enable(s.STENCIL_TEST) : s.disable(s.STENCIL_TEST), this.current = t, this.dirty = !1; } } class p extends gn { getDefault() { return [0, 1]; } set(t) { const s = this.current; (t[0] !== s[0] || t[1] !== s[1] || this.dirty) && (this.gl.depthRange(t[0], t[1]), this.current = t, this.dirty = !1); } } class A extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; t ? s.enable(s.DEPTH_TEST) : s.disable(s.DEPTH_TEST), this.current = t, this.dirty = !1; } } class B extends gn { getDefault() { return this.gl.LESS; } set(t) { (t !== this.current || this.dirty) && (this.gl.depthFunc(t), this.current = t, this.dirty = !1); } } class X extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; t ? s.enable(s.BLEND) : s.disable(s.BLEND), this.current = t, this.dirty = !1; } } class ne extends gn { getDefault() { const t = this.gl; return [t.ONE, t.ZERO, t.ONE, t.ZERO]; } set(t) { const s = this.current; (t[0] !== s[0] || t[1] !== s[1] || t[2] !== s[2] || t[3] !== s[3] || this.dirty) && (this.gl.blendFuncSeparate(t[0], t[1], t[2], t[3]), this.current = t, this.dirty = !1); } } class ye extends gn { getDefault() { return i.aj.transparent; } set(t) { const s = this.current; (t.r !== s.r || t.g !== s.g || t.b !== s.b || t.a !== s.a || this.dirty) && (this.gl.blendColor(t.r, t.g, t.b, t.a), this.current = t, this.dirty = !1); } } class We extends gn { getDefault() { return this.gl.FUNC_ADD; } set(t) { (t !== this.current || this.dirty) && (this.gl.blendEquationSeparate(t, t), this.current = t, this.dirty = !1); } } class at extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; t ? s.enable(s.CULL_FACE) : s.disable(s.CULL_FACE), this.current = t, this.dirty = !1; } } class ft extends gn { getDefault() { return this.gl.BACK; } set(t) { (t !== this.current || this.dirty) && (this.gl.cullFace(t), this.current = t, this.dirty = !1); } } class Rt extends gn { getDefault() { return this.gl.CCW; } set(t) { (t !== this.current || this.dirty) && (this.gl.frontFace(t), this.current = t, this.dirty = !1); } } let ii = class extends gn { getDefault() { return null; } set(c) { (c !== this.current || this.dirty) && (this.gl.useProgram(c), this.current = c, this.dirty = !1); } }; class Ci extends gn { getDefault() { return this.gl.TEXTURE0; } set(t) { (t !== this.current || this.dirty) && (this.gl.activeTexture(t), this.current = t, this.dirty = !1); } } class Wi extends gn { getDefault() { const t = this.gl; return [0, 0, t.drawingBufferWidth, t.drawingBufferHeight]; } set(t) { const s = this.current; (t[0] !== s[0] || t[1] !== s[1] || t[2] !== s[2] || t[3] !== s[3] || this.dirty) && (this.gl.viewport(t[0], t[1], t[2], t[3]), this.current = t, this.dirty = !1); } } class Hs extends gn { getDefault() { return null; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.bindFramebuffer(s.FRAMEBUFFER, t), this.current = t, this.dirty = !1; } } class ws extends gn { getDefault() { return null; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.bindRenderbuffer(s.RENDERBUFFER, t), this.current = t, this.dirty = !1; } } class Rs extends gn { getDefault() { return null; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.bindTexture(s.TEXTURE_2D, t), this.current = t, this.dirty = !1; } } class ur extends gn { getDefault() { return null; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.bindBuffer(s.ARRAY_BUFFER, t), this.current = t, this.dirty = !1; } } class Za extends gn { getDefault() { return null; } set(t) { const s = this.gl; s.bindBuffer(s.ELEMENT_ARRAY_BUFFER, t), this.current = t, this.dirty = !1; } } class nd extends gn { getDefault() { return null; } set(t) { this.gl && (t !== this.current || this.dirty) && (this.gl.bindVertexArray(t), this.current = t, this.dirty = !1); } } class sd extends gn { getDefault() { return 4; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.pixelStorei(s.UNPACK_ALIGNMENT, t), this.current = t, this.dirty = !1; } } class rd extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.pixelStorei(s.UNPACK_PREMULTIPLY_ALPHA_WEBGL, t), this.current = t, this.dirty = !1; } } class Xh extends gn { getDefault() { return !1; } set(t) { if (t === this.current && !this.dirty) return; const s = this.gl; s.pixelStorei(s.UNPACK_FLIP_Y_WEBGL, t), this.current = t, this.dirty = !1; } } class wl extends gn { constructor(t, s) { super(t), this.context = t, this.parent = s; } getDefault() { return null; } } class ic extends wl { setDirty() { this.dirty = !0; } set(t) { if (t === this.current && !this.dirty) return; this.context.bindFramebuffer.set(this.parent); const s = this.gl; s.framebufferTexture2D(s.FRAMEBUFFER, s.COLOR_ATTACHMENT0, s.TEXTURE_2D, t, 0), this.current = t, this.dirty = !1; } } class es extends wl { attachment() { return this.gl.DEPTH_ATTACHMENT; } set(t) { if (t === this.current && !this.dirty) return; this.context.bindFramebuffer.set(this.parent); const s = this.gl; s.framebufferRenderbuffer(s.FRAMEBUFFER, this.attachment(), s.RENDERBUFFER, t), this.current = t, this.dirty = !1; } } class Ao extends wl { attachment() { return this.gl.DEPTH_ATTACHMENT; } set(t) { if (t === this.current && !this.dirty) return; this.context.bindFramebuffer.set(this.parent); const s = this.gl; s.framebufferTexture2D(s.FRAMEBUFFER, this.attachment(), s.TEXTURE_2D, t, 0), this.current = t, this.dirty = !1; } } class Yh extends es { attachment() { return this.gl.DEPTH_STENCIL_ATTACHMENT; } } const Kh = (c, t, s) => ({ u_matrix: c, u_image0: 0, u_skirt_height: t, u_ground_shadow_factor: s }), Yc = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee) => ({ u_proj_matrix: Float32Array.from(c), u_globe_matrix: t, u_normalize_matrix: Float32Array.from(h), u_merc_matrix: s, u_zoom_transition: _, u_merc_center: y, u_image0: 0, u_frustum_tl: T, u_frustum_tr: z, u_frustum_br: R, u_frustum_bl: F, u_globe_pos: N, u_globe_radius: G, u_viewport: Z, u_grid_matrix: ee ? Float32Array.from(ee) : new Float32Array(9), u_skirt_height: W, u_far_z_cutoff: te }); function Ha(c, t) { return c != null && t != null && !(!c.hasData() || !t.hasData()) && c.demTexture != null && t.demTexture != null && c.tileID.key !== t.tileID.key; } const vr = new class { constructor() { this.operations = {}; } newMorphing(c, t, s, h, _) { if (c in this.operations) { const y = this.operations[c]; y.to.tileID.key !== s.tileID.key && (y.queued = s); } else this.operations[c] = { startTime: h, phase: 0, duration: _, from: t, to: s, queued: null }; } getMorphValuesForProxy(c) { if (!(c in this.operations)) return null; const t = this.operations[c]; return { from: t.from, to: t.to, phase: t.phase }; } update(c) { for (const t in this.operations) { const s = this.operations[t]; for (s.phase = (c - s.startTime) / s.duration; s.phase >= 1 || !this._validOp(s); ) if (!this._nextOp(s, c)) { delete this.operations[t]; break; } } } _nextOp(c, t) { return !!c.queued && (c.from = c.to, c.to = c.queued, c.queued = null, c.phase = 0, c.startTime = t, !0); } _validOp(c) { return c.from.hasData() && c.to.hasData(); } }(), Kc = { 0: null, 1: "TERRAIN_VERTEX_MORPHING" }; function xa(c, t, s) { if (t === 0) return 0; const h = t < 1 && s === 514 ? 0.25 / t : 1; return 6 * Math.pow(1.5, 22 - c) * Math.max(t, 1) * h; } function od(c, t) { const s = 1 << c.z; return !t && (c.x === 0 || c.x === s - 1) || c.y === 0 || c.y === s - 1; } const nc = (c) => ({ u_matrix: c }); function Jh(c, t, s, h, _) { if (_ > 0) { const y = i.q.now(), T = (y - c.timeAdded) / _, z = t ? (y - t.timeAdded) / _ : -1, R = s.getSource(), F = h.coveringZoomLevel({ tileSize: R.tileSize, roundZoom: R.roundZoom }), N = !t || Math.abs(t.tileID.overscaledZ - F) > Math.abs(c.tileID.overscaledZ - F), G = N && c.refreshedUponExpiration ? 1 : i.aw(N ? T : 1 - z, 0, 1); return c.refreshedUponExpiration && T >= 1 && (c.refreshedUponExpiration = !1), t ? { opacity: 1, mix: 1 - G } : { opacity: G, mix: 0 }; } return { opacity: 1, mix: 0 }; } class qf extends sr { constructor(t) { const s = { type: "raster-dem", maxzoom: t.transform.maxZoom }, h = new i.D(i.ci(), null), _ = Go("mock-dem", s, h, t.style); super("mock-dem", _, !1), _.setEventedParent(this), this._sourceLoaded = !0; } _loadTile(t, s) { t.state = "loaded", s(null); } } class ad extends sr { constructor(t) { const s = Go("proxy", { type: "geojson", maxzoom: t.transform.maxZoom }, new i.D(i.ci(), null), t.style); super("proxy", s, !1), s.setEventedParent(this), this.map = this.getSource().map = t, this.used = this._sourceLoaded = !0, this.renderCache = [], this.renderCachePool = [], this.proxyCachedFBO = {}; } update(t, s, h) { if (t.freezeTileCoverage) return; this.transform = t; const _ = t.coveringTiles({ tileSize: this._source.tileSize, minzoom: this._source.minzoom, maxzoom: this._source.maxzoom, roundZoom: this._source.roundZoom, reparseOverscaled: this._source.reparseOverscaled }).reduce((y, T) => { if (y[T.key] = "", !this._tiles[T.key]) { const z = new Cr(T, this._source.tileSize * T.overscaleFactor(), t.tileZoom); z.state = "loaded", this._tiles[T.key] = z; } return y; }, {}); for (const y in this._tiles) y in _ || (this.freeFBO(y), this._tiles[y].unloadVectorData(), delete this._tiles[y]); } freeFBO(t) { const s = this.proxyCachedFBO[t]; if (s !== void 0) { const h = Object.values(s); this.renderCachePool.push(...h), delete this.proxyCachedFBO[t]; } } deallocRenderCache() { this.renderCache.forEach((t) => t.fb.destroy()), this.renderCache = [], this.renderCachePool = [], this.proxyCachedFBO = {}; } } class Qh extends i.aG { constructor(t, s, h) { super(t.overscaledZ, t.wrap, t.canonical.z, t.canonical.x, t.canonical.y), this.proxyTileKey = s, this.projMatrix = h; } } class Wf extends i.cJ { constructor(t, s) { super(), this._debugParams = { sortTilesHiZFirst: !0, disableRenderCache: !1 }, t.tp.registerParameter(this._debugParams, ["Terrain"], "sortTilesHiZFirst", {}, () => { this._style.map.triggerRepaint(); }), t.tp.registerParameter(this._debugParams, ["Terrain"], "disableRenderCache", {}, () => { this._style.map.triggerRepaint(); }), t.tp.registerButton(["Terrain"], "Invalidate Render Cache", () => { this.invalidateRenderCache = !0, this._style.map.triggerRepaint(); }), this.painter = t, this.terrainTileForTile = {}, this.prevTerrainTileForTile = {}; const [h, _, y] = function(R) { const F = new i.b4(), N = new i.aU(), G = 131; F.reserve(17161), N.reserve(33800); const Z = i.ag / 128, W = i.ag + Z / 2, te = W + Z; for (let se = -Z; se < te; se += Z) for (let oe = -Z; oe < te; oe += Z) { const he = oe < 0 || oe > W || se < 0 || se > W ? 24575 : 0, _e = i.aw(Math.round(oe), 0, i.ag), pe = i.aw(Math.round(se), 0, i.ag); F.emplaceBack(_e + he, pe); } const ee = (se, oe) => { const he = oe * G + se; N.emplaceBack(he + 1, he, he + G), N.emplaceBack(he + G, he + G + 1, he + 1); }; for (let se = 1; se < 129; se++) for (let oe = 1; oe < 129; oe++) ee(oe, se); return [0, 129].forEach((se) => { for (let oe = 0; oe < 130; oe++) ee(oe, se), ee(se, oe); }), [F, N, 32768]; }(), T = t.context; this.gridBuffer = T.createVertexBuffer(h, i.b6.members), this.gridIndexBuffer = T.createIndexBuffer(_), this.gridSegments = i.b7.simpleSegment(0, 0, h.length, _.length), this.gridNoSkirtSegments = i.b7.simpleSegment(0, 0, h.length, y), this.proxyCoords = [], this.proxiedCoords = {}, this._visibleDemTiles = [], this._drapedRenderBatches = [], this._sourceTilesOverlap = {}, this.proxySourceCache = new ad(s.map), this.orthoMatrix = i.ab.mat4.create(), i.ab.mat4.ortho(this.orthoMatrix, this.painter.transform.projection.name === "globe" ? 0.015 : 0, i.ag, 0, i.ag, 0, 1); const z = T.gl; this._overlapStencilMode = new ci({ func: z.GEQUAL, mask: 255 }, 0, 255, z.KEEP, z.KEEP, z.REPLACE), this._previousZoom = t.transform.zoom, this.pool = [], this._findCoveringTileCache = {}, this._tilesDirty = {}, this.style = s, this._useVertexMorphing = !0, this._exaggeration = 1, this._mockSourceCache = new qf(s.map), this._pendingGroundEffectLayers = []; } set style(t) { t.on("data", this._onStyleDataEvent.bind(this)), this._style = t, this._style.map.on("moveend", () => { this._clearLineLayersFromRenderCache(); }); } update(t, s, h) { if (t && t.terrain) { this._style !== t && (this.style = t, this._evaluationZoom = void 0); const _ = t.terrain.properties, y = t.terrain.drapeRenderMode === 0, T = t.terrain.isZoomDependent(); this._previousUpdateTimestamp = this.enabled ? this._updateTimestamp : void 0, this._updateTimestamp = i.q.now(); const z = t.terrain && t.terrain.scope, R = _.get("source"), F = y ? this._mockSourceCache : t.getSourceCache(R, z); if (!F) return void i.w(`Couldn't find terrain source "${R}".`); if (this.sourceCache = F, this._attenuationRange = t.terrain.getAttenuationRange(), this._exaggeration = T ? this.calculateExaggeration(s) : _.get("exaggeration"), !s.projection.requiresDraping && T && this._exaggeration === 0) return void this._disable(); this.enabled = !0; const N = () => { this.sourceCache.used && i.w(`Raster DEM source '${this.sourceCache.id}' is used both for terrain and as layer source. This leads to lower resolution of hillshade. For full hillshade resolution but higher memory consumption, define another raster DEM source.`); const G = this.getScaledDemTileSize(); this.sourceCache.update(s, G, !0), this.resetTileLookupCache(this.sourceCache.id); }; this.sourceCache.usedForTerrain || (this.resetTileLookupCache(this.sourceCache.id), this.sourceCache.usedForTerrain = !0, N(), this._initializing = !0), N(), s.updateElevation(!0, h), this.resetTileLookupCache(this.proxySourceCache.id), this.proxySourceCache.update(s), this._emptyDEMTextureDirty = !0, this._previousZoom = s.zoom; } else this._disable(); } calculateExaggeration(t) { if (this._attenuationRange && t.zoom >= Math.ceil(this._attenuationRange[1])) return this._style.terrain.getExaggeration(t.zoom); const s = this._previousCameraAltitude, h = t.getFreeCameraOptions().position.z / t.pixelsPerMeter * t.worldSize; this._previousCameraAltitude = h; const _ = s != null ? h - s : Number.MAX_VALUE; if (Math.abs(_) < 2) return this._exaggeration; const y = t.zoom, T = this._style.terrain; if (!this._previousUpdateTimestamp) return T.getExaggeration(y); let z = y - this._previousZoom; const R = this._previousUpdateTimestamp; let F = y; this._evaluationZoom != null && (F = this._evaluationZoom, Math.abs(y - F) > 0.5 && (z = 0.5 * (y - F + z)), z * _ < 0 && (F += z)), this._evaluationZoom = F; const N = T.getExaggeration(F), G = N === T.getExaggeration(Math.max(0, F - 0.1)); if (G && Math.abs(N - this._exaggeration) < 0.01) return N; let Z = Math.min(0.1, 375e-5 * (this._updateTimestamp - R)); return (G || N < 0.1 || Math.abs(z) < 1e-4) && (Z = Math.min(0.2, 4 * Z)), i.af(this._exaggeration, N, Z); } resetTileLookupCache(t) { this._findCoveringTileCache[t] = {}; } attenuationRange() { return this._attenuationRange; } getDemUpscale() { return this.proxySourceCache.getSource().tileSize / 128; } getScaledDemTileSize() { return this.sourceCache.getSource().tileSize / 128 * this.proxySourceCache.getSource().tileSize; } _onStyleDataEvent(t) { t.coord && t.dataType === "source" ? this._clearRenderCacheForTile(t.sourceCacheId, t.coord) : t.dataType === "style" && (this.invalidateRenderCache = !0, this._evaluationZoom = void 0, this._previousUpdateTimestamp = void 0, this._previousCameraAltitude = void 0); } _disable() { if (this.enabled && (this.enabled = !1, this._emptyDEMTextureDirty = !0, this._sharedDepthStencil = void 0, this._evaluationZoom = void 0, this._previousUpdateTimestamp = void 0, this.proxySourceCache.deallocRenderCache(), this._style)) for (const t in this._style._mergedSourceCaches) this._style._mergedSourceCaches[t].usedForTerrain = !1; } destroy() { this._disable(), this._emptyDEMTexture && this._emptyDEMTexture.destroy(), this.pool.forEach((t) => t.fb.destroy()), this.pool = [], this.framebufferCopyTexture && this.framebufferCopyTexture.destroy(); } _source() { return this.enabled ? this.sourceCache : null; } isUsingMockSource() { return this.sourceCache === this._mockSourceCache; } exaggeration() { return this.enabled ? this._exaggeration : 0; } get visibleDemTiles() { return this._visibleDemTiles; } get drapeBufferSize() { const t = 2 * this.proxySourceCache.getSource().tileSize; return [t, t]; } set useVertexMorphing(t) { this._useVertexMorphing = t; } updateTileBinding(t) { if (!this.enabled) return; this.prevTerrainTileForTile = this.terrainTileForTile; const s = this.proxySourceCache, h = this.painter.transform; this._initializing && (this._initializing = h._centerAltitude === 0 && this.getAtPointOrZero(i.aa.fromLngLat(h.center), -1) === -1, this._emptyDEMTextureDirty = !this._initializing); const _ = this.proxyCoords = s.getIds().map((R) => { const F = s.getTileByID(R).tileID; return F.projMatrix = h.calculateProjMatrix(F.toUnwrapped()), F; }); (function(R, F) { const N = F.transform.pointCoordinate(F.transform.getCameraPoint()), G = new i.P(N.x, N.y); R.sort((Z, W) => { if (W.overscaledZ - Z.overscaledZ) return W.overscaledZ - Z.overscaledZ; const te = new i.P(Z.canonical.x + (1 << Z.canonical.z) * Z.wrap, Z.canonical.y), ee = new i.P(W.canonical.x + (1 << W.canonical.z) * W.wrap, W.canonical.y), se = G.mult(1 << Z.canonical.z); return se.x -= 0.5, se.y -= 0.5, se.distSqr(te) - se.distSqr(ee); }); })(_, this.painter); const y = this.proxyToSource || {}; this.proxyToSource = {}, _.forEach((R) => { this.proxyToSource[R.key] = {}; }), this.terrainTileForTile = {}; const T = this._style._mergedSourceCaches; for (const R in T) { const F = T[R]; if (!F.used || (F !== this.sourceCache && this.resetTileLookupCache(F.id), this._setupProxiedCoordsForOrtho(F, t[R], y), F.usedForTerrain)) continue; const N = t[R]; F.getSource().reparseOverscaled && this._assignTerrainTiles(N); } this.proxiedCoords[s.id] = _.map((R) => new Qh(R, R.key, this.orthoMatrix)), this._assignTerrainTiles(_), this._prepareDEMTextures(), this._setupDrapedRenderBatches(), this._initFBOPool(), this._setupRenderCache(y), this.renderingToTexture = !1; const z = {}; this._visibleDemTiles = []; for (const R of this.proxyCoords) { const F = this.terrainTileForTile[R.key]; if (!F) continue; const N = F.tileID.key; N in z || (this._visibleDemTiles.push(F), z[N] = N); } } _assignTerrainTiles(t) { this._initializing || t.forEach((s) => { if (this.terrainTileForTile[s.key]) return; const h = this._findTileCoveringTileID(s, this.sourceCache); h && (this.terrainTileForTile[s.key] = h); }); } _prepareDEMTextures() { const t = this.painter.context, s = t.gl; for (const h in this.terrainTileForTile) { const _ = this.terrainTileForTile[h], y = _.dem; !y || _.demTexture && !_.needsDEMTextureUpload || (t.activeTexture.set(s.TEXTURE1), Qo(this.painter, _, y)); } } _prepareDemTileUniforms(t, s, h, _) { if (!s || s.demTexture == null) return !1; const y = t.tileID.canonical, T = Math.pow(2, s.tileID.canonical.z - y.z), z = _ || ""; return h[`u_dem_tl${z}`] = [y.x * T % 1, y.y * T % 1], h[`u_dem_scale${z}`] = T, !0; } get emptyDEMTexture() { return !this._emptyDEMTextureDirty && this._emptyDEMTexture ? this._emptyDEMTexture : this._updateEmptyDEMTexture(); } _getLoadedAreaMinimum() { if (!this.enabled) return 0; let t = 0; const s = this._visibleDemTiles.reduce((h, _) => { if (!_.dem) return h; const y = _.dem.tree.minimums[0]; return y > 0 && t++, h + y; }, 0); return t ? s / t : 0; } _updateEmptyDEMTexture() { const t = this.painter.context, s = t.gl; t.activeTexture.set(s.TEXTURE2); const h = this._getLoadedAreaMinimum(), _ = new i.cK({ width: 1, height: 1 }, new Float32Array([h])); this._emptyDEMTextureDirty = !1; let y = this._emptyDEMTexture; return y ? y.update(_, { premultiply: !1 }) : y = this._emptyDEMTexture = new i.T(t, _, s.R32F, { premultiply: !1 }), y; } setupElevationDraw(t, s, h) { const _ = this.painter.context, y = _.gl, T = { u_dem: 2, u_dem_prev: 4, 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_depth_range_unpack: [0, 1], u_occluder_half_size: 16, u_occlusion_depth_offset: -1e-4, u_exaggeration: 0 }; T.u_exaggeration = this.exaggeration(); let z = null, R = null, F = 1; if (h && h.morphing && this._useVertexMorphing) { const W = h.morphing.srcDemTile, te = h.morphing.dstDemTile; F = h.morphing.phase, W && te && (this._prepareDemTileUniforms(t, W, T, "_prev") && (R = W), this._prepareDemTileUniforms(t, te, T) && (z = te)); } const N = (W) => W && W.demTexture && this.painter.linearFloatFilteringSupported() ? y.LINEAR : y.NEAREST; let G = null; var Z; if (this.enabled ? R && z ? (G = z.demTexture, _.activeTexture.set(y.TEXTURE4), R.demTexture.bind(N(R), y.CLAMP_TO_EDGE), T.u_dem_lerp = F) : (z = this.terrainTileForTile[t.tileID.key], G = this._prepareDemTileUniforms(t, z, T) ? z.demTexture : this.emptyDEMTexture) : G = this.emptyDEMTexture, _.activeTexture.set(y.TEXTURE2), G && (T.u_dem_size = (Z = G).size[0] === 1 ? 1 : Z.size[0] - 2, G.bind(N(z), y.CLAMP_TO_EDGE)), this.painter.setupDepthForOcclusion(h && h.useDepthForOcclusion, s, T), h && h.useMeterToDem && z) { const W = (1 << z.tileID.canonical.z) * i.bH(1, this.painter.transform.center.lat) * this.sourceCache.getSource().tileSize; T.u_meter_to_dem = W; } if (h && h.labelPlaneMatrixInv && (T.u_label_plane_matrix_inv = h.labelPlaneMatrixInv), s.setTerrainUniformValues(_, T), this.painter.transform.projection.name === "globe") { const W = this.globeUniformValues(this.painter.transform, t.tileID.canonical, h && h.useDenormalizedUpVectorScale); s.setGlobeUniformValues(_, W); } } globeUniformValues(t, s, h) { const _ = t.projection; return { u_tile_tl_up: _.upVector(s, 0, 0), u_tile_tr_up: _.upVector(s, i.ag, 0), u_tile_br_up: _.upVector(s, i.ag, i.ag), u_tile_bl_up: _.upVector(s, 0, i.ag), u_tile_up_scale: h ? i.cL(1) : _.upVectorScale(s, t.center.lat, t.worldSize).metersToTile }; } renderToBackBuffer(t) { const s = this.painter, h = this.painter.context; t.length !== 0 && (h.bindFramebuffer.set(null), h.viewport.set([0, 0, s.width, s.height]), s.gpuTimingDeferredRenderStart(), this.renderingToTexture = !1, function(_, y, T, z, R) { if (_.transform.projection.name === "globe") (function(F, N, G, Z, W) { const te = F.context, ee = te.gl; let se, oe; const he = F.transform, _e = i.cC(F, te, he), pe = (ke, Ne) => { if (oe === Ne) return; const st = [Kc[Ne], "PROJECTION_GLOBE_VIEW"]; _e && st.push("CUSTOM_ANTIALIASING"); const ut = F.isTileAffectedByFog(ke); se = F.getOrCreateProgram("globeRaster", { defines: st, overrideFog: ut }), oe = Ne; }, Me = F.colorModeForRenderPass(), xe = new Wt(ee.LEQUAL, Wt.ReadWrite, F.depthRangeFor3D); vr.update(W); const we = i.cD(he), ve = [i.at(he.center.lng), i.aA(he.center.lat)], Ae = F.globeSharedBuffers, Oe = [he.width * i.q.devicePixelRatio, he.height * i.q.devicePixelRatio], Xe = Float32Array.from(he.globeMatrix), He = { useDenormalizedUpVectorScale: !0 }; { const ke = F.transform, Ne = xa(ke.zoom, N.exaggeration(), N.sourceCache._source.tileSize); oe = -1; const st = ee.TRIANGLES; for (const ut of Z) { const xt = G.getTile(ut), Ge = ci.disabled, lt = N.prevTerrainTileForTile[ut.key], Je = N.terrainTileForTile[ut.key]; Ha(lt, Je) && vr.newMorphing(ut.key, lt, Je, W, 250), te.activeTexture.set(ee.TEXTURE0), xt.texture && xt.texture.bind(ee.LINEAR, ee.CLAMP_TO_EDGE); const _t = vr.getMorphValuesForProxy(ut.key), ct = _t ? 1 : 0; _t && i.J(He, { morphing: { srcDemTile: _t.from, dstDemTile: _t.to, phase: i.cB(_t.phase) } }); const nt = i.cE(ut.canonical), Lt = i.cF(nt.getCenter().lat), bt = i.cG(ut.canonical, nt, Lt, ke.worldSize / ke._pixelsPerMercatorPixel), zt = i.bb(i.cH(ut.canonical)), Bt = Yc(ke.expandedFarZProjMatrix, Xe, we, zt, i.ae(ke.zoom), ve, ke.frustumCorners.TL, ke.frustumCorners.TR, ke.frustumCorners.BR, ke.frustumCorners.BL, ke.globeCenterInViewSpace, ke.globeRadius, Oe, Ne, ke._farZ, bt); if (pe(ut, ct), se && (N.setupElevationDraw(xt, se, He), F.uploadCommonUniforms(te, se, ut.toUnwrapped()), Ae)) { const [oi, $t, Xt] = Ae.getGridBuffers(Lt, Ne !== 0); se.draw(F, st, xe, Ge, Me, ti.backCCW, Bt, "globe_raster", oi, $t, Xt); } } } if (Ae && (F.renderDefaultNorthPole || F.renderDefaultSouthPole)) { const ke = ["GLOBE_POLES", "PROJECTION_GLOBE_VIEW"]; _e && ke.push("CUSTOM_ANTIALIASING"), se = F.getOrCreateProgram("globeRaster", { defines: ke }); for (const Ne of Z) { const { x: st, y: ut, z: xt } = Ne.canonical, Ge = ut === 0, lt = ut === (1 << xt) - 1, [Je, _t, ct, nt] = Ae.getPoleBuffers(xt, !1); if (nt && (Ge || lt)) { const Lt = G.getTile(Ne); te.activeTexture.set(ee.TEXTURE0), Lt.texture && Lt.texture.bind(ee.LINEAR, ee.CLAMP_TO_EDGE); let bt = i.cI(xt, st, he); const zt = i.bb(i.cH(Ne.canonical)), Bt = (oi, $t) => oi.draw(F, ee.TRIANGLES, xe, ci.disabled, Me, ti.disabled, Yc(he.expandedFarZProjMatrix, bt, bt, zt, 0, ve, he.frustumCorners.TL, he.frustumCorners.TR, he.frustumCorners.BR, he.frustumCorners.BL, he.globeCenterInViewSpace, he.globeRadius, Oe, 0, he._farZ), "globe_pole_raster", $t, ct, nt); N.setupElevationDraw(Lt, se, He), F.uploadCommonUniforms(te, se, Ne.toUnwrapped()), Ge && F.renderDefaultNorthPole && Bt(se, Je), lt && F.renderDefaultSouthPole && (bt = i.ab.mat4.scale(i.ab.mat4.create(), bt, [1, -1, 1]), Bt(se, _t)); } } } })(_, y, T, z, R); else { const F = _.context, N = F.gl; let G, Z; const W = _.shadowRenderer, te = Mo(_, _.longestCutoffRange), ee = (Me) => { if (Z === Me) return; const xe = []; xe.push(Kc[Me]), te.shouldRenderCutoff && xe.push("RENDER_CUTOFF"), W && (xe.push("RENDER_SHADOWS", "DEPTH_TEXTURE"), W.useNormalOffset && xe.push("NORMAL_OFFSET")), G = _.getOrCreateProgram("terrainRaster", { defines: xe }), Z = Me; }, se = _.colorModeForRenderPass(), oe = new Wt(N.LEQUAL, Wt.ReadWrite, _.depthRangeFor3D); vr.update(R); const he = _.transform, _e = xa(he.zoom, y.exaggeration(), y.sourceCache._source.tileSize); let pe = [0, 0, 0]; if (W) { const Me = _.style.directionalLight, xe = _.style.ambientLight; Me && xe && (pe = cr(_.style, Me, xe)); } { Z = -1; const Me = N.TRIANGLES, [xe, we] = [y.gridIndexBuffer, y.gridSegments]; for (const ve of z) { const Ae = T.getTile(ve), Oe = ci.disabled, Xe = y.prevTerrainTileForTile[ve.key], He = y.terrainTileForTile[ve.key]; Ha(Xe, He) && vr.newMorphing(ve.key, Xe, He, R, 250), F.activeTexture.set(N.TEXTURE0), Ae.texture && Ae.texture.bind(N.LINEAR, N.CLAMP_TO_EDGE); const ke = vr.getMorphValuesForProxy(ve.key), Ne = ke ? 1 : 0; let st; ke && (st = { morphing: { srcDemTile: ke.from, dstDemTile: ke.to, phase: i.cB(ke.phase) } }); const ut = Kh(ve.projMatrix, od(ve.canonical, he.renderWorldCopies) ? _e / 10 : _e, pe); if (ee(Ne), !G) continue; y.setupElevationDraw(Ae, G, st); const xt = ve.toUnwrapped(); W && W.setupShadows(xt, G), _.uploadCommonUniforms(F, G, xt, null, te), G.draw(_, Me, oe, Oe, se, ti.backCCW, ut, "terrain_raster", y.gridBuffer, xe, we); } } } }(s, this, this.proxySourceCache, t, this._updateTimestamp), this.renderingToTexture = !0, s.gpuTimingDeferredRenderEnd(), t.splice(0, t.length)); } renderBatch(t) { if (this._drapedRenderBatches.length === 0) return t + 1; this.renderingToTexture = !0; const s = this.painter, h = this.painter.context, _ = this.proxySourceCache, y = this.proxiedCoords[_.id], T = this._drapedRenderBatches.shift(), z = s.style.order, R = []; let F = 0; for (const N of y) { const G = _.getTileByID(N.proxyTileKey), Z = _.proxyCachedFBO[N.key] ? _.proxyCachedFBO[N.key][t] : void 0, W = Z !== void 0 ? _.renderCache[Z] : this.pool[F++], te = Z !== void 0; if (G.texture = W.tex, te && !W.dirty) { R.push(G.tileID); continue; } let ee; h.bindFramebuffer.set(W.fb.framebuffer), this.renderedToTile = !1, W.dirty && (h.clear({ color: i.aj.transparent, stencil: 0 }), W.dirty = !1); for (let se = T.start; se <= T.end; ++se) { const oe = s.style._mergedLayers[z[se]]; if (oe.isHidden(s.transform.zoom)) continue; const he = s.style.getLayerSourceCache(oe), _e = he ? this.proxyToSource[N.key][he.id] : [N]; if (!_e) continue; const pe = _e; h.viewport.set([0, 0, W.fb.width, W.fb.height]), ee !== (he ? he.id : null) && (this._setupStencil(W, _e, oe, he), ee = he ? he.id : null), s.renderLayer(s, he, oe, pe); } if (this._drapedRenderBatches.length === 0) for (const se of this._pendingGroundEffectLayers) { const oe = s.style._mergedLayers[z[se]]; if (oe.isHidden(s.transform.zoom)) continue; const he = s.style.getLayerSourceCache(oe), _e = he ? this.proxyToSource[N.key][he.id] : [N]; if (!_e) continue; const pe = _e; h.viewport.set([0, 0, W.fb.width, W.fb.height]), ee !== (he ? he.id : null) && (this._setupStencil(W, _e, oe, he), ee = he ? he.id : null), s.renderLayer(s, he, oe, pe); } this.renderedToTile ? (W.dirty = !0, R.push(G.tileID)) : te || --F, F === 5 && (F = 0, this.renderToBackBuffer(R)); } return this.renderToBackBuffer(R), this.renderingToTexture = !1, h.bindFramebuffer.set(null), h.viewport.set([0, 0, s.width, s.height]), T.end + 1; } postRender() { } isLayerOrderingCorrect(t) { const s = t.order.length; let h = -1, _ = s; for (let y = 0; y < s; ++y) this._style.isLayerDraped(t._mergedLayers[t.order[y]]) ? h = Math.max(h, y) : _ = Math.min(_, y); return _ > h; } getMinElevationBelowMSL() { let t = 0; return this._visibleDemTiles.filter((s) => s.dem).forEach((s) => { t = Math.min(t, s.dem.tree.minimums[0]); }), t === 0 ? t : (t - 30) * this._exaggeration; } raycast(t, s, h) { if (!this._visibleDemTiles) return null; const _ = this._visibleDemTiles.filter((y) => y.dem).map((y) => { const T = y.tileID, z = 1 << T.overscaledZ, { x: R, y: F } = T.canonical, N = R / z, G = (R + 1) / z, Z = F / z, W = (F + 1) / z; return { minx: N, miny: Z, maxx: G, maxy: W, t: y.dem.tree.raycastRoot(N, Z, G, W, t, s, h), tile: y }; }); _.sort((y, T) => (y.t !== null ? y.t : Number.MAX_VALUE) - (T.t !== null ? T.t : Number.MAX_VALUE)); for (const y of _) { if (y.t == null) return null; const T = y.tile.dem.tree.raycast(y.minx, y.miny, y.maxx, y.maxy, t, s, h); if (T != null) return T; } return null; } _createFBO() { const t = this.painter.context, s = t.gl, h = this.drapeBufferSize; t.activeTexture.set(s.TEXTURE0); const _ = new i.T(t, { width: h[0], height: h[1], data: null }, s.RGBA8); _.bind(s.LINEAR, s.CLAMP_TO_EDGE); const y = t.createFramebuffer(h[0], h[1], !0, null); return y.colorAttachment.set(_.texture), y.depthAttachment = new Yh(t, y.framebuffer), this._sharedDepthStencil === void 0 ? (this._sharedDepthStencil = t.createRenderbuffer(t.gl.DEPTH_STENCIL, h[0], h[1]), this._stencilRef = 0, y.depthAttachment.set(this._sharedDepthStencil), t.clear({ stencil: 0 })) : y.depthAttachment.set(this._sharedDepthStencil), t.extTextureFilterAnisotropic && s.texParameterf(s.TEXTURE_2D, t.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, t.extTextureFilterAnisotropicMax), { fb: y, tex: _, dirty: !1 }; } _initFBOPool() { for (; this.pool.length < Math.min(5, this.proxyCoords.length); ) this.pool.push(this._createFBO()); } _shouldDisableRenderCache() { if (this._debugParams.disableRenderCache || this._style.hasLightTransitions()) return !0; for (const t in this._style._mergedSourceCaches) if (this._style._mergedSourceCaches[t].hasTransition()) return !0; return this._style.order.some((t) => { const s = this._style._mergedLayers[t], h = s.isHidden(this.painter.transform.zoom); return s.type === "hillshade" || s.type === "custom" ? !h && s.shouldRedrape() : !h && s.hasTransition(); }); } _clearLineLayersFromRenderCache() { let t = !1; for (const h of this._style.getSources()) if (h instanceof jo) { t = !0; break; } if (!t) return; const s = {}; for (let h = 0; h < this._style.order.length; ++h) { const _ = this._style._mergedLayers[this._style.order[h]], y = this._style.getLayerSourceCache(_); if (y && !s[y.id] && !_.isHidden(this.painter.transform.zoom) && _.type === "line" && _.widthExpression() instanceof i.a9) { s[y.id] = !0; for (const T of this.proxyCoords) { const z = this.proxyToSource[T.key][y.id]; if (z) for (const R of z) this._clearRenderCacheForTile(y.id, R); } } } } _clearRasterLayersFromRenderCache() { let t = !1; for (const h in this._style._mergedSourceCaches) if (this._style._mergedSourceCaches[h]._source instanceof tn) { t = !0; break; } if (!t) return; const s = {}; for (let h = 0; h < this._style.order.length; ++h) { const _ = this._style._mergedLayers[this._style.order[h]], y = this._style.getLayerSourceCache(_); if (!y || s[y.id] || _.isHidden(this.painter.transform.zoom) || _.type !== "raster") continue; const T = _.paint.get("raster-fade-duration"); for (const z of this.proxyCoords) { const R = this.proxyToSource[z.key][y.id]; if (R) for (const F of R) { const N = Jh(y.getTile(F), y.findLoadedParent(F, 0), y, this.painter.transform, T); (N.opacity !== 1 || N.mix !== 0) && this._clearRenderCacheForTile(y.id, F); } } } } _setupDrapedRenderBatches() { this._style.updateDrapeFirstLayers(); const t = this._style.order, s = t.length; if (s === 0) return; const h = []; this._pendingGroundEffectLayers = []; let _, y = 0, T = this._style._mergedLayers[t[y]]; for (; !this._style.isLayerDraped(T) && T.isHidden(this.painter.transform.zoom) && ++y < s; ) T = this._style._mergedLayers[t[y]]; for (; y < s; ++y) { const z = this._style._mergedLayers[t[y]]; z.isHidden(this.painter.transform.zoom) || (this._style.isLayerDraped(z) ? _ === void 0 && (_ = y) : (z.type === "fill-extrusion" && this._pendingGroundEffectLayers.push(y), _ !== void 0 && (h.push({ start: _, end: y - 1 }), _ = void 0))); } if (_ !== void 0 && h.push({ start: _, end: y - 1 }), h.length !== 0) { const z = h[h.length - 1]; this._pendingGroundEffectLayers.every((R) => R > z.end) || i.w("fill-extrusion with flood lighting and/or ground ambient occlusion should be moved to be on top of all draped layers."); } this._drapedRenderBatches = h; } _setupRenderCache(t) { const s = this.proxySourceCache; if (this._shouldDisableRenderCache() || this.invalidateRenderCache) { if (this.invalidateRenderCache = !1, s.renderCache.length > s.renderCachePool.length) { const T = Object.values(s.proxyCachedFBO); s.proxyCachedFBO = {}; for (let z = 0; z < T.length; ++z) { const R = Object.values(T[z]); s.renderCachePool.push(...R); } } return; } this._clearRasterLayersFromRenderCache(); const h = this.proxyCoords, _ = this._tilesDirty; for (let T = h.length - 1; T >= 0; T--) { const z = h[T]; if (s.getTileByID(z.key), s.proxyCachedFBO[z.key] !== void 0) { const R = t[z.key], F = this.proxyToSource[z.key]; let N = 0; for (const G in F) { const Z = F[G], W = R[G]; if (!W || W.length !== Z.length || Z.some((te, ee) => te !== W[ee] || _[G] && _[G].hasOwnProperty(te.key))) { N = -1; break; } ++N; } for (const G in s.proxyCachedFBO[z.key]) s.renderCache[s.proxyCachedFBO[z.key][G]].dirty = N < 0 || N !== Object.values(R).length; } } const y = [...this._drapedRenderBatches]; y.sort((T, z) => z.end - z.start - (T.end - T.start)); for (const T of y) for (const z of h) { if (s.proxyCachedFBO[z.key]) continue; let R = s.renderCachePool.pop(); R === void 0 && s.renderCache.length < 50 && (R = s.renderCache.length, s.renderCache.push(this._createFBO())), R !== void 0 && (s.proxyCachedFBO[z.key] = {}, s.proxyCachedFBO[z.key][T.start] = R, s.renderCache[R].dirty = !0); } this._tilesDirty = {}; } _setupStencil(t, s, h, _) { if (!_ || !this._sourceTilesOverlap[_.id]) return void (this._overlapStencilType && (this._overlapStencilType = !1)); const y = this.painter.context, T = y.gl; if (s.length <= 1) return void (this._overlapStencilType = !1); let z; if (h.isTileClipped()) z = s.length, this._overlapStencilMode.test = { func: T.EQUAL, mask: 255 }, this._overlapStencilType = "Clip"; else { if (!(s[0].overscaledZ > s[s.length - 1].overscaledZ)) return void (this._overlapStencilType = !1); z = 1, this._overlapStencilMode.test = { func: T.GREATER, mask: 255 }, this._overlapStencilType = "Mask"; } this._stencilRef + z > 255 && (y.clear({ stencil: 0 }), this._stencilRef = 0), this._stencilRef += z, this._overlapStencilMode.ref = this._stencilRef, h.isTileClipped() && this._renderTileClippingMasks(s, this._overlapStencilMode.ref); } clipOrMaskOverlapStencilType() { return this._overlapStencilType === "Clip" || this._overlapStencilType === "Mask"; } stencilModeForRTTOverlap(t) { return this.renderingToTexture && this._overlapStencilType ? (this._overlapStencilType === "Clip" && (this._overlapStencilMode.ref = this.painter._tileClippingMaskIDs[t.key]), this._overlapStencilMode) : ci.disabled; } _renderTileClippingMasks(t, s) { const h = this.painter, _ = this.painter.context, y = _.gl; h._tileClippingMaskIDs = {}, _.setColorMode(bi.disabled), _.setDepthMode(Wt.disabled); const T = h.getOrCreateProgram("clippingMask"); for (const z of t) { const R = h._tileClippingMaskIDs[z.key] = --s; T.draw(h, y.TRIANGLES, Wt.disabled, new ci({ func: y.ALWAYS, mask: 0 }, R, 255, y.KEEP, y.KEEP, y.REPLACE), bi.disabled, ti.disabled, nc(z.projMatrix), "$clipping", h.tileExtentBuffer, h.quadTriangleIndexBuffer, h.tileExtentSegments); } } pointCoordinate(t) { const s = this.painter.transform; if (t.x < 0 || t.x > s.width || t.y < 0 || t.y > s.height) return null; const h = [t.x, t.y, 1, 1]; i.ab.vec4.transformMat4(h, h, s.pixelMatrixInverse), i.ab.vec4.scale(h, h, 1 / h[3]), h[0] /= s.worldSize, h[1] /= s.worldSize; const _ = s._camera.position, y = i.bH(1, s.center.lat), T = [_[0], _[1], _[2] / y, 0], z = i.ab.vec3.subtract([], h.slice(0, 3), T); i.ab.vec3.normalize(z, z); const R = this.raycast(T, z, this._exaggeration); return R !== null && R ? (i.ab.vec3.scaleAndAdd(T, T, z, R), T[3] = T[2], T[2] *= y, T) : null; } _setupProxiedCoordsForOrtho(t, s, h) { if (t.getSource() instanceof i.aJ) return this._setupProxiedCoordsForImageSource(t, s, h); this._findCoveringTileCache[t.id] = this._findCoveringTileCache[t.id] || {}; const _ = this.proxiedCoords[t.id] = [], y = this.proxyCoords; for (let R = 0; R < y.length; R++) { const F = y[R], N = this._findTileCoveringTileID(F, t); if (N) { const G = this._createProxiedId(F, N, h[F.key] && h[F.key][t.id]); _.push(G), this.proxyToSource[F.key][t.id] = [G]; } } let T = !1; const z = /* @__PURE__ */ new Set(); for (let R = 0; R < s.length; R++) { const F = t.getTile(s[R]); if (!F || !F.hasData()) continue; const N = this._findTileCoveringTileID(F.tileID, this.proxySourceCache); if (N && N.tileID.canonical.z !== F.tileID.canonical.z) { const G = this.proxyToSource[N.tileID.key][t.id], Z = this._createProxiedId(N.tileID, F, h[N.tileID.key] && h[N.tileID.key][t.id]); G ? G.splice(G.length - 1, 0, Z) : this.proxyToSource[N.tileID.key][t.id] = [Z]; const W = this.proxyToSource[N.tileID.key][t.id]; z.has(W) || z.add(W), _.push(Z), T = !0; } } if (this._sourceTilesOverlap[t.id] = T, T && this._debugParams.sortTilesHiZFirst) for (const R of z) R.sort((F, N) => N.overscaledZ - F.overscaledZ); } _setupProxiedCoordsForImageSource(t, s, h) { if (!t.getSource().loaded()) return; const _ = this.proxiedCoords[t.id] = [], y = this.proxyCoords, T = t.getSource(), z = T.tileID; if (!z) return; const R = new i.P(z.x, z.y)._div(1 << z.z), F = T.coordinates.map(i.aa.fromLngLat).reduce((G, Z) => (G.min.x = Math.min(G.min.x, Z.x - R.x), G.min.y = Math.min(G.min.y, Z.y - R.y), G.max.x = Math.max(G.max.x, Z.x - R.x), G.max.y = Math.max(G.max.y, Z.y - R.y), G), { min: new i.P(Number.MAX_VALUE, Number.MAX_VALUE), max: new i.P(-Number.MAX_VALUE, -Number.MAX_VALUE) }), N = (G, Z) => { const W = G.wrap + G.canonical.x / (1 << G.canonical.z), te = G.canonical.y / (1 << G.canonical.z), ee = i.ag / (1 << G.canonical.z), se = Z.wrap + Z.canonical.x / (1 << Z.canonical.z), oe = Z.canonical.y / (1 << Z.canonical.z); return W + ee < se + F.min.x || W > se + F.max.x || te + ee < oe + F.min.y || te > oe + F.max.y; }; for (let G = 0; G < y.length; G++) { const Z = y[G]; for (let W = 0; W < s.length; W++) { const te = t.getTile(s[W]); if (!te || !te.hasData() || N(Z, te.tileID)) continue; const ee = this._createProxiedId(Z, te, h[Z.key] && h[Z.key][t.id]), se = this.proxyToSource[Z.key][t.id]; se ? se.push(ee) : this.proxyToSource[Z.key][t.id] = [ee], _.push(ee); } } } _createProxiedId(t, s, h) { let _ = this.orthoMatrix; if (h) { const y = h.find((T) => T.key === s.tileID.key); if (y) return y; } if (s.tileID.key !== t.key) { const y = t.canonical.z - s.tileID.canonical.z; let T, z, R; _ = i.ab.mat4.create(); const F = s.tileID.wrap - t.wrap << t.overscaledZ; y > 0 ? (T = i.ag >> y, z = T * ((s.tileID.canonical.x << y) - t.canonical.x + F), R = T * ((s.tileID.canonical.y << y) - t.canonical.y)) : (T = i.ag << -y, z = i.ag * (s.tileID.canonical.x - (t.canonical.x + F << -y)), R = i.ag * (s.tileID.canonical.y - (t.canonical.y << -y))), i.ab.mat4.ortho(_, 0, T, 0, T, 0, 1), i.ab.mat4.translate(_, _, [z, R, 0]); } return new Qh(s.tileID, t.key, _); } _findTileCoveringTileID(t, s) { let h = s.getTile(t); if (h && h.hasData()) return h; const _ = this._findCoveringTileCache[s.id], y = _[t.key]; if (h = y ? s.getTileByID(y) : null, h && h.hasData() || y === null) return h; let T = h ? h.tileID : t, z = T.overscaledZ; const R = s.getSource().minzoom, F = []; if (!y) { const G = s.getSource().maxzoom; if (t.canonical.z >= G) { const Z = t.canonical.z - G; s.getSource().reparseOverscaled ? (z = Math.max(t.canonical.z + 2, s.transform.tileZoom), T = new i.aG(z, t.wrap, G, t.canonical.x >> Z, t.canonical.y >> Z)) : Z !== 0 && (z = G, T = new i.aG(z, t.wrap, G, t.canonical.x >> Z, t.canonical.y >> Z)); } T.key !== t.key && (F.push(T.key), h = s.getTile(T)); } const N = (G) => { F.forEach((Z) => { _[Z] = G; }), F.length = 0; }; for (z -= 1; z >= R && (!h || !h.hasData()); z--) { h && N(h.tileID.key); const G = T.calculateScaledKey(z); if (h = s.getTileByID(G), h && h.hasData()) break; const Z = _[G]; if (Z === null) break; Z === void 0 ? F.push(G) : h = s.getTileByID(Z); } return N(h ? h.tileID.key : null), h && h.hasData() ? h : null; } findDEMTileFor(t) { return this.enabled ? this._findTileCoveringTileID(t, this.sourceCache) : null; } prepareDrawTile() { this.renderedToTile = !0; } _clearRenderCacheForTile(t, s) { let h = this._tilesDirty[t]; h || (h = this._tilesDirty[t] = {}), h[s.key] = !0; } } function $f(c, t, s) { const h = function(z, R, F) { const N = i.ab.vec3.dot(R, z), G = i.ab.vec3.dot(F, [0.2126, 0.7152, 0.0722]), Z = (te, ee, se) => (1 - se) * te + se * ee, W = Z(1 - 0.3 * Math.min(G, 1), 1, Math.min(N + 1, 1)); return Z(0.92, 1, Math.asin(i.aw(R[2], -1, 1)) / Math.PI + 0.5) * W; }(c, [0, 0, 1], t), _ = [0, 0, 0]; i.ab.vec3.scale(_, s.slice(0, 3), h); const y = [0, 0, 0]; i.ab.vec3.scale(y, t.slice(0, 3), c[2]); const T = [0, 0, 0]; return i.ab.vec3.add(T, _, y), i.cf(T); } const Jc = ["fill", "fillOutline", "fillPattern", "line", "linePattern", "background", "backgroundPattern", "hillshade", "raster"], Jm = ["stars", "rainParticle", "snowParticle", "fillExtrusion", "fillExtrusionGroundEffect", "model", "symbol"]; class Xf { static cacheKey(t, s, h, _) { let y = `${s}${_ ? _.cacheKey : ""}`; for (const T of h) t.usedDefines.includes(T) && (y += `/${T}`); return y; } constructor(t, s, h, _, y, T) { const z = t.gl; this.program = z.createProgram(), this.configuration = _, this.name = s, this.fixedDefines = [...T]; const R = _ ? _.getBinderAttributes() : [], F = (h.staticAttributes || []).concat(R); let N = _ ? _.defines() : []; N = N.concat(T.map((se) => `#define ${se}`)); const G = `#version 300 es `; let Z = G + N.concat("precision mediump float;", Qr, Jl.fragmentSource).join(` `); for (const se of h.fragmentIncludes) Z += ` ${oo[se]}`; Z += ` ${h.fragmentSource}`; let W = G + N.concat("precision highp float;", Qr, Jl.vertexSource).join(` `); for (const se of h.vertexIncludes) W += ` ${oo[se]}`; this.forceManualRenderingForInstanceIDShaders = t.forceManualRenderingForInstanceIDShaders && h.vertexSource.indexOf("gl_InstanceID") !== -1, this.forceManualRenderingForInstanceIDShaders && (W += ` uniform int u_instanceID; `), W += ` ${h.vertexSource}`, this.forceManualRenderingForInstanceIDShaders && (W = W.replaceAll("gl_InstanceID", "u_instanceID")); const te = z.createShader(z.FRAGMENT_SHADER); if (z.isContextLost()) return void (this.failedToCreate = !0); z.shaderSource(te, Z), z.compileShader(te), z.attachShader(this.program, te); const ee = z.createShader(z.VERTEX_SHADER); if (z.isContextLost()) this.failedToCreate = !0; else { z.shaderSource(ee, W), z.compileShader(ee), z.attachShader(this.program, ee), this.attributes = {}, this.numAttributes = F.length; for (let se = 0; se < this.numAttributes; se++) if (F[se]) { const oe = F[se].startsWith("a_") ? F[se] : `a_${F[se]}`; z.bindAttribLocation(this.program, se, oe), this.attributes[oe] = se; } z.linkProgram(this.program), z.deleteShader(ee), z.deleteShader(te), this.fixedUniforms = y(t), this.binderUniforms = _ ? _.getUniforms(t) : [], this.forceManualRenderingForInstanceIDShaders && (this.instancingUniforms = ((se) => ({ u_instanceID: new i.bN(se) }))(t)), (T.includes("TERRAIN") || s.indexOf("symbol") !== -1 || s.indexOf("circle") !== -1) && (this.terrainUniforms = ((se) => ({ u_dem: new i.bN(se), u_dem_prev: new i.bN(se), u_dem_tl: new i.bK(se), u_dem_scale: new i.bM(se), u_dem_tl_prev: new i.bK(se), u_dem_scale_prev: new i.bM(se), u_dem_size: new i.bM(se), u_dem_lerp: new i.bM(se), u_exaggeration: new i.bM(se), u_depth: new i.bN(se), u_depth_size_inv: new i.bK(se), u_depth_range_unpack: new i.bK(se), u_occluder_half_size: new i.bM(se), u_occlusion_depth_offset: new i.bM(se), u_meter_to_dem: new i.bM(se), u_label_plane_matrix_inv: new i.bJ(se) }))(t)), T.includes("GLOBE") && (this.globeUniforms = ((se) => ({ u_tile_tl_up: new i.bL(se), u_tile_tr_up: new i.bL(se), u_tile_br_up: new i.bL(se), u_tile_bl_up: new i.bL(se), u_tile_up_scale: new i.bM(se) }))(t)), T.includes("FOG") && (this.fogUniforms = ((se) => ({ u_fog_matrix: new i.bJ(se), u_fog_range: new i.bK(se), u_fog_color: new i.ca(se), u_fog_horizon_blend: new i.bM(se), u_fog_vertical_limit: new i.bK(se), u_fog_temporal_offset: new i.bM(se), u_frustum_tl: new i.bL(se), u_frustum_tr: new i.bL(se), u_frustum_br: new i.bL(se), u_frustum_bl: new i.bL(se), u_globe_pos: new i.bL(se), u_globe_radius: new i.bM(se), u_globe_transition: new i.bM(se), u_is_globe: new i.bN(se), u_viewport: new i.bK(se) }))(t)), T.includes("RENDER_CUTOFF") && (this.cutoffUniforms = ((se) => ({ u_cutoff_params: new i.ca(se) }))(t)), T.includes("LIGHTING_3D_MODE") && (this.lightsUniforms = ((se) => ({ u_lighting_ambient_color: new i.bL(se), u_lighting_directional_dir: new i.bL(se), u_lighting_directional_color: new i.bL(se), u_ground_radiance: new i.bL(se) }))(t)), T.includes("RENDER_SHADOWS") && (this.shadowUniforms = ((se) => ({ u_light_matrix_0: new i.bJ(se), u_light_matrix_1: new i.bJ(se), u_fade_range: new i.bK(se), u_shadow_normal_offset: new i.bL(se), u_shadow_intensity: new i.bM(se), u_shadow_texel_size: new i.bM(se), u_shadow_map_resolution: new i.bM(se), u_shadow_direction: new i.bL(se), u_shadow_bias: new i.bL(se), u_shadowmap_0: new i.bN(se), u_shadowmap_1: new i.bN(se) }))(t)); } } setTerrainUniformValues(t, s) { if (!this.terrainUniforms) return; const h = this.terrainUniforms; if (!this.failedToCreate) { t.program.set(this.program); for (const _ in s) h[_] && h[_].set(this.program, _, s[_]); } } setGlobeUniformValues(t, s) { if (!this.globeUniforms) return; const h = this.globeUniforms; if (!this.failedToCreate) { t.program.set(this.program); for (const _ in s) h[_] && h[_].set(this.program, _, s[_]); } } setFogUniformValues(t, s) { if (!this.fogUniforms) return; const h = this.fogUniforms; if (!this.failedToCreate) { t.program.set(this.program); for (const _ in s) h[_].set(this.program, _, s[_]); } } setCutoffUniformValues(t, s) { if (!this.cutoffUniforms) return; const h = this.cutoffUniforms; if (!this.failedToCreate) { t.program.set(this.program); for (const _ in s) h[_].set(this.program, _, s[_]); } } setLightsUniformValues(t, s) { if (!this.lightsUniforms) return; const h = this.lightsUniforms; if (!this.failedToCreate) { t.program.set(this.program); for (const _ in s) h[_].set(this.program, _, s[_]); } } setShadowUniformValues(t, s) { if (this.failedToCreate || !this.shadowUniforms) return; const h = this.shadowUniforms; t.program.set(this.program); for (const _ in s) h[_].set(this.program, _, s[_]); } _drawDebugWireframe(t, s, h, _, y, T, z, R, F, N) { const G = t.options.wireframe; if (G.terrain === !1 && G.layers2D === !1 && G.layers3D === !1) return; const Z = t.context; if (!(() => !(!G.terrain || this.name !== "terrainRaster" && this.name !== "globeRaster") || !(!G.layers2D || t._terrain && t._terrain.renderingToTexture || !Jc.includes(this.name)) || !(!G.layers3D || !Jm.includes(this.name)))()) return; const W = Z.gl, te = t.wireframeDebugCache.getLinesFromTrianglesBuffer(t.frameCounter, y, Z); if (!te) return; const ee = [...this.fixedDefines]; ee.push("DEBUG_WIREFRAME"); const se = t.getOrCreateProgram(this.name, { config: this.configuration, defines: ee }); Z.program.set(se.program); const oe = (pe, Me, xe) => { if (Me[pe] && xe[pe]) for (const we in Me[pe]) xe[pe][we] && xe[pe][we].set(xe.program, we, Me[pe][we].current); }; F && F.setUniforms(se.program, Z, se.binderUniforms, z, { zoom: R }), oe("fixedUniforms", this, se), oe("terrainUniforms", this, se), oe("globeUniforms", this, se), oe("fogUniforms", this, se), oe("lightsUniforms", this, se), oe("shadowUniforms", this, se), te.bind(), Z.setColorMode(new bi([W.ONE, W.ONE_MINUS_SRC_ALPHA, W.ZERO, W.ONE], i.aj.transparent, [!0, !0, !0, !1])), Z.setDepthMode(new Wt(s.func === W.LESS ? W.LEQUAL : s.func, Wt.ReadOnly, s.range)), Z.setStencilMode(ci.disabled); const he = 3 * T.primitiveLength * 2, _e = 3 * T.primitiveOffset * 2 * 2; if (this.forceManualRenderingForInstanceIDShaders) { const pe = N || 1; for (let Me = 0; Me < pe; ++Me) se.instancingUniforms.u_instanceID.set(this.program, "u_instanceID", Me), W.drawElements(W.LINES, he, W.UNSIGNED_SHORT, _e); } else N && N > 1 ? W.drawElementsInstanced(W.LINES, he, W.UNSIGNED_SHORT, _e, N) : W.drawElements(W.LINES, he, W.UNSIGNED_SHORT, _e); y.bind(), Z.program.set(this.program), Z.setDepthMode(s), Z.setStencilMode(h), Z.setColorMode(_); } checkUniforms(t, s, h) { if (this.fixedDefines.includes(s)) { for (const _ of Object.keys(h)) if (!h[_].initialized) throw new Error(`Program '${this.name}', from draw '${t}': uniform ${_} not set but required by ${s} being defined`); } } draw(t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se) { const oe = t.context, he = oe.gl; if (this.failedToCreate) return; oe.program.set(this.program), oe.setDepthMode(h), oe.setStencilMode(_), oe.setColorMode(y), oe.setCullFace(T); for (const Me of Object.keys(this.fixedUniforms)) this.fixedUniforms[Me].set(this.program, Me, z[Me]); te && te.setUniforms(this.program, oe, this.binderUniforms, Z, { zoom: W }); const _e = { [he.POINTS]: 1, [he.LINES]: 2, [he.TRIANGLES]: 3, [he.LINE_STRIP]: 1 }[s]; this.checkUniforms(R, "RENDER_SHADOWS", this.shadowUniforms); const pe = se && se > 0 ? 1 : void 0; for (const Me of G.get()) { const xe = Me.vaos || (Me.vaos = {}); if ((xe[R] || (xe[R] = new qh())).bind(oe, this, F, te ? te.getPaintVertexBuffers() : [], N, Me.vertexOffset, ee || [], pe), this.forceManualRenderingForInstanceIDShaders) { const we = se || 1; for (let ve = 0; ve < we; ++ve) this.instancingUniforms.u_instanceID.set(this.program, "u_instanceID", ve), N ? he.drawElements(s, Me.primitiveLength * _e, he.UNSIGNED_SHORT, Me.primitiveOffset * _e * 2) : he.drawArrays(s, Me.vertexOffset, Me.vertexLength); } else se && se > 1 ? he.drawElementsInstanced(s, Me.primitiveLength * _e, he.UNSIGNED_SHORT, Me.primitiveOffset * _e * 2, se) : N ? he.drawElements(s, Me.primitiveLength * _e, he.UNSIGNED_SHORT, Me.primitiveOffset * _e * 2) : he.drawArrays(s, Me.vertexOffset, Me.vertexLength); s === he.TRIANGLES && N && this._drawDebugWireframe(t, h, _, y, N, Me, Z, W, te, se); } } } function ld(c, t) { const s = Math.pow(2, t.tileID.overscaledZ), h = t.tileSize * Math.pow(2, c.transform.tileZoom) / s, _ = h * (t.tileID.canonical.x + t.tileID.wrap * s), y = h * t.tileID.canonical.y; return { u_image: 0, u_texsize: t.imageAtlasTexture ? t.imageAtlasTexture.size : [0, 0], u_tile_units_to_pixels: 1 / i.ar(t, 1, c.transform.tileZoom), u_pixel_coord_upper: [_ >> 16, y >> 16], u_pixel_coord_lower: [65535 & _, 65535 & y] }; } const eu = { terrain: 0, flat: 1 }, cd = i.ab.mat4.create(), tu = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe) => { const he = t.style.light, _e = he.properties.get("position"), pe = [_e.x, _e.y, _e.z], Me = i.ab.mat3.create(); he.properties.get("anchor") === "viewport" && (i.ab.mat3.fromRotation(Me, -t.transform.angle), i.ab.vec3.transformMat3(pe, pe, Me)); const xe = he.properties.get("color"), we = t.transform, ve = { u_matrix: c, u_lightpos: pe, u_lightintensity: he.properties.get("intensity"), u_lightcolor: [xe.r, xe.g, xe.b], u_vertical_gradient: +s, u_opacity: h, u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_inv_rot_matrix: cd, u_merc_center: [0, 0], u_up_dir: [0, 0, 0], u_height_lift: 0, u_height_type: eu[F], u_base_type: eu[N], u_ao: _, u_edge_radius: y, u_width_scale: T, u_flood_light_color: te, u_vertical_scale: ee, u_flood_light_intensity: se, u_ground_shadow_factor: oe }; return we.projection.name === "globe" && (ve.u_tile_id = [z.canonical.x, z.canonical.y, 1 << z.canonical.z], ve.u_zoom_transition = G, ve.u_inv_rot_matrix = W, ve.u_merc_center = Z, ve.u_up_dir = we.projection.upVector(new i.bT(0, 0, 0), Z[0] * i.ag, Z[1] * i.ag), ve.u_height_lift = R), ve; }, Qc = (c, t, s, h, _, y) => ({ u_matrix: c, u_edge_radius: t, u_width_scale: s, u_vertical_scale: h, u_height_type: eu[_], u_base_type: eu[y] }), hd = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se) => { const oe = tu(c, t, s, h, _, y, T, z, F, N, G, Z, W, te, ee, se, 1, [0, 0, 0]), he = { u_height_factor: -Math.pow(2, z.overscaledZ) / R.tileSize / 8 }; return i.l(oe, ld(t, R), he); }, sc = (c, t) => ({ u_matrix: c, u_emissive_strength: t }), ud = (c, t, s, h) => i.l(sc(c, t), ld(s, h)), iu = (c, t, s) => ({ u_matrix: c, u_world: s, u_emissive_strength: t }), nu = (c, t, s, h, _) => i.l(ud(c, t, s, h), { u_world: _ }), dd = (c, t, s, h) => { const _ = i.ag / s.tileSize; return { u_matrix: c, u_camera_to_center_distance: t.getCameraToCenterDistance(h), u_extrude_scale: [t.pixelsToGLUnits[0] / _, t.pixelsToGLUnits[1] / _] }; }, fd = (c, t, s = 1) => ({ u_matrix: c, u_color: t.toRenderColor(null), u_overlay: 0, u_overlay_scale: s }), Qm = i.ab.mat4.create(), rc = (c, t, s, h, _, y, T) => { const z = c.transform, R = z.projection.name === "globe", F = R ? i.cN(z.zoom, t.canonical) * z._pixelsPerMercatorPixel : i.ar(s, 1, y), N = { u_matrix: t.projMatrix, u_extrude_scale: F, u_intensity: T, u_inv_rot_matrix: Qm, u_merc_center: [0, 0], u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_up_dir: [0, 0, 0] }; if (R) { N.u_inv_rot_matrix = h, N.u_merc_center = _, N.u_tile_id = [t.canonical.x, t.canonical.y, 1 << t.canonical.z], N.u_zoom_transition = i.ae(z.zoom); const G = _[0] * i.ag, Z = _[1] * i.ag; N.u_up_dir = z.projection.upVector(new i.bT(0, 0, 0), G, Z); } return N; }; function eh(c, [t, s, h, _], [y, T]) { if (y === T) return [0, 0, 0, 0]; const z = 255 * (c - 1) / (c * (T - y)); return [t * z, s * z, h * z, _ * z]; } function Ft(c, t, [s, h]) { return s === h ? 0 : 0.5 / c + (t - s) * (c - 1) / (c * (h - s)); } const pd = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe, he, _e, pe) => ({ u_matrix: c, u_normalize_matrix: t, u_globe_matrix: s, u_merc_matrix: h, u_grid_matrix: _, u_tl_parent: y, u_scale_parent: F, u_fade_t: N.mix, u_opacity: N.opacity * G.paint.get("raster-opacity"), u_image0: 0, u_image1: 1, u_brightness_low: G.paint.get("raster-brightness-min"), u_brightness_high: G.paint.get("raster-brightness-max"), u_saturation_factor: i.cO(G.paint.get("raster-saturation")), u_contrast_factor: i.cP(G.paint.get("raster-contrast")), u_spin_weights: Yf(G.paint.get("raster-hue-rotate")), u_perspective_transform: Z, u_raster_elevation: W, u_zoom_transition: T, u_merc_center: z, u_cutoff_params: R, u_colorization_mix: eh(i.cQ, ee, oe), u_colorization_offset: Ft(i.cQ, se, oe), u_color_ramp: te, u_texture_offset: [_e / (he + 2 * _e), he / (he + 2 * _e)], u_texture_res: [he + 2 * _e, he + 2 * _e], u_emissive_strength: pe }); function Yf(c) { c *= Math.PI / 180; const t = Math.sin(c), s = Math.cos(c); return [(2 * s + 1) / 3, (-Math.sqrt(3) * t - s + 1) / 3, (Math.sqrt(3) * t - s + 1) / 3]; } const lo = 0.05, Tl = (c, t, s, h, _, y, T, z, R, F, N, G) => ({ u_matrix: c, u_normalize_matrix: t, u_globe_matrix: s, u_merc_matrix: h, u_grid_matrix: _, u_tl_parent: y, u_scale_parent: F, u_fade_t: N.mix, u_opacity: N.opacity, u_image0: 0, u_image1: 1, u_raster_elevation: G, u_zoom_transition: T, u_merc_center: z, u_cutoff_params: R }), Zt = (c, t, s, h, _, y, T, z, R, F) => ({ u_particle_texture: c, u_particle_texture_side_len: t, u_tile_offset: s, u_velocity: h, u_color_ramp: y, u_velocity_res: _, u_max_speed: T, u_uv_offset: z, u_data_scale: [255 * R[0], 255 * R[1]], u_data_offset: F, u_particle_pos_scale: 1.1, u_particle_pos_offset: [lo, lo] }), md = (c, t, s, h, _, y, T, z, R, F) => ({ u_particle_texture: c, u_particle_texture_side_len: t, u_velocity: s, u_velocity_res: h, u_max_speed: _, u_speed_factor: y, u_reset_rate: T, u_rand_seed: Math.random(), u_uv_offset: z, u_data_scale: [255 * R[0], 255 * R[1]], u_data_offset: F, u_particle_pos_scale: 1.1, u_particle_pos_offset: [lo, lo] }), Kf = i.ab.mat4.create(), Jf = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe, he, _e, pe, Me) => { const xe = _.transform, we = { u_is_size_zoom_constant: +(c === "constant" || c === "source"), u_is_size_feature_constant: +(c === "constant" || c === "camera"), u_size_t: t ? t.uSizeT : 0, u_size: t ? t.uSize : 0, u_camera_to_center_distance: xe.getCameraToCenterDistance(he), u_rotate_symbol: +s, u_aspect_ratio: xe.width / xe.height, u_fade_change: _.options.fadeDuration ? _.symbolFadeChange : 1, u_matrix: y, u_label_plane_matrix: T, u_coord_matrix: z, u_is_text: +F, u_elevation_from_sea: R ? 1 : 0, u_pitch_with_map: +h, u_texsize: N, u_texsize_icon: G, u_texture: 0, u_texture_icon: 1, u_tile_id: [0, 0, 0], u_zoom_transition: 0, u_inv_rot_matrix: Kf, u_merc_center: [0, 0], u_camera_forward: [0, 0, 0], u_ecef_origin: [0, 0, 0], u_tile_matrix: Kf, u_up_vector: [0, -1, 0], u_color_adj_mat: _e, u_icon_transition: pe || 0, u_gamma_scale: h ? _.transform.getCameraToCenterDistance(he) * Math.cos(_.terrain ? 0 : _.transform._pitch) : 1, u_device_pixel_ratio: i.q.devicePixelRatio, u_is_halo: +Z, u_scale_factor: Me || 1 }; return he.name === "globe" && (we.u_tile_id = [W.canonical.x, W.canonical.y, 1 << W.canonical.z], we.u_zoom_transition = te, we.u_inv_rot_matrix = se, we.u_merc_center = ee, we.u_camera_forward = xe._camera.forward(), we.u_ecef_origin = i.cR(xe.globeMatrix, W.toUnwrapped()), we.u_tile_matrix = Float32Array.from(xe.globeMatrix), we.u_up_vector = oe), we; }, su = (c, t, s, h) => ({ u_matrix: c, u_emissive_strength: t, u_opacity: s, u_color: h }), _d = (c, t, s, h, _, y, T, z, R) => i.l(function(F, N, G, Z, W, te) { const { width: ee, height: se } = Z.imageManager.getPixelSize(N), oe = Math.pow(2, te.tileID.overscaledZ), he = te.tileSize * Math.pow(2, Z.transform.tileZoom) / oe, _e = he * (te.tileID.canonical.x + te.tileID.wrap * oe), pe = he * te.tileID.canonical.y; return { u_image: 0, u_pattern_tl: G.tl, u_pattern_br: G.br, u_texsize: [ee, se], u_pattern_size: G.displaySize, u_pattern_units_to_pixels: W ? [Z.transform.width, -1 * Z.transform.height] : [1 / i.ar(te, 1, Z.transform.tileZoom), 1 / i.ar(te, 1, Z.transform.tileZoom)], u_pixel_coord_upper: [_e >> 16, pe >> 16], u_pixel_coord_lower: [65535 & _e, 65535 & pe] }; }(0, y, T, h, z, R), { u_matrix: c, u_emissive_strength: t, u_opacity: s }), ru = new Float32Array(i.ab.mat4.identity([])), gd = (c, t, s, h, _, y, T, z, R, F, N, G, Z, W = [0, 0, 0], te) => { const ee = _.style.light, se = ee.properties.get("position"), oe = [-se.x, -se.y, se.z], he = i.ab.mat3.create(); ee.properties.get("anchor") === "viewport" && (i.ab.mat3.fromRotation(he, -_.transform.angle), i.ab.vec3.transformMat3(oe, oe, he)); const _e = N.alphaMode === "MASK", pe = ee.properties.get("color").toRenderColor(null), Me = Z.paint.get("model-ambient-occlusion-intensity"), xe = Z.paint.get("model-color").constantOr(i.aj.white).toRenderColor(null), we = Z.paint.get("model-color-mix-intensity").constantOr(0); return { u_matrix: c, u_lighting_matrix: t, u_normal_matrix: s, u_node_matrix: h || ru, u_lightpos: oe, u_lightintensity: ee.properties.get("intensity"), u_lightcolor: [pe.r, pe.g, pe.b], u_camera_pos: W, u_opacity: y, u_baseTextureIsAlpha: 0, u_alphaMask: +_e, u_alphaCutoff: N.alphaCutoff, u_baseColorFactor: [T.r, T.g, T.b, T.a], u_emissiveFactor: [z[0], z[1], z[2], 1], u_metallicFactor: R, u_roughnessFactor: F, u_baseColorTexture: bs.BaseColor, u_metallicRoughnessTexture: bs.MetallicRoughness, u_normalTexture: bs.Normal, u_occlusionTexture: bs.Occlusion, u_emissionTexture: bs.Emission, u_lutTexture: bs.LUT, u_color_mix: [xe.r, xe.g, xe.b, we], u_aoIntensity: Me, u_emissive_strength: G, u_occlusionTextureTransform: te || [0, 0, 0, 0] }; }, Qf = (c, t = ru, s = ru) => ({ u_matrix: c, u_instance: t, u_node_matrix: s }), yd = { fillExtrusion: (c) => ({ u_matrix: new i.bJ(c), u_lightpos: new i.bL(c), u_lightintensity: new i.bM(c), u_lightcolor: new i.bL(c), u_vertical_gradient: new i.bM(c), u_opacity: new i.bM(c), u_edge_radius: new i.bM(c), u_width_scale: new i.bM(c), u_ao: new i.bK(c), u_height_type: new i.bN(c), u_base_type: new i.bN(c), u_tile_id: new i.bL(c), u_zoom_transition: new i.bM(c), u_inv_rot_matrix: new i.bJ(c), u_merc_center: new i.bK(c), u_up_dir: new i.bL(c), u_height_lift: new i.bM(c), u_flood_light_color: new i.bL(c), u_vertical_scale: new i.bM(c), u_flood_light_intensity: new i.bM(c), u_ground_shadow_factor: new i.bL(c) }), fillExtrusionDepth: (c) => ({ u_matrix: new i.bJ(c), u_edge_radius: new i.bM(c), u_width_scale: new i.bM(c), u_vertical_scale: new i.bM(c), u_height_type: new i.bN(c), u_base_type: new i.bN(c) }), fillExtrusionPattern: (c) => ({ u_matrix: new i.bJ(c), u_lightpos: new i.bL(c), u_lightintensity: new i.bM(c), u_lightcolor: new i.bL(c), u_vertical_gradient: new i.bM(c), u_height_factor: new i.bM(c), u_edge_radius: new i.bM(c), u_width_scale: new i.bM(c), u_ao: new i.bK(c), u_height_type: new i.bN(c), u_base_type: new i.bN(c), u_tile_id: new i.bL(c), u_zoom_transition: new i.bM(c), u_inv_rot_matrix: new i.bJ(c), u_merc_center: new i.bK(c), u_up_dir: new i.bL(c), u_height_lift: new i.bM(c), u_image: new i.bN(c), u_texsize: new i.bK(c), u_pixel_coord_upper: new i.bK(c), u_pixel_coord_lower: new i.bK(c), u_tile_units_to_pixels: new i.bM(c), u_opacity: new i.bM(c) }), fillExtrusionGroundEffect: (c) => ({ u_matrix: new i.bJ(c), u_opacity: new i.bM(c), u_ao_pass: new i.bM(c), u_meter_to_tile: new i.bM(c), u_ao: new i.bK(c), u_flood_light_intensity: new i.bM(c), u_flood_light_color: new i.bL(c), u_attenuation: new i.bM(c), u_edge_radius: new i.bM(c), u_fb: new i.bN(c), u_fb_size: new i.bM(c), u_dynamic_offset: new i.bM(c) }), fill: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c) }), fillPattern: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c), u_image: new i.bN(c), u_texsize: new i.bK(c), u_pixel_coord_upper: new i.bK(c), u_pixel_coord_lower: new i.bK(c), u_tile_units_to_pixels: new i.bM(c) }), fillOutline: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c), u_world: new i.bK(c) }), fillOutlinePattern: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c), u_world: new i.bK(c), u_image: new i.bN(c), u_texsize: new i.bK(c), u_pixel_coord_upper: new i.bK(c), u_pixel_coord_lower: new i.bK(c), u_tile_units_to_pixels: new i.bM(c) }), circle: i.cS, collisionBox: (c) => ({ u_matrix: new i.bJ(c), u_camera_to_center_distance: new i.bM(c), u_extrude_scale: new i.bK(c) }), collisionCircle: (c) => ({ u_matrix: new i.bJ(c), u_inv_matrix: new i.bJ(c), u_camera_to_center_distance: new i.bM(c), u_viewport_size: new i.bK(c) }), debug: (c) => ({ u_color: new i.cz(c), u_matrix: new i.bJ(c), u_overlay: new i.bN(c), u_overlay_scale: new i.bM(c) }), clippingMask: (c) => ({ u_matrix: new i.bJ(c) }), heatmap: (c) => ({ u_extrude_scale: new i.bM(c), u_intensity: new i.bM(c), u_matrix: new i.bJ(c), u_inv_rot_matrix: new i.bJ(c), u_merc_center: new i.bK(c), u_tile_id: new i.bL(c), u_zoom_transition: new i.bM(c), u_up_dir: new i.bL(c) }), heatmapTexture: (c) => ({ u_image: new i.bN(c), u_color_ramp: new i.bN(c), u_opacity: new i.bM(c) }), hillshade: (c) => ({ u_matrix: new i.bJ(c), u_image: new i.bN(c), u_latrange: new i.bK(c), u_light: new i.bK(c), u_shadow: new i.cz(c), u_highlight: new i.cz(c), u_emissive_strength: new i.bM(c), u_accent: new i.cz(c) }), hillshadePrepare: (c) => ({ u_matrix: new i.bJ(c), u_image: new i.bN(c), u_dimension: new i.bK(c), u_zoom: new i.bM(c) }), line: i.cT, linePattern: i.cU, raster: (c) => ({ u_matrix: new i.bJ(c), u_normalize_matrix: new i.bJ(c), u_globe_matrix: new i.bJ(c), u_merc_matrix: new i.bJ(c), u_grid_matrix: new i.cA(c), u_tl_parent: new i.bK(c), u_scale_parent: new i.bM(c), u_fade_t: new i.bM(c), u_opacity: new i.bM(c), u_image0: new i.bN(c), u_image1: new i.bN(c), u_brightness_low: new i.bM(c), u_brightness_high: new i.bM(c), u_saturation_factor: new i.bM(c), u_contrast_factor: new i.bM(c), u_spin_weights: new i.bL(c), u_perspective_transform: new i.bK(c), u_raster_elevation: new i.bM(c), u_zoom_transition: new i.bM(c), u_merc_center: new i.bK(c), u_cutoff_params: new i.ca(c), u_colorization_mix: new i.ca(c), u_colorization_offset: new i.bM(c), u_color_ramp: new i.bN(c), u_texture_offset: new i.bK(c), u_texture_res: new i.bK(c), u_emissive_strength: new i.bM(c) }), rasterParticle: (c) => ({ u_matrix: new i.bJ(c), u_normalize_matrix: new i.bJ(c), u_globe_matrix: new i.bJ(c), u_merc_matrix: new i.bJ(c), u_grid_matrix: new i.cA(c), u_tl_parent: new i.bK(c), u_scale_parent: new i.bM(c), u_fade_t: new i.bM(c), u_opacity: new i.bM(c), u_image0: new i.bN(c), u_image1: new i.bN(c), u_raster_elevation: new i.bM(c), u_zoom_transition: new i.bM(c), u_merc_center: new i.bK(c), u_cutoff_params: new i.ca(c) }), rasterParticleTexture: (c) => ({ u_texture: new i.bN(c), u_opacity: new i.bM(c) }), rasterParticleDraw: (c) => ({ u_particle_texture: new i.bN(c), u_particle_texture_side_len: new i.bM(c), u_tile_offset: new i.bK(c), u_velocity: new i.bN(c), u_color_ramp: new i.bN(c), u_velocity_res: new i.bK(c), u_max_speed: new i.bM(c), u_uv_offset: new i.bK(c), u_data_scale: new i.bK(c), u_data_offset: new i.bM(c), u_particle_pos_scale: new i.bM(c), u_particle_pos_offset: new i.bK(c) }), rasterParticleUpdate: (c) => ({ u_particle_texture: new i.bN(c), u_particle_texture_side_len: new i.bM(c), u_velocity: new i.bN(c), u_velocity_res: new i.bK(c), u_max_speed: new i.bM(c), u_speed_factor: new i.bM(c), u_reset_rate: new i.bM(c), u_rand_seed: new i.bM(c), u_uv_offset: new i.bK(c), u_data_scale: new i.bK(c), u_data_offset: new i.bM(c), u_particle_pos_scale: new i.bM(c), u_particle_pos_offset: new i.bK(c) }), symbol: (c) => ({ u_is_size_zoom_constant: new i.bN(c), u_is_size_feature_constant: new i.bN(c), u_size_t: new i.bM(c), u_size: new i.bM(c), u_camera_to_center_distance: new i.bM(c), u_rotate_symbol: new i.bN(c), u_aspect_ratio: new i.bM(c), u_fade_change: new i.bM(c), u_matrix: new i.bJ(c), u_label_plane_matrix: new i.bJ(c), u_coord_matrix: new i.bJ(c), u_is_text: new i.bN(c), u_elevation_from_sea: new i.bN(c), u_pitch_with_map: new i.bN(c), u_texsize: new i.bK(c), u_texsize_icon: new i.bK(c), u_texture: new i.bN(c), u_texture_icon: new i.bN(c), u_gamma_scale: new i.bM(c), u_device_pixel_ratio: new i.bM(c), u_tile_id: new i.bL(c), u_zoom_transition: new i.bM(c), u_inv_rot_matrix: new i.bJ(c), u_merc_center: new i.bK(c), u_camera_forward: new i.bL(c), u_tile_matrix: new i.bJ(c), u_up_vector: new i.bL(c), u_ecef_origin: new i.bL(c), u_is_halo: new i.bN(c), u_icon_transition: new i.bM(c), u_color_adj_mat: new i.bJ(c), u_scale_factor: new i.bM(c) }), background: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c), u_opacity: new i.bM(c), u_color: new i.cz(c) }), backgroundPattern: (c) => ({ u_matrix: new i.bJ(c), u_emissive_strength: new i.bM(c), u_opacity: new i.bM(c), u_image: new i.bN(c), u_pattern_tl: new i.bK(c), u_pattern_br: new i.bK(c), u_texsize: new i.bK(c), u_pattern_size: new i.bK(c), u_pixel_coord_upper: new i.bK(c), u_pixel_coord_lower: new i.bK(c), u_pattern_units_to_pixels: new i.bK(c) }), terrainRaster: (c) => ({ u_matrix: new i.bJ(c), u_image0: new i.bN(c), u_skirt_height: new i.bM(c), u_ground_shadow_factor: new i.bL(c) }), skybox: (c) => ({ u_matrix: new i.bJ(c), u_sun_direction: new i.bL(c), u_cubemap: new i.bN(c), u_opacity: new i.bM(c), u_temporal_offset: new i.bM(c) }), skyboxGradient: (c) => ({ u_matrix: new i.bJ(c), u_color_ramp: new i.bN(c), u_center_direction: new i.bL(c), u_radius: new i.bM(c), u_opacity: new i.bM(c), u_temporal_offset: new i.bM(c) }), skyboxCapture: (c) => ({ u_matrix_3f: new i.cA(c), u_sun_direction: new i.bL(c), u_sun_intensity: new i.bM(c), u_color_tint_r: new i.ca(c), u_color_tint_m: new i.ca(c), u_luminance: new i.bM(c) }), globeRaster: (c) => ({ u_proj_matrix: new i.bJ(c), u_globe_matrix: new i.bJ(c), u_normalize_matrix: new i.bJ(c), u_merc_matrix: new i.bJ(c), u_zoom_transition: new i.bM(c), u_merc_center: new i.bK(c), u_image0: new i.bN(c), u_grid_matrix: new i.cA(c), u_skirt_height: new i.bM(c), u_far_z_cutoff: new i.bM(c), u_frustum_tl: new i.bL(c), u_frustum_tr: new i.bL(c), u_frustum_br: new i.bL(c), u_frustum_bl: new i.bL(c), u_globe_pos: new i.bL(c), u_globe_radius: new i.bM(c), u_viewport: new i.bK(c) }), globeAtmosphere: (c) => ({ u_frustum_tl: new i.bL(c), u_frustum_tr: new i.bL(c), u_frustum_br: new i.bL(c), u_frustum_bl: new i.bL(c), u_horizon: new i.bM(c), u_transition: new i.bM(c), u_fadeout_range: new i.bM(c), u_color: new i.ca(c), u_high_color: new i.ca(c), u_space_color: new i.ca(c), u_temporal_offset: new i.bM(c), u_horizon_angle: new i.bM(c) }), model: (c) => ({ u_matrix: new i.bJ(c), u_lighting_matrix: new i.bJ(c), u_normal_matrix: new i.bJ(c), u_node_matrix: new i.bJ(c), u_lightpos: new i.bL(c), u_lightintensity: new i.bM(c), u_lightcolor: new i.bL(c), u_camera_pos: new i.bL(c), u_opacity: new i.bM(c), u_baseColorFactor: new i.ca(c), u_emissiveFactor: new i.ca(c), u_metallicFactor: new i.bM(c), u_roughnessFactor: new i.bM(c), u_baseTextureIsAlpha: new i.bN(c), u_alphaMask: new i.bN(c), u_alphaCutoff: new i.bM(c), u_baseColorTexture: new i.bN(c), u_metallicRoughnessTexture: new i.bN(c), u_normalTexture: new i.bN(c), u_occlusionTexture: new i.bN(c), u_emissionTexture: new i.bN(c), u_lutTexture: new i.bN(c), u_color_mix: new i.ca(c), u_aoIntensity: new i.bM(c), u_emissive_strength: new i.bM(c), u_occlusionTextureTransform: new i.ca(c) }), modelDepth: (c) => ({ u_matrix: new i.bJ(c), u_instance: new i.bJ(c), u_node_matrix: new i.bJ(c) }), groundShadow: (c) => ({ u_matrix: new i.bJ(c), u_ground_shadow_factor: new i.bL(c) }), stars: (c) => ({ u_matrix: new i.bJ(c), u_up: new i.bL(c), u_right: new i.bL(c), u_intensity_multiplier: new i.bM(c) }), snowParticle: (c) => ({ u_modelview: new i.bJ(c), u_projection: new i.bJ(c), u_time: new i.bM(c), u_cam_pos: new i.bL(c), u_velocityConeAperture: new i.bM(c), u_velocity: new i.bM(c), u_horizontalOscillationRadius: new i.bM(c), u_horizontalOscillationRate: new i.bM(c), u_boxSize: new i.bM(c), u_billboardSize: new i.bM(c), u_simpleShapeParameters: new i.bK(c), u_screenSize: new i.bK(c), u_thinningCenterPos: new i.bK(c), u_thinningShape: new i.bL(c), u_thinningAffectedRatio: new i.bM(c), u_thinningParticleOffset: new i.bM(c), u_particleColor: new i.ca(c), u_direction: new i.bL(c) }), rainParticle: (c) => ({ u_modelview: new i.bJ(c), u_projection: new i.bJ(c), u_time: new i.bM(c), u_cam_pos: new i.bL(c), u_texScreen: new i.bN(c), u_velocityConeAperture: new i.bM(c), u_velocity: new i.bM(c), u_boxSize: new i.bM(c), u_rainDropletSize: new i.bK(c), u_distortionStrength: new i.bM(c), u_rainDirection: new i.bL(c), u_color: new i.ca(c), u_screenSize: new i.bK(c), u_thinningCenterPos: new i.bK(c), u_thinningShape: new i.bL(c), u_thinningAffectedRatio: new i.bM(c), u_thinningParticleOffset: new i.bM(c), u_shapeDirectionalPower: new i.bM(c), u_shapeNormalPower: new i.bM(c), u_mode: new i.bM(c) }), vignette: (c) => ({ u_vignetteShape: new i.bL(c), u_vignetteColor: new i.ca(c) }), occlusion: (c) => ({ u_matrix: new i.bJ(c), u_anchorPos: new i.bL(c), u_screenSizePx: new i.bK(c), u_occluderSizePx: new i.bK(c), u_color: new i.ca(c) }) }; class ea { constructor(t, s, h, _) { this.id = ea.uniqueIdxCounter, ea.uniqueIdxCounter++, this.context = t; const y = t.gl; this.buffer = y.createBuffer(), this.dynamicDraw = !!h, this.context.unbindVAO(), t.bindElementBuffer.set(this.buffer), y.bufferData(y.ELEMENT_ARRAY_BUFFER, s.arrayBuffer, this.dynamicDraw ? y.DYNAMIC_DRAW : y.STATIC_DRAW), this.dynamicDraw || _ || s.destroy(); } bind() { this.context.bindElementBuffer.set(this.buffer); } updateData(t) { this.id = ea.uniqueIdxCounter, ea.uniqueIdxCounter++; const s = this.context.gl; this.context.unbindVAO(), this.bind(), s.bufferSubData(s.ELEMENT_ARRAY_BUFFER, 0, t.arrayBuffer); } destroy() { this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer); } } ea.uniqueIdxCounter = 0; const xd = { Int8: "BYTE", Uint8: "UNSIGNED_BYTE", Int16: "SHORT", Uint16: "UNSIGNED_SHORT", Int32: "INT", Uint32: "UNSIGNED_INT", Float32: "FLOAT" }; class vd { constructor(t, s, h, _, y, T) { this.length = s.length, this.attributes = h, this.itemSize = s.bytesPerElement, this.dynamicDraw = _, this.instanceCount = T, this.context = t; const z = t.gl; this.buffer = z.createBuffer(), t.bindVertexBuffer.set(this.buffer), z.bufferData(z.ARRAY_BUFFER, s.arrayBuffer, this.dynamicDraw ? z.DYNAMIC_DRAW : z.STATIC_DRAW), this.dynamicDraw || y || s.destroy(); } bind() { this.context.bindVertexBuffer.set(this.buffer); } updateData(t) { const s = this.context.gl; this.bind(), s.bufferSubData(s.ARRAY_BUFFER, 0, t.arrayBuffer); } enableAttributes(t, s) { for (let h = 0; h < this.attributes.length; h++) { const _ = s.attributes[this.attributes[h].name]; _ !== void 0 && t.enableVertexAttribArray(_); } } setVertexAttribPointers(t, s, h) { for (let _ = 0; _ < this.attributes.length; _++) { const y = this.attributes[_], T = s.attributes[y.name]; T !== void 0 && t.vertexAttribPointer(T, y.components, t[xd[y.type]], !1, this.itemSize, y.offset + this.itemSize * (h || 0)); } } setVertexAttribDivisor(t, s, h) { for (let _ = 0; _ < this.attributes.length; _++) { const y = s.attributes[this.attributes[_].name]; y !== void 0 && this.instanceCount && this.instanceCount > 0 && t.vertexAttribDivisor(y, h); } } destroy() { this.buffer && (this.context.gl.deleteBuffer(this.buffer), delete this.buffer); } } class br { constructor(t, s, h, _, y) { this.context = t, this.width = s, this.height = h; const T = this.framebuffer = t.gl.createFramebuffer(); _ && (this.colorAttachment = new ic(t, T)), y && (this.depthAttachmentType = y, this.depthAttachment = y === "renderbuffer" ? new es(t, T) : new Ao(t, T)); } destroy() { const t = this.context.gl; if (this.colorAttachment) { const s = this.colorAttachment.get(); s && t.deleteTexture(s); } if (this.depthAttachment && this.depthAttachmentType) if (this.depthAttachmentType === "renderbuffer") { const s = this.depthAttachment.get(); s && t.deleteRenderbuffer(s); } else { const s = this.depthAttachment.get(); s && t.deleteTexture(s); } t.deleteFramebuffer(this.framebuffer); } } class qa { constructor(t, s) { this.gl = t, this.clearColor = new Wh(this), this.clearDepth = new $h(this), this.clearStencil = new Ql(this), this.colorMask = new ec(this), this.depthMask = new tc(this), this.stencilMask = new Wc(this), this.stencilFunc = new $c(this), this.stencilOp = new Xc(this), this.stencilTest = new id(this), this.depthRange = new p(this), this.depthTest = new A(this), this.depthFunc = new B(this), this.blend = new X(this), this.blendFunc = new ne(this), this.blendColor = new ye(this), this.blendEquation = new We(this), this.cullFace = new at(this), this.cullFaceSide = new ft(this), this.frontFace = new Rt(this), this.program = new ii(this), this.activeTexture = new Ci(this), this.viewport = new Wi(this), this.bindFramebuffer = new Hs(this), this.bindRenderbuffer = new ws(this), this.bindTexture = new Rs(this), this.bindVertexBuffer = new ur(this), this.bindElementBuffer = new Za(this), this.bindVertexArrayOES = new nd(this), this.pixelStoreUnpack = new sd(this), this.pixelStoreUnpackPremultiplyAlpha = new rd(this), this.pixelStoreUnpackFlipY = new Xh(this), this.options = s ? { ...s } : {}, this.options.extTextureFilterAnisotropicForceOff || (this.extTextureFilterAnisotropic = t.getExtension("EXT_texture_filter_anisotropic") || t.getExtension("MOZ_EXT_texture_filter_anisotropic") || t.getExtension("WEBKIT_EXT_texture_filter_anisotropic"), this.extTextureFilterAnisotropic && (this.extTextureFilterAnisotropicMax = t.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT))), this.extDebugRendererInfo = t.getExtension("WEBGL_debug_renderer_info"), this.extDebugRendererInfo && (this.renderer = t.getParameter(this.extDebugRendererInfo.UNMASKED_RENDERER_WEBGL), this.vendor = t.getParameter(this.extDebugRendererInfo.UNMASKED_VENDOR_WEBGL)), this.forceManualRenderingForInstanceIDShaders = s && !!s.forceManualRenderingForInstanceIDShaders || this.renderer && this.renderer.indexOf("PowerVR") !== -1, this.options.extTextureFloatLinearForceOff || (this.extTextureFloatLinear = t.getExtension("OES_texture_float_linear")), this.extRenderToTextureHalfFloat = t.getExtension("EXT_color_buffer_half_float"), this.extTimerQuery = t.getExtension("EXT_disjoint_timer_query_webgl2"), this.maxTextureSize = t.getParameter(t.MAX_TEXTURE_SIZE), this.maxPointSize = t.getParameter(t.ALIASED_POINT_SIZE_RANGE)[1]; } 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.bindVertexArrayOES.dirty = !0, this.pixelStoreUnpack.dirty = !0, this.pixelStoreUnpackPremultiplyAlpha.dirty = !0, this.pixelStoreUnpackFlipY.dirty = !0; } createIndexBuffer(t, s, h) { return new ea(this, t, s, h); } createVertexBuffer(t, s, h, _, y) { return new vd(this, t, s, h, _, y); } createRenderbuffer(t, s, h) { const _ = this.gl, y = _.createRenderbuffer(); return this.bindRenderbuffer.set(y), _.renderbufferStorage(_.RENDERBUFFER, t, s, h), this.bindRenderbuffer.set(null), y; } createFramebuffer(t, s, h, _) { return new br(this, t, s, h, _); } clear({ color: t, depth: s, stencil: h, colorMask: _ }) { const y = this.gl; let T = 0; t && (T |= y.COLOR_BUFFER_BIT, this.clearColor.set(t), this.colorMask.set(_ || [!0, !0, !0, !0])), s !== void 0 && (T |= y.DEPTH_BUFFER_BIT, this.depthRange.set([0, 1]), this.clearDepth.set(s), this.depthMask.set(!0)), h !== void 0 && (T |= y.STENCIL_BUFFER_BIT, this.clearStencil.set(h), this.stencilMask.set(255)), y.clear(T); } setCullFace(t) { t.enable === !1 ? this.cullFace.set(!1) : (this.cullFace.set(!0), this.cullFaceSide.set(t.mode), this.frontFace.set(t.frontFace)); } setDepthMode(t) { t.func !== this.gl.ALWAYS || t.mask ? (this.depthTest.set(!0), this.depthFunc.set(t.func), this.depthMask.set(t.mask), this.depthRange.set(t.range)) : this.depthTest.set(!1); } setStencilMode(t) { t.test.func !== this.gl.ALWAYS || t.mask ? (this.stencilTest.set(!0), this.stencilMask.set(t.mask), this.stencilOp.set([t.fail, t.depthFail, t.pass]), this.stencilFunc.set({ func: t.test.func, ref: t.ref, mask: t.test.mask })) : this.stencilTest.set(!1); } setColorMode(t) { i.bn(t.blendFunction, bi.Replace) ? this.blend.set(!1) : (this.blend.set(!0), this.blendFunc.set(t.blendFunction), this.blendColor.set(t.blendColor), t.blendEquation ? this.blendEquation.set(t.blendEquation) : this.blendEquation.setDefault()), this.colorMask.set(t.mask); } unbindVAO() { this.bindVertexArrayOES.set(null); } } let th; function ou(c, t, s, h, _, y, T) { const z = c.context, R = z.gl, F = c.transform, N = c.getOrCreateProgram("collisionBox"), G = []; let Z = 0, W = 0; for (let pe = 0; pe < h.length; pe++) { const Me = h[pe], xe = t.getTile(Me), we = xe.getBucket(s); if (!we) continue; const ve = qn(Me, we, F); let Ae = ve; _[0] === 0 && _[1] === 0 || (Ae = c.translatePosMatrix(ve, xe, _, y)); const Oe = T ? we.textCollisionBox : we.iconCollisionBox, Xe = we.collisionCircleArray; if (Xe.length > 0) { const He = i.ab.mat4.create(), ke = Ae; i.ab.mat4.mul(He, we.placementInvProjMatrix, F.glCoordMatrix), i.ab.mat4.mul(He, He, we.placementViewportMatrix), G.push({ circleArray: Xe, circleOffset: W, transform: ke, invTransform: He, projection: we.getProjection() }), Z += Xe.length / 4, W = Z; } Oe && (c.terrain && c.terrain.setupElevationDraw(xe, N), N.draw(c, R.LINES, Wt.disabled, ci.disabled, c.colorModeForRenderPass(), ti.disabled, dd(Ae, F, xe, we.getProjection()), s.id, Oe.layoutVertexBuffer, Oe.indexBuffer, Oe.segments, null, F.zoom, null, [Oe.collisionVertexBuffer, Oe.collisionVertexBufferExt])); } if (!T || !G.length) return; const te = c.getOrCreateProgram("collisionCircle"), ee = new i.cV(); ee.resize(4 * Z), ee._trim(); let se = 0; for (const pe of G) for (let Me = 0; Me < pe.circleArray.length / 4; Me++) { const xe = 4 * Me, we = pe.circleArray[xe + 0], ve = pe.circleArray[xe + 1], Ae = pe.circleArray[xe + 2], Oe = pe.circleArray[xe + 3]; ee.emplace(se++, we, ve, Ae, Oe, 0), ee.emplace(se++, we, ve, Ae, Oe, 1), ee.emplace(se++, we, ve, Ae, Oe, 2), ee.emplace(se++, we, ve, Ae, Oe, 3); } (!th || th.length < 2 * Z) && (th = function(pe) { const Me = 2 * pe, xe = new i.aU(); xe.resize(Me), xe._trim(); for (let we = 0; we < Me; we++) { const ve = 6 * we; xe.uint16[ve + 0] = 4 * we + 0, xe.uint16[ve + 1] = 4 * we + 1, xe.uint16[ve + 2] = 4 * we + 2, xe.uint16[ve + 3] = 4 * we + 2, xe.uint16[ve + 4] = 4 * we + 3, xe.uint16[ve + 5] = 4 * we + 0; } return xe; }(Z)); const oe = z.createIndexBuffer(th, !0), he = z.createVertexBuffer(ee, i.cW.members, !0); for (const pe of G) { const Me = { u_matrix: pe.transform, u_inv_matrix: pe.invTransform, u_camera_to_center_distance: (_e = F).getCameraToCenterDistance(pe.projection), u_viewport_size: [_e.width, _e.height] }; te.draw(c, R.TRIANGLES, Wt.disabled, ci.disabled, c.colorModeForRenderPass(), ti.disabled, Me, s.id, he, oe, i.b7.simpleSegment(0, 2 * pe.circleOffset, pe.circleArray.length, pe.circleArray.length / 2), null, F.zoom); } var _e; he.destroy(), oe.destroy(); } const oc = i.ab.mat4.create(); function au(c) { const t = c._camera.getWorldToCamera(c.worldSize, 1), s = i.ab.mat4.multiply([], t, c.globeMatrix); i.ab.mat4.invert(s, s); const h = [0, 0, 0], _ = [0, 1, 0, 0]; return i.ab.vec4.transformMat4(_, _, s), h[0] = _[0], h[1] = _[1], h[2] = _[2], i.ab.vec3.normalize(h, h), h; } function ep({ width: c, height: t, anchor: s, textOffset: h, textScale: _ }, y) { const { horizontalAlign: T, verticalAlign: z } = i.bD(s), R = -(T - 0.5) * c, F = -(z - 0.5) * t, N = i.bC(s, h); return new i.P((R / _ + N[0]) * y, (F / _ + N[1]) * y); } function co(c, t, s, h, _, y, T, z, R, F, N) { const G = c.text.placedSymbolArray, Z = c.text.dynamicLayoutVertexArray, W = c.icon.dynamicLayoutVertexArray, te = {}, ee = c.getProjection(), se = pa(z, ee, y), oe = y.elevation, he = ee.upVectorScale(z.canonical, y.center.lat, y.worldSize).metersToTile; Z.clear(); for (let _e = 0; _e < G.length; _e++) { const pe = G.get(_e), { tileAnchorX: Me, tileAnchorY: xe, numGlyphs: we } = pe, ve = pe.hidden || !pe.crossTileID || c.allowVerticalPlacement && !pe.placedOrientation ? null : h[pe.crossTileID]; if (ve) { let Ae = 0, Oe = 0, Xe = 0; if (oe) { const Je = oe ? oe.getAtTileOffset(z, Me, xe) : 0, [_t, ct, nt] = ee.upVector(z.canonical, Me, xe); Ae = Je * _t * he, Oe = Je * ct * he, Xe = Je * nt * he; } let [He, ke, Ne, st] = un(pe.projectedAnchorX + Ae, pe.projectedAnchorY + Oe, pe.projectedAnchorZ + Xe, s ? se : T); const ut = Bc(y.getCameraToCenterDistance(ee), st); let xt = _.evaluateSizeForFeature(c.textSizeData, F, pe) * ut / i.bw; s && (xt *= c.tilePixelRatio / R); const Ge = ep(ve, xt); s ? ({ x: He, y: ke, z: Ne } = ee.projectTilePoint(Me + Ge.x, xe + Ge.y, z.canonical), [He, ke, Ne] = un(He + Ae, ke + Oe, Ne + Xe, T)) : (t && Ge._rotate(-y.angle), He += Ge.x, ke += Ge.y, Ne = 0); const lt = c.allowVerticalPlacement && pe.placedOrientation === i.bq.vertical ? Math.PI / 2 : 0; for (let Je = 0; Je < we; Je++) i.bt(Z, He, ke, Ne, lt); N && pe.associatedIconIndex >= 0 && (te[pe.associatedIconIndex] = { x: He, y: ke, z: Ne, angle: lt }); } else fa(we, Z); } if (N) { W.clear(); const _e = c.icon.placedSymbolArray; for (let pe = 0; pe < _e.length; pe++) { const Me = _e.get(pe), { numGlyphs: xe } = Me, we = te[pe]; if (Me.hidden || !we) fa(xe, W); else { const { x: ve, y: Ae, z: Oe, angle: Xe } = we; for (let He = 0; He < xe; He++) i.bt(W, ve, Ae, Oe, Xe); } } c.icon.dynamicLayoutVertexBuffer.updateData(W); } c.text.dynamicLayoutVertexBuffer.updateData(Z); } function Tn(c, t, s, h, _, y, T = {}) { const z = s.paint.get("icon-translate"), R = s.paint.get("text-translate"), F = s.paint.get("icon-translate-anchor"), N = s.paint.get("text-translate-anchor"), G = s.layout.get("icon-rotation-alignment"), Z = s.layout.get("text-rotation-alignment"), W = s.layout.get("icon-pitch-alignment"), te = s.layout.get("text-pitch-alignment"), ee = s.layout.get("icon-keep-upright"), se = s.layout.get("text-keep-upright"), oe = s.paint.get("icon-color-saturation"), he = s.paint.get("icon-color-contrast"), _e = s.paint.get("icon-color-brightness-min"), pe = s.paint.get("icon-color-brightness-max"), Me = s.layout.get("symbol-elevation-reference") === "sea", xe = c.context, we = xe.gl, ve = c.transform, Ae = G === "map", Oe = Z === "map", Xe = W === "map", He = te === "map", ke = s.layout.get("symbol-sort-key").constantOr(1) !== void 0; let Ne = !1; const st = c.depthModeForSublayer(0, Wt.ReadOnly), ut = [i.at(ve.center.lng), i.aA(ve.center.lat)], xt = s.layout.get("text-variable-anchor"), Ge = ve.projection.name === "globe", lt = [], Je = [0, -1, 0]; for (const _t of h) { const ct = t.getTile(_t), nt = ct.getBucket(s); if (!nt || nt.projection.name === "mercator" && Ge || nt.fullyClipped) continue; const Lt = nt.projection.name === "globe", bt = Lt ? i.ae(ve.zoom) : 0, zt = pa(_t, nt.getProjection(), ve), Bt = ve.calculatePixelsToTileUnitsMatrix(ct), oi = xt && nt.hasTextData(), $t = nt.hasIconTextFit() && oi && nt.hasIconData(), Xt = nt.getProjection().createInversionMatrix(ve, _t.canonical), ai = (ji) => { ve.depthOcclusionForSymbolsAndCircles && (s.hasInitialOcclusionOpacityProperties || c.terrain) && (ji.push("DEPTH_D24"), ji.push("DEPTH_OCCLUSION")); }, zi = () => { const ji = Ae && s.layout.get("symbol-placement") !== "point", Yi = []; ai(Yi); const In = ji || $t, Fs = s.paint.get("icon-image-cross-fade").constantOr(0); c.terrainRenderModeElevated() && Xe && Yi.push("PITCH_WITH_MAP_TERRAIN"), Lt && (Yi.push("PROJECTION_GLOBE_VIEW"), In && Yi.push("PROJECTED_POS_ON_VIEWPORT")), Fs > 0 && Yi.push("ICON_TRANSITION"), nt.icon.zOffsetVertexBuffer && Yi.push("Z_OFFSET"), oe === 0 && he === 0 && _e === 0 && pe === 1 || Yi.push("COLOR_ADJUSTMENT"), nt.sdfIcons && Yi.push("RENDER_SDF"); const pr = nt.icon.programConfigurations.get(s.id), ts = c.getOrCreateProgram("symbol", { config: pr, defines: Yi }), Ps = ct.imageAtlasTexture ? ct.imageAtlasTexture.size : [0, 0], Qs = nt.iconSizeData, jn = i.bp(Qs, ve.zoom), dn = Xe || ve.pitch !== 0, _n = Js(zt, ct.tileID.canonical, Xe, Ae, ve, nt.getProjection(), Bt), Ri = Ss(zt, ct.tileID.canonical, Xe, Ae, ve, nt.getProjection(), Bt), Gn = c.translatePosMatrix(Ri, ct, z, F, !0), Bs = c.translatePosMatrix(zt, ct, z, F), cn = In ? oc : _n, er = Ae && !Xe && !ji; let eo = Je; !Ge && !ve.mercatorFromTransition || Ae || (eo = au(ve)); const Br = Lt ? eo : Je, Ma = s.getColorAdjustmentMatrix(oe, he, _e, pe), mr = Jf(Qs.kind, jn, er, Xe, c, Bs, cn, Gn, Me, !1, Ps, [0, 0], !0, _t, bt, ut, Xt, Br, nt.getProjection(), Ma, Fs), ko = ct.imageAtlasTexture ? ct.imageAtlasTexture : null, Nr = s.layout.get("icon-size").constantOr(0) !== 1 || nt.iconsNeedLinear, il = nt.sdfIcons || c.options.rotating || c.options.zooming || Nr || dn ? we.LINEAR : we.NEAREST, ia = nt.sdfIcons && s.paint.get("icon-halo-width").constantOr(1) !== 0, Ll = c.terrain && Xe && ji ? i.ab.mat4.invert(i.ab.mat4.create(), _n) : oc; if (ji && nt.icon) { const yh = ve.elevation, Pu = yh ? yh.getAtTileOffsetFunc(_t, ve.center.lat, ve.worldSize, nt.getProjection()) : null, Au = Ho(zt, ct.tileID.canonical, Xe, Ae, ve, nt.getProjection(), Bt); Zl(nt, zt, c, !1, Au, Ri, Xe, ee, Pu, _t); } return { program: ts, buffers: nt.icon, uniformValues: mr, atlasTexture: ko, atlasTextureIcon: null, atlasInterpolation: il, atlasInterpolationIcon: null, isSDF: nt.sdfIcons, hasHalo: ia, tile: ct, labelPlaneMatrixInv: Ll }; }, wi = () => { const ji = Oe && s.layout.get("symbol-placement") !== "point", Yi = [], In = ji || xt || $t; c.terrainRenderModeElevated() && He && Yi.push("PITCH_WITH_MAP_TERRAIN"), Lt && (Yi.push("PROJECTION_GLOBE_VIEW"), In && Yi.push("PROJECTED_POS_ON_VIEWPORT")), nt.text.zOffsetVertexBuffer && Yi.push("Z_OFFSET"), nt.iconsInText && Yi.push("RENDER_TEXT_AND_SYMBOL"), Yi.push("RENDER_SDF"), ai(Yi); const Fs = nt.text.programConfigurations.get(s.id), pr = c.getOrCreateProgram("symbol", { config: Fs, defines: Yi }); let ts, Ps = [0, 0], Qs = null; const jn = nt.textSizeData; nt.iconsInText && (Ps = ct.imageAtlasTexture ? ct.imageAtlasTexture.size : [0, 0], Qs = ct.imageAtlasTexture ? ct.imageAtlasTexture : null, ts = He || ve.pitch !== 0 || c.options.rotating || c.options.zooming || jn.kind === "composite" || jn.kind === "camera" ? we.LINEAR : we.NEAREST); const dn = ct.glyphAtlasTexture ? ct.glyphAtlasTexture.size : [0, 0], _n = s.layout.get("text-size-scale-range"), Ri = i.aw(c.scaleFactor, _n[0], _n[1]), Gn = i.bp(jn, ve.zoom, Ri), Bs = Js(zt, ct.tileID.canonical, He, Oe, ve, nt.getProjection(), Bt), cn = Ss(zt, ct.tileID.canonical, He, Oe, ve, nt.getProjection(), Bt), er = c.translatePosMatrix(cn, ct, R, N, !0), eo = c.translatePosMatrix(zt, ct, R, N), Br = In ? oc : Bs, Ma = Oe && !He && !ji; let mr = Je; !Ge && !ve.mercatorFromTransition || Oe || (mr = au(ve)); const ko = Jf(jn.kind, Gn, Ma, He, c, eo, Br, er, Me, !0, dn, Ps, !0, _t, bt, ut, Xt, Lt ? mr : Je, nt.getProjection(), null, null, Ri), Nr = ct.glyphAtlasTexture ? ct.glyphAtlasTexture : null, il = we.LINEAR, ia = s.paint.get("text-halo-width").constantOr(1) !== 0, Ll = c.terrain && He && ji ? i.ab.mat4.invert(i.ab.mat4.create(), Bs) : oc; if (ji && nt.text) { const yh = ve.elevation, Pu = yh ? yh.getAtTileOffsetFunc(_t, ve.center.lat, ve.worldSize, nt.getProjection()) : null, Au = Ho(zt, ct.tileID.canonical, He, Oe, ve, nt.getProjection(), Bt); Zl(nt, zt, c, !0, Au, cn, He, se, Pu, _t); } return { program: pr, buffers: nt.text, uniformValues: ko, atlasTexture: Nr, atlasTextureIcon: Qs, atlasInterpolation: il, atlasInterpolationIcon: ts, isSDF: !0, hasHalo: ia, tile: ct, labelPlaneMatrixInv: Ll }; }, mn = nt.icon.segments.get().length, Mn = nt.text.segments.get().length, Xi = mn && !T.onlyText ? zi() : null, sn = Mn && !T.onlyIcons ? wi() : null, _i = s.paint.get("icon-opacity").constantOr(1), Jt = s.paint.get("text-opacity").constantOr(1); if (ke && nt.canOverlap) { Ne = !0; const ji = _i && !T.onlyText ? nt.icon.segments.get() : [], Yi = Jt && !T.onlyIcons ? nt.text.segments.get() : []; for (const In of ji) lt.push({ segments: new i.b7([In]), sortKey: In.sortKey, state: Xi }); for (const In of Yi) lt.push({ segments: new i.b7([In]), sortKey: In.sortKey, state: sn }); } else T.onlyText || lt.push({ segments: _i ? nt.icon.segments : new i.b7([]), sortKey: 0, state: Xi }), T.onlyIcons || lt.push({ segments: Jt ? nt.text.segments : new i.b7([]), sortKey: 0, state: sn }); } Ne && lt.sort((_t, ct) => _t.sortKey - ct.sortKey); for (const _t of lt) { const ct = _t.state; if (ct) if (c.terrain ? c.terrain.setupElevationDraw(ct.tile, ct.program, { useDepthForOcclusion: ve.depthOcclusionForSymbolsAndCircles, labelPlaneMatrixInv: ct.labelPlaneMatrixInv }) : c.setupDepthForOcclusion(ve.depthOcclusionForSymbolsAndCircles, ct.program), xe.activeTexture.set(we.TEXTURE0), ct.atlasTexture && ct.atlasTexture.bind(ct.atlasInterpolation, we.CLAMP_TO_EDGE, !0), ct.atlasTextureIcon && (xe.activeTexture.set(we.TEXTURE1), ct.atlasTextureIcon && ct.atlasTextureIcon.bind(ct.atlasInterpolationIcon, we.CLAMP_TO_EDGE, !0)), c.uploadCommonLightUniforms(c.context, ct.program), ct.hasHalo) { const nt = ct.uniformValues; nt.u_is_halo = 1, ac(ct.buffers, _t.segments, s, c, ct.program, st, _, y, nt, 2), nt.u_is_halo = 0; } else { if (ct.isSDF) { const nt = ct.uniformValues; ct.hasHalo && (nt.u_is_halo = 1, ac(ct.buffers, _t.segments, s, c, ct.program, st, _, y, nt, 1)), nt.u_is_halo = 0; } ac(ct.buffers, _t.segments, s, c, ct.program, st, _, y, ct.uniformValues, 1); } } } function ac(c, t, s, h, _, y, T, z, R, F) { const N = [c.dynamicLayoutVertexBuffer, c.opacityVertexBuffer, c.iconTransitioningVertexBuffer, c.globeExtVertexBuffer, c.zOffsetVertexBuffer]; _.draw(h, h.context.gl.TRIANGLES, y, T, z, ti.disabled, R, s.id, c.layoutVertexBuffer, c.indexBuffer, t, s.paint, h.transform.zoom, c.programConfigurations.get(s.id), N, F); } function lu(c, t, s, h, _, y, T) { const z = c.context.gl, R = s.paint.get("fill-pattern"), F = s.is3D(), N = F ? c.stencilModeFor3D() : ci.disabled, G = R && R.constantOr(1); let Z, W, te, ee, se; T ? (W = G && !s.getPaintProperty("fill-outline-color") ? "fillOutlinePattern" : "fillOutline", Z = z.LINES) : (W = G ? "fillPattern" : "fill", Z = z.TRIANGLES); for (const oe of h) { const he = t.getTile(oe); if (G && !he.patternsLoaded()) continue; const _e = he.getBucket(s); if (!_e) continue; c.prepareDrawTile(); const pe = _e.programConfigurations.get(s.id), Me = c.isTileAffectedByFog(oe), xe = c.getOrCreateProgram(W, { config: pe, overrideFog: Me }); G && (c.context.activeTexture.set(z.TEXTURE0), he.imageAtlasTexture && he.imageAtlasTexture.bind(z.LINEAR, z.CLAMP_TO_EDGE), pe.updatePaintBuffers()); const we = R.constantOr(null); if (we && he.imageAtlas) { const Oe = he.imageAtlas, Xe = i.A.from(we), He = Oe.patternPositions[Xe.getSerializedPrimary()]; He && pe.setConstantPatternPositions(He); } const ve = c.translatePosMatrix(oe.projMatrix, he, s.paint.get("fill-translate"), s.paint.get("fill-translate-anchor")), Ae = s.paint.get("fill-emissive-strength"); if (T) { ee = _e.indexBuffer2, se = _e.segments2; const Oe = c.terrain && c.terrain.renderingToTexture ? c.terrain.drapeBufferSize : [z.drawingBufferWidth, z.drawingBufferHeight]; te = W === "fillOutlinePattern" && G ? nu(ve, Ae, c, he, Oe) : iu(ve, Ae, Oe); } else ee = _e.indexBuffer, se = _e.segments, te = G ? ud(ve, Ae, c, he) : sc(ve, Ae); c.uploadCommonUniforms(c.context, xe, oe.toUnwrapped()), xe.draw(c, Z, _, F ? N : c.stencilModeForClipping(oe), y, ti.disabled, te, s.id, _e.layoutVertexBuffer, ee, se, s.paint, c.transform.zoom, pe, void 0); } } function ih(c, t, s, h, _, y, T, z) { s.resetLayerRenderingStats(c); const R = c.context, F = R.gl, N = c.transform, G = s.paint.get("fill-extrusion-pattern"), Z = G.constantOr(1), W = s.paint.get("fill-extrusion-opacity"), te = c.style.enable3dLights(), ee = s.paint.get(te && !Z ? "fill-extrusion-ambient-occlusion-wall-radius" : "fill-extrusion-ambient-occlusion-radius"), se = [s.paint.get("fill-extrusion-ambient-occlusion-intensity"), ee], oe = s.layout.get("fill-extrusion-edge-radius"), he = oe > 0 && !s.paint.get("fill-extrusion-rounded-roof"), _e = he ? 0 : oe, pe = N.projection.name === "globe" ? i.d3() : 0, Me = N.projection.name === "globe", xe = Me ? i.ae(N.zoom) : 0, we = [i.at(N.center.lng), i.aA(N.center.lat)], ve = s.paint.get("fill-extrusion-flood-light-color-use-theme").constantOr("default") === "none", Ae = s.paint.get("fill-extrusion-flood-light-color").toRenderColor(ve ? null : s.lut).toArray01().slice(0, 3), Oe = s.paint.get("fill-extrusion-flood-light-intensity"), Xe = s.paint.get("fill-extrusion-vertical-scale"), He = s.paint.get("fill-extrusion-line-width").constantOr(1) !== 0, ke = s.paint.get("fill-extrusion-height-alignment"), Ne = s.paint.get("fill-extrusion-base-alignment"), st = Mo(c, s.paint.get("fill-extrusion-cutoff-fade-range")), ut = []; let xt; Me && ut.push("PROJECTION_GLOBE_VIEW"), se[0] > 0 && ut.push("FAUX_AO"), he && ut.push("ZERO_ROOF_RADIUS"), z && ut.push("HAS_CENTROID"), Oe > 0 && ut.push("FLOOD_LIGHT"), st.shouldRenderCutoff && ut.push("RENDER_CUTOFF"), He && ut.push("RENDER_WALL_MODE"); const Ge = c.renderPass === "shadow", lt = c.shadowRenderer, Je = Ge && !!lt; c.shadowRenderer && (c.shadowRenderer.useNormalOffset = !0); let _t = [0, 0, 0]; if (lt) { const Lt = c.style.directionalLight, bt = c.style.ambientLight; Lt && bt && (_t = cr(c.style, Lt, bt)), Ge || (ut.push("RENDER_SHADOWS", "DEPTH_TEXTURE"), lt.useNormalOffset && ut.push("NORMAL_OFFSET")), xt = ut.concat(["SHADOWS_SINGLE_CASCADE"]); } const ct = Je ? "fillExtrusionDepth" : Z ? "fillExtrusionPattern" : "fillExtrusion", nt = s.getLayerRenderingStats(); for (const Lt of h) { const bt = t.getTile(Lt), zt = bt.getBucket(s); if (!zt || zt.projection.name !== N.projection.name) continue; let Bt = !1; lt && (Bt = lt.getMaxCascadeForTile(Lt.toUnwrapped()) === 0); const oi = c.isTileAffectedByFog(Lt), $t = zt.programConfigurations.get(s.id), Xt = c.getOrCreateProgram(ct, { config: $t, defines: Bt ? xt : ut, overrideFog: oi }); if (c.terrain && c.terrain.setupElevationDraw(bt, Xt, { useMeterToDem: !0 }), !zt.centroidVertexBuffer) { const sn = Xt.attributes.a_centroid_pos; sn !== void 0 && F.vertexAttrib2f(sn, 0, 0); } !Ge && lt && lt.setupShadows(bt.tileID.toUnwrapped(), Xt, "vector-tile", bt.tileID.overscaledZ), Z && (c.context.activeTexture.set(F.TEXTURE0), bt.imageAtlasTexture && bt.imageAtlasTexture.bind(F.LINEAR, F.CLAMP_TO_EDGE), $t.updatePaintBuffers()); const ai = G.constantOr(null); if (ai && bt.imageAtlas) { const sn = bt.imageAtlas, _i = i.A.from(ai), Jt = sn.patternPositions[_i.getSerializedPrimary()]; Jt && $t.setConstantPatternPositions(Jt); } const zi = s.paint.get("fill-extrusion-vertical-gradient"), wi = 1 / zt.tileToMeter; let mn; if (Ge && lt) { if (yt(bt.tileID, zt, c)) continue; const sn = lt.calculateShadowPassMatrixFromTile(bt.tileID.toUnwrapped()); mn = Qc(sn, _e, wi, Xe, ke, Ne); } else { const sn = c.translatePosMatrix(Lt.expandedProjMatrix, bt, s.paint.get("fill-extrusion-translate"), s.paint.get("fill-extrusion-translate-anchor")), _i = N.projection.createInversionMatrix(N, Lt.canonical); mn = Z ? hd(sn, c, zi, W, se, _e, wi, Lt, bt, pe, ke, Ne, xe, we, _i, Ae, Xe) : tu(sn, c, zi, W, se, _e, wi, Lt, pe, ke, Ne, xe, we, _i, Ae, Xe, Oe, _t); } c.uploadCommonUniforms(R, Xt, Lt.toUnwrapped(), null, st); let Mn = zt.segments; if (N.projection.name === "mercator" && !Ge && (Mn = zt.getVisibleSegments(bt.tileID, c.terrain, c.transform.getFrustum(0)), !Mn.get().length)) continue; if (nt) if (Ge) for (const sn of Mn.get()) nt.numRenderedVerticesInShadowPass += sn.primitiveLength; else for (const sn of Mn.get()) nt.numRenderedVerticesInTransparentPass += sn.primitiveLength; const Xi = []; (c.terrain || z) && Xi.push(zt.centroidVertexBuffer), Me && Xi.push(zt.layoutVertexExtBuffer), He && Xi.push(zt.wallVertexBuffer), Xt.draw(c, R.gl.TRIANGLES, _, y, T, ti.backCCW, mn, s.id, zt.layoutVertexBuffer, zt.indexBuffer, Mn, s.paint, c.transform.zoom, $t, Xi); } c.shadowRenderer && (c.shadowRenderer.useNormalOffset = !1); } function Ml(c, t, s, h, _, y, T, z, R, F, N, G, Z, W, te, ee, se, oe, he) { const _e = c.context, pe = _e.gl, Me = c.transform, xe = c.transform.zoom, we = [], ve = Mo(c, s.paint.get("fill-extrusion-cutoff-fade-range")); F === "clear" ? (we.push("CLEAR_SUBPASS"), he && (we.push("CLEAR_FROM_TEXTURE"), _e.activeTexture.set(pe.TEXTURE0), he.bind(pe.LINEAR, pe.CLAMP_TO_EDGE))) : F === "sdf" && we.push("SDF_SUBPASS"), se && we.push("HAS_CENTROID"), ve.shouldRenderCutoff && we.push("RENDER_CUTOFF"); const Ae = s.layout.get("fill-extrusion-edge-radius"), Oe = (Xe, He, ke, Ne, st) => { const ut = He.programConfigurations.get(s.id), xt = c.isTileAffectedByFog(Xe), Ge = c.getOrCreateProgram("fillExtrusionGroundEffect", { config: ut, defines: we, overrideFog: xt }), lt = ((_t, ct, nt, Lt, bt, zt, Bt, oi, $t, Xt, ai) => ({ u_matrix: ct, u_opacity: nt, u_ao_pass: Lt ? 1 : 0, u_meter_to_tile: bt, u_ao: zt, u_flood_light_intensity: Bt, u_flood_light_color: oi, u_attenuation: $t, u_edge_radius: Xt, u_fb: 0, u_fb_size: ai, u_dynamic_offset: 1 }))(0, Ne, N, R, st, [G, Z * st], W, te, ee, xe >= 17 ? 0 : Ae * st, he ? he.size[0] : 0), Je = []; se && Je.push(He.hiddenByLandmarkVertexBuffer), c.uploadCommonUniforms(_e, Ge, Xe.toUnwrapped(), null, ve), Ge.draw(c, _e.gl.TRIANGLES, _, y, T, z, lt, s.id, He.vertexBuffer, He.indexBuffer, ke, s.paint, xe, ut, Je); }; for (const Xe of h) { const He = t.getTile(Xe), ke = He.getBucket(s); if (!ke || ke.projection.name !== Me.projection.name || !ke.groundEffect || ke.groundEffect && !ke.groundEffect.hasData()) continue; const Ne = ke.groundEffect, st = 1 / ke.tileToMeter; { const ut = c.translatePosMatrix(Xe.projMatrix, He, s.paint.get("fill-extrusion-translate"), s.paint.get("fill-extrusion-translate-anchor")), xt = Ne.getDefaultSegment(); Oe(Xe, Ne, xt, ut, st); } if (oe) for (let ut = 0; ut < 4; ut++) { const xt = i.d4[ut](Xe), Ge = t.getTile(xt); if (!Ge) continue; const lt = Ge.getBucket(s); if (!lt || lt.projection.name !== Me.projection.name || !lt.groundEffect || lt.groundEffect && !lt.groundEffect.hasData()) continue; const Je = lt.groundEffect; let _t, ct; ut === 0 ? (_t = [-i.ag, 0, 0], ct = 1) : ut === 1 ? (_t = [i.ag, 0, 0], ct = 0) : ut === 2 ? (_t = [0, -i.ag, 0], ct = 3) : (_t = [0, i.ag, 0], ct = 2); const nt = Je.regionSegments[ct]; if (!nt) continue; const Lt = new Float32Array(16); i.ab.mat4.translate(Lt, Xe.projMatrix, _t), Oe(Xe, Je, nt, c.translatePosMatrix(Lt, He, s.paint.get("fill-extrusion-translate"), s.paint.get("fill-extrusion-translate-anchor")), st); } } } function tp(c, t, s, h, _, y, T) { h.centroidVertexArray.length === 0 && h.createCentroidsBuffer(); const z = y ? y.findDEMTileFor(s) : null; if (!(z && z.dem || T)) return; y && z && z.dem && h.selfDEMTileTimestamp !== z.dem._timestamp && (h.borderDoneWithNeighborZ = [-1, -1, -1, -1], h.selfDEMTileTimestamp = z.dem._timestamp); const R = (oe) => new i.P(Math.ceil((oe + i.d7) * i.d8), 0), F = (oe) => { const he = t.getSource().minzoom, _e = (Me) => { const xe = t.getTileByID(Me); if (xe && xe.hasData()) return xe.getBucket(_); }, pe = [0, -1, 1]; for (const Me of pe) { if (oe.overscaledZ + Me < he) continue; const xe = _e(oe.calculateScaledKey(oe.overscaledZ + Me)); if (xe) return xe; } }, N = [0, 0, 0], G = (oe, he) => (N[0] = Math.min(oe.min.y, he.min.y), N[1] = Math.max(oe.max.y, he.max.y), N[2] = i.ag - he.min.x > oe.max.x ? he.min.x - i.ag : oe.max.x, N), Z = (oe, he) => (N[0] = Math.min(oe.min.x, he.min.x), N[1] = Math.max(oe.max.x, he.max.x), N[2] = i.ag - he.min.y > oe.max.y ? he.min.y - i.ag : oe.max.y, N), W = [(oe, he) => G(oe, he), (oe, he) => G(he, oe), (oe, he) => Z(oe, he), (oe, he) => Z(he, oe)], te = (oe, he, _e, pe, Me, xe, we) => { if (!y) return 0; const ve = [[xe ? _e : oe, xe ? oe : _e, 0], [xe ? _e : he, xe ? he : _e, 0]], Ae = we < 0 ? i.ag + we : we, Oe = [xe ? Ae : (oe + he) / 2, xe ? (oe + he) / 2 : Ae, 0]; return _e === 0 && we < 0 || _e !== 0 && we > 0 ? y.getForTilePoints(Me, [Oe], !0, pe) : ve.push(Oe), y.getForTilePoints(s, ve, !0, z), Math.max(ve[0][2], ve[1][2], Oe[2]) / y.exaggeration(); }; for (let oe = 0; oe < 4; oe++) { const he = h.borderFeatureIndices[oe]; if (he.length === 0) continue; const _e = i.d4[oe](s), pe = F(_e); if (!(pe && pe instanceof i.d5)) continue; const Me = y ? y.findDEMTileFor(_e) : null; if (!(Me && Me.dem || T) || (y && Me && Me.dem && h.borderDEMTileTimestamp[oe] !== Me.dem._timestamp && (h.borderDoneWithNeighborZ[oe] = -1, h.borderDEMTileTimestamp[oe] = Me.dem._timestamp), h.borderDoneWithNeighborZ[oe] === pe.canonical.z)) continue; pe.centroidVertexArray.length === 0 && pe.createCentroidsBuffer(); const xe = (oe < 2 ? 1 : 5) - oe, we = pe.borderDoneWithNeighborZ[xe] !== h.canonical.z, ve = pe.borderFeatureIndices[xe]; let Ae = 0; if (h.canonical.z !== pe.canonical.z) { for (const Oe of he) h.showCentroid(h.featuresOnBorder[Oe]); if (we) for (const Oe of ve) pe.showCentroid(pe.featuresOnBorder[Oe]); h.borderDoneWithNeighborZ[oe] = pe.canonical.z, pe.borderDoneWithNeighborZ[xe] = h.canonical.z; } for (const Oe of he) { const Xe = h.featuresOnBorder[Oe], He = h.centroidData[Xe.centroidDataIndex], ke = Xe.borders[oe]; let Ne; for (; Ae < ve.length; ) { Ne = pe.featuresOnBorder[ve[Ae]]; const st = Ne.borders[xe]; if (st[1] > ke[0] + 3 || st[0] > ke[0] - 3) break; pe.showCentroid(Ne), Ae++; } if (Ne && Ae < ve.length) { const st = Ae; let ut = 0; for (; !(Ne.borders[xe][0] > ke[1] - 3) && (ut++, ++Ae !== ve.length); ) Ne = pe.featuresOnBorder[ve[Ae]]; Ne = pe.featuresOnBorder[ve[st]]; let xt = !1; if (ut >= 1) { const Je = Ne.borders[xe]; Math.abs(ke[0] - Je[0]) < 3 && Math.abs(ke[1] - Je[1]) < 3 && (ut = 1, xt = !0, Ae = st + 1); } else if (ut === 0) { h.showCentroid(Xe); continue; } const Ge = pe.centroidData[Ne.centroidDataIndex]; T && xt && (((ee = He).flags | (se = Ge).flags) & i.d6 ? (ee.flags |= i.d6, se.flags |= i.d6) : (ee.flags &= ~i.d6, se.flags &= ~i.d6)); const lt = Xe.intersectsCount() > 1 || Ne.intersectsCount() > 1; if (ut > 1) Ae = st, He.centroidXY = Ge.centroidXY = new i.P(0, 0); else if (Me && Me.dem && !lt) { const Je = W[oe](He, Ge), _t = oe % 2 ? i.ag - 1 : 0, ct = te(Je[0], Math.min(i.ag - 1, Je[1]), _t, Me, _e, oe < 2, Je[2]); He.centroidXY = Ge.centroidXY = R(ct); } else lt ? He.centroidXY = Ge.centroidXY = new i.P(0, 0) : (He.centroidXY = h.encodeBorderCentroid(Xe), Ge.centroidXY = pe.encodeBorderCentroid(Ne)); h.writeCentroidToBuffer(He), pe.writeCentroidToBuffer(Ge); } else h.showCentroid(Xe); } h.borderDoneWithNeighborZ[oe] = pe.canonical.z, pe.borderDoneWithNeighborZ[xe] = h.canonical.z; } var ee, se; (h.needsCentroidUpdate || !h.centroidVertexBuffer && h.centroidVertexArray.length !== 0) && h.uploadCentroid(c); } const e_ = [1, 0, 0], lc = [0, 1, 0], cc = [0, 0, 1]; function yt(c, t, s) { const h = s.transform, _ = s.shadowRenderer; if (!_) return !0; const y = c.toUnwrapped(), T = h.tileSize * _._cascades[s.currentShadowCascade].scale; let z = t.maxHeight; if (h.elevation) { const ee = h.elevation.getMinMaxForTile(c); ee && (z += ee.max); } const R = [..._.shadowDirection]; R[2] = -R[2]; const F = _.computeSimplifiedTileShadowVolume(y, z, T, R); if (!F) return !1; const N = [e_, lc, cc, R, [R[0], 0, R[2]], [0, R[1], R[2]]], G = h.projection.name === "globe", Z = h.scaleZoom(T), W = i.bR.fromInvProjectionMatrix(h.invProjMatrix, h.worldSize, Z, !G), te = _.getCurrentCascadeFrustum(); return W.intersectsPrecise(F.vertices, F.planes, N) === 0 || te.intersectsPrecise(F.vertices, F.planes, N) === 0; } function Dt(c) { return [c[0] * i.d9, c[1] * i.d9, c[2] * i.d9, 0]; } function Wa(c, t, s, h, _, y, T, z, R) { const F = h.getSource(), N = s.globeSharedBuffers; if (!N) return; let G, Z, W; if (t && (G = h.getTile(t)), F instanceof i.aJ ? (Z = F.texture, W = i.cI(0, 0, s.transform)) : G && t && (Z = G.texture, W = i.cI(t.canonical.z, t.canonical.x, s.transform)), !Z || !W) return; c || (W = i.ab.mat4.scale(i.ab.mat4.create(), W, [1, -1, 1])); const te = s.context, ee = te.gl, se = _.paint.get("raster-resampling") === "nearest" ? ee.NEAREST : ee.LINEAR, oe = s.colorModeForDrapableLayerRenderPass(y), he = T.defines; he.push("GLOBE_POLES"); const _e = new Wt(ee.LEQUAL, Wt.ReadWrite, s.depthRangeFor3D), pe = Float32Array.from(s.transform.expandedFarZProjMatrix), Me = Float32Array.from(i.bb(i.cH(new i.bT(0, 0, 0)))); s.terrain && s.terrain.prepareDrawTile(), te.activeTexture.set(ee.TEXTURE0), Z.bind(se, ee.CLAMP_TO_EDGE), te.activeTexture.set(ee.TEXTURE1), Z.bind(se, ee.CLAMP_TO_EDGE), Z.useMipmap && te.extTextureFilterAnisotropic && s.transform.pitch > 20 && ee.texParameterf(ee.TEXTURE_2D, te.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, te.extTextureFilterAnisotropicMax); const [xe, we, ve, Ae] = t ? N.getPoleBuffers(t.canonical.z, !1) : N.getPoleBuffers(0, !0), Oe = _.paint.get("raster-elevation"); let Xe; c ? (Xe = xe, s.renderDefaultNorthPole = Oe !== 0) : (Xe = we, s.renderDefaultSouthPole = Oe !== 0); const He = Dt(T.mix), ke = ((st, ut, xt, Ge, lt, Je, _t, ct, nt, Lt, bt, zt, Bt) => pd(st, ut, xt, new Float32Array(16), new Float32Array(9), [0, 0], Ge, [0, 0], [0, 0, 0, 0], 1, { opacity: 1, mix: 0 }, Je, [0, 0], ct, 2, Lt, bt, zt, 1, 0, Bt))(pe, Me, W, i.ae(s.transform.zoom), 0, _, 0, Oe, 0, He, T.offset, T.range, y), Ne = s.getOrCreateProgram("raster", { defines: he }); s.uploadCommonUniforms(te, Ne, null), Ne.draw(s, ee.TRIANGLES, _e, R, oe, z, ke, _.id, Xe, ve, Ae); } function Bn(c) { const t = c._nearZ, s = c.projection.farthestPixelDistance(c), h = s - t, _ = 0.2 * c.height, y = t + _; return [t, s, (y - _ - t) / h, (y - t) / h]; } function $e(c, t, s, h) { if (c) return t instanceof xn && c instanceof ka ? t.getTextureDescriptor(c, s, !0) : { texture: c.texture, mix: Dt(h.mix), offset: h.offset, buffer: 0, tileSize: 1 }; } var ip = i.da([{ name: "a_index", type: "Int16", components: 1 }]); class cu { constructor(t, s, h, _) { const y = { width: h[0], height: h[1], data: null }, T = t.gl; this.targetColorTexture = new i.T(t, y, T.RGBA8, { useMipmap: !1 }), this.backgroundColorTexture = new i.T(t, y, T.RGBA8, { useMipmap: !1 }), this.context = t, this.updateParticleTexture(s, _), this.lastInvalidatedAt = 0; } updateParticleTexture(t, s) { if (this.particleTextureDimension === s.width) return; (this.particleTexture0 || this.particleTexture1 || this.particleIndexBuffer || this.particleSegment) && (this.particleTexture0.destroy(), this.particleTexture1.destroy(), this.particleIndexBuffer.destroy(), this.particleSegment.destroy()); const h = this.context.gl, _ = s.width * s.height; this.particleTexture0 = new i.T(this.context, s, h.RGBA8, { premultiply: !1, useMipmap: !1 }), this.particleTexture1 = new i.T(this.context, s, h.RGBA8, { premultiply: !1, useMipmap: !1 }); const y = new i.db(); y.reserve(_); for (let T = 0; T < _; T++) y.emplaceBack(T); this.particleIndexBuffer = this.context.createVertexBuffer(y, ip.members, !0), this.particleSegment = i.b7.simpleSegment(0, 0, this.particleIndexBuffer.length, 0), this.particleTextureDimension = s.width; } update(t) { return !(this.lastInvalidatedAt < t && (this.lastInvalidatedAt = i.q.now(), 1)); } destroy() { this.targetColorTexture.destroy(), this.backgroundColorTexture.destroy(), this.particleIndexBuffer.destroy(), this.particleTexture0.destroy(), this.particleTexture1.destroy(), this.particleSegment.destroy(); } } function bd(c, t, s) { if (!c) return null; const h = t.getTextureDescriptor(c, s, !0); if (!h) return null; let { texture: _, mix: y, offset: T, tileSize: z, buffer: R, format: F } = h; if (!_ || !F) return null; let N = !1; return F === "uint32" && (N = !0, y[3] = 0, y = eh(i.dc, y, [0, s.paint.get("raster-particle-max-speed")]), T = Ft(i.dc, T, [0, s.paint.get("raster-particle-max-speed")])), { texture: _, textureOffset: [R / (z + 2 * R), z / (z + 2 * R)], tileSize: z, scalarData: N, scale: y, offset: T, defines: ["RASTER_ARRAY", { uint8: "DATA_FORMAT_UINT8", uint16: "DATA_FORMAT_UINT16", uint32: "DATA_FORMAT_UINT32" }[F]] }; } function np(c) { const t = c._nearZ, s = c.projection.farthestPixelDistance(c), h = s - t, _ = 0.2 * c.height, y = t + _; return [t, s, (y - _ - t) / h, (y - t) / h]; } const sp = new i.aj(1, 0, 0, 1), rp = new i.aj(0, 1, 0, 1), hc = new i.aj(0, 0, 1, 1), t_ = new i.aj(1, 0, 1, 1), i_ = new i.aj(0, 1, 1, 1); function Sl(c, t, s, h, _, y, T) { const z = c.context, R = c.transform, F = z.gl, N = R.projection.name === "globe", G = N ? ["PROJECTION_GLOBE_VIEW"] : []; let Z = i.ab.mat4.clone(s.projMatrix); if (N && i.ae(R.zoom) > 0) { const He = i.ba(s.canonical, R), ke = i.dd(He); Z = i.ab.mat4.multiply(new Float32Array(16), R.globeMatrix, ke), i.ab.mat4.multiply(Z, R.projMatrix, Z); } const W = i.ab.mat4.create(); W[12] += 2 * _ / (i.q.devicePixelRatio * R.width), W[13] += 2 * y / (i.q.devicePixelRatio * R.height), i.ab.mat4.multiply(Z, W, Z); const te = c.getOrCreateProgram("debug", { defines: G }), ee = t.getTileByID(s.key); c.terrain && c.terrain.setupElevationDraw(ee, te); const se = Wt.disabled, oe = ci.disabled, he = c.colorModeForRenderPass(), _e = "$debug"; z.activeTexture.set(F.TEXTURE0), c.emptyTexture.bind(F.LINEAR, F.CLAMP_TO_EDGE), N ? ee._makeGlobeTileDebugBuffers(c.context, R) : ee._makeDebugTileBoundsBuffers(c.context, R.projection); const pe = ee._tileDebugBuffer || c.debugBuffer, Me = ee._tileDebugIndexBuffer || c.debugIndexBuffer, xe = ee._tileDebugSegments || c.debugSegments; if (te.draw(c, F.LINE_STRIP, se, oe, he, ti.disabled, fd(Z, h), _e, pe, Me, xe, null, null, null, [ee._globeTileDebugBorderBuffer]), T) { const He = ee.latestRawTileData, ke = Math.floor((He && He.byteLength || 0) / 1024); let Ne = s.canonical.toString(); s.overscaledZ !== s.canonical.z && (Ne += ` => ${s.overscaledZ}`), Ne += ` ${ee.state}`, Ne += ` ${ke}kb`, function(st, ut) { st.initDebugOverlayCanvas(); const xt = st.debugOverlayCanvas, Ge = st.context.gl, lt = st.debugOverlayCanvas.getContext("2d"); lt.clearRect(0, 0, xt.width, xt.height), lt.shadowColor = "white", lt.shadowBlur = 2, lt.lineWidth = 1.5, lt.strokeStyle = "white", lt.textBaseline = "top", lt.font = "bold 36px Open Sans, sans-serif", lt.fillText(ut, 5, 5), lt.strokeText(ut, 5, 5), st.debugOverlayTexture.update(xt), st.debugOverlayTexture.bind(Ge.LINEAR, Ge.CLAMP_TO_EDGE); }(c, Ne); } const we = t.getTile(s).tileSize, ve = 512 / Math.min(we, 512) * (s.overscaledZ / R.zoom) * 0.5, Ae = ee._tileDebugTextBuffer || c.debugBuffer, Oe = ee._tileDebugTextIndexBuffer || c.quadTriangleIndexBuffer, Xe = ee._tileDebugTextSegments || c.debugSegments; te.draw(c, F.TRIANGLES, se, oe, bi.alphaBlended, ti.disabled, fd(Z, i.aj.transparent, ve), _e, Ae, Oe, Xe, null, null, null, [ee._globeTileDebugTextBuffer]); } function nh(c, t, s, h) { sh(c, 0, t + s / 2, c.transform.width, s, h); } function hu(c, t, s, h) { sh(c, t - s / 2, 0, s, c.transform.height, h); } function sh(c, t, s, h, _, y) { const T = c.context, z = T.gl; z.enable(z.SCISSOR_TEST), z.scissor(t * i.q.devicePixelRatio, s * i.q.devicePixelRatio, h * i.q.devicePixelRatio, _ * i.q.devicePixelRatio), T.clear({ color: y }), z.disable(z.SCISSOR_TEST); } const op = i.da([{ name: "a_pos_3f", components: 3, type: "Float32" }]), { members: uu } = op; function Co(c, t, s, h) { c.emplaceBack(t, s, h); } class Io { constructor(t) { this.vertexArray = new i.de(), this.indices = new i.aU(), Co(this.vertexArray, -1, -1, 1), Co(this.vertexArray, 1, -1, 1), Co(this.vertexArray, -1, 1, 1), Co(this.vertexArray, 1, 1, 1), Co(this.vertexArray, -1, -1, -1), Co(this.vertexArray, 1, -1, -1), Co(this.vertexArray, -1, 1, -1), Co(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, uu), this.indexBuffer = t.createIndexBuffer(this.indices), this.segment = i.b7.simpleSegment(0, 0, 36, 12); } } function El(c, t, s, h, _, y) { const T = c.context.gl, z = t.paint.get("sky-atmosphere-color"), R = t.paint.get("sky-atmosphere-halo-color"), F = t.paint.get("sky-atmosphere-sun-intensity"), N = ((G, Z, W, te, ee) => ({ u_matrix_3f: G, u_sun_direction: Z, u_sun_intensity: W, u_color_tint_r: [te.r, te.g, te.b, te.a], u_color_tint_m: [ee.r, ee.g, ee.b, ee.a], u_luminance: 5e-5 }))(i.ab.mat3.fromMat4(i.ab.mat3.create(), h), _, F, z, R); T.framebufferTexture2D(T.FRAMEBUFFER, T.COLOR_ATTACHMENT0, T.TEXTURE_CUBE_MAP_POSITIVE_X + y, t.skyboxTexture, 0), s.draw(c, T.TRIANGLES, Wt.disabled, ci.disabled, bi.unblended, ti.frontCW, N, "skyboxCapture", t.skyboxGeometry.vertexBuffer, t.skyboxGeometry.indexBuffer, t.skyboxGeometry.segment); } const n_ = i.da([{ type: "Float32", name: "a_pos", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }]); class wr { constructor(t) { const s = new i.df(); s.emplaceBack(-1, 1, 1, 0, 0), s.emplaceBack(1, 1, 1, 1, 0), s.emplaceBack(1, -1, 1, 1, 1), s.emplaceBack(-1, -1, 1, 0, 1); const h = new i.aU(); h.emplaceBack(0, 1, 2), h.emplaceBack(2, 3, 0), this.vertexBuffer = t.createVertexBuffer(s, n_.members), this.indexBuffer = t.createIndexBuffer(h), this.segments = i.b7.simpleSegment(0, 0, 4, 2); } destroy() { this.vertexBuffer.destroy(), this.indexBuffer.destroy(), this.segments.destroy(); } } const s_ = i.da([{ type: "Float32", name: "a_pos_3f", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }, { type: "Float32", name: "a_size_scale", components: 1 }, { type: "Float32", name: "a_fade_opacity", components: 1 }]); class rh { constructor() { this.starsCount = 16e3, this.sizeMultiplier = 0.15, this.sizeRange = 100, this.intensityRange = 200; } } class bn { constructor(t) { this.colorModeAlphaBlendedWriteRGB = new bi([1, Xo, 1, Xo], i.aj.transparent, [!0, !0, !0, !1]), this.colorModeWriteAlpha = new bi([1, 0, 1, 0], i.aj.transparent, [!1, !1, !1, !0]), this.params = new rh(), this.updateNeeded = !0, t.tp.registerParameter(this.params, ["Stars"], "starsCount", { min: 100, max: 16e3, step: 1 }, () => { this.updateNeeded = !0; }), t.tp.registerParameter(this.params, ["Stars"], "sizeMultiplier", { min: 0.01, max: 2, step: 0.01 }), t.tp.registerParameter(this.params, ["Stars"], "sizeRange", { min: 0, max: 200, step: 1 }, () => { this.updateNeeded = !0; }), t.tp.registerParameter(this.params, ["Stars"], "intensityRange", { min: 0, max: 200, step: 1 }, () => { this.updateNeeded = !0; }); } update(t) { const s = t.context; if (!this.atmosphereBuffer || this.updateNeeded) { this.updateNeeded = !1, this.atmosphereBuffer = new wr(s); const h = this.params.sizeRange, _ = this.params.intensityRange, y = function(N) { const G = i.di(30), Z = []; for (let W = 0; W < N; ++W) { const te = 2 * Math.PI * G(), ee = Math.acos(1 - 2 * G()) - 0.5 * Math.PI; Z.push(i.ab.vec3.fromValues(Math.cos(ee) * Math.cos(te), Math.cos(ee) * Math.sin(te), Math.sin(ee))); } return Z; }(this.params.starsCount), T = i.di(300), z = new i.dg(), R = new i.aU(); let F = 0; for (let N = 0; N < y.length; ++N) { const G = i.ab.vec3.scale([], y[N], 200), Z = Math.max(0, 1 + 0.01 * h * (1 * T() - 0.5)), W = Math.max(0, 1 + 0.01 * _ * (1 * T() - 0.5)); z.emplaceBack(G[0], G[1], G[2], -1, -1, Z, W), z.emplaceBack(G[0], G[1], G[2], 1, -1, Z, W), z.emplaceBack(G[0], G[1], G[2], 1, 1, Z, W), z.emplaceBack(G[0], G[1], G[2], -1, 1, Z, W), R.emplaceBack(F + 0, F + 1, F + 2), R.emplaceBack(F + 0, F + 2, F + 3), F += 4; } this.starsVx = s.createVertexBuffer(z, s_.members), this.starsIdx = s.createIndexBuffer(R), this.starsSegments = i.b7.simpleSegment(0, 0, z.length, R.length); } } destroy() { this.atmosphereBuffer && this.atmosphereBuffer.destroy(), this.starsVx && this.starsVx.destroy(), this.starsIdx && this.starsIdx.destroy(); } drawAtmosphereGlow(t, s) { const h = t.context, _ = h.gl, y = t.transform, T = new Wt(_.LEQUAL, Wt.ReadOnly, [0, 1]), z = i.ae(y.zoom), R = t.style.getLut(s.scope), F = s.properties.get("color-use-theme") === "none", N = s.properties.get("color").toRenderColor(F ? null : R).toArray01(), G = s.properties.get("high-color-use-theme") === "none", Z = s.properties.get("high-color").toRenderColor(G ? null : R).toArray01(), W = s.properties.get("space-color-use-theme") === "none", te = s.properties.get("space-color").toRenderColor(W ? null : R).toArray01PremultipliedAlpha(), ee = 5e-4, se = i.dh(s.properties.get("horizon-blend"), 0, 1, ee, 0.25), oe = i.cC(t, h, y) && se === ee ? y.worldSize / (2 * Math.PI * 1.025) - 1 : y.globeRadius, he = t.frameCounter / 1e3 % 1, _e = i.ab.vec3.length(y.globeCenterInViewSpace), pe = Math.sqrt(Math.pow(_e, 2) - Math.pow(oe, 2)), Me = Math.acos(pe / _e), xe = (we) => { const ve = y.projection.name === "globe" ? ["PROJECTION_GLOBE_VIEW", "FOG"] : ["FOG"]; we && ve.push("ALPHA_PASS"); const Ae = t.getOrCreateProgram("globeAtmosphere", { defines: ve }), Oe = ((He, ke, Ne, st, ut, xt, Ge, lt, Je, _t, ct, nt) => ({ u_frustum_tl: He, u_frustum_tr: ke, u_frustum_br: Ne, u_frustum_bl: st, u_horizon: ut, u_transition: xt, u_fadeout_range: Ge, u_color: lt, u_high_color: Je, u_space_color: _t, u_temporal_offset: ct, u_horizon_angle: nt }))(y.frustumCorners.TL, y.frustumCorners.TR, y.frustumCorners.BR, y.frustumCorners.BL, y.frustumCorners.horizon, z, se, N, Z, te, he, Me); t.uploadCommonUniforms(h, Ae); const Xe = this.atmosphereBuffer; Xe && Ae.draw(t, _.TRIANGLES, T, ci.disabled, we ? this.colorModeWriteAlpha : this.colorModeAlphaBlendedWriteRGB, ti.backCW, Oe, we ? "atmosphere_glow_alpha" : "atmosphere_glow", Xe.vertexBuffer, Xe.indexBuffer, Xe.segments); }; xe(!1), xe(!0); } drawStars(t, s) { const h = i.aw(s.properties.get("star-intensity"), 0, 1); if (h === 0) return; const _ = t.context, y = _.gl, T = t.transform, z = t.getOrCreateProgram("stars"), R = i.ab.quat.identity([]); i.ab.quat.rotateX(R, R, -T._pitch), i.ab.quat.rotateZ(R, R, -T.angle), i.ab.quat.rotateX(R, R, i.ai(T._center.lat)), i.ab.quat.rotateY(R, R, -i.ai(T._center.lng)); const F = i.ab.mat4.fromQuat(new Float32Array(16), R), N = i.ab.mat4.multiply([], T.starsProjMatrix, F), G = i.ab.mat3.fromMat4([], F), Z = i.ab.mat3.invert([], G), W = [0, 1, 0]; i.ab.vec3.transformMat3(W, W, Z), i.ab.vec3.scale(W, W, this.params.sizeMultiplier); const te = [1, 0, 0]; i.ab.vec3.transformMat3(te, te, Z), i.ab.vec3.scale(te, te, this.params.sizeMultiplier); const ee = (se = W, oe = te, he = h, { u_matrix: Float32Array.from(N), u_up: se, u_right: oe, u_intensity_multiplier: he }); var se, oe, he; t.uploadCommonUniforms(_, z), this.starsVx && this.starsIdx && z.draw(t, y.TRIANGLES, Wt.disabled, ci.disabled, this.colorModeAlphaBlendedWriteRGB, ti.disabled, ee, "atmosphere_stars", this.starsVx, this.starsIdx, this.starsSegments); } } function qi(c, t) { const s = [...c], h = t.cameraWorldSizeForFog / t.worldSize, _ = i.ab.mat4.identity([]); return i.ab.mat4.scale(_, _, [h, h, 1]), i.ab.mat4.multiply(s, _, s), i.ab.mat4.multiply(s, t.worldToFogMatrix, s), s; } function du(c, t, s, h, _) { const y = s.material, T = h.context, { baseColorTexture: z, metallicRoughnessTexture: R } = y.pbrMetallicRoughness, { normalTexture: F, occlusionTexture: N, emissionTexture: G } = y; function Z(te, ee, se) { if (te && (c.push(ee), T.activeTexture.set(T.gl.TEXTURE0 + se), te.gfxTexture)) { const { minFilter: oe, magFilter: he, wrapS: _e, wrapT: pe } = te.sampler; te.gfxTexture.bindExtraParam(oe, he, _e, pe); } } Z(z, "HAS_TEXTURE_u_baseColorTexture", bs.BaseColor), Z(R, "HAS_TEXTURE_u_metallicRoughnessTexture", bs.MetallicRoughness), Z(F, "HAS_TEXTURE_u_normalTexture", bs.Normal), Z(N, "HAS_TEXTURE_u_occlusionTexture", bs.Occlusion), Z(G, "HAS_TEXTURE_u_emissionTexture", bs.Emission), _ && (_.texture || (_.texture = new i.dk(h.context, _.image, [_.image.height, _.image.height, _.image.height], T.gl.RGBA8)), T.activeTexture.set(T.gl.TEXTURE0 + bs.LUT), _.texture && _.texture.bind(T.gl.LINEAR, T.gl.CLAMP_TO_EDGE), c.push("APPLY_LUT_ON_GPU")), s.texcoordBuffer && (c.push("HAS_ATTRIBUTE_a_uv_2f"), t.push(s.texcoordBuffer)), s.colorBuffer && (c.push(s.colorBuffer.itemSize === 12 ? "HAS_ATTRIBUTE_a_color_3f" : "HAS_ATTRIBUTE_a_color_4f"), t.push(s.colorBuffer)), s.normalBuffer && (c.push("HAS_ATTRIBUTE_a_normal_3f"), t.push(s.normalBuffer)), s.pbrBuffer && (c.push("HAS_ATTRIBUTE_a_pbr"), c.push("HAS_ATTRIBUTE_a_heightBasedEmissiveStrength"), t.push(s.pbrBuffer)), y.alphaMode !== "OPAQUE" && y.alphaMode !== "MASK" || c.push("UNPREMULT_TEXTURE_IN_SHADER"), y.defined || c.push("DIFFUSE_SHADED"), c.push("USE_STANDARD_DERIVATIVES"); const W = h.shadowRenderer; W && (c.push("RENDER_SHADOWS", "DEPTH_TEXTURE"), W.useNormalOffset && c.push("NORMAL_OFFSET")); } function Lo(c, t, s, h, _, y) { const T = s.paint.get("model-opacity").constantOr(1), z = t.context, R = new Wt(t.context.gl.LEQUAL, Wt.ReadWrite, t.depthRangeFor3D), F = t.transform, N = c.mesh, G = N.material, Z = G.pbrMetallicRoughness, W = t.style.fog; let te; te = t.transform.projection.zAxisUnit === "pixels" ? [...c.nodeModelMatrix] : i.ab.mat4.multiply([], h.zScaleMatrix, c.nodeModelMatrix), i.ab.mat4.multiply(te, h.negCameraPosMatrix, te); const ee = i.ab.mat4.invert([], te); i.ab.mat4.transpose(ee, ee); const se = s.paint.get("model-color-use-theme").constantOr("default") === "none", oe = s.paint.get("model-emissive-strength").constantOr(0), he = gd(new Float32Array(c.worldViewProjection), new Float32Array(te), new Float32Array(ee), null, t, T, Z.baseColorFactor.toRenderColor(null), G.emissiveFactor, Z.metallicFactor, Z.roughnessFactor, G, oe, s), _e = { defines: [] }, pe = [], Me = t.shadowRenderer; Me && (Me.useNormalOffset = !1), du(_e.defines, pe, N, t, se ? null : s.lut); let xe = null; if (W) { const Ae = qi(c.nodeModelMatrix, t.transform); if (xe = new Float32Array(Ae), F.projection.name !== "globe") { const Oe = N.aabb.min, Xe = N.aabb.max, [He, ke] = W.getOpacityForBounds(Ae, Oe[0], Oe[1], Xe[0], Xe[1]); _e.overrideFog = He >= It || ke >= It; } } const we = Mo(t, s.paint.get("model-cutoff-fade-range")); we.shouldRenderCutoff && _e.defines.push("RENDER_CUTOFF"); const ve = t.getOrCreateProgram("model", _e); t.uploadCommonUniforms(z, ve, null, xe, we), t.renderPass !== "shadow" && Me && Me.setupShadowsFromMatrix(c.nodeModelMatrix, ve), ve.draw(t, z.gl.TRIANGLES, R, _, y, N.material.doubleSided ? ti.disabled : ti.backCCW, he, s.id, N.vertexBuffer, N.indexBuffer, N.segments, s.paint, t.transform.zoom, void 0, pe); } function oh(c, t, s, h, _, y, T) { let z; z = c.projection.name === "globe" ? i.dl(s, c) : [...s], i.ab.mat4.multiply(z, z, t.matrix); const R = i.ab.mat4.multiply([], h, z); if (t.meshes) for (const F of t.meshes) { if (F.material.alphaMode !== "BLEND") { T.push({ mesh: F, depth: 0, modelIndex: _, worldViewProjection: R, nodeModelMatrix: z }); continue; } const N = i.ab.vec3.transformMat4([], F.centroid, R); N[2] > 0 && y.push({ mesh: F, depth: N[2], modelIndex: _, worldViewProjection: R, nodeModelMatrix: z }); } if (t.children) for (const F of t.children) oh(c, F, s, h, _, y, T); } function $a(c, t, s, h) { const _ = s.shadowRenderer; if (!_) return; const y = _.getShadowPassDepthMode(), T = _.getShadowPassColorMode(), z = _.calculateShadowPassMatrixFromMatrix(t), R = Qf(z); s.getOrCreateProgram("modelDepth", { defines: s._shadowMapDebug ? [] : ["DEPTH_TEXTURE"] }).draw(s, s.context.gl.TRIANGLES, y, ci.disabled, T, ti.backCCW, R, h.id, c.vertexBuffer, c.indexBuffer, c.segments, h.paint, s.transform.zoom, void 0, void 0); } function wd(c, t, s) { const h = t.updateZoomBasedPaintProperties(), _ = function(y, T, z) { let R, F, N, G = y.terrain ? y.terrain.exaggeration() : 0; if (y.terrain && G > 0) { const Z = y.terrain, W = Z.findDEMTileFor(z); W && W.dem ? R = i.dn.create(Z, z, W) : G = 0; } if (G === 0 && (T.terrainElevationMin = 0, T.terrainElevationMax = 0), G === T.validForExaggeration && (G === 0 || R && R._demTile && R._demTile.tileID === T.validForDEMTile.id && R._dem._timestamp === T.validForDEMTile.timestamp)) return !1; for (const Z in T.instancesPerModel) { const W = T.instancesPerModel[Z]; for (let te = 0; te < W.instancedDataArray.length; ++te) { const ee = (R ? G * R.getElevationAt(0 | W.instancedDataArray.float32[16 * te], 0 | W.instancedDataArray.float32[16 * te + 1], !0, !0) : 0) + W.instancesEvaluatedElevation[te]; W.instancedDataArray.float32[16 * te + 6] = ee, F = F ? Math.min(T.terrainElevationMin, ee) : ee, N = N ? Math.max(T.terrainElevationMax, ee) : ee; } } return T.terrainElevationMin = F || 0, T.terrainElevationMax = N || 0, T.validForExaggeration = G, T.validForDEMTile = R && R._demTile ? { id: R._demTile.tileID, timestamp: R._dem._timestamp } : { id: void 0, timestamp: 0 }, !0; }(c, t, s); (h || _) && (t.uploaded = !1, t.upload(c.context)); } const ho = { shadowUniformsInitialized: !1, useSingleShadowCascade: !1, tileMatrix: new Float64Array(16), shadowTileMatrix: new Float32Array(16), aabb: new i.cd([0, 0, 0], [i.ag, i.ag, 0]) }; function Xa(c, t) { const s = 1 << c.canonical.z, h = t.getFreeCameraOptions().position, _ = t.elevation, y = c.canonical.x / s, T = (c.canonical.x + 1) / s, z = c.canonical.y / s, R = (c.canonical.y + 1) / s; let F = t._centerAltitude; if (_) { const W = _.getMinMaxForTile(c); W && W.max > F && (F = W.max); } const N = i.aw(h.x, y, T) - h.x, G = i.aw(h.y, z, R) - h.y, Z = i.bH(F, t.center.lat) - h.z; return t._zoomFromMercatorZ(Math.sqrt(N * N + G * G + Z * Z)); } function va(c, t, s, h, _, y, T) { const z = c.context, R = c.renderPass === "shadow", F = c.shadowRenderer, N = R && F ? F.getShadowPassDepthMode() : new Wt(z.gl.LEQUAL, Wt.ReadWrite, c.depthRangeFor3D), G = c.isTileAffectedByFog(y); if (s.meshes) for (const Z of s.meshes) { const W = ["MODEL_POSITION_ON_GPU"], te = []; let ee, se, oe; h.instancedDataArray.length > 20 && W.push("INSTANCED_ARRAYS"); const he = Mo(c, t.paint.get("model-cutoff-fade-range")); if (he.shouldRenderCutoff && W.push("RENDER_CUTOFF"), R && F) ee = c.getOrCreateProgram("modelDepth", { defines: W }), se = Qf(T.shadowTileMatrix, T.shadowTileMatrix, Float32Array.from(s.matrix)), oe = F.getShadowPassColorMode(); else { du(W, te, Z, c, t.paint.get("model-color-use-theme").constantOr("default") === "none" ? null : t.lut), ee = c.getOrCreateProgram("model", { defines: W, overrideFog: G }); const pe = Z.material, Me = pe.pbrMetallicRoughness, xe = t.paint.get("model-opacity").constantOr(1), we = t.paint.get("model-emissive-strength").constantOr(0); se = gd(y.expandedProjMatrix, Float32Array.from(s.matrix), new Float32Array(16), null, c, xe, Me.baseColorFactor.toRenderColor(null), pe.emissiveFactor, Me.metallicFactor, Me.roughnessFactor, pe, we, t, _), F && (T.shadowUniformsInitialized ? ee.setShadowUniformValues(z, F.getShadowUniformValues()) : (F.setupShadows(y.toUnwrapped(), ee, "model-tile", y.overscaledZ), T.shadowUniformsInitialized = !0)), oe = he.shouldRenderCutoff || xe < 1 || pe.alphaMode !== "OPAQUE" ? bi.alphaBlended : bi.unblended; } c.uploadCommonUniforms(z, ee, y.toUnwrapped(), null, he); const _e = Z.material.doubleSided ? ti.disabled : ti.backCCW; if (h.instancedDataArray.length > 20) te.push(h.instancedDataBuffer), ee.draw(c, z.gl.TRIANGLES, N, ci.disabled, oe, _e, se, t.id, Z.vertexBuffer, Z.indexBuffer, Z.segments, t.paint, c.transform.zoom, void 0, te, h.instancedDataArray.length); else { const pe = R ? "u_instance" : "u_normal_matrix"; for (let Me = 0; Me < h.instancedDataArray.length; ++Me) se[pe] = new Float32Array(h.instancedDataArray.arrayBuffer, 64 * Me, 16), ee.draw(c, z.gl.TRIANGLES, N, ci.disabled, oe, _e, se, t.id, Z.vertexBuffer, Z.indexBuffer, Z.segments, t.paint, c.transform.zoom, void 0, te); } } if (s.children) for (const Z of s.children) va(c, t, Z, h, _, y, T); } const Ya = [1, -1, 1]; function fu(c, t, s, h) { if (!s.modelManager) return !0; const _ = s.modelManager; if (!s.shadowRenderer) return !0; const y = s.shadowRenderer, T = t.aabb; let z = !0, R = c.maxHeight; if (R === 0) { let N = 0; for (const G in c.instancesPerModel) { const Z = _.getModel(G, h); Z ? N = Math.max(N, Math.max(Math.max(Z.aabb.max[0], Z.aabb.max[1]), Z.aabb.max[2])) : z = !1; } R = c.maxScale * N * 1.41 + c.maxVerticalOffset, z && (c.maxHeight = R); } T.max[2] = R, T.min[2] += c.terrainElevationMin, T.max[2] += c.terrainElevationMax, i.ab.vec3.transformMat4(T.min, T.min, t.tileMatrix), i.ab.vec3.transformMat4(T.max, T.max, t.tileMatrix); const F = T.intersects(y.getCurrentCascadeFrustum()); return s.currentShadowCascade === 0 && (c.isInsideFirstShadowMapFrustum = F === 2), F === 0; } function pu(c, t) { const s = c.uniformValues.u_cutoff_params[0], h = c.uniformValues.u_cutoff_params[1], _ = c.uniformValues.u_cutoff_params[2], y = c.uniformValues.u_cutoff_params[3]; return h === s || y === _ ? 1 : i.aw(((t - s) / (h - s) - _) / (y - _), 0, 1); } function Td(c, t, s, h) { if (t.pitch < 20) return 1; const _ = t.getWorldToCameraMatrix(); i.ab.mat4.multiply(_, _, c); const y = i.ab.vec4.fromValues(s.min[0], s.min[1], s.min[2], 1); let T = i.ab.vec4.transformMat4(i.ab.vec4.create(), y, _), z = T, R = T; y[1] = s.max[1], T = i.ab.vec4.transformMat4(i.ab.vec4.create(), y, _), z = T[1] < z[1] ? T : z, R = T[1] > R[1] ? T : R, y[0] = s.max[0], T = i.ab.vec4.transformMat4(i.ab.vec4.create(), y, _), z = T[1] < z[1] ? T : z, R = T[1] > R[1] ? T : R, y[1] = s.min[1], T = i.ab.vec4.transformMat4(i.ab.vec4.create(), y, _), z = T[1] < z[1] ? T : z, R = T[1] > R[1] ? T : R; const F = i.aw(h[0], 0, 1), N = 100 * t.pixelsPerMeter * i.aw(h[1], 0, 1), G = i.aw(h[2], 0, 1), Z = i.ab.vec4.lerp(i.ab.vec4.create(), z, R, F), W = Math.tan(0.5 * t.fovX), te = -Z[2] * W; if (N === 0) return Z[1] < -Math.abs(te) ? G : 1; const ee = (-Math.abs(te) - Z[1]) / N, se = (he, _e, pe) => (1 - pe) * he + pe * _e, oe = i.aw(se(1, G, ee), G, 1); return se(1, oe, i.aw((t.pitch - 20) / 20, 0, 1)); } class Md { } class Sd { constructor() { this._storage = /* @__PURE__ */ new Map(); } getLinesFromTrianglesBuffer(t, s, h) { { const G = this._storage.get(s.id); if (G) return G.lastUsedFrameIdx = t, G.buf; } const _ = h.gl, y = _.getBufferParameter(_.ELEMENT_ARRAY_BUFFER, _.BUFFER_SIZE), T = new ArrayBuffer(y), z = new Int16Array(T); _.getBufferSubData(_.ELEMENT_ARRAY_BUFFER, 0, new Int16Array(T)); const R = new i.dq(); for (let G = 0; G < y / 2; G += 3) { const Z = z[G], W = z[G + 1], te = z[G + 2]; R.emplaceBack(Z, W), R.emplaceBack(W, te), R.emplaceBack(te, Z); } const F = h.bindVertexArrayOES.current, N = new Md(); return N.buf = new ea(h, R), N.lastUsedFrameIdx = t, this._storage.set(s.id, N), h.bindVertexArrayOES.set(F), N.buf; } update(t) { for (const [s, h] of this._storage) t - h.lastUsedFrameIdx > 30 && (h.buf.destroy(), this._storage.delete(s)); } destroy() { for (const [t, s] of this._storage) s.buf.destroy(), this._storage.delete(t); } } class Ka { constructor(t) { this.occluderSize = 30, this.depthOffset = -1e-4, t.registerParameter(this, ["Occlusion"], "occluderSize", { min: 1, max: 100, step: 1 }), t.registerParameter(this, ["Occlusion"], "depthOffset", { min: -0.05, max: 0, step: 1e-5 }); } } const Ed = i.da([{ type: "Float32", name: "a_pos_3f", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }, { type: "Float32", name: "a_rainParticleData", components: 4 }]); class mu { registerParameter() { } registerButton() { } registerBinding() { } refreshUI() { } } class _u { constructor(t, s) { this.revealStart = 11, this.revealRange = 2, t.registerParameter(this, [...s, "Reveal"], "revealStart", { min: 0, max: 17, step: 0.05 }), t.registerParameter(this, [...s, "Reveal"], "revealRange", { min: 0.1, max: 5.1, step: 0.05 }); } } const Pd = i.da([{ type: "Float32", name: "a_pos_2f", components: 2 }]); class qs { destroy() { this.vignetteVx && this.vignetteVx.destroy(), this.vignetteIdx && this.vignetteIdx.destroy(); } draw(t, s) { const h = t.getOrCreateProgram("vignette"); if (!this.vignetteVx || !this.vignetteIdx) { const T = new i.dr(), z = new i.aU(); T.emplaceBack(-1, -1), T.emplaceBack(1, -1), T.emplaceBack(1, 1), T.emplaceBack(-1, 1), z.emplaceBack(0, 1, 2), z.emplaceBack(0, 2, 3), this.vignetteVx = t.context.createVertexBuffer(T, Pd.members), this.vignetteIdx = t.context.createIndexBuffer(z); } const _ = i.b7.simpleSegment(0, 0, 4, 6); if (this.vignetteVx && this.vignetteIdx) { t.uploadCommonUniforms(t.context, h); const T = { u_vignetteShape: (y = { vignetteShape: [s.start, s.range, Math.pow(10, s.fadePower)], vignetteColor: [s.color.r, s.color.g, s.color.b, s.color.a * s.strength] }).vignetteShape, u_vignetteColor: y.vignetteColor }; h.draw(t, t.context.gl.TRIANGLES, Wt.disabled, ci.disabled, bi.alphaBlended, ti.disabled, T, "vignette", this.vignetteVx, this.vignetteIdx, _, {}); } var y; } } class Ad { constructor() { this._accumulatedOffsetX = 0, this._accumulatedOffsetY = 0, this._accumulatedElevation = 0; } update(t, s) { const h = t.getFreeCameraOptions().position, _ = h.toAltitude(), y = h.toLngLat(), T = i.ai(y.lng), z = i.ai(y.lat), R = t.pixelsPerMeter / s, F = T * i.ds, N = i.ds * Math.log(Math.tan(Math.PI / 4 + z / 2)); if (this._offsetXPrev === void 0) this._offsetXPrev = 0, this._offsetYPrev = 0, this._elevationPrev = 0, this._accumulatedOffsetX = 0, this._accumulatedOffsetY = 0, this._accumulatedElevation = 0; else { const G = -this._offsetYPrev + N, Z = -this._elevationPrev + _; this._accumulatedOffsetX += (-this._offsetXPrev + F) * R, this._accumulatedOffsetY += G * R, this._accumulatedElevation += Z * R, this._offsetXPrev = F, this._offsetYPrev = N, this._elevationPrev = _; } } getPosition() { return [this._accumulatedOffsetX, this._accumulatedOffsetY, this._accumulatedElevation]; } } function gu(c, t) { return [-(c[0] - Math.floor(c[0] / t) * t), -(c[1] - Math.floor(c[1] / t) * t), -(c[2] - Math.floor(c[2] / t) * t)]; } function uc(c) { const t = i.di(1323123451230), s = []; for (let h = 0; h < c; ++h) { const _ = 2 * t() - 1, y = 2 * t() - 1, T = 2 * t() - 1; s.push(i.ab.vec3.fromValues(_, y, T)); } return s; } function Rr(c, t, s, h, _) { const y = i.aw((_ - s) / (h - s), 0, 1); return (1 - y) * c + y * t; } class yu { constructor(t) { this._movement = new Ad(), this._accumulatedTimeFromStart = 0, this._prevTime = Date.now() / 1e3, this._vignette = new qs(), this._ppmScaleFactor = t; } destroy() { this.particlesVx && this.particlesVx.destroy(), this.particlesIdx && this.particlesIdx.destroy(), this._vignette && this._vignette.destroy(); } updateOnRender(t, s) { const h = t.transform; this._movement.update(h, this._ppmScaleFactor); const _ = h.starsProjMatrix, y = i.ab.quat.identity([]); i.ab.quat.rotateX(y, y, i.ai(90) - h._pitch), i.ab.quat.rotateZ(y, y, -h.angle); const T = i.ab.mat4.fromQuat(new Float32Array(16), y), z = i.ab.mat4.fromValues(1, 0, 0, 0, 0, 0, 1, 0, 0, -1, 0, 0, 0, 0, 0, 1), R = i.ab.mat4.transpose([], z), F = i.ab.mat4.multiply([], R, T), N = Date.now() / 1e3; return this._accumulatedTimeFromStart += (N - this._prevTime) * s, this._prevTime = N, { projectionMatrix: _, modelviewMatrix: F }; } } class Cd extends yu { constructor(t) { super(4.25), this._params = { overrideStyleParameters: !1, intensity: 0.5, timeFactor: 1, velocityConeAperture: 0, velocity: 300, boxSize: 2500, dropletSizeX: 1, dropletSizeYScale: 10, distortionStrength: 70, screenThinning: { intensity: 0.57, start: 0.46, range: 1.17, fadePower: 0.17, affectedRatio: 1, particleOffset: -0.2 }, color: { r: 0.66, g: 0.68, b: 0.74, a: 0.7 }, direction: { x: -50, y: -35 }, shapeDirPower: 2, shapeNormalPower: 1 }, this._revealParams = new _u(t.tp, ["Precipitation", "Rain"]), this._vignetteParams = { strength: 1, start: 0.7, range: 1, fadePower: 0.4, color: { r: 0.27, g: 0.27, b: 0.27, a: 1 } }, this.particlesCount = 16e3; } update(t) { const s = t.context; if (!this.particlesVx) { const h = uc(this.particlesCount), _ = new i.dt(), y = new i.aU(); let T = 0; const z = i.di(1323123451230); for (let R = 0; R < h.length; ++R) { const F = h[R], N = [2 * z() - 1, z(), z(), z()]; _.emplaceBack(F[0], F[1], F[2], -1, -1, ...N), _.emplaceBack(F[0], F[1], F[2], 1, -1, ...N), _.emplaceBack(F[0], F[1], F[2], 1, 1, ...N), _.emplaceBack(F[0], F[1], F[2], -1, 1, ...N), y.emplaceBack(T + 0, T + 1, T + 2), y.emplaceBack(T + 0, T + 2, T + 3), T += 4; } this.particlesVx = s.createVertexBuffer(_, Ed.members), this.particlesIdx = s.createIndexBuffer(y); } } draw(t) { if (!this._params.overrideStyleParameters && !t.style.rain) return; const s = this._params.overrideStyleParameters ? this._revealParams : { revealStart: 0, revealRange: 0.01 }, h = t.transform.zoom; if (s.revealStart > h) return; const _ = Rr(0, 1, s.revealStart, s.revealStart + s.revealRange, h); if (!this.particlesVx || !this.particlesIdx) return; const y = structuredClone(this._params); let T = [-y.direction.x, y.direction.y, -100]; i.ab.vec3.normalize(T, T); const z = structuredClone(this._vignetteParams); z.strength *= _, y.overrideStyleParameters || (y.intensity = t.style.rain.state.density, y.timeFactor = t.style.rain.state.intensity, y.color = structuredClone(t.style.rain.state.color), T = structuredClone(t.style.rain.state.direction), y.screenThinning.intensity = t.style.rain.state.centerThinning, y.dropletSizeX = t.style.rain.state.dropletSize[0], y.dropletSizeYScale = t.style.rain.state.dropletSize[1] / t.style.rain.state.dropletSize[0], y.distortionStrength = 100 * t.style.rain.state.distortionStrength, z.strength = 1, z.color = structuredClone(t.style.rain.state.vignetteColor)); const R = this.updateOnRender(t, y.timeFactor), F = t.context, N = F.gl, G = t.transform; this.screenTexture && this.screenTexture.size[0] === t.width && this.screenTexture.size[1] === t.height || (this.screenTexture = new i.T(F, { width: t.width, height: t.height, data: null }, N.RGBA8)), y.distortionStrength > 0 && (F.activeTexture.set(N.TEXTURE0), this.screenTexture.bind(N.LINEAR, N.CLAMP_TO_EDGE), N.copyTexSubImage2D(N.TEXTURE_2D, 0, 0, 0, 0, 0, t.width, t.height)); const Z = t.getOrCreateProgram("rainParticle"); t.uploadCommonUniforms(F, Z), F.activeTexture.set(N.TEXTURE0), this.screenTexture.bind(N.LINEAR, N.CLAMP_TO_EDGE); const W = [y.color.r, y.color.g, y.color.b, y.color.a], te = (ee, se) => { const oe = gu(this._movement.getPosition(), ee), he = y.dropletSizeX, _e = y.dropletSizeX * y.dropletSizeYScale, pe = t.width / 2, Me = t.height / 2, xe = Rr(0, y.screenThinning.start, 0, 1, y.screenThinning.intensity), we = Rr(1e-3, y.screenThinning.range, 0, 1, y.screenThinning.intensity), ve = Rr(0, y.screenThinning.particleOffset, 0, 1, y.screenThinning.intensity), Ae = (Oe = { modelview: R.modelviewMatrix, projection: R.projectionMatrix, time: this._accumulatedTimeFromStart, camPos: oe, velocityConeAperture: y.velocityConeAperture, velocity: y.velocity, boxSize: ee, rainDropletSize: [he, _e], distortionStrength: y.distortionStrength, rainDirection: T, color: W, screenSize: [G.width, G.height], thinningCenterPos: [pe, Me], thinningShape: [xe, we, Math.pow(10, y.screenThinning.fadePower)], thinningAffectedRatio: y.screenThinning.affectedRatio, thinningParticleOffset: ve, shapeDirectionalPower: y.shapeDirPower, shapeNormalPower: y.shapeNormalPower, mode: se ? 0 : 1 }, { u_modelview: Float32Array.from(Oe.modelview), u_projection: Float32Array.from(Oe.projection), u_time: Oe.time, u_cam_pos: Oe.camPos, u_texScreen: 0, u_velocityConeAperture: Oe.velocityConeAperture, u_velocity: Oe.velocity, u_boxSize: Oe.boxSize, u_rainDropletSize: Oe.rainDropletSize, u_distortionStrength: Oe.distortionStrength, u_rainDirection: Oe.rainDirection, u_color: Oe.color, u_screenSize: Oe.screenSize, u_thinningCenterPos: Oe.thinningCenterPos, u_thinningShape: Oe.thinningShape, u_thinningAffectedRatio: Oe.thinningAffectedRatio, u_thinningParticleOffset: Oe.thinningParticleOffset, u_shapeDirectionalPower: Oe.shapeDirectionalPower, u_shapeNormalPower: Oe.shapeNormalPower, u_mode: Oe.mode }); var Oe; const Xe = Math.round(_ * y.intensity * this.particlesCount), He = i.b7.simpleSegment(0, 0, 4 * Xe, 2 * Xe); Z.draw(t, N.TRIANGLES, Wt.disabled, ci.disabled, bi.alphaBlended, ti.disabled, Ae, "rain_particles", this.particlesVx, this.particlesIdx, He, {}); }; y.distortionStrength > 0 && te(y.boxSize, !0), te(y.boxSize, !1), this._vignette.draw(t, z); } } const Id = i.da([{ type: "Float32", name: "a_pos_3f", components: 3 }, { type: "Float32", name: "a_uv", components: 2 }, { type: "Float32", name: "a_snowParticleData", components: 4 }, { type: "Float32", name: "a_snowParticleDataHorizontalOscillation", components: 2 }]); class Pl extends yu { constructor(t) { super(2.25), this._params = { overrideStyleParameters: !1, intensity: 0.85, timeFactor: 0.75, velocityConeAperture: 70, velocity: 40, horizontalOscillationRadius: 4, horizontalOscillationRate: 1.5, boxSize: 2e3, billboardSize: 2, shapeFadeStart: 0.27, shapeFadePower: 0.21, screenThinning: { intensity: 0.4, start: 0.15, range: 1.4, fadePower: 0.24, affectedRatio: 1, particleOffset: -0.2 }, color: { r: 1, g: 1, b: 1, a: 1 }, direction: { x: -50, y: -35 } }, this._revealParams = new _u(t.tp, ["Precipitation", "Snow"]), this._vignetteParams = { strength: 0.3, start: 0.78, range: 0.46, fadePower: 0.2, color: { r: 1, g: 1, b: 1, a: 1 } }, this.particlesCount = 16e3; } update(t) { const s = t.context; if (!this.particlesVx) { const h = uc(this.particlesCount), _ = new i.du(), y = new i.aU(); let T = 0; const z = i.di(1323123451230); for (let R = 0; R < h.length; ++R) { const F = h[R], N = z(), G = z(), Z = z(), W = [R / h.length, N, G, Z], te = [z(), z()]; _.emplaceBack(F[0], F[1], F[2], -1, -1, ...W, ...te), _.emplaceBack(F[0], F[1], F[2], 1, -1, ...W, ...te), _.emplaceBack(F[0], F[1], F[2], 1, 1, ...W, ...te), _.emplaceBack(F[0], F[1], F[2], -1, 1, ...W, ...te), y.emplaceBack(T + 0, T + 1, T + 2), y.emplaceBack(T + 0, T + 2, T + 3), T += 4; } this.particlesVx = s.createVertexBuffer(_, Id.members), this.particlesIdx = s.createIndexBuffer(y); } } draw(t) { if (!this._params.overrideStyleParameters && !t.style.snow) return; const s = structuredClone(this._params); let h = [-s.direction.x, s.direction.y, -100]; i.ab.vec3.normalize(h, h); const _ = structuredClone(this._vignetteParams), y = s.overrideStyleParameters ? this._revealParams : { revealStart: 0, revealRange: 0.01 }, T = t.transform.zoom; if (y.revealStart > T) return; const z = Rr(0, 1, y.revealStart, y.revealStart + y.revealRange, T); _.strength *= z, s.overrideStyleParameters || (s.intensity = t.style.snow.state.density, s.timeFactor = t.style.snow.state.intensity, s.color = structuredClone(t.style.snow.state.color), h = structuredClone(t.style.snow.state.direction), s.screenThinning.intensity = t.style.snow.state.centerThinning, s.billboardSize = 2.79 * t.style.snow.state.flakeSize, _.strength = 1, _.color = structuredClone(t.style.snow.state.vignetteColor)); const R = this.updateOnRender(t, s.timeFactor); if (!this.particlesVx || !this.particlesIdx) return; const F = t.context, N = F.gl, G = t.transform, Z = t.getOrCreateProgram("snowParticle"); t.uploadCommonUniforms(F, Z), ((W, te, ee) => { const se = gu(this._movement.getPosition(), W), oe = G.width / 2, he = G.height / 2, _e = Rr(0, ee.screenThinning.start, 0, 1, ee.screenThinning.intensity), pe = Rr(1e-3, ee.screenThinning.range, 0, 1, ee.screenThinning.intensity), Me = Rr(0, ee.screenThinning.particleOffset, 0, 1, ee.screenThinning.intensity), xe = (we = { modelview: R.modelviewMatrix, projection: R.projectionMatrix, time: this._accumulatedTimeFromStart, camPos: se, velocityConeAperture: ee.velocityConeAperture, velocity: ee.velocity, horizontalOscillationRadius: ee.horizontalOscillationRadius, horizontalOscillationRate: ee.horizontalOscillationRate, boxSize: W, billboardSize: 1 * ee.billboardSize, simpleShapeParameters: [ee.shapeFadeStart, ee.shapeFadePower], screenSize: [G.width, G.height], thinningCenterPos: [oe, he], thinningShape: [_e, pe, Math.pow(10, ee.screenThinning.fadePower)], thinningAffectedRatio: ee.screenThinning.affectedRatio, thinningParticleOffset: Me, color: [ee.color.r, ee.color.g, ee.color.b, ee.color.a], direction: h }, { u_modelview: Float32Array.from(we.modelview), u_projection: Float32Array.from(we.projection), u_time: we.time, u_cam_pos: we.camPos, u_velocityConeAperture: we.velocityConeAperture, u_velocity: we.velocity, u_horizontalOscillationRadius: we.horizontalOscillationRadius, u_horizontalOscillationRate: we.horizontalOscillationRate, u_boxSize: we.boxSize, u_billboardSize: we.billboardSize, u_simpleShapeParameters: we.simpleShapeParameters, u_screenSize: we.screenSize, u_thinningCenterPos: we.thinningCenterPos, u_thinningShape: we.thinningShape, u_thinningAffectedRatio: we.thinningAffectedRatio, u_thinningParticleOffset: we.thinningParticleOffset, u_particleColor: we.color, u_direction: we.direction }); var we; const ve = Math.round(z * ee.intensity * this.particlesCount), Ae = i.b7.simpleSegment(0, 0, 4 * ve, 2 * ve); this.particlesVx && this.particlesIdx && Z.draw(t, N.TRIANGLES, Wt.disabled, ci.disabled, bi.alphaBlended, ti.disabled, xe, "snow_particles", this.particlesVx, this.particlesIdx, Ae, {}); })(s.boxSize, 0, s), this._vignette.draw(t, _); } } const ah = { symbol: function(c, t, s, h, _) { if (c.renderPass !== "translucent") return; const y = ci.disabled, T = c.colorModeForRenderPass(), z = s.layout.get("text-variable-anchor"), R = s.layout.get("text-size-scale-range"), F = i.aw(c.scaleFactor, R[0], R[1]); z && function(Z, W, te, ee, se, oe, he, _e) { const pe = W.transform, Me = se === "map", xe = oe === "map"; for (const we of Z) { const ve = ee.getTile(we), Ae = ve.getBucket(te); if (!Ae || !Ae.text || !Ae.text.segments.get().length) continue; const Oe = i.bp(Ae.textSizeData, pe.zoom, _e), Xe = pa(we, Ae.getProjection(), pe), He = pe.calculatePixelsToTileUnitsMatrix(ve), ke = Js(Xe, ve.tileID.canonical, xe, Me, pe, Ae.getProjection(), He), Ne = Ae.hasIconTextFit() && Ae.hasIconData(); if (Oe) { const st = Math.pow(2, pe.zoom - ve.tileID.overscaledZ); co(Ae, Me, xe, he, i.cX, pe, ke, we, st, Oe, Ne); } } }(h, c, s, t, s.layout.get("text-rotation-alignment"), s.layout.get("text-pitch-alignment"), _, F); const N = s.paint.get("icon-opacity").constantOr(1) !== 0, G = s.paint.get("text-opacity").constantOr(1) !== 0; s.layout.get("symbol-sort-key").constantOr(1) !== void 0 && (N || G) ? Tn(c, t, s, h, y, T) : (N && Tn(c, t, s, h, y, T, { onlyIcons: !0 }), G && Tn(c, t, s, h, y, T, { onlyText: !0 })), t.map.showCollisionBoxes && (ou(c, t, s, h, s.paint.get("text-translate"), s.paint.get("text-translate-anchor"), !0), ou(c, t, s, h, s.paint.get("icon-translate"), s.paint.get("icon-translate-anchor"), !1)); }, circle: function(c, t, s, h) { if (c.renderPass !== "translucent") return; const _ = s.paint.get("circle-opacity"), y = s.paint.get("circle-stroke-width"), T = s.paint.get("circle-stroke-opacity"), z = s.layout.get("circle-sort-key").constantOr(1) !== void 0, R = s.paint.get("circle-emissive-strength"); if (_.constantOr(1) === 0 && (y.constantOr(1) === 0 || T.constantOr(1) === 0)) return; const F = c.context, N = F.gl, G = c.transform, Z = c.depthModeForSublayer(0, Wt.ReadOnly), W = ci.disabled, te = c.colorModeForDrapableLayerRenderPass(R), ee = G.projection.name === "globe", se = [i.at(G.center.lng), i.aA(G.center.lat)], oe = []; for (let _e = 0; _e < h.length; _e++) { const pe = h[_e], Me = t.getTile(pe), xe = Me.getBucket(s); if (!xe || xe.projection.name !== G.projection.name) continue; const we = xe.programConfigurations.get(s.id), ve = i.cY(s), Ae = c.isTileAffectedByFog(pe); ee && ve.push("PROJECTION_GLOBE_VIEW"), ve.push("DEPTH_D24"), c.terrain && G.depthOcclusionForSymbolsAndCircles && ve.push("DEPTH_OCCLUSION"); const Oe = c.getOrCreateProgram("circle", { config: we, defines: ve, overrideFog: Ae }), Xe = xe.layoutVertexBuffer, He = xe.globeExtVertexBuffer, ke = xe.indexBuffer, Ne = G.projection.createInversionMatrix(G, pe.canonical), st = { programConfiguration: we, program: Oe, layoutVertexBuffer: Xe, globeExtVertexBuffer: He, indexBuffer: ke, uniformValues: i.cZ(c, pe, Me, Ne, se, s), tile: Me }; if (z) { const ut = xe.segments.get(); for (const xt of ut) oe.push({ segments: new i.b7([xt]), sortKey: xt.sortKey, state: st }); } else oe.push({ segments: xe.segments, sortKey: 0, state: st }); } z && oe.sort((_e, pe) => _e.sortKey - pe.sortKey); const he = { useDepthForOcclusion: G.depthOcclusionForSymbolsAndCircles }; for (const _e of oe) { const { programConfiguration: pe, program: Me, layoutVertexBuffer: xe, globeExtVertexBuffer: we, indexBuffer: ve, uniformValues: Ae, tile: Oe } = _e.state, Xe = _e.segments; c.terrain && c.terrain.setupElevationDraw(Oe, Me, he), c.uploadCommonUniforms(F, Me, Oe.tileID.toUnwrapped()), Me.draw(c, N.TRIANGLES, Z, W, te, ti.disabled, Ae, s.id, xe, ve, Xe, s.paint, G.zoom, pe, [we]); } }, heatmap: function(c, t, s, h) { if (s.paint.get("heatmap-opacity") !== 0) if (c.renderPass === "offscreen") { const _ = c.context, y = _.gl, T = ci.disabled, z = new bi([y.ONE, y.ONE, y.ONE, y.ONE], i.aj.transparent, [!0, !0, !0, !0]); (function(W, te, ee, se) { const oe = W.gl, he = te.width * se, _e = te.height * se; W.activeTexture.set(oe.TEXTURE1), W.viewport.set([0, 0, he, _e]); let pe = ee.heatmapFbo; if (!pe || pe && (pe.width !== he || pe.height !== _e)) { pe && pe.destroy(); const Me = oe.createTexture(); oe.bindTexture(oe.TEXTURE_2D, Me), oe.texParameteri(oe.TEXTURE_2D, oe.TEXTURE_WRAP_S, oe.CLAMP_TO_EDGE), oe.texParameteri(oe.TEXTURE_2D, oe.TEXTURE_WRAP_T, oe.CLAMP_TO_EDGE), oe.texParameteri(oe.TEXTURE_2D, oe.TEXTURE_MIN_FILTER, oe.LINEAR), oe.texParameteri(oe.TEXTURE_2D, oe.TEXTURE_MAG_FILTER, oe.LINEAR), pe = ee.heatmapFbo = W.createFramebuffer(he, _e, !0, null), function(xe, we, ve, Ae, Oe, Xe) { const He = xe.gl; He.texImage2D(He.TEXTURE_2D, 0, xe.extRenderToTextureHalfFloat ? He.RGBA16F : He.RGBA, Oe, Xe, 0, He.RGBA, xe.extRenderToTextureHalfFloat ? He.HALF_FLOAT : He.UNSIGNED_BYTE, null), Ae.colorAttachment.set(ve); }(W, 0, Me, pe, he, _e); } else oe.bindTexture(oe.TEXTURE_2D, pe.colorAttachment.get()), W.bindFramebuffer.set(pe.framebuffer); })(_, c, s, c.transform.projection.name === "globe" ? 0.5 : 0.25), _.clear({ color: i.aj.transparent }); const R = c.transform, F = R.projection.name === "globe", N = F ? ["PROJECTION_GLOBE_VIEW"] : [], G = F ? ti.frontCCW : ti.disabled, Z = [i.at(R.center.lng), i.aA(R.center.lat)]; for (let W = 0; W < h.length; W++) { const te = h[W]; if (t.hasRenderableParent(te)) continue; const ee = t.getTile(te), se = ee.getBucket(s); if (!se || se.projection.name !== R.projection.name) continue; const oe = c.isTileAffectedByFog(te), he = se.programConfigurations.get(s.id), _e = c.getOrCreateProgram("heatmap", { config: he, defines: N, overrideFog: oe }), { zoom: pe } = c.transform; c.terrain && c.terrain.setupElevationDraw(ee, _e), c.uploadCommonUniforms(_, _e, te.toUnwrapped()); const Me = R.projection.createInversionMatrix(R, te.canonical); _e.draw(c, y.TRIANGLES, Wt.disabled, T, z, G, rc(c, te, ee, Me, Z, pe, s.paint.get("heatmap-intensity")), s.id, se.layoutVertexBuffer, se.indexBuffer, se.segments, s.paint, c.transform.zoom, he, F ? [se.globeExtVertexBuffer] : null); } _.viewport.set([0, 0, c.width, c.height]); } else c.renderPass === "translucent" && (c.context.setColorMode(c.colorModeForRenderPass()), function(_, y) { const T = _.context, z = T.gl, R = y.heatmapFbo; if (!R) return; T.activeTexture.set(z.TEXTURE0), z.bindTexture(z.TEXTURE_2D, R.colorAttachment.get()), T.activeTexture.set(z.TEXTURE1); let F = y.colorRampTexture; F || (F = y.colorRampTexture = new i.T(T, y.colorRamp, z.RGBA8)), F.bind(z.LINEAR, z.CLAMP_TO_EDGE), _.getOrCreateProgram("heatmapTexture").draw(_, z.TRIANGLES, Wt.disabled, ci.disabled, _.colorModeForRenderPass(), ti.disabled, ((N, G, Z, W) => ({ u_image: 0, u_color_ramp: 1, u_opacity: G.paint.get("heatmap-opacity") }))(0, y), y.id, _.viewportBuffer, _.quadTriangleIndexBuffer, _.viewportSegments, y.paint, _.transform.zoom); }(c, s)); }, line: function(c, t, s, h) { if (c.renderPass !== "translucent") return; const _ = s.paint.get("line-opacity"), y = s.paint.get("line-width"); if (_.constantOr(1) === 0 || y.constantOr(1) === 0) return; const T = s.paint.get("line-emissive-strength"), z = s.paint.get("line-occlusion-opacity"), R = s.layout.get("line-elevation-reference"), F = s.layout.get("line-width-unit") === "meters", N = R === "sea", G = c.context, Z = G.gl, W = !s.isDraped(); if (W && c.transform.projection.name === "globe") return; const te = s.layout.get("line-cross-slope"), ee = te !== void 0, se = te < 1, oe = W ? new Wt(c.depthOcclusion ? Z.GREATER : Z.LEQUAL, Wt.ReadOnly, c.depthRangeFor3D) : c.depthModeForSublayer(0, Wt.ReadOnly), he = c.colorModeForDrapableLayerRenderPass(T), _e = c.terrain && c.terrain.renderingToTexture, pe = _e ? 1 : i.q.devicePixelRatio, Me = s.paint.get("line-dasharray"), xe = Me.constantOr(1), we = s.layout.get("line-cap"), ve = Me.constantOr(null), Ae = we.constantOr(null), Oe = s.paint.get("line-pattern"), Xe = Oe.constantOr(1), He = Oe.constantOr(null), ke = s.paint.get("line-opacity").constantOr(1); let Ne = !Xe && ke !== 1 || c.depthOcclusion && z > 0 && z < 1; const st = s.paint.get("line-gradient"), ut = Xe ? "linePattern" : "line", xt = i.c_(s); let Ge; if (_e && c.terrain && c.terrain.clipOrMaskOverlapStencilType() && (Ne = !1), z !== 0 && c.depthOcclusion) { const Je = s.paint._values["line-opacity"]; Je && Je.value && Je.value.kind === "constant" ? Ge = Je.value : i.w(`Occlusion opacity for layer ${s.id} is supported only when line-opacity isn't data-driven.`); } if (W && (c.forceTerrainMode = !0), !W && z !== 0 && c.terrain && !_e) return void i.w(`Occlusion opacity for layer ${s.id} is supported on terrain only if the layer has line-z-offset enabled.`); const lt = Ne && W ? c.stencilModeFor3D() : ci.disabled; W && (xt.push("ELEVATED"), ee && xt.push(se ? "CROSS_SLOPE_HORIZONTAL" : "CROSS_SLOPE_VERTICAL"), N && xt.push("ELEVATION_REFERENCE_SEA")), y.value.kind !== "constant" && y.value.isLineProgressConstant === !1 && xt.push("VARIABLE_LINE_WIDTH"); for (const Je of h) { const _t = t.getTile(Je); if (Xe && !_t.patternsLoaded()) continue; const ct = _t.getBucket(s); if (!ct) continue; c.prepareDrawTile(); const nt = ct.programConfigurations.get(s.id), Lt = c.isTileAffectedByFog(Je), bt = c.getOrCreateProgram(ut, { config: nt, defines: xt, overrideFog: Lt, overrideRtt: !W && void 0 }); if (He && _t.imageAtlas) { const wi = i.A.from(He), mn = _t.imageAtlas.patternPositions[wi.getSerializedPrimary()]; mn && nt.setConstantPatternPositions(mn); } if (!Xe && ve && Ae && _t.lineAtlas) { const wi = _t.lineAtlas.getDash(ve, Ae); wi && nt.setConstantPatternPositions(wi); } let [zt, Bt] = s.paint.get("line-trim-offset"); (Ae === "round" || Ae === "square") && zt !== Bt && (zt === 0 && (zt -= 1), Bt === 1 && (Bt += 1)); const oi = _e ? Je.projMatrix : null, $t = F ? 1 / ct.tileToMeter / i.ar(_t, 1, c.transform.zoom) : 1, Xt = F ? 1 / ct.tileToMeter / i.ar(_t, 1, Math.floor(c.transform.zoom)) : 1, ai = Xe ? i.c$(c, _t, s, oi, pe, $t, Xt, [zt, Bt]) : i.d0(c, _t, s, oi, ct.lineClipsArray.length, pe, $t, Xt, [zt, Bt]); if (st) { const wi = ct.gradients[s.id]; let mn = wi.texture; if (s.gradientVersion !== wi.version) { let Mn = 256; if (s.stepInterpolant) { const Xi = t.getSource().maxzoom, sn = Je.canonical.z === Xi ? Math.ceil(1 << c.transform.maxZoom - Je.canonical.z) : 1; Mn = i.aw(i.d1(ct.maxLineLength / i.ag * 1024 * sn), 256, G.maxTextureSize); } wi.gradient = i.d2({ expression: s.gradientExpression(), evaluationKey: "lineProgress", resolution: Mn, image: wi.gradient || void 0, clips: ct.lineClipsArray }), wi.texture ? wi.texture.update(wi.gradient) : wi.texture = new i.T(G, wi.gradient, Z.RGBA8), wi.version = s.gradientVersion, mn = wi.texture; } G.activeTexture.set(Z.TEXTURE1), mn.bind(s.stepInterpolant ? Z.NEAREST : Z.LINEAR, Z.CLAMP_TO_EDGE); } xe && (G.activeTexture.set(Z.TEXTURE0), _t.lineAtlasTexture && _t.lineAtlasTexture.bind(Z.LINEAR, Z.REPEAT), nt.updatePaintBuffers()), Xe && (G.activeTexture.set(Z.TEXTURE0), _t.imageAtlasTexture && _t.imageAtlasTexture.bind(Z.LINEAR, Z.CLAMP_TO_EDGE), nt.updatePaintBuffers()), W && !N && c.terrain.setupElevationDraw(_t, bt), c.uploadCommonUniforms(G, bt, Je.toUnwrapped()); const zi = (wi) => { Ge != null && (Ge.value = ke * z), bt.draw(c, Z.TRIANGLES, oe, wi, he, ti.disabled, ai, s.id, ct.layoutVertexBuffer, ct.indexBuffer, ct.segments, s.paint, c.transform.zoom, nt, [ct.layoutVertexBuffer2, ct.patternVertexBuffer, ct.zOffsetVertexBuffer]), Ge != null && (Ge.value = ke); }; if (Ne && !W) { const wi = c.stencilModeForClipping(Je).ref; wi === 0 && _e && G.clear({ stencil: 0 }); const mn = { func: Z.EQUAL, mask: 255 }; ai.u_alpha_discard_threshold = 0.8, zi(new ci(mn, wi, 255, Z.KEEP, Z.KEEP, Z.INVERT)), ai.u_alpha_discard_threshold = 0, zi(new ci(mn, wi, 255, Z.KEEP, Z.KEEP, Z.KEEP)); } else Ne && W && (ai.u_alpha_discard_threshold = 1e-3), zi(W ? lt : c.stencilModeForClipping(Je)); } W && (c.forceTerrainMode = !1), Ne && (c.resetStencilClippingMasks(), _e && G.clear({ stencil: 0 })), z === 0 || c.depthOcclusion || _e || c.layersWithOcclusionOpacity.push(c.currentLayer); }, fill: function(c, t, s, h) { const _ = s.paint.get("fill-color"), y = s.paint.get("fill-opacity"), T = s.is3D(), z = new Wt(c.context.gl.LEQUAL, Wt.ReadWrite, c.depthRangeFor3D); if (y.constantOr(1) === 0) return; const R = s.paint.get("fill-emissive-strength"), F = c.colorModeForDrapableLayerRenderPass(R), N = s.paint.get("fill-pattern"), G = c.opaquePassEnabledForLayer() && !N.constantOr(1) && _.constantOr(i.aj.transparent).a === 1 && y.constantOr(0) === 1 ? "opaque" : "translucent"; if (c.renderPass === G) { const Z = T ? z : c.depthModeForSublayer(1, c.renderPass === "opaque" ? Wt.ReadWrite : Wt.ReadOnly); lu(c, t, s, h, Z, F, !1); } if (!T && c.renderPass === "translucent" && s.paint.get("fill-antialias")) { const Z = T ? z : c.depthModeForSublayer(s.getPaintProperty("fill-outline-color") ? 2 : 0, Wt.ReadOnly); lu(c, t, s, h, Z, F, !0); } }, "fill-extrusion": function(c, t, s, h) { const _ = s.paint.get("fill-extrusion-opacity"), y = c.context, T = y.gl, z = c.terrain, R = z && z.renderingToTexture; if (_ === 0) return; const F = c.conflationActive && c.style.isLayerClipped(s, t.getSource()), N = c.style.order.indexOf(s.fqid); if (F && function(G, Z, W, te, ee) { for (const se of te) { const oe = Z.getTile(se).getBucket(W); oe && (oe.updateReplacement(se, G.replacementSource, ee), oe.uploadCentroid(G.context)); } }(c, t, s, h, N), z || F) for (const G of h) { const Z = t.getTile(G).getBucket(s); Z && tp(c.context, t, G, Z, s, z, F); } if (c.renderPass === "shadow" && c.shadowRenderer) { const G = c.shadowRenderer; if (z && _ < 0.65 && s._transitionablePaint._values["fill-extrusion-opacity"].value.expression instanceof i.a9) return; const Z = G.getShadowPassDepthMode(), W = G.getShadowPassColorMode(); ih(c, t, s, h, Z, ci.disabled, W, F); } else if (c.renderPass === "translucent") { const G = !s.paint.get("fill-extrusion-pattern").constantOr(1), Z = s.paint.get("fill-extrusion-color").constantOr(i.aj.white); if (!R && Z.a !== 0) { const W = new Wt(c.context.gl.LEQUAL, Wt.ReadWrite, c.depthRangeFor3D); _ === 1 && G ? ih(c, t, s, h, W, ci.disabled, bi.unblended, F) : (ih(c, t, s, h, W, ci.disabled, bi.disabled, F), ih(c, t, s, h, W, c.stencilModeFor3D(), c.colorModeForRenderPass(), F), c.resetStencilClippingMasks()); } if (c.style.enable3dLights() && G && (!z && c.transform.projection.name !== "globe" || R)) { const W = s.paint.get("fill-extrusion-opacity"), te = s.paint.get("fill-extrusion-ambient-occlusion-intensity"), ee = s.paint.get("fill-extrusion-ambient-occlusion-ground-radius"), se = s.paint.get("fill-extrusion-flood-light-intensity"), oe = s.paint.get("fill-extrusion-flood-light-color-use-theme").constantOr("default") === "none", he = s.paint.get("fill-extrusion-flood-light-color").toRenderColor(oe ? null : s.lut).toArray01().slice(0, 3), _e = te > 0 && ee > 0, pe = se > 0, Me = (we, ve, Ae) => (1 - Ae) * we + Ae * ve, xe = (we) => { const ve = c.depthModeForSublayer(1, Wt.ReadOnly, T.LEQUAL, !0), Ae = s.paint.get(we ? "fill-extrusion-ambient-occlusion-ground-attenuation" : "fill-extrusion-flood-light-ground-attenuation"), Oe = Me(0.1, 3, Ae), Xe = c._showOverdrawInspector; if (!Xe) { const He = new ci({ func: T.ALWAYS, mask: 255 }, 255, 255, T.KEEP, T.KEEP, T.REPLACE), ke = new bi([T.ONE, T.ONE, T.ONE, T.ONE], i.aj.transparent, [!1, !1, !1, !0], T.MIN); Ml(c, t, s, h, ve, He, ke, ti.disabled, we, "sdf", W, te, ee, se, he, Oe, F, !1); } { const He = Xe ? ci.disabled : new ci({ func: T.EQUAL, mask: 255 }, 255, 255, T.KEEP, T.DECR, T.DECR), ke = Xe ? c.colorModeForRenderPass() : new bi([T.ONE_MINUS_DST_ALPHA, T.DST_ALPHA, T.ONE, T.ONE], i.aj.transparent, [!0, !0, !0, !0]); Ml(c, t, s, h, ve, He, ke, ti.disabled, we, "color", W, te, ee, se, he, Oe, F, !1); } }; if (R) { const we = (ve, Ae, Oe) => { const Xe = c.depthModeForSublayer(1, Wt.ReadOnly, T.LEQUAL, !1), He = s.paint.get(ve ? "fill-extrusion-ambient-occlusion-ground-attenuation" : "fill-extrusion-flood-light-ground-attenuation"), ke = Me(0.1, 3, He); { const Ne = new bi([T.ONE, T.ONE, T.ONE, T.ONE], i.aj.transparent, [!1, !1, !1, !0]); Ml(c, t, s, h, Xe, ci.disabled, Ne, ti.disabled, ve, "clear", W, te, ee, se, he, ke, F, Ae); } { const Ne = new ci({ func: T.ALWAYS, mask: 255 }, 255, 255, T.KEEP, T.KEEP, T.REPLACE), st = new bi([T.ONE, T.ONE, T.ONE, T.ONE], i.aj.transparent, [!1, !1, !1, !0], T.MIN); Ml(c, t, s, h, Xe, Ne, st, ti.disabled, ve, "sdf", W, te, ee, se, he, ke, F, Ae); } { const Ne = ve ? T.ZERO : T.ONE_MINUS_DST_ALPHA, st = new ci({ func: T.EQUAL, mask: 255 }, 255, 255, T.KEEP, T.DECR, T.DECR), ut = new bi([Ne, T.DST_ALPHA, T.ONE_MINUS_DST_ALPHA, T.ZERO], i.aj.transparent, [!0, !0, !0, !0]); Ml(c, t, s, h, Xe, st, ut, ti.disabled, ve, "color", W, te, ee, se, he, ke, F, Ae); } { const Ne = new bi([T.ONE, T.ONE, T.ONE, ve ? T.ZERO : T.ONE], i.aj.transparent, [!1, !1, !1, !0], ve ? T.FUNC_ADD : T.MAX); Ml(c, t, s, h, Xe, ci.disabled, Ne, ti.disabled, ve, "clear", W, te, ee, se, he, ke, F, Ae, Oe); } }; if (_e || pe) { let ve; if (c.prepareDrawTile(), z) { const Ae = z.drapeBufferSize[0], Oe = z.drapeBufferSize[1]; ve = z.framebufferCopyTexture, ve && (!ve || ve.size[0] === Ae && ve.size[1] === Oe) || (ve && ve.destroy(), ve = z.framebufferCopyTexture = new i.T(y, new i.r({ width: Ae, height: Oe }), T.RGBA8)), ve.bind(T.LINEAR, T.CLAMP_TO_EDGE), T.copyTexSubImage2D(T.TEXTURE_2D, 0, 0, 0, 0, 0, Ae, Oe); } _e && we(!0, !1, ve), pe && we(!1, !0, ve); } } else _e && xe(!0), pe && xe(!1), (_e || pe) && c.resetStencilClippingMasks(); } } }, hillshade: function(c, t, s, h) { if (c.renderPass !== "offscreen" && c.renderPass !== "translucent" || c.style.disableElevatedTerrain) return; const _ = c.context, y = c.terrain && c.terrain.renderingToTexture, [T, z] = c.renderPass !== "translucent" || y ? [{}, h] : c.stencilConfigForOverlap(h); for (const R of z) { const F = t.getTile(R); if (F.needsHillshadePrepare && c.renderPass === "offscreen") qc(c, F, s); else if (c.renderPass === "translucent") { const N = c.depthModeForSublayer(0, Wt.ReadOnly), G = s.paint.get("hillshade-emissive-strength"), Z = c.colorModeForDrapableLayerRenderPass(G), W = y && c.terrain ? c.terrain.stencilModeForRTTOverlap(R) : T[R.overscaledZ]; Ga(c, R, F, s, N, W, Z); } } _.viewport.set([0, 0, c.width, c.height]), c.resetStencilClippingMasks(); }, raster: function(c, t, s, h, _, y) { if (c.renderPass !== "translucent" || s.paint.get("raster-opacity") === 0) return; const T = c.transform.projection.name === "globe", z = s.paint.get("raster-elevation") !== 0, R = z && T; if (c.renderElevatedRasterBackface && !R) return; const F = c.context, N = F.gl, G = t.getSource(), Z = function(xe, we, ve, Ae) { const Oe = we.paint.get("raster-color"), Xe = xe.type === "raster-array", He = [], ke = we.paint.get("raster-resampling"), Ne = we.paint.get("raster-color-mix"); let st = we.paint.get("raster-color-range"); const ut = [Ne[0], Ne[1], Ne[2], 0], xt = Ne[3]; let Ge = ke === "nearest" ? Ae.NEAREST : Ae.LINEAR; if (Xe && (He.push("RASTER_ARRAY"), Oe || He.push("RASTER_COLOR"), ke === "linear" && He.push("RASTER_ARRAY_LINEAR"), Ge = Ae.NEAREST, !st && xe.rasterLayers)) { const lt = xe.rasterLayers.find(({ id: Je }) => Je === we.sourceLayer); lt && lt.fields && lt.fields.range && (st = lt.fields.range); } if (st = st || [0, 1], Oe) { He.push("RASTER_COLOR"), ve.activeTexture.set(Ae.TEXTURE2), we.updateColorRamp(st); let lt = we.colorRampTexture; lt || (lt = we.colorRampTexture = new i.T(ve, we.colorRamp, Ae.RGBA8)), lt.bind(Ae.LINEAR, Ae.CLAMP_TO_EDGE); } return { mix: ut, range: st, offset: xt, defines: He, resampling: Ge }; }(G, s, F, N); if (G instanceof i.aJ && !h.length && !T) return; const W = s.paint.get("raster-emissive-strength"), te = c.colorModeForDrapableLayerRenderPass(W), ee = c.terrain && c.terrain.renderingToTexture, se = !c.options.moving, oe = s.paint.get("raster-resampling") === "nearest" ? N.NEAREST : N.LINEAR; if (G instanceof i.aJ && !h.length && (G.onNorthPole || G.onSouthPole)) { const xe = z ? c.stencilModeFor3D() : ci.disabled; return void Wa(!!G.onNorthPole, null, c, t, s, W, Z, ti.disabled, xe); } if (!h.length) return; const [he, _e] = G instanceof i.aJ || ee ? [{}, h] : c.stencilConfigForOverlap(h), pe = _e[_e.length - 1].overscaledZ; R && Z.defines.push("PROJECTION_GLOBE_VIEW"), z && Z.defines.push("RENDER_CUTOFF"); const Me = (xe, we, ve) => { for (const Ae of xe) { const Oe = Ae.toUnwrapped(), Xe = t.getTile(Ae); if (ee && (!Xe || !Xe.hasData())) continue; F.activeTexture.set(N.TEXTURE0); const He = $e(Xe, G, s, Z); if (!He || !He.texture) continue; const { texture: ke, mix: Ne, offset: st, tileSize: ut, buffer: xt } = He; let Ge, lt; ee ? (Ge = Wt.disabled, lt = Ae.projMatrix) : z ? (Ge = new Wt(N.LEQUAL, Wt.ReadWrite, c.depthRangeFor3D), lt = T ? Float32Array.from(c.transform.expandedFarZProjMatrix) : c.transform.calculateProjMatrix(Oe, se)) : (Ge = c.depthModeForSublayer(Ae.overscaledZ - pe, s.paint.get("raster-opacity") === 1 ? Wt.ReadWrite : Wt.ReadOnly, N.LESS), lt = c.transform.calculateProjMatrix(Oe, se)); const Je = c.terrain && ee ? c.terrain.stencilModeForRTTOverlap(Ae) : he[Ae.overscaledZ], _t = y ? 0 : s.paint.get("raster-fade-duration"); Xe.registerFadeDuration(_t); const ct = t.findLoadedParent(Ae, 0), nt = Jh(Xe, ct, t, c.transform, _t); let Lt, bt; c.terrain && c.terrain.prepareDrawTile(), F.activeTexture.set(N.TEXTURE0), ke.bind(oe, N.CLAMP_TO_EDGE), F.activeTexture.set(N.TEXTURE1), ct ? (ct.texture && ct.texture.bind(oe, N.CLAMP_TO_EDGE), Lt = Math.pow(2, ct.tileID.overscaledZ - Xe.tileID.overscaledZ), bt = [Xe.tileID.canonical.x * Lt % 1, Xe.tileID.canonical.y * Lt % 1]) : ke.bind(oe, N.CLAMP_TO_EDGE), ke.useMipmap && F.extTextureFilterAnisotropic && c.transform.pitch > 20 && N.texParameterf(N.TEXTURE_2D, F.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT, F.extTextureFilterAnisotropicMax); const zt = c.transform; let Bt; const oi = z ? Bn(zt) : [0, 0, 0, 0]; let $t, Xt, ai, zi, wi, mn = 0; if (R && G instanceof i.aJ && G.coordinates.length > 3) $t = Float32Array.from(i.bb(i.cH(new i.bT(0, 0, 0)))), Xt = Float32Array.from(zt.globeMatrix), ai = Float32Array.from(i.cD(zt)), zi = [i.at(zt.center.lng), i.aA(zt.center.lat)], Bt = G.elevatedGlobePerspectiveTransform, wi = G.elevatedGlobeGridMatrix || new Float32Array(9); else if (R) { const _i = i.cE(Ae.canonical); mn = i.cF(_i.getCenter().lat), $t = Float32Array.from(i.bb(i.cH(Ae.canonical))), Xt = Float32Array.from(zt.globeMatrix), ai = Float32Array.from(i.cD(zt)), zi = [i.at(zt.center.lng), i.aA(zt.center.lat)], Bt = [0, 0], wi = Float32Array.from(i.cG(Ae.canonical, _i, mn, zt.worldSize / zt._pixelsPerMercatorPixel)); } else Bt = G instanceof i.aJ ? G.perspectiveTransform : [0, 0], $t = new Float32Array(16), Xt = new Float32Array(9), ai = new Float32Array(16), zi = [0, 0], wi = new Float32Array(9); const Mn = pd(lt, $t, Xt, ai, wi, bt || [0, 0], i.ae(c.transform.zoom), zi, oi, Lt || 1, nt, s, Bt, z ? s.paint.get("raster-elevation") : 0, 2, Ne, st, Z.range, ut, xt, W), Xi = c.isTileAffectedByFog(Ae), sn = c.getOrCreateProgram("raster", { defines: Z.defines, overrideFog: Xi }); if (c.uploadCommonUniforms(F, sn, Oe), G instanceof i.aJ) { const _i = G.elevatedGlobeVertexBuffer, Jt = G.elevatedGlobeIndexBuffer; if (ee || !T) G.boundsBuffer && G.boundsSegments && sn.draw(c, N.TRIANGLES, Ge, ci.disabled, te, ti.disabled, Mn, s.id, G.boundsBuffer, c.quadTriangleIndexBuffer, G.boundsSegments); else if (_i && Jt) { const ji = zt.zoom <= i.c6 ? G.elevatedGlobeSegments : G.getSegmentsForLongitude(zt.center.lng); ji && sn.draw(c, N.TRIANGLES, Ge, ci.disabled, te, we, Mn, s.id, _i, Jt, ji); } } else if (R) { Ge = new Wt(N.LEQUAL, Wt.ReadOnly, c.depthRangeFor3D); const _i = c.globeSharedBuffers; if (_i) { const [Jt, ji, Yi] = _i.getGridBuffers(mn, !1); sn.draw(c, N.TRIANGLES, Ge, ve || Je, c.colorModeForRenderPass(), we, Mn, s.id, Jt, ji, Yi); } } else { const { tileBoundsBuffer: _i, tileBoundsIndexBuffer: Jt, tileBoundsSegments: ji } = c.getTileBoundsBuffers(Xe); sn.draw(c, N.TRIANGLES, Ge, Je, te, ti.disabled, Mn, s.id, _i, Jt, ji); } } if (!(G instanceof i.aJ) && R) for (const Ae of xe) { const Oe = Ae.canonical.y === (1 << Ae.canonical.z) - 1; Ae.canonical.y === 0 && Wa(!0, Ae, c, t, s, W, Z, we, ve || ci.disabled), Oe && Wa(!1, Ae, c, t, s, W, Z, we === ti.frontCW ? ti.backCW : ti.frontCW, ve || ci.disabled); } }; R ? Me(_e, c.renderElevatedRasterBackface ? ti.backCW : ti.frontCW, c.stencilModeFor3D()) : Me(_e, ti.disabled, void 0), c.resetStencilClippingMasks(); }, "raster-particle": function(c, t, s, h, _, y) { c.renderPass === "offscreen" && function(T, z, R, F) { if (!F.length) return; const N = T.context, G = N.gl, Z = z.getSource(); if (!(Z instanceof xn)) return; const W = Math.ceil(Math.sqrt(R.paint.get("raster-particle-count"))); let te = R.particlePositionRGBAImage; if (!te || te.width !== W) { const _e = function(pe) { const Me = pe * pe, xe = new Uint8Array(4 * Me), we = function(Ae) { return Ae |= 0, Ae = Math.imul(2747636419 ^ Ae, 2654435769), Ae = Math.imul(Ae ^ Ae >>> 16, 2654435769), ((Ae = Math.imul(Ae ^ Ae >>> 16, 2654435769)) >>> 0) / 4294967296; }, ve = 1 / 1.1; for (let Ae = 0; Ae < Me; Ae++) { const Oe = ve * (we(2 * Ae + 0) + lo), Xe = ve * (we(2 * Ae + 1) + lo), He = 255 * Oe % 1, ke = 255 * Xe % 1, Ne = He, st = Xe - ke / 255, ut = ke; xe[4 * Ae + 0] = 255 * (Oe - He / 255), xe[4 * Ae + 1] = 255 * Ne, xe[4 * Ae + 2] = 255 * st, xe[4 * Ae + 3] = 255 * ut; } return xe; }(W); te = R.particlePositionRGBAImage = new i.r({ width: W, height: W }, _e); } let ee = R.particleFramebuffer; ee ? ee.width !== W && (ee.destroy(), ee = R.particleFramebuffer = N.createFramebuffer(W, W, !0, null)) : ee = R.particleFramebuffer = N.createFramebuffer(W, W, !0, null); const se = []; for (const _e of F) { const pe = z.getTile(_e); if (!(pe instanceof ka)) continue; const Me = bd(pe, Z, R); if (!Me) continue; const xe = [pe.tileSize, pe.tileSize]; let we = R.tileFramebuffer; we || (we = R.tileFramebuffer = N.createFramebuffer(xe[0], xe[1], !0, null)); let ve = pe.rasterParticleState; ve || (ve = pe.rasterParticleState = new cu(N, _e, xe, te)); const Ae = ve.update(R.lastInvalidatedAt); ve.particleTextureDimension !== W && ve.updateParticleTexture(_e, te); const Oe = ve.targetColorTexture; ve.targetColorTexture = ve.backgroundColorTexture, ve.backgroundColorTexture = Oe; const Xe = ve.particleTexture0; ve.particleTexture0 = ve.particleTexture1, ve.particleTexture1 = Xe, se.push([_e, Me, ve, Ae]); } if (se.length === 0) return; const oe = i.q.now(), he = R.previousDrawTimestamp ? 1e-3 * (oe - R.previousDrawTimestamp) : 0.0167; if (R.previousDrawTimestamp = oe, R.hasColorMap()) { N.activeTexture.set(G.TEXTURE0 + 2); let _e = R.colorRampTexture; _e || (_e = R.colorRampTexture = new i.T(N, R.colorRamp, G.RGBA8)), _e.bind(G.LINEAR, G.CLAMP_TO_EDGE); } N.bindFramebuffer.set(R.tileFramebuffer.framebuffer), function(_e, pe, Me) { const xe = _e.context, we = xe.gl, ve = pe.tileFramebuffer; xe.activeTexture.set(we.TEXTURE0); const Ae = { u_texture: 0, u_opacity: 1.05 * (Xe = pe.paint.get("raster-particle-fade-opacity-factor")) / (Xe + 0.05) }, Oe = _e.getOrCreateProgram("rasterParticleTexture", { defines: [], overrideFog: !1 }); var Xe; for (const He of Me) { const [, , ke, Ne] = He; ve.colorAttachment.set(ke.targetColorTexture.texture), xe.viewport.set([0, 0, ve.width, ve.height]), xe.clear({ color: i.aj.transparent }), Ne && (ke.backgroundColorTexture.bind(we.NEAREST, we.CLAMP_TO_EDGE), Oe.draw(_e, we.TRIANGLES, Wt.disabled, ci.disabled, bi.alphaBlended, ti.disabled, Ae, pe.id, _e.viewportBuffer, _e.quadTriangleIndexBuffer, _e.viewportSegments)); } }(T, R, se), function(_e, pe, Me, xe) { const we = _e.context, ve = we.gl, Ae = Me.tileFramebuffer, Oe = _e.transform.projection.name === "globe", Xe = Me.paint.get("raster-particle-max-speed"); for (const He of xe) { const [ke, Ne, st] = He; we.activeTexture.set(ve.TEXTURE0 + 0), Ne.texture.bind(ve.LINEAR, ve.CLAMP_TO_EDGE), Ae.colorAttachment.set(st.targetColorTexture.texture); const ut = _e.getOrCreateProgram("rasterParticleDraw", { defines: Ne.defines, overrideFog: !1 }); we.activeTexture.set(ve.TEXTURE0 + 1); const xt = Ne.scalarData ? [] : [0, 1, 2, 3].map((Je) => i.d4[Je](ke)); xt.push(ke); const Ge = ke.canonical.x, lt = ke.canonical.y; for (const Je of xt) { const _t = pe.getTile(Oe ? Je.wrapped() : Je); if (!_t) continue; const ct = _t.rasterParticleState; if (!ct) continue; const nt = Je.canonical.x + (1 << Je.canonical.z) * (Je.wrap - ke.wrap), Lt = Je.canonical.y; ct.particleTexture0.bind(ve.NEAREST, ve.CLAMP_TO_EDGE); const bt = Zt(1, ct.particleTexture0.size[0], [nt - Ge, Lt - lt], 0, Ne.texture.size, 2, Xe, Ne.textureOffset, Ne.scale, Ne.offset); ut.draw(_e, ve.POINTS, Wt.disabled, ci.disabled, bi.alphaBlended, ti.disabled, bt, Me.id, ct.particleIndexBuffer, void 0, ct.particleSegment); } } }(T, z, R, se), N.bindFramebuffer.set(R.particleFramebuffer.framebuffer), function(_e, pe, Me, xe) { const we = _e.context, ve = we.gl, Ae = pe.paint.get("raster-particle-max-speed"), Oe = xe * pe.paint.get("raster-particle-speed-factor") * 0.15, Xe = function(ke) { return Math.pow(ke, 6); }(0.01 + 1 * pe.paint.get("raster-particle-reset-rate-factor")), He = pe.particleFramebuffer; we.viewport.set([0, 0, He.width, He.height]); for (const ke of Me) { const [, Ne, st] = ke; we.activeTexture.set(ve.TEXTURE0 + 0), Ne.texture.bind(ve.LINEAR, ve.CLAMP_TO_EDGE), we.activeTexture.set(ve.TEXTURE0 + 1); const ut = st.particleTexture0; ut.bind(ve.NEAREST, ve.CLAMP_TO_EDGE); const xt = md(1, ut.size[0], 0, Ne.texture.size, Ae, Oe, Xe, Ne.textureOffset, Ne.scale, Ne.offset); He.colorAttachment.set(st.particleTexture1.texture), we.clear({ color: i.aj.transparent }), _e.getOrCreateProgram("rasterParticleUpdate", { defines: Ne.defines }).draw(_e, ve.TRIANGLES, Wt.disabled, ci.disabled, bi.unblended, ti.disabled, xt, pe.id, _e.viewportBuffer, _e.quadTriangleIndexBuffer, _e.viewportSegments); } }(T, R, se, he); }(c, t, s, h), c.renderPass === "translucent" && (function(T, z, R, F, N) { const G = T.context, Z = G.gl, W = z.getSource().tileSize, te = 5 * (1 - i.ac(i.bY, i.bY + 1, T.transform.zoom)) * W + R.paint.get("raster-particle-elevation"), ee = !T.options.moving, se = T.transform.projection.name === "globe"; if (!F.length) return; const [oe, he] = T.stencilConfigForOverlap(F), _e = []; se && _e.push("PROJECTION_GLOBE_VIEW"); const pe = T.stencilModeFor3D(); for (const Me of he) { const xe = Me.toUnwrapped(), we = z.getTile(Me); if (!we.rasterParticleState) continue; const ve = we.rasterParticleState, Ae = 100; we.registerFadeDuration(Ae); const Oe = z.findLoadedParent(Me, 0), Xe = Jh(we, Oe, z, T.transform, Ae); let He, ke; T.terrain && T.terrain.prepareDrawTile(), G.activeTexture.set(Z.TEXTURE0), ve.targetColorTexture.bind(Z.LINEAR, Z.CLAMP_TO_EDGE), G.activeTexture.set(Z.TEXTURE1), Oe && Oe.rasterParticleState ? (Oe.rasterParticleState.targetColorTexture.bind(Z.LINEAR, Z.CLAMP_TO_EDGE), He = Math.pow(2, Oe.tileID.overscaledZ - we.tileID.overscaledZ), ke = [we.tileID.canonical.x * He % 1, we.tileID.canonical.y * He % 1]) : ve.targetColorTexture.bind(Z.LINEAR, Z.CLAMP_TO_EDGE); const Ne = se ? Float32Array.from(T.transform.expandedFarZProjMatrix) : T.transform.calculateProjMatrix(xe, ee), st = T.transform, ut = np(st), xt = i.cE(Me.canonical), Ge = i.cF(xt.getCenter().lat); let lt, Je, _t, ct, nt; se ? (lt = Float32Array.from(i.bb(i.cH(Me.canonical))), Je = Float32Array.from(st.globeMatrix), _t = Float32Array.from(i.cD(st)), ct = [i.at(st.center.lng), i.aA(st.center.lat)], nt = Float32Array.from(i.cG(Me.canonical, xt, Ge, st.worldSize / st._pixelsPerMercatorPixel))) : (lt = new Float32Array(16), Je = new Float32Array(9), _t = new Float32Array(16), ct = [0, 0], nt = new Float32Array(9)); const Lt = Tl(Ne, lt, Je, _t, nt, ke || [0, 0], i.ae(T.transform.zoom), ct, ut, He || 1, Xe, te), bt = T.isTileAffectedByFog(Me), zt = T.getOrCreateProgram("rasterParticle", { defines: _e, overrideFog: bt }); if (T.uploadCommonUniforms(G, zt, xe), se) { const Bt = new Wt(Z.LEQUAL, Wt.ReadOnly, T.depthRangeFor3D), oi = 0, $t = T.globeSharedBuffers; if ($t) { const [Xt, ai, zi] = $t.getGridBuffers(Ge, oi !== 0); zt.draw(T, Z.TRIANGLES, Bt, pe, bi.alphaBlended, T.renderElevatedRasterBackface ? ti.frontCCW : ti.backCCW, Lt, R.id, Xt, ai, zi); } } else { const Bt = T.depthModeForSublayer(0, Wt.ReadOnly), oi = oe[Me.overscaledZ], { tileBoundsBuffer: $t, tileBoundsIndexBuffer: Xt, tileBoundsSegments: ai } = T.getTileBoundsBuffers(we); zt.draw(T, Z.TRIANGLES, Bt, oi, bi.alphaBlended, ti.disabled, Lt, R.id, $t, Xt, ai); } } T.resetStencilClippingMasks(); }(c, t, s, h), c.style.map.triggerRepaint()); }, background: function(c, t, s, h) { const _ = s.paint.get("background-color"), y = s.paint.get("background-color-use-theme").constantOr("default") === "none", T = s.paint.get("background-opacity"), z = s.paint.get("background-emissive-strength"), R = s.paint.get("background-pitch-alignment") === "viewport"; if (T === 0) return; const F = c.context, N = F.gl, G = c.transform, Z = G.tileSize, W = s.paint.get("background-pattern"); let te; if (W !== void 0 && (W === null || (te = c.imageManager.getPattern(W.toString(), s.scope, c.style.getLut(s.scope)), !te))) return; const ee = !W && _.a === 1 && T === 1 && c.opaquePassEnabledForLayer() ? "opaque" : "translucent"; if (c.renderPass !== ee) return; const se = ci.disabled, oe = c.depthModeForSublayer(0, ee === "opaque" ? Wt.ReadWrite : Wt.ReadOnly), he = c.colorModeForDrapableLayerRenderPass(z), _e = W ? "backgroundPattern" : "background"; let pe, Me = h; if (Me || (pe = c.getBackgroundTiles(), Me = Object.values(pe).map((xe) => xe.tileID)), W && (F.activeTexture.set(N.TEXTURE0), c.imageManager.bind(c.context, s.scope)), R) { const xe = c.getOrCreateProgram(_e, { overrideFog: !1, overrideRtt: !0 }), we = new Float32Array(i.ab.mat4.identity([])), ve = new i.aG(0, 0, 0, 0, 0), Ae = W ? _d(we, z, T, c, 0, s.scope, te, R, { tileID: ve, tileSize: Z }) : su(we, z, T, _.toRenderColor(y ? null : s.lut)); xe.draw(c, N.TRIANGLES, oe, se, he, ti.disabled, Ae, s.id, c.viewportBuffer, c.quadTriangleIndexBuffer, c.viewportSegments); } else for (const xe of Me) { const we = c.isTileAffectedByFog(xe), ve = c.getOrCreateProgram(_e, { overrideFog: we }), Ae = xe.toUnwrapped(), Oe = h ? xe.projMatrix : c.transform.calculateProjMatrix(Ae); c.prepareDrawTile(); const Xe = t ? t.getTile(xe) : pe ? pe[xe.key] : new Cr(xe, Z, G.zoom, c), He = W ? _d(Oe, z, T, c, 0, s.scope, te, R, { tileID: xe, tileSize: Z }) : su(Oe, z, T, _.toRenderColor(y ? null : s.lut)); c.uploadCommonUniforms(F, ve, Ae); const { tileBoundsBuffer: ke, tileBoundsIndexBuffer: Ne, tileBoundsSegments: st } = c.getTileBoundsBuffers(Xe); ve.draw(c, N.TRIANGLES, oe, se, he, ti.disabled, He, s.id, ke, Ne, st); } }, sky: function(c, t, s) { const h = c._atmosphere ? i.ae(c.transform.zoom) : 1, _ = s.paint.get("sky-opacity") * h; if (_ === 0) return; const y = c.context, T = s.paint.get("sky-type"), z = new Wt(y.gl.LEQUAL, Wt.ReadOnly, [0, 1]), R = c.frameCounter / 1e3 % 1; T === "atmosphere" ? c.renderPass === "offscreen" ? s.needsSkyboxCapture(c) && (function(F, N, G, Z) { const W = F.context, te = W.gl; let ee = N.skyboxFbo; if (!ee) { ee = N.skyboxFbo = W.createFramebuffer(32, 32, !0, null), N.skyboxGeometry = new Io(W), N.skyboxTexture = W.gl.createTexture(), te.bindTexture(te.TEXTURE_CUBE_MAP, N.skyboxTexture), te.texParameteri(te.TEXTURE_CUBE_MAP, te.TEXTURE_WRAP_S, te.CLAMP_TO_EDGE), te.texParameteri(te.TEXTURE_CUBE_MAP, te.TEXTURE_WRAP_T, te.CLAMP_TO_EDGE), te.texParameteri(te.TEXTURE_CUBE_MAP, te.TEXTURE_MIN_FILTER, te.LINEAR), te.texParameteri(te.TEXTURE_CUBE_MAP, te.TEXTURE_MAG_FILTER, te.LINEAR); for (let _e = 0; _e < 6; ++_e) te.texImage2D(te.TEXTURE_CUBE_MAP_POSITIVE_X + _e, 0, te.RGBA, 32, 32, 0, te.RGBA, te.UNSIGNED_BYTE, null); } W.bindFramebuffer.set(ee.framebuffer), W.viewport.set([0, 0, 32, 32]); const se = N.getCenter(F, !0), oe = F.getOrCreateProgram("skyboxCapture"), he = new Float64Array(16); i.ab.mat4.identity(he), i.ab.mat4.rotateY(he, he, 0.5 * -Math.PI), El(F, N, oe, he, se, 0), i.ab.mat4.identity(he), i.ab.mat4.rotateY(he, he, 0.5 * Math.PI), El(F, N, oe, he, se, 1), i.ab.mat4.identity(he), i.ab.mat4.rotateX(he, he, 0.5 * -Math.PI), El(F, N, oe, he, se, 2), i.ab.mat4.identity(he), i.ab.mat4.rotateX(he, he, 0.5 * Math.PI), El(F, N, oe, he, se, 3), i.ab.mat4.identity(he), El(F, N, oe, he, se, 4), i.ab.mat4.identity(he), i.ab.mat4.rotateY(he, he, Math.PI), El(F, N, oe, he, se, 5), W.viewport.set([0, 0, F.width, F.height]); }(c, s), s.markSkyboxValid(c)) : c.renderPass === "sky" && function(F, N, G, Z, W) { const te = F.context, ee = te.gl, se = F.transform, oe = F.getOrCreateProgram("skybox"); te.activeTexture.set(ee.TEXTURE0), ee.bindTexture(ee.TEXTURE_CUBE_MAP, N.skyboxTexture); const he = ((_e, pe, Me, xe, we) => ({ u_matrix: _e, u_sun_direction: pe, u_cubemap: 0, u_opacity: xe, u_temporal_offset: we }))(se.skyboxMatrix, N.getCenter(F, !1), 0, Z, W); F.uploadCommonUniforms(te, oe), oe.draw(F, ee.TRIANGLES, G, ci.disabled, F.colorModeForRenderPass(), ti.backCW, he, "skybox", N.skyboxGeometry.vertexBuffer, N.skyboxGeometry.indexBuffer, N.skyboxGeometry.segment); }(c, s, z, _, R) : T === "gradient" && c.renderPass === "sky" && function(F, N, G, Z, W) { const te = F.context, ee = te.gl, se = F.transform, oe = F.getOrCreateProgram("skyboxGradient"); N.skyboxGeometry || (N.skyboxGeometry = new Io(te)), te.activeTexture.set(ee.TEXTURE0); let he = N.colorRampTexture; he || (he = N.colorRampTexture = new i.T(te, N.colorRamp, ee.RGBA8)), he.bind(ee.LINEAR, ee.CLAMP_TO_EDGE); const _e = ((pe, Me, xe, we, ve) => ({ u_matrix: pe, u_color_ramp: 0, u_center_direction: Me, u_radius: i.ai(xe), u_opacity: we, u_temporal_offset: ve }))(se.skyboxMatrix, N.getCenter(F, !1), N.paint.get("sky-gradient-radius"), Z, W); F.uploadCommonUniforms(te, oe), oe.draw(F, ee.TRIANGLES, G, ci.disabled, F.colorModeForRenderPass(), ti.backCW, _e, "skyboxGradient", N.skyboxGeometry.vertexBuffer, N.skyboxGeometry.indexBuffer, N.skyboxGeometry.segment); }(c, s, z, _, R); }, debug: function(c, t, s, h, _, y) { for (let T = 0; T < s.length; T++) if (_) { const F = new i.aj(h.r * 0.8, h.g * 0.8, h.b * 0.8, 1); Sl(c, t, s[T], h, -1, -1, y), Sl(c, t, s[T], h, -1, 1, y), Sl(c, t, s[T], h, 1, 1, y), Sl(c, t, s[T], h, 1, -1, y), Sl(c, t, s[T], F, 0, 0, y); } else Sl(c, t, s[T], h, 0, 0, y); }, custom: function(c, t, s, h) { const _ = c.context, y = s.implementation; if (!c.transform.projection.unsupportedLayers || !c.transform.projection.unsupportedLayers.includes("custom") || c.terrain && (c.terrain.renderingToTexture || c.renderPass === "offscreen") && s.isDraped(t)) { if (c.renderPass === "offscreen") { const T = y.prerender; if (T) { if (c.setCustomLayerDefaults(), _.setColorMode(c.colorModeForRenderPass()), c.transform.projection.name === "globe") { const z = c.transform.pointMerc; T.call(y, _.gl, c.transform.customLayerMatrix(), c.transform.getProjection(), c.transform.globeToMercatorMatrix(), i.ae(c.transform.zoom), [z.x, z.y], c.transform.pixelsPerMeterRatio); } else T.call(y, _.gl, c.transform.customLayerMatrix()); _.setDirty(), c.setBaseState(); } } else if (c.renderPass === "translucent") { if (c.terrain && c.terrain.renderingToTexture) { const z = y.renderToTile; if (z) { const R = h[0].canonical, F = new i.aa(R.x + h[0].wrap * (1 << R.z), R.y, R.z); _.setDepthMode(Wt.disabled), _.setStencilMode(ci.disabled), _.setColorMode(c.colorModeForRenderPass()), c.setCustomLayerDefaults(), z.call(y, _.gl, F), _.setDirty(), c.setBaseState(); } return; } c.setCustomLayerDefaults(), _.setColorMode(c.colorModeForRenderPass()), _.setStencilMode(ci.disabled); const T = y.renderingMode === "3d" ? new Wt(c.context.gl.LEQUAL, Wt.ReadWrite, c.depthRangeFor3D) : c.depthModeForSublayer(0, Wt.ReadOnly); if (_.setDepthMode(T), c.transform.projection.name === "globe") { const z = c.transform.pointMerc; y.render(_.gl, c.transform.customLayerMatrix(), c.transform.getProjection(), c.transform.globeToMercatorMatrix(), i.ae(c.transform.zoom), [z.x, z.y], c.transform.pixelsPerMeterRatio); } else y.render(_.gl, c.transform.customLayerMatrix()); _.setDirty(), c.setBaseState(), _.bindFramebuffer.set(null); } } else i.w("Custom layers are not yet supported with this projection. Use mercator or globe to enable usage of custom layers."); }, model: function(c, t, s, h) { if (c.renderPass === "opaque") return; const _ = s.paint.get("model-opacity").constantOr(1); if (_ === 0) return; const y = s.paint.get("model-cast-shadows"); if (c.renderPass === "shadow" && (!y || c.terrain && _ < 0.65 && s._transitionablePaint._values["model-opacity"].value.expression instanceof i.a9)) return; const T = c.shadowRenderer, z = s.paint.get("model-receive-shadows"); T && (T.useNormalOffset = !0, z || (T.enabled = !1)); const R = () => { T && (T.useNormalOffset = !0, z || (T.enabled = !0)); }, F = t.getSource(); if (c.renderPass === "light-beam" && F.type !== "batched-model") return; if (F.type === "vector" || F.type === "geojson") return function(oe, he, _e, pe, Me) { const xe = oe.transform; if (xe.projection.name !== "mercator") return void i.w(`Drawing 3D models for ${xe.projection.name} projection is not yet implemented`); const we = xe.getFreeCameraOptions().position; if (!oe.modelManager) return; const ve = oe.modelManager; _e.modelManager = ve; const Ae = oe.shadowRenderer; if (!_e._unevaluatedLayout._values.hasOwnProperty("model-id")) return; const Oe = _e._unevaluatedLayout._values["model-id"], Xe = { ..._e.layout.get("model-id").parameters }, He = oe.style.order.indexOf(_e.fqid); for (const ke of pe) { const Ne = he.getTile(ke).getBucket(_e); if (!Ne || Ne.projection.name !== xe.projection.name) continue; const st = Ne.getModelUris(); st && !Ne.modelsRequested && (ve.addModelsFromBucket(st, Me), Ne.modelsRequested = !0); const ut = Xa(ke, xe); Xe.zoom = ut; const xt = Oe.possiblyEvaluate(Xe); if (wd(oe, Ne, ke), ho.shadowUniformsInitialized = !1, ho.useSingleShadowCascade = !!Ae && Ae.getMaxCascadeForTile(ke.toUnwrapped()) === 0, oe.renderPass === "shadow" && Ae) { if (oe.currentShadowCascade === 1 && Ne.isInsideFirstShadowMapFrustum) continue; const Je = xe.calculatePosMatrix(ke.toUnwrapped(), xe.worldSize); if (ho.tileMatrix.set(Je), ho.shadowTileMatrix = Float32Array.from(Ae.calculateShadowPassMatrixFromMatrix(Je)), ho.aabb.min.fill(0), ho.aabb.max[0] = ho.aabb.max[1] = i.ag, ho.aabb.max[2] = 0, fu(Ne, ho, oe, _e.scope)) continue; } const Ge = 1 << ke.canonical.z, lt = [((we.x - ke.wrap) * Ge - ke.canonical.x) * i.ag, (we.y * Ge - ke.canonical.y) * i.ag, we.z * Ge * i.ag]; oe.conflationActive && Object.keys(Ne.instancesPerModel).length > 0 && oe.style.isLayerClipped(_e, he.getSource()) && Ne.updateReplacement(ke, oe.replacementSource, He, Me) && (Ne.uploaded = !1, Ne.upload(oe.context)); for (let Je in Ne.instancesPerModel) { const _t = Ne.instancesPerModel[Je]; _t.features.length > 0 && (Je = xt.evaluate(_t.features[0].feature, {})); const ct = ve.getModel(Je, Me); if (ct && ct.uploaded) for (const nt of ct.nodes) va(oe, _e, nt, _t, lt, ke, ho); } } }(c, t, s, h, F.type === "vector" ? s.scope : ""), void R(); if (!F.loaded()) return; if (F.type === "batched-model") return function(oe, he, _e, pe) { _e.resetLayerRenderingStats(oe); const Me = oe.context, xe = oe.transform, we = oe.style.fog, ve = oe.shadowRenderer; if (xe.projection.name !== "mercator") return void i.w(`Drawing 3D landmark models for ${xe.projection.name} projection is not yet implemented`); const Ae = oe.transform.getFreeCameraOptions().position, Oe = i.ab.vec3.scale([], [Ae.x, Ae.y, Ae.z], oe.transform.worldSize), Xe = i.ab.vec3.negate([], Oe), He = i.ab.mat4.identity([]), ke = i.dj(xe.center.lat, xe.zoom), Ne = i.ab.mat4.fromScaling([], [1, 1, 1 / ke]); i.ab.mat4.translate(He, He, Xe); const st = _e.paint.get("model-opacity").constantOr(1), ut = new Wt(Me.gl.LEQUAL, Wt.ReadWrite, oe.depthRangeFor3D), xt = new Wt(Me.gl.LEQUAL, Wt.ReadOnly, oe.depthRangeFor3D), Ge = new i.cd([1 / 0, 1 / 0, 1 / 0], [-1 / 0, -1 / 0, -1 / 0]), lt = oe.renderPass === "shadow", Je = lt && ve ? ve.getCurrentCascadeFrustum() : xe.getFrustum(xe.scaleZoom(xe.worldSize)), _t = _e.paint.get("model-front-cutoff"), ct = _t[2] < 1, nt = Mo(oe, _e.paint.get("model-cutoff-fade-range")), Lt = _e.getLayerRenderingStats(); (function(bt, zt, Bt, oi) { const $t = bt.terrain ? bt.terrain.exaggeration() : 0, Xt = bt.transform.zoom; for (const ai of oi) { const zi = zt.getTile(ai).getBucket(Bt); zi && (bt.conflationActive && zi.updateReplacement(ai, bt.replacementSource), zi.evaluateScale(bt, Bt), bt.terrain && $t > 0 && zi.elevationUpdate(bt.terrain, $t, ai, Bt.source), zi.needsReEvaluation(bt, Xt, Bt) && zi.evaluate(Bt)); } })(oe, he, _e, pe), function() { let bt, zt, Bt; ct ? (bt = pe.length - 1, zt = -1, Bt = -1) : (bt = 0, zt = pe.length, Bt = 1); const oi = new Float64Array(16), $t = i.ab.vec3.create(), Xt = new i.P(0, 0); for (let ai = bt; ai !== zt; ai += Bt) { const zi = pe[ai], wi = he.getTile(zi).getBucket(_e); if (!wi || !wi.uploaded) continue; let mn = !1; ve && (mn = ve.getMaxCascadeForTile(zi.toUnwrapped()) === 0); const Mn = xe.calculatePosMatrix(zi.toUnwrapped(), xe.worldSize), Xi = wi.modelTraits; !lt && ct && (i.ab.mat4.invert(oi, Mn), i.ab.vec3.transformMat4($t, Oe, oi), Xt.x = $t[0], Xt.y = $t[1]); const sn = []; for (const _i of wi.getNodesInfo()) { if (_i.hiddenByReplacement || !_i.node.meshes) continue; const Jt = _i.node; let ji = 0; oe.terrain && Jt.elevation && (ji = Jt.elevation * oe.terrain.exaggeration()); const Yi = (() => { const Ri = _i.aabb; return Ge.min = [...Ri.min], Ge.max = [...Ri.max], Ge.min[2] += ji, Ge.max[2] += ji, i.ab.vec3.transformMat4(Ge.min, Ge.min, Mn), i.ab.vec3.transformMat4(Ge.max, Ge.max, Mn), Ge; })(), In = _i.evaluatedScale; if (In[0] <= 1 && In[1] <= 1 && In[2] <= 1 && Yi.intersects(Je) === 0) continue; if (!lt && ct) { const Ri = 0.16666666666666666; _i.cameraCollisionOpacity = Oe[0] > Yi.min[0] && Oe[0] < Yi.max[0] && Oe[1] > Yi.min[1] && Oe[1] < Yi.max[1] && Oe[2] * ke < Yi.max[2] && Jt.footprint && i.bA(Xt, Jt.footprint) ? Math.max(_i.cameraCollisionOpacity - Ri, 0) : Math.min(1, _i.cameraCollisionOpacity + Ri); } const Fs = [...Mn], pr = Jt.anchor ? Jt.anchor[0] : 0, ts = Jt.anchor ? Jt.anchor[1] : 0; i.ab.mat4.translate(Fs, Fs, [pr * (In[0] - 1), ts * (In[1] - 1), ji]), i.ab.vec3.exactEquals(In, i.dm) || i.ab.mat4.scale(Fs, Fs, In); const Ps = i.ab.mat4.multiply([], Fs, Jt.matrix), Qs = i.ab.mat4.multiply([], xe.expandedFarZProjMatrix, Ps), jn = i.ab.mat4.multiply([], xe.expandedFarZProjMatrix, Fs), dn = i.ab.vec4.transformMat4([], [pr, ts, ji, 1], Qs)[2]; Jt.hidden = !1; let _n = st; lt || (ct && (_n *= _i.cameraCollisionOpacity, _n *= Td(Fs, xe, _i.aabb, _t)), _n *= pu(nt, dn)), _n !== 0 ? sn.push({ nodeInfo: _i, depth: dn, opacity: _n, wvpForNode: Qs, wvpForTile: jn, nodeModelMatrix: Ps, tileModelMatrix: Fs }) : Jt.hidden = !0; } lt || sn.sort((_i, Jt) => !ct || _i.opacity === 1 && Jt.opacity === 1 ? _i.depth < Jt.depth ? -1 : 1 : _i.opacity === 1 ? -1 : Jt.opacity === 1 ? 1 : _i.depth > Jt.depth ? -1 : 1); for (const _i of sn) { const Jt = _i.nodeInfo, ji = Jt.node; let Yi = i.ab.mat4.multiply([], Ne, _i.tileModelMatrix); i.ab.mat4.multiply(Yi, He, Yi); const In = i.ab.mat4.invert([], Yi); i.ab.mat4.transpose(In, In), i.ab.mat4.scale(In, In, Ya), Yi = i.ab.mat4.multiply(Yi, Yi, ji.matrix); const Fs = oe.renderPass === "light-beam", pr = _e.paint.get("model-color-use-theme").constantOr("default") === "none", ts = Xi & i.dp.HasMapboxMeshFeatures, Ps = ts ? 0 : Jt.evaluatedRMEA[0][2]; for (let Qs = 0; Qs < ji.meshes.length; ++Qs) { const jn = ji.meshes[Qs], dn = Qs === ji.lightMeshIndex; let _n = _i.wvpForNode; if (dn) { if (!Fs && !oe.terrain && oe.shadowRenderer) { oe.currentLayer < oe.firstLightBeamLayer && (oe.firstLightBeamLayer = oe.currentLayer); continue; } _n = _i.wvpForTile; } else if (Fs) continue; const Ri = { defines: [] }, Gn = []; if (!lt && ve && (ve.useNormalOffset = !!jn.normalBuffer), du(Ri.defines, Gn, jn, oe, pr ? null : _e.lut), ts || Ri.defines.push("DIFFUSE_SHADED"), mn && Ri.defines.push("SHADOWS_SINGLE_CASCADE"), Lt && (lt ? Lt.numRenderedVerticesInShadowPass += jn.vertexArray.length : Lt.numRenderedVerticesInTransparentPass += jn.vertexArray.length), lt) { $a(jn, _i.nodeModelMatrix, oe, _e); continue; } let Bs = null; if (we) { const mr = qi(_i.nodeModelMatrix, oe.transform); if (Bs = new Float32Array(mr), xe.projection.name !== "globe") { const ko = jn.aabb.min, Nr = jn.aabb.max, [il, ia] = we.getOpacityForBounds(mr, ko[0], ko[1], Nr[0], Nr[1]); Ri.overrideFog = il >= It || ia >= It; } } const cn = jn.material; let er; cn.occlusionTexture && cn.occlusionTexture.offsetScale && (er = cn.occlusionTexture.offsetScale, Ri.defines.push("OCCLUSION_TEXTURE_TRANSFORM")); const eo = oe.getOrCreateProgram("model", Ri); !lt && ve && ve.setupShadowsFromMatrix(_i.tileModelMatrix, eo, ve.useNormalOffset), oe.uploadCommonUniforms(Me, eo, null, Bs); const Br = cn.pbrMetallicRoughness; Br.metallicFactor = 0.9, Br.roughnessFactor = 0.5; const Ma = gd(new Float32Array(_n), new Float32Array(Yi), new Float32Array(In), new Float32Array(ji.matrix), oe, _i.opacity, Br.baseColorFactor.toRenderColor(null), cn.emissiveFactor, Br.metallicFactor, Br.roughnessFactor, cn, Ps, _e, [0, 0, 0], er); !dn && (Jt.hasTranslucentParts || _i.opacity < 1) && eo.draw(oe, Me.gl.TRIANGLES, ut, ci.disabled, bi.disabled, ti.backCCW, Ma, _e.id, jn.vertexBuffer, jn.indexBuffer, jn.segments, _e.paint, oe.transform.zoom, void 0, Gn), eo.draw(oe, Me.gl.TRIANGLES, dn ? xt : ut, ci.disabled, dn || _i.opacity < 1 || Jt.hasTranslucentParts ? bi.alphaBlended : bi.unblended, ti.backCCW, Ma, _e.id, jn.vertexBuffer, jn.indexBuffer, jn.segments, _e.paint, oe.transform.zoom, void 0, Gn); } } } }(); }(c, t, s, h), void R(); if (F.type !== "model") return; const N = F.getModels(), G = [], Z = c.transform.getFreeCameraOptions().position, W = i.ab.vec3.scale([], [Z.x, Z.y, Z.z], c.transform.worldSize); i.ab.vec3.negate(W, W); const te = [], ee = []; let se = 0; for (const oe of N) { const he = s.paint.get("model-rotation").constantOr(null), _e = s.paint.get("model-scale").constantOr(null), pe = s.paint.get("model-translation").constantOr(null); oe.computeModelMatrix(c, he, _e, pe, !0, !0, !1); const Me = i.ab.mat4.identity([]), xe = i.dj(oe.position.lat, c.transform.zoom), we = i.ab.mat4.fromScaling([], [1, 1, 1 / xe]); i.ab.mat4.translate(Me, Me, W), G.push({ zScaleMatrix: we, negCameraPosMatrix: Me }); for (const ve of oe.nodes) oh(c.transform, ve, oe.matrix, c.transform.expandedFarZProjMatrix, se, te, ee); se++; } if (te.sort((oe, he) => he.depth - oe.depth), c.renderPass !== "shadow") { if (_ === 1) for (const oe of ee) Lo(oe, c, s, G[oe.modelIndex], ci.disabled, c.colorModeForRenderPass()); else { for (const oe of ee) Lo(oe, c, s, G[oe.modelIndex], ci.disabled, bi.disabled); for (const oe of ee) Lo(oe, c, s, G[oe.modelIndex], c.stencilModeFor3D(), c.colorModeForRenderPass()); c.resetStencilClippingMasks(); } for (const oe of te) Lo(oe, c, s, G[oe.modelIndex], ci.disabled, c.colorModeForRenderPass()); R(); } else { for (const oe of ee) $a(oe.mesh, oe.nodeModelMatrix, c, s); for (const oe of te) $a(oe.mesh, oe.nodeModelMatrix, c, s); R(); } } }, xu = { model: function(c, t, s) { const h = t.getSource(); if (!h.loaded()) return; if (h.type === "vector" || h.type === "geojson") return void (s.modelManager && s.modelManager.upload(s, h.type === "vector" ? c.scope : "")); if (h.type === "batched-model" || h.type !== "model") return; const _ = h.getModels(); for (const y of _) y.upload(s.context); }, raster: function(c, t, s) { const h = t.getSource(); if (!(h instanceof xn && h.loaded())) return; const _ = c.sourceLayer || h.rasterLayerIds && h.rasterLayerIds[0]; if (!_) return; const y = c.paint.get("raster-array-band") || h.getInitialBand(_); if (y == null) return; const T = t.getIds().map((z) => t.getTileByID(z)); for (const z of T) z.updateNeeded(_, y) && h.prepareTile(z, _, y); }, "raster-particle": function(c, t, s) { const h = t.getSource(); if (!(h instanceof xn && h.loaded())) return; const _ = c.sourceLayer || h.rasterLayerIds && h.rasterLayerIds[0]; if (!_) return; const y = c.paint.get("raster-particle-array-band") || h.getInitialBand(_); if (y == null) return; const T = t.getIds().map((z) => t.getTileByID(z)); for (const z of T) z.updateNeeded(_, y) && h.prepareTile(z, _, y); } }; class Ld { constructor(t, s, h, _, y) { this.context = new qa(t, s), this.transform = h, this._tileTextures = {}, this.frameCopies = [], this.loadTimeStamps = [], this.tp = y, this._timeStamp = i.q.now(), this._averageFPS = 0, this._fpsHistory = [], this._dt = 0, this._debugParams = { forceEnablePrecipitation: !1, showTerrainProxyTiles: !1, fpsWindow: 30, continousRedraw: !1, enabledLayers: {} }; const T = ["fill", "line", "symbol", "circle", "heatmap", "fill-extrusion", "raster", "raster-particle", "hillshade", "model", "background", "sky"]; for (const R of T) this._debugParams.enabledLayers[R] = !0; y.registerParameter(this._debugParams, ["Terrain"], "showTerrainProxyTiles", {}, () => { this.style.map.triggerRepaint(); }), y.registerParameter(this._debugParams, ["Precipitation"], "forceEnablePrecipitation"), y.registerParameter(this._debugParams, ["FPS"], "fpsWindow", { min: 1, max: 100, step: 1 }), y.registerBinding(this._debugParams, ["FPS"], "continousRedraw", { readonly: !0, label: "continuous redraw" }), y.registerBinding(this, ["FPS"], "_averageFPS", { readonly: !0, label: "value" }), y.registerBinding(this, ["FPS"], "_averageFPS", { readonly: !0, label: "graph", view: "graph", min: 0, max: 200 }); for (const R of T) y.registerParameter(this._debugParams.enabledLayers, ["Debug", "Layers"], R); this.occlusionParams = new Ka(y), this.setup(), this.numSublayers = sr.maxUnderzooming + sr.maxOverzooming + 1, this.depthEpsilon = 1 / Math.pow(2, 16), this.deferredRenderGpuTimeQueries = [], this.gpuTimers = {}, this.frameCounter = 0, this._backgroundTiles = {}, this.conflationActive = !1, this.replacementSource = new i.dv(), this.longestCutoffRange = 0, this.minCutoffZoom = 0, this._fogVisible = !1, this._cachedTileFogOpacities = {}, this._shadowRenderer = new So(this), this._wireframeDebugCache = new Sd(), this.renderDefaultNorthPole = !0, this.renderDefaultSouthPole = !0, this.layersWithOcclusionOpacity = []; const z = new i.r({ width: 1, height: 1 }, Uint8Array.of(0, 0, 0, 0)); this.emptyDepthTexture = new i.T(this.context, z, t.RGBA8), this._clippingActiveLastFrame = !1, this.scaleFactor = _; } updateTerrain(t, s) { const h = !!t && !!t.terrain && this.transform.projection.supportsTerrain; if (!(h || this._terrain && this._terrain.enabled)) return; this._terrain || (this._terrain = new Wf(this, t)); const _ = this._terrain; this.transform.elevation = h ? _ : null, _.update(t, this.transform, s), this.transform.elevation && !_.enabled && (this.transform.elevation = null); } _updateFog(t) { const s = t.fog; if (!s || this.transform.projection.name === "globe" || s.getOpacity(this.transform.pitch) < 1 || s.properties.get("horizon-blend") < 0.03) return void (this.transform.fogCullDistSq = null); const [h, _] = s.getFovAdjustedRange(this.transform._fov); if (h > _) return void (this.transform.fogCullDistSq = null); const y = h + 0.78 * (_ - h); this.transform.fogCullDistSq = y * y; } get terrain() { return this.transform._terrainEnabled() && this._terrain && this._terrain.enabled || this._forceTerrainMode ? this._terrain : null; } get forceTerrainMode() { return this._forceTerrainMode; } set forceTerrainMode(t) { t && !this._terrain && (this._terrain = new Wf(this, this.style)), this._forceTerrainMode = t; } get shadowRenderer() { return this._shadowRenderer && this._shadowRenderer.enabled ? this._shadowRenderer : null; } get wireframeDebugCache() { return this._wireframeDebugCache; } resize(t, s) { if (this.width = t * i.q.devicePixelRatio, this.height = s * i.q.devicePixelRatio, this.context.viewport.set([0, 0, this.width, this.height]), this.style) for (const h of this.style.order) this.style._mergedLayers[h].resize(); } setup() { const t = this.context, s = new i.b4(); s.emplaceBack(0, 0), s.emplaceBack(i.ag, 0), s.emplaceBack(0, i.ag), s.emplaceBack(i.ag, i.ag), this.tileExtentBuffer = t.createVertexBuffer(s, i.b6.members), this.tileExtentSegments = i.b7.simpleSegment(0, 0, 4, 2); const h = new i.b4(); h.emplaceBack(0, 0), h.emplaceBack(i.ag, 0), h.emplaceBack(0, i.ag), h.emplaceBack(i.ag, i.ag), this.debugBuffer = t.createVertexBuffer(h, i.b6.members), this.debugSegments = i.b7.simpleSegment(0, 0, 4, 5); const _ = new i.b4(); _.emplaceBack(-1, -1), _.emplaceBack(1, -1), _.emplaceBack(-1, 1), _.emplaceBack(1, 1), this.viewportBuffer = t.createVertexBuffer(_, i.b6.members), this.viewportSegments = i.b7.simpleSegment(0, 0, 4, 2); const y = new i.aT(); y.emplaceBack(0, 0, 0, 0), y.emplaceBack(i.ag, 0, i.ag, 0), y.emplaceBack(0, i.ag, 0, i.ag), y.emplaceBack(i.ag, i.ag, i.ag, i.ag), this.mercatorBoundsBuffer = t.createVertexBuffer(y, i.b9.members), this.mercatorBoundsSegments = i.b7.simpleSegment(0, 0, 4, 2); const T = new i.aU(); T.emplaceBack(0, 1, 2), T.emplaceBack(2, 1, 3), this.quadTriangleIndexBuffer = t.createIndexBuffer(T); const z = new i.b5(); for (const F of [0, 1, 3, 2, 0]) z.emplaceBack(F); this.debugIndexBuffer = t.createIndexBuffer(z), this.emptyTexture = new i.T(t, new i.r({ width: 1, height: 1 }, Uint8Array.of(0, 0, 0, 0)), t.gl.RGBA8), this.identityMat = i.ab.mat4.create(); const R = this.context.gl; this.stencilClearMode = new ci({ func: R.ALWAYS, mask: 0 }, 0, 255, R.ZERO, R.ZERO, R.ZERO), this.loadTimeStamps.push(performance.now()); } getMercatorTileBoundsBuffers() { return { tileBoundsBuffer: this.mercatorBoundsBuffer, tileBoundsIndexBuffer: this.quadTriangleIndexBuffer, tileBoundsSegments: this.mercatorBoundsSegments }; } getTileBoundsBuffers(t) { return t._makeTileBoundsBuffers(this.context, this.transform.projection), t._tileBoundsBuffer ? { tileBoundsBuffer: t._tileBoundsBuffer, tileBoundsIndexBuffer: t._tileBoundsIndexBuffer, tileBoundsSegments: t._tileBoundsSegments } : this.getMercatorTileBoundsBuffers(); } clearStencil() { const t = this.context.gl; this.nextStencilID = 1, this.currentStencilSource = void 0, this._tileClippingMaskIDs = {}, this.getOrCreateProgram("clippingMask").draw(this, t.TRIANGLES, Wt.disabled, this.stencilClearMode, bi.disabled, ti.disabled, nc(this.identityMat), "$clipping", this.viewportBuffer, this.quadTriangleIndexBuffer, this.viewportSegments); } resetStencilClippingMasks() { this.terrain || (this.currentStencilSource = void 0, this._tileClippingMaskIDs = {}); } _renderTileClippingMasks(t, s, h) { if (!s || this.currentStencilSource === s.id || !t.isTileClipped() || !h || h.length === 0) return; if (this._tileClippingMaskIDs && !this.terrain) { let z = !1; for (const R of h) if (this._tileClippingMaskIDs[R.key] === void 0) { z = !0; break; } if (!z) return; } this.currentStencilSource = s.id; const _ = this.context, y = _.gl; this.nextStencilID + h.length > 256 && this.clearStencil(), _.setColorMode(bi.disabled), _.setDepthMode(Wt.disabled); const T = this.getOrCreateProgram("clippingMask"); this._tileClippingMaskIDs = {}; for (const z of h) { const R = s.getTile(z), F = this._tileClippingMaskIDs[z.key] = this.nextStencilID++, { tileBoundsBuffer: N, tileBoundsIndexBuffer: G, tileBoundsSegments: Z } = this.getTileBoundsBuffers(R); T.draw(this, y.TRIANGLES, Wt.disabled, new ci({ func: y.ALWAYS, mask: 0 }, F, 255, y.KEEP, y.KEEP, y.REPLACE), bi.disabled, ti.disabled, nc(z.projMatrix), "$clipping", N, G, Z); } } stencilModeFor3D() { this.currentStencilSource = void 0, this.nextStencilID + 1 > 256 && this.clearStencil(); const t = this.nextStencilID++, s = this.context.gl; return new ci({ func: s.NOTEQUAL, mask: 255 }, t, 255, s.KEEP, s.KEEP, s.REPLACE); } stencilModeForClipping(t) { if (this.terrain) return this.terrain.stencilModeForRTTOverlap(t); const s = this.context.gl; return new ci({ func: s.EQUAL, mask: 255 }, this._tileClippingMaskIDs[t.key], 0, s.KEEP, s.KEEP, s.REPLACE); } stencilConfigForOverlap(t) { const s = this.context.gl, h = t.sort((T, z) => z.overscaledZ - T.overscaledZ), _ = h[h.length - 1].overscaledZ, y = h[0].overscaledZ - _ + 1; if (y > 1) { this.currentStencilSource = void 0, this.nextStencilID + y > 256 && this.clearStencil(); const T = {}; for (let z = 0; z < y; z++) T[z + _] = new ci({ func: s.GEQUAL, mask: 255 }, z + this.nextStencilID, 255, s.KEEP, s.KEEP, s.REPLACE); return this.nextStencilID += y, [T, h]; } return [{ [_]: ci.disabled }, h]; } colorModeForRenderPass() { const t = this.context.gl; return this._showOverdrawInspector ? new bi([t.CONSTANT_COLOR, t.ONE, t.CONSTANT_COLOR, t.ONE], new i.aj(0.125, 0.125, 0.125, 0), [!0, !0, !0, !0]) : this.renderPass === "opaque" ? bi.unblended : bi.alphaBlended; } colorModeForDrapableLayerRenderPass(t) { const s = this.context.gl; return (() => this.style && this.style.enable3dLights() && this.terrain && this.terrain.renderingToTexture)() && this.renderPass === "translucent" ? new bi([s.ONE, s.ONE_MINUS_SRC_ALPHA, s.CONSTANT_ALPHA, s.ONE_MINUS_SRC_ALPHA], new i.aj(0, 0, 0, t === void 0 ? 0 : t), [!0, !0, !0, !0]) : this.colorModeForRenderPass(); } depthModeForSublayer(t, s, h, _ = !1) { if (this.depthOcclusion) return new Wt(this.context.gl.GREATER, Wt.ReadOnly, this.depthRangeFor3D); if (!this.opaquePassEnabledForLayer() && !_) return Wt.disabled; const y = 1 - ((1 + this.currentLayer) * this.numSublayers + t) * this.depthEpsilon; return new Wt(h || this.context.gl.LEQUAL, s, [y, y]); } opaquePassEnabledForLayer() { return this.currentLayer < this.opaquePassCutoff; } blitDepth() { const t = this.context.gl, s = Math.ceil(this.width), h = Math.ceil(this.height), _ = this.context.bindFramebuffer.get(), y = t.getParameter(t.TEXTURE_BINDING_2D); this.depthFBO && this.depthFBO.width === s && this.depthFBO.height === h || (this.depthFBO && (this.depthFBO.destroy(), this.depthFBO = void 0, this.depthTexture = void 0), s !== 0 && h !== 0 && (this.depthFBO = new br(this.context, s, h, !1, "texture"), this.depthTexture = new i.T(this.context, { width: s, height: h, data: null }, t.DEPTH24_STENCIL8), this.depthFBO.depthAttachment.set(this.depthTexture.texture))), this.context.bindFramebuffer.set(_), t.bindTexture(t.TEXTURE_2D, y), this.depthFBO && (t.bindFramebuffer(t.READ_FRAMEBUFFER, null), t.bindFramebuffer(t.DRAW_FRAMEBUFFER, this.depthFBO.framebuffer), t.blitFramebuffer(0, 0, s, h, 0, 0, s, h, t.DEPTH_BUFFER_BIT, t.NEAREST), t.bindFramebuffer(t.FRAMEBUFFER, this.context.bindFramebuffer.current)); } updateAverageFPS() { this._fpsHistory.push(this._dt === 0 ? 0 : 1e3 / this._dt), this._fpsHistory.length > this._debugParams.fpsWindow && this._fpsHistory.splice(0, this._fpsHistory.length - this._debugParams.fpsWindow), this._averageFPS = Math.round(this._fpsHistory.reduce((t, s) => t + s / this._fpsHistory.length, 0)); } render(t, s) { const h = i.q.now(); this._dt = h - this._timeStamp, this._timeStamp = h, this._wireframeDebugCache.update(this.frameCounter), this._debugParams.continousRedraw = t.map.repaint, this.style = t, this.options = s; const _ = this.style._mergedLayers, y = this.style._getOrder(!(!this.terrain || !this.terrain.enabled)).filter((ke) => { const Ne = _[ke]; return !(Ne.type in this._debugParams.enabledLayers) || this._debugParams.enabledLayers[Ne.type]; }); let T = !1, z = !1; for (const ke of y) { const Ne = _[ke]; Ne.type === "circle" && (T = !0), Ne.type === "symbol" && (Ne.hasInitialOcclusionOpacityProperties ? z = !0 : T = !0); } const R = y.map((ke) => _[ke]), F = this.style._mergedSourceCaches; this.imageManager = t.imageManager, this.modelManager = t.modelManager, this.symbolFadeChange = t.placement.symbolFadeChange(i.q.now()), this.imageManager.beginFrame(); let N = 0, G = !1; for (const ke in F) { const Ne = F[ke]; Ne.used && (Ne.prepare(this.context), Ne.getSource().usedInConflation && ++N); } let Z = !1; for (const ke of R) ke.isHidden(this.transform.zoom) || (ke.type === "clip" && (Z = !0), this.prepareLayer(ke)); const W = {}, te = {}, ee = {}, se = {}, oe = {}; for (const ke in F) { const Ne = F[ke]; W[ke] = Ne.getVisibleCoordinates(), te[ke] = W[ke].slice().reverse(), ee[ke] = Ne.getVisibleCoordinates(!0).reverse(), se[ke] = Ne.getShadowCasterCoordinates(), oe[ke] = Ne.sortCoordinatesByDistance(W[ke]); } const he = (ke) => { const Ne = this.style.getLayerSourceCache(ke); return Ne && Ne.used ? Ne.getSource() : null; }; if (N || Z || this._clippingActiveLastFrame) { const ke = [], Ne = []; let st = 0; for (const ut of R) this.isSourceForClippingOrConflation(ut, he(ut)) && (ke.push(ut), Ne.push(st)), st++; if (ke && (Z || ke.length > 1) || this._clippingActiveLastFrame) { Z = !1; const ut = []; for (let xt = 0; xt < ke.length; xt++) { const Ge = ke[xt], lt = Ne[xt], Je = this.style.getLayerSourceCache(Ge); if (!Je || !Je.used || !Je.getSource().usedInConflation && Ge.type !== "clip") continue; let _t = i.dx, ct = i.by.None; const nt = []; let Lt = !0; if (Ge.type === "clip") { _t = lt; for (const bt of Ge.layout.get("clip-layer-types")) ct |= bt === "model" ? i.by.Model : bt === "symbol" ? i.by.Symbol : i.by.FillExtrusion; for (const bt of Ge.layout.get("clip-layer-scope")) nt.push(bt); Ge.isHidden(this.transform.zoom) ? Lt = !1 : Z = !0; } Lt && ut.push({ layer: Ge.fqid, cache: Je, order: _t, clipMask: ct, clipScope: nt }); } this.replacementSource.setSources(ut), G = !0; } } this._clippingActiveLastFrame = Z, G || this.replacementSource.clear(), this.conflationActive = G, this.minCutoffZoom = 0, this.longestCutoffRange = 0, this.opaquePassCutoff = 1 / 0, this._lastOcclusionLayer = -1, this.layersWithOcclusionOpacity = []; for (let ke = 0; ke < R.length; ke++) { const Ne = R[ke], st = Ne.cutoffRange(); if (this.longestCutoffRange = Math.max(st, this.longestCutoffRange), st > 0) { const ut = he(Ne); ut && (this.minCutoffZoom = Math.max(ut.minzoom, this.minCutoffZoom)), Ne.minzoom && (this.minCutoffZoom = Math.max(Ne.minzoom, this.minCutoffZoom)); } Ne.is3D() && (this.opaquePassCutoff === 1 / 0 && (this.opaquePassCutoff = ke), this._lastOcclusionLayer = ke); } const _e = this.style && this.style.fog; _e ? (this._fogVisible = _e.getOpacity(this.transform.pitch) !== 0, this._fogVisible && this.transform.projection.name !== "globe" && (this._fogVisible = _e.isVisibleOnFrustum(this.transform.cameraFrustum))) : this._fogVisible = !1, this._cachedTileFogOpacities = {}, this.terrain && (this.terrain.updateTileBinding(ee), this.opaquePassCutoff = 0); const pe = this._shadowRenderer; if (pe) { pe.updateShadowParameters(this.transform, this.style.directionalLight); for (const ke in F) for (const Ne of W[ke]) { let st = { min: 0, max: 0 }; this.terrain && (st = this.terrain.getMinMaxForTile(Ne) || st), pe.addShadowReceiver(Ne.toUnwrapped(), st.min, st.max); } } this.transform.projection.name !== "globe" || this.globeSharedBuffers || (this.globeSharedBuffers = new i.dw(this.context)), this.style.fog && this.transform.projection.supportsFog ? (this._atmosphere || (this._atmosphere = new bn(this)), this._atmosphere.update(this)) : this._atmosphere && (this._atmosphere.destroy(), this._atmosphere = void 0); const Me = this._debugParams.forceEnablePrecipitation || !(!this.style || !this.style.snow), xe = this._debugParams.forceEnablePrecipitation || !(!this.style || !this.style.rain); if (Me && !this._snow && (this._snow = new Pl(this)), !Me && this._snow && (this._snow.destroy(), delete this._snow), xe && !this._rain && (this._rain = new Cd(this)), !xe && this._rain && (this._rain.destroy(), delete this._rain), this._snow && this._snow.update(this), this._rain && this._rain.update(this), !Vs.has(this.context.gl)) return; this.renderPass = "offscreen"; for (const ke of R) { const Ne = t.getLayerSourceCache(ke); if (!ke.hasOffscreenPass() || ke.isHidden(this.transform.zoom)) continue; const st = Ne ? te[Ne.id] : void 0; (ke.type === "custom" || ke.type === "raster" || ke.type === "raster-particle" || ke.isSky() || st && st.length) && this.renderLayer(this, Ne, ke, st); } this.depthRangeFor3D = [0, 1 - (R.length + 2) * this.numSublayers * this.depthEpsilon], this._shadowRenderer && (this.renderPass = "shadow", this._shadowRenderer.drawShadowPass(this.style, se)), this.context.bindFramebuffer.set(null), this.context.viewport.set([0, 0, this.width, this.height]); const we = this.transform.projection.name === "globe" || this.transform.isHorizonVisible(), ve = (() => { if (s.showOverdrawInspector) return i.aj.black; const ke = this.style.fog; if (ke && this.transform.projection.supportsFog) { const Ne = this.style.getLut(ke.scope); if (!we) { const st = ke.properties.get("color-use-theme") === "none", ut = ke.properties.get("color").toRenderColor(st ? null : Ne).toArray01(); return new i.aj(...ut); } if (we) { const st = ke.properties.get("space-color-use-theme") === "none", ut = ke.properties.get("space-color").toRenderColor(st ? null : Ne).toArray01(); return new i.aj(...ut); } } return i.aj.transparent; })(); if (this.context.clear({ color: ve, depth: 1 }), this.clearStencil(), this._showOverdrawInspector = s.showOverdrawInspector, this.renderPass = "opaque", this.style.fog && this.transform.projection.supportsFog && this._atmosphere && !this._showOverdrawInspector && we && this._atmosphere.drawStars(this, this.style.fog), !this.terrain) for (this.currentLayer = y.length - 1; this.currentLayer >= 0; this.currentLayer--) { const ke = R[this.currentLayer], Ne = t.getLayerSourceCache(ke); if (ke.isSky()) continue; const st = Ne ? (ke.is3D() ? oe : te)[Ne.id] : void 0; this._renderTileClippingMasks(ke, Ne, st), this.renderLayer(this, Ne, ke, st); } if (this.style.fog && this.transform.projection.supportsFog && this._atmosphere && !this._showOverdrawInspector && we && this._atmosphere.drawAtmosphereGlow(this, this.style.fog), this.renderPass = "sky", (!this._atmosphere || i.ae(this.transform.zoom) > 0) && (this.transform.projection.name === "globe" || this.transform.isHorizonVisible())) for (this.currentLayer = 0; this.currentLayer < y.length; this.currentLayer++) { const ke = R[this.currentLayer], Ne = t.getLayerSourceCache(ke); ke.isSky() && this.renderLayer(this, Ne, ke, Ne ? te[Ne.id] : void 0); } function Ae(ke, Ne) { let st; return Ne && (st = (ke.type === "symbol" ? ee : ke.is3D() ? oe : te)[Ne.id]), st; } if (this.renderPass = "translucent", this.transform.projection.name === "globe") { for (this.renderElevatedRasterBackface = !0, this.currentLayer = 0; this.currentLayer < y.length; ) { const ke = R[this.currentLayer]; if (ke.type === "raster" || ke.type === "raster-particle") { const Ne = t.getLayerSourceCache(ke); this.renderLayer(this, Ne, ke, Ae(ke, Ne)); } ++this.currentLayer; } this.renderElevatedRasterBackface = !1; } this.currentLayer = 0, this.firstLightBeamLayer = Number.MAX_SAFE_INTEGER; let Oe = 0; pe && (Oe = pe.getShadowCastingLayerCount()); let Xe = !1, He = -1; for (let ke = 0; ke < y.length; ++ke) { const Ne = R[ke]; Ne.isHidden(this.transform.zoom) || Ne.is3D() && (He = ke); } for (z && He === -1 && (T = !0); this.currentLayer < y.length; ) { const ke = R[this.currentLayer], Ne = t.getLayerSourceCache(ke); if (ke.isSky()) ++this.currentLayer; else if (this.terrain && this.style.isLayerDraped(ke)) { if (ke.isHidden(this.transform.zoom)) { ++this.currentLayer; continue; } this.currentLayer = this.terrain.renderBatch(this.currentLayer), this._lastOcclusionLayer = Math.max(this.currentLayer, this._lastOcclusionLayer); } else { if (T && !Xe && this.terrain && !this.transform.isOrthographic && (Xe = !0, this.blitDepth()), z && He !== -1 && this.currentLayer === He + 1 && !this.transform.isOrthographic && this.blitDepth(), ke.is3D() || this.terrain || this._renderTileClippingMasks(ke, Ne, Ne ? W[Ne.id] : void 0), this.renderLayer(this, Ne, ke, Ae(ke, Ne)), !this.terrain && pe && Oe > 0 && ke.hasShadowPass() && --Oe == 0 && (pe.drawGroundShadows(), this.firstLightBeamLayer <= this.currentLayer)) { const st = this.currentLayer; for (this.renderPass = "light-beam", this.currentLayer = this.firstLightBeamLayer; this.currentLayer <= st; this.currentLayer++) { const ut = R[this.currentLayer]; if (!ut.hasLightBeamPass()) continue; const xt = t.getLayerSourceCache(ut); this.renderLayer(this, xt, ut, xt ? te[xt.id] : void 0); } this.currentLayer = st, this.renderPass = "translucent"; } if (this.currentLayer >= this._lastOcclusionLayer && this.layersWithOcclusionOpacity.length > 0) { const st = this.currentLayer; this.depthOcclusion = !0; for (const ut of this.layersWithOcclusionOpacity) { this.currentLayer = ut; const xt = R[this.currentLayer], Ge = t.getLayerSourceCache(xt), lt = Ge ? te[Ge.id] : void 0; xt.is3D() || this.terrain || this._renderTileClippingMasks(xt, Ge, Ge ? W[Ge.id] : void 0), this.renderLayer(this, Ge, xt, lt); } this.depthOcclusion = !1, this.currentLayer = st, this.renderPass = "translucent", this.layersWithOcclusionOpacity = []; } ++this.currentLayer; } } if (this.terrain && this.terrain.postRender(), this._snow && this._snow.draw(this), this._rain && this._rain.draw(this), this.options.showTileBoundaries || this.options.showQueryGeometry || this.options.showTileAABBs) { let ke = null; R.forEach((Ne) => { const st = t.getLayerSourceCache(Ne); st && !Ne.isHidden(this.transform.zoom) && st.getVisibleCoordinates().length && (!ke || ke.getSource().maxzoom < st.getSource().maxzoom) && (ke = st); }), ke && this.options.showTileBoundaries && ah.debug(this, ke, ke.getVisibleCoordinates(), i.aj.red, !1, this.options.showParseStatus); } this.terrain && this._debugParams.showTerrainProxyTiles && ah.debug(this, this.terrain.proxySourceCache, this.terrain.proxyCoords, new i.aj(1, 0.8, 0.1, 1), !0, this.options.showParseStatus), this.options.showPadding && function(ke) { const Ne = ke.transform.padding; nh(ke, ke.transform.height - (Ne.top || 0), 3, sp), nh(ke, Ne.bottom || 0, 3, rp), hu(ke, Ne.left || 0, 3, hc), hu(ke, ke.transform.width - (Ne.right || 0), 3, t_); const st = ke.transform.centerPoint; (function(ut, xt, Ge, lt) { sh(ut, xt - 1, Ge - 10, 2, 20, lt), sh(ut, xt - 10, Ge - 1, 20, 2, lt); })(ke, st.x, ke.transform.height - st.y, i_); }(this), this.context.setDefault(), this.frameCounter = (this.frameCounter + 1) % Number.MAX_SAFE_INTEGER, this.tileLoaded && this.options.speedIndexTiming && (this.loadTimeStamps.push(performance.now()), this.saveCanvasCopy()), G || (this.conflationActive = !1); } prepareLayer(t) { this.gpuTimingStart(t); const { unsupportedLayers: s } = this.transform.projection, h = !s || !s.includes(t.type); if (xu[t.type] && (h || this.terrain && t.type === "custom")) { const _ = this.style.getLayerSourceCache(t); xu[t.type](t, _, this); } this.gpuTimingEnd(); } renderLayer(t, s, h, _) { h.isHidden(this.transform.zoom) || (h.type === "background" || h.type === "sky" || h.type === "custom" || h.type === "model" || h.type === "raster" || h.type === "raster-particle" || _ && _.length) && (this.id = h.id, this.gpuTimingStart(h), t.transform.projection.unsupportedLayers && t.transform.projection.unsupportedLayers.includes(h.type) && (!t.terrain || h.type !== "custom") || h.type === "clip" || ah[h.type](t, s, h, _, this.style.placement.variableOffsets, this.options.isInitialLoad), this.gpuTimingEnd()); } gpuTimingStart(t) { if (!this.options.gpuTiming) return; const s = this.context.extTimerQuery, h = this.context.gl; let _ = this.gpuTimers[t.id]; _ || (_ = this.gpuTimers[t.id] = { calls: 0, cpuTime: 0, query: h.createQuery() }), _.calls++, h.beginQuery(s.TIME_ELAPSED_EXT, _.query); } gpuTimingDeferredRenderStart() { if (this.options.gpuTimingDeferredRender) { const t = this.context.extTimerQuery, s = this.context.gl, h = s.createQuery(); this.deferredRenderGpuTimeQueries.push(h), s.beginQuery(t.TIME_ELAPSED_EXT, h); } } gpuTimingDeferredRenderEnd() { this.options.gpuTimingDeferredRender && this.context.gl.endQuery(this.context.extTimerQuery.TIME_ELAPSED_EXT); } gpuTimingEnd() { this.options.gpuTiming && this.context.gl.endQuery(this.context.extTimerQuery.TIME_ELAPSED_EXT); } collectGpuTimers() { const t = this.gpuTimers; return this.gpuTimers = {}, t; } collectDeferredRenderGpuQueries() { const t = this.deferredRenderGpuTimeQueries; return this.deferredRenderGpuTimeQueries = [], t; } queryGpuTimers(t) { const s = {}; for (const h in t) { const _ = t[h], y = this.context.extTimerQuery, T = y.getQueryParameter(_.query, this.context.gl.QUERY_RESULT) / 1e6; y.deleteQueryEXT(_.query), s[h] = T; } return s; } queryGpuTimeDeferredRender(t) { if (!this.options.gpuTimingDeferredRender) return 0; const s = this.context.gl; let h = 0; for (const _ of t) h += s.getQueryParameter(_, s.QUERY_RESULT) / 1e6, s.deleteQuery(_); return h; } translatePosMatrix(t, s, h, _, y) { if (!h[0] && !h[1]) return t; const T = y ? _ === "map" ? this.transform.angle : 0 : _ === "viewport" ? -this.transform.angle : 0; if (T) { const F = Math.sin(T), N = Math.cos(T); h = [h[0] * N - h[1] * F, h[0] * F + h[1] * N]; } const z = [y ? h[0] : i.ar(s, h[0], this.transform.zoom), y ? h[1] : i.ar(s, h[1], this.transform.zoom), 0], R = new Float32Array(16); return i.ab.mat4.translate(R, t, z), R; } saveTileTexture(t) { const s = t.size[0], h = this._tileTextures[s]; h ? h.push(t) : this._tileTextures[s] = [t]; } getTileTexture(t) { const s = this._tileTextures[t]; return s && s.length > 0 ? s.pop() : null; } terrainRenderModeElevated() { return this.style && !!this.style.getTerrain() && !!this.terrain && !this.terrain.renderingToTexture || this.forceTerrainMode; } linearFloatFilteringSupported() { return this.context.extTextureFloatLinear != null; } currentGlobalDefines(t, s, h) { const _ = h === void 0 ? this.terrain && this.terrain.renderingToTexture : h, y = []; return this.style && this.style.enable3dLights() && (t === "globeRaster" || t === "terrainRaster" ? (y.push("LIGHTING_3D_MODE"), y.push("LIGHTING_3D_ALPHA_EMISSIVENESS")) : _ || y.push("LIGHTING_3D_MODE")), this.renderPass === "shadow" && (this._shadowMapDebug || y.push("DEPTH_TEXTURE")), this.terrainRenderModeElevated() && (y.push("TERRAIN"), this.linearFloatFilteringSupported() && y.push("TERRAIN_DEM_FLOAT_FORMAT")), this.transform.projection.name === "globe" && y.push("GLOBE"), !this._fogVisible || _ || s !== void 0 && !s || y.push("FOG", "FOG_DITHERING"), _ && y.push("RENDER_TO_TEXTURE"), this._showOverdrawInspector && y.push("OVERDRAW_INSPECTOR"), y; } getOrCreateProgram(t, s) { this.cache = this.cache || {}; const h = s && s.defines || [], _ = s && s.config, y = this.currentGlobalDefines(t, s && s.overrideFog, s && s.overrideRtt).concat(h), T = Xf.cacheKey(vl[t], t, y, _); return this.cache[T] || (this.cache[T] = new Xf(this.context, t, vl[t], _, yd[t], y)), this.cache[T]; } 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 t = this.context.gl; this.context.cullFace.set(!1), this.context.viewport.set([0, 0, this.width, this.height]), this.context.blendEquation.set(t.FUNC_ADD); } initDebugOverlayCanvas() { this.debugOverlayCanvas == null && (this.debugOverlayCanvas = document.createElement("canvas"), this.debugOverlayCanvas.width = 512, this.debugOverlayCanvas.height = 512, this.debugOverlayTexture = new i.T(this.context, this.debugOverlayCanvas, this.context.gl.RGBA8)); } destroy() { this._terrain && this._terrain.destroy(), this._atmosphere && (this._atmosphere.destroy(), this._atmosphere = void 0), this.globeSharedBuffers && this.globeSharedBuffers.destroy(), this.emptyTexture.destroy(), this.debugOverlayTexture && this.debugOverlayTexture.destroy(), this._wireframeDebugCache.destroy(), this.depthFBO && (this.depthFBO.destroy(), this.depthFBO = void 0, this.depthTexture = void 0), this.emptyDepthTexture && this.emptyDepthTexture.destroy(); } prepareDrawTile() { this.terrain && this.terrain.prepareDrawTile(); } uploadCommonLightUniforms(t, s) { if (this.style.enable3dLights()) { const h = this.style.directionalLight, _ = this.style.ambientLight; if (h && _) { const y = ((T, z, R) => { const F = T.properties.get("direction"), N = T.properties.get("color-use-theme") === "none", G = T.properties.get("color").toRenderColor(N ? null : R.getLut(T.scope)).toArray01(), Z = T.properties.get("intensity"), W = z.properties.get("color-use-theme") === "none", te = z.properties.get("color").toRenderColor(W ? null : R.getLut(z.scope)).toArray01(), ee = z.properties.get("intensity"), se = [F.x, F.y, F.z], oe = i.cM(te, ee), he = i.cM(G, Z); return { u_lighting_ambient_color: oe, u_lighting_directional_dir: se, u_lighting_directional_color: he, u_ground_radiance: $f(se, he, oe) }; })(h, _, this.style); s.setLightsUniformValues(t, y); } } } uploadCommonUniforms(t, s, h, _, y) { if (this.uploadCommonLightUniforms(t, s), this.terrain && this.terrain.renderingToTexture) return; const T = this.style.fog; if (T) { const z = T.getOpacity(this.transform.pitch), R = ((F, N, G, Z, W, te, ee, se, oe, he, _e, pe) => { const Me = F.transform, xe = N.properties.get("color-use-theme") === "none", we = N.properties.get("color").toRenderColor(xe ? null : F.style.getLut(N.scope)).toArray01(); we[3] = Z; const ve = F.frameCounter / 1e3 % 1, [Ae, Oe] = N.properties.get("vertical-range"); return { u_fog_matrix: G ? Me.calculateFogTileMatrix(G) : pe || F.identityMat, u_fog_range: N.getFovAdjustedRange(Me._fov), u_fog_color: we, u_fog_horizon_blend: N.properties.get("horizon-blend"), u_fog_vertical_limit: [Math.min(Ae, Oe), Oe], u_fog_temporal_offset: ve, u_frustum_tl: W, u_frustum_tr: te, u_frustum_br: ee, u_frustum_bl: se, u_globe_pos: oe, u_globe_radius: he, u_viewport: _e, u_globe_transition: i.ae(Me.zoom), u_is_globe: +(Me.projection.name === "globe") }; })(this, T, h, z, 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 * i.q.devicePixelRatio, this.transform.height * i.q.devicePixelRatio], _); s.setFogUniformValues(t, R); } y && s.setCutoffUniformValues(t, y.uniformValues); } setTileLoadedFlag(t) { this.tileLoaded = t; } saveCanvasCopy() { const t = this.canvasCopy(); t && (this.frameCopies.push(t), this.tileLoaded = !1); } canvasCopy() { const t = this.context.gl, s = t.createTexture(); return t.bindTexture(t.TEXTURE_2D, s), t.copyTexImage2D(t.TEXTURE_2D, 0, t.RGBA, 0, 0, t.drawingBufferWidth, t.drawingBufferHeight, 0), s; } getCanvasCopiesAndTimestamps() { return { canvasCopies: this.frameCopies, timeStamps: this.loadTimeStamps }; } averageElevationNeedsEasing() { if (!this.transform._elevation) return !1; const t = this.style && this.style.fog; return !!t && t.getOpacity(this.transform.pitch) !== 0; } getBackgroundTiles() { const t = this._backgroundTiles, s = this._backgroundTiles = {}, h = this.transform.coveringTiles({ tileSize: 512 }); for (const _ of h) s[_.key] = t[_.key] || new Cr(_, 512, this.transform.tileZoom, this); return s; } clearBackgroundTiles() { this._backgroundTiles = {}; } isSourceForClippingOrConflation(t, s) { return !(!t.is3D() || t.type !== "clip" && (t.minzoom && t.minzoom > this.transform.zoom || (this.style._clipLayerPresent || t.sourceLayer !== "building") && (!s || s.type !== "batched-model"))); } isTileAffectedByFog(t) { if (!this.style || !this.style.fog) return !1; if (this.transform.projection.name === "globe") return !0; let s = this._cachedTileFogOpacities[t.key]; return s || (this._cachedTileFogOpacities[t.key] = s = this.style.fog.getOpacityForTile(t)), s[0] >= It || s[1] >= It; } setupDepthForOcclusion(t, s, h) { const _ = this.context, y = _.gl, T = !!h; var z; h || (h = { u_dem: 2, u_dem_prev: 4, 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_depth_range_unpack: [0, 1], u_occluder_half_size: 16, u_occlusion_depth_offset: -1e-4, u_exaggeration: 0 }), _.activeTexture.set(y.TEXTURE3), t && this.depthFBO && this.depthTexture ? (this.depthTexture.bind(y.NEAREST, y.CLAMP_TO_EDGE), h.u_depth_size_inv = [1 / this.depthFBO.width, 1 / this.depthFBO.height], h.u_depth_range_unpack = [2 / ((z = this.depthRangeFor3D)[1] - z[0]), -1 - 2 * z[0] / (z[1] - z[0])], h.u_occluder_half_size = 0.5 * this.occlusionParams.occluderSize, h.u_occlusion_depth_offset = this.occlusionParams.depthOffset) : this.emptyDepthTexture.bind(y.NEAREST, y.CLAMP_TO_EDGE), _.activeTexture.set(y.TEXTURE0), T || s.setTerrainUniformValues(_, h); } } function lh(c, t) { let s = !1, h = null; const _ = () => { h = null, s && (c(), h = setTimeout(_, t), s = !1); }; return () => (s = !0, h || _(), h); } class zd { constructor(t) { this._hashName = t && encodeURIComponent(t), i.aP(["_getCurrentHash", "_onHashChange", "_updateHash"], this), this._updateHash = lh(this._updateHashUnthrottled.bind(this), 300); } addTo(t) { return this._map = t, window.addEventListener("hashchange", this._onHashChange, !1), t.on("moveend", this._updateHash), this; } remove() { return this._map ? (this._map.off("moveend", this._updateHash), window.removeEventListener("hashchange", this._onHashChange, !1), clearTimeout(this._updateHash()), this._map = void 0, this) : this; } getHashString() { const t = this._map; if (!t) return ""; const s = vu(t); if (this._hashName) { const h = this._hashName; let _ = !1; const y = location.hash.slice(1).split("&").map((T) => { const z = T.split("=")[0]; return z === h ? (_ = !0, `${z}=${s}`) : T; }).filter((T) => T); return _ || y.push(`${h}=${s}`), `#${y.join("&")}`; } return `#${s}`; } _getCurrentHash() { const t = location.hash.replace("#", ""); if (this._hashName) { let s; return t.split("&").map((h) => h.split("=")).forEach((h) => { h[0] === this._hashName && (s = h); }), (s && s[1] || "").split("/"); } return t.split("/"); } _onHashChange() { const t = this._map; if (!t) return !1; const s = this._getCurrentHash(); if (s.length >= 3 && !s.some((h) => isNaN(h))) { const h = t.dragRotate.isEnabled() && t.touchZoomRotate.isEnabled() ? +(s[3] || 0) : t.getBearing(); return t.jumpTo({ center: [+s[2], +s[1]], zoom: +s[0], bearing: h, pitch: +(s[4] || 0) }), !0; } return !1; } _updateHashUnthrottled() { history.replaceState(history.state, "", location.href.replace(/(#.+)?$/, this.getHashString())); } } function vu(c, t) { const s = c.getCenter(), h = Math.round(100 * c.getZoom()) / 100, _ = Math.ceil((h * Math.LN2 + Math.log(512 / 360 / 0.5)) / Math.LN10), y = Math.pow(10, _), T = Math.round(s.lng * y) / y, z = Math.round(s.lat * y) / y, R = c.getBearing(), F = c.getPitch(); let N = t ? `/${T}/${z}/${h}` : `${h}/${z}/${T}`; return (R || F) && (N += "/" + Math.round(10 * R) / 10), F && (N += `/${Math.round(F)}`), N; } const ch = { linearity: 0.3, easing: i.dy(0, 0, 0.3, 1) }, ap = i.l({ deceleration: 2500, maxSpeed: 1400 }, ch), lp = i.l({ deceleration: 20, maxSpeed: 1400 }, ch), cp = i.l({ deceleration: 1e3, maxSpeed: 360 }, ch), hp = i.l({ deceleration: 1e3, maxSpeed: 90 }, ch); class up { constructor(t) { this._map = t, this.clear(); } clear() { this._inertiaBuffer = []; } record(t) { this._drainInertiaBuffer(), this._inertiaBuffer.push({ time: i.q.now(), settings: t }); } _drainInertiaBuffer() { const t = this._inertiaBuffer, s = i.q.now(); for (; t.length > 0 && s - t[0].time > 160; ) t.shift(); } _onMoveEnd(t) { if (this._map._prefersReducedMotion() || (this._drainInertiaBuffer(), this._inertiaBuffer.length < 2)) return; const s = { zoom: 0, bearing: 0, pitch: 0, pan: new i.P(0, 0), pinchAround: void 0, around: void 0 }; for (const { settings: y } of this._inertiaBuffer) s.zoom += y.zoomDelta || 0, s.bearing += y.bearingDelta || 0, s.pitch += y.pitchDelta || 0, y.panDelta && s.pan._add(y.panDelta), y.around && (s.around = y.around), y.pinchAround && (s.pinchAround = y.pinchAround); const h = this._inertiaBuffer[this._inertiaBuffer.length - 1].time - this._inertiaBuffer[0].time, _ = {}; if (s.pan.mag()) { const y = uh(s.pan.mag(), h, i.l({}, ap, t || {})); _.offset = s.pan.mult(y.amount / s.pan.mag()), _.center = this._map.transform.center, hh(_, y); } if (s.zoom) { const y = uh(s.zoom, h, lp); _.zoom = this._map.transform.zoom + y.amount, hh(_, y); } if (s.bearing) { const y = uh(s.bearing, h, cp); _.bearing = this._map.transform.bearing + i.aw(y.amount, -179, 179), hh(_, y); } if (s.pitch) { const y = uh(s.pitch, h, hp); _.pitch = this._map.transform.pitch + y.amount, hh(_, y); } if (_.zoom || _.bearing) { const y = s.pinchAround === void 0 ? s.around : s.pinchAround; _.around = y ? this._map.unproject(y) : this._map.getCenter(); } return this.clear(), _.noMoveStart = !0, _; } } function hh(c, t) { (!c.duration || c.duration < t.duration) && (c.duration = t.duration, c.easing = t.easing); } function uh(c, t, s) { const { maxSpeed: h, linearity: _, deceleration: y } = s, T = i.aw(c * _ / (t / 1e3), -h, h), z = Math.abs(T) / (y * _); return { easing: s.easing, duration: 1e3 * z, amount: T * (z / 2) }; } class Or extends i.z { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented; } constructor(t, s, h, _ = {}) { const y = Gt(s.getCanvasContainer(), h), T = s.unproject(y); super(t, i.l({ point: y, lngLat: T, originalEvent: h }, _)), this._defaultPrevented = !1, this.target = s; } } class dh extends i.z { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented; } constructor(t, s, h) { const _ = t === "touchend" ? h.changedTouches : h.touches, y = ui(s.getCanvasContainer(), _), T = y.map((R) => s.unproject(R)), z = y.reduce((R, F, N, G) => R.add(F.div(G.length)), new i.P(0, 0)); super(t, { points: y, point: z, lngLats: T, lngLat: s.unproject(z), originalEvent: h }), this._defaultPrevented = !1; } } class dp extends i.z { preventDefault() { this._defaultPrevented = !0; } get defaultPrevented() { return this._defaultPrevented; } constructor(t, s) { super("wheel", { originalEvent: s }), this._defaultPrevented = !1; } } class fp { constructor(t, s) { this._map = t, this._clickTolerance = s.clickTolerance; } reset() { this._mousedownPos = void 0; } wheel(t) { return this._firePreventable(new dp(this._map, t)); } mousedown(t, s) { return this._mousedownPos = s, this._firePreventable(new Or(t.type, this._map, t)); } mouseup(t) { this._map.fire(new Or(t.type, this._map, t)); } preclick(t) { const s = i.l({}, t); s.type = "preclick", this._map.fire(new Or(s.type, this._map, s)); } click(t, s) { this._mousedownPos && this._mousedownPos.dist(s) >= this._clickTolerance || (this.preclick(t), this._map.fire(new Or(t.type, this._map, t))); } dblclick(t) { return this._firePreventable(new Or(t.type, this._map, t)); } mouseover(t) { this._map.fire(new Or(t.type, this._map, t)); } mouseout(t) { this._map.fire(new Or(t.type, this._map, t)); } touchstart(t) { return this._firePreventable(new dh(t.type, this._map, t)); } touchmove(t) { this._map.fire(new dh(t.type, this._map, t)); } touchend(t) { this._map.fire(new dh(t.type, this._map, t)); } touchcancel(t) { this._map.fire(new dh(t.type, this._map, t)); } _firePreventable(t) { if (this._map.fire(t), t.defaultPrevented) return {}; } isEnabled() { return !0; } isActive() { return !1; } enable() { } disable() { } } class pp { constructor(t) { this._map = t; } reset() { this._delayContextMenu = !1, this._contextMenuEvent = void 0; } mousemove(t) { this._map.fire(new Or(t.type, this._map, t)); } mousedown() { this._delayContextMenu = !0; } mouseup() { this._delayContextMenu = !1, this._contextMenuEvent && (this._map.fire(new Or("contextmenu", this._map, this._contextMenuEvent)), delete this._contextMenuEvent); } contextmenu(t) { this._delayContextMenu ? this._contextMenuEvent = t : this._map.fire(new Or(t.type, this._map, t)), this._map.listens("contextmenu") && t.preventDefault(); } isEnabled() { return !0; } isActive() { return !1; } enable() { } disable() { } } class r_ { constructor(t, s) { this._map = t, this._el = t.getCanvasContainer(), this._container = t.getContainer(), this._clickTolerance = s.clickTolerance || 1; } isEnabled() { return !!this._enabled; } isActive() { return !!this._active; } enable() { this.isEnabled() || (this._enabled = !0); } disable() { this.isEnabled() && (this._enabled = !1); } mousedown(t, s) { this.isEnabled() && t.shiftKey && t.button === 0 && (ht(), this._startPos = this._lastPos = s, this._active = !0); } mousemoveWindow(t, s) { if (!this._active) return; const h = s, _ = this._startPos, y = this._lastPos; if (!_ || !y || y.equals(h) || !this._box && h.dist(_) < this._clickTolerance) return; this._lastPos = h, this._box || (this._box = be("div", "mapboxgl-boxzoom", this._container), this._container.classList.add("mapboxgl-crosshair"), this._fireEvent("boxzoomstart", t)); const T = Math.min(_.x, h.x), z = Math.max(_.x, h.x), R = Math.min(_.y, h.y), F = Math.max(_.y, h.y); this._map._requestDomTask(() => { this._box && (this._box.style.transform = `translate(${T}px,${R}px)`, this._box.style.width = z - T + "px", this._box.style.height = F - R + "px"); }); } mouseupWindow(t, s) { if (!this._active) return; const h = this._startPos, _ = s; if (h && t.button === 0) { if (this.reset(), pt(), h.x !== _.x || h.y !== _.y) return this._map.fire(new i.z("boxzoomend", { originalEvent: t })), { cameraAnimation: (y) => y.fitScreenCoordinates(h, _, this._map.getBearing(), { linear: !1 }) }; this._fireEvent("boxzoomcancel", t); } } keydown(t) { this._active && t.keyCode === 27 && (this.reset(), this._fireEvent("boxzoomcancel", t)); } blur() { this.reset(); } reset() { this._active = !1, this._container.classList.remove("mapboxgl-crosshair"), this._box && (this._box.remove(), this._box = null), gt(), delete this._startPos, delete this._lastPos; } _fireEvent(t, s) { return this._map.fire(new i.z(t, { originalEvent: s })); } } function Dd(c, t) { const s = {}; for (let h = 0; h < c.length; h++) s[c[h].identifier] = t[h]; return s; } class Wn { constructor(t) { this.reset(), this.numTouches = t.numTouches; } reset() { this.centroid = void 0, this.startTime = 0, this.touches = {}, this.aborted = !1; } touchstart(t, s, h) { (this.centroid || h.length > this.numTouches) && (this.aborted = !0), this.aborted || (this.startTime === 0 && (this.startTime = t.timeStamp), h.length === this.numTouches && (this.centroid = function(_) { const y = new i.P(0, 0); for (const T of _) y._add(T); return y.div(_.length); }(s), this.touches = Dd(h, s))); } touchmove(t, s, h) { if (this.aborted || !this.centroid) return; const _ = Dd(h, s); for (const y in this.touches) { const T = _[y]; (!T || T.dist(this.touches[y]) > 30) && (this.aborted = !0); } } touchend(t, s, h) { if ((!this.centroid || t.timeStamp - this.startTime > 500) && (this.aborted = !0), h.length === 0) { const _ = !this.aborted && this.centroid; if (this.reset(), _) return _; } } } class bu { constructor(t) { this.singleTap = new Wn(t), this.numTaps = t.numTaps, this.reset(); } reset() { this.lastTime = 1 / 0, this.lastTap = void 0, this.count = 0, this.singleTap.reset(); } touchstart(t, s, h) { this.singleTap.touchstart(t, s, h); } touchmove(t, s, h) { this.singleTap.touchmove(t, s, h); } touchend(t, s, h) { const _ = this.singleTap.touchend(t, s, h); if (_) { const y = t.timeStamp - this.lastTime < 500, T = !this.lastTap || this.lastTap.dist(_) < 30; if (y && T || this.reset(), this.count++, this.lastTime = t.timeStamp, this.lastTap = _, this.count === this.numTaps) return this.reset(), _; } } } class o_ { constructor() { this._zoomIn = new bu({ numTouches: 1, numTaps: 2 }), this._zoomOut = new bu({ numTouches: 2, numTaps: 1 }), this.reset(); } reset() { this._active = !1, this._zoomIn.reset(), this._zoomOut.reset(); } touchstart(t, s, h) { this._zoomIn.touchstart(t, s, h), this._zoomOut.touchstart(t, s, h); } touchmove(t, s, h) { this._zoomIn.touchmove(t, s, h), this._zoomOut.touchmove(t, s, h); } touchend(t, s, h) { const _ = this._zoomIn.touchend(t, s, h), y = this._zoomOut.touchend(t, s, h); return _ ? (this._active = !0, t.preventDefault(), setTimeout(() => this.reset(), 0), { cameraAnimation: (T) => T.easeTo({ duration: 300, zoom: T.getZoom() + 1, around: T.unproject(_) }, { originalEvent: t }) }) : y ? (this._active = !0, t.preventDefault(), setTimeout(() => this.reset(), 0), { cameraAnimation: (T) => T.easeTo({ duration: 300, zoom: T.getZoom() - 1, around: T.unproject(y) }, { originalEvent: t }) }) : void 0; } touchcancel() { this.reset(); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled; } isActive() { return this._active; } } const a_ = { 0: 1, 2: 2 }; class Al { constructor(t) { this.reset(), this._clickTolerance = t.clickTolerance || 1; } blur() { this.reset(); } reset() { this._active = !1, this._moved = !1, this._lastPoint = void 0, this._eventButton = void 0; } _correctButton(t, s) { return !1; } _move(t, s) { return {}; } mousedown(t, s) { if (this._lastPoint) return; const h = kt(t); this._correctButton(t, h) && (this._lastPoint = s, this._eventButton = h); } mousemoveWindow(t, s) { const h = this._lastPoint; if (h) { if (t.preventDefault(), this._eventButton != null && function(_, y) { const T = a_[y]; return _.buttons === void 0 || (_.buttons & T) !== T; }(t, this._eventButton)) this.reset(); else if (this._moved || !(s.dist(h) < this._clickTolerance)) return this._moved = !0, this._lastPoint = s, this._move(h, s); } } mouseupWindow(t) { this._lastPoint && kt(t) === this._eventButton && (this._moved && pt(), this.reset()); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled; } isActive() { return this._active; } } class mp extends Al { mousedown(t, s) { super.mousedown(t, s), this._lastPoint && (this._active = !0); } _correctButton(t, s) { return s === 0 && !t.ctrlKey; } _move(t, s) { return { around: s, panDelta: s.sub(t) }; } } class wu extends Al { _correctButton(t, s) { return s === 0 && t.ctrlKey || s === 2; } _move(t, s) { const h = 0.8 * (s.x - t.x); if (h) return this._active = !0, { bearingDelta: h }; } contextmenu(t) { t.preventDefault(); } } class fh extends Al { _correctButton(t, s) { return s === 0 && t.ctrlKey || s === 2; } _move(t, s) { const h = -0.5 * (s.y - t.y); if (h) return this._active = !0, { pitchDelta: h }; } contextmenu(t) { t.preventDefault(); } } class ba { constructor(t, s) { this._map = t, this._el = t.getCanvasContainer(), this._minTouches = 1, this._clickTolerance = s.clickTolerance || 1, this.reset(), i.aP(["_addTouchPanBlocker", "_showTouchPanBlockerAlert"], this); } reset() { this._active = !1, this._touches = {}, this._sum = new i.P(0, 0); } touchstart(t, s, h) { return this._calculateTransform(t, s, h); } touchmove(t, s, h) { if (this._active && !(h.length < this._minTouches)) { if (this._map._cooperativeGestures && !this._map.isMoving()) { if (h.length === 1 && !i.dz()) return void this._showTouchPanBlockerAlert(); this._alertContainer.style.visibility !== "hidden" && (this._alertContainer.style.visibility = "hidden", clearTimeout(this._alertTimer)); } return t.cancelable && t.preventDefault(), this._calculateTransform(t, s, h); } } touchend(t, s, h) { this._calculateTransform(t, s, h), this._active && h.length < this._minTouches && this.reset(); } touchcancel() { this.reset(); } _calculateTransform(t, s, h) { h.length > 0 && (this._active = !0); const _ = Dd(h, s), y = new i.P(0, 0), T = new i.P(0, 0); let z = 0; for (const F in _) { const N = _[F], G = this._touches[F]; G && (y._add(N), T._add(N.sub(G)), z++, _[F] = N); } if (this._touches = _, z < this._minTouches || !T.mag()) return; const R = T.div(z); return this._sum._add(R), this._sum.mag() < this._clickTolerance ? void 0 : { around: y.div(z), panDelta: R }; } 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 = be("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(0.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 = window.setTimeout(() => { this._alertContainer.classList.remove("mapboxgl-touch-pan-blocker-show"), this._alertContainer.removeAttribute("role"); }, 500); } } class dc { constructor() { this.reset(); } reset() { this._active = !1, this._firstTwoTouches = void 0; } _start(t) { } _move(t, s, h) { return {}; } touchstart(t, s, h) { this._firstTwoTouches || h.length < 2 || (this._firstTwoTouches = [h[0].identifier, h[1].identifier], this._start([s[0], s[1]])); } touchmove(t, s, h) { const _ = this._firstTwoTouches; if (!_) return; t.preventDefault(); const [y, T] = _, z = Nn(h, s, y), R = Nn(h, s, T); if (!z || !R) return; const F = this._aroundCenter ? null : z.add(R).div(2); return this._move([z, R], F, t); } touchend(t, s, h) { if (!this._firstTwoTouches) return; const [_, y] = this._firstTwoTouches, T = Nn(h, s, _), z = Nn(h, s, y); T && z || (this._active && pt(), this.reset()); } touchcancel() { this.reset(); } enable(t) { this._enabled = !0, this._aroundCenter = !!t && t.around === "center"; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled; } isActive() { return this._active; } } function Nn(c, t, s) { for (let h = 0; h < c.length; h++) if (c[h].identifier === s) return t[h]; } function zo(c, t) { return Math.log(c / t) / Math.LN2; } class kd extends dc { reset() { super.reset(), this._distance = 0, this._startDistance = 0; } _start(t) { this._startDistance = this._distance = t[0].dist(t[1]); } _move(t, s) { const h = this._distance; if (this._distance = t[0].dist(t[1]), this._active || !(Math.abs(zo(this._distance, this._startDistance)) < 0.1)) return this._active = !0, { zoomDelta: zo(this._distance, h), pinchAround: s }; } } function ph(c, t) { return 180 * c.angleWith(t) / Math.PI; } class _p extends dc { reset() { super.reset(), this._minDiameter = 0, this._startVector = void 0, this._vector = void 0; } _start(t) { this._startVector = this._vector = t[0].sub(t[1]), this._minDiameter = t[0].dist(t[1]); } _move(t, s) { const h = this._vector; if (this._vector = t[0].sub(t[1]), h && (this._active || !this._isBelowThreshold(this._vector))) return this._active = !0, { bearingDelta: ph(this._vector, h), pinchAround: s }; } _isBelowThreshold(t) { this._minDiameter = Math.min(this._minDiameter, t.mag()); const s = 25 / (Math.PI * this._minDiameter) * 360, h = this._startVector; if (!h) return !1; const _ = ph(t, h); return Math.abs(_) < s; } } function Rd(c) { return Math.abs(c.y) > Math.abs(c.x); } class mh extends dc { constructor(t) { super(), this._map = t; } reset() { super.reset(), this._valid = void 0, this._firstMove = void 0, this._lastPoints = void 0; } _start(t) { this._lastPoints = t, Rd(t[0].sub(t[1])) && (this._valid = !1); } _move(t, s, h) { const _ = this._lastPoints; if (!_) return; const y = t[0].sub(_[0]), T = t[1].sub(_[1]); return this._map._cooperativeGestures && !i.dz() && h.touches.length < 3 || (this._valid = this.gestureBeginsVertically(y, T, h.timeStamp), !this._valid) ? void 0 : (this._lastPoints = t, this._active = !0, { pitchDelta: (y.y + T.y) / 2 * -0.5 }); } gestureBeginsVertically(t, s, h) { if (this._valid !== void 0) return this._valid; const _ = t.mag() >= 2, y = s.mag() >= 2; if (!_ && !y) return; if (!_ || !y) return this._firstMove == null && (this._firstMove = h), h - this._firstMove < 100 && void 0; const T = t.y > 0 == s.y > 0; return Rd(t) && Rd(s) && T; } } const l_ = { panStep: 100, bearingStep: 15, pitchStep: 10 }; class c_ { constructor() { const t = l_; this._panStep = t.panStep, this._bearingStep = t.bearingStep, this._pitchStep = t.pitchStep, this._rotationDisabled = !1; } blur() { this.reset(); } reset() { this._active = !1; } keydown(t) { if (t.altKey || t.ctrlKey || t.metaKey) return; let s = 0, h = 0, _ = 0, y = 0, T = 0; switch (t.keyCode) { case 61: case 107: case 171: case 187: s = 1; break; case 189: case 109: case 173: s = -1; break; case 37: t.shiftKey ? h = -1 : (t.preventDefault(), y = -1); break; case 39: t.shiftKey ? h = 1 : (t.preventDefault(), y = 1); break; case 38: t.shiftKey ? _ = 1 : (t.preventDefault(), T = -1); break; case 40: t.shiftKey ? _ = -1 : (t.preventDefault(), T = 1); break; default: return; } return this._rotationDisabled && (h = 0, _ = 0), { cameraAnimation: (z) => { const R = z.getZoom(); z.easeTo({ duration: 300, easeId: "keyboardHandler", easing: Od, zoom: s ? Math.round(R) + s * (t.shiftKey ? 2 : 1) : R, bearing: z.getBearing() + h * this._bearingStep, pitch: z.getPitch() + _ * this._pitchStep, offset: [-y * this._panStep, -T * this._panStep], center: z.getCenter() }, { originalEvent: t }); } }; } 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 Od(c) { return c * (2 - c); } const Tu = 4.000244140625, fc = 1 / 450; class pc { constructor(t, s) { this._map = t, this._el = t.getCanvasContainer(), this._handler = s, this._delta = 0, this._lastDelta = 0, this._defaultZoomRate = 0.01, this._wheelZoomRate = fc, i.aP(["_onTimeout", "_addScrollZoomBlocker", "_showBlockerAlert"], this); } setZoomRate(t) { this._defaultZoomRate = t; } setWheelZoomRate(t) { this._wheelZoomRate = t; } isEnabled() { return !!this._enabled; } isActive() { return this._active || this._finishTimeout !== void 0; } isZooming() { return !!this._zooming; } enable(t) { this.isEnabled() || (this._enabled = !0, this._aroundCenter = !!t && t.around === "center", 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() || i.dz())) return void this._showBlockerAlert(); this._alertContainer.style.visibility !== "hidden" && (this._alertContainer.style.visibility = "hidden", clearTimeout(this._alertTimer)); } let s = t.deltaMode === WheelEvent.DOM_DELTA_LINE ? 40 * t.deltaY : t.deltaY; const h = i.q.now(), _ = h - (this._lastWheelEventTime || 0); this._lastWheelEventTime = h, s !== 0 && s % Tu == 0 ? this._type = "wheel" : s !== 0 && Math.abs(s) < 4 ? this._type = "trackpad" : _ > 400 ? (this._type = null, this._lastValue = s, this._timeout = window.setTimeout(this._onTimeout, 40, t)) : this._type || (this._type = Math.abs(_ * s) < 200 ? "trackpad" : "wheel", this._timeout && (clearTimeout(this._timeout), this._timeout = null, s += this._lastValue)), t.shiftKey && s && (s /= 4), this._type && (this._lastWheelEvent = t, this._delta -= s, this._active || this._start(t)), t.preventDefault(); } _onTimeout(t) { this._type = "wheel", this._delta -= this._lastValue, this._active || this._start(t); } _start(t) { 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 s = Gt(this._el, t); this._aroundPoint = this._aroundCenter ? this._map.transform.centerPoint : s, this._aroundCoord = this._map.transform.pointCoordinate3D(this._aroundPoint), this._targetZoom = void 0, this._frameId || (this._frameId = !0, this._handler._triggerRenderFrame()); } renderFrame() { if (!this._frameId || (this._frameId = null, !this.isActive())) return; const t = this._map.transform; this._type === "wheel" && t.projection.wrap && (t._center.lng >= 180 || t._center.lng <= -180) && (this._prevEase = null, this._easing = null, this._lastWheelEvent = null, this._lastWheelEventTime = 0); const s = () => t._terrainEnabled() && this._aroundCoord ? t.computeZoomRelativeTo(this._aroundCoord) : t.zoom; if (this._delta !== 0) { const F = this._type === "wheel" && Math.abs(this._delta) > Tu ? this._wheelZoomRate : this._defaultZoomRate; let N = 2 / (1 + Math.exp(-Math.abs(this._delta * F))); this._delta < 0 && N !== 0 && (N = 1 / N); const G = s(), Z = Math.pow(2, G), W = typeof this._targetZoom == "number" ? t.zoomScale(this._targetZoom) : Z; this._targetZoom = Math.min(t.maxZoom, Math.max(t.minZoom, t.scaleZoom(W * N))), this._type === "wheel" && (this._startZoom = G, this._easing = this._smoothOutEasing(200)), this._lastDelta = this._delta, this._delta = 0; } const h = typeof this._targetZoom == "number" ? this._targetZoom : s(), _ = this._startZoom, y = this._easing; let T, z = !1; if (this._type === "wheel" && _ && y) { const F = Math.min((i.q.now() - this._lastWheelEventTime) / 200, 1), N = y(F); T = i.af(_, h, N), F < 1 ? this._frameId || (this._frameId = !0) : z = !0; } else T = h, z = !0; this._active = !0, z && (this._active = !1, this._finishTimeout = window.setTimeout(() => { this._zooming = !1, this._handler._triggerRenderFrame(), delete this._targetZoom, delete this._finishTimeout; }, 200)); let R = T - s(); return R * this._lastDelta < 0 && (R = 0), { noInertia: !0, needsRenderFrame: !z, zoomDelta: R, around: this._aroundPoint, aroundCoord: this._aroundCoord, originalEvent: this._lastWheelEvent }; } _smoothOutEasing(t) { let s = i.dA; if (this._prevEase) { const h = this._prevEase, _ = (i.q.now() - h.start) / h.duration, y = h.easing(_ + 0.01) - h.easing(_), T = 0.27 / Math.sqrt(y * y + 1e-4) * 0.01, z = Math.sqrt(0.0729 - T * T); s = i.dy(T, z, 0.25, 1); } return this._prevEase = { start: i.q.now(), duration: t, easing: s }, s; } blur() { this.reset(); } reset() { this._active = !1; } _addScrollZoomBlocker() { this._map && !this._alertContainer && (this._alertContainer = be("div", "mapboxgl-scroll-zoom-blocker", this._map._container), this._alertContainer.textContent = /(Mac|iPad)/i.test(navigator.userAgent) ? this._map._getUIString("ScrollZoomBlocker.CmdMessage") : this._map._getUIString("ScrollZoomBlocker.CtrlMessage"), this._alertContainer.style.fontSize = `${Math.max(10, Math.min(24, Math.floor(0.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 = window.setTimeout(() => { this._alertContainer.classList.remove("mapboxgl-scroll-zoom-blocker-show"), this._alertContainer.removeAttribute("role"); }, 200); } } class wa { constructor(t, s) { this._clickZoom = t, this._tapZoom = s; } 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 Do { constructor() { this.reset(); } reset() { this._active = !1; } blur() { this.reset(); } dblclick(t, s) { return t.preventDefault(), { cameraAnimation: (h) => { h.easeTo({ duration: 300, zoom: h.getZoom() + (t.shiftKey ? -1 : 1), around: h.unproject(s) }, { originalEvent: t }); } }; } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled; } isActive() { return this._active; } } class Ja { constructor() { this._tap = new bu({ numTouches: 1, numTaps: 1 }), this.reset(); } reset() { this._active = !1, this._swipePoint = void 0, this._swipeTouch = 0, this._tapTime = 0, this._tap.reset(); } touchstart(t, s, h) { this._swipePoint || (this._tapTime && t.timeStamp - this._tapTime > 500 && this.reset(), this._tapTime ? h.length > 0 && (this._swipePoint = s[0], this._swipeTouch = h[0].identifier) : this._tap.touchstart(t, s, h)); } touchmove(t, s, h) { if (this._tapTime) { if (this._swipePoint) { if (h[0].identifier !== this._swipeTouch) return; const _ = s[0], y = _.y - this._swipePoint.y; return this._swipePoint = _, t.preventDefault(), this._active = !0, { zoomDelta: y / 128 }; } } else this._tap.touchmove(t, s, h); } touchend(t, s, h) { this._tapTime ? this._swipePoint && h.length === 0 && this.reset() : this._tap.touchend(t, s, h) && (this._tapTime = t.timeStamp); } touchcancel() { this.reset(); } enable() { this._enabled = !0; } disable() { this._enabled = !1, this.reset(); } isEnabled() { return this._enabled; } isActive() { return this._active; } } class Cl { constructor(t, s, h) { this._el = t, this._mousePan = s, this._touchPan = h; } enable(t) { this._inertiaOptions = t || {}, 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 Qa { constructor(t, s, h) { this._pitchWithRotate = t.pitchWithRotate, this._mouseRotate = s, this._mousePitch = h; } 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 h_ { constructor(t, s, h, _) { this._el = t, this._touchZoom = s, this._touchRotate = h, this._tapDragZoom = _, this._rotationDisabled = !1, this._enabled = !0; } enable(t) { this._touchZoom.enable(t), this._rotationDisabled || this._touchRotate.enable(t), 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 Mu = (c) => c.zoom || c.drag || c.pitch || c.rotate; class u_ extends i.z { } class d_ { constructor() { this.constants = [1, 1, 0.01], this.radius = 0; } setup(t, s) { const h = i.ab.vec3.sub([], s, t); this.radius = i.ab.vec3.length(h[2] < 0 ? i.ab.vec3.div([], h, this.constants) : [h[0], h[1], 0]); } projectRay(t) { i.ab.vec3.div(t, t, this.constants), i.ab.vec3.normalize(t, t), i.ab.vec3.mul(t, t, this.constants); const s = i.ab.vec3.scale([], t, this.radius); if (s[2] > 0) { const h = i.ab.vec3.scale([], [0, 0, 1], i.ab.vec3.dot(s, [0, 0, 1])), _ = i.ab.vec3.scale([], i.ab.vec3.normalize([], [s[0], s[1], 0]), this.radius), y = i.ab.vec3.add([], s, i.ab.vec3.scale([], i.ab.vec3.sub([], i.ab.vec3.add([], _, h), s), 2)); s[0] = y[0], s[1] = y[1]; } return s; } } function _h(c) { return c.panDelta && c.panDelta.mag() || c.zoomDelta || c.bearingDelta || c.pitchDelta; } class dr { constructor(t, s) { this._map = t, this._el = this._map.getCanvasContainer(), this._handlers = [], this._handlersById = {}, this._changes = [], this._inertia = new up(t), this._bearingSnap = s.bearingSnap, this._previousActiveHandlers = {}, this._trackingEllipsoid = new d_(), this._dragOrigin = null, this._eventsInProgress = {}, this._addDefaultHandlers(s), i.aP(["handleEvent", "handleWindowEvent"], this); const h = this._el; this._listeners = [[h, "touchstart", { passive: !0 }], [h, "touchmove", { passive: !1 }], [h, "touchend", void 0], [h, "touchcancel", void 0], [h, "mousedown", void 0], [h, "mousemove", void 0], [h, "mouseup", void 0], [document, "mousemove", { capture: !0 }], [document, "mouseup", void 0], [h, "mouseover", void 0], [h, "mouseout", void 0], [h, "dblclick", void 0], [h, "click", void 0], [h, "keydown", { capture: !1 }], [h, "keyup", void 0], [h, "wheel", { passive: !1 }], [h, "contextmenu", void 0], [window, "blur", void 0]]; for (const [_, y, T] of this._listeners) { const z = _ === document ? this.handleWindowEvent : this.handleEvent; _.addEventListener(y, z, T); } } destroy() { for (const [t, s, h] of this._listeners) { const _ = t === document ? this.handleWindowEvent : this.handleEvent; t.removeEventListener(s, _, h); } } _addDefaultHandlers(t) { const s = this._map, h = s.getCanvasContainer(); this._add("mapEvent", new fp(s, t)); const _ = s.boxZoom = new r_(s, t); this._add("boxZoom", _); const y = new o_(), T = new Do(); s.doubleClickZoom = new wa(T, y), this._add("tapZoom", y), this._add("clickZoom", T); const z = new Ja(); this._add("tapDragZoom", z); const R = s.touchPitch = new mh(s); this._add("touchPitch", R); const F = new wu(t), N = new fh(t); s.dragRotate = new Qa(t, F, N), this._add("mouseRotate", F, ["mousePitch"]), this._add("mousePitch", N, ["mouseRotate"]); const G = new mp(t), Z = new ba(s, t); s.dragPan = new Cl(h, G, Z), this._add("mousePan", G), this._add("touchPan", Z, ["touchZoom", "touchRotate"]); const W = new _p(), te = new kd(); s.touchZoomRotate = new h_(h, te, W, z), this._add("touchRotate", W, ["touchPan", "touchZoom"]), this._add("touchZoom", te, ["touchPan", "touchRotate"]), this._add("blockableMapEvent", new pp(s)); const ee = s.scrollZoom = new pc(s, this); this._add("scrollZoom", ee, ["mousePan"]); const se = s.keyboard = new c_(); this._add("keyboard", se); for (const oe of ["boxZoom", "doubleClickZoom", "tapDragZoom", "touchPitch", "dragRotate", "dragPan", "touchZoomRotate", "scrollZoom", "keyboard"]) t.interactive && t[oe] && s[oe].enable(t[oe]); } _add(t, s, h) { this._handlers.push({ handlerName: t, handler: s, allowed: h }), this._handlersById[t] = s; } stop(t) { if (!this._updatingCamera) { for (const { handler: s } of this._handlers) s.reset(); this._inertia.clear(), this._fireEvents({}, {}, t), this._changes = [], this._originalZoom = void 0; } } isActive() { for (const { handler: t } of this._handlers) if (t.isActive()) return !0; return !1; } isZooming() { return !!this._eventsInProgress.zoom || this._map.scrollZoom.isZooming(); } isRotating() { return !!this._eventsInProgress.rotate; } isMoving() { return !!Mu(this._eventsInProgress) || this.isZooming(); } _isDragging() { return !!this._eventsInProgress.drag; } _blockedByActive(t, s, h) { for (const _ in t) if (_ !== h && (!s || s.indexOf(_) < 0)) return !0; return !1; } handleWindowEvent(t) { this.handleEvent(t, `${t.type}Window`); } _getMapTouches(t) { const s = []; for (const h of t) this._el.contains(h.target) && s.push(h); return s; } handleEvent(t, s) { this._updatingCamera = !0; const h = t.type === "renderFrame", _ = h ? void 0 : t, y = { needsRenderFrame: !1 }, T = {}, z = {}, R = t.touches ? this._getMapTouches(t.touches) : void 0, F = R ? ui(this._el, R) : h ? void 0 : Gt(this._el, t); for (const { handlerName: Z, handler: W, allowed: te } of this._handlers) { if (!W.isEnabled()) continue; let ee; this._blockedByActive(z, te, Z) ? W.reset() : W[s || t.type] && (ee = W[s || t.type](t, F, R), this.mergeHandlerResult(y, T, ee, Z, _), ee && ee.needsRenderFrame && this._triggerRenderFrame()), (ee || W.isActive()) && (z[Z] = W); } const N = {}; for (const Z in this._previousActiveHandlers) z[Z] || (N[Z] = _); this._previousActiveHandlers = z, (Object.keys(N).length || _h(y)) && (this._changes.push([y, T, N]), this._triggerRenderFrame()), (Object.keys(z).length || _h(y)) && this._map._stop(!0), this._updatingCamera = !1; const { cameraAnimation: G } = y; G && (this._inertia.clear(), this._fireEvents({}, {}, !0), this._changes = [], G(this._map)); } mergeHandlerResult(t, s, h, _, y) { if (!h) return; i.l(t, h); const T = { handlerName: _, originalEvent: h.originalEvent || y }; h.zoomDelta !== void 0 && (s.zoom = T), h.panDelta !== void 0 && (s.drag = T), h.pitchDelta !== void 0 && (s.pitch = T), h.bearingDelta !== void 0 && (s.rotate = T); } _applyChanges() { const t = {}, s = {}, h = {}; for (const [_, y, T] of this._changes) _.panDelta && (t.panDelta = (t.panDelta || new i.P(0, 0))._add(_.panDelta)), _.zoomDelta && (t.zoomDelta = (t.zoomDelta || 0) + _.zoomDelta), _.bearingDelta && (t.bearingDelta = (t.bearingDelta || 0) + _.bearingDelta), _.pitchDelta && (t.pitchDelta = (t.pitchDelta || 0) + _.pitchDelta), _.around !== void 0 && (t.around = _.around), _.aroundCoord !== void 0 && (t.aroundCoord = _.aroundCoord), _.pinchAround !== void 0 && (t.pinchAround = _.pinchAround), _.noInertia && (t.noInertia = _.noInertia), i.l(s, y), i.l(h, T); this._updateMapTransform(t, s, h), this._changes = []; } _updateMapTransform(t, s, h) { const _ = this._map, y = _.transform, T = (he) => [he.x, he.y, he.z]; if (((he) => { const _e = this._eventsInProgress.drag; return _e && !this._handlersById[_e.handlerName].isActive(); })() && !_h(t)) { const he = y.zoom; y.cameraElevationReference = "sea", this._originalZoom != null && y._orthographicProjectionAtLowPitch && y.projection.name !== "globe" && y.pitch === 0 ? (y.cameraElevationReference = "ground", y.zoom = this._originalZoom) : (y.recenterOnTerrain(), y.cameraElevationReference = "ground"), he !== y.zoom && this._map._update(!0); } if (y._isCameraConstrained && _._stop(!0), !_h(t)) return void this._fireEvents(s, h, !0); let { panDelta: z, zoomDelta: R, bearingDelta: F, pitchDelta: N, around: G, aroundCoord: Z, pinchAround: W } = t; y._isCameraConstrained && (R > 0 && (R = 0), y._isCameraConstrained = !1), W !== void 0 && (G = W), (R || ((he) => s[he] && !this._eventsInProgress[he])("drag")) && G && (this._dragOrigin = T(y.pointCoordinate3D(G)), this._originalZoom = y.zoom, this._trackingEllipsoid.setup(y._camera.position, this._dragOrigin)), y.cameraElevationReference = "sea", _._stop(!0), G = G || _.transform.centerPoint, F && (y.bearing += F), N && (y.pitch += N), y._updateCameraState(); const te = [0, 0, 0]; if (z) if (y.projection.name === "mercator") { const he = this._trackingEllipsoid.projectRay(y.screenPointToMercatorRay(G).dir), _e = this._trackingEllipsoid.projectRay(y.screenPointToMercatorRay(G.sub(z)).dir); te[0] = _e[0] - he[0], te[1] = _e[1] - he[1]; } else { const he = y.pointCoordinate(G); if (y.projection.name === "globe") { z = z.rotate(-y.angle); const _e = y._pixelsPerMercatorPixel / y.worldSize; te[0] = -z.x * i.dB(i.aS(he.y)) * _e, te[1] = -z.y * i.dB(y.center.lat) * _e; } else { const _e = y.pointCoordinate(G.sub(z)); he && _e && (te[0] = _e.x - he.x, te[1] = _e.y - he.y); } } const ee = y.zoom, se = [0, 0, 0]; if (R) { const he = T(Z || y.pointCoordinate3D(G)), _e = { dir: i.ab.vec3.normalize([], i.ab.vec3.sub([], he, y._camera.position)) }; if (_e.dir[2] < 0) { const pe = y.zoomDeltaToMovement(he, R); i.ab.vec3.scale(se, _e.dir, pe); } } const oe = i.ab.vec3.add(te, te, se); y._translateCameraConstrained(oe), R && Math.abs(y.zoom - ee) > 1e-4 && y.recenterOnTerrain(), y.cameraElevationReference = "ground", this._map._update(), t.noInertia || this._inertia.record(t), this._fireEvents(s, h, !0); } _fireEvents(t, s, h) { const _ = Mu(this._eventsInProgress), y = Mu(t), T = {}; for (const N in t) { const { originalEvent: G } = t[N]; this._eventsInProgress[N] || (T[`${N}start`] = G), this._eventsInProgress[N] = t[N]; } !_ && y && this._fireEvent("movestart", y.originalEvent); for (const N in T) this._fireEvent(N, T[N]); y && this._fireEvent("move", y.originalEvent); for (const N in t) { const { originalEvent: G } = t[N]; this._fireEvent(N, G); } const z = {}; let R; for (const N in this._eventsInProgress) { const { handlerName: G, originalEvent: Z } = this._eventsInProgress[N]; this._handlersById[G].isActive() || (delete this._eventsInProgress[N], R = s[G] || Z, z[`${N}end`] = R); } for (const N in z) this._fireEvent(N, z[N]); const F = Mu(this._eventsInProgress); if (h && (_ || y) && !F) { this._updatingCamera = !0; const N = this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions), G = (Z) => Z !== 0 && -this._bearingSnap < Z && Z < this._bearingSnap; N ? (G(N.bearing || this._map.getBearing()) && (N.bearing = 0), this._map.easeTo(N, { originalEvent: R })) : (this._map.fire(new i.z("moveend", { originalEvent: R })), G(this._map.getBearing()) && this._map.resetNorth()), this._updatingCamera = !1; } } _fireEvent(t, s) { this._map.fire(new i.z(t, s ? { originalEvent: s } : {})); } _requestFrame() { return this._map.triggerRepaint(), this._map._renderTaskQueue.add((t) => { this._frameId = void 0, this.handleEvent(new u_("renderFrame", { timeStamp: t })), this._applyChanges(); }); } _triggerRenderFrame() { this._frameId === void 0 && (this._frameId = this._requestFrame()); } } const Su = "map.setFreeCameraOptions(...) and map.getFreeCameraOptions() are not yet supported for non-mercator projections."; class gp extends i.E { constructor(t, s) { super(), this._moving = !1, this._zooming = !1, this.transform = t, this._bearingSnap = s.bearingSnap, this._respectPrefersReducedMotion = s.respectPrefersReducedMotion !== !1, i.aP(["_renderFrameCallback"], this); } getCenter() { return new i.bO(this.transform.center.lng, this.transform.center.lat); } setCenter(t, s) { return this.jumpTo({ center: t }, s); } panBy(t, s, h) { return t = i.P.convert(t).mult(-1), this.panTo(this.transform.center, i.l({ offset: t }, s), h); } panTo(t, s, h) { return this.easeTo(i.l({ center: t }, s), h); } getZoom() { return this.transform.zoom; } setZoom(t, s) { return this.jumpTo({ zoom: t }, s), this; } zoomTo(t, s, h) { return this.easeTo(i.l({ zoom: t }, s), h); } zoomIn(t, s) { return this.zoomTo(this.getZoom() + 1, t, s), this; } zoomOut(t, s) { return this.zoomTo(this.getZoom() - 1, t, s), this; } getBearing() { return this.transform.bearing; } setBearing(t, s) { return this.jumpTo({ bearing: t }, s), this; } getPadding() { return this.transform.padding; } setPadding(t, s) { return this.jumpTo({ padding: t }, s), this; } rotateTo(t, s, h) { return this.easeTo(i.l({ bearing: t }, s), h); } resetNorth(t, s) { return this.rotateTo(0, i.l({ duration: 1e3 }, t), s), this; } resetNorthPitch(t, s) { return this.easeTo(i.l({ bearing: 0, pitch: 0, duration: 1e3 }, t), s), this; } snapToNorth(t, s) { return Math.abs(this.getBearing()) < this._bearingSnap ? this.resetNorth(t, s) : this; } getPitch() { return this.transform.pitch; } setPitch(t, s) { return this.jumpTo({ pitch: t }, s), this; } cameraForBounds(t, s) { t = i.az.convert(t); const h = s && s.bearing || 0, _ = s && s.pitch || 0, y = t.getNorthWest(), T = t.getSouthEast(); return this._cameraForBounds(this.transform, y, T, h, _, s); } _extendPadding(t) { const s = { top: 0, right: 0, bottom: 0, left: 0 }; return t == null ? i.l({}, s, this.transform.padding) : typeof t == "number" ? { top: t, bottom: t, right: t, left: t } : i.l({}, s, t); } _extendCameraOptions(t) { return (t = i.l({ offset: [0, 0], maxZoom: this.transform.maxZoom }, t)).padding = this._extendPadding(t.padding), t; } _minimumAABBFrustumDistance(t, s) { const h = s.max[0] - s.min[0], _ = s.max[1] - s.min[1]; return h / _ > t.aspect ? h / (2 * Math.tan(0.5 * t.fovX) * t.aspect) : _ / (2 * Math.tan(0.5 * t.fovY) * t.aspect); } _cameraForBoundsOnGlobe(t, s, h, _, y, T) { const z = t.clone(), R = this._extendCameraOptions(T); z.bearing = _, z.pitch = y; const F = i.bO.convert(s), N = i.bO.convert(h), G = 0.5 * (F.lat + N.lat), Z = 0.5 * (F.lng + N.lng), W = i.dC(G, Z), te = i.ab.vec3.normalize([], W), ee = i.ab.vec3.normalize([], i.ab.vec3.cross([], te, [0, 1, 0])), se = i.ab.vec3.cross([], ee, te), oe = [ee[0], ee[1], ee[2], 0, se[0], se[1], se[2], 0, te[0], te[1], te[2], 0, 0, 0, 0, 1], he = [W, i.dC(F.lat, F.lng), i.dC(N.lat, F.lng), i.dC(N.lat, N.lng), i.dC(F.lat, N.lng), i.dC(G, F.lng), i.dC(G, N.lng), i.dC(F.lat, Z), i.dC(N.lat, Z)]; let _e = i.cd.fromPoints(he.map((Je) => [i.ab.vec3.dot(ee, Je), i.ab.vec3.dot(se, Je), i.ab.vec3.dot(te, Je)])); const pe = i.ab.vec3.transformMat4([], _e.center, oe); i.ab.vec3.squaredLength(pe) === 0 && i.ab.vec3.set(pe, 0, 0, 1), i.ab.vec3.normalize(pe, pe), i.ab.vec3.scale(pe, pe, i.ax), z.center = i.dD(pe); const Me = z.getWorldToCameraMatrix(), xe = i.ab.mat4.invert(new Float64Array(16), Me); _e = i.cd.applyTransform(_e, i.ab.mat4.multiply([], Me, oe)); const we = this._extendAABB(_e, z, R, _); if (!we) return void i.w("Map cannot fit within canvas with the given bounds, padding, and/or offset."); _e = we, i.ab.vec3.transformMat4(pe, pe, Me); const ve = 0.5 * (_e.max[2] - _e.min[2]), Ae = this._minimumAABBFrustumDistance(z, _e), Oe = i.ab.vec3.scale([], [0, 0, 1], ve), Xe = i.ab.vec3.add(Oe, pe, Oe), He = Ae + (z.pitch === 0 ? 0 : i.ab.vec3.distance(pe, Xe)), ke = z.globeCenterInViewSpace, Ne = i.ab.vec3.sub([], pe, [ke[0], ke[1], ke[2]]); i.ab.vec3.normalize(Ne, Ne), i.ab.vec3.scale(Ne, Ne, He); const st = i.ab.vec3.add([], pe, Ne); i.ab.vec3.transformMat4(st, st, xe); const ut = i.ds / i.ax, xt = i.ab.vec3.length(st), Ge = i.bH(Math.max(xt * ut - i.ds, Number.EPSILON), 0), lt = Math.min(z.zoomFromMercatorZAdjusted(Ge), R.maxZoom); return lt > 0.5 * (i.c6 + i.bY) ? (z.setProjection({ name: "mercator" }), z.zoom = lt, this._cameraForBounds(z, s, h, _, y, T)) : { center: z.center, zoom: lt, bearing: _, pitch: y }; } _extendAABB(t, s, h, _) { const y = 0.5 * ((h.padding.left || 0) + (h.padding.right || 0)), T = 0.5 * ((h.padding.top || 0) + (h.padding.bottom || 0)), z = T, R = y, F = y, N = T, G = s.width - (R + F), Z = s.height - (z + N), W = i.ab.vec3.sub([], t.max, t.min), te = Math.min(G / W[0], Z / W[1]), ee = Math.min(s.scaleZoom(s.scale * te), h.maxZoom); if (isNaN(ee)) return null; const se = s.scale / s.zoomScale(ee), oe = new i.cd([t.min[0] - R * se, t.min[1] - N * se, t.min[2]], [t.max[0] + F * se, t.max[1] + z * se, t.max[2]]), he = (typeof h.offset.x == "number" && typeof h.offset.y == "number" ? new i.P(h.offset.x, h.offset.y) : i.P.convert(h.offset)).rotate(-i.ai(_)); return oe.center[0] -= he.x * se, oe.center[1] += he.y * se, oe; } queryTerrainElevation(t, s) { const h = this.transform.elevation; return h ? (s = i.l({}, { exaggerated: !0 }, s), h.getAtPoint(i.aa.fromLngLat(t), null, s.exaggerated)) : null; } _cameraForBounds(t, s, h, _, y, T) { if (t.projection.name === "globe") return this._cameraForBoundsOnGlobe(t, s, h, _, y, T); const z = t.clone(), R = this._extendCameraOptions(T); z.bearing = _, z.pitch = y; const F = i.bO.convert(s), N = i.bO.convert(h), G = new i.bO(F.lng, N.lat), Z = new i.bO(N.lng, F.lat), W = z.project(F), te = z.project(N), ee = this.queryTerrainElevation(F), se = this.queryTerrainElevation(N), oe = this.queryTerrainElevation(G), he = this.queryTerrainElevation(Z), _e = [[W.x, W.y, Math.min(ee || 0, se || 0, oe || 0, he || 0)], [te.x, te.y, Math.max(ee || 0, se || 0, oe || 0, he || 0)]]; let pe = i.cd.fromPoints(_e); const Me = z.getWorldToCameraMatrix(), xe = i.ab.mat4.invert(new Float64Array(16), Me); pe = i.cd.applyTransform(pe, Me); const we = this._extendAABB(pe, z, R, _); if (!we) return void i.w("Map cannot fit within canvas with the given bounds, padding, and/or offset."); pe = we; const ve = 0.5 * i.ab.vec3.sub([], pe.max, pe.min)[2], Ae = this._minimumAABBFrustumDistance(z, pe), Oe = [0, 0, 1, 0]; i.ab.vec4.transformMat4(Oe, Oe, Me), i.ab.vec4.normalize(Oe, Oe); const Xe = i.ab.vec3.scale([], Oe, Ae + ve), He = i.ab.vec3.add([], pe.center, Xe); i.ab.vec3.transformMat4(pe.center, pe.center, xe), i.ab.vec3.transformMat4(He, He, xe); const ke = z.unproject(new i.P(pe.center[0], pe.center[1])), Ne = i.dE(z.projection, ke), st = Math.pow(2, Ne), ut = Math.min(z._zoomFromMercatorZ(He[2] * z.pixelsPerMeter * st / z.worldSize), R.maxZoom); return z.mercatorFromTransition && ut < 0.5 * (i.c6 + i.bY) ? (z.setProjection({ name: "globe" }), z.zoom = ut, this._cameraForBounds(z, s, h, _, y, T)) : { center: ke, zoom: ut, bearing: _, pitch: y }; } fitBounds(t, s, h) { const _ = this.cameraForBounds(t, s); return this._fitInternal(_, s, h); } fitScreenCoordinates(t, s, h, _, y) { const T = i.P.convert(t), z = i.P.convert(s), R = new i.P(Math.min(T.x, z.x), Math.min(T.y, z.y)), F = new i.P(Math.max(T.x, z.x), Math.max(T.y, z.y)); if (this.transform.projection.name === "mercator" && this.transform.anyCornerOffEdge(T, z)) return this; const N = this.transform.pointLocation3D(R), G = this.transform.pointLocation3D(F), Z = this.transform.pointLocation3D(new i.P(R.x, F.y)), W = this.transform.pointLocation3D(new i.P(F.x, R.y)), te = [Math.min(N.lng, G.lng, Z.lng, W.lng), Math.min(N.lat, G.lat, Z.lat, W.lat)], ee = [Math.max(N.lng, G.lng, Z.lng, W.lng), Math.max(N.lat, G.lat, Z.lat, W.lat)], se = _ && _.pitch ? _.pitch : this.getPitch(), oe = this._cameraForBounds(this.transform, te, ee, h, se, _); return this._fitInternal(oe, _, y); } _fitInternal(t, s, h) { return t ? (s = i.l(t, s)).linear ? this.easeTo(s, h) : this.flyTo(s, h) : this; } jumpTo(t, s) { this.stop(); const h = t.preloadOnly ? this.transform.clone() : this.transform; let _ = !1, y = !1, T = !1; "zoom" in t && h.zoom !== +t.zoom && (_ = !0, h.zoom = +t.zoom), t.center !== void 0 && (h.center = i.bO.convert(t.center)), "bearing" in t && h.bearing !== +t.bearing && (y = !0, h.bearing = +t.bearing), "pitch" in t && h.pitch !== +t.pitch && (T = !0, h.pitch = +t.pitch); const z = typeof t.padding == "number" ? this._extendPadding(t.padding) : t.padding; if (t.padding != null && !h.isPaddingEqual(z)) if (t.retainPadding === !1) { const R = h.clone(); R.padding = z, h.setLocationAtPoint(h.center, R.centerPoint); } else h.padding = z; return t.preloadOnly ? (this._preloadTiles(h), this) : (this.fire(new i.z("movestart", s)).fire(new i.z("move", s)), _ && this.fire(new i.z("zoomstart", s)).fire(new i.z("zoom", s)).fire(new i.z("zoomend", s)), y && this.fire(new i.z("rotatestart", s)).fire(new i.z("rotate", s)).fire(new i.z("rotateend", s)), T && this.fire(new i.z("pitchstart", s)).fire(new i.z("pitch", s)).fire(new i.z("pitchend", s)), this.fire(new i.z("moveend", s))); } getFreeCameraOptions() { return this.transform.projection.supportsFreeCamera || i.w(Su), this.transform.getFreeCameraOptions(); } setFreeCameraOptions(t, s) { const h = this.transform; if (!h.projection.supportsFreeCamera) return i.w(Su), this; this.stop(); const _ = h.zoom, y = h.pitch, T = h.bearing; h.setFreeCameraOptions(t); const z = _ !== h.zoom, R = y !== h.pitch, F = T !== h.bearing; return this.fire(new i.z("movestart", s)).fire(new i.z("move", s)), z && this.fire(new i.z("zoomstart", s)).fire(new i.z("zoom", s)).fire(new i.z("zoomend", s)), F && this.fire(new i.z("rotatestart", s)).fire(new i.z("rotate", s)).fire(new i.z("rotateend", s)), R && this.fire(new i.z("pitchstart", s)).fire(new i.z("pitch", s)).fire(new i.z("pitchend", s)), this.fire(new i.z("moveend", s)), this; } easeTo(t, s) { this._stop(!1, t.easeId), ((t = i.l({ offset: [0, 0], duration: 500, easing: i.dA }, t)).animate === !1 || this._prefersReducedMotion(t)) && (t.duration = 0); const h = this.transform, _ = this.getZoom(), y = this.getBearing(), T = this.getPitch(), z = this.getPadding(), R = "zoom" in t ? +t.zoom : _, F = "bearing" in t ? this._normalizeBearing(t.bearing, y) : y, N = "pitch" in t ? +t.pitch : T, G = this._extendPadding(t.padding), Z = i.P.convert(t.offset); let W, te, ee; if (h.projection.name === "globe") { const Oe = i.aa.fromLngLat(h.center), Xe = Z.rotate(-h.angle); Oe.x += Xe.x / h.worldSize, Oe.y += Xe.y / h.worldSize; const He = Oe.toLngLat(), ke = i.bO.convert(t.center || He); this._normalizeCenter(ke), W = h.centerPoint.add(Xe), te = new i.P(Oe.x, Oe.y).mult(h.worldSize), ee = new i.P(i.at(ke.lng), i.aA(ke.lat)).mult(h.worldSize).sub(te); } else { W = h.centerPoint.add(Z); const Oe = h.pointLocation(W), Xe = i.bO.convert(t.center || Oe); this._normalizeCenter(Xe), te = h.project(Oe), ee = h.project(Xe).sub(te); } const se = h.zoomScale(R - _); let oe, he; t.around && (oe = i.bO.convert(t.around), he = h.locationPoint(oe)); const _e = this._zooming || R !== _, pe = this._rotating || y !== F, Me = this._pitching || N !== T, xe = !h.isPaddingEqual(G), we = t.retainPadding === !1 ? h.clone() : h, ve = (Oe) => (Xe) => { if (_e && (Oe.zoom = i.af(_, R, Xe)), pe && (Oe.bearing = i.af(y, F, Xe)), Me && (Oe.pitch = i.af(T, N, Xe)), xe && (we.interpolatePadding(z, G, Xe), W = we.centerPoint.add(Z)), oe) Oe.setLocationAtPoint(oe, he); else { const He = Oe.zoomScale(Oe.zoom - _), ke = R > _ ? Math.min(2, se) : Math.max(0.5, se), Ne = Math.pow(ke, 1 - Xe), st = Oe.unproject(te.add(ee.mult(Xe * Ne)).mult(He)); Oe.setLocationAtPoint(Oe.renderWorldCopies ? st.wrap() : st, W); } return t.preloadOnly || this._fireMoveEvents(s), Oe; }; if (t.preloadOnly) { const Oe = this._emulate(ve, t.duration, h); return this._preloadTiles(Oe), this; } const Ae = { moving: this._moving, zooming: this._zooming, rotating: this._rotating, pitching: this._pitching }; return this._zooming = _e, this._rotating = pe, this._pitching = Me, this._padding = xe, this._easeId = t.easeId, this._prepareEase(s, t.noMoveStart, Ae), this._ease(ve(h), (Oe) => { h.cameraElevationReference === "sea" && h.recenterOnTerrain(), this._afterEase(s, Oe); }, t), this; } _prepareEase(t, s, h = {}) { this._moving = !0, this.transform.cameraElevationReference = "sea", this.transform._orthographicProjectionAtLowPitch && this.transform.pitch === 0 && this.transform.projection.name !== "globe" && (this.transform.cameraElevationReference = "ground"), s || h.moving || this.fire(new i.z("movestart", t)), this._zooming && !h.zooming && this.fire(new i.z("zoomstart", t)), this._rotating && !h.rotating && this.fire(new i.z("rotatestart", t)), this._pitching && !h.pitching && this.fire(new i.z("pitchstart", t)); } _fireMoveEvents(t) { this.fire(new i.z("move", t)), this._zooming && this.fire(new i.z("zoom", t)), this._rotating && this.fire(new i.z("rotate", t)), this._pitching && this.fire(new i.z("pitch", t)); } _afterEase(t, s) { if (this._easeId && s && this._easeId === s) return; this._easeId = void 0, this.transform.cameraElevationReference = "ground"; const h = this._zooming, _ = this._rotating, y = this._pitching; this._moving = !1, this._zooming = !1, this._rotating = !1, this._pitching = !1, this._padding = !1, h && this.fire(new i.z("zoomend", t)), _ && this.fire(new i.z("rotateend", t)), y && this.fire(new i.z("pitchend", t)), this.fire(new i.z("moveend", t)); } flyTo(t, s) { if (this._prefersReducedMotion(t)) { const Je = i.ay(t, ["center", "zoom", "bearing", "pitch", "around", "padding", "retainPadding"]); return this.jumpTo(Je, s); } this.stop(), t = i.l({ offset: [0, 0], speed: 1.2, curve: 1.42, easing: i.dA }, t); const h = this.transform, _ = this.getZoom(), y = this.getBearing(), T = this.getPitch(), z = this.getPadding(), R = "zoom" in t ? i.aw(+t.zoom, h.minZoom, h.maxZoom) : _, F = "bearing" in t ? this._normalizeBearing(t.bearing, y) : y, N = "pitch" in t ? +t.pitch : T, G = this._extendPadding(t.padding), Z = h.zoomScale(R - _), W = i.P.convert(t.offset); let te = h.centerPoint.add(W); const ee = h.pointLocation(te), se = i.bO.convert(t.center || ee); this._normalizeCenter(se); const oe = h.project(ee), he = h.project(se).sub(oe); let _e = t.curve; const pe = Math.max(h.width, h.height), Me = pe / Z, xe = he.mag(); if ("minZoom" in t) { const Je = i.aw(Math.min(t.minZoom, _, R), h.minZoom, h.maxZoom), _t = pe / h.zoomScale(Je - _); _e = Math.sqrt(_t / xe * 2); } const we = _e * _e; function ve(Je) { const _t = (Me * Me - pe * pe + (Je ? -1 : 1) * we * we * xe * xe) / (2 * (Je ? Me : pe) * we * xe); return Math.log(Math.sqrt(_t * _t + 1) - _t); } function Ae(Je) { return (Math.exp(Je) - Math.exp(-Je)) / 2; } function Oe(Je) { return (Math.exp(Je) + Math.exp(-Je)) / 2; } const Xe = ve(0); let He = function(Je) { return Oe(Xe) / Oe(Xe + _e * Je); }, ke = function(Je) { return pe * ((Oe(Xe) * (Ae(_t = Xe + _e * Je) / Oe(_t)) - Ae(Xe)) / we) / xe; var _t; }, Ne = (ve(1) - Xe) / _e; if (Math.abs(xe) < 1e-6 || !isFinite(Ne)) { if (Math.abs(pe - Me) < 1e-6) return this.easeTo(t, s); const Je = Me < pe ? -1 : 1; Ne = Math.abs(Math.log(Me / pe)) / _e, ke = function() { return 0; }, He = function(_t) { return Math.exp(Je * _e * _t); }; } t.duration = "duration" in t ? +t.duration : 1e3 * Ne / ("screenSpeed" in t ? +t.screenSpeed / _e : +t.speed), t.maxDuration && t.duration > t.maxDuration && (t.duration = 0); const st = y !== F, ut = N !== T, xt = !h.isPaddingEqual(G), Ge = t.retainPadding === !1 ? h.clone() : h, lt = (Je) => (_t) => { const ct = _t * Ne, nt = 1 / He(ct); Je.zoom = _t === 1 ? R : _ + Je.scaleZoom(nt), st && (Je.bearing = i.af(y, F, _t)), ut && (Je.pitch = i.af(T, N, _t)), xt && (Ge.interpolatePadding(z, G, _t), te = Ge.centerPoint.add(W)); const Lt = _t === 1 ? se : Je.unproject(oe.add(he.mult(ke(ct))).mult(nt)); return Je.setLocationAtPoint(Je.renderWorldCopies ? Lt.wrap() : Lt, te), Je._updateCameraOnTerrain(), t.preloadOnly || this._fireMoveEvents(s), Je; }; if (t.preloadOnly) { const Je = this._emulate(lt, t.duration, h); return this._preloadTiles(Je), this; } return this._zooming = !0, this._rotating = st, this._pitching = ut, this._padding = xt, this._prepareEase(s, !1), this._ease(lt(h), () => this._afterEase(s), t), this; } isEasing() { return !!this._easeFrameId; } stop() { return this._stop(); } _requestRenderFrame(t) { } _cancelRenderFrame(t) { } _stop(t, s) { if (this._easeFrameId && (this._cancelRenderFrame(this._easeFrameId), this._easeFrameId = void 0, this._onEaseFrame = void 0), this._onEaseEnd) { const h = this._onEaseEnd; this._onEaseEnd = void 0, h.call(this, s); } if (!t) { const h = this.handlers; h && h.stop(!1); } return this; } _ease(t, s, h) { h.animate === !1 || h.duration === 0 ? (t(1), s()) : (this._easeStart = i.q.now(), this._easeOptions = h, this._onEaseFrame = t, this._onEaseEnd = s, this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback)); } _renderFrameCallback() { const t = Math.min((i.q.now() - this._easeStart) / this._easeOptions.duration, 1), s = this._onEaseFrame; s && s(this._easeOptions.easing(t)), t < 1 ? this._easeFrameId = this._requestRenderFrame(this._renderFrameCallback) : this.stop(); } _normalizeBearing(t, s) { t = i.bF(t, -180, 180); const h = Math.abs(t - s); return Math.abs(t - 360 - s) < h && (t -= 360), Math.abs(t + 360 - s) < h && (t += 360), t; } _normalizeCenter(t) { const s = this.transform; if (s.maxBounds || s.projection.name !== "globe" && !s.renderWorldCopies) return; const h = t.lng - s.center.lng; t.lng += h > 180 ? -360 : h < -180 ? 360 : 0; } _prefersReducedMotion(t) { return this._respectPrefersReducedMotion && i.q.prefersReducedMotion && !(t && t.essential); } _emulate(t, s, h) { const _ = Math.ceil(15 * s / 1e3), y = [], T = t(h.clone()); for (let z = 0; z <= _; z++) { const R = T(z / _); y.push(R.clone()); } return y; } _preloadTiles(t, s) { } } class yp { constructor(t = {}) { this.options = t, i.aP(["_toggleAttribution", "_updateEditLink", "_updateData", "_updateCompact"], this); } getDefaultPosition() { return "bottom-right"; } onAdd(t) { const s = this.options && this.options.compact, h = t._getUIString("AttributionControl.ToggleAttribution"); this._map = t, this._container = be("div", "mapboxgl-ctrl mapboxgl-ctrl-attrib"), this._compactButton = be("button", "mapboxgl-ctrl-attrib-button", this._container), this._compactButton.type = "button", this._compactButton.addEventListener("click", this._toggleAttribution), this._compactButton.setAttribute("aria-label", h); const _ = be("span", "mapboxgl-ctrl-icon", this._compactButton); return _.setAttribute("aria-hidden", "true"), _.setAttribute("title", h), this._innerContainer = be("div", "mapboxgl-ctrl-attrib-inner", this._container), s && 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), s === void 0 && (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; } _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 s = [{ key: "owner", value: this.styleOwner }, { key: "id", value: this.styleId }, { key: "access_token", value: this._map._requestManager._customAccessToken || i.e.ACCESS_TOKEN }]; if (t) { const h = s.reduce((_, y, T) => (y.value && (_ += `${y.key}=${y.value}${T < s.length - 1 ? "&" : ""}`), _), "?"); t.href = `${i.e.FEEDBACK_URL}/${h}#${vu(this._map, !0)}`, t.rel = "noopener nofollow"; } } _updateData(t) { !t || t.sourceDataType !== "metadata" && t.sourceDataType !== "visibility" && t.dataType !== "style" || (this._updateAttributions(), this._updateEditLink()); } _updateAttributions() { if (!this._map.style) return; let t = []; if (this._map.style.stylesheet) { const _ = this._map.style.stylesheet; this.styleOwner = _.owner, this.styleId = _.id; } const s = this._map.style._mergedSourceCaches; for (const _ in s) { const y = s[_]; if (y.used) { const T = y.getSource(); T.attribution && t.indexOf(T.attribution) < 0 && t.push(T.attribution); } } t.sort((_, y) => _.length - y.length), t = t.filter((_, y) => { for (let T = y + 1; T < t.length; T++) if (t[T].indexOf(_) >= 0) return !1; return !0; }), this.options.customAttribution && (Array.isArray(this.options.customAttribution) ? t = [...this.options.customAttribution, ...t] : t.unshift(this.options.customAttribution)); const h = t.join(" | "); h !== this._attribHTML && (this._attribHTML = h, t.length ? (this._innerContainer.innerHTML = h, 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 Il { constructor() { i.aP(["_updateLogo", "_updateCompact"], this); } onAdd(t) { this._map = t, this._container = be("div", "mapboxgl-ctrl"); const s = be("a", "mapboxgl-ctrl-logo"); return s.target = "_blank", s.rel = "noopener nofollow", s.href = "https://www.mapbox.com/", s.setAttribute("aria-label", this._map._getUIString("LogoControl.Title")), s.setAttribute("rel", "noopener nofollow"), this._container.appendChild(s), 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(t) { t && t.sourceDataType !== "metadata" || (this._container.style.display = this._logoRequired() ? "block" : "none"); } _logoRequired() { if (!this._map.style) return !0; const t = this._map.style._sourceCaches; if (Object.entries(t).length === 0) return !0; for (const s in t) { const h = t[s].getSource(); if (h.hasOwnProperty("mapbox_logo") && !h.mapbox_logo) return !1; } return !0; } _updateCompact() { const t = this._container.children; if (t.length) { const s = t[0]; this._map.getCanvasContainer().offsetWidth < 250 ? s.classList.add("mapboxgl-compact") : s.classList.remove("mapboxgl-compact"); } } } class Eu { constructor() { this._queue = [], this._id = 0, this._cleared = !1, this._currentlyRunning = !1; } add(t) { const s = ++this._id; return this._queue.push({ callback: t, id: s, cancelled: !1 }), s; } remove(t) { const s = this._currentlyRunning, h = s ? this._queue.concat(s) : this._queue; for (const _ of h) if (_.id === t) return void (_.cancelled = !0); } run(t = 0) { const s = this._currentlyRunning = this._queue; this._queue = []; for (const h of s) if (!h.cancelled && (h.callback(t), this._cleared)) break; this._cleared = !1, this._currentlyRunning = !1; } clear() { this._currentlyRunning && (this._cleared = !0), this._queue = []; } } class uo { constructor(t) { this.jumpTo(t); } getValue(t) { if (t <= this._startTime) return this._start; if (t >= this._endTime) return this._end; const s = i.cB((t - this._startTime) / (this._endTime - this._startTime)); return this._start * (1 - s) + this._end * s; } isEasing(t) { return t >= this._startTime && t <= this._endTime; } jumpTo(t) { this._startTime = -1 / 0, this._endTime = -1 / 0, this._start = t, this._end = t; } easeTo(t, s, h) { this._start = this.getValue(s), this._end = t, this._startTime = s, this._endTime = s + h; } } const fo = { "AttributionControl.ToggleAttribution": "Toggle attribution", "FullscreenControl.Enter": "Enter fullscreen", "FullscreenControl.Exit": "Exit fullscreen", "GeolocateControl.FindMyLocation": "Find my location", "GeolocateControl.LocationNotAvailable": "Location not available", "LogoControl.Title": "Mapbox homepage", "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" }, mc = ["mouseenter", "mouseover", "mouseleave", "mouseout"]; class el extends i.z { constructor(t, s, h, _) { const { point: y, lngLat: T, originalEvent: z, target: R } = t; super(t.type, { point: y, lngLat: T, originalEvent: z, target: R }), this.preventDefault = () => { t.preventDefault(); }, this.id = s, this.interaction = h, this.feature = _; } } class _c { constructor(t) { this.map = t, this.interactionsByType = /* @__PURE__ */ new Map(), this.typeById = /* @__PURE__ */ new Map(), this.filters = /* @__PURE__ */ new Map(), this.delegatedHandlers = /* @__PURE__ */ new Map(), this.handleType = this.handleType.bind(this); } add(t, s) { if (this.typeById.has(t)) throw new Error(`Interaction id "${t}" already exists.`); const { type: h, filter: _ } = s; _ && this.filters.set(t, i.aZ(_)); const y = this.interactionsByType.get(h) || /* @__PURE__ */ new Map(); if (y.size === 0) { if (mc.includes(h)) { const { mousemove: T, mouseout: z } = this._createDelegatedHandlers(t, s); this.map.on("mousemove", T), this.map.on("mouseout", z), this.delegatedHandlers.set(t, { mousemove: T, mouseout: z }); } else this.map.on(h, this.handleType); this.interactionsByType.set(h, y); } y.set(t, s), this.typeById.set(t, h); } get(t) { const s = this.typeById.get(t); if (!s) return; const h = this.interactionsByType.get(s); return h ? h.get(t) : void 0; } remove(t) { const s = this.typeById.get(t); if (!s) return; this.typeById.delete(t), this.filters.delete(t); const h = this.interactionsByType.get(s); if (h) { if (h.delete(t), this.delegatedHandlers.has(t)) { const { mousemove: _, mouseout: y } = this.delegatedHandlers.get(t); this.map.off("mousemove", _), this.map.off("mouseout", y), this.delegatedHandlers.delete(t); } h.size === 0 && this.map.off(s, this.handleType); } } queryTargets(t, s) { const h = []; for (const [_, y] of s) y.target && h.push({ targetId: _, target: y.target, filter: this.filters.get(_) }); return this.map.style.queryRenderedTargets(t, h, this.map.transform); } handleType(t, s) { const h = this.interactionsByType.get(t.type), _ = Array.from(h).reverse(); s = s || this.queryTargets(t.point, _); let y = !1; for (const T of s) { for (const [z, R] of _) { if (!R.target) continue; const F = T.variants ? T.variants[z] : null; if (F) { for (const N of F) { const G = new i.cw(T, N); if (R.handler(new el(t, z, R, G)) !== !1) { y = !0; break; } } if (y) break; } } if (y) break; } if (!y) for (const [T, z] of _) { const { handler: R, target: F } = z; if (!F && R(new el(t, T, z, null)) !== !1) break; } } _createDelegatedHandlers(t, s) { switch (s.type) { case "mouseenter": case "mouseover": { let h = !1, _ = /* @__PURE__ */ new Set(); return { mousemove: (y) => { const T = this.queryTargets(y.point, [[t, s]]), z = /* @__PURE__ */ new Set(); if (!T.length) return h = !1, void _.clear(); const R = []; for (const F of T) _.has(F.id) || (z.add(F.id), R.push(F)); h && !R.length || (h = !0, _ = z, y.type = s.type, this.handleType(y, R)); }, mouseout: () => { h = !1, _.clear(); } }; } case "mouseleave": case "mouseout": { let h = []; return { mousemove: (_) => { const y = this.queryTargets(_.point, [[t, s]]); if (!y.length) return _.type = s.type, this.handleType(_, h), void (h = y); const T = [], z = new Set(y.map((R) => R.id)); for (const R of h) z.has(R.id) || T.push(R); T.length && (_.type = s.type, this.handleType(_, T)), h = y; }, mouseout: (_) => { h.length && (_.type = s.type, this.handleType(_, h), h = []); } }; } } } } function Fd(c, t) { if (Array.isArray(c) && Array.isArray(t)) { const s = new Set(c), h = new Set(t); return s.size === h.size && c.every((_) => h.has(_)); } return i.bn(c, t); } const Ui = { 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, antialias: !1, failIfMajorPerformanceCaveat: !1, preserveDrawingBuffer: !1, trackResize: !0, renderWorldCopies: !0, refreshExpiredTiles: !0, minTileCacheSize: null, maxTileCacheSize: null, localIdeographFontFamily: "sans-serif", localFontFamily: null, transformRequest: null, accessToken: null, fadeDuration: 300, respectPrefersReducedMotion: !0, crossSourceCollisions: !0, collectResourceTiming: !1, testMode: !1, precompilePrograms: !0, scaleFactor: 1, spriteFormat: "auto" }, tl = { showCompass: !0, showZoom: !0, visualizePitch: !1 }; class f_ { constructor(t, s, h = !1) { this._clickTolerance = 10, this.element = s, this.mouseRotate = new wu({ clickTolerance: t.dragRotate._mouseRotate._clickTolerance }), this.map = t, h && (this.mousePitch = new fh({ clickTolerance: t.dragRotate._mousePitch._clickTolerance })), i.aP(["mousedown", "mousemove", "mouseup", "touchstart", "touchmove", "touchend", "reset"], this), s.addEventListener("mousedown", this.mousedown), s.addEventListener("touchstart", this.touchstart, { passive: !1 }), s.addEventListener("touchmove", this.touchmove), s.addEventListener("touchend", this.touchend), s.addEventListener("touchcancel", this.reset); } down(t, s) { this.mouseRotate.mousedown(t, s), this.mousePitch && this.mousePitch.mousedown(t, s), ht(); } move(t, s) { const h = this.map, _ = this.mouseRotate.mousemoveWindow(t, s), y = _ && _.bearingDelta; if (y && h.setBearing(h.getBearing() + y), this.mousePitch) { const T = this.mousePitch.mousemoveWindow(t, s), z = T && T.pitchDelta; z && h.setPitch(h.getPitch() + z); } } off() { const t = this.element; t.removeEventListener("mousedown", this.mousedown), t.removeEventListener("touchstart", this.touchstart, { passive: !1 }), t.removeEventListener("touchmove", this.touchmove), t.removeEventListener("touchend", this.touchend), t.removeEventListener("touchcancel", this.reset), this.offTemp(); } offTemp() { gt(), window.removeEventListener("mousemove", this.mousemove), window.removeEventListener("mouseup", this.mouseup); } mousedown(t) { this.down(i.l({}, t, { ctrlKey: !0, preventDefault: () => t.preventDefault() }), Gt(this.element, t)), window.addEventListener("mousemove", this.mousemove), window.addEventListener("mouseup", this.mouseup); } mousemove(t) { this.move(t, Gt(this.element, t)); } mouseup(t) { this.mouseRotate.mouseupWindow(t), this.mousePitch && this.mousePitch.mouseupWindow(t), this.offTemp(); } touchstart(t) { t.targetTouches.length !== 1 ? this.reset() : (this._startPos = this._lastPos = ui(this.element, t.targetTouches)[0], this.down({ type: "mousedown", button: 0, ctrlKey: !0, preventDefault: () => t.preventDefault() }, this._startPos)); } touchmove(t) { t.targetTouches.length !== 1 ? this.reset() : (this._lastPos = ui(this.element, t.targetTouches)[0], this.move({ preventDefault: () => t.preventDefault() }, this._lastPos)); } touchend(t) { t.targetTouches.length === 0 && 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(); } } function xp(c, t, s) { if (c = new i.bO(c.lng, c.lat), t) { const h = new i.bO(c.lng - 360, c.lat), _ = new i.bO(c.lng + 360, c.lat), y = 360 * Math.ceil(Math.abs(c.lng - s.center.lng) / 360), T = s.locationPoint(c).distSqr(t), z = t.x < 0 || t.y < 0 || t.x > s.width || t.y > s.height; s.locationPoint(h).distSqr(t) < T && (z || Math.abs(h.lng - s.center.lng) < y) ? c = h : s.locationPoint(_).distSqr(t) < T && (z || Math.abs(_.lng - s.center.lng) < y) && (c = _); } for (; Math.abs(c.lng - s.center.lng) > 180; ) { const h = s.locationPoint(c); if (h.x >= 0 && h.y >= 0 && h.x <= s.width && h.y <= s.height) break; c.lng > s.center.lng ? c.lng -= 360 : c.lng += 360; } return c; } const gh = { 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 ta extends i.E { constructor(t, s) { if (super(), (t instanceof HTMLElement || s) && (t = i.l({ element: t }, s)), i.aP(["_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 || 0.2, t && t.element) this._element = t.element, this._offset = i.P.convert(t && t.offset || [0, 0]); else { this._defaultMarker = !0, this._element = be("div"); const y = 41, T = 27, z = Ze("svg", { display: "block", height: y * this._scale + "px", width: T * this._scale + "px", viewBox: `0 0 ${T} ${y}` }, this._element), R = Ze("radialGradient", { id: "shadowGradient" }, Ze("defs", {}, z)); Ze("stop", { offset: "10%", "stop-opacity": 0.4 }, R), Ze("stop", { offset: "100%", "stop-opacity": 0.05 }, R), Ze("ellipse", { cx: 13.5, cy: 34.8, rx: 10.5, ry: 5.25, fill: "url(#shadowGradient)" }, z), Ze("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" }, z), Ze("path", { opacity: 0.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" }, z), Ze("circle", { fill: "white", cx: 13.5, cy: 13.5, r: 5.5 }, z), this._offset = i.P.convert(t && t.offset || [0, -14]); } this._element.hasAttribute("aria-label") || this._element.setAttribute("aria-label", "Map marker"), this._element.hasAttribute("role") || this._element.setAttribute("role", "img"), this._element.classList.add("mapboxgl-marker"), this._element.addEventListener("dragstart", (y) => { y.preventDefault(); }), this._element.addEventListener("mousedown", (y) => { y.preventDefault(); }); const h = this._element.classList; for (const y in gh) h.remove(`mapboxgl-marker-anchor-${y}`); h.add(`mapboxgl-marker-anchor-${this._anchor}`); const _ = t && t.className ? t.className.trim().split(/\s+/) : []; h.add(..._), this._popup = null; } addTo(t) { return t === this._map || (this.remove(), this._map = t, t.getCanvasContainer().appendChild(this._element), t.on("move", this._updateMoving), t.on("moveend", this._update), t.on("remove", this._clearFadeTimer), t._addMarker(this), this.setDraggable(this._draggable), this._update(), t.on("click", this._onMapClick)), this; } remove() { const t = this._map; return t && (t.off("click", this._onMapClick), t.off("move", this._updateMoving), t.off("moveend", this._update), t.off("mousedown", this._addDragHandler), t.off("touchstart", this._addDragHandler), t.off("mouseup", this._onUp), t.off("touchend", this._onUp), t.off("mousemove", this._onMove), t.off("touchmove", this._onMove), t.off("remove", this._clearFadeTimer), t._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 = i.bO.convert(t), this._pos = null, this._popup && this._popup.setLngLat(this._lngLat), this._update(!0), this; } getElement() { return this._element; } setPopup(t) { 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")), t) { if (!("offset" in t.options)) { const _ = Math.sqrt(Math.pow(13.5, 2) / 2); t.options.offset = this._defaultMarker ? { top: [0, 0], "top-left": [0, 0], "top-right": [0, 0], bottom: [0, -38.1], "bottom-left": [_, -1 * (38.1 - 13.5 + _)], "bottom-right": [-_, -1 * (38.1 - 13.5 + _)], left: [13.5, -1 * (38.1 - 13.5)], right: [-13.5, -1 * (38.1 - 13.5)] } : this._offset; } this._popup = t, t._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(t) { const s = t.code, h = t.charCode || t.keyCode; s !== "Space" && s !== "Enter" && h !== 32 && h !== 13 || this.togglePopup(); } _onMapClick(t) { const s = t.originalEvent.target, h = this._element; this._popup && (s === h || h.contains(s)) && this.togglePopup(); } getPopup() { return this._popup; } togglePopup() { const t = this._popup; return t ? (t.isOpen() ? (t.remove(), this._element.setAttribute("aria-expanded", "false")) : this._map && (t.addTo(this._map), this._element.setAttribute("aria-expanded", "true")), this) : this; } _behindTerrain() { const t = this._map, s = this._pos; if (!t || !s) return !1; const h = t.unproject(s), _ = t.getFreeCameraOptions(); if (!_.position) return !1; const y = _.position.toLngLat(); return y.distanceTo(h) < 0.9 * y.distanceTo(this._lngLat); } _evaluateOpacity() { const t = this._map; if (!t) return; const s = this._pos; if (!s || s.x < 0 || s.x > t.transform.width || s.y < 0 || s.y > t.transform.height) return void this._clearFadeTimer(); const h = t.unproject(s); let _; t._showingGlobe() && i.dH(t.transform, this._lngLat) ? _ = 0 : (_ = 1 - t._queryFogOpacity(h), t.transform._terrainEnabled() && t.getTerrain() && this._behindTerrain() && (_ *= this._occludedOpacity)), this._element.style.opacity = `${_}`, this._element.style.pointerEvents = _ > 0 ? "auto" : "none", this._popup && this._popup._setOpacity(_), this._fadeTimer = null; } _clearFadeTimer() { this._fadeTimer && (clearTimeout(this._fadeTimer), this._fadeTimer = null); } _updateDOM() { const t = this._pos; if (!t || !this._map) return; const s = this._offset.mult(this._scale); this._element.style.transform = ` translate(${t.x}px,${t.y}px) ${gh[this._anchor]} ${this._calculateXYTransform()} ${this._calculateZTransform()} translate(${s.x}px,${s.y}px) `; } _calculateXYTransform() { const t = this._pos, s = this._map, h = this.getPitchAlignment(); if (!s || !t || h !== "map") return ""; if (!s._showingGlobe()) { const R = s.getPitch(); return R ? `rotateX(${R}deg)` : ""; } const _ = i.c4(i.dI(s.transform, this._lngLat)), y = t.sub(i.dJ(s.transform)), T = Math.abs(y.x) + Math.abs(y.y); if (T === 0) return ""; const z = _ / T; return `rotateX(${-y.y * z}deg) rotateY(${y.x * z}deg)`; } _calculateZTransform() { const t = this._pos, s = this._map; if (!s || !t) return ""; let h = 0; const _ = this.getRotationAlignment(); if (_ === "map") if (s._showingGlobe()) { const y = s.project(new i.bO(this._lngLat.lng, this._lngLat.lat + 1e-3)), T = s.project(new i.bO(this._lngLat.lng, this._lngLat.lat - 1e-3)).sub(y); h = i.c4(Math.atan2(T.y, T.x)) - 90; } else h = -s.getBearing(); else if (_ === "horizon") { const y = i.ac(4, 6, s.getZoom()), T = i.dJ(s.transform); T.y += y * s.transform.height; const z = t.sub(T), R = i.c4(Math.atan2(z.y, z.x)); h = (R > 90 ? R - 270 : R + 90) * (1 - y); } return h += this._rotation, h ? `rotateZ(${h}deg)` : ""; } _update(t) { cancelAnimationFrame(this._updateFrameId); const s = this._map; s && (s.transform.renderWorldCopies && (this._lngLat = xp(this._lngLat, this._pos, s.transform)), this._pos = s.project(this._lngLat), t === !0 ? this._updateFrameId = requestAnimationFrame(() => { this._element && this._pos && this._anchor && (this._pos = this._pos.round(), this._updateDOM()); }) : this._pos = this._pos.round(), s._requestDomTask(() => { this._map && (this._element && this._pos && this._anchor && this._updateDOM(), (s._showingGlobe() || s.getTerrain() || s.getFog()) && !this._fadeTimer && (this._fadeTimer = window.setTimeout(this._evaluateOpacity.bind(this), 60))); })); } getOffset() { return this._offset; } setOffset(t) { return this._offset = i.P.convert(t), this._update(), this; } addClassName(t) { return this._element.classList.add(t), this; } removeClassName(t) { return this._element.classList.remove(t), this; } toggleClassName(t) { return this._element.classList.toggle(t); } _onMove(t) { const s = this._map; if (!s) return; const h = this._pointerdownPos, _ = this._positionDelta; if (h && _) { if (!this._isDragging) { const y = this._clickTolerance || s._clickTolerance; if (t.point.dist(h) < y) return; this._isDragging = !0; } this._pos = t.point.sub(_), this._lngLat = s.unproject(this._pos), this.setLngLat(this._lngLat), this._element.style.pointerEvents = "none", this._state === "pending" && (this._state = "active", this.fire(new i.z("dragstart"))), this.fire(new i.z("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)), this._state === "active" && this.fire(new i.z("dragend")), this._state = "inactive"; } _addDragHandler(t) { const s = this._map, h = this._pos; s && h && this._element.contains(t.originalEvent.target) && (t.preventDefault(), this._positionDelta = t.point.sub(h), this._pointerdownPos = t.point, this._state = "pending", s.on("mousemove", this._onMove), s.on("touchmove", this._onMove), s.once("mouseup", this._onUp), s.once("touchend", this._onUp)); } setDraggable(t) { this._draggable = !!t; const s = this._map; return s && (t ? (s.on("mousedown", this._addDragHandler), s.on("touchstart", this._addDragHandler)) : (s.off("mousedown", this._addDragHandler), s.off("touchstart", this._addDragHandler))), this; } isDraggable() { return this._draggable; } setRotation(t) { return this._rotation = t || 0, this._update(), this; } getRotation() { return this._rotation; } setRotationAlignment(t) { return this._rotationAlignment = t || "auto", this._update(), this; } getRotationAlignment() { return this._rotationAlignment === "auto" || this._rotationAlignment === "horizon" && this._map && !this._map._showingGlobe() ? "viewport" : this._rotationAlignment; } setPitchAlignment(t) { return this._pitchAlignment = t || "auto", this._update(), this; } getPitchAlignment() { return this._pitchAlignment === "auto" ? this.getRotationAlignment() : this._pitchAlignment; } setOccludedOpacity(t) { return this._occludedOpacity = t || 0.2, this._update(), this; } getOccludedOpacity() { return this._occludedOpacity; } } const Ta = { positionOptions: { enableHighAccuracy: !1, maximumAge: 0, timeout: 6e3 }, fitBoundsOptions: { maxZoom: 15 }, trackUserLocation: !1, showAccuracyCircle: !0, showUserLocation: !0, showUserHeading: !1 }, fr = { maxWidth: 100, unit: "metric" }, Fr = { kilometer: "km", meter: "m", mile: "mi", foot: "ft", "nautical-mile": "nm" }, Os = { closeButton: !0, closeOnClick: !0, focusAfterOpen: !0, className: "", maxWidth: "240px" }, vp = ["a[href]", "[tabindex]:not([tabindex='-1'])", "[contenteditable]:not([contenteditable='false'])", "button:not([disabled])", "input:not([disabled])", "select:not([disabled])", "textarea:not([disabled])"].join(", "); function Un(c = new i.P(0, 0), t = "bottom") { if (typeof c == "number") { const s = Math.round(Math.sqrt(0.5 * Math.pow(c, 2))); switch (t) { case "top": return new i.P(0, c); case "top-left": return new i.P(s, s); case "top-right": return new i.P(-s, s); case "bottom": return new i.P(0, -c); case "bottom-left": return new i.P(s, -s); case "bottom-right": return new i.P(-s, -s); case "left": return new i.P(c, 0); case "right": return new i.P(-c, 0); } return new i.P(0, 0); } return c instanceof i.P || Array.isArray(c) ? i.P.convert(c) : i.P.convert(c[t] || [0, 0]); } return { version: O, supported: Te.supported, setRTLTextPlugin: i.dK, getRTLTextPluginStatus: i.dL, Map: class extends gp { constructor(c) { Y.mark(j.create); const t = c; if ((c = i.l({}, Ui, c)).minZoom != null && c.maxZoom != null && c.minZoom > c.maxZoom) throw new Error("maxZoom must be greater than or equal to minZoom"); if (c.minPitch != null && c.maxPitch != null && c.minPitch > c.maxPitch) throw new Error("maxPitch must be greater than or equal to minPitch"); if (c.minPitch != null && c.minPitch < 0) throw new Error("minPitch must be greater than or equal to 0"); if (c.maxPitch != null && c.maxPitch > 85) throw new Error("maxPitch must be less than or equal to 85"); if (c.antialias && i.dF(window) && (c.antialias = !1, i.w("Antialiasing is disabled for this WebGL context to avoid browser bug: https://github.com/mapbox/mapbox-gl-js/issues/11609")), super(new ma(c.minZoom, c.maxZoom, c.minPitch, c.maxPitch, c.renderWorldCopies), c), this._repaint = !!c.repaint, this._interactive = c.interactive, this._minTileCacheSize = c.minTileCacheSize, this._maxTileCacheSize = c.maxTileCacheSize, this._failIfMajorPerformanceCaveat = c.failIfMajorPerformanceCaveat, this._preserveDrawingBuffer = c.preserveDrawingBuffer, this._antialias = c.antialias, this._trackResize = c.trackResize, this._bearingSnap = c.bearingSnap, this._refreshExpiredTiles = c.refreshExpiredTiles, this._fadeDuration = c.fadeDuration, this._isInitialLoad = !0, this._crossSourceCollisions = c.crossSourceCollisions, this._collectResourceTiming = c.collectResourceTiming, this._language = this._parseLanguage(c.language), this._worldview = c.worldview, this._renderTaskQueue = new Eu(), this._domRenderTaskQueue = new Eu(), this._controls = [], this._markers = [], this._popups = [], this._mapId = i.aV(), this._locale = i.l({}, fo, c.locale), this._clickTolerance = c.clickTolerance, this._cooperativeGestures = c.cooperativeGestures, this._performanceMetricsCollection = c.performanceMetricsCollection, this._tessellationStep = c.tessellationStep, this._containerWidth = 0, this._containerHeight = 0, this._showParseStatus = !0, this._precompilePrograms = c.precompilePrograms, this._scaleFactorChanged = !1, this._averageElevationLastSampledAt = -1 / 0, this._averageElevationExaggeration = 0, this._averageElevation = new uo(0), this._interactionRange = [1 / 0, -1 / 0], this._visibilityHidden = 0, this._useExplicitProjection = !1, this._frameId = 0, this._scaleFactor = c.scaleFactor, this._requestManager = new hn(c.transformRequest, c.accessToken, c.testMode), this._silenceAuthErrors = !!c.testMode, this._contextCreateOptions = c.contextCreateOptions ? { ...c.contextCreateOptions } : {}, typeof c.container == "string") { const s = document.getElementById(c.container); if (!s) throw new Error(`Container '${c.container.toString()}' not found.`); this._container = s; } else { if (!(c.container instanceof HTMLElement)) throw new Error("Invalid type: 'container' must be a String or HTMLElement."); this._container = c.container; } if (this._container.childNodes.length > 0 && i.w("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."), c.maxBounds && this.setMaxBounds(c.maxBounds), this._spriteFormat = c.spriteFormat, i.aP(["_onWindowOnline", "_onWindowResize", "_onVisibilityChange", "_onMapScroll", "_contextLost", "_contextRestored"], this), this._setupContainer(), this._tp || (this._tp = new mu()), this._tp.registerParameter(this, ["Debug"], "showOverdrawInspector"), this._tp.registerParameter(this, ["Debug"], "showTileBoundaries"), this._tp.registerParameter(this, ["Debug"], "showParseStatus"), this._tp.registerParameter(this, ["Debug"], "repaint"), this._tp.registerParameter(this, ["Debug"], "showTileAABBs"), this._tp.registerParameter(this, ["Debug"], "showPadding"), this._tp.registerParameter(this, ["Debug"], "showCollisionBoxes", { noSave: !0 }), this._tp.registerParameter(this.transform, ["Debug"], "freezeTileCoverage", { noSave: !0 }, () => { this._update(); }), this._tp.registerParameter(this, ["Debug", "Wireframe"], "showTerrainWireframe"), this._tp.registerParameter(this, ["Debug", "Wireframe"], "showLayers2DWireframe"), this._tp.registerParameter(this, ["Debug", "Wireframe"], "showLayers3DWireframe"), this._tp.registerParameter(this, ["Scaling"], "_scaleFactor", { min: 0.1, max: 10, step: 0.1 }, () => { this.setScaleFactor(this._scaleFactor); }), this._setupPainter(), this.painter === void 0) throw new Error("Failed to initialize WebGL."); if (this.on("move", () => this._update(!1)), this.on("moveend", () => this._update(!1)), this.on("zoom", () => this._update(!0)), this._fullscreenchangeEvent = "onfullscreenchange" in document ? "fullscreenchange" : "webkitfullscreenchange", window.addEventListener("online", this._onWindowOnline, !1), window.addEventListener("resize", this._onWindowResize, !1), window.addEventListener("orientationchange", this._onWindowResize, !1), window.addEventListener(this._fullscreenchangeEvent, this._onWindowResize, !1), window.addEventListener("visibilitychange", this._onVisibilityChange, !1), this.handlers = new dr(this, c), this._localFontFamily = c.localFontFamily, this._localIdeographFontFamily = c.localIdeographFontFamily, (c.style || !c.testMode) && this.setStyle(c.style || i.e.DEFAULT_STYLE, { config: c.config, localFontFamily: this._localFontFamily, localIdeographFontFamily: this._localIdeographFontFamily }), c.projection && this.setProjection(c.projection), this.indoor = new yl(this), c.hash && (this._hash = new zd(typeof c.hash == "string" && c.hash || void 0).addTo(this)), !this._hash || !this._hash._onHashChange()) { t.center == null && t.zoom == null || (this.transform._unmodified = !1), this.jumpTo({ center: c.center, zoom: c.zoom, bearing: c.bearing, pitch: c.pitch }); const s = c.bounds; s && (this.resize(), this.fitBounds(s, i.l({}, c.fitBoundsOptions, { duration: 0 }))); } this.resize(), c.attributionControl && this.addControl(new yp({ customAttribution: c.customAttribution })), this._logoControl = new Il(), this.addControl(this._logoControl, c.logoPosition), this.on("style.load", () => { this.transform.unmodified && this.jumpTo(this.style.stylesheet), this._postStyleLoadEvent(); }), this.on("data", (s) => { this._update(s.dataType === "style"), this.fire(new i.z(`${s.dataType}data`, s)); }), this.on("dataloading", (s) => { this.fire(new i.z(`${s.dataType}dataloading`, s)); }), this._interactions = new _c(this); } _getMapId() { return this._mapId; } addControl(c, t) { if (t === void 0 && (t = c.getDefaultPosition ? c.getDefaultPosition() : "top-right"), !c || !c.onAdd) return this.fire(new i.y(new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods."))); const s = c.onAdd(this); this._controls.push(c); const h = this._controlPositions[t]; return t.indexOf("bottom") !== -1 ? h.insertBefore(s, h.firstChild) : h.appendChild(s), this; } removeControl(c) { if (!c || !c.onRemove) return this.fire(new i.y(new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods."))); const t = this._controls.indexOf(c); return t > -1 && this._controls.splice(t, 1), c.onRemove(this), this; } hasControl(c) { return this._controls.indexOf(c) > -1; } getContainer() { return this._container; } getCanvasContainer() { return this._canvasContainer; } getCanvas() { return this._canvas; } resize(c) { 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 t = !this._moving; return t && this.fire(new i.z("movestart", c)).fire(new i.z("move", c)), this.fire(new i.z("resize", c)), t && this.fire(new i.z("moveend", c)), this; } getBounds() { return this.transform.getBounds(); } getMaxBounds() { return this.transform.getMaxBounds() || null; } setMaxBounds(c) { return this.transform.setMaxBounds(i.az.convert(c)), this._update(); } setMinZoom(c) { if ((c = c ?? -2) >= -2 && c <= this.transform.maxZoom) return this.transform.minZoom = c, this._update(), this.getZoom() < c ? this.setZoom(c) : this.fire(new i.z("zoomstart")).fire(new i.z("zoom")).fire(new i.z("zoomend")), this; throw new Error("minZoom must be between -2 and the current maxZoom, inclusive"); } getMinZoom() { return this.transform.minZoom; } setMaxZoom(c) { if ((c = c ?? 22) >= this.transform.minZoom) return this.transform.maxZoom = c, this._update(), this.getZoom() > c ? this.setZoom(c) : this.fire(new i.z("zoomstart")).fire(new i.z("zoom")).fire(new i.z("zoomend")), this; throw new Error("maxZoom must be greater than the current minZoom"); } getMaxZoom() { return this.transform.maxZoom; } setMinPitch(c) { if ((c = c ?? 0) < 0) throw new Error("minPitch must be greater than or equal to 0"); if (c >= 0 && c <= this.transform.maxPitch) return this.transform.minPitch = c, this._update(), this.getPitch() < c ? this.setPitch(c) : this.fire(new i.z("pitchstart")).fire(new i.z("pitch")).fire(new i.z("pitchend")), this; throw new Error("minPitch must be between 0 and the current maxPitch, inclusive"); } getMinPitch() { return this.transform.minPitch; } setMaxPitch(c) { if ((c = c ?? 85) > 85) throw new Error("maxPitch must be less than or equal to 85"); if (c >= this.transform.minPitch) return this.transform.maxPitch = c, this._update(), this.getPitch() > c ? this.setPitch(c) : this.fire(new i.z("pitchstart")).fire(new i.z("pitch")).fire(new i.z("pitchend")), this; throw new Error("maxPitch must be greater than or equal to minPitch"); } getMaxPitch() { return this.transform.maxPitch; } getScaleFactor() { return this._scaleFactor; } setScaleFactor(c) { return this._scaleFactor = c, this.painter.scaleFactor = c, this._tp.refreshUI(), this._scaleFactorChanged = !0, this.style._updateFilteredLayers((t) => t.type === "symbol"), this._update(!0), this; } getRenderWorldCopies() { return this.transform.renderWorldCopies; } setRenderWorldCopies(c) { return this.transform.renderWorldCopies = c, this.transform.renderWorldCopies || this._forceMarkerAndPopupUpdate(!0), this._update(); } getLanguage() { return this._language; } _parseLanguage(c) { return c === "auto" ? navigator.language : Array.isArray(c) ? c.length === 0 ? void 0 : c.map((t) => t === "auto" ? navigator.language : t) : c; } setLanguage(c) { const t = this._parseLanguage(c); if (!this.style || t === this._language) return this; this._language = t, this.style.reloadSources(); for (const s of this._controls) s._setLanguage && s._setLanguage(this._language); return this; } getWorldview() { return this._worldview; } setWorldview(c) { return this.style && c !== this._worldview ? (this._worldview = c, this.style.reloadSources(), this) : this; } getProjection() { return this.transform.mercatorFromTransition ? { name: "globe", center: [0, 0] } : this.transform.getProjection(); } _showingGlobe() { return this.transform.projection.name === "globe"; } setProjection(c) { return this._lazyInitEmptyStyle(), c ? typeof c == "string" && (c = { name: c }) : c = null, this._useExplicitProjection = !!c, this._prioritizeAndUpdateProjection(c, this.style.projection); } _updateProjectionTransition() { if (this.getProjection().name !== "globe") return; const c = this.transform, t = c.projection.name; let s; t === "globe" && c.zoom >= i.bY ? (c.setMercatorFromTransition(), s = !0) : t === "mercator" && c.zoom < i.bY && (c.setProjection({ name: "globe" }), s = !0), s && (this.style.applyProjectionUpdate(), this.style._forceSymbolLayerUpdate()); } _prioritizeAndUpdateProjection(c, t) { return this._updateProjection(c || t || { name: "mercator" }); } _updateProjection(c) { let t; return t = c.name === "globe" && this.transform.zoom >= i.bY ? this.transform.setMercatorFromTransition() : this.transform.setProjection(c), this.style.applyProjectionUpdate(), t && (this.painter.clearBackgroundTiles(), this.style.clearSources(), this._update(!0), this._forceMarkerAndPopupUpdate(!0)), this; } project(c) { return this.transform.locationPoint3D(i.bO.convert(c)); } unproject(c) { return this.transform.pointLocation3D(i.P.convert(c)); } 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(c, t, s) { const h = (_) => { let y = []; if (Array.isArray(t)) { const T = t.filter((z) => this.getLayer(z)); y = T.length ? this.queryRenderedFeatures(_, { layers: T }) : []; } else y = this.queryRenderedFeatures(_, { target: t }); return y; }; if (c === "mouseenter" || c === "mouseover") { let _ = !1; return { listener: s, targets: t, delegates: { mousemove: (T) => { const z = h(T.point); z.length ? _ || (_ = !0, s.call(this, new Or(c, this, T.originalEvent, { features: z }))) : _ = !1; }, mouseout: () => { _ = !1; } } }; } if (c === "mouseleave" || c === "mouseout") { let _ = !1; return { listener: s, targets: t, delegates: { mousemove: (z) => { h(z.point).length ? _ = !0 : _ && (_ = !1, s.call(this, new Or(c, this, z.originalEvent))); }, mouseout: (z) => { _ && (_ = !1, s.call(this, new Or(c, this, z.originalEvent))); } } }; } { const _ = (y) => { const T = h(y.point); T.length && (y.features = T, s.call(this, y), delete y.features); }; return { listener: s, targets: t, delegates: { [c]: _ } }; } } on(c, t, s) { if (typeof t == "function" || s === void 0) return super.on(c, t); if (typeof t == "string" && (t = [t]), !this._areTargetsValid(t)) return this; const h = this._createDelegatedListener(c, t, s); this._delegatedListeners = this._delegatedListeners || {}, this._delegatedListeners[c] = this._delegatedListeners[c] || [], this._delegatedListeners[c].push(h); for (const _ in h.delegates) this.on(_, h.delegates[_]); return this; } once(c, t, s) { if (typeof t == "function" || s === void 0) return super.once(c, t); if (typeof t == "string" && (t = [t]), !this._areTargetsValid(t)) return this; const h = this._createDelegatedListener(c, t, s); for (const _ in h.delegates) this.once(_, h.delegates[_]); return this; } off(c, t, s) { if (typeof t == "function" || s === void 0) return super.off(c, t); if (typeof t == "string" && (t = [t]), !this._areTargetsValid(t)) return this; const h = this._delegatedListeners ? this._delegatedListeners[c] : void 0; return h && ((_) => { for (let y = 0; y < _.length; y++) { const T = _[y]; if (T.listener === s && Fd(T.targets, t)) { for (const z in T.delegates) this.off(z, T.delegates[z]); return _.splice(y, 1), this; } } })(h), this; } queryRenderedFeatures(c, t) { if (!this.style) return []; if (c === void 0 || c instanceof i.P || Array.isArray(c) || t !== void 0 || (t = c, c = void 0), c = c || [[0, 0], [this.transform.width, this.transform.height]], !t) { const y = this.style.queryRenderedFeatures(c, void 0, this.transform), T = this.style.queryRenderedFeatureset(c, void 0, this.transform); return y.concat(T); } let s = !0; if (t.target && (s = this._isTargetValid(t.target), s && !t.layers)) return this.style.queryRenderedFeatureset(c, t, this.transform); let h = !0; if (t.layers && Array.isArray(t.layers)) { for (const y of t.layers) if (!this._isValidId(y)) { h = !1; break; } if (h && !t.target) return this.style.queryRenderedFeatures(c, t, this.transform); } let _ = []; return h && (_ = _.concat(this.style.queryRenderedFeatures(c, t, this.transform))), s && (_ = _.concat(this.style.queryRenderedFeatureset(c, t, this.transform))), _; } querySourceFeatures(c, t) { return !c || typeof c == "string" && !this._isValidId(c) ? [] : this.style.querySourceFeatures(c, t); } isPointOnSurface(c) { const { name: t } = this.transform.projection; return t !== "globe" && t !== "mercator" && i.w(`${t} projection does not support isPointOnSurface, this API may behave unexpectedly.`), this.transform.isPointOnSurface(i.P.convert(c)); } addInteraction(c, t) { return this._interactions.add(c, t), this; } removeInteraction(c) { return this._interactions.remove(c), this; } setStyle(c, t) { return t = i.l({}, { localIdeographFontFamily: this._localIdeographFontFamily, localFontFamily: this._localFontFamily }, t), this.style && c && t.diff !== !1 && t.localFontFamily === this._localFontFamily && t.localIdeographFontFamily === this._localIdeographFontFamily && !t.config ? (this.style._diffStyle(c, (s, h) => { s ? (i.w(`Unable to perform style diff: ${String(s.message || s.error || s)}. Rebuilding the style from scratch.`), this._updateStyle(c, t)) : h && this._update(!0); }, () => { this._postStyleLoadEvent(); }), this) : (this._localIdeographFontFamily = t.localIdeographFontFamily, this._localFontFamily = t.localFontFamily, this._updateStyle(c, t)); } _getUIString(c) { const t = this._locale[c]; if (t == null) throw new Error(`Missing UI string '${c}'`); return t; } _updateStyle(c, t) { if (this.style && (this.style.setEventedParent(null), this.style._remove(), this.style = void 0), c) { const s = i.l({}, t); t && t.config && (s.initialConfig = t.config, delete s.config), this.style = new hr(this, s).load(c), this.style.setEventedParent(this, { style: this.style }); } return this._updateTerrain(), this; } _lazyInitEmptyStyle() { this.style || (this.style = new hr(this, {}), this.style.setEventedParent(this, { style: this.style }), this.style.loadEmpty()); } getStyle() { if (this.style) return this.style.serialize(); } isStyleLoaded() { return this.style ? this.style.loaded() : (i.w("There is no style added to the map."), !1); } _isValidId(c) { return c == null ? (this.fire(new i.y(new Error("IDs can't be empty."))), !1) : !i.cr(c) || (this.fire(new i.y(new Error(`IDs can't contain special symbols: "${c}".`))), !1); } _isTargetValid(c) { return "featuresetId" in c ? this._isValidId("importId" in c ? c.importId : c.featuresetId) : "layerId" in c && this._isValidId(c.layerId); } _areTargetsValid(c) { if (Array.isArray(c)) { for (const t of c) if (!this._isValidId(t)) return !1; return !0; } return this._isTargetValid(c); } addSource(c, t) { return this._isValidId(c) ? (this._lazyInitEmptyStyle(), this.style.addSource(c, t), this._update(!0)) : this; } isSourceLoaded(c) { return !!this._isValidId(c) && !!this.style && this.style._isSourceCacheLoaded(c); } areTilesLoaded() { return this.style.areTilesLoaded(); } addSourceType(c, t, s) { this._lazyInitEmptyStyle(), this.style.addSourceType(c, t, s); } removeSource(c) { return this._isValidId(c) ? (this.style.removeSource(c), this._updateTerrain(), this._update(!0)) : this; } getSource(c) { return this._isValidId(c) ? this.style.getOwnSource(c) : null; } addImage(c, t, { pixelRatio: s = 1, sdf: h = !1, stretchX: _, stretchY: y, content: T } = {}) { if (this._lazyInitEmptyStyle(), t instanceof HTMLImageElement || ImageBitmap && t instanceof ImageBitmap) { const { width: z, height: R, data: F } = i.q.getImageData(t); this.style.addImage(c, { data: new i.r({ width: z, height: R }, F), pixelRatio: s, stretchX: _, stretchY: y, content: T, sdf: h, version: 0, usvg: !1 }); } else if (t.width === void 0 || t.height === void 0) this.fire(new i.y(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: z, height: R } = t, F = t; this.style.addImage(c, { data: new i.r({ width: z, height: R }, new Uint8Array(F.data)), pixelRatio: s, stretchX: _, stretchY: y, content: T, sdf: h, usvg: !1, version: 0, userImage: F }), F.onAdd && F.onAdd(this, c); } } updateImage(c, t) { this._lazyInitEmptyStyle(); const s = this.style.getImage(c); if (!s) return void this.fire(new i.y(new Error("The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead."))); const h = t instanceof HTMLImageElement || ImageBitmap && t instanceof ImageBitmap ? i.q.getImageData(t) : t, { width: _, height: y, data: T } = h; if (_ === void 0 || y === void 0) return void this.fire(new i.y(new Error("Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`"))); if (_ !== (s.usvg ? s.icon.usvg_tree.width : s.data.width) || y !== (s.usvg ? s.icon.usvg_tree.height : s.data.height)) return void this.fire(new i.y(new Error(`The width and height of the updated image (${_}, ${y}) must be that same as the previous version of the image (${s.data.width}, ${s.data.height})`))); const z = !(t instanceof HTMLImageElement || ImageBitmap && t instanceof ImageBitmap); let R = !1; s.usvg ? (s.data = new i.r({ width: _, height: y }, new Uint8Array(T)), s.usvg = !1, s.icon = void 0, R = !0) : s.data.replace(T, z), this.style.updateImage(c, s, R); } hasImage(c) { return c ? !!this.style && !!this.style.getImage(c) : (this.fire(new i.y(new Error("Missing required image id"))), !1); } removeImage(c) { this.style.removeImage(c); } loadImage(c, t) { i.o(this._requestManager.transformRequest(c, i.R.Image), (s, h) => { t(s, h instanceof HTMLImageElement ? i.q.getImageData(h) : h); }); } listImages() { return this.style.listImages(); } addModel(c, t) { this._lazyInitEmptyStyle(), this.style.addModel(c, t); } hasModel(c) { return c ? this.style.hasModel(c) : (this.fire(new i.y(new Error("Missing required model id"))), !1); } removeModel(c) { this.style.removeModel(c); } listModels() { return this.style.listModels(); } addLayer(c, t) { return this._isValidId(c.id) ? (this._lazyInitEmptyStyle(), this.style.addLayer(c, t), this._update(!0)) : this; } getSlot(c) { const t = this.getLayer(c); return t && t.slot || null; } setSlot(c, t) { return this.style.setSlot(c, t), this.style.mergeLayers(), this._update(!0); } addImport(c, t) { return this.style.addImport(c, t), this; } updateImport(c, t) { return typeof t != "string" && t.id !== c ? (this.removeImport(c), this.addImport(t)) : (this.style.updateImport(c, t), this._update(!0)); } removeImport(c) { return this.style.removeImport(c), this; } moveImport(c, t) { return this.style.moveImport(c, t), this._update(!0); } moveLayer(c, t) { return this._isValidId(c) ? (this.style.moveLayer(c, t), this._update(!0)) : this; } removeLayer(c) { return this._isValidId(c) ? (this.style.removeLayer(c), this._update(!0)) : this; } getLayer(c) { if (!this._isValidId(c)) return null; const t = this.style.getOwnLayer(c); return t ? t.type === "custom" ? t.implementation : t.serialize() : void 0; } getSlots() { return this.style.getSlots(); } setLayerZoomRange(c, t, s) { return this._isValidId(c) ? (this.style.setLayerZoomRange(c, t, s), this._update(!0)) : this; } setFilter(c, t, s = {}) { return this._isValidId(c) ? (this.style.setFilter(c, t, s), this._update(!0)) : this; } getFilter(c) { return this._isValidId(c) ? this.style.getFilter(c) : null; } setPaintProperty(c, t, s, h = {}) { return this._isValidId(c) ? (this.style.setPaintProperty(c, t, s, h), this._update(!0)) : this; } getPaintProperty(c, t) { return this._isValidId(c) ? this.style.getPaintProperty(c, t) : null; } setLayoutProperty(c, t, s, h = {}) { return this._isValidId(c) ? (this.style.setLayoutProperty(c, t, s, h), this._update(!0)) : this; } getLayoutProperty(c, t) { return this._isValidId(c) ? this.style.getLayoutProperty(c, t) : null; } getSchema(c) { return this.style.getSchema(c); } setSchema(c, t) { return this.style.setSchema(c, t), this._update(!0); } getConfig(c) { return this.style.getConfig(c); } setConfig(c, t) { return this.style.setConfig(c, t), this._update(!0); } getConfigProperty(c, t) { return this.style.getConfigProperty(c, t); } setConfigProperty(c, t, s) { return this.style.setConfigProperty(c, t, s), this._update(!0); } getFeaturesetDescriptors(c) { return this.style.getFeaturesetDescriptors(c); } setLights(c) { if (this._lazyInitEmptyStyle(), c && c.length === 1 && c[0].type === "flat") { const t = c[0]; t.properties ? this.style.setFlatLight(t.properties, t.id, {}) : this.style.setFlatLight({}, "flat"); } else this.style.setLights(c), this.painter.terrain && (this.painter.terrain.invalidateRenderCache = !0); return this._update(!0); } getLights() { const c = this.style.getLights() || []; return c.length === 0 && c.push({ id: this.style.light.id, type: "flat", properties: this.style.getFlatLight() }), c; } setLight(c, t = {}) { return console.log("The `map.setLight` function is deprecated, prefer using `map.setLights` with `flat` light type instead."), this.setLights([{ id: "flat", type: "flat", properties: c }]); } getLight() { return console.log("The `map.getLight` function is deprecated, prefer using `map.getLights` instead."), this.style.getFlatLight(); } setTerrain(c) { return this._lazyInitEmptyStyle(), !c && this.transform.projection.requiresDraping ? this.style.setTerrainForDraping() : this.style.setTerrain(c), this._averageElevationLastSampledAt = -1 / 0, this._update(!0); } getTerrain() { return this.style ? this.style.getTerrain() : null; } setFog(c) { return this._lazyInitEmptyStyle(), this.style.setFog(c), this._update(!0); } getFog() { return this.style ? this.style.getFog() : null; } setSnow(c) { return this._lazyInitEmptyStyle(), this.style.setSnow(c), this._update(!0); } getSnow() { return this.style ? this.style.getSnow() : null; } setRain(c) { return this._lazyInitEmptyStyle(), this.style.setRain(c), this._update(!0); } getRain() { return this.style ? this.style.getRain() : null; } setColorTheme(c) { return this._lazyInitEmptyStyle(), this.style.setColorTheme(c), this._update(!0); } setImportColorTheme(c, t) { return this._lazyInitEmptyStyle(), this.style.setImportColorTheme(c, t), this._update(!0); } setCamera(c) { return this.style.setCamera(c), this._triggerCameraUpdate(c); } _triggerCameraUpdate(c) { return this._update(this.transform.setOrthographicProjectionAtLowPitch(c["camera-projection"] === "orthographic")); } getCamera() { return this.style.camera; } _queryFogOpacity(c) { return this.style && this.style.fog ? this.style.fog.getOpacityAtLatLng(i.bO.convert(c), this.transform) : 0; } setFeatureState(c, t) { return c.source && !this._isValidId(c.source) ? this : (this.style.setFeatureState(c, t), this._update()); } removeFeatureState(c, t) { return c.source && !this._isValidId(c.source) ? this : (this.style.removeFeatureState(c, t), this._update()); } getFeatureState(c) { return c.source && !this._isValidId(c.source) ? null : this.style.getFeatureState(c); } _updateContainerDimensions() { if (!this._container) return; const c = this._container.getBoundingClientRect().width || 400, t = this._container.getBoundingClientRect().height || 300; let s, h, _, y = this._container; for (; y && (!h || !_); ) { const T = window.getComputedStyle(y).transform; T && T !== "none" && (s = T.match(/matrix.*\((.+)\)/)[1].split(", "), s[0] && s[0] !== "0" && s[0] !== "1" && (h = s[0]), s[3] && s[3] !== "0" && s[3] !== "1" && (_ = s[3])), y = y.parentElement; } this._containerWidth = h ? Math.abs(c / h) : c, this._containerHeight = _ ? Math.abs(t / _) : t; } _detectMissingCSS() { window.getComputedStyle(this._missingCSSCanary).getPropertyValue("background-color") !== "rgb(250, 128, 114)" && i.w("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 c = this._container; c.classList.add("mapboxgl-map"), (this._missingCSSCanary = be("div", "mapboxgl-canary", c)).style.visibility = "hidden", this._detectMissingCSS(); const t = this._canvasContainer = be("div", "mapboxgl-canvas-container", c); this._canvas = be("canvas", "mapboxgl-canvas", t), this._interactive && (t.classList.add("mapboxgl-interactive"), this._canvas.setAttribute("tabindex", "0")), this._canvas.addEventListener("webglcontextlost", this._contextLost, !1), this._canvas.addEventListener("webglcontextrestored", this._contextRestored, !1), this._canvas.setAttribute("aria-label", this._getUIString("Map.Title")), this._canvas.setAttribute("role", "region"), this._updateContainerDimensions(), this._resizeCanvas(this._containerWidth, this._containerHeight); const s = this._controlContainer = be("div", "mapboxgl-control-container", c), h = this._controlPositions = {}; ["top-left", "top", "top-right", "right", "bottom-right", "bottom", "bottom-left", "left"].forEach((_) => { h[_] = be("div", `mapboxgl-ctrl-${_}`, s); }), this._container.addEventListener("scroll", this._onMapScroll, !1); } _resizeCanvas(c, t) { const s = i.q.devicePixelRatio || 1; this._canvas.width = s * Math.ceil(c), this._canvas.height = s * Math.ceil(t), this._canvas.style.width = `${c}px`, this._canvas.style.height = `${t}px`; } _addMarker(c) { this._markers.push(c); } _removeMarker(c) { const t = this._markers.indexOf(c); t !== -1 && this._markers.splice(t, 1); } _addPopup(c) { this._popups.push(c); } _removePopup(c) { const t = this._popups.indexOf(c); t !== -1 && this._popups.splice(t, 1); } _setupPainter() { const c = i.l({}, Te.supported.webGLContextAttributes, { failIfMajorPerformanceCaveat: this._failIfMajorPerformanceCaveat, preserveDrawingBuffer: this._preserveDrawingBuffer, antialias: this._antialias || !1 }), t = this._canvas.getContext("webgl2", c); t ? (Us(t, !0), this.painter = new Ld(t, this._contextCreateOptions, this.transform, this._scaleFactor, this._tp), this.on("data", (s) => { s.dataType === "source" && this.painter.setTileLoadedFlag(!0); }), i.m.testSupport(t)) : this.fire(new i.y(new Error("Failed to initialize WebGL"))); } _contextLost(c) { c.preventDefault(), this._frame && (this._frame.cancel(), this._frame = null), this.fire(new i.z("webglcontextlost", { originalEvent: c })); } _contextRestored(c) { this._setupPainter(), this.resize(), this._update(), this.fire(new i.z("webglcontextrestored", { originalEvent: c })); } _onMapScroll(c) { if (c.target === this._container) return this._container.scrollTop = 0, this._container.scrollLeft = 0, !1; } idle() { return !this.isMoving() && this.loaded(); } loaded() { return !this._styleDirty && !this._sourcesDirty && !!this.style && this.style.loaded(); } frameReady() { return this.loaded() && !this._placementDirty; } _update(c) { return this.style ? (this._styleDirty = this._styleDirty || c, this._sourcesDirty = !0, this.triggerRepaint(), this) : this; } _requestRenderFrame(c) { return this._update(), this._renderTaskQueue.add(c); } _cancelRenderFrame(c) { this._renderTaskQueue.remove(c); } _requestDomTask(c) { !this.loaded() || this.loaded() && !this.isMoving() ? c() : this._domRenderTaskQueue.add(c); } _render(c) { let t; this.fire(new i.z("renderstart")), ++this._frameId; const s = this.painter.context.extTimerQuery, h = i.q.now(), _ = this.painter.context.gl; if (this.listens("gpu-timing-frame") && (t = _.createQuery(), _.beginQuery(s.TIME_ELAPSED_EXT, t)), this.painter.context.setDirty(), this.painter.setBaseState(), (this.isMoving() || this.isRotating() || this.isZooming()) && (this._interactionRange[0] = Math.min(this._interactionRange[0], performance.now()), this._interactionRange[1] = Math.max(this._interactionRange[1], performance.now())), this._renderTaskQueue.run(c), this._domRenderTaskQueue.run(c), this._removed) return; this._updateProjectionTransition(); const y = this._isInitialLoad ? 0 : this._fadeDuration; if (this.style && this._styleDirty) { this._styleDirty = !1; const F = this.transform.zoom, N = this.transform.pitch, G = i.q.now(), Z = new i.a8(F, { now: G, fadeDuration: y, pitch: N, transition: this.style.transition }); this.style.update(Z); } this.style && this.style.hasFogTransition() && (this.style._markersNeedUpdate = !0, this._sourcesDirty = !0); let T = !1; this.style && this._sourcesDirty ? (this._sourcesDirty = !1, this.painter._updateFog(this.style), this._updateTerrain(), T = this._updateAverageElevation(h), this.style.updateSources(this.transform), this._forceMarkerAndPopupUpdate()) : T = this._updateAverageElevation(h); const z = this.style && this.style._updatePlacement(this.painter, this.painter.transform, this.showCollisionBoxes, y, this._crossSourceCollisions, this.painter.replacementSource, this._scaleFactorChanged); if (this._scaleFactorChanged && (this._scaleFactorChanged = !1), z && (this._placementDirty = z.needsRerender), this.style && this.painter.render(this.style, { showTileBoundaries: this.showTileBoundaries, showParseStatus: this.showParseStatus, wireframe: { terrain: this.showTerrainWireframe, layers2D: this.showLayers2DWireframe, layers3D: this.showLayers3DWireframe }, showOverdrawInspector: this._showOverdrawInspector, showQueryGeometry: !!this._showQueryGeometry, showTileAABBs: this.showTileAABBs, rotating: this.isRotating(), zooming: this.isZooming(), moving: this.isMoving(), fadeDuration: y, 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 i.z("render")), this.loaded() && !this._loaded && (this._loaded = !0, Y.mark(j.load), this.fire(new i.z("load"))), this.style && this.style.hasTransitions() && (this._styleDirty = !0), this.style && (this.style.snow || this.style.rain) && (this._styleDirty = !0), this.style && !this._placementDirty && this.style._releaseSymbolFadeTiles(), t) { const F = i.q.now() - h; _.endQuery(s.TIME_ELAPSED_EXT), setTimeout(() => { const N = _.getQueryParameter(t, _.QUERY_RESULT) / 1e6; _.deleteQuery(t), this.fire(new i.z("gpu-timing-frame", { cpuTime: F, gpuTime: N })); }, 50); } if (this.listens("gpu-timing-layer")) { const F = this.painter.collectGpuTimers(); setTimeout(() => { const N = this.painter.queryGpuTimers(F); this.fire(new i.z("gpu-timing-layer", { layerTimes: N })); }, 50); } if (this.listens("gpu-timing-deferred-render")) { const F = this.painter.collectDeferredRenderGpuQueries(); setTimeout(() => { const N = this.painter.queryGpuTimeDeferredRender(F); this.fire(new i.z("gpu-timing-deferred-render", { gpuTime: N })); }, 50); } const R = this._sourcesDirty || this._styleDirty || this._placementDirty || T; if (R || this._repaint) this.triggerRepaint(); else { const F = this.idle(); if (F && (T = this._updateAverageElevation(h, !0)), T) this.triggerRepaint(); else if (this._triggerFrame(!1), F && (this.fire(new i.z("idle")), this._isInitialLoad = !1, this.speedIndexTiming)) { const N = this._calculateSpeedIndex(); this.fire(new i.z("speedindexcompleted", { speedIndex: N })), this.speedIndexTiming = !1; } } !this._loaded || this._fullyLoaded || R || (this._fullyLoaded = !0, Y.mark(j.fullLoad), this._performanceMetricsCollection && xs(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(c) { for (const t of this._markers) c && !this.getRenderWorldCopies() && (t._lngLat = t._lngLat.wrap()), t._update(); for (const t of this._popups) !c || this.getRenderWorldCopies() || t._trackPointer || (t._lngLat = t._lngLat.wrap()), t._update(); } _updateAverageElevation(c, t = !1) { const s = (_) => (this.transform.averageElevation = _, this._update(!1), !0); if (!this.painter.averageElevationNeedsEasing()) return this.transform.averageElevation !== 0 && s(0); const h = this.transform.elevation && this.transform.elevation.exaggeration() !== this._averageElevationExaggeration; if (h || (t || c - this._averageElevationLastSampledAt > 500) && !this._averageElevation.isEasing(c)) { const _ = this.transform.averageElevation; let y = this.transform.sampleAverageElevation(); this.transform.elevation != null && (this._averageElevationExaggeration = this.transform.elevation.exaggeration()), isNaN(y) ? y = 0 : this._averageElevationLastSampledAt = c; const T = Math.abs(_ - y); if (T > 1) { if (this._isInitialLoad || h) return this._averageElevation.jumpTo(y), s(y); this._averageElevation.easeTo(y, c, 300); } else if (T > 1e-4) return this._averageElevation.jumpTo(y), s(y); } return !!this._averageElevation.isEasing(c) && s(this._averageElevation.getValue(c)); } _authenticate() { De(this._getMapId(), this._requestManager._skuToken, this._requestManager._customAccessToken, (c) => { if (c && (c.message === Pn || c.status === 401)) { const t = this.painter.context.gl; Us(t, !1), this._logoControl instanceof Il && this._logoControl._updateLogo(), t && t.clear(t.DEPTH_BUFFER_BIT | t.COLOR_BUFFER_BIT | t.STENCIL_BUFFER_BIT), this._silenceAuthErrors || this.fire(new i.y(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/"))); } }), ln(this._getMapId(), this._requestManager._skuToken, this._requestManager._customAccessToken, () => { }); } _postStyleLoadEvent() { this.style.globalId && xi(this._requestManager._customAccessToken, { map: this, skuToken: this._requestManager._skuToken, style: this.style.globalId, importedStyles: this.style.getImportGlobalIds() }); } _updateTerrain() { const c = this._isDragging(); this.painter.updateTerrain(this.style, c); } _calculateSpeedIndex() { const c = this.painter.canvasCopy(), t = this.painter.getCanvasCopiesAndTimestamps(); t.timeStamps.push(performance.now()); const s = this.painter.context.gl, h = s.createFramebuffer(); function _(y) { s.framebufferTexture2D(s.FRAMEBUFFER, s.COLOR_ATTACHMENT0, s.TEXTURE_2D, y, 0); const T = new Uint8Array(s.drawingBufferWidth * s.drawingBufferHeight * 4); return s.readPixels(0, 0, s.drawingBufferWidth, s.drawingBufferHeight, s.RGBA, s.UNSIGNED_BYTE, T), T; } return s.bindFramebuffer(s.FRAMEBUFFER, h), this._canvasPixelComparison(_(c), t.canvasCopies.map(_), t.timeStamps); } _canvasPixelComparison(c, t, s) { let h = s[1] - s[0]; const _ = c.length / 4; for (let y = 0; y < t.length; y++) { const T = t[y]; let z = 0; for (let R = 0; R < T.length; R += 4) T[R] === c[R] && T[R + 1] === c[R + 1] && T[R + 2] === c[R + 2] && T[R + 3] === c[R + 3] && (z += 1); h += (s[y + 2] - s[y + 1]) * (1 - z / _); } return h; } remove() { this._hash && this._hash.remove(); for (const t of this._controls) t.onRemove(this); this._controls = [], this._frame && (this._frame.cancel(), this._frame = null), this._renderTaskQueue.clear(), this._domRenderTaskQueue.clear(), this.style && this.style.destroy(), this.indoor.destroy(), this.painter.destroy(), this.handlers && this.handlers.destroy(), this.handlers = void 0, this.setStyle(null), window.removeEventListener("resize", this._onWindowResize, !1), window.removeEventListener("orientationchange", this._onWindowResize, !1), window.removeEventListener(this._fullscreenchangeEvent, this._onWindowResize, !1), window.removeEventListener("online", this._onWindowOnline, !1), window.removeEventListener("visibilitychange", this._onVisibilityChange, !1); const c = this.painter.context.gl.getExtension("WEBGL_lose_context"); c && c.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), Vs.delete(this.painter.context.gl), Is.remove(), qt.remove(), this._removed = !0, this.fire(new i.z("remove")); } triggerRepaint() { this._triggerFrame(!0); } _triggerFrame(c) { this._renderNextFrame = this._renderNextFrame || c, this.style && !this._frame && (this._frame = i.q.frame((t) => { const s = !!this._renderNextFrame; this._frame = null, this._renderNextFrame = null, s && this._render(t); })); } _preloadTiles(c) { const t = this.style ? this.style.getSourceCaches() : []; return i.bl(t, (s, h) => s._preloadTiles(c, h), () => { this.triggerRepaint(); }), this; } _onWindowOnline() { this._update(); } _onWindowResize(c) { this._trackResize && this.resize({ originalEvent: c })._update(); } _onVisibilityChange() { document.visibilityState === "hidden" && this._visibilityHidden++; } get showTileBoundaries() { return !!this._showTileBoundaries; } set showTileBoundaries(c) { this._showTileBoundaries !== c && (this._showTileBoundaries = c, this._tp.refreshUI(), this._update()); } get showParseStatus() { return !!this._showParseStatus; } set showParseStatus(c) { this._showParseStatus !== c && (this._showParseStatus = c, this._tp.refreshUI(), this._update()); } get showTerrainWireframe() { return !!this._showTerrainWireframe; } set showTerrainWireframe(c) { this._showTerrainWireframe !== c && (this._showTerrainWireframe = c, this._tp.refreshUI(), this._update()); } get showLayers2DWireframe() { return !!this._showLayers2DWireframe; } set showLayers2DWireframe(c) { this._showLayers2DWireframe !== c && (this._showLayers2DWireframe = c, this._tp.refreshUI(), this._update()); } get showLayers3DWireframe() { return !!this._showLayers3DWireframe; } set showLayers3DWireframe(c) { this._showLayers3DWireframe !== c && (this._showLayers3DWireframe = c, this._tp.refreshUI(), this._update()); } get speedIndexTiming() { return !!this._speedIndexTiming; } set speedIndexTiming(c) { this._speedIndexTiming !== c && (this._speedIndexTiming = c, this._update()); } get showPadding() { return !!this._showPadding; } set showPadding(c) { this._showPadding !== c && (this._showPadding = c, this._tp.refreshUI(), this._update()); } get showCollisionBoxes() { return !!this._showCollisionBoxes; } set showCollisionBoxes(c) { this._showCollisionBoxes !== c && (this._showCollisionBoxes = c, this._tp.refreshUI(), c ? this.style._generateCollisionBoxes() : this._update()); } get showOverdrawInspector() { return !!this._showOverdrawInspector; } set showOverdrawInspector(c) { this._showOverdrawInspector !== c && (this._showOverdrawInspector = c, this._tp.refreshUI(), this._update()); } get repaint() { return !!this._repaint; } set repaint(c) { this._repaint !== c && (this._repaint = c, this._tp.refreshUI(), this.triggerRepaint()); } get vertices() { return !!this._vertices; } set vertices(c) { this._vertices = c, this._update(); } get showTileAABBs() { return !!this._showTileAABBs; } set showTileAABBs(c) { this._showTileAABBs !== c && (this._showTileAABBs = c, this._tp.refreshUI(), c && this._update()); } _setCacheLimits(c, t) { i.dG(c, t); } get version() { return O; } }, NavigationControl: class { constructor(c = {}) { this.options = i.l({}, tl, c), this._container = be("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._container.addEventListener("contextmenu", (t) => t.preventDefault()), this.options.showZoom && (i.aP(["_setButtonTitle", "_updateZoomButtons"], this), this._zoomInButton = this._createButton("mapboxgl-ctrl-zoom-in", (t) => { this._map && this._map.zoomIn({}, { originalEvent: t }); }), be("span", "mapboxgl-ctrl-icon", this._zoomInButton).setAttribute("aria-hidden", "true"), this._zoomOutButton = this._createButton("mapboxgl-ctrl-zoom-out", (t) => { this._map && this._map.zoomOut({}, { originalEvent: t }); }), be("span", "mapboxgl-ctrl-icon", this._zoomOutButton).setAttribute("aria-hidden", "true")), this.options.showCompass && (i.aP(["_rotateCompassArrow"], this), this._compass = this._createButton("mapboxgl-ctrl-compass", (t) => { const s = this._map; s && (this.options.visualizePitch ? s.resetNorthPitch({}, { originalEvent: t }) : s.resetNorth({}, { originalEvent: t })); }), this._compassIcon = be("span", "mapboxgl-ctrl-icon", this._compass), this._compassIcon.setAttribute("aria-hidden", "true")); } _updateZoomButtons() { const c = this._map; if (!c) return; const t = c.getZoom(), s = t === c.getMaxZoom(), h = t === c.getMinZoom(); this._zoomInButton.disabled = s, this._zoomOutButton.disabled = h, this._zoomInButton.setAttribute("aria-disabled", s.toString()), this._zoomOutButton.setAttribute("aria-disabled", h.toString()); } _rotateCompassArrow() { const c = this._map; if (!c) return; const t = this.options.visualizePitch ? `scale(${1 / Math.pow(Math.cos(c.transform.pitch * (Math.PI / 180)), 0.5)}) rotateX(${c.transform.pitch}deg) rotateZ(${c.transform.angle * (180 / Math.PI)}deg)` : `rotate(${c.transform.angle * (180 / Math.PI)}deg)`; c._requestDomTask(() => { this._compassIcon && (this._compassIcon.style.transform = t); }); } onAdd(c) { return this._map = c, this.options.showZoom && (this._setButtonTitle(this._zoomInButton, "ZoomIn"), this._setButtonTitle(this._zoomOutButton, "ZoomOut"), c.on("zoom", this._updateZoomButtons), this._updateZoomButtons()), this.options.showCompass && (this._setButtonTitle(this._compass, "ResetBearing"), this.options.visualizePitch && c.on("pitch", this._rotateCompassArrow), c.on("rotate", this._rotateCompassArrow), this._rotateCompassArrow(), this._handler = new f_(c, this._compass, this.options.visualizePitch)), this._container; } onRemove() { const c = this._map; c && (this._container.remove(), this.options.showZoom && c.off("zoom", this._updateZoomButtons), this.options.showCompass && (this.options.visualizePitch && c.off("pitch", this._rotateCompassArrow), c.off("rotate", this._rotateCompassArrow), this._handler && this._handler.off(), this._handler = void 0), this._map = void 0); } _createButton(c, t) { const s = be("button", c, this._container); return s.type = "button", s.addEventListener("click", t), s; } _setButtonTitle(c, t) { if (!this._map) return; const s = this._map._getUIString(`NavigationControl.${t}`); c.setAttribute("aria-label", s), c.firstElementChild && c.firstElementChild.setAttribute("title", s); } }, GeolocateControl: class extends i.E { constructor(c = {}) { super(); const t = navigator.geolocation; this.options = i.l({ geolocation: t }, Ta, c), i.aP(["_onSuccess", "_onError", "_onZoom", "_finish", "_setupUI", "_updateCamera", "_updateMarker", "_updateMarkerRotation", "_onDeviceOrientation"], this), this._updateMarkerRotationThrottled = lh(this._updateMarkerRotation, 20), this._numberOfWatches = 0; } onAdd(c) { return this._map = c, this._container = be("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._checkGeolocationSupport(this._setupUI), this._container; } onRemove() { this._geolocationWatchID !== void 0 && (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(c) { const t = (s = !!this.options.geolocation) => { this._supportsGeolocation = s, c(s); }; this._supportsGeolocation !== void 0 ? c(this._supportsGeolocation) : navigator.permissions !== void 0 ? navigator.permissions.query({ name: "geolocation" }).then((s) => t(s.state !== "denied")).catch(() => t()) : t(); } _isOutOfMapMaxBounds(c) { const t = this._map.getMaxBounds(), s = c.coords; return !!t && (s.longitude < t.getWest() || s.longitude > t.getEast() || s.latitude < t.getSouth() || s.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(c) { if (this._map) { if (this._isOutOfMapMaxBounds(c)) return this._setErrorState(), this.fire(new i.z("outofmaxbounds", c)), this._updateMarker(), void this._finish(); if (this.options.trackUserLocation) switch (this._lastKnownPosition = c, 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 && this._watchState !== "OFF" && this._updateMarker(c), this.options.trackUserLocation && this._watchState !== "ACTIVE_LOCK" || this._updateCamera(c), this.options.showUserLocation && this._userLocationDotMarker.removeClassName("mapboxgl-user-location-dot-stale"), this.fire(new i.z("geolocate", c)), this._finish(); } } _updateCamera(c) { const t = new i.bO(c.coords.longitude, c.coords.latitude), s = c.coords.accuracy, h = this._map.getBearing(), _ = i.l({ bearing: h }, this.options.fitBoundsOptions); this._map.fitBounds(t.toBounds(s), _, { geolocateSource: !0 }); } _updateMarker(c) { if (c) { const t = new i.bO(c.coords.longitude, c.coords.latitude); this._accuracyCircleMarker.setLngLat(t).addTo(this._map), this._userLocationDotMarker.setLngLat(t).addTo(this._map), this._accuracy = c.coords.accuracy, this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius(); } else this._userLocationDotMarker.remove(), this._accuracyCircleMarker.remove(); } _updateCircleRadius() { const c = this._map.transform, t = i.bH(1, c._center.lat) * c.worldSize, s = Math.ceil(2 * this._accuracy * t); this._circleElement.style.width = `${s}px`, this._circleElement.style.height = `${s}px`; } _onZoom() { this.options.showUserLocation && this.options.showAccuracyCircle && this._updateCircleRadius(); } _updateMarkerRotation() { this._userLocationDotMarker && typeof this._heading == "number" ? (this._userLocationDotMarker.setRotation(this._heading), this._userLocationDotMarker.addClassName("mapboxgl-user-location-show-heading")) : (this._userLocationDotMarker.removeClassName("mapboxgl-user-location-show-heading"), this._userLocationDotMarker.setRotation(0)); } _onError(c) { if (this._map) { if (this.options.trackUserLocation) if (c.code === 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._geolocateButton.disabled = !0; const t = this._map._getUIString("GeolocateControl.LocationNotAvailable"); this._geolocateButton.setAttribute("aria-label", t), this._geolocateButton.firstElementChild && this._geolocateButton.firstElementChild.setAttribute("title", t), this._geolocationWatchID !== void 0 && this._clearWatch(); } else { if (c.code === 3 && this._noTimeout) return; this._setErrorState(); } this._watchState !== "OFF" && this.options.showUserLocation && this._userLocationDotMarker.addClassName("mapboxgl-user-location-dot-stale"), this.fire(new i.z("error", c)), this._finish(); } } _finish() { this._timeoutId && clearTimeout(this._timeoutId), this._timeoutId = void 0; } _setupUI(c) { if (this._map !== void 0) { if (this._container.addEventListener("contextmenu", (t) => t.preventDefault()), this._geolocateButton = be("button", "mapboxgl-ctrl-geolocate", this._container), be("span", "mapboxgl-ctrl-icon", this._geolocateButton).setAttribute("aria-hidden", "true"), this._geolocateButton.type = "button", c === !1) { i.w("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 t = this._map._getUIString("GeolocateControl.FindMyLocation"); this._geolocateButton.setAttribute("aria-label", t), this._geolocateButton.firstElementChild && this._geolocateButton.firstElementChild.setAttribute("title", t); } this.options.trackUserLocation && (this._geolocateButton.setAttribute("aria-pressed", "false"), this._watchState = "OFF"), this.options.showUserLocation && (this._dotElement = be("div", "mapboxgl-user-location"), this._dotElement.appendChild(be("div", "mapboxgl-user-location-dot")), this._dotElement.appendChild(be("div", "mapboxgl-user-location-heading")), this._userLocationDotMarker = new ta({ element: this._dotElement, rotationAlignment: "map", pitchAlignment: "map" }), this._circleElement = be("div", "mapboxgl-user-location-accuracy-circle"), this._accuracyCircleMarker = new ta({ 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 || this._watchState !== "ACTIVE_LOCK" || t.originalEvent && t.originalEvent.type === "resize" || (this._watchState = "BACKGROUND", this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"), this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"), this.fire(new i.z("trackuserlocationend"))); }); } } _onDeviceOrientation(c) { this._userLocationDotMarker && (c.webkitCompassHeading ? this._heading = c.webkitCompassHeading : c.absolute === !0 && (this._heading = -1 * c.alpha), this._updateMarkerRotationThrottled()); } trigger() { if (!this._setup) return i.w("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 i.z("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 i.z("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 i.z("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 (this._watchState === "OFF" && this._geolocationWatchID !== void 0) this._clearWatch(); else if (this._geolocationWatchID === void 0) { let c; this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"), this._geolocateButton.setAttribute("aria-pressed", "true"), this._numberOfWatches++, this._numberOfWatches > 1 ? (c = { maximumAge: 6e5, timeout: 0 }, this._noTimeout = !0) : (c = this.options.positionOptions, this._noTimeout = !1), this._geolocationWatchID = this.options.geolocation.watchPosition(this._onSuccess, this._onError, c), this.options.showUserHeading && this._addDeviceOrientationListener(); } } else this.options.geolocation.getCurrentPosition(this._onSuccess, this._onError, this.options.positionOptions), this._timeoutId = window.setTimeout(this._finish, 1e4); return !0; } _addDeviceOrientationListener() { const c = () => { "ondeviceorientationabsolute" in window ? window.addEventListener("deviceorientationabsolute", this._onDeviceOrientation) : window.addEventListener("deviceorientation", this._onDeviceOrientation); }; typeof DeviceMotionEvent < "u" && typeof DeviceMotionEvent.requestPermission == "function" ? DeviceOrientationEvent.requestPermission().then((t) => { t === "granted" && c(); }).catch(console.error) : c(); } _clearWatch() { this.options.geolocation.clearWatch(this._geolocationWatchID), window.removeEventListener("deviceorientation", this._onDeviceOrientation), 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: yp, ScaleControl: class { constructor(c = {}) { this.options = i.l({}, fr, c), this._isNumberFormatSupported = function() { try { return new Intl.NumberFormat("en", { style: "unit", unitDisplay: "short", unit: "meter" }), !0; } catch { return !1; } }(), i.aP(["_update", "_setScale", "setUnit"], this); } getDefaultPosition() { return "bottom-left"; } _update() { const c = this.options.maxWidth || 100, t = this._map, s = t._containerHeight / 2, h = t._containerWidth / 2 - c / 2, _ = t.unproject([h, s]), y = t.unproject([h + c, s]), T = _.distanceTo(y); if (this.options.unit === "imperial") { const z = 3.2808 * T; z > 5280 ? this._setScale(c, z / 5280, "mile") : this._setScale(c, z, "foot"); } else this.options.unit === "nautical" ? this._setScale(c, T / 1852, "nautical-mile") : T >= 1e3 ? this._setScale(c, T / 1e3, "kilometer") : this._setScale(c, T, "meter"); } _setScale(c, t, s) { this._map._requestDomTask(() => { const h = function(y) { const T = Math.pow(10, `${Math.floor(y)}`.length - 1); let z = y / T; return z = z >= 10 ? 10 : z >= 5 ? 5 : z >= 3 ? 3 : z >= 2 ? 2 : z >= 1 ? 1 : function(R) { const F = Math.pow(10, Math.ceil(-Math.log(R) / Math.LN10)); return Math.round(R * F) / F; }(z), T * z; }(t), _ = h / t; this._container.innerHTML = this._isNumberFormatSupported && s !== "nautical-mile" ? new Intl.NumberFormat(this._language, { style: "unit", unitDisplay: "short", unit: s }).format(h) : `${h} ${Fr[s]}`, this._container.style.width = c * _ + "px"; }); } onAdd(c) { return this._map = c, this._language = c.getLanguage(), this._container = be("div", "mapboxgl-ctrl mapboxgl-ctrl-scale", c.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(c) { this._language = c, this._update(); } setUnit(c) { this.options.unit = c, this._update(); } }, FullscreenControl: class { constructor(c = {}) { this._fullscreen = !1, c && c.container && (c.container instanceof HTMLElement ? this._container = c.container : i.w("Full screen control 'container' must be a DOM element.")), i.aP(["_onClickFullscreen", "_changeIcon"], this), "onfullscreenchange" in document ? this._fullscreenchange = "fullscreenchange" : "onwebkitfullscreenchange" in document && (this._fullscreenchange = "webkitfullscreenchange"); } onAdd(c) { return this._map = c, this._container || (this._container = this._map.getContainer()), this._controlContainer = be("div", "mapboxgl-ctrl mapboxgl-ctrl-group"), this._checkFullscreenSupport() ? this._setupUI() : (this._controlContainer.style.display = "none", i.w("This device does not support fullscreen mode.")), this._controlContainer; } onRemove() { this._controlContainer.remove(), this._map = null, document.removeEventListener(this._fullscreenchange, this._changeIcon); } _checkFullscreenSupport() { return !(!document.fullscreenEnabled && !document.webkitFullscreenEnabled); } _setupUI() { const c = this._fullscreenButton = be("button", "mapboxgl-ctrl-fullscreen", this._controlContainer); be("span", "mapboxgl-ctrl-icon", c).setAttribute("aria-hidden", "true"), c.type = "button", this._updateTitle(), this._fullscreenButton.addEventListener("click", this._onClickFullscreen), document.addEventListener(this._fullscreenchange, this._changeIcon); } _updateTitle() { const c = this._getTitle(); this._fullscreenButton.setAttribute("aria-label", c), this._fullscreenButton.firstElementChild && this._fullscreenButton.firstElementChild.setAttribute("title", c); } _getTitle() { return this._map._getUIString(this._isFullscreen() ? "FullscreenControl.Exit" : "FullscreenControl.Enter"); } _isFullscreen() { return this._fullscreen; } _changeIcon() { (document.fullscreenElement || 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() ? document.exitFullscreen ? document.exitFullscreen() : document.webkitCancelFullScreen && document.webkitCancelFullScreen() : this._container.requestFullscreen ? this._container.requestFullscreen() : this._container.webkitRequestFullscreen && this._container.webkitRequestFullscreen(); } }, Popup: class extends i.E { constructor(c) { super(), this.options = i.l(Object.create(Os), c), i.aP(["_update", "_onClose", "remove", "_onMouseEvent"], this), this._classList = new Set(c && c.className ? c.className.trim().split(/\s+/) : []); } addTo(c) { return this._map && this.remove(), this._map = c, this.options.closeOnClick && c.on("preclick", this._onClose), this.options.closeOnMove && c.on("move", this._onClose), c.on("remove", this.remove), this._update(), c._addPopup(this), this._focusFirstElement(), this._trackPointer ? (c.on("mousemove", this._onMouseEvent), c.on("mouseup", this._onMouseEvent), c._canvasContainer.classList.add("mapboxgl-track-pointer")) : c.on("move", this._update), this.fire(new i.z("open")), this; } isOpen() { return !!this._map; } remove() { this._content && this._content.remove(), this._container && (this._container.remove(), this._container = void 0); const c = this._map; return c && (c.off("move", this._update), c.off("move", this._onClose), c.off("preclick", this._onClose), c.off("click", this._onClose), c.off("remove", this.remove), c.off("mousemove", this._onMouseEvent), c.off("mouseup", this._onMouseEvent), c.off("drag", this._onMouseEvent), c._canvasContainer && c._canvasContainer.classList.remove("mapboxgl-track-pointer"), c._removePopup(this), this._map = void 0), this.fire(new i.z("close")), this; } getLngLat() { return this._lngLat; } setLngLat(c) { this._lngLat = i.bO.convert(c), this._pos = null, this._trackPointer = !1, this._update(); const t = this._map; return t && (t.on("move", this._update), t.off("mousemove", this._onMouseEvent), t._canvasContainer.classList.remove("mapboxgl-track-pointer")), this; } trackPointer() { this._trackPointer = !0, this._pos = null, this._update(); const c = this._map; return c && (c.off("move", this._update), c.on("mousemove", this._onMouseEvent), c.on("drag", this._onMouseEvent), c._canvasContainer.classList.add("mapboxgl-track-pointer")), this; } getElement() { return this._container; } setText(c) { return this.setDOMContent(document.createTextNode(c)); } setHTML(c) { const t = document.createDocumentFragment(), s = document.createElement("body"); let h; for (s.innerHTML = c; h = s.firstChild, h; ) t.appendChild(h); return this.setDOMContent(t); } getMaxWidth() { return this._container && this._container.style.maxWidth; } setMaxWidth(c) { return this.options.maxWidth = c, this._update(), this; } setDOMContent(c) { let t = this._content; if (t) for (; t.hasChildNodes(); ) t.firstChild && t.removeChild(t.firstChild); else t = this._content = be("div", "mapboxgl-popup-content", this._container || void 0); if (t.appendChild(c), this.options.closeButton) { const s = this._closeButton = be("button", "mapboxgl-popup-close-button", t); s.type = "button", s.setAttribute("aria-label", "Close popup"), s.setAttribute("aria-hidden", "true"), s.innerHTML = "×", s.addEventListener("click", this._onClose); } return this._update(), this._focusFirstElement(), this; } addClassName(c) { return this._classList.add(c), this._updateClassList(), this; } removeClassName(c) { return this._classList.delete(c), this._updateClassList(), this; } setOffset(c) { return this.options.offset = c, this._update(), this; } toggleClassName(c) { let t; return this._classList.delete(c) ? t = !1 : (this._classList.add(c), t = !0), this._updateClassList(), t; } _onMouseEvent(c) { this._update(c.point); } _getAnchor(c) { if (this.options.anchor) return this.options.anchor; const t = this._map, s = this._container, h = this._pos; if (!t || !s || !h) return "bottom"; const _ = s.offsetWidth, y = s.offsetHeight, T = h.x < _ / 2, z = h.x > t.transform.width - _ / 2; if (h.y + c < y) return T ? "top-left" : z ? "top-right" : "top"; if (h.y > t.transform.height - y) { if (T) return "bottom-left"; if (z) return "bottom-right"; } return T ? "left" : z ? "right" : "bottom"; } _updateClassList() { const c = this._container; if (!c) 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"), c.className = t.join(" "); } _update(c) { const t = this._map, s = this._content; if (!t || !this._lngLat && !this._trackPointer || !s) return; let h = this._container; if (h || (h = this._container = be("div", "mapboxgl-popup", t.getContainer()), this._tip = be("div", "mapboxgl-popup-tip", h), h.appendChild(s)), this.options.maxWidth && h.style.maxWidth !== this.options.maxWidth && (h.style.maxWidth = this.options.maxWidth), t.transform.renderWorldCopies && !this._trackPointer && (this._lngLat = xp(this._lngLat, this._pos, t.transform)), !this._trackPointer || c) { const _ = this._pos = this._trackPointer && c instanceof i.P ? c : t.project(this._lngLat), y = Un(this.options.offset), T = this._anchor = this._getAnchor(y.y), z = Un(this.options.offset, T), R = _.add(z).round(); t._requestDomTask(() => { this._container && T && (this._container.style.transform = `${gh[T]} translate(${R.x}px,${R.y}px)`); }); } if (!this._marker && t._showingGlobe()) { const _ = i.dH(t.transform, this._lngLat) ? 0 : 1; this._setOpacity(_); } this._updateClassList(); } _focusFirstElement() { if (!this.options.focusAfterOpen || !this._container) return; const c = this._container.querySelector(vp); c && c.focus(); } _onClose() { this.remove(); } _setOpacity(c) { this._container && (this._container.style.opacity = `${c}`), this._content && (this._content.style.pointerEvents = c ? "auto" : "none"); } }, Marker: ta, Style: hr, LngLat: i.bO, LngLatBounds: i.az, Point: i.P, MercatorCoordinate: i.aa, FreeCameraOptions: Va, Evented: i.E, config: i.e, prewarm: i.dM, clearPrewarmedResources: i.dN, get accessToken() { return i.e.ACCESS_TOKEN; }, set accessToken(c) { i.e.ACCESS_TOKEN = c; }, get baseApiUrl() { return i.e.API_URL; }, set baseApiUrl(c) { i.e.API_URL = c; }, get workerCount() { return i.dO.workerCount; }, set workerCount(c) { i.dO.workerCount = c; }, get maxParallelImageRequests() { return i.e.MAX_PARALLEL_IMAGE_REQUESTS; }, set maxParallelImageRequests(c) { i.e.MAX_PARALLEL_IMAGE_REQUESTS = c; }, clearStorage(c) { i.dP(c); }, get workerUrl() { return i.dQ.workerUrl; }, set workerUrl(c) { i.dQ.workerUrl = c; }, get workerClass() { return i.dQ.workerClass; }, set workerClass(c) { i.dQ.workerClass = c; }, get workerParams() { return i.dQ.workerParams; }, set workerParams(c) { i.dQ.workerParams = c; }, get dracoUrl() { return i.dR(); }, set dracoUrl(c) { i.dS(c); }, get meshoptUrl() { return i.dT(); }, set meshoptUrl(c) { i.dU(c); }, setNow: i.q.setNow, restoreNow: i.q.restoreNow }; }); var E = w; return E; }); })(vw); var LC = vw.exports; const Cc = /* @__PURE__ */ gw(LC); var _o = 63710088e-1, ww = { centimeters: _o * 100, centimetres: _o * 100, degrees: _o / 111325, feet: _o * 3.28084, inches: _o * 39.37, kilometers: _o / 1e3, kilometres: _o / 1e3, meters: _o, metres: _o, miles: _o / 1609.344, millimeters: _o * 1e3, millimetres: _o * 1e3, nauticalmiles: _o / 1852, radians: 1, yards: _o * 1.0936 }; function Hm(m, a, d) { d === void 0 && (d = {}); var g = { type: "Feature" }; return (d.id === 0 || d.id) && (g.id = d.id), d.bbox && (g.bbox = d.bbox), g.properties = a || {}, g.geometry = m, g; } function ry(m, a, d) { if (d === void 0 && (d = {}), !m) throw new Error("coordinates is required"); if (!Array.isArray(m)) throw new Error("coordinates must be an Array"); if (m.length < 2) throw new Error("coordinates must be at least 2 numbers long"); if (!yb(m[0]) || !yb(m[1])) throw new Error("coordinates must contain numbers"); var g = { type: "Point", coordinates: m }; return Hm(g, a, d); } function Af(m, a, d) { if (d === void 0 && (d = {}), m.length < 2) throw new Error("coordinates must be an array of two or more positions"); var g = { type: "LineString", coordinates: m }; return Hm(g, a, d); } function zC(m, a) { a === void 0 && (a = "kilometers"); var d = ww[a]; if (!d) throw new Error(a + " units is invalid"); return m * d; } function DC(m, a) { a === void 0 && (a = "kilometers"); var d = ww[a]; if (!d) throw new Error(a + " units is invalid"); return m / d; } function oy(m) { var a = m % (2 * Math.PI); return a * 180 / Math.PI; } function La(m) { var a = m % 360; return a * Math.PI / 180; } function yb(m) { return !isNaN(m) && m !== null && !Array.isArray(m); } function Tw(m, a, d) { if (m !== null) for (var g, w, b, E, i, O, j, Y = 0, J = 0, ae, ce = m.type, Te = ce === "FeatureCollection", be = ce === "Feature", Ze = Te ? m.features.length : 1, je = 0; je < Ze; je++) { j = Te ? m.features[je].geometry : be ? m.geometry : m, ae = j ? j.type === "GeometryCollection" : !1, i = ae ? j.geometries.length : 1; for (var ot = 0; ot < i; ot++) { var vt = 0, ht = 0; if (E = ae ? j.geometries[ot] : j, E !== null) { O = E.coordinates; var gt = E.type; switch (Y = d && (gt === "Polygon" || gt === "MultiPolygon") ? 1 : 0, gt) { case null: break; case "Point": if (a( O, J, je, vt, ht ) === !1) return !1; J++, vt++; break; case "LineString": case "MultiPoint": for (g = 0; g < O.length; g++) { if (a( O[g], J, je, vt, ht ) === !1) return !1; J++, gt === "MultiPoint" && vt++; } gt === "LineString" && vt++; break; case "Polygon": case "MultiLineString": for (g = 0; g < O.length; g++) { for (w = 0; w < O[g].length - Y; w++) { if (a( O[g][w], J, je, vt, ht ) === !1) return !1; J++; } gt === "MultiLineString" && vt++, gt === "Polygon" && ht++; } gt === "Polygon" && vt++; break; case "MultiPolygon": for (g = 0; g < O.length; g++) { for (ht = 0, w = 0; w < O[g].length; w++) { for (b = 0; b < O[g][w].length - Y; b++) { if (a( O[g][w][b], J, je, vt, ht ) === !1) return !1; J++; } ht++; } vt++; } break; case "GeometryCollection": for (g = 0; g < E.geometries.length; g++) if (Tw(E.geometries[g], a, d) === !1) return !1; break; default: throw new Error("Unknown Geometry Type"); } } } } } function kC(m, a) { var d, g, w, b, E, i, O, j, Y, J, ae = 0, ce = m.type === "FeatureCollection", Te = m.type === "Feature", be = ce ? m.features.length : 1; for (d = 0; d < be; d++) { for (i = ce ? m.features[d].geometry : Te ? m.geometry : m, j = ce ? m.features[d].properties : Te ? m.properties : {}, Y = ce ? m.features[d].bbox : Te ? m.bbox : void 0, J = ce ? m.features[d].id : Te ? m.id : void 0, O = i ? i.type === "GeometryCollection" : !1, E = O ? i.geometries.length : 1, w = 0; w < E; w++) { if (b = O ? i.geometries[w] : i, b === null) { if (a( null, ae, j, Y, J ) === !1) return !1; continue; } switch (b.type) { case "Point": case "LineString": case "MultiPoint": case "Polygon": case "MultiLineString": case "MultiPolygon": { if (a( b, ae, j, Y, J ) === !1) return !1; break; } case "GeometryCollection": { for (g = 0; g < b.geometries.length; g++) if (a( b.geometries[g], ae, j, Y, J ) === !1) return !1; break; } default: throw new Error("Unknown Geometry Type"); } } ae++; } } function RC(m, a) { kC(m, function(d, g, w, b, E) { var i = d === null ? null : d.type; switch (i) { case null: case "Point": case "LineString": case "Polygon": return a( Hm(d, w, { bbox: b, id: E }), g, 0 ) === !1 ? !1 : void 0; } var O; switch (i) { case "MultiPoint": O = "Point"; break; case "MultiLineString": O = "LineString"; break; case "MultiPolygon": O = "Polygon"; break; } for (var j = 0; j < d.coordinates.length; j++) { var Y = d.coordinates[j], J = { type: O, coordinates: Y }; if (a(Hm(J, w), g, j) === !1) return !1; } }); } function OC(m, a) { RC(m, function(d, g, w) { var b = 0; if (d.geometry) { var E = d.geometry.type; if (!(E === "Point" || E === "MultiPoint")) { var i, O = 0, j = 0, Y = 0; if (Tw( d, function(J, ae, ce, Te, be) { if (i === void 0 || g > O || Te > j || be > Y) { i = J, O = g, j = Te, Y = be, b = 0; return; } var Ze = Af( [i, J], d.properties ); if (a( Ze, g, w, be, b ) === !1) return !1; b++, i = J; } ) === !1) return !1; } } }); } function FC(m, a, d) { var g = d, w = !1; return OC( m, function(b, E, i, O, j) { w === !1 && d === void 0 ? g = b : g = a( g, b, E, i, O, j ), w = !0; } ), g; } function jf(m) { if (!m) throw new Error("coord is required"); if (!Array.isArray(m)) { if (m.type === "Feature" && m.geometry !== null && m.geometry.type === "Point") return m.geometry.coordinates; if (m.type === "Point") return m.coordinates; } if (Array.isArray(m) && m.length >= 2 && !Array.isArray(m[0]) && !Array.isArray(m[1])) return m; throw new Error("coord must be GeoJSON Point or an Array of numbers"); } function BC(m) { return m.type === "Feature" ? m.geometry : m; } function Mw(m, a, d) { d === void 0 && (d = {}); var g = jf(m), w = jf(a), b = La(w[1] - g[1]), E = La(w[0] - g[0]), i = La(g[1]), O = La(w[1]), j = Math.pow(Math.sin(b / 2), 2) + Math.pow(Math.sin(E / 2), 2) * Math.cos(i) * Math.cos(O); return zC(2 * Math.atan2(Math.sqrt(j), Math.sqrt(1 - j)), d.units); } function NC(m, a, d, g) { g === void 0 && (g = {}); var w = jf(m), b = La(w[0]), E = La(w[1]), i = La(d), O = DC(a, g.units), j = Math.asin(Math.sin(E) * Math.cos(O) + Math.cos(E) * Math.sin(O) * Math.cos(i)), Y = b + Math.atan2(Math.sin(i) * Math.sin(O) * Math.cos(E), Math.cos(O) - Math.sin(E) * Math.sin(j)), J = oy(Y), ae = oy(j); return ry([J, ae], g.properties); } function Sw(m, a, d) { if (d === void 0 && (d = {}), d.final === !0) return VC(m, a); var g = jf(m), w = jf(a), b = La(g[0]), E = La(w[0]), i = La(g[1]), O = La(w[1]), j = Math.sin(E - b) * Math.cos(O), Y = Math.cos(i) * Math.sin(O) - Math.sin(i) * Math.cos(O) * Math.cos(E - b); return oy(Math.atan2(j, Y)); } function VC(m, a) { var d = Sw(a, m); return d = (d + 180) % 360, d; } function xb(m, a, d) { d === void 0 && (d = {}); for (var g = BC(m), w = g.coordinates, b = 0, E = 0; E < w.length && !(a >= b && E === w.length - 1); E++) if (b >= a) { var i = a - b; if (i) { var O = Sw(w[E], w[E - 1]) - 180, j = NC(w[E], i, O, d); return j; } else return ry(w[E]); } else b += Mw(w[E], w[E + 1], d); return ry(w[w.length - 1]); } function vb(m, a) { return a === void 0 && (a = {}), FC(m, function(d, g) { var w = g.geometry.coordinates; return d + Mw(w[0], w[1], a); }, 0); } class UC { constructor() { this.start = 0, this.animationDuration = 8e4, this.cameraAltitude = 1e3, this.targetRoute = [], this.cameraRoute = [], this.iconDefault = "/wp-content/plugins/wp-gpx-maps/img/map-play-svgrepo-com.svg", this.iconStop = "/wp-content/plugins/wp-gpx-maps/img/stop-svgrepo-com.svg", this.routeDistance = 0, this.cameraRouteDistance = 0, this.isPlaying = !1; } onAdd(a) { return this.map = a, this.container = document.createElement("div"), this.container.className = "mapboxgl-ctrl mapboxgl-ctrl-group mapboxgl-wp-gpx-maps", this.container.innerHTML = `