UNPKG

mobility-toolbox-js

Version:

Toolbox for JavaScript applications in the domains of mobility and logistics.

500 lines (499 loc) 4.1 MB
"use strict"; (() => { var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __esm = (fn, res) => function __init() { return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res; }; var __commonJS = (cb, mod) => function __require() { return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; }; var __export = (target, all3) => { for (var name in all3) __defProp(target, name, { get: all3[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); // node_modules/maplibre-gl/dist/maplibre-gl.js var require_maplibre_gl = __commonJS({ "node_modules/maplibre-gl/dist/maplibre-gl.js"(exports, module) { (function(global2, factory) { typeof exports === "object" && typeof module !== "undefined" ? module.exports = factory() : typeof define === "function" && define.amd ? define(factory) : (global2 = typeof globalThis !== "undefined" ? globalThis : global2 || self, global2.maplibregl = factory()); })(exports, function() { "use strict"; var maplibregl2 = {}; var modules = {}; function define2(moduleName, _dependencies, moduleFactory) { modules[moduleName] = moduleFactory; if (moduleName !== "index") { return; } var workerBundleString = "var sharedModule = {}; (" + modules.shared + ")(sharedModule); (" + modules.worker + ")(sharedModule);"; var sharedModule = {}; modules.shared(sharedModule); modules.index(maplibregl2, sharedModule); if (typeof window !== "undefined") { maplibregl2.setWorkerUrl(window.URL.createObjectURL(new Blob([workerBundleString], { type: "text/javascript" }))); } return maplibregl2; } ; define2("shared", ["exports"], function(t) { "use strict"; function e(t2, e2, r2, n2) { return new (r2 || (r2 = Promise))(function(i2, s2) { function a3(t3) { try { l2(n2.next(t3)); } catch (t4) { s2(t4); } } function o2(t3) { try { l2(n2.throw(t3)); } catch (t4) { s2(t4); } } function l2(t3) { var e3; t3.done ? i2(t3.value) : (e3 = t3.value, e3 instanceof r2 ? e3 : new r2(function(t4) { t4(e3); })).then(a3, o2); } l2((n2 = n2.apply(t2, e2 || [])).next()); }); } function r(t2) { return t2 && t2.__esModule && Object.prototype.hasOwnProperty.call(t2, "default") ? t2.default : t2; } var n, i; function s() { if (i) return n; function t2(t3, e2) { this.x = t3, this.y = e2; } return i = 1, n = t2, t2.prototype = { clone: function() { return new t2(this.x, this.y); }, add: function(t3) { return this.clone()._add(t3); }, sub: function(t3) { return this.clone()._sub(t3); }, multByPoint: function(t3) { return this.clone()._multByPoint(t3); }, divByPoint: function(t3) { return this.clone()._divByPoint(t3); }, mult: function(t3) { return this.clone()._mult(t3); }, div: function(t3) { return this.clone()._div(t3); }, rotate: function(t3) { return this.clone()._rotate(t3); }, rotateAround: function(t3, e2) { return this.clone()._rotateAround(t3, e2); }, matMult: function(t3) { return this.clone()._matMult(t3); }, 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(t3) { return this.x === t3.x && this.y === t3.y; }, dist: function(t3) { return Math.sqrt(this.distSqr(t3)); }, distSqr: function(t3) { var e2 = t3.x - this.x, r2 = t3.y - this.y; return e2 * e2 + r2 * r2; }, angle: function() { return Math.atan2(this.y, this.x); }, angleTo: function(t3) { return Math.atan2(this.y - t3.y, this.x - t3.x); }, angleWith: function(t3) { return this.angleWithSep(t3.x, t3.y); }, angleWithSep: function(t3, e2) { return Math.atan2(this.x * e2 - this.y * t3, this.x * t3 + this.y * e2); }, _matMult: function(t3) { var e2 = t3[2] * this.x + t3[3] * this.y; return this.x = t3[0] * this.x + t3[1] * this.y, this.y = e2, this; }, _add: function(t3) { return this.x += t3.x, this.y += t3.y, this; }, _sub: function(t3) { return this.x -= t3.x, this.y -= t3.y, this; }, _mult: function(t3) { return this.x *= t3, this.y *= t3, this; }, _div: function(t3) { return this.x /= t3, this.y /= t3, this; }, _multByPoint: function(t3) { return this.x *= t3.x, this.y *= t3.y, this; }, _divByPoint: function(t3) { return this.x /= t3.x, this.y /= t3.y, this; }, _unit: function() { return this._div(this.mag()), this; }, _perp: function() { var t3 = this.y; return this.y = this.x, this.x = -t3, this; }, _rotate: function(t3) { var e2 = Math.cos(t3), r2 = Math.sin(t3), n2 = r2 * this.x + e2 * this.y; return this.x = e2 * this.x - r2 * this.y, this.y = n2, this; }, _rotateAround: function(t3, e2) { var r2 = Math.cos(t3), n2 = Math.sin(t3), i2 = e2.y + n2 * (this.x - e2.x) + r2 * (this.y - e2.y); return this.x = e2.x + r2 * (this.x - e2.x) - n2 * (this.y - e2.y), this.y = i2, this; }, _round: function() { return this.x = Math.round(this.x), this.y = Math.round(this.y), this; } }, t2.convert = function(e2) { return e2 instanceof t2 ? e2 : Array.isArray(e2) ? new t2(e2[0], e2[1]) : e2; }, n; } "function" == typeof SuppressedError && SuppressedError; var a, o, l = r(s()), u = function() { if (o) return a; function t2(t3, e2, r2, n2) { this.cx = 3 * t3, this.bx = 3 * (r2 - t3) - this.cx, this.ax = 1 - this.cx - this.bx, this.cy = 3 * e2, this.by = 3 * (n2 - e2) - this.cy, this.ay = 1 - this.cy - this.by, this.p1x = t3, this.p1y = e2, this.p2x = r2, this.p2y = n2; } return o = 1, a = t2, t2.prototype = { sampleCurveX: function(t3) { return ((this.ax * t3 + this.bx) * t3 + this.cx) * t3; }, sampleCurveY: function(t3) { return ((this.ay * t3 + this.by) * t3 + this.cy) * t3; }, sampleCurveDerivativeX: function(t3) { return (3 * this.ax * t3 + 2 * this.bx) * t3 + this.cx; }, solveCurveX: function(t3, e2) { if (void 0 === e2 && (e2 = 1e-6), t3 < 0) return 0; if (t3 > 1) return 1; for (var r2 = t3, n2 = 0; n2 < 8; n2++) { var i2 = this.sampleCurveX(r2) - t3; if (Math.abs(i2) < e2) return r2; var s2 = this.sampleCurveDerivativeX(r2); if (Math.abs(s2) < 1e-6) break; r2 -= i2 / s2; } var a3 = 0, o2 = 1; for (r2 = t3, n2 = 0; n2 < 20 && (i2 = this.sampleCurveX(r2), !(Math.abs(i2 - t3) < e2)); n2++) t3 > i2 ? a3 = r2 : o2 = r2, r2 = 0.5 * (o2 - a3) + a3; return r2; }, solve: function(t3, e2) { return this.sampleCurveY(this.solveCurveX(t3, e2)); } }, a; }(), c = r(u); let h, p; function f() { return null == h && (h = "undefined" != typeof OffscreenCanvas && new OffscreenCanvas(1, 1).getContext("2d") && "function" == typeof createImageBitmap), h; } function d() { if (null == p && (p = false, f())) { const t2 = 5, e2 = new OffscreenCanvas(t2, t2).getContext("2d", { willReadFrequently: true }); if (e2) { for (let r3 = 0; r3 < t2 * t2; r3++) { const n2 = 4 * r3; e2.fillStyle = `rgb(${n2},${n2 + 1},${n2 + 2})`, e2.fillRect(r3 % t2, Math.floor(r3 / t2), 1, 1); } const r2 = e2.getImageData(0, 0, t2, t2).data; for (let e3 = 0; e3 < t2 * t2 * 4; e3++) if (e3 % 4 != 3 && r2[e3] !== e3) { p = true; break; } } } return p || false; } var y = 1e-6, m = "undefined" != typeof Float32Array ? Float32Array : Array; function g() { var t2 = new m(9); return m != Float32Array && (t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[5] = 0, t2[6] = 0, t2[7] = 0), t2[0] = 1, t2[4] = 1, t2[8] = 1, t2; } function x(t2) { return t2[0] = 1, t2[1] = 0, t2[2] = 0, t2[3] = 0, t2[4] = 0, t2[5] = 1, t2[6] = 0, t2[7] = 0, t2[8] = 0, t2[9] = 0, t2[10] = 1, t2[11] = 0, t2[12] = 0, t2[13] = 0, t2[14] = 0, t2[15] = 1, t2; } function v() { var t2 = new m(3); return m != Float32Array && (t2[0] = 0, t2[1] = 0, t2[2] = 0), t2; } function b(t2) { return Math.hypot(t2[0], t2[1], t2[2]); } function w(t2, e2, r2) { var n2 = new m(3); return n2[0] = t2, n2[1] = e2, n2[2] = r2, n2; } function _(t2, e2, r2) { return t2[0] = e2[0] + r2[0], t2[1] = e2[1] + r2[1], t2[2] = e2[2] + r2[2], t2; } function S(t2, e2, r2) { return t2[0] = e2[0] * r2, t2[1] = e2[1] * r2, t2[2] = e2[2] * r2, t2; } function A(t2, e2, r2) { var n2 = e2[0], i2 = e2[1], s2 = e2[2], a3 = r2[0], o2 = r2[1], l2 = r2[2]; return t2[0] = i2 * l2 - s2 * o2, t2[1] = s2 * a3 - n2 * l2, t2[2] = n2 * o2 - i2 * a3, t2; } Math.hypot || (Math.hypot = function() { for (var t2 = 0, e2 = arguments.length; e2--; ) t2 += arguments[e2] * arguments[e2]; return Math.sqrt(t2); }); var k, M = b; function I(t2, e2, r2) { var n2 = e2[0], i2 = e2[1], s2 = e2[2], a3 = e2[3]; return t2[0] = r2[0] * n2 + r2[4] * i2 + r2[8] * s2 + r2[12] * a3, t2[1] = r2[1] * n2 + r2[5] * i2 + r2[9] * s2 + r2[13] * a3, t2[2] = r2[2] * n2 + r2[6] * i2 + r2[10] * s2 + r2[14] * a3, t2[3] = r2[3] * n2 + r2[7] * i2 + r2[11] * s2 + r2[15] * a3, t2; } function z() { var t2 = new m(4); return m != Float32Array && (t2[0] = 0, t2[1] = 0, t2[2] = 0), t2[3] = 1, t2; } function P(t2, e2, r2, n2) { var i2 = 0.5 * Math.PI / 180; e2 *= i2, r2 *= i2, n2 *= i2; var s2 = Math.sin(e2), a3 = Math.cos(e2), o2 = Math.sin(r2), l2 = Math.cos(r2), u2 = Math.sin(n2), c2 = Math.cos(n2); return t2[0] = s2 * l2 * c2 - a3 * o2 * u2, t2[1] = a3 * o2 * c2 + s2 * l2 * u2, t2[2] = a3 * l2 * u2 - s2 * o2 * c2, t2[3] = a3 * l2 * c2 + s2 * o2 * u2, t2; } function C() { var t2 = new m(2); return m != Float32Array && (t2[0] = 0, t2[1] = 0), t2; } function B(t2, e2) { var r2 = new m(2); return r2[0] = t2, r2[1] = e2, r2; } v(), k = new m(4), m != Float32Array && (k[0] = 0, k[1] = 0, k[2] = 0, k[3] = 0), v(), w(1, 0, 0), w(0, 1, 0), z(), z(), g(), C(); const E4 = 8192; function T(t2, e2, r2) { return e2 * (E4 / (t2.tileSize * Math.pow(2, r2 - t2.tileID.overscaledZ))); } function V(t2, e2) { return (t2 % e2 + e2) % e2; } function F(t2, e2, r2) { return t2 * (1 - r2) + e2 * r2; } function L(t2) { if (t2 <= 0) return 0; if (t2 >= 1) return 1; const e2 = t2 * t2, r2 = e2 * t2; return 4 * (t2 < 0.5 ? r2 : 3 * (t2 - e2) + r2 - 0.75); } function $(t2, e2, r2, n2) { const i2 = new c(t2, e2, r2, n2); return (t3) => i2.solve(t3); } const D = $(0.25, 0.1, 0.25, 1); function O(t2, e2, r2) { return Math.min(r2, Math.max(e2, t2)); } function R2(t2, e2, r2) { const n2 = r2 - e2, i2 = ((t2 - e2) % n2 + n2) % n2 + e2; return i2 === e2 ? r2 : i2; } function j(t2, ...e2) { for (const r2 of e2) for (const e3 in r2) t2[e3] = r2[e3]; return t2; } let N = 1; function U(t2, e2, r2) { const n2 = {}; for (const r3 in t2) n2[r3] = e2.call(this, t2[r3], r3, t2); return n2; } function q(t2, e2, r2) { const n2 = {}; for (const r3 in t2) e2.call(this, t2[r3], r3, t2) && (n2[r3] = t2[r3]); return n2; } function G(t2) { return Array.isArray(t2) ? t2.map(G) : "object" == typeof t2 && t2 ? U(t2, G) : t2; } const X = {}; function Z(t2) { X[t2] || ("undefined" != typeof console && console.warn(t2), X[t2] = true); } function Y(t2, e2, r2) { return (r2.y - t2.y) * (e2.x - t2.x) > (e2.y - t2.y) * (r2.x - t2.x); } function H(t2) { return "undefined" != typeof WorkerGlobalScope && void 0 !== t2 && t2 instanceof WorkerGlobalScope; } let K = null; function J(t2) { return "undefined" != typeof ImageBitmap && t2 instanceof ImageBitmap; } const W = ""; function Q(t2, r2, n2, i2, s2) { return e(this, void 0, void 0, function* () { if ("undefined" == typeof VideoFrame) throw new Error("VideoFrame not supported"); const e2 = new VideoFrame(t2, { timestamp: 0 }); try { const a3 = null == e2 ? void 0 : e2.format; if (!a3 || !a3.startsWith("BGR") && !a3.startsWith("RGB")) throw new Error(`Unrecognized format ${a3}`); const o2 = a3.startsWith("BGR"), l2 = new Uint8ClampedArray(i2 * s2 * 4); if (yield e2.copyTo(l2, function(t3, e3, r3, n3, i3) { const s3 = 4 * Math.max(-e3, 0), a4 = (Math.max(0, r3) - r3) * n3 * 4 + s3, o3 = 4 * n3, l3 = Math.max(0, e3), u2 = Math.max(0, r3); return { rect: { x: l3, y: u2, width: Math.min(t3.width, e3 + n3) - l3, height: Math.min(t3.height, r3 + i3) - u2 }, layout: [{ offset: a4, stride: o3 }] }; }(t2, r2, n2, i2, s2)), o2) for (let t3 = 0; t3 < l2.length; t3 += 4) { const e3 = l2[t3]; l2[t3] = l2[t3 + 2], l2[t3 + 2] = e3; } return l2; } finally { e2.close(); } }); } let tt, et; function rt(t2, e2, r2, n2) { return t2.addEventListener(e2, r2, n2), { unsubscribe: () => { t2.removeEventListener(e2, r2, n2); } }; } function nt(t2) { return t2 * Math.PI / 180; } function it(t2) { return t2 / Math.PI * 180; } const st = { touchstart: true, touchmove: true, touchmoveWindow: true, touchend: true, touchcancel: true }, at = { dblclick: true, click: true, mouseover: true, mouseout: true, mousedown: true, mousemove: true, mousemoveWindow: true, mouseup: true, mouseupWindow: true, contextmenu: true, wheel: true }, ot = "AbortError"; function lt() { return new Error(ot); } const ut = { MAX_PARALLEL_IMAGE_REQUESTS: 16, MAX_PARALLEL_IMAGE_REQUESTS_PER_FRAME: 8, MAX_TILE_CACHE_ZOOM_LEVELS: 5, REGISTERED_PROTOCOLS: {}, WORKER_URL: "" }; function ct(t2) { return ut.REGISTERED_PROTOCOLS[t2.substring(0, t2.indexOf("://"))]; } const ht = "global-dispatcher"; class pt extends Error { constructor(t2, e2, r2, n2) { super(`AJAXError: ${e2} (${t2}): ${r2}`), this.status = t2, this.statusText = e2, this.url = r2, this.body = n2; } } const ft = () => H(self) ? self.worker && self.worker.referrer : ("blob:" === window.location.protocol ? window.parent : window).location.href, dt = function(t2, r2) { if (/:\/\//.test(t2.url) && !/^https?:|^file:/.test(t2.url)) { const e2 = ct(t2.url); if (e2) return e2(t2, r2); if (H(self) && self.worker && self.worker.actor) return self.worker.actor.sendAsync({ type: "GR", data: t2, targetMapId: ht }, r2); } if (!(/^file:/.test(n2 = t2.url) || /^file:/.test(ft()) && !/^\w+:/.test(n2))) { if (fetch && Request && AbortController && Object.prototype.hasOwnProperty.call(Request.prototype, "signal")) return function(t3, r3) { return e(this, void 0, void 0, function* () { const e2 = new Request(t3.url, { method: t3.method || "GET", body: t3.body, credentials: t3.credentials, headers: t3.headers, cache: t3.cache, referrer: ft(), signal: r3.signal }); let n3, i2; "json" !== t3.type || e2.headers.has("Accept") || e2.headers.set("Accept", "application/json"); try { n3 = yield fetch(e2); } catch (e3) { throw new pt(0, e3.message, t3.url, new Blob()); } if (!n3.ok) { const e3 = yield n3.blob(); throw new pt(n3.status, n3.statusText, t3.url, e3); } i2 = "arrayBuffer" === t3.type || "image" === t3.type ? n3.arrayBuffer() : "json" === t3.type ? n3.json() : n3.text(); const s2 = yield i2; if (r3.signal.aborted) throw lt(); return { data: s2, cacheControl: n3.headers.get("Cache-Control"), expires: n3.headers.get("Expires") }; }); }(t2, r2); if (H(self) && self.worker && self.worker.actor) return self.worker.actor.sendAsync({ type: "GR", data: t2, mustQueue: true, targetMapId: ht }, r2); } var n2; return function(t3, e2) { return new Promise((r3, n3) => { var i2; const s2 = new XMLHttpRequest(); s2.open(t3.method || "GET", t3.url, true), "arrayBuffer" !== t3.type && "image" !== t3.type || (s2.responseType = "arraybuffer"); for (const e3 in t3.headers) s2.setRequestHeader(e3, t3.headers[e3]); "json" === t3.type && (s2.responseType = "text", (null === (i2 = t3.headers) || void 0 === i2 ? void 0 : i2.Accept) || s2.setRequestHeader("Accept", "application/json")), s2.withCredentials = "include" === t3.credentials, s2.onerror = () => { n3(new Error(s2.statusText)); }, s2.onload = () => { if (!e2.signal.aborted) if ((s2.status >= 200 && s2.status < 300 || 0 === s2.status) && null !== s2.response) { let e3 = s2.response; if ("json" === t3.type) try { e3 = JSON.parse(s2.response); } catch (t4) { return void n3(t4); } r3({ data: e3, cacheControl: s2.getResponseHeader("Cache-Control"), expires: s2.getResponseHeader("Expires") }); } else { const e3 = new Blob([s2.response], { type: s2.getResponseHeader("Content-Type") }); n3(new pt(s2.status, s2.statusText, t3.url, e3)); } }, e2.signal.addEventListener("abort", () => { s2.abort(), n3(lt()); }), s2.send(t3.body); }); }(t2, r2); }; function yt(t2) { if (!t2 || t2.indexOf("://") <= 0 || 0 === t2.indexOf("data:image/") || 0 === t2.indexOf("blob:")) return true; const e2 = new URL(t2), r2 = window.location; return e2.protocol === r2.protocol && e2.host === r2.host; } function mt(t2, e2, r2) { r2[t2] && -1 !== r2[t2].indexOf(e2) || (r2[t2] = r2[t2] || [], r2[t2].push(e2)); } function gt(t2, e2, r2) { if (r2 && r2[t2]) { const n2 = r2[t2].indexOf(e2); -1 !== n2 && r2[t2].splice(n2, 1); } } class xt { constructor(t2, e2 = {}) { j(this, e2), this.type = t2; } } class vt extends xt { constructor(t2, e2 = {}) { super("error", j({ error: t2 }, e2)); } } class bt { on(t2, e2) { return this._listeners = this._listeners || {}, mt(t2, e2, this._listeners), { unsubscribe: () => { this.off(t2, e2); } }; } off(t2, e2) { return gt(t2, e2, this._listeners), gt(t2, e2, this._oneTimeListeners), this; } once(t2, e2) { return e2 ? (this._oneTimeListeners = this._oneTimeListeners || {}, mt(t2, e2, this._oneTimeListeners), this) : new Promise((e3) => this.once(t2, e3)); } fire(t2, e2) { "string" == typeof t2 && (t2 = new xt(t2, e2 || {})); const r2 = t2.type; if (this.listens(r2)) { t2.target = this; const e3 = this._listeners && this._listeners[r2] ? this._listeners[r2].slice() : []; for (const r3 of e3) r3.call(this, t2); const n2 = this._oneTimeListeners && this._oneTimeListeners[r2] ? this._oneTimeListeners[r2].slice() : []; for (const e4 of n2) gt(r2, e4, this._oneTimeListeners), e4.call(this, t2); const i2 = this._eventedParent; i2 && (j(t2, "function" == typeof this._eventedParentData ? this._eventedParentData() : this._eventedParentData), i2.fire(t2)); } else t2 instanceof vt && console.error(t2.error); return this; } listens(t2) { return this._listeners && this._listeners[t2] && this._listeners[t2].length > 0 || this._oneTimeListeners && this._oneTimeListeners[t2] && this._oneTimeListeners[t2].length > 0 || this._eventedParent && this._eventedParent.listens(t2); } setEventedParent(t2, e2) { return this._eventedParent = t2, this._eventedParentData = e2, this; } } var wt = { $version: 8, $root: { version: { required: true, type: "enum", values: [8] }, name: { type: "string" }, metadata: { type: "*" }, center: { type: "array", value: "number" }, centerAltitude: { type: "number" }, zoom: { type: "number" }, bearing: { type: "number", default: 0, period: 360, units: "degrees" }, pitch: { type: "number", default: 0, units: "degrees" }, roll: { type: "number", default: 0, units: "degrees" }, state: { type: "state", default: {} }, light: { type: "light" }, sky: { type: "sky" }, projection: { type: "projection" }, terrain: { type: "terrain" }, sources: { required: true, type: "sources" }, sprite: { type: "sprite" }, glyphs: { type: "string" }, transition: { type: "transition" }, layers: { required: true, type: "array", value: "layer" } }, sources: { "*": { type: "source" } }, source: ["source_vector", "source_raster", "source_raster_dem", "source_geojson", "source_video", "source_image"], source_vector: { type: { required: true, type: "enum", values: { vector: {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, scheme: { type: "enum", values: { xyz: {}, tms: {} }, default: "xyz" }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, attribution: { type: "string" }, promoteId: { type: "promoteId" }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_raster: { type: { required: true, type: "enum", values: { raster: {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, tileSize: { type: "number", default: 512, units: "pixels" }, scheme: { type: "enum", values: { xyz: {}, tms: {} }, default: "xyz" }, attribution: { type: "string" }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_raster_dem: { type: { required: true, type: "enum", values: { "raster-dem": {} } }, url: { type: "string" }, tiles: { type: "array", value: "string" }, bounds: { type: "array", value: "number", length: 4, default: [-180, -85.051129, 180, 85.051129] }, minzoom: { type: "number", default: 0 }, maxzoom: { type: "number", default: 22 }, tileSize: { type: "number", default: 512, units: "pixels" }, attribution: { type: "string" }, encoding: { type: "enum", values: { terrarium: {}, mapbox: {}, custom: {} }, default: "mapbox" }, redFactor: { type: "number", default: 1 }, blueFactor: { type: "number", default: 1 }, greenFactor: { type: "number", default: 1 }, baseShift: { type: "number", default: 0 }, volatile: { type: "boolean", default: false }, "*": { type: "*" } }, source_geojson: { type: { required: true, type: "enum", values: { geojson: {} } }, data: { required: true, type: "*" }, maxzoom: { type: "number", default: 18 }, attribution: { type: "string" }, buffer: { type: "number", default: 128, maximum: 512, minimum: 0 }, filter: { type: "*" }, tolerance: { type: "number", default: 0.375 }, cluster: { type: "boolean", default: false }, clusterRadius: { type: "number", default: 50, minimum: 0 }, clusterMaxZoom: { type: "number" }, clusterMinPoints: { type: "number" }, clusterProperties: { type: "*" }, lineMetrics: { type: "boolean", default: false }, generateId: { type: "boolean", default: false }, promoteId: { type: "promoteId" } }, source_video: { type: { required: true, type: "enum", values: { video: {} } }, urls: { required: true, type: "array", value: "string" }, coordinates: { required: true, type: "array", length: 4, value: { type: "array", length: 2, value: "number" } } }, source_image: { type: { required: true, type: "enum", values: { image: {} } }, url: { required: true, type: "string" }, coordinates: { required: true, type: "array", length: 4, value: { type: "array", length: 2, value: "number" } } }, layer: { id: { type: "string", required: true }, type: { type: "enum", values: { fill: {}, line: {}, symbol: {}, circle: {}, heatmap: {}, "fill-extrusion": {}, raster: {}, hillshade: {}, "color-relief": {}, background: {} }, required: true }, metadata: { type: "*" }, source: { type: "string" }, "source-layer": { type: "string" }, minzoom: { type: "number", minimum: 0, maximum: 24 }, maxzoom: { type: "number", minimum: 0, maximum: 24 }, filter: { type: "filter" }, layout: { type: "layout" }, paint: { type: "paint" } }, layout: ["layout_fill", "layout_line", "layout_circle", "layout_heatmap", "layout_fill-extrusion", "layout_symbol", "layout_raster", "layout_hillshade", "layout_color-relief", "layout_background"], layout_background: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_fill: { "fill-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_circle: { "circle-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_heatmap: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, "layout_fill-extrusion": { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_line: { "line-cap": { type: "enum", values: { butt: {}, round: {}, square: {} }, default: "butt", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-join": { type: "enum", values: { bevel: {}, round: {}, miter: {} }, default: "miter", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "line-miter-limit": { type: "number", default: 2, requires: [{ "line-join": "miter" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-round-limit": { type: "number", default: 1.05, requires: [{ "line-join": "round" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_symbol: { "symbol-placement": { type: "enum", values: { point: {}, line: {}, "line-center": {} }, default: "point", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-spacing": { type: "number", default: 250, minimum: 1, units: "pixels", requires: [{ "symbol-placement": "line" }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-avoid-edges": { type: "boolean", default: false, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "symbol-sort-key": { type: "number", expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "symbol-z-order": { type: "enum", values: { auto: {}, "viewport-y": {}, source: {} }, default: "auto", expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-allow-overlap": { type: "boolean", default: false, requires: ["icon-image", { "!": "icon-overlap" }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-overlap": { type: "enum", values: { never: {}, always: {}, cooperative: {} }, requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-ignore-placement": { type: "boolean", default: false, requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-optional": { type: "boolean", default: false, requires: ["icon-image", "text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-rotation-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-size": { type: "number", default: 1, minimum: 0, units: "factor of the original icon size", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-text-fit": { type: "enum", values: { none: {}, width: {}, height: {}, both: {} }, default: "none", requires: ["icon-image", "text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-text-fit-padding": { type: "array", value: "number", length: 4, default: [0, 0, 0, 0], units: "pixels", requires: ["icon-image", "text-field", { "icon-text-fit": ["both", "width", "height"] }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-image": { type: "resolvedImage", tokens: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-rotate": { type: "number", default: 0, period: 360, units: "degrees", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-padding": { type: "padding", default: [2], units: "pixels", requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-keep-upright": { type: "boolean", default: false, requires: ["icon-image", { "icon-rotation-alignment": "map" }, { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "icon-offset": { type: "array", value: "number", length: 2, default: [0, 0], requires: ["icon-image"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-anchor": { type: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, default: "center", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "icon-pitch-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-pitch-alignment": { type: "enum", values: { map: {}, viewport: {}, auto: {} }, default: "auto", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-rotation-alignment": { type: "enum", values: { map: {}, viewport: {}, "viewport-glyph": {}, auto: {} }, default: "auto", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-field": { type: "formatted", default: "", tokens: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-font": { type: "array", value: "string", default: ["Open Sans Regular", "Arial Unicode MS Regular"], requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-size": { type: "number", default: 16, minimum: 0, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-max-width": { type: "number", default: 10, minimum: 0, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-line-height": { type: "number", default: 1.2, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-letter-spacing": { type: "number", default: 0, units: "ems", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-justify": { type: "enum", values: { auto: {}, left: {}, center: {}, right: {} }, default: "center", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-radial-offset": { type: "number", units: "ems", default: 0, requires: ["text-field"], "property-type": "data-driven", expression: { interpolated: true, parameters: ["zoom", "feature"] } }, "text-variable-anchor": { type: "array", value: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-variable-anchor-offset": { type: "variableAnchorOffsetCollection", requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-anchor": { type: "enum", values: { center: {}, left: {}, right: {}, top: {}, bottom: {}, "top-left": {}, "top-right": {}, "bottom-left": {}, "bottom-right": {} }, default: "center", requires: ["text-field", { "!": "text-variable-anchor" }], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-max-angle": { type: "number", default: 45, units: "degrees", requires: ["text-field", { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-writing-mode": { type: "array", value: "enum", values: { horizontal: {}, vertical: {} }, requires: ["text-field", { "symbol-placement": ["point"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-rotate": { type: "number", default: 0, period: 360, units: "degrees", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-padding": { type: "number", default: 2, minimum: 0, units: "pixels", requires: ["text-field"], expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-keep-upright": { type: "boolean", default: true, requires: ["text-field", { "text-rotation-alignment": "map" }, { "symbol-placement": ["line", "line-center"] }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-transform": { type: "enum", values: { none: {}, uppercase: {}, lowercase: {} }, default: "none", requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-offset": { type: "array", value: "number", units: "ems", length: 2, default: [0, 0], requires: ["text-field", { "!": "text-radial-offset" }], expression: { interpolated: true, parameters: ["zoom", "feature"] }, "property-type": "data-driven" }, "text-allow-overlap": { type: "boolean", default: false, requires: ["text-field", { "!": "text-overlap" }], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-overlap": { type: "enum", values: { never: {}, always: {}, cooperative: {} }, requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-ignore-placement": { type: "boolean", default: false, requires: ["text-field"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "text-optional": { type: "boolean", default: false, requires: ["text-field", "icon-image"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_raster: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, layout_hillshade: { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, "layout_color-relief": { visibility: { type: "enum", values: { visible: {}, none: {} }, default: "visible", "property-type": "constant" } }, filter: { type: "array", value: "*" }, filter_operator: { type: "enum", values: { "==": {}, "!=": {}, ">": {}, ">=": {}, "<": {}, "<=": {}, in: {}, "!in": {}, all: {}, any: {}, none: {}, has: {}, "!has": {} } }, geometry_type: { type: "enum", values: { Point: {}, LineString: {}, Polygon: {} } }, function: { expression: { type: "expression" }, stops: { type: "array", value: "function_stop" }, base: { type: "number", default: 1, minimum: 0 }, property: { type: "string", default: "$zoom" }, type: { type: "enum", values: { identity: {}, exponential: {}, interval: {}, categorical: {} }, default: "exponential" }, colorSpace: { type: "enum", values: { rgb: {}, lab: {}, hcl: {} }, default: "rgb" }, default: { type: "*", required: false } }, function_stop: { type: "array", minimum: 0, maximum: 24, value: ["number", "color"], length: 2 }, expression: { type: "array", value: "*", minimum: 1 }, light: { anchor: { type: "enum", default: "viewport", values: { map: {}, viewport: {} }, "property-type": "data-constant", transition: false, expression: { interpolated: false, parameters: ["zoom"] } }, position: { type: "array", default: [1.15, 210, 30], length: 3, value: "number", "property-type": "data-constant", transition: true, expression: { interpolated: true, parameters: ["zoom"] } }, color: { type: "color", "property-type": "data-constant", default: "#ffffff", expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, intensity: { type: "number", "property-type": "data-constant", default: 0.5, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true } }, sky: { "sky-color": { type: "color", "property-type": "data-constant", default: "#88C6FC", expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "horizon-color": { type: "color", "property-type": "data-constant", default: "#ffffff", expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "fog-color": { type: "color", "property-type": "data-constant", default: "#ffffff", expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "fog-ground-blend": { type: "number", "property-type": "data-constant", default: 0.5, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "horizon-fog-blend": { type: "number", "property-type": "data-constant", default: 0.8, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "sky-horizon-blend": { type: "number", "property-type": "data-constant", default: 0.8, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true }, "atmosphere-blend": { type: "number", "property-type": "data-constant", default: 0.8, minimum: 0, maximum: 1, expression: { interpolated: true, parameters: ["zoom"] }, transition: true } }, terrain: { source: { type: "string", required: true }, exaggeration: { type: "number", minimum: 0, default: 1 } }, projection: { type: { type: "projectionDefinition", default: "mercator", "property-type": "data-constant", transition: false, expression: { interpolated: true, parameters: ["zoom"] } } }, paint: ["paint_fill", "paint_line", "paint_circle", "paint_heatmap", "paint_fill-extrusion", "paint_symbol", "paint_raster", "paint_hillshade", "paint_color-relief", "paint_background"], paint_fill: { "fill-antialias": { type: "boolean", default: true, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "fill-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-outline-color": { type: "color", transition: true, requires: [{ "!": "fill-pattern" }, { "fill-antialias": true }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["fill-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "cross-faded-data-driven" } }, "paint_fill-extrusion": { "fill-extrusion-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "fill-extrusion-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["fill-extrusion-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "fill-extrusion-pattern": { type: "resolvedImage", transition: true, expression: { interpolated: false, parameters: ["zoom", "feature"] }, "property-type": "cross-faded-data-driven" }, "fill-extrusion-height": { type: "number", default: 0, minimum: 0, units: "meters", transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-base": { type: "number", default: 0, minimum: 0, units: "meters", transition: true, requires: ["fill-extrusion-height"], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "fill-extrusion-vertical-gradient": { type: "boolean", default: true, transition: false, expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" } }, paint_line: { "line-opacity": { type: "number", default: 1, minimum: 0, maximum: 1, transition: true, expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-color": { type: "color", default: "#000000", transition: true, requires: [{ "!": "line-pattern" }], expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-translate": { type: "array", value: "number", length: 2, default: [0, 0], transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-translate-anchor": { type: "enum", values: { map: {}, viewport: {} }, default: "map", requires: ["line-translate"], expression: { interpolated: false, parameters: ["zoom"] }, "property-type": "data-constant" }, "line-width": { type: "number", default: 1, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-gap-width": { type: "number", default: 0, minimum: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-offset": { type: "number", default: 0, transition: true, units: "pixels", expression: { interpolated: true, parameters: ["zoom", "feature", "feature-state"] }, "property-type": "data-driven" }, "line-blur": { type: "number", default: 0, minimum: 0, transitio