@maptalks/vt 0.72.1 → 0.72.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * @maptalks/vt v0.72.1
2
+ * @maptalks/vt v0.72.5
3
3
  * LICENSE : undefined
4
4
  * (c) 2016-2022 maptalks.org
5
5
  */
@@ -25,18 +25,18 @@ import { createFilter as z } from "@maptalks/feature-filter";
25
25
 
26
26
  import j from "@maptalks/vt-plugin";
27
27
 
28
- const D = 'function(t){function e(t,e){for(let i=0;i<t.stops.length;i++)if(e===t.stops[i][0])return t.stops[i][1];return t.default}function i(t,e){for(var i=0;i<t.stops.length&&!(e<t.stops[i][0]);i++);return t.stops[Math.max(i-1,0)][1]}function n(t,e){for(var i=void 0!==t.base?t.base:1,n=0;!(n>=t.stops.length||e<=t.stops[n][0]);)n++;return 0===n?t.stops[n][1]:n===t.stops.length?t.stops[n-1][1]:function t(e,i,n,r,s,a){return"function"==typeof s?function(){var o=s.apply(void 0,arguments),l=a.apply(void 0,arguments);return t(e,i,n,r,o,l)}:s.length?function(t,e,i,n,r,s){var a=[];for(let l=0;l<r.length;l++)a[l]=o(t,e,i,n,r[l],s[l]);return a}(e,i,n,r,s,a):o(e,i,n,r,s,a)}(e,i,t.stops[n-1][0],t.stops[n][0],t.stops[n-1][1],t.stops[n][1])}function r(t,e){return function(t,e,i){return void 0!==t?t:void 0!==e?e:void 0!==i?i:null}(e,t.default)}function o(t,e,i,n,r,o){var s,a=n-i,l=t-i;return r*(1-(s=1===e?l/a:(Math.pow(e,l)-1)/(Math.pow(e,a)-1)))+o*s}function s(t){return t&&"object"==typeof t&&(t.stops||t.property&&"identity"===t.type)}function a(t){return c(t,"exponential")}function l(t){return c(t,"interval")}function u(t,e){if(!t)return null;var i=!1;if(Array.isArray(t)){var n,r=[];for(let o=0;o<t.length;o++)(n=u(t[o],e))?(r.push(n),i=!0):r.push(t[o]);return i?r:t}var o,l={__fn_types_loaded:!0},c=[];for(o in t)t.hasOwnProperty(o)&&c.push(o);const h=function(t){Object.defineProperty(l,t,{get:function(){return this["__fn_"+t]||(this["__fn_"+t]=a(this["_"+t])),this["__fn_"+t].apply(this,e())},set:function(e){this["_"+t]=e},configurable:!0,enumerable:!0})};for(let e=0,n=c.length;e<n;e++)s(t[o=c[e]])?(i=!0,l["_"+o]=t[o],h(o)):l[o]=t[o];return i?l:t}function c(t,o){if(!s(t))return function(){return t};let a=!0,l=!0;const u=(t=JSON.parse(JSON.stringify(t))).stops;if(u)for(let t=0;t<u.length;t++)if(s(u[t][1])){const e=c(u[t][1],o);a=a&&e.isZoomConstant,l=l&&e.isFeatureConstant,u[t]=[u[t][0],e]}const h=function t(o,a){var l,u,c;if(s(o)){var h,d=o.stops&&"object"==typeof o.stops[0][0],f=d||void 0!==o.property,p=d||!f,m=o.type||a||"exponential";if("exponential"===m)h=n;else if("interval"===m)h=i;else if("categorical"===m)h=e;else{if("identity"!==m)throw new Error(\'Unknown function type "\'+m+\'"\');h=r}if(d){var y={},g=[];for(let t=0;t<o.stops.length;t++){var b=o.stops[t];void 0===y[b[0].zoom]&&(y[b[0].zoom]={zoom:b[0].zoom,type:o.type,property:o.property,default:o.default,stops:[]}),y[b[0].zoom].stops.push([b[0].value,b[1]])}for(let e in y)g.push([y[e].zoom,t(y[e])]);l=function(t,e){const i=n({stops:g,base:o.base},t)(t,e);return"function"==typeof i?i(t,e):i},u=!1,c=!1}else p?(l=function(t){const e=h(o,t);return"function"==typeof e?e(t):e},u=!0,c=!1):(l=function(t,e){const i=h(o,e?e[o.property]:null);return"function"==typeof i?i(t,e):i},u=!1,c=!0)}else l=function(){return o},u=!0,c=!0;return l.isZoomConstant=c,l.isFeatureConstant=u,l}(t,o);return h.isZoomConstant=a&&h.isZoomConstant,h.isFeatureConstant=l&&h.isFeatureConstant,h}let h=0;const d="function"==typeof Object.assign;function f(t,...e){if(d)return Object.assign(t,...e),t;for(let i=0;i<e.length;i++){const n=e[i];for(const e in n)t[e]=n[e]}return t}function p(t){return!b(t)&&("string"==typeof t||null!==t.constructor&&t.constructor===String)}function m(t){return"number"==typeof t&&!isNaN(t)}function y(t){return!b(t)&&("function"==typeof t||null!==t.constructor&&t.constructor===Function)}function g(t){return!Array.isArray(t)&&"object"==typeof t&&!!t}function b(t){return null==t}function v(t){for(let e=1;e<arguments.length;e++){const i=arguments[e];if(i)for(let e=0,n=i.length;e<n;e++)t.push(i[e])}return t.length}function w(t){return t<65536?Uint16Array:Uint32Array}function x(t){return t<256?Uint8Array:t<65536?Uint16Array:Uint32Array}function k(t){return(t=Math.abs(t))<128?Int8Array:t<32768?Int16Array:Float32Array}function M(t){return s(t)&&t.property}const j="function"==typeof fetch&&"function"==typeof AbortController,A={jsonp:function(t,e){const i="_maptalks_jsonp_"+h++;t.match(/\\?/)?t+="&callback="+i:t+="?callback="+i;let n=document.createElement("script");return n.type="text/javascript",n.src=t,window[i]=function(t){e(null,t),document.getElementsByTagName("head")[0].removeChild(n),n=null,delete window[i]},document.getElementsByTagName("head")[0].appendChild(n),this},get:function(t,e,i){if(y(e)){const t=i;i=e,e=t}(e=e||{}).method&&(e.method=e.method.toUpperCase());const n="POST"===e.method;if(j){const r=new AbortController,o={signal:r.signal,method:e.method||"GET",referrerPolicy:"origin"};return n&&(b(e.body)||(o.body=JSON.stringify(e.body))),b(e.headers)||(o.headers=e.headers),b(e.credentials)||(o.credentials=e.credentials),fetch(t,o).then(n=>{const r=this.t(n,e.returnJSON,e.responseType);r.message?(r.url=t,i(r)):r.then(t=>{"arraybuffer"===e.responseType?i(null,{data:t,cacheControl:n.headers.get("Cache-Control"),expires:n.headers.get("Expires"),contentType:n.headers.get("Content-Type")}):i(null,t)}).catch(t=>{t.code&&t.code===DOMException.ABORT_ERR||(console.error(t),i(t))})}).catch(t=>{t.code&&t.code===DOMException.ABORT_ERR||(console.error(t),i(t))}),r}{const r=A.o(i);if(r.open(e.method||"GET",t,!0),e){for(const t in e.headers)r.setRequestHeader(t,e.headers[t]);r.withCredentials="include"===e.credentials,e.responseType&&(r.responseType=e.responseType)}return r.send(n?e.body:null),r}},t:(t,e,i)=>200!==t.status?{status:t.status,statusText:t.statusText,message:`incorrect http request with status code(${t.status}): ${t.statusText}`}:"arraybuffer"===i?t.arrayBuffer():e?t.json():t.text(),s:function(t,e){return function(){if(4===t.readyState)if(200===t.status)if("arraybuffer"===t.responseType){0===t.response.byteLength?e({status:200,statusText:t.statusText,message:"http status 200 returned without content."}):e(null,{data:t.response,cacheControl:t.getResponseHeader("Cache-Control"),expires:t.getResponseHeader("Expires"),contentType:t.getResponseHeader("Content-Type")})}else e(null,t.responseText);else e({status:t.status,statusText:t.statusText,message:`incorrect http request with status code(${t.status}): ${t.statusText}`})}},o:function(t){let e;try{e=new XMLHttpRequest}catch(t){try{e=new ActiveXObject("Msxml2.XMLHTTP")}catch(t){try{e=new ActiveXObject("Microsoft.XMLHTTP")}catch(t){}}}return e.onreadystatechange=A.s(e,t),e},getArrayBuffer(t,e,i){if(y(e)){const t=i;i=e,e=t}return e||(e={}),e.responseType="arraybuffer",A.get(t,e,i)}};function F(t,e,i,n,r,o){let s=r-i,a=o-n;if(0!==s||0!==a){const l=((t-i)*s+(e-n)*a)/(s*s+a*a);l>1?(i=r,n=o):l>0&&(i+=s*l,n+=a*l)}return s=t-i,a=e-n,s*s+a*a}function T(t,e,i,n,r,o){const s={id:null==t?null:t,type:e,geometry:i,tags:n,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0};r&&(s.layer=r);return function(t,e){const i=t.geometry,n=t.type;if("Point"===n||"MultiPoint"===n||"LineString"===n)z(t,i,e);else if("Polygon"===n)z(t,i[0],e);else if("MultiLineString"===n)for(const n of i)z(t,n,e);else if("MultiPolygon"===n)for(const n of i)z(t,n[0],e)}(s,o?4:3),s}function z(t,e,i){for(let n=0;n<e.length;n+=i)t.minX=Math.min(t.minX,e[n]),t.minY=Math.min(t.minY,e[n+1]),t.maxX=Math.max(t.maxX,e[n]),t.maxY=Math.max(t.maxY,e[n+1])}function S(t,e,i,n){if(n.layer=e,"FeatureCollection"===i.type)for(let e=0;e<i.features.length;e++)_(t,i.features[e],n,e);else"Feature"===i.type?_(t,i,n):_(t,{geometry:i},n)}function _(t,e,i,n){if(!e.geometry)return;const r=e.geometry.coordinates,o=e.geometry.type,s=Math.pow(i.tolerance/((1<<i.maxZoom)*i.extent),2);let a=[],l=e.id;if(i.promoteId?l=e.properties[i.promoteId]:i.generateId&&(l=n||0),"Point"===o)P(r,a,i.hasAltitude);else if("MultiPoint"===o)for(const t of r)P(t,a,i.hasAltitude);else if("LineString"===o)I(r,a,s,!1,i.hasAltitude);else if("MultiLineString"===o){if(i.lineMetrics){for(const n of r)a=[],I(n,a,s,!1,i.hasAltitude),t.push(T(l,"LineString",a,e.properties,i.layer,i.hasAltitude));return}O(r,a,s,!1,i.hasAltitude)}else if("Polygon"===o)O(r,a,s,!0,i.hasAltitude);else{if("MultiPolygon"!==o){if("GeometryCollection"===o){for(const r of e.geometry.geometries)_(t,{id:l,geometry:r,properties:e.properties},i,n);return}throw new Error("Input data is not a valid GeoJSON object.")}for(const t of r){const e=[];O(t,e,s,!0,i.hasAltitude),a.push(e)}}t.push(T(l,o,a,e.properties,i.layer,i.hasAltitude))}function P(t,e,i){e.push(E(t[0]),q(t[1]),0),i&&(t.length>2?e.push(t[2]):e.push(0))}function I(t,e,i,n,r){let o,s,a=0;for(let i=0;i<t.length;i++){const l=E(t[i][0]),u=q(t[i][1]);e.push(l,u,0),r&&(t[i].length>2?e.push(t[i][2]):e.push(0)),i>0&&(a+=n?(o*u-l*s)/2:Math.sqrt(Math.pow(l-o,2)+Math.pow(u-s,2))),o=l,s=u}const l=r?4:3,u=e.length-l;e[2]=1,function t(e,i,n,r,o=3){let s=r;const a=n-i>>1;let l,u=n-i;const c=e[i],h=e[i+1],d=e[n],f=e[n+1];for(let t=i+o;t<n;t+=o){const i=F(e[t],e[t+1],c,h,d,f);if(i>s)l=t,s=i;else if(i===s){const e=Math.abs(t-a);e<u&&(l=t,u=e)}}s>r&&(l-i>o&&t(e,i,l,r,o),e[l+2]=s,n-l>o&&t(e,l,n,r,o))}(e,0,u,i,l),e[u+2]=1,e.size=Math.abs(a),e.start=0,e.end=e.size}function O(t,e,i,n,r){for(let o=0;o<t.length;o++){const s=[];I(t[o],s,i,n,r),e.push(s)}}function E(t){return t/360+.5}function q(t){const e=Math.sin(t*Math.PI/180),i=.5-.25*Math.log((1+e)/(1-e))/Math.PI;return i<0?0:i>1?1:i}function R(t,e,i,n,r,o,s,a){if(n/=e,o>=(i/=e)&&s<n)return t;if(s<i||o>=n)return null;const l=[];for(const e of t){const t=e.geometry;let o=e.type;const s=0===r?e.minX:e.minY,u=0===r?e.maxX:e.maxY;if(s>=i&&u<n){l.push(e);continue}if(u<i||s>=n)continue;let c=[];if("Point"===o||"MultiPoint"===o)C(t,c,i,n,r,a.hasAltitude);else if("LineString"===o)N(t,c,i,n,r,!1,a.lineMetrics,a.hasAltitude);else if("MultiLineString"===o)D(t,c,i,n,r,!1,a.hasAltitude);else if("Polygon"===o)D(t,c,i,n,r,!0,a.hasAltitude);else if("MultiPolygon"===o)for(const e of t){const t=[];D(e,t,i,n,r,!0,a.hasAltitude),t.length&&c.push(t)}if(c.length){if(a.lineMetrics&&"LineString"===o){for(const t of c)l.push(T(e.id,o,t,e.tags,e.layer,a.hasAltitude));continue}"LineString"!==o&&"MultiLineString"!==o||(1===c.length?(o="LineString",c=c[0]):o="MultiLineString"),"Point"!==o&&"MultiPoint"!==o||(o=3===c.length?"Point":"MultiPoint"),l.push(T(e.id,o,c,e.tags,e.layer,a.hasAltitude))}}return l.length?l:null}function C(t,e,i,n,r,o){const s=o?4:3;for(let a=0;a<t.length;a+=s){const s=t[a+r];s>=i&&s<=n&&(U(e,t[a],t[a+1],t[a+2]),o&&e.push(t[a+3]))}}function N(t,e,i,n,r,o,s,a){let l=L(t);const u=0===r?$:W;let c,h,d=t.start;const f=a?4:3;for(let p=0;p<t.length-f;p+=f){const m=t[p],y=t[p+1],g=t[p+2],b=t[p+f],v=t[p+f+1];let w,x;a&&(w=t[p+3],x=t[p+f+3]);const k=0===r?m:y,M=0===r?b:v;let j=!1;s&&(c=Math.sqrt(Math.pow(m-b,2)+Math.pow(y-v,2))),k<i?M>i&&(h=u(l,m,y,b,v,i),a&&l.push(J(w,x,h)),s&&(l.start=d+c*h)):k>n?M<n&&(h=u(l,m,y,b,v,n),a&&l.push(J(w,x,h)),s&&(l.start=d+c*h)):(U(l,m,y,g),a&&l.push(w)),M<i&&k>=i&&(h=u(l,m,y,b,v,i),a&&l.push(J(w,x,h)),j=!0),M>n&&k<=n&&(h=u(l,m,y,b,v,n),a&&l.push(J(w,x,h)),j=!0),!o&&j&&(s&&(l.end=d+c*h),e.push(l),l=L(t)),s&&(d+=c)}let p=t.length-f;const m=t[p],y=t[p+1],g=t[p+2],b=0===r?m:y;if(b>=i&&b<=n&&U(l,m,y,g),b>=i&&b<=n&&a){const e=t[p+3];l.push(e)}p=l.length-f,o&&p>=f&&(l[p]!==l[0]||l[p+1]!==l[1])&&(U(l,l[0],l[1],l[2]),a&&l.push(l[3])),l.length&&e.push(l)}function L(t){const e=[];return e.size=t.size,e.start=t.start,e.end=t.end,e}function D(t,e,i,n,r,o,s){for(const a of t)N(a,e,i,n,r,o,!1,s)}function U(t,e,i,n){t.push(e,i,n)}function $(t,e,i,n,r,o){const s=(o-e)/(n-e);return U(t,o,i+(r-i)*s,1),s}function W(t,e,i,n,r,o){const s=(o-i)/(r-i);return U(t,e+(n-e)*s,o,1),s}function J(t,e,i){return t+(e-t)*i}function H(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=t[r],s=o.type;let a;if("Point"===s||"MultiPoint"===s||"LineString"===s)a=G(o.geometry,e,i);else if("MultiLineString"===s||"Polygon"===s){a=[];for(const t of o.geometry)a.push(G(t,e,i))}else if("MultiPolygon"===s){a=[];for(const t of o.geometry){const n=[];for(const r of t)n.push(G(r,e,i));a.push(n)}}n.push(T(o.id,s,a,o.tags,o.layer,i))}return n}function G(t,e,i){const n=[];n.size=t.size,void 0!==t.start&&(n.start=t.start,n.end=t.end);const r=i?4:3;for(let o=0;o<t.length;o+=r)n.push(t[o]+e,t[o+1],t[o+2]),i&&n.push(t[o+3]);return n}function V(t,e,i){if(t.transformed)return t;const n=1<<t.z,r=t.x,o=t.y,s=i?3:2;for(const a of t.features){const t=a.geometry,l=a.type;if(a.geometry=[],1===l)for(let l=0;l<t.length;l+=s)a.geometry.push(B(t[l],t[l+1],e,n,r,o)),i&&a.geometry[a.geometry.length-1].push(t[l+2]);else for(let l=0;l<t.length;l++){const u=[];for(let a=0;a<t[l].length;a+=s)u.push(B(t[l][a],t[l][a+1],e,n,r,o)),i&&u[u.length-1].push(t[l][a+2]);a.geometry.push(u)}}return t.transformed=!0,t}function B(t,e,i,n,r,o){return[Math.round(i*(t*n-r)),Math.round(i*(e*n-o))]}function X(t,e,i,n,r){const o=e===r.maxZoom?0:r.tolerance/((1<<e)*r.extent),s={features:[],numPoints:0,numSimplified:0,numFeatures:t.length,source:null,x:i,y:n,z:e,transformed:!1,minX:2,minY:1,maxX:-1,maxY:0};for(const e of t)Z(s,e,o,r);return s}function Z(t,e,i,n){const r=e.geometry,o=e.type,s=[],a=n.hasAltitude?4:3;if(t.minX=Math.min(t.minX,e.minX),t.minY=Math.min(t.minY,e.minY),t.maxX=Math.max(t.maxX,e.maxX),t.maxY=Math.max(t.maxY,e.maxY),"Point"===o||"MultiPoint"===o)for(let e=0;e<r.length;e+=a)s.push(r[e],r[e+1]),n.hasAltitude&&s.push(r[e+3]),t.numPoints++,t.numSimplified++;else if("LineString"===o)Y(s,r,t,i,!1,!1,n);else if("MultiLineString"===o||"Polygon"===o)for(let e=0;e<r.length;e++)Y(s,r[e],t,i,"Polygon"===o,0===e,n);else if("MultiPolygon"===o)for(let e=0;e<r.length;e++){const o=r[e];for(let e=0;e<o.length;e++)Y(s,o[e],t,i,!0,0===e,n)}if(s.length){let i=e.tags||null;if("LineString"===o&&n.lineMetrics){i={};for(const t in e.tags)i[t]=e.tags[t];i.mapbox_clip_start=r.start/r.size,i.mapbox_clip_end=r.end/r.size}const a={geometry:s,type:"Polygon"===o||"MultiPolygon"===o?3:"LineString"===o||"MultiLineString"===o?2:1,tags:i};e.layer&&(a.layer=e.layer),null!==e.id&&(a.id=e.id),t.features.push(a)}}function Y(t,e,i,n,r,o,s){const a=n*n,{hasAltitude:l,disableFilter:u}=s,c=l?4:3;if(!u&&n>0&&e.size<(r?a:n))return void(i.numPoints+=e.length/c);const h=[];for(let t=0;t<e.length;t+=c)(0===n||e[t+2]>a)&&(i.numSimplified++,h.push(e[t],e[t+1]),l&&h.push(e[t+3])),i.numPoints++;r&&function(t,e,i){const n=i?3:2;let r=0;for(let e=0,i=t.length,o=i-n;e<i;o=e,e+=n)r+=(t[e]-t[o])*(t[e+1]+t[o+1]);if(r>0===e){const e=n,r=n-1,o=n-2;for(let s=0,a=t.length;s<a/2;s+=n){const n=t[s],l=t[s+1];let u;i&&(u=t[s+2]),t[s]=t[a-e-s],t[s+1]=t[a-r-s],i&&(t[s+2]=t[a-o-s]),t[a-e-s]=n,t[a-r-s]=l,i&&(t[a-o-s]=u)}}}(h,o,l),t.push(h)}A.getJSON=function(t,e,i){if(y(e)){const t=i;i=e,e=t}const n=function(t,e){const n="string"==typeof e?JSON.parse(e):e||null;i(t,n)};return e&&e.jsonp?A.jsonp(t,n):((e=e||{}).returnJSON=!0,A.get(t,e,n))};const K={maxZoom:14,indexMaxZoom:5,indexMaxPoints:1e5,tolerance:3,extent:4096,buffer:64,lineMetrics:!1,promoteId:null,generateId:!1,hasAltitude:!1,disableFilter:!1,debug:0};class Q{constructor(t,e){const i=(e=this.options=function(t,e){for(const i in e)t[i]=e[i];return t}(Object.create(K),e)).debug;if(i&&console.time("preprocess data"),e.maxZoom<0||e.maxZoom>24)throw new Error("maxZoom should be in the 0-24 range");if(e.promoteId&&e.generateId)throw new Error("promoteId and generateId cannot be used together.");let n=function(t,e){const i=[];if(Array.isArray(t)){for(let n=0;n<t.length;n++)S(i,t[n].layer,t[n].data,e);return i}if("FeatureCollection"===t.type)for(let n=0;n<t.features.length;n++)_(i,t.features[n],e,n);else"Feature"===t.type?_(i,t,e):_(i,{geometry:t},e);return i}(t,e);this.tiles={},this.tileCoords=[],i&&(console.timeEnd("preprocess data"),console.log("index: maxZoom: %d, maxPoints: %d",e.indexMaxZoom,e.indexMaxPoints),console.time("generate tiles"),this.stats={},this.total=0),n=function(t,e){const i=e.buffer/e.extent;let n=t;const r=R(t,1,-1-i,i,0,-1,2,e),o=R(t,1,1-i,2+i,0,-1,2,e);return(r||o)&&(n=R(t,1,-i,1+i,0,-1,2,e)||[],r&&(n=H(r,1,e.hasAltitude).concat(n)),o&&(n=n.concat(H(o,-1,e.hasAltitude)))),n}(n,e),n.length&&this.splitTile(n,0,0,0),i&&(n.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(t,e,i,n,r,o,s){const a=[t,e,i,n],l=this.options,u=l.debug;for(;a.length;){n=a.pop(),i=a.pop(),e=a.pop(),t=a.pop();const c=1<<e,h=tt(e,i,n);let d=this.tiles[h];if(!d&&(u>1&&console.time("creation"),d=this.tiles[h]=X(t,e,i,n,l),this.tileCoords.push({z:e,x:i,y:n}),u)){u>1&&(console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)",e,i,n,d.numFeatures,d.numPoints,d.numSimplified),console.timeEnd("creation"));const t="z"+e;this.stats[t]=(this.stats[t]||0)+1,this.total++}if(d.source=t,null==r){if(e===l.indexMaxZoom||d.numPoints<=l.indexMaxPoints)continue}else{if(e===l.maxZoom||e===r)continue;if(null!=r){const t=r-e;if(i!==o>>t||n!==s>>t)continue}}if(d.source=null,0===t.length)continue;u>1&&console.time("clipping");const f=.5*l.buffer/l.extent,p=.5-f,m=.5+f,y=1+f;let g=null,b=null,v=null,w=null,x=R(t,c,i-f,i+m,0,d.minX,d.maxX,l),k=R(t,c,i+p,i+y,0,d.minX,d.maxX,l);t=null,x&&(g=R(x,c,n-f,n+m,1,d.minY,d.maxY,l),b=R(x,c,n+p,n+y,1,d.minY,d.maxY,l),x=null),k&&(v=R(k,c,n-f,n+m,1,d.minY,d.maxY,l),w=R(k,c,n+p,n+y,1,d.minY,d.maxY,l),k=null),u>1&&console.timeEnd("clipping"),a.push(g||[],e+1,2*i,2*n),a.push(b||[],e+1,2*i,2*n+1),a.push(v||[],e+1,2*i+1,2*n),a.push(w||[],e+1,2*i+1,2*n+1)}}getTile(t,e,i){t=+t,e=+e,i=+i;const n=this.options,{extent:r,debug:o}=n,{hasAltitude:s}=n;if(t<0||t>24)return null;const a=1<<t,l=tt(t,e=e+a&a-1,i);if(this.tiles[l])return V(this.tiles[l],r,s);o>1&&console.log("drilling down to z%d-%d-%d",t,e,i);let u,c=t,h=e,d=i;for(;!u&&c>0;)c--,h>>=1,d>>=1,u=this.tiles[tt(c,h,d)];return u&&u.source?(o>1&&(console.log("found parent tile z%d-%d-%d",c,h,d),console.time("drilling down")),this.splitTile(u.source,c,h,d,t,e,i),o>1&&console.timeEnd("drilling down"),this.tiles[l]?V(this.tiles[l],r,s):null):null}}function tt(t,e,i){return 32*((1<<t)*i+e)+t}function et(t,e,i,n,r,o){const s=i&&Array.isArray(i[0]);for(let a=0,l=i.length;a<l;a++){t[e]=Math.round((s?i[a][0]:i[a].x)*n),t[e+1]=Math.round((s?i[a][1]:i[a].y)*n);let u=r||0;Array.isArray(r)&&(u=r[a]),u=u?Math.round(n*u):0,t[e+2]=u,e+=3,o&&0!==a&&a!==l-1&&(t[e]=t[e-3],t[e+1]=t[e-2],t[e+2]=t[e-1],e+=3)}return e}function it(t,e,i,n){const r=t[3*e],o=t[3*e+1],s=t[3*i],a=t[3*i+1];return r===s&&(r<0||r>n)||o===a&&(o<0||o>n)}class nt{constructor(t,e){this.x=t,this.y=e}clone(){return new nt(this.x,this.y)}normalize(){const t=this.length();this.x/=t,this.y/=t}negate(){this.x=-this.x,this.y=-this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}diff(t){return new nt(this.x-t.x,this.y-t.y)}distance(t){const e=this.x-t.x,i=this.y-t.y;return Math.sqrt(e*e+i*i)}dot(t){return this.x*t.x+this.y*t.y}equals(t){return this.x===t.x&&this.y===t.y}orthogonal(){return new nt(this.y,-this.x)}}function rt(t,e,i){const n=(e.x-t.x)*(i.y-t.y)-(e.y-t.y)*(i.x-t.x);return n>1e-5?1:n<-1e-5?2:0}function ot(t,e,i,n){const r=e.x*n.y-e.y*n.x,o=i.x-t.x,s=i.y-t.y,a=(o*n.y-s*n.x)/r;return new nt(t.x+a*e.x,t.y+a*e.y)}const st=[];function at(t,e,i){let n=0;const r=[];for(let o=e;o<i;o+=3)st[n]?(st[n].x=t[o],st[n].y=t[o+1]):st[n]=new nt(t[o],t[o+1]),r.push(st[n]),n++;const o=function(t){let e;this.UpdateOmbb=function(t,i,n,r,o,s,a,l){const u=ot(t,i,o,s),c=ot(n,r,o,s),h=ot(a,l,t,i),d=ot(a,l,n,r),f=u.distance(c)*u.distance(h);f<this.BestObbArea&&(e=[u,h,d,c],this.BestObbArea=f)},this.BestObbArea=Number.MAX_VALUE;const i=[];for(let e=0;e<t.length;e++)i.push(t[(e+1)%t.length].diff(t[e])),i[e].normalize();const n=new nt(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY),r=new nt(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY);let o,s,a,l;for(let e=0;e<t.length;e++){const i=t[e];i.x<n.x&&(n.x=i.x,o=e),i.x>r.x&&(r.x=i.x,s=e),i.y<n.y&&(n.y=i.y,l=e),i.y>r.y&&(r.y=i.y,a=e)}let u=new nt(0,-1),c=new nt(0,1),h=new nt(-1,0),d=new nt(1,0);for(let e=0;e<t.length;e++){const e=[Math.acos(u.dot(i[o])),Math.acos(c.dot(i[s])),Math.acos(h.dot(i[a])),Math.acos(d.dot(i[l]))];switch(e.indexOf(Math.min.apply(Math,e))){case 0:u=i[o].clone(),c=u.clone(),c.negate(),h=u.orthogonal(),d=h.clone(),d.negate(),o=(o+1)%t.length;break;case 1:c=i[s].clone(),u=c.clone(),u.negate(),h=u.orthogonal(),d=h.clone(),d.negate(),s=(s+1)%t.length;break;case 2:h=i[a].clone(),d=h.clone(),d.negate(),u=d.orthogonal(),c=u.clone(),c.negate(),a=(a+1)%t.length;break;case 3:d=i[l].clone(),h=d.clone(),h.negate(),u=d.orthogonal(),c=u.clone(),c.negate(),l=(l+1)%t.length}this.UpdateOmbb(t[o],u,t[s],c,t[a],h,t[l],d)}return e}(function(t){if(t.length<3)return t;let e=t[0];const i=[];for(let i=1;i<t.length;i++)(t[i].x<e.x||Math.abs(t[i].x-e.x)<1e-5&&t[i].y<e.y)&&(e=t[i]);let n=t[0];do{i.unshift(e.clone());for(let i=1;i<t.length;i++){const r=rt(e,n,t[i]);(n.equals(e)||1===r||0===r&&e.distance(t[i])>e.distance(n))&&(n=t[i])}e=n}while(!n.equals(i[i.length-1]));return i}(r)),s=o[0].distance(o[1]),a=o[1].distance(o[2]),l=o.map(t=>[t.x,t.y]);return l.push(+(a>s)),l}var lt="undefined"!=typeof Float32Array?Float32Array:Array;function ut(){var t=new lt(3);return lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function ct(t,e,i){var n=new lt(3);return n[0]=t,n[1]=e,n[2]=i,n}function ht(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function dt(t,e,i,n){return t[0]=e,t[1]=i,t[2]=n,t}function ft(t,e,i){return t[0]=e[0]+i[0],t[1]=e[1]+i[1],t[2]=e[2]+i[2],t}function pt(t,e,i){return t[0]=e[0]/i[0],t[1]=e[1]/i[1],t[2]=e[2]/i[2],t}function mt(t,e){var i=e[0],n=e[1],r=e[2],o=i*i+n*n+r*r;return o>0&&(o=1/Math.sqrt(o),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o),t}function yt(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function gt(t,e,i){var n=e[0],r=e[1],o=e[2],s=i[0],a=i[1],l=i[2];return t[0]=r*l-o*a,t[1]=o*s-n*l,t[2]=n*a-r*s,t}var bt=function(t,e,i){return t[0]=e[0]-i[0],t[1]=e[1]-i[1],t[2]=e[2]-i[2],t};function vt(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function wt(t,e,i,n,r){return t[0]=e,t[1]=i,t[2]=n,t[3]=r,t}function xt(t,e,i){return t[0]=e[0]*i,t[1]=e[1]*i,t[2]=e[2]*i,t[3]=e[3]*i,t}function kt(){var t=new lt(4);return lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function Mt(t,e){var i=e[0]+e[4]+e[8],n=void 0;if(i>0)n=Math.sqrt(i+1),t[3]=.5*n,n=.5/n,t[0]=(e[5]-e[7])*n,t[1]=(e[6]-e[2])*n,t[2]=(e[1]-e[3])*n;else{var r=0;e[4]>e[0]&&(r=1),e[8]>e[3*r+r]&&(r=2);var o=(r+1)%3,s=(r+2)%3;n=Math.sqrt(e[3*r+r]-e[3*o+o]-e[3*s+s]+1),t[r]=.5*n,n=.5/n,t[3]=(e[3*o+s]-e[3*s+o])*n,t[o]=(e[3*o+r]+e[3*r+o])*n,t[s]=(e[3*s+r]+e[3*r+s])*n}return t}ut(),function(){var t,e=(t=new lt(4),lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t)}();var jt,At=xt,Ft=function(t,e){var i=e[0],n=e[1],r=e[2],o=e[3],s=i*i+n*n+r*r+o*o;return s>0&&(s=1/Math.sqrt(s),t[0]=i*s,t[1]=n*s,t[2]=r*s,t[3]=o*s),t};function Tt(t,e){var i=e[0]-t[0],n=e[1]-t[1];return Math.sqrt(i*i+n*n)}ut(),ct(1,0,0),ct(0,1,0),kt(),kt(),jt=new lt(9),lt!=Float32Array&&(jt[1]=0,jt[2]=0,jt[3]=0,jt[5]=0,jt[6]=0,jt[7]=0),jt[0]=1,jt[4]=1,jt[8]=1;var zt=function(t){var e=t[0],i=t[1];return Math.sqrt(e*e+i*i)};function St(t,e,i,n,r,o,s,a,l,u){0===t?function(t,e,i,n,r,o,s,a,l){const u=[0,0];for(let r=t;r<e;r+=3){const t=r/3*2,e=n[r],c=n[r+1];i[t]=u[0]+e*o*s/a,i[t+1]=u[1]-c*o*s/l}}(e,i,n,r,0,s,a,l,u):1===t&&function(t,e,i,n){const r=at(n,t,e),o=r[4],s=r[o],a=r[o+1],l=r[o+2],u=(a[1]-s[1])/(a[0]-s[0]),c=(l[1]-a[1])/(l[0]-a[0]),h=Tt(s,a),d=Tt(a,l);for(let r=t;r<e;r+=3){const t=r/3*2,e=n[r],o=n[r+1];i[t]=Pt(e,o,s,u,h),i[t+1]=-Pt(e,o,a,c,d)}}(e,i,n,r)}!function(){var t=function(){var t=new lt(2);return lt!=Float32Array&&(t[0]=0,t[1]=0),t}()}();const _t=[];function Pt(t,e,i,n,r){return _t[0]=(n*n*i[0]+n*(e-i[1])+t)/(n*n+1),_t[1]=n*(_t[0]-i[0])+i[1],Tt(i,_t)/r}function It(t,e,i,n,r){const o=3*e[i-1],s=3*e[i-1]+1,a=t[o],l=t[s];return u=n,c=r,h=a,d=l,Math.sqrt((h-u)*(h-u)+(d-c)*(d-c));var u,c,h,d}"undefined"!=typeof undefinedThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof undefined?global:"undefined"!=typeof self&&self;var Ot=Et;function Et(t,e){this.x=t,this.y=e}function qt(t,e,i){i=i||{},this.w=t||64,this.h=e||64,this.autoResize=!!i.autoResize,this.shelves=[],this.freebins=[],this.stats={},this.bins={},this.maxId=0}function Rt(t,e,i){this.x=0,this.y=t,this.w=this.free=e,this.h=i}function Ct(t,e,i,n,r,o,s){this.id=t,this.x=e,this.y=i,this.w=n,this.h=r,this.maxw=o||n,this.maxh=s||r,this.refcount=0}\n/*!\n Feature Filter by\n\n (c) mapbox 2016 and maptalks 2018\n www.mapbox.com | www.maptalks.org\n License: MIT, header required.\n */Et.prototype={clone:function(){return new Et(this.x,this.y)},add:function(t){return this.clone().u(t)},sub:function(t){return this.clone().m(t)},multByPoint:function(t){return this.clone().v(t)},divByPoint:function(t){return this.clone().k(t)},mult:function(t){return this.clone().M(t)},div:function(t){return this.clone().j(t)},rotate:function(t){return this.clone().A(t)},rotateAround:function(t,e){return this.clone().F(t,e)},matMult:function(t){return this.clone().T(t)},unit:function(){return this.clone().S()},perp:function(){return this.clone()._()},round:function(){return this.clone().P()},mag:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},equals:function(t){return this.x===t.x&&this.y===t.y},dist:function(t){return Math.sqrt(this.distSqr(t))},distSqr:function(t){var e=t.x-this.x,i=t.y-this.y;return e*e+i*i},angle:function(){return Math.atan2(this.y,this.x)},angleTo:function(t){return Math.atan2(this.y-t.y,this.x-t.x)},angleWith:function(t){return this.angleWithSep(t.x,t.y)},angleWithSep:function(t,e){return Math.atan2(this.x*e-this.y*t,this.x*t+this.y*e)},T:function(t){var e=t[0]*this.x+t[1]*this.y,i=t[2]*this.x+t[3]*this.y;return this.x=e,this.y=i,this},u:function(t){return this.x+=t.x,this.y+=t.y,this},m:function(t){return this.x-=t.x,this.y-=t.y,this},M:function(t){return this.x*=t,this.y*=t,this},j:function(t){return this.x/=t,this.y/=t,this},v:function(t){return this.x*=t.x,this.y*=t.y,this},k:function(t){return this.x/=t.x,this.y/=t.y,this},S:function(){return this.j(this.mag()),this},_:function(){var t=this.y;return this.y=this.x,this.x=-t,this},A:function(t){var e=Math.cos(t),i=Math.sin(t),n=e*this.x-i*this.y,r=i*this.x+e*this.y;return this.x=n,this.y=r,this},F:function(t,e){var i=Math.cos(t),n=Math.sin(t),r=e.x+i*(this.x-e.x)-n*(this.y-e.y),o=e.y+n*(this.x-e.x)+i*(this.y-e.y);return this.x=r,this.y=o,this},P:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}},Et.convert=function(t){return t instanceof Et?t:Array.isArray(t)?new Et(t[0],t[1]):t},qt.prototype.pack=function(t,e){t=[].concat(t),e=e||{};for(var i,n,r,o,s=[],a=0;a<t.length;a++)if(i=t[a].w||t[a].width,n=t[a].h||t[a].height,r=t[a].id,i&&n){if(!(o=this.packOne(i,n,r)))continue;e.inPlace&&(t[a].x=o.x,t[a].y=o.y,t[a].id=o.id),s.push(o)}return this.shrink(),s},qt.prototype.packOne=function(t,e,i){var n,r,o,s,a,l,u,c,h={freebin:-1,shelf:-1,waste:1/0},d=0;if("string"==typeof i||"number"==typeof i){if(n=this.getBin(i))return this.ref(n),n;"number"==typeof i&&(this.maxId=Math.max(i,this.maxId))}else i=++this.maxId;for(s=0;s<this.freebins.length;s++){if(e===(n=this.freebins[s]).maxh&&t===n.maxw)return this.allocFreebin(s,t,e,i);e>n.maxh||t>n.maxw||e<=n.maxh&&t<=n.maxw&&(o=n.maxw*n.maxh-t*e)<h.waste&&(h.waste=o,h.freebin=s)}for(s=0;s<this.shelves.length;s++)if(d+=(r=this.shelves[s]).h,!(t>r.free)){if(e===r.h)return this.allocShelf(s,t,e,i);e>r.h||e<r.h&&(o=(r.h-e)*t)<h.waste&&(h.freebin=-1,h.waste=o,h.shelf=s)}return-1!==h.freebin?this.allocFreebin(h.freebin,t,e,i):-1!==h.shelf?this.allocShelf(h.shelf,t,e,i):e<=this.h-d&&t<=this.w?(r=new Rt(d,this.w,e),this.allocShelf(this.shelves.push(r)-1,t,e,i)):this.autoResize?(a=l=this.h,((u=c=this.w)<=a||t>u)&&(c=2*Math.max(t,u)),(a<u||e>a)&&(l=2*Math.max(e,a)),this.resize(c,l),this.packOne(t,e,i)):null},qt.prototype.allocFreebin=function(t,e,i,n){var r=this.freebins.splice(t,1)[0];return r.id=n,r.w=e,r.h=i,r.refcount=0,this.bins[n]=r,this.ref(r),r},qt.prototype.allocShelf=function(t,e,i,n){var r=this.shelves[t].alloc(e,i,n);return this.bins[n]=r,this.ref(r),r},qt.prototype.shrink=function(){if(this.shelves.length>0){for(var t=0,e=0,i=0;i<this.shelves.length;i++){var n=this.shelves[i];e+=n.h,t=Math.max(n.w-n.free,t)}this.resize(t,e)}},qt.prototype.getBin=function(t){return this.bins[t]},qt.prototype.ref=function(t){if(1==++t.refcount){var e=t.h;this.stats[e]=1+(0|this.stats[e])}return t.refcount},qt.prototype.unref=function(t){return 0===t.refcount?0:(0==--t.refcount&&(this.stats[t.h]--,delete this.bins[t.id],this.freebins.push(t)),t.refcount)},qt.prototype.clear=function(){this.shelves=[],this.freebins=[],this.stats={},this.bins={},this.maxId=0},qt.prototype.resize=function(t,e){this.w=t,this.h=e;for(var i=0;i<this.shelves.length;i++)this.shelves[i].resize(t);return!0},Rt.prototype.alloc=function(t,e,i){if(t>this.free||e>this.h)return null;var n=this.x;return this.x+=t,this.free-=t,new Ct(i,n,this.y,t,e,t,this.h)},Rt.prototype.resize=function(t){return this.free+=t-this.w,this.w=t,!0};const Nt=["Unknown","Point","LineString","Polygon","MultiPoint","MultiLineString","MultiPolygon","GeometryCollection"];function Lt(t){return new Function("f","var p = (f && f.properties || {}); return "+Dt(t))}function Dt(t){if(!t)return"true";const e=t[0];if(t.length<=1)return"any"===e?"false":"true";return`(${"=="===e?$t(t[1],t[2],"===",!1):"!="===e?$t(t[1],t[2],"!==",!1):"<"===e||">"===e||"<="===e||">="===e?$t(t[1],t[2],e,!0):"any"===e?Wt(t.slice(1),"||"):"all"===e?Wt(t.slice(1),"&&"):"none"===e?Gt(Wt(t.slice(1),"||")):"in"===e?Jt(t[1],t.slice(2)):"!in"===e?Gt(Jt(t[1],t.slice(2))):"has"===e?Ht(t[1]):"!has"===e?Gt(Ht(t[1])):"true"})`}function Ut(t){return"$"===t[0]?"f."+t.substring(1):"p["+JSON.stringify(t)+"]"}function $t(t,e,i,n){const r=Ut(t),o="$type"===t?Nt.indexOf(e):JSON.stringify(e);return(n?`typeof ${r}=== typeof ${o}&&`:"")+r+i+o}function Wt(t,e){return t.map(Dt).join(e)}function Jt(t,e){"$type"===t&&(e=e.map(t=>Nt.indexOf(t)));const i=JSON.stringify(e.sort(Vt)),n=Ut(t);return e.length<=200?`${i}.indexOf(${n}) !== -1`:`function(v, a, i, j) {\\n while (i <= j) { var m = (i + j) >> 1;\\n if (a[m] === v) return true; if (a[m] > v) j = m - 1; else i = m + 1;\\n }\\n return false; }(${n}, ${i},0,${e.length-1})`}function Ht(t){return"$id"===t?\'"id" in f\':JSON.stringify(t)+" in p"}function Gt(t){return`!(${t})`}function Vt(t,e){return t<e?-1:t>e?1:0}var Bt={exports:{}};Bt.exports=function(){function t(t,e,i){var n=t[e];t[e]=t[i],t[i]=n}function e(t,e){return t<e?-1:t>e?1:0}return function(i,n,r,o,s){!function e(i,n,r,o,s){for(;o>r;){if(o-r>600){var a=o-r+1,l=n-r+1,u=Math.log(a),c=.5*Math.exp(2*u/3),h=.5*Math.sqrt(u*c*(a-c)/a)*(l-a/2<0?-1:1),d=Math.max(r,Math.floor(n-l*c/a+h)),f=Math.min(o,Math.floor(n+(a-l)*c/a+h));e(i,n,d,f,s)}var p=i[n],m=r,y=o;for(t(i,r,n),s(i[o],p)>0&&t(i,r,o);m<y;){for(t(i,m,y),m++,y--;s(i[m],p)<0;)m++;for(;s(i[y],p)>0;)y--}0===s(i[r],p)?t(i,r,y):(y++,t(i,y,o)),y<=n&&(r=y+1),n<=y&&(o=y-1)}}(i,n,r||0,o||i.length-1,s||e)}}();var Xt=Bt.exports,Zt={exports:{}};function Yt(t,e){if(!(this instanceof Yt))return new Yt(t,e);if(this.data=t||[],this.length=this.data.length,this.compare=e||Kt,this.length>0)for(var i=(this.length>>1)-1;i>=0;i--)this.I(i)}function Kt(t,e){return t<e?-1:t>e?1:0}Zt.exports=Yt,Zt.exports.default=Yt,Yt.prototype={push:function(t){this.data.push(t),this.length++,this.O(this.length-1)},pop:function(){if(0!==this.length){var t=this.data[0];return this.length--,this.length>0&&(this.data[0]=this.data[this.length],this.I(0)),this.data.pop(),t}},peek:function(){return this.data[0]},O:function(t){for(var e=this.data,i=this.compare,n=e[t];t>0;){var r=t-1>>1,o=e[r];if(i(n,o)>=0)break;e[t]=o,t=r}e[t]=n},I:function(t){for(var e=this.data,i=this.compare,n=this.length>>1,r=e[t];t<n;){var o=1+(t<<1),s=o+1,a=e[o];if(s<this.length&&i(e[s],a)<0&&(o=s,a=e[s]),i(a,r)>=0)break;e[t]=a,t=o}e[t]=r}};var Qt=Zt.exports,te={exports:{}},ee={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},ie={exports:{}},ne=function(t){return!(!t||"string"==typeof t)&&(t instanceof Array||Array.isArray(t)||t.length>=0&&(t.splice instanceof Function||Object.getOwnPropertyDescriptor(t,t.length-1)&&"String"!==t.constructor.name))},re=Array.prototype.concat,oe=Array.prototype.slice,se=ie.exports=function(t){for(var e=[],i=0,n=t.length;i<n;i++){var r=t[i];ne(r)?e=re.call(e,oe.call(r)):e.push(r)}return e};se.wrap=function(t){return function(){return t(se(arguments))}};var ae=ee,le=ie.exports,ue=Object.hasOwnProperty,ce={};for(var he in ae)ue.call(ae,he)&&(ce[ae[he]]=he);var de=te.exports={to:{},get:{}};function fe(t,e,i){return Math.min(Math.max(e,t),i)}function pe(t){var e=Math.round(t).toString(16).toUpperCase();return e.length<2?"0"+e:e}de.get=function(t){var e,i;switch(t.substring(0,3).toLowerCase()){case"hsl":e=de.get.hsl(t),i="hsl";break;case"hwb":e=de.get.hwb(t),i="hwb";break;default:e=de.get.rgb(t),i="rgb"}return e?{model:i,value:e}:null},de.get.rgb=function(t){if(!t)return null;var e,i,n,r=[0,0,0,1];if(e=t.match(/^#([a-f0-9]{6})([a-f0-9]{2})?$/i)){for(n=e[2],e=e[1],i=0;i<3;i++){var o=2*i;r[i]=parseInt(e.slice(o,o+2),16)}n&&(r[3]=parseInt(n,16)/255)}else if(e=t.match(/^#([a-f0-9]{3,4})$/i)){for(n=(e=e[1])[3],i=0;i<3;i++)r[i]=parseInt(e[i]+e[i],16);n&&(r[3]=parseInt(n+n,16)/255)}else if(e=t.match(/^rgba?\\(\\s*([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/)){for(i=0;i<3;i++)r[i]=parseInt(e[i+1],0);e[4]&&(e[5]?r[3]=.01*parseFloat(e[4]):r[3]=parseFloat(e[4]))}else{if(!(e=t.match(/^rgba?\\(\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/)))return(e=t.match(/^(\\w+)$/))?"transparent"===e[1]?[0,0,0,0]:ue.call(ae,e[1])?((r=ae[e[1]])[3]=1,r):null:null;for(i=0;i<3;i++)r[i]=Math.round(2.55*parseFloat(e[i+1]));e[4]&&(e[5]?r[3]=.01*parseFloat(e[4]):r[3]=parseFloat(e[4]))}for(i=0;i<3;i++)r[i]=fe(r[i],0,255);return r[3]=fe(r[3],0,1),r},de.get.hsl=function(t){if(!t)return null;var e=t.match(/^hsla?\\(\\s*([+-]?(?:\\d{0,3}\\.)?\\d+)(?:deg)?\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*(?:[,|\\/]\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/);if(e){var i=parseFloat(e[4]);return[(parseFloat(e[1])%360+360)%360,fe(parseFloat(e[2]),0,100),fe(parseFloat(e[3]),0,100),fe(isNaN(i)?1:i,0,1)]}return null},de.get.hwb=function(t){if(!t)return null;var e=t.match(/^hwb\\(\\s*([+-]?\\d{0,3}(?:\\.\\d+)?)(?:deg)?\\s*,\\s*([+-]?[\\d\\.]+)%\\s*,\\s*([+-]?[\\d\\.]+)%\\s*(?:,\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/);if(e){var i=parseFloat(e[4]);return[(parseFloat(e[1])%360+360)%360,fe(parseFloat(e[2]),0,100),fe(parseFloat(e[3]),0,100),fe(isNaN(i)?1:i,0,1)]}return null},de.to.hex=function(){var t=le(arguments);return"#"+pe(t[0])+pe(t[1])+pe(t[2])+(t[3]<1?pe(Math.round(255*t[3])):"")},de.to.rgb=function(){var t=le(arguments);return t.length<4||1===t[3]?"rgb("+Math.round(t[0])+", "+Math.round(t[1])+", "+Math.round(t[2])+")":"rgba("+Math.round(t[0])+", "+Math.round(t[1])+", "+Math.round(t[2])+", "+t[3]+")"},de.to.rgb.percent=function(){var t=le(arguments),e=Math.round(t[0]/255*100),i=Math.round(t[1]/255*100),n=Math.round(t[2]/255*100);return t.length<4||1===t[3]?"rgb("+e+"%, "+i+"%, "+n+"%)":"rgba("+e+"%, "+i+"%, "+n+"%, "+t[3]+")"},de.to.hsl=function(){var t=le(arguments);return t.length<4||1===t[3]?"hsl("+t[0]+", "+t[1]+"%, "+t[2]+"%)":"hsla("+t[0]+", "+t[1]+"%, "+t[2]+"%, "+t[3]+")"},de.to.hwb=function(){var t=le(arguments),e="";return t.length>=4&&1!==t[3]&&(e=", "+t[3]),"hwb("+t[0]+", "+t[1]+"%, "+t[2]+"%"+e+")"},de.to.keyword=function(t){return ce[t.slice(0,3)]};var me={exports:{}},ye=ee,ge={};for(var be in ye)ye.hasOwnProperty(be)&&(ge[ye[be]]=be);var ve=me.exports={rgb:{channels:3,labels:"rgb"},hsl:{channels:3,labels:"hsl"},hsv:{channels:3,labels:"hsv"},hwb:{channels:3,labels:"hwb"},cmyk:{channels:4,labels:"cmyk"},xyz:{channels:3,labels:"xyz"},lab:{channels:3,labels:"lab"},lch:{channels:3,labels:"lch"},hex:{channels:1,labels:["hex"]},keyword:{channels:1,labels:["keyword"]},ansi16:{channels:1,labels:["ansi16"]},ansi256:{channels:1,labels:["ansi256"]},hcg:{channels:3,labels:["h","c","g"]},apple:{channels:3,labels:["r16","g16","b16"]},gray:{channels:1,labels:["gray"]}};for(var we in ve)if(ve.hasOwnProperty(we)){if(!("channels"in ve[we]))throw new Error("missing channels property: "+we);if(!("labels"in ve[we]))throw new Error("missing channel labels property: "+we);if(ve[we].labels.length!==ve[we].channels)throw new Error("channel and label counts mismatch: "+we);var xe=ve[we].channels,ke=ve[we].labels;delete ve[we].channels,delete ve[we].labels,Object.defineProperty(ve[we],"channels",{value:xe}),Object.defineProperty(ve[we],"labels",{value:ke})}function Me(t,e){return Math.pow(t[0]-e[0],2)+Math.pow(t[1]-e[1],2)+Math.pow(t[2]-e[2],2)}ve.rgb.hsl=function(t){var e,i,n=t[0]/255,r=t[1]/255,o=t[2]/255,s=Math.min(n,r,o),a=Math.max(n,r,o),l=a-s;return a===s?e=0:n===a?e=(r-o)/l:r===a?e=2+(o-n)/l:o===a&&(e=4+(n-r)/l),(e=Math.min(60*e,360))<0&&(e+=360),i=(s+a)/2,[e,100*(a===s?0:i<=.5?l/(a+s):l/(2-a-s)),100*i]},ve.rgb.hsv=function(t){var e,i,n,r,o,s=t[0]/255,a=t[1]/255,l=t[2]/255,u=Math.max(s,a,l),c=u-Math.min(s,a,l),h=function(t){return(u-t)/6/c+.5};return 0===c?r=o=0:(o=c/u,e=h(s),i=h(a),n=h(l),s===u?r=n-i:a===u?r=1/3+e-n:l===u&&(r=2/3+i-e),r<0?r+=1:r>1&&(r-=1)),[360*r,100*o,100*u]},ve.rgb.hwb=function(t){var e=t[0],i=t[1],n=t[2];return[ve.rgb.hsl(t)[0],100*(1/255*Math.min(e,Math.min(i,n))),100*(n=1-1/255*Math.max(e,Math.max(i,n)))]},ve.rgb.cmyk=function(t){var e,i=t[0]/255,n=t[1]/255,r=t[2]/255;return[100*((1-i-(e=Math.min(1-i,1-n,1-r)))/(1-e)||0),100*((1-n-e)/(1-e)||0),100*((1-r-e)/(1-e)||0),100*e]},ve.rgb.keyword=function(t){var e=ge[t];if(e)return e;var i,n=1/0;for(var r in ye)if(ye.hasOwnProperty(r)){var o=Me(t,ye[r]);o<n&&(n=o,i=r)}return i},ve.keyword.rgb=function(t){return ye[t]},ve.rgb.xyz=function(t){var e=t[0]/255,i=t[1]/255,n=t[2]/255;return[100*(.4124*(e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92)+.3576*(i=i>.04045?Math.pow((i+.055)/1.055,2.4):i/12.92)+.1805*(n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92)),100*(.2126*e+.7152*i+.0722*n),100*(.0193*e+.1192*i+.9505*n)]},ve.rgb.lab=function(t){var e=ve.rgb.xyz(t),i=e[0],n=e[1],r=e[2];return n/=100,r/=108.883,i=(i/=95.047)>.008856?Math.pow(i,1/3):7.787*i+16/116,[116*(n=n>.008856?Math.pow(n,1/3):7.787*n+16/116)-16,500*(i-n),200*(n-(r=r>.008856?Math.pow(r,1/3):7.787*r+16/116))]},ve.hsl.rgb=function(t){var e,i,n,r,o,s=t[0]/360,a=t[1]/100,l=t[2]/100;if(0===a)return[o=255*l,o,o];e=2*l-(i=l<.5?l*(1+a):l+a-l*a),r=[0,0,0];for(var u=0;u<3;u++)(n=s+1/3*-(u-1))<0&&n++,n>1&&n--,o=6*n<1?e+6*(i-e)*n:2*n<1?i:3*n<2?e+(i-e)*(2/3-n)*6:e,r[u]=255*o;return r},ve.hsl.hsv=function(t){var e=t[0],i=t[1]/100,n=t[2]/100,r=i,o=Math.max(n,.01);return i*=(n*=2)<=1?n:2-n,r*=o<=1?o:2-o,[e,100*(0===n?2*r/(o+r):2*i/(n+i)),100*((n+i)/2)]},ve.hsv.rgb=function(t){var e=t[0]/60,i=t[1]/100,n=t[2]/100,r=Math.floor(e)%6,o=e-Math.floor(e),s=255*n*(1-i),a=255*n*(1-i*o),l=255*n*(1-i*(1-o));switch(n*=255,r){case 0:return[n,l,s];case 1:return[a,n,s];case 2:return[s,n,l];case 3:return[s,a,n];case 4:return[l,s,n];case 5:return[n,s,a]}},ve.hsv.hsl=function(t){var e,i,n,r=t[0],o=t[1]/100,s=t[2]/100,a=Math.max(s,.01);return n=(2-o)*s,i=o*a,[r,100*(i=(i/=(e=(2-o)*a)<=1?e:2-e)||0),100*(n/=2)]},ve.hwb.rgb=function(t){var e,i,n,r,o,s,a,l=t[0]/360,u=t[1]/100,c=t[2]/100,h=u+c;switch(h>1&&(u/=h,c/=h),n=6*l-(e=Math.floor(6*l)),0!=(1&e)&&(n=1-n),r=u+n*((i=1-c)-u),e){default:case 6:case 0:o=i,s=r,a=u;break;case 1:o=r,s=i,a=u;break;case 2:o=u,s=i,a=r;break;case 3:o=u,s=r,a=i;break;case 4:o=r,s=u,a=i;break;case 5:o=i,s=u,a=r}return[255*o,255*s,255*a]},ve.cmyk.rgb=function(t){var e=t[0]/100,i=t[1]/100,n=t[2]/100,r=t[3]/100;return[255*(1-Math.min(1,e*(1-r)+r)),255*(1-Math.min(1,i*(1-r)+r)),255*(1-Math.min(1,n*(1-r)+r))]},ve.xyz.rgb=function(t){var e,i,n,r=t[0]/100,o=t[1]/100,s=t[2]/100;return i=-.9689*r+1.8758*o+.0415*s,n=.0557*r+-.204*o+1.057*s,e=(e=3.2406*r+-1.5372*o+-.4986*s)>.0031308?1.055*Math.pow(e,1/2.4)-.055:12.92*e,i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,n=n>.0031308?1.055*Math.pow(n,1/2.4)-.055:12.92*n,[255*(e=Math.min(Math.max(0,e),1)),255*(i=Math.min(Math.max(0,i),1)),255*(n=Math.min(Math.max(0,n),1))]},ve.xyz.lab=function(t){var e=t[0],i=t[1],n=t[2];return i/=100,n/=108.883,e=(e/=95.047)>.008856?Math.pow(e,1/3):7.787*e+16/116,[116*(i=i>.008856?Math.pow(i,1/3):7.787*i+16/116)-16,500*(e-i),200*(i-(n=n>.008856?Math.pow(n,1/3):7.787*n+16/116))]},ve.lab.xyz=function(t){var e,i,n,r=t[0];e=t[1]/500+(i=(r+16)/116),n=i-t[2]/200;var o=Math.pow(i,3),s=Math.pow(e,3),a=Math.pow(n,3);return i=o>.008856?o:(i-16/116)/7.787,e=s>.008856?s:(e-16/116)/7.787,n=a>.008856?a:(n-16/116)/7.787,[e*=95.047,i*=100,n*=108.883]},ve.lab.lch=function(t){var e,i=t[0],n=t[1],r=t[2];return(e=360*Math.atan2(r,n)/2/Math.PI)<0&&(e+=360),[i,Math.sqrt(n*n+r*r),e]},ve.lch.lab=function(t){var e,i=t[0],n=t[1];return e=t[2]/360*2*Math.PI,[i,n*Math.cos(e),n*Math.sin(e)]},ve.rgb.ansi16=function(t){var e=t[0],i=t[1],n=t[2],r=1 in arguments?arguments[1]:ve.rgb.hsv(t)[2];if(0===(r=Math.round(r/50)))return 30;var o=30+(Math.round(n/255)<<2|Math.round(i/255)<<1|Math.round(e/255));return 2===r&&(o+=60),o},ve.hsv.ansi16=function(t){return ve.rgb.ansi16(ve.hsv.rgb(t),t[2])},ve.rgb.ansi256=function(t){var e=t[0],i=t[1],n=t[2];return e===i&&i===n?e<8?16:e>248?231:Math.round((e-8)/247*24)+232:16+36*Math.round(e/255*5)+6*Math.round(i/255*5)+Math.round(n/255*5)},ve.ansi16.rgb=function(t){var e=t%10;if(0===e||7===e)return t>50&&(e+=3.5),[e=e/10.5*255,e,e];var i=.5*(1+~~(t>50));return[(1&e)*i*255,(e>>1&1)*i*255,(e>>2&1)*i*255]},ve.ansi256.rgb=function(t){if(t>=232){var e=10*(t-232)+8;return[e,e,e]}var i;return t-=16,[Math.floor(t/36)/5*255,Math.floor((i=t%36)/6)/5*255,i%6/5*255]},ve.rgb.hex=function(t){var e=(((255&Math.round(t[0]))<<16)+((255&Math.round(t[1]))<<8)+(255&Math.round(t[2]))).toString(16).toUpperCase();return"000000".substring(e.length)+e},ve.hex.rgb=function(t){var e=t.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);if(!e)return[0,0,0];var i=e[0];3===e[0].length&&(i=i.split("").map((function(t){return t+t})).join(""));var n=parseInt(i,16);return[n>>16&255,n>>8&255,255&n]},ve.rgb.hcg=function(t){var e,i=t[0]/255,n=t[1]/255,r=t[2]/255,o=Math.max(Math.max(i,n),r),s=Math.min(Math.min(i,n),r),a=o-s;return e=a<=0?0:o===i?(n-r)/a%6:o===n?2+(r-i)/a:4+(i-n)/a+4,e/=6,[360*(e%=1),100*a,100*(a<1?s/(1-a):0)]},ve.hsl.hcg=function(t){var e=t[1]/100,i=t[2]/100,n=1,r=0;return(n=i<.5?2*e*i:2*e*(1-i))<1&&(r=(i-.5*n)/(1-n)),[t[0],100*n,100*r]},ve.hsv.hcg=function(t){var e=t[1]/100,i=t[2]/100,n=e*i,r=0;return n<1&&(r=(i-n)/(1-n)),[t[0],100*n,100*r]},ve.hcg.rgb=function(t){var e=t[0]/360,i=t[1]/100,n=t[2]/100;if(0===i)return[255*n,255*n,255*n];var r,o=[0,0,0],s=e%1*6,a=s%1,l=1-a;switch(Math.floor(s)){case 0:o[0]=1,o[1]=a,o[2]=0;break;case 1:o[0]=l,o[1]=1,o[2]=0;break;case 2:o[0]=0,o[1]=1,o[2]=a;break;case 3:o[0]=0,o[1]=l,o[2]=1;break;case 4:o[0]=a,o[1]=0,o[2]=1;break;default:o[0]=1,o[1]=0,o[2]=l}return r=(1-i)*n,[255*(i*o[0]+r),255*(i*o[1]+r),255*(i*o[2]+r)]},ve.hcg.hsv=function(t){var e=t[1]/100,i=e+t[2]/100*(1-e),n=0;return i>0&&(n=e/i),[t[0],100*n,100*i]},ve.hcg.hsl=function(t){var e=t[1]/100,i=t[2]/100*(1-e)+.5*e,n=0;return i>0&&i<.5?n=e/(2*i):i>=.5&&i<1&&(n=e/(2*(1-i))),[t[0],100*n,100*i]},ve.hcg.hwb=function(t){var e=t[1]/100,i=e+t[2]/100*(1-e);return[t[0],100*(i-e),100*(1-i)]},ve.hwb.hcg=function(t){var e=t[1]/100,i=1-t[2]/100,n=i-e,r=0;return n<1&&(r=(i-n)/(1-n)),[t[0],100*n,100*r]},ve.apple.rgb=function(t){return[t[0]/65535*255,t[1]/65535*255,t[2]/65535*255]},ve.rgb.apple=function(t){return[t[0]/255*65535,t[1]/255*65535,t[2]/255*65535]},ve.gray.rgb=function(t){return[t[0]/100*255,t[0]/100*255,t[0]/100*255]},ve.gray.hsl=ve.gray.hsv=function(t){return[0,0,t[0]]},ve.gray.hwb=function(t){return[0,100,t[0]]},ve.gray.cmyk=function(t){return[0,0,0,t[0]]},ve.gray.lab=function(t){return[t[0],0,0]},ve.gray.hex=function(t){var e=255&Math.round(t[0]/100*255),i=((e<<16)+(e<<8)+e).toString(16).toUpperCase();return"000000".substring(i.length)+i},ve.rgb.gray=function(t){return[(t[0]+t[1]+t[2])/3/255*100]};var je=me.exports;function Ae(t){var e=function(){for(var t={},e=Object.keys(je),i=e.length,n=0;n<i;n++)t[e[n]]={distance:-1,parent:null};return t}(),i=[t];for(e[t].distance=0;i.length;)for(var n=i.pop(),r=Object.keys(je[n]),o=r.length,s=0;s<o;s++){var a=r[s],l=e[a];-1===l.distance&&(l.distance=e[n].distance+1,l.parent=n,i.unshift(a))}return e}function Fe(t,e){return function(i){return e(t(i))}}function Te(t,e){for(var i=[e[t].parent,t],n=je[e[t].parent][t],r=e[t].parent;e[r].parent;)i.unshift(e[r].parent),n=Fe(je[e[r].parent][r],n),r=e[r].parent;return n.conversion=i,n}var ze=me.exports,Se=function(t){for(var e=Ae(t),i={},n=Object.keys(e),r=n.length,o=0;o<r;o++){var s=n[o];null!==e[s].parent&&(i[s]=Te(s,e))}return i},_e={};Object.keys(ze).forEach((function(t){_e[t]={},Object.defineProperty(_e[t],"channels",{value:ze[t].channels}),Object.defineProperty(_e[t],"labels",{value:ze[t].labels});var e=Se(t);Object.keys(e).forEach((function(i){var n=e[i];_e[t][i]=function(t){var e=function(e){if(null==e)return e;arguments.length>1&&(e=Array.prototype.slice.call(arguments));var i=t(e);if("object"==typeof i)for(var n=i.length,r=0;r<n;r++)i[r]=Math.round(i[r]);return i};return"conversion"in t&&(e.conversion=t.conversion),e}(n),_e[t][i].raw=function(t){var e=function(e){return null==e?e:(arguments.length>1&&(e=Array.prototype.slice.call(arguments)),t(e))};return"conversion"in t&&(e.conversion=t.conversion),e}(n)}))}));var Pe=_e,Ie=te.exports,Oe=Pe,Ee=[].slice,qe=["keyword","gray","hex"],Re={};Object.keys(Oe).forEach((function(t){Re[Ee.call(Oe[t].labels).sort().join("")]=t}));var Ce={};function Ne(t,e){if(!(this instanceof Ne))return new Ne(t,e);if(e&&e in qe&&(e=null),e&&!(e in Oe))throw new Error("Unknown model: "+e);var i,n;if(null==t)this.model="rgb",this.color=[0,0,0],this.valpha=1;else if(t instanceof Ne)this.model=t.model,this.color=t.color.slice(),this.valpha=t.valpha;else if("string"==typeof t){var r=Ie.get(t);if(null===r)throw new Error("Unable to parse color from string: "+t);this.model=r.model,n=Oe[this.model].channels,this.color=r.value.slice(0,n),this.valpha="number"==typeof r.value[n]?r.value[n]:1}else if(t.length){this.model=e||"rgb",n=Oe[this.model].channels;var o=Ee.call(t,0,n);this.color=$e(o,n),this.valpha="number"==typeof t[n]?t[n]:1}else if("number"==typeof t)t&=16777215,this.model="rgb",this.color=[t>>16&255,t>>8&255,255&t],this.valpha=1;else{this.valpha=1;var s=Object.keys(t);"alpha"in t&&(s.splice(s.indexOf("alpha"),1),this.valpha="number"==typeof t.alpha?t.alpha:0);var a=s.sort().join("");if(!(a in Re))throw new Error("Unable to parse color from object: "+JSON.stringify(t));this.model=Re[a];var l=Oe[this.model].labels,u=[];for(i=0;i<l.length;i++)u.push(t[l[i]]);this.color=$e(u)}if(Ce[this.model])for(n=Oe[this.model].channels,i=0;i<n;i++){var c=Ce[this.model][i];c&&(this.color[i]=c(this.color[i]))}this.valpha=Math.max(0,Math.min(1,this.valpha)),Object.freeze&&Object.freeze(this)}function Le(t,e,i){return(t=Array.isArray(t)?t:[t]).forEach((function(t){(Ce[t]||(Ce[t]=[]))[e]=i})),t=t[0],function(n){var r;return arguments.length?(i&&(n=i(n)),(r=this[t]()).color[e]=n,r):(r=this[t]().color[e],i&&(r=i(r)),r)}}function De(t){return function(e){return Math.max(0,Math.min(t,e))}}function Ue(t){return Array.isArray(t)?t:[t]}function $e(t,e){for(var i=0;i<e;i++)"number"!=typeof t[i]&&(t[i]=0);return t}Ne.prototype={toString:function(){return this.string()},toJSON:function(){return this[this.model]()},string:function(t){var e=this.model in Ie.to?this:this.rgb(),i=1===(e=e.round("number"==typeof t?t:1)).valpha?e.color:e.color.concat(this.valpha);return Ie.to[e.model](i)},percentString:function(t){var e=this.rgb().round("number"==typeof t?t:1),i=1===e.valpha?e.color:e.color.concat(this.valpha);return Ie.to.rgb.percent(i)},array:function(){return 1===this.valpha?this.color.slice():this.color.concat(this.valpha)},object:function(){for(var t={},e=Oe[this.model].channels,i=Oe[this.model].labels,n=0;n<e;n++)t[i[n]]=this.color[n];return 1!==this.valpha&&(t.alpha=this.valpha),t},unitArray:function(){var t=this.rgb().color;return t[0]/=255,t[1]/=255,t[2]/=255,1!==this.valpha&&t.push(this.valpha),t},unitObject:function(){var t=this.rgb().object();return t.r/=255,t.g/=255,t.b/=255,1!==this.valpha&&(t.alpha=this.valpha),t},round:function(t){return t=Math.max(t||0,0),new Ne(this.color.map(function(t){return function(e){return function(t,e){return Number(t.toFixed(e))}(e,t)}}(t)).concat(this.valpha),this.model)},alpha:function(t){return arguments.length?new Ne(this.color.concat(Math.max(0,Math.min(1,t))),this.model):this.valpha},red:Le("rgb",0,De(255)),green:Le("rgb",1,De(255)),blue:Le("rgb",2,De(255)),hue:Le(["hsl","hsv","hsl","hwb","hcg"],0,(function(t){return(t%360+360)%360})),saturationl:Le("hsl",1,De(100)),lightness:Le("hsl",2,De(100)),saturationv:Le("hsv",1,De(100)),value:Le("hsv",2,De(100)),chroma:Le("hcg",1,De(100)),gray:Le("hcg",2,De(100)),white:Le("hwb",1,De(100)),wblack:Le("hwb",2,De(100)),cyan:Le("cmyk",0,De(100)),magenta:Le("cmyk",1,De(100)),yellow:Le("cmyk",2,De(100)),black:Le("cmyk",3,De(100)),x:Le("xyz",0,De(100)),y:Le("xyz",1,De(100)),z:Le("xyz",2,De(100)),l:Le("lab",0,De(100)),a:Le("lab",1),b:Le("lab",2),keyword:function(t){return arguments.length?new Ne(t):Oe[this.model].keyword(this.color)},hex:function(t){return arguments.length?new Ne(t):Ie.to.hex(this.rgb().round().color)},rgbNumber:function(){var t=this.rgb().color;return(255&t[0])<<16|(255&t[1])<<8|255&t[2]},luminosity:function(){for(var t=this.rgb().color,e=[],i=0;i<t.length;i++){var n=t[i]/255;e[i]=n<=.03928?n/12.92:Math.pow((n+.055)/1.055,2.4)}return.2126*e[0]+.7152*e[1]+.0722*e[2]},contrast:function(t){var e=this.luminosity(),i=t.luminosity();return e>i?(e+.05)/(i+.05):(i+.05)/(e+.05)},level:function(t){var e=this.contrast(t);return e>=7.1?"AAA":e>=4.5?"AA":""},isDark:function(){var t=this.rgb().color;return(299*t[0]+587*t[1]+114*t[2])/1e3<128},isLight:function(){return!this.isDark()},negate:function(){for(var t=this.rgb(),e=0;e<3;e++)t.color[e]=255-t.color[e];return t},lighten:function(t){var e=this.hsl();return e.color[2]+=e.color[2]*t,e},darken:function(t){var e=this.hsl();return e.color[2]-=e.color[2]*t,e},saturate:function(t){var e=this.hsl();return e.color[1]+=e.color[1]*t,e},desaturate:function(t){var e=this.hsl();return e.color[1]-=e.color[1]*t,e},whiten:function(t){var e=this.hwb();return e.color[1]+=e.color[1]*t,e},blacken:function(t){var e=this.hwb();return e.color[2]+=e.color[2]*t,e},grayscale:function(){var t=this.rgb().color,e=.3*t[0]+.59*t[1]+.11*t[2];return Ne.rgb(e,e,e)},fade:function(t){return this.alpha(this.valpha-this.valpha*t)},opaquer:function(t){return this.alpha(this.valpha+this.valpha*t)},rotate:function(t){var e=this.hsl(),i=e.color[0];return i=(i=(i+t)%360)<0?360+i:i,e.color[0]=i,e},mix:function(t,e){if(!t||!t.rgb)throw new Error(\'Argument to "mix" was not a Color instance, but rather an instance of \'+typeof t);var i=t.rgb(),n=this.rgb(),r=void 0===e?.5:e,o=2*r-1,s=i.alpha()-n.alpha(),a=((o*s==-1?o:(o+s)/(1+o*s))+1)/2,l=1-a;return Ne.rgb(a*i.red()+l*n.red(),a*i.green()+l*n.green(),a*i.blue()+l*n.blue(),i.alpha()*r+n.alpha()*(1-r))}},Object.keys(Oe).forEach((function(t){if(-1===qe.indexOf(t)){var e=Oe[t].channels;Ne.prototype[t]=function(){if(this.model===t)return new Ne(this);if(arguments.length)return new Ne(arguments,t);var i="number"==typeof arguments[e]?e:this.valpha;return new Ne(Ue(Oe[this.model][t].raw(this.color)).concat(i),t)},Ne[t]=function(i){return"number"==typeof i&&(i=$e(Ee.call(arguments),e)),new Ne(i,t)}}}));var We=Ne;class Je{constructor(t,e){this.position=t,this.index=e,this.faces=[],this.neighbors=[]}addUniqueNeighbor(t){-1===this.neighbors.indexOf(t)&&this.neighbors.push(t)}}class He{constructor(t,e,i,n){this.a=n.a,this.b=n.b,this.c=n.c,this.v1=t,this.v2=e,this.v3=i,this.normal=[],this.computeNormal(),t.faces.push(this),t.addUniqueNeighbor(e),t.addUniqueNeighbor(i),e.faces.push(this),e.addUniqueNeighbor(t),e.addUniqueNeighbor(i),i.faces.push(this),i.addUniqueNeighbor(t),i.addUniqueNeighbor(e)}computeNormal(){const t=this.v1.position,e=this.v2.position,i=this.v3.position,n=gt([],bt([],i,e),bt([],t,e));mt(this.normal,n)}hasVertex(t){return t===this.v1||t===this.v2||t===this.v3}}\n/*!\n * Contains code from google filament\n * https://github.com/google/filament/\n * License Apache-2.0\n */const Ge=[],Ve=[],Be=[],Xe=[];function Ze(t,e,i){const n=gt(Ve,e,i);t=Mt(t,function(t,e,i,n,r,o,s,a,l,u){return t[0]=e,t[1]=i,t[2]=n,t[3]=r,t[4]=o,t[5]=s,t[6]=a,t[7]=l,t[8]=u,t}(Ge,i[0],i[1],i[2],...n,...e));if((t=function(t){return t[3]<0?At(t,t,-1):t}(t=Ft(t,t)))[3]<1/32767){t[3]=1/32767;const e=Math.sqrt(.9999999990686206);t[0]*=e,t[1]*=e,t[2]*=e}const r=i[3]>0?gt(Be,i,e):gt(Be,e,i);return yt(gt(Xe,i,e),r)<0&&At(t,t,-1),t}function Ye(t,e){const i=[],n=[];let r=0;for(r=0;r<t.length;r+=3){const e=new Je([t[r],t[r+1],t[r+2]],r/3);i.push(e)}if(!e.length){const t=e;e=[];for(let i=0;i<t;i++)e.push(i)}for(r=0;r<e.length/3;r++){const t={a:e[3*r],b:e[3*r+1],c:e[3*r+2]};new He(i[t.a],i[t.b],i[t.c],t)}const o=[],s=[0,0,0];for(r=0;r<i.length;r++){const t=i[r],e=t.index;dt(s,0,0,0);let a=t.faces.length;for(let e=0;e<a;e++)ft(s,s,t.faces[e].normal);a=a||1,dt(o,a,a,a),pt(s,s,o),n[3*e]=s[0],n[3*e+1]=s[1],n[3*e+2]=s[2]}return n}\n/*!\n * Contains code from THREE.JS\n * https://github.com/mrdoob/three.js/\n * License MIT\n * \n * Generate tangents per vertex.\n */function Ke(t,e,i){return t[0]=e[i],t[1]=e[i+1],t[2]=e[i+2],t}function Qe(t,e,i){return t[0]=e[i],t[1]=e[i+1],t}var ti={exports:{}};function ei(t,e,i){i=i||2;var n,r,o,s,a,l,u,c=e&&e.length,h=c?e[0]*i:t.length,d=ii(t,0,h,i,!0),f=[];if(!d||d.next===d.prev)return f;if(c&&(d=function(t,e,i,n){var r,o,s,a,l,u=[];for(r=0,o=e.length;r<o;r++)s=e[r]*n,a=r<o-1?e[r+1]*n:t.length,(l=ii(t,s,a,n,!1))===l.next&&(l.steiner=!0),u.push(fi(l));for(u.sort(ui),r=0;r<u.length;r++)i=ci(u[r],i);return i}(t,e,d,i)),t.length>80*i){n=o=t[0],r=s=t[1];for(var p=i;p<h;p+=i)(a=t[p])<n&&(n=a),(l=t[p+1])<r&&(r=l),a>o&&(o=a),l>s&&(s=l);u=0!==(u=Math.max(o-n,s-r))?32767/u:0}return ri(d,f,i,n,r,u,0),f}function ii(t,e,i,n,r){var o,s;if(r===Fi(t,e,i,n)>0)for(o=e;o<i;o+=n)s=Mi(o,t[o],t[o+1],s);else for(o=i-n;o>=e;o-=n)s=Mi(o,t[o],t[o+1],s);return s&&gi(s,s.next)&&(ji(s),s=s.next),s}function ni(t,e){if(!t)return t;e||(e=t);var i,n=t;do{if(i=!1,n.steiner||!gi(n,n.next)&&0!==yi(n.prev,n,n.next))n=n.next;else{if(ji(n),(n=e=n.prev)===n.next)break;i=!0}}while(i||n!==e);return e}function ri(t,e,i,n,r,o,s){if(t){!s&&o&&function(t,e,i,n){var r=t;do{0===r.z&&(r.z=di(r.x,r.y,e,i,n)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next}while(r!==t);r.prevZ.nextZ=null,r.prevZ=null,function(t){var e,i,n,r,o,s,a,l,u=1;do{for(i=t,t=null,o=null,s=0;i;){for(s++,n=i,a=0,e=0;e<u&&(a++,n=n.nextZ);e++);for(l=u;a>0||l>0&&n;)0!==a&&(0===l||!n||i.z<=n.z)?(r=i,i=i.nextZ,a--):(r=n,n=n.nextZ,l--),o?o.nextZ=r:t=r,r.prevZ=o,o=r;i=n}o.nextZ=null,u*=2}while(s>1)}(r)}(t,n,r,o);for(var a,l,u=t;t.prev!==t.next;)if(a=t.prev,l=t.next,o?si(t,n,r,o):oi(t))e.push(a.i/i|0),e.push(t.i/i|0),e.push(l.i/i|0),ji(t),t=l.next,u=l.next;else if((t=l)===u){s?1===s?ri(t=ai(ni(t),e,i),e,i,n,r,o,2):2===s&&li(t,e,i,n,r,o):ri(ni(t),e,i,n,r,o,1);break}}}function oi(t){var e=t.prev,i=t,n=t.next;if(yi(e,i,n)>=0)return!1;for(var r=e.x,o=i.x,s=n.x,a=e.y,l=i.y,u=n.y,c=r<o?r<s?r:s:o<s?o:s,h=a<l?a<u?a:u:l<u?l:u,d=r>o?r>s?r:s:o>s?o:s,f=a>l?a>u?a:u:l>u?l:u,p=n.next;p!==e;){if(p.x>=c&&p.x<=d&&p.y>=h&&p.y<=f&&pi(r,a,o,l,s,u,p.x,p.y)&&yi(p.prev,p,p.next)>=0)return!1;p=p.next}return!0}function si(t,e,i,n){var r=t.prev,o=t,s=t.next;if(yi(r,o,s)>=0)return!1;for(var a=r.x,l=o.x,u=s.x,c=r.y,h=o.y,d=s.y,f=a<l?a<u?a:u:l<u?l:u,p=c<h?c<d?c:d:h<d?h:d,m=a>l?a>u?a:u:l>u?l:u,y=c>h?c>d?c:d:h>d?h:d,g=di(f,p,e,i,n),b=di(m,y,e,i,n),v=t.prevZ,w=t.nextZ;v&&v.z>=g&&w&&w.z<=b;){if(v.x>=f&&v.x<=m&&v.y>=p&&v.y<=y&&v!==r&&v!==s&&pi(a,c,l,h,u,d,v.x,v.y)&&yi(v.prev,v,v.next)>=0)return!1;if(v=v.prevZ,w.x>=f&&w.x<=m&&w.y>=p&&w.y<=y&&w!==r&&w!==s&&pi(a,c,l,h,u,d,w.x,w.y)&&yi(w.prev,w,w.next)>=0)return!1;w=w.nextZ}for(;v&&v.z>=g;){if(v.x>=f&&v.x<=m&&v.y>=p&&v.y<=y&&v!==r&&v!==s&&pi(a,c,l,h,u,d,v.x,v.y)&&yi(v.prev,v,v.next)>=0)return!1;v=v.prevZ}for(;w&&w.z<=b;){if(w.x>=f&&w.x<=m&&w.y>=p&&w.y<=y&&w!==r&&w!==s&&pi(a,c,l,h,u,d,w.x,w.y)&&yi(w.prev,w,w.next)>=0)return!1;w=w.nextZ}return!0}function ai(t,e,i){var n=t;do{var r=n.prev,o=n.next.next;!gi(r,o)&&bi(r,n,n.next,o)&&xi(r,o)&&xi(o,r)&&(e.push(r.i/i|0),e.push(n.i/i|0),e.push(o.i/i|0),ji(n),ji(n.next),n=t=o),n=n.next}while(n!==t);return ni(n)}function li(t,e,i,n,r,o){var s=t;do{for(var a=s.next.next;a!==s.prev;){if(s.i!==a.i&&mi(s,a)){var l=ki(s,a);return s=ni(s,s.next),l=ni(l,l.next),ri(s,e,i,n,r,o,0),void ri(l,e,i,n,r,o,0)}a=a.next}s=s.next}while(s!==t)}function ui(t,e){return t.x-e.x}function ci(t,e){var i=function(t,e){var i,n=e,r=t.x,o=t.y,s=-1/0;do{if(o<=n.y&&o>=n.next.y&&n.next.y!==n.y){var a=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(a<=r&&a>s&&(s=a,i=n.x<n.next.x?n:n.next,a===r))return i}n=n.next}while(n!==e);if(!i)return null;var l,u=i,c=i.x,h=i.y,d=1/0;n=i;do{r>=n.x&&n.x>=c&&r!==n.x&&pi(o<h?r:s,o,c,h,o<h?s:r,o,n.x,n.y)&&(l=Math.abs(o-n.y)/(r-n.x),xi(n,t)&&(l<d||l===d&&(n.x>i.x||n.x===i.x&&hi(i,n)))&&(i=n,d=l)),n=n.next}while(n!==u);return i}(t,e);if(!i)return e;var n=ki(i,t);return ni(n,n.next),ni(i,i.next)}function hi(t,e){return yi(t.prev,t,e.prev)<0&&yi(e.next,t,t.next)<0}function di(t,e,i,n,r){return(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-i)*r|0)|t<<8))|t<<4))|t<<2))|t<<1))|(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-n)*r|0)|e<<8))|e<<4))|e<<2))|e<<1))<<1}function fi(t){var e=t,i=t;do{(e.x<i.x||e.x===i.x&&e.y<i.y)&&(i=e),e=e.next}while(e!==t);return i}function pi(t,e,i,n,r,o,s,a){return(r-s)*(e-a)>=(t-s)*(o-a)&&(t-s)*(n-a)>=(i-s)*(e-a)&&(i-s)*(o-a)>=(r-s)*(n-a)}function mi(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!function(t,e){var i=t;do{if(i.i!==t.i&&i.next.i!==t.i&&i.i!==e.i&&i.next.i!==e.i&&bi(i,i.next,t,e))return!0;i=i.next}while(i!==t);return!1}(t,e)&&(xi(t,e)&&xi(e,t)&&function(t,e){var i=t,n=!1,r=(t.x+e.x)/2,o=(t.y+e.y)/2;do{i.y>o!=i.next.y>o&&i.next.y!==i.y&&r<(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x&&(n=!n),i=i.next}while(i!==t);return n}(t,e)&&(yi(t.prev,t,e.prev)||yi(t,e.prev,e))||gi(t,e)&&yi(t.prev,t,t.next)>0&&yi(e.prev,e,e.next)>0)}function yi(t,e,i){return(e.y-t.y)*(i.x-e.x)-(e.x-t.x)*(i.y-e.y)}function gi(t,e){return t.x===e.x&&t.y===e.y}function bi(t,e,i,n){var r=wi(yi(t,e,i)),o=wi(yi(t,e,n)),s=wi(yi(i,n,t)),a=wi(yi(i,n,e));return r!==o&&s!==a||(!(0!==r||!vi(t,i,e))||(!(0!==o||!vi(t,n,e))||(!(0!==s||!vi(i,t,n))||!(0!==a||!vi(i,e,n)))))}function vi(t,e,i){return e.x<=Math.max(t.x,i.x)&&e.x>=Math.min(t.x,i.x)&&e.y<=Math.max(t.y,i.y)&&e.y>=Math.min(t.y,i.y)}function wi(t){return t>0?1:t<0?-1:0}function xi(t,e){return yi(t.prev,t,t.next)<0?yi(t,e,t.next)>=0&&yi(t,t.prev,e)>=0:yi(t,e,t.prev)<0||yi(t,t.next,e)<0}function ki(t,e){var i=new Ai(t.i,t.x,t.y),n=new Ai(e.i,e.x,e.y),r=t.next,o=e.prev;return t.next=e,e.prev=t,i.next=r,r.prev=i,n.next=i,i.prev=n,o.next=n,n.prev=o,n}function Mi(t,e,i,n){var r=new Ai(t,e,i);return n?(r.next=n.next,r.prev=n,n.next.prev=r,n.next=r):(r.prev=r,r.next=r),r}function ji(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function Ai(t,e,i){this.i=t,this.x=e,this.y=i,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}function Fi(t,e,i,n){for(var r=0,o=e,s=i-n;o<i;o+=n)r+=(t[s]-t[o])*(t[o+1]+t[s+1]),s=o;return r}ti.exports=ei,ti.exports.default=ei,ei.deviation=function(t,e,i,n){var r=e&&e.length,o=r?e[0]*i:t.length,s=Math.abs(Fi(t,0,o,i));if(r)for(var a=0,l=e.length;a<l;a++){var u=e[a]*i,c=a<l-1?e[a+1]*i:t.length;s-=Math.abs(Fi(t,u,c,i))}var h=0;for(a=0;a<n.length;a+=3){var d=n[a]*i,f=n[a+1]*i,p=n[a+2]*i;h+=Math.abs((t[d]-t[p])*(t[f+1]-t[d+1])-(t[d]-t[f])*(t[p+1]-t[d+1]))}return 0===s&&0===h?0:Math.abs((h-s)/s)},ei.flatten=function(t){for(var e=t[0][0].length,i={vertices:[],holes:[],dimensions:e},n=0,r=0;r<t.length;r++){for(var o=0;o<t[r].length;o++)for(var s=0;s<e;s++)i.vertices.push(t[r][o][s]);r>0&&(n+=t[r-1].length,i.holes.push(n))}return i};var Ti=ti.exports;\n/*!\n * @maptalks/vector-packer v0.72.1\n * LICENSE : UNLICENSED\n * (c) 2016-2022 maptalks.com\n */const zi={Point:1,LineString:2,Polygon:3,MultiPoint:4,MultiLineString:5,MultiPolygon:6};function Si(t,e={}){var i=[];if("FeatureCollection"===t.type)for(var n=0;n<t.features.length;n++)_i(i,t.features[n],e,n);else _i(i,"Feature"===t.type?t:{geometry:t},e);return i}function _i(t,e,i,n){if(e.geometry&&e.geometry.geometry){var r=e.geometry.coordinates,o=e.geometry.type,s=[],a=e.id;if(i.promoteId?a=e.properties[i.promoteId]:i.generateId&&(a=n||0),"Point"===o)Pi(r,s);else if("MultiPoint"===o)for(var l=0;l<r.length;l++)Pi(r[l],s);else if("LineString"===o)Oi([r],s);else if("MultiLineString"===o){if(i.lineMetrics){for(l=0;l<r.length;l++)Ii(r[l],s=[]),t.push(Ei(a,"LineString",s,e.properties));return}Oi(r,s)}else if("Polygon"===o)Oi(r,s);else{if("MultiPolygon"!==o){if("GeometryCollection"===o){for(l=0;l<e.geometry.geometries.length;l++)_i(t,{id:a,geometry:e.geometry.geometries[l],properties:e.properties},i,n);return}return void console.warn(`Input data type(${o}) is not a valid GeoJSON geometry type.`)}for(l=0;l<r.length;l++){var u=[];Oi(r[l],u),s.push(u)}}t.push(Ei(a,o,s,e.properties))}}function Pi(t,e){const i=new Ot(t[0],t[1]);i.z=100*(t[2]||0),e.push([i])}function Ii(t,e){for(let i=0;i<t.length;i++){const n=new Ot(t[i][0],t[i][1]);n.z=100*(t[i][2]||0),e.push(n)}}function Oi(t,e,i,n){for(var r=0;r<t.length;r++){var o=[];Ii(t[r],o),e.push(o)}}function Ei(t,e,i,n){return{id:void 0===t?null:t,type:zi[e],geometry:i,properties:n}}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n */function qi(t,{width:e,height:i},n,r){if(r){if(r.length!==e*i*n)throw new RangeError("mismatched image size")}else r=new Uint8Array(e*i*n);return t.width=e,t.height=i,t.data=r,t}function Ri(t,{width:e,height:i},n){if(e===t.width&&i===t.height)return;const r=qi({},{width:e,height:i},n);Ci(t,r,{x:0,y:0},{x:0,y:0},{width:Math.min(t.width,e),height:Math.min(t.height,i)},n),t.width=e,t.height=i,t.data=r.data}function Ci(t,e,i,n,r,o){if(0===r.width||0===r.height)return e;if(r.width>t.width||r.height>t.height||i.x>t.width-r.width||i.y>t.height-r.height)throw new RangeError("out of range source coordinates for image copy");if(r.width>e.width||r.height>e.height||n.x>e.width-r.width||n.y>e.height-r.height)throw new RangeError("out of range destination coordinates for image copy");const s=t.data,a=e.data;if(s===a)return e;for(let l=0;l<r.height;l++){const u=((i.y+l)*t.width+i.x)*o,c=((n.y+l)*e.width+n.x)*o;for(let t=0;t<r.width*o;t++)a[c+t]=s[u+t]}return e}class Ni{constructor(t,e){qi(this,t,1,e)}resize(t){Ri(this,t,1)}clone(){return new Ni({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(t,e,i,n,r){Ci(t,e,i,n,r,1)}}class Li{constructor(t,e){qi(this,t,4,e)}resize(t){Ri(this,t,4)}clone(){return new Li({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(t,e,i,n,r){Ci(t,e,i,n,r,4)}}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n */class Di{constructor(t,{pixelRatio:e}){this.paddedRect=t,this.pixelRatio=e||1}get tl(){return[this.paddedRect.x+1,this.paddedRect.y+1]}get br(){return[this.paddedRect.x+this.paddedRect.w-1,this.paddedRect.y+this.paddedRect.h-1]}get displaySize(){return[(this.paddedRect.w-2)/this.pixelRatio,(this.paddedRect.h-2)/this.pixelRatio]}}class Ui{constructor(t){this.glyphMap=t,this.build()}build(){const t=this.glyphMap,e={},i=new qt(0,0,{autoResize:!0}),n=[];for(const i in t){const r=t[i],o={x:0,y:0,w:r.data.width+2,h:r.data.height+2};n.push(o),e[i]=new Di(o,r)}if(i.pack(n,{inPlace:!0}),!$i(i.w)||!$i(i.h)){const t=Wi(i.w),e=Wi(i.h);i.resize(t,e)}const r=new Li({width:i.w,height:i.h});for(const i in t){const n=t[i],o=e[i].paddedRect;Li.copy(n.data,r,{x:0,y:0},{x:o.x+1,y:o.y+1},n.data)}this.image=r,this.positions=e}}function $i(t){return 0==(t&t-1)&&0!==t}function Wi(t){return Math.pow(2,Math.ceil(Math.log(t)/Math.LN2))}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n * TODO 升级为potpack\n */class Ji{constructor(t){this.glyphMap=t,this.build()}build(){const t=this.glyphMap,e={},i=new qt(0,0,{autoResize:!0}),n=[];for(const i in t){const r=t[i],o=e[i]={};for(const t in r){const e=r[+t];if(!e||0===e.bitmap.width||0===e.bitmap.height)continue;const i={x:0,y:0,w:e.bitmap.width+2,h:e.bitmap.height+2};n.push(i),o[t]={rect:i,metrics:e.metrics}}}i.pack(n,{inPlace:!0});const r=new Ni({width:i.w,height:i.h});for(const i in t){const n=t[i];for(const t in n){const o=n[+t];if(!o||0===o.bitmap.width||0===o.bitmap.height)continue;const s=e[i][t].rect;Ni.copy(o.bitmap,r,{x:0,y:0},{x:s.x+1,y:s.y+1},o.bitmap)}}this.image=r,this.positions=e}}function Hi(t){return t<65536?Uint16Array:Uint32Array}function Gi(t){return(t=Math.abs(t))<128?Int8Array:t<32768?Int16Array:Float32Array}function Vi(t){return t<256?Uint8Array:t<65536?Uint16Array:Float32Array}function Bi(t){const e=t.type,i=[];if(1===e||4===e)for(let e=0;e<t.geometry.length;e++)Pi(t.geometry[e],i);else if(2===e)Oi(t.geometry,i);else if(3===e)Oi(t.geometry,i);else if(5===e)Oi(t.geometry,i);else if(6===e)for(let e=0;e<t.geometry.length;e++){const n=[];Oi(t.geometry[e],n),i.push(n)}return t.geometry=i,t}function Xi(t){for(let e=1;e<arguments.length;e++){const i=arguments[e];for(const e in i)t[e]=i[e]}return t}function Zi(t){return null==t}function Yi(t){return"number"==typeof t&&!isNaN(t)}function Ki(t){return"object"==typeof t&&!!t}function Qi(t){return!Zi(t)&&("string"==typeof t||null!==t.constructor&&t.constructor===String)}function tn(t){return!Zi(t)&&("function"==typeof t||null!==t.constructor&&t.constructor===Function)}const en=Object.prototype.hasOwnProperty;function nn(t,e){return en.call(t,e)}const rn=Math.PI/180;function on(t){return t&&s(t)&&t.property}function sn(t){const{pointAtTileRes:e,tileRatio:i}=t;return e*i}function an(t){return"centimeter"===t||"cm"===t?1:"millimeter"===t||"mm"===t?.1:100}function ln(t){let e=0;for(let i,n,r=0,o=t.length,s=o-1;r<o;s=r++)i=t[r],n=t[s],e+=void 0!==i.x?(n.x-i.x)*(i.y+n.y):(n[0]-i[0])*(i[1]+n[1]);return e}function un(t,e,i,n,r){const o=t[e*n],s=t[e*n+1],a=t[i*n],l=t[i*n+1];return o===a&&(o<0||o>r)&&s!==l||s===l&&(s<0||s>r)&&o!==a}function cn(t,e,i){let n=i;return e&&t&&(n=t[e]),void 0===n&&(n=i),100*(n||0)}function hn(t,e,i,n,r,o,s){e||0===e||(e=1);const a=cn(t.properties,i,n),l=a*e;let u=a;return r?u=cn(t.properties,r,o):s&&(u=a-cn(t.properties,s,0)),u*=e,{altitude:l,height:u}}function dn(t,e){return e<1/0&&(t.x<0||t.x>e||t.y<0||t.y>e)}function fn(t){return null==t}function pn(t,e,i){if(t===i||t===e)return t;const n=i-e;return((t-e)%n+n)%n+e}Object.freeze({__proto__:null,now:function(){return Date.now()},extend:Xi,isNil:Zi,isNumber:Yi,isInteger:function(t){return(0|t)===t},isObject:Ki,isString:Qi,isFunction:tn,hasOwn:nn,join:function(t,e){return t.join?t.join(e||","):Array.prototype.join.call(t,e||",")},toRadian:function(t){return t*rn},toDegree:function(t){return t/rn},evaluate:function(t,e,i){return tn(t)?t(void 0!==i?i:null,e):t},isFnTypeSymbol:on,getAltitudeToLocal:sn,getTubeSizeScale:an});class mn{constructor(t,e,i,n){this.feature=t,this.symbol=e,this.fnTypes=i,this.options=n}getPolygonResource(){let t=this.symbol.polygonPatternFile;const{polygonPatternFileFn:e}=this.fnTypes;return this.q(t,e)}getLineResource(){let t=this.symbol.linePatternFile;const{linePatternFileFn:e}=this.fnTypes;return this.q(t,e)}q(t,e){return e&&(t=e(this.options.zoom,this.feature.properties)),t}}function yn(t,e,i,n){const r=Math.abs(n)>>15,o=r>>1,s=r%2;let a=n%Math.pow(2,15);const l=e+(o<<14)*Math.sign(e),u=i+(s<<14)*Math.sign(i);return t[0]=l,t[1]=u,a=Math.round(a),t[2]=0===a?n<0?-1:0:a,t}const gn=Math.pow(2,14),bn=Math.pow(2,15);var vn={$version:8,$root:{version:{required:!0,type:"enum",values:[8],doc:"Style specification version number. Must be 8.",example:8},name:{type:"string",doc:"A human-readable name for the style.",example:"Bright"},metadata:{type:"*",doc:"Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},center:{type:"array",value:"number",doc:"Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:[-73.9749,40.7736]},zoom:{type:"number",doc:"Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:12.5},bearing:{type:"number",default:0,period:360,units:"degrees",doc:\'Default bearing, in degrees. The bearing is the compass direction that is "up"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\',example:29},pitch:{type:"number",default:0,units:"degrees",doc:"Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:50},light:{type:"light",doc:"The global light source.",example:{anchor:"viewport",color:"white",intensity:.4}},terrain:{type:"terrain",doc:"A global modifier that elevates layers and markers based on a DEM data source."},fog:{type:"fog",doc:"A global effect that fades layers and markers based on their distance to the camera. The fog can be used to approximate the effect of atmosphere on distant objects and enhance the depth perception of the map when used with terrain or 3D features."},sources:{required:!0,type:"sources",doc:"Data source specifications.",example:{"mapbox-streets":{type:"vector",url:"mapbox://mapbox.mapbox-streets-v6"}}},sprite:{type:"string",doc:"A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",example:"mapbox://sprites/mapbox/bright-v8"},glyphs:{type:"string",doc:"A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",example:"mapbox://fonts/mapbox/{fontstack}/{range}.pbf"},transition:{type:"transition",doc:"A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style\'s `transition` property.",example:{duration:300,delay:0}},projection:{type:"projection",doc:"The projection the map should be rendered in. Supported projections are Albers, Equal Earth, Equirectangular (WGS84), Lambert conformal conic, Mercator, Natural Earth, and Winkel Tripel. Terrain, fog, sky and CustomLayerInterface are not supported for projections other than mercator.",example:{name:"albers",center:[-154,50],parallels:[55,65]}},layers:{required:!0,type:"array",value:"layer",doc:"Layers will be drawn in the order of this array.",example:[{id:"water",source:"mapbox-streets","source-layer":"water",type:"fill",paint:{"fill-color":"#00ffff"}}]}},sources:{"*":{type:"source",doc:"Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided."}},source:["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],source_vector:{type:{required:!0,type:"enum",values:{vector:{doc:"A vector tile source."}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},scheme:{type:"enum",values:{xyz:{doc:"Slippy map tilenames scheme."},tms:{doc:"OSGeo spec scheme."}},default:"xyz",doc:"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},promoteId:{type:"promoteId",doc:"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{<sourceLayer>: <propertyName>}`. If specified as a string for a vector tile source, the same property is used across all its source layers."},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_raster:{type:{required:!0,type:"enum",values:{raster:{doc:"A raster tile source."}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},tileSize:{type:"number",default:512,units:"pixels",doc:"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},scheme:{type:"enum",values:{xyz:{doc:"Slippy map tilenames scheme."},tms:{doc:"OSGeo spec scheme."}},default:"xyz",doc:"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_raster_dem:{type:{required:!0,type:"enum",values:{"raster-dem":{doc:"A RGB-encoded raster DEM source"}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},tileSize:{type:"number",default:512,units:"pixels",doc:"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},encoding:{type:"enum",values:{terrarium:{doc:"Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info."},mapbox:{doc:"Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info."}},default:"mapbox",doc:"The encoding used by this source. Mapbox Terrain RGB is used by default"},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_geojson:{type:{required:!0,type:"enum",values:{geojson:{doc:"A GeoJSON data source."}},doc:"The data type of the GeoJSON source."},data:{type:"*",doc:"A URL to a GeoJSON file, or inline GeoJSON."},maxzoom:{type:"number",default:18,doc:"Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels)."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},buffer:{type:"number",default:128,maximum:512,minimum:0,doc:"Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance."},filter:{type:"*",doc:"An expression for filtering features prior to processing them for rendering."},tolerance:{type:"number",default:.375,doc:"Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance)."},cluster:{type:"boolean",default:!1,doc:"If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\\n * `cluster` Is `true` if the point is a cluster \\n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\\n * `point_count` Number of original points grouped into this cluster\\n * `point_count_abbreviated` An abbreviated point count"},clusterRadius:{type:"number",default:50,minimum:0,doc:"Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile."},clusterMaxZoom:{type:"number",doc:"Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered). Clusters are re-evaluated at integer zoom levels so setting clusterMaxZoom to 14 means the clusters will be displayed until z15."},clusterMinPoints:{type:"number",doc:"Minimum number of points necessary to form a cluster if clustering is enabled. Defaults to `2`."},clusterProperties:{type:"*",doc:\'An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{"property_name": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `"+"` or `"max"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\\n\\nExample: `{"sum": ["+", ["get", "scalerank"]]}`.\\n\\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `["accumulated"]` value, e.g.:\\n`{"sum": [["+", ["accumulated"], ["get", "sum"]], ["get", "scalerank"]]}`\'},lineMetrics:{type:"boolean",default:!1,doc:"Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values."},generateId:{type:"boolean",default:!1,doc:"Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values."},promoteId:{type:"promoteId",doc:"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{<sourceLayer>: <propertyName>}`."}},source_video:{type:{required:!0,type:"enum",values:{video:{doc:"A video data source."}},doc:"The data type of the video source."},urls:{required:!0,type:"array",value:"string",doc:"URLs to video content in order of preferred format."},coordinates:{required:!0,doc:"Corners of video specified in longitude, latitude pairs.",type:"array",length:4,value:{type:"array",length:2,value:"number",doc:"A single longitude, latitude pair."}}},source_image:{type:{required:!0,type:"enum",values:{image:{doc:"An image data source."}},doc:"The data type of the image source."},url:{required:!0,type:"string",doc:"URL that points to an image."},coordinates:{required:!0,doc:"Corners of image specified in longitude, latitude pairs.",type:"array",length:4,value:{type:"array",length:2,value:"number",doc:"A single longitude, latitude pair."}}},layer:{id:{type:"string",doc:"Unique layer name.",required:!0},type:{type:"enum",values:{fill:{doc:"A filled polygon with an optional stroked border.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},line:{doc:"A stroked line.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},symbol:{doc:"An icon or a text label.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},circle:{doc:"A filled circle.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},heatmap:{doc:"A heatmap.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"fill-extrusion":{doc:"An extruded (3D) polygon.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},raster:{doc:"Raster map textures such as satellite imagery.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},hillshade:{doc:"Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},background:{doc:"The background color or pattern of the map.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},sky:{doc:"A spherical dome around the map that is always rendered behind all other layers.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}}},doc:"Rendering type of this layer.",required:!0},metadata:{type:"*",doc:"Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},source:{type:"string",doc:"Name of a source description to be used for this layer. Required for all layer types except `background`."},"source-layer":{type:"string",doc:"Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources."},minzoom:{type:"number",minimum:0,maximum:24,doc:"The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden."},maxzoom:{type:"number",minimum:0,maximum:24,doc:"The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden."},filter:{type:"filter",doc:\'An expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `["feature-state", ...]` expression is not supported in filter expressions. The `["pitch"]` and `["distance-from-center"]` expressions are supported only for filter expressions on the symbol layer.\'},layout:{type:"layout",doc:"Layout properties for the layer."},paint:{type:"paint",doc:"Default paint properties for this layer."}},layout:["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],layout_background:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_sky:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"constant"}},layout_fill:{"fill-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"},"data-driven styling":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_circle:{"circle-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.2.0",ios:"5.9.0",macos:"0.16.0"},"data-driven styling":{js:"1.2.0",android:"9.2.0",ios:"5.9.0",macos:"0.16.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_heatmap:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},"property-type":"constant"}},"layout_fill-extrusion":{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},"property-type":"constant"}},layout_line:{"line-cap":{type:"enum",values:{butt:{doc:"A cap with a squared-off end which is drawn to the exact endpoint of the line."},round:{doc:"A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},square:{doc:"A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."}},default:"butt",doc:"The display of line endings.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-join":{type:"enum",values:{bevel:{doc:"A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."},round:{doc:"A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},miter:{doc:"A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet."}},default:"miter",doc:"The display of lines when joining.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{type:"number",default:2,doc:"Used to automatically convert miter joins to bevel joins for sharp angles.",requires:[{"line-join":"miter"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-round-limit":{type:"number",default:1.05,doc:"Used to automatically convert round joins to miter joins for shallow angles.",requires:[{"line-join":"round"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"},"data-driven styling":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_symbol:{"symbol-placement":{type:"enum",values:{point:{doc:"The label is placed at the point where the geometry is located."},line:{doc:"The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries."},"line-center":{doc:"The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries."}},default:"point",doc:"Label placement relative to its geometry.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`line-center` value":{js:"0.47.0",android:"6.4.0",ios:"4.3.0",macos:"0.10.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-spacing":{type:"number",default:250,minimum:1,units:"pixels",doc:"Distance between two symbol anchors.",requires:[{"symbol-placement":"line"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{type:"boolean",default:!1,doc:"If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don\'t have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer. When using a client that supports global collision detection, like Mapbox GL JS version 0.42.0 or greater, enabling this property is not needed to prevent clipped labels at tile boundaries.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with lower sort keys are drawn and placed first. When `icon-allow-overlap` or `text-allow-overlap` is `false`, features with a lower sort key will have priority during placement. When `icon-allow-overlap` or `text-allow-overlap` is set to `true`, features with a higher sort key will overlap over features with a lower sort key.","sdk-support":{"basic functionality":{js:"0.53.0",android:"7.4.0",ios:"4.11.0",macos:"0.14.0"},"data-driven styling":{js:"0.53.0",android:"7.4.0",ios:"4.11.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{type:"enum",values:{auto:{doc:"Sorts symbols by `symbol-sort-key` if set. Otherwise, sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},"viewport-y":{doc:"Sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},source:{doc:"Sorts symbols by `symbol-sort-key` if set. Otherwise, no sorting is applied; symbols are rendered in the same order as the source data."}},default:"auto",doc:"Determines whether overlapping symbols in the same layer are rendered in the order that they appear in the data source or by their y-position relative to the viewport. To control the order and prioritization of symbols otherwise, use `symbol-sort-key`.","sdk-support":{"basic functionality":{js:"0.49.0",android:"6.6.0",ios:"4.5.0",macos:"0.12.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{type:"boolean",default:!1,doc:"If true, the icon will be visible even if it collides with other previously drawn symbols.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{type:"boolean",default:!1,doc:"If true, other symbols can be visible even if they collide with the icon.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-optional":{type:"boolean",default:!1,doc:"If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.",requires:["icon-image","text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{type:"enum",values:{map:{doc:"When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line."},viewport:{doc:"Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},auto:{doc:"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},default:"auto",doc:"In combination with `symbol-placement`, determines the rotation behavior of icons.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-size":{type:"number",default:1,minimum:0,units:"factor of the original icon size",doc:"Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{type:"enum",values:{none:{doc:"The icon is displayed at its intrinsic aspect ratio."},width:{doc:"The icon is scaled in the x-dimension to fit the width of the text."},height:{doc:"The icon is scaled in the y-dimension to fit the height of the text."},both:{doc:"The icon is scaled in both x- and y-dimensions."}},default:"none",doc:"Scales the icon to fit around the associated text.",requires:["icon-image","text-field"],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"},"stretchable icons":{js:"1.6.0",android:"9.2.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{type:"array",value:"number",length:4,default:[0,0,0,0],units:"pixels",doc:"Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.",requires:["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-image":{type:"resolvedImage",doc:"Name of image in sprite to use for drawing an image background.",tokens:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{type:"number",default:0,period:360,units:"degrees",doc:"Rotates the icon clockwise.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.21.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{type:"number",default:2,minimum:0,units:"pixels",doc:"Size of the additional area around the icon bounding box used for detecting symbol collisions.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{type:"boolean",default:!1,doc:"If true, the icon may be flipped to prevent it from being rendered upside-down.",requires:["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-offset":{type:"array",value:"number",length:2,default:[0,0],doc:"Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{type:"enum",values:{center:{doc:"The center of the icon is placed closest to the anchor."},left:{doc:"The left side of the icon is placed closest to the anchor."},right:{doc:"The right side of the icon is placed closest to the anchor."},top:{doc:"The top of the icon is placed closest to the anchor."},bottom:{doc:"The bottom of the icon is placed closest to the anchor."},"top-left":{doc:"The top left corner of the icon is placed closest to the anchor."},"top-right":{doc:"The top right corner of the icon is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the icon is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the icon is placed closest to the anchor."}},default:"center",doc:"Part of the icon placed closest to the anchor.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{type:"enum",values:{map:{doc:"The icon is aligned to the plane of the map."},viewport:{doc:"The icon is aligned to the plane of the viewport."},auto:{doc:"Automatically matches the value of `icon-rotation-alignment`."}},default:"auto",doc:"Orientation of icon when map is pitched.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{type:"enum",values:{map:{doc:"The text is aligned to the plane of the map."},viewport:{doc:"The text is aligned to the plane of the viewport."},auto:{doc:"Automatically matches the value of `text-rotation-alignment`."}},default:"auto",doc:"Orientation of text when map is pitched.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{type:"enum",values:{map:{doc:"When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line."},viewport:{doc:"Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},auto:{doc:"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},default:"auto",doc:"In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-field":{type:"formatted",default:"",tokens:!0,doc:"Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options. SDF images are not supported in formatted text and will be ignored.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-font":{type:"array",value:"string",default:["Open Sans Regular","Arial Unicode MS Regular"],doc:"Font stack to use for displaying text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-size":{type:"number",default:16,minimum:0,units:"pixels",doc:"Font size.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{type:"number",default:10,minimum:0,units:"ems",doc:"The maximum line width for text wrapping.",requires:["text-field",{"symbol-placement":["point"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{type:"number",default:1.2,units:"ems",doc:"Text leading value for multi-line text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{type:"number",default:0,units:"ems",doc:"Text tracking amount.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-justify":{type:"enum",values:{auto:{doc:"The text is aligned towards the anchor position."},left:{doc:"The text is aligned to the left."},center:{doc:"The text is centered."},right:{doc:"The text is aligned to the right."}},default:"center",doc:"Text justification options.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"},auto:{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{type:"number",units:"ems",default:0,doc:"Radial offset of text, in the direction of the symbol\'s anchor. Useful in combination with `text-variable-anchor`, which defaults to using the two-dimensional `text-offset` if present.","sdk-support":{"basic functionality":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"},"data-driven styling":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},requires:["text-field"],"property-type":"data-driven",expression:{interpolated:!0,parameters:["zoom","feature"]}},"text-variable-anchor":{type:"array",value:"enum",values:{center:{doc:"The center of the text is placed closest to the anchor."},left:{doc:"The left side of the text is placed closest to the anchor."},right:{doc:"The right side of the text is placed closest to the anchor."},top:{doc:"The top of the text is placed closest to the anchor."},bottom:{doc:"The bottom of the text is placed closest to the anchor."},"top-left":{doc:"The top left corner of the text is placed closest to the anchor."},"top-right":{doc:"The top right corner of the text is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the text is placed closest to the anchor."}},requires:["text-field",{"symbol-placement":["point"]}],doc:"To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the renderer will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` or the two-dimensional `text-offset`.","sdk-support":{"basic functionality":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-anchor":{type:"enum",values:{center:{doc:"The center of the text is placed closest to the anchor."},left:{doc:"The left side of the text is placed closest to the anchor."},right:{doc:"The right side of the text is placed closest to the anchor."},top:{doc:"The top of the text is placed closest to the anchor."},bottom:{doc:"The bottom of the text is placed closest to the anchor."},"top-left":{doc:"The top left corner of the text is placed closest to the anchor."},"top-right":{doc:"The top right corner of the text is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the text is placed closest to the anchor."}},default:"center",doc:"Part of the text placed closest to the anchor.",requires:["text-field",{"!":"text-variable-anchor"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{type:"number",default:45,units:"degrees",doc:"Maximum angle change between adjacent characters.",requires:["text-field",{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-writing-mode":{type:"array",value:"enum",values:{horizontal:{doc:"If a text\'s language supports horizontal writing mode, symbols would be laid out horizontally."},vertical:{doc:"If a text\'s language supports vertical writing mode, symbols would be laid out vertically."}},doc:"The property allows control over a symbol\'s orientation. Note that the property values act as a hint, so that a symbol whose language doesn’t support the provided orientation will be laid out in its natural orientation. Example: English point symbol will be rendered horizontally even if array value contains single \'vertical\' enum value. For symbol with point placement, the order of elements in an array define priority order for the placement of an orientation variant. For symbol with line placement, the default text writing mode is either [\'horizontal\', \'vertical\'] or [\'vertical\', \'horizontal\'], the order doesn\'t affect the placement.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"1.3.0",android:"8.3.0",ios:"5.3.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotate":{type:"number",default:0,period:360,units:"degrees",doc:"Rotates the text clockwise.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-padding":{type:"number",default:2,minimum:0,units:"pixels",doc:"Size of the additional area around the text bounding box used for detecting symbol collisions.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-keep-upright":{type:"boolean",default:!0,doc:"If true, the text may be flipped vertically to prevent it from being rendered upside-down.",requires:["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-transform":{type:"enum",values:{none:{doc:"The text is not altered."},uppercase:{doc:"Forces all letters to be displayed in uppercase."},lowercase:{doc:"Forces all letters to be displayed in lowercase."}},default:"none",doc:"Specifies how to capitalize text, similar to the CSS `text-transform` property.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-offset":{type:"array",doc:"Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up. If used with text-variable-anchor, input values will be taken as absolute values. Offsets along the x- and y-axis will be applied automatically based on the anchor position.",value:"number",units:"ems",length:2,default:[0,0],requires:["text-field",{"!":"text-radial-offset"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{type:"boolean",default:!1,doc:"If true, the text will be visible even if it collides with other previously drawn symbols.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{type:"boolean",default:!1,doc:"If true, other symbols can be visible even if they collide with the text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-optional":{type:"boolean",default:!1,doc:"If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.",requires:["text-field","icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_raster:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_hillshade:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},"property-type":"constant"}},filter:{type:"array",value:"*",doc:"A filter selects specific features from a layer."},filter_symbol:{type:"boolean",doc:\'Expression which determines whether or not to display a symbol. Symbols support dynamic filtering, meaning this expression can use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature","pitch","distance-from-center"]}},filter_fill:{type:"boolean",doc:\'Expression which determines whether or not to display a polygon. Fill layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_line:{type:"boolean",doc:\'Expression which determines whether or not to display a Polygon or LineString. Line layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_circle:{type:"boolean",doc:\'Expression which determines whether or not to display a circle. Circle layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},"filter_fill-extrusion":{type:"boolean",doc:\'Expression which determines whether or not to display a Polygon. Fill-extrusion layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_heatmap:{type:"boolean",doc:\'Expression used to determine whether a point is being displayed or not. Heatmap layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_operator:{type:"enum",values:{"==":{doc:\'`["==", key, value]` equality: `feature[key] = value`\'},"!=":{doc:\'`["!=", key, value]` inequality: `feature[key] ≠ value`\'},">":{doc:\'`[">", key, value]` greater than: `feature[key] > value`\'},">=":{doc:\'`[">=", key, value]` greater than or equal: `feature[key] ≥ value`\'},"<":{doc:\'`["<", key, value]` less than: `feature[key] < value`\'},"<=":{doc:\'`["<=", key, value]` less than or equal: `feature[key] ≤ value`\'},in:{doc:\'`["in", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`\'},"!in":{doc:\'`["!in", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`\'},all:{doc:\'`["all", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`\'},any:{doc:\'`["any", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`\'},none:{doc:\'`["none", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`\'},has:{doc:\'`["has", key]` `feature[key]` exists\'},"!has":{doc:\'`["!has", key]` `feature[key]` does not exist\'},within:{doc:\'`["within", object]` feature geometry is within object geometry\'}},doc:"The filter operator."},geometry_type:{type:"enum",values:{Point:{doc:"Filter to point geometries."},LineString:{doc:"Filter to line geometries."},Polygon:{doc:"Filter to polygon geometries."}},doc:"The geometry type for the filter to select."},function:{expression:{type:"expression",doc:"An expression."},stops:{type:"array",doc:"An array of stops.",value:"function_stop"},base:{type:"number",default:1,minimum:0,doc:"The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly."},property:{type:"string",doc:"The name of a feature property to use as the function input.",default:"$zoom"},type:{type:"enum",values:{identity:{doc:"Return the input value as the output value."},exponential:{doc:"Generate an output by interpolating between stops just less than and just greater than the function input."},interval:{doc:"Return the output value of the stop just less than the function input."},categorical:{doc:"Return the output value of the stop equal to the function input."}},doc:"The interpolation strategy to use in function evaluation.",default:"exponential"},colorSpace:{type:"enum",values:{rgb:{doc:"Use the RGB color space to interpolate color values"},lab:{doc:"Use the LAB color space to interpolate color values."},hcl:{doc:"Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually."}},doc:"The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.",default:"rgb"},default:{type:"*",required:!1,doc:"A value to serve as a fallback function result when a value isn\'t otherwise available. It is used in the following circumstances:\\n* In categorical functions, when the feature value does not match any of the stop domain values.\\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\\nIf no default is provided, the style property\'s default is used in these circumstances."}},function_stop:{type:"array",minimum:0,maximum:24,value:["number","color"],length:2,doc:"Zoom level and value pair."},expression:{type:"array",value:"*",minimum:1,doc:"An expression defines a function that can be used for data-driven style properties or feature filters."},expression_name:{doc:"",type:"enum",values:{let:{doc:\'Binds expressions to named variables, which can then be referenced in the result expression using ["var", "variable_name"].\',group:"Variable binding","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},var:{doc:\'References variable bound using "let".\',group:"Variable binding","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},literal:{doc:"Provides a literal array or object value.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},array:{doc:"Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},at:{doc:"Retrieves an item from an array.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},in:{doc:"Determines whether an item exists in an array or a substring exists in a string. In the specific case when the second and third arguments are string literals, you must wrap at least one of them in a [`literal`](#types-literal) expression to hint correct interpretation to the [type system](#type-system).",group:"Lookup","sdk-support":{"basic functionality":{js:"1.6.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}}},"index-of":{doc:"Returns the first position at which an item can be found in an array or a substring can be found in a string, or `-1` if the input cannot be found. Accepts an optional index from where to begin the search.",group:"Lookup","sdk-support":{"basic functionality":{js:"1.10.0"}}},slice:{doc:"Returns an item from an array or a substring from a string from a specified start index, or between a start index and an end index if set. The return value is inclusive of the start index but not of the end index.",group:"Lookup","sdk-support":{"basic functionality":{js:"1.10.0"}}},case:{doc:"Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},match:{doc:\'Selects the output for which the label value matches the input value, or the fallback value if no match is found. The input can be any expression (for example, `["get", "building_type"]`). Each label must be unique, and must be either:\\n - a single literal value; or\\n - an array of literal values, the values of which must be all strings or all numbers (for example `[100, 101]` or `["c", "b"]`).\\n\\nThe input matches if any of the values in the array matches using strict equality, similar to the `"in"` operator.\\nIf the input type does not match the type of the labels, the result will be the fallback value.\',group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},coalesce:{doc:"Evaluates each expression in turn until the first valid value is obtained. Invalid values are `null` and [`\'image\'`](#types-image) expressions that are unavailable in the style. If all values are invalid, `coalesce` returns the first value listed.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},step:{doc:\'Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first output if the input is less than the first stop.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},interpolate:{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array<number>`, or `color`.\\n\\nInterpolation types:\\n- `["linear"]`: Interpolates linearly between the pair of stops just less than and just greater than the input.\\n- `["exponential", base]`: Interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\\n- `["cubic-bezier", x1, y1, x2, y2]`: Interpolates using the cubic bezier curve defined by the given control points.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"interpolate-hcl":{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.49.0"}}},"interpolate-lab":{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.49.0"}}},ln2:{doc:"Returns mathematical constant ln(2).",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},pi:{doc:"Returns the mathematical constant pi.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},e:{doc:"Returns the mathematical constant e.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},typeof:{doc:"Returns a string describing the type of the given value.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},string:{doc:"Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},number:{doc:"Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},boolean:{doc:"Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},object:{doc:"Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},collator:{doc:"Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.",group:"Types","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},format:{doc:\'Returns a `formatted` string for displaying mixed-format text in the `text-field` property. The input may contain a string literal or expression, including an [`\\\'image\\\'`](#types-image) expression. Strings may be followed by a style override object that supports the following properties:\\n- `"text-font"`: Overrides the font stack specified by the root layout property.\\n- `"text-color"`: Overrides the color specified by the root paint property.\\n- `"font-scale"`: Applies a scaling factor on `text-size` as specified by the root layout property.\',group:"Types","sdk-support":{"basic functionality":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"text-font":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"font-scale":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"text-color":{js:"1.3.0",android:"7.3.0",ios:"4.10.0",macos:"0.14.0"},image:{js:"1.6.0",android:"8.6.0",ios:"5.7.0",macos:"0.15.0"}}},image:{doc:"Returns a [`ResolvedImage`](/mapbox-gl-js/style-spec/types/#resolvedimage) for use in [`icon-image`](/mapbox-gl-js/style-spec/layers/#layout-symbol-icon-image), `*-pattern` entries, and as a section in the [`\'format\'`](#types-format) expression. A [`\'coalesce\'`](#coalesce) expression containing `image` expressions will evaluate to the first listed image that is currently in the style. This validation process is synchronous and requires the image to have been added to the style before requesting it in the `\'image\'` argument.",group:"Types","sdk-support":{"basic functionality":{js:"1.4.0",android:"8.6.0",ios:"5.7.0",macos:"0.15.0"}}},"number-format":{doc:"Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.",group:"Types","sdk-support":{"basic functionality":{js:"0.54.0",android:"8.4.0",ios:"5.4.0",macos:"0.15.0"}}},"to-string":{doc:\'Converts the input value to a string. If the input is `null`, the result is `""`. If the input is a [`boolean`](#types-boolean), the result is `"true"` or `"false"`. If the input is a number, it is converted to a string as specified by the ["NumberToString" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a [`color`](#color), it is converted to a string of the form `"rgba(r,g,b,a)"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. If the input is an [`\\\'image\\\'`](#types-image) expression, `\\\'to-string\\\'` returns the image name. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.\',group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-number":{doc:\'Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the ["ToNumber Applied to the String Type" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\',group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-boolean":{doc:"Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-rgba":{doc:"Returns a four-element array containing the input color\'s red, green, blue, and alpha components, in that order.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-color":{doc:"Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},rgb:{doc:"Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},rgba:{doc:"Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},get:{doc:"Retrieves a property value from the current feature\'s properties, or from another object if a second argument is provided. Returns `null` if the requested property is missing.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},has:{doc:"Tests for the presence of an property value in the current feature\'s properties, or from another object if a second argument is provided.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},length:{doc:"Returns the length of an array or string.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},properties:{doc:\'Returns the feature properties object. Note that in some cases, it may be more efficient to use `["get", "property_name"]` directly.\',group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"feature-state":{doc:"Retrieves a property value from the current feature\'s state. Returns `null` if the requested property is not present on the feature\'s state. A feature\'s state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Features are identified by their `id` attribute, which must be an integer or a string that can be cast to an integer. Note that [\\"feature-state\\"] can only be used with paint properties that support data-driven styling.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.46.0"}}},"geometry-type":{doc:"Returns the feature\'s geometry type: `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`. `Multi*` feature types are only returned in GeoJSON sources. When working with vector tile sources, use the singular forms.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},id:{doc:"Returns the feature\'s id, if it has one.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},zoom:{doc:\'Returns the current zoom level. Note that in style layout and paint properties, ["zoom"] may only appear as the input to a top-level "step" or "interpolate" expression.\',group:"Camera","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},pitch:{doc:\'Returns the current pitch in degrees. `["pitch"]` may only be used in the `filter` expression for a `symbol` layer.\',group:"Camera","sdk-support":{"basic functionality":{js:"2.6.0"}}},"distance-from-center":{doc:\'Returns the distance of a `symbol` instance from the center of the map. The distance is measured in pixels divided by the height of the map container. It measures 0 at the center, decreases towards the camera and increase away from the camera. For example, if the height of the map is 1000px, a value of -1 means 1000px away from the center towards the camera, and a value of 1 means a distance of 1000px away from the camera from the center. `["distance-from-center"]` may only be used in the `filter` expression for a `symbol` layer.\',group:"Camera","sdk-support":{"basic functionality":{js:"2.6.0"}}},"heatmap-density":{doc:"Returns the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.",group:"Heatmap","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"line-progress":{doc:"Returns the progress along a gradient line. Can only be used in the `line-gradient` property.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.6.0",macos:"0.12.0"}}},"sky-radial-progress":{doc:"Returns the distance of a point on the sky from the sun position. Returns 0 at sun position and 1 when the distance reaches `sky-gradient-radius`. Can only be used in the `sky-gradient` property.",group:"sky","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}},accumulated:{doc:"Returns the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.53.0",android:"8.4.0",ios:"5.5.0",macos:"0.15.0"}}},"+":{doc:"Returns the sum of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"*":{doc:"Returns the product of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"-":{doc:"For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"/":{doc:"Returns the result of floating point division of the first input by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"%":{doc:"Returns the remainder after integer division of the first input by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"^":{doc:"Returns the result of raising the first input to the power specified by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},sqrt:{doc:"Returns the square root of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},log10:{doc:"Returns the base-ten logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},ln:{doc:"Returns the natural logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},log2:{doc:"Returns the base-two logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},sin:{doc:"Returns the sine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},cos:{doc:"Returns the cosine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},tan:{doc:"Returns the tangent of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},asin:{doc:"Returns the arcsine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},acos:{doc:"Returns the arccosine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},atan:{doc:"Returns the arctangent of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},min:{doc:"Returns the minimum value of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},max:{doc:"Returns the maximum value of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},round:{doc:\'Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `["round", -1.5]` evaluates to -2.\',group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},abs:{doc:"Returns the absolute value of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},ceil:{doc:"Returns the smallest integer that is greater than or equal to the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},floor:{doc:"Returns the largest integer that is less than or equal to the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},distance:{doc:"Returns the shortest distance in meters between the evaluated feature and the input geometry. The input value can be a valid GeoJSON of type `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Distance values returned may vary in precision due to loss in precision from encoding geometries, particularly below zoom level 13.",group:"Math","sdk-support":{"basic functionality":{android:"9.2.0",ios:"5.9.0",macos:"0.16.0"}}},"==":{doc:"Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"!=":{doc:"Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},">":{doc:"Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"<":{doc:"Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},">=":{doc:"Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"<=":{doc:"Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},all:{doc:"Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},any:{doc:"Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"!":{doc:"Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},within:{doc:"Returns `true` if the evaluated feature is fully contained inside a boundary of the input geometry, `false` otherwise. The input value can be a valid GeoJSON of type `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Supported features for evaluation:\\n- `Point`: Returns `false` if a point is on the boundary or falls outside the boundary.\\n- `LineString`: Returns `false` if any part of a line falls outside the boundary, the line intersects the boundary, or a line\'s endpoint is on the boundary.",group:"Decision","sdk-support":{"basic functionality":{js:"1.9.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}}},"is-supported-script":{doc:"Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).",group:"String","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.6.0"}}},upcase:{doc:"Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},downcase:{doc:"Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},concat:{doc:"Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"resolved-locale":{doc:"Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.",group:"String","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}}}},fog:{range:{type:"array",default:[.5,10],minimum:-20,maximum:20,length:2,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},doc:"The start and end distance range in which fog fades from fully transparent to fully opaque. The distance to the point at the center of the map is defined as zero, so that negative range values are closer to the camera, and positive values are farther away.",example:[.5,10],"sdk-support":{"basic functionality":{js:"2.3.0"}}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"The color of the fog. Using opacity is recommended only for smoothly transitioning fog on/off as anything less than 100% opacity results in more tiles loaded and drawn.","sdk-support":{"basic functionality":{js:"2.3.0"}}},"horizon-blend":{type:"number","property-type":"data-constant",default:.1,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Horizon blend applies a smooth fade from the color of the fog to the color of the sky. A value of zero leaves a sharp transition from fog to sky. Increasing the value blends the color of fog into increasingly high angles of the sky.","sdk-support":{"basic functionality":{js:"2.3.0"}}}},light:{anchor:{type:"enum",default:"viewport",values:{map:{doc:"The position of the light source is aligned to the rotation of the map."},viewport:{doc:"The position of the light source is aligned to the rotation of the viewport."}},"property-type":"data-constant",transition:!1,expression:{interpolated:!1,parameters:["zoom"]},doc:"Whether extruded geometries are lit relative to the map or viewport.",example:"map","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},position:{type:"array",default:[1.15,210,30],length:3,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},doc:"Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).",example:[1.5,90,80],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Color tint for lighting extruded geometries.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},intensity:{type:"number","property-type":"data-constant",default:.5,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}}},projection:{name:{type:"enum",values:{albers:{doc:"An Albers equal-area projection centered on the continental United States. You can configure the projection for a different region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},equalEarth:{doc:"An Equal Earth projection."},equirectangular:{doc:"An Equirectangular projection. This projection is very similar to the Plate Carrée projection."},lambertConformalConic:{doc:"A Lambert conformal conic projection. You can configure the projection for a region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},mercator:{doc:"The Mercator projection is the default projection."},naturalEarth:{doc:"A Natural Earth projection."},winkelTripel:{doc:"A Winkel Tripel projection."}},default:"mercator",doc:"The name of the projection to be used for rendering the map.",required:!0,"sdk-support":{"basic functionality":{js:"2.6.0"}}},center:{type:"array",length:2,value:"number","property-type":"data-constant",transition:!1,doc:"The reference longitude and latitude of the projection. `center` takes the form of [lng, lat]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic). All other projections are centered on [0, 0].",example:[-96,37.5],requires:[{name:["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{js:"2.6.0"}}},parallels:{type:"array",length:2,value:"number","property-type":"data-constant",transition:!1,doc:"The standard parallels of the projection, denoting the desired latitude range with minimal distortion. `parallels` takes the form of [lat0, lat1]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic).",example:[29.5,45.5],requires:[{name:["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{js:"2.6.0"}}}},terrain:{source:{type:"string",doc:"Name of a source of `raster_dem` type to be used for terrain elevation.",required:!0,"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}},exaggeration:{type:"number","property-type":"data-constant",default:1,minimum:0,maximum:1e3,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Exaggerates the elevation of the terrain by multiplying the data from the DEM with this value.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}}},paint:["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],paint_fill:{"fill-antialias":{type:"boolean",default:!0,doc:"Whether or not the fill should be antialiased.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.21.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{type:"color",default:"#000000",doc:"The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color\'s opacity will not affect the opacity of the 1px stroke, if it is used.",transition:!0,requires:[{"!":"fill-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.19.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{type:"color",doc:"The outline color of the fill. Matches the value of `fill-color` if unspecified.",transition:!0,requires:[{"!":"fill-pattern"},{"fill-antialias":!0}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.19.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{type:"enum",values:{map:{doc:"The fill is translated relative to the map."},viewport:{doc:"The fill is translated relative to the viewport."}},doc:"Controls the frame of reference for `fill-translate`.",default:"map",requires:["fill-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.",transition:!0,"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{type:"color",default:"#000000",doc:"The base color of the extruded fill. The extrusion\'s surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.",transition:!0,requires:[{"!":"fill-extrusion-pattern"}],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{type:"enum",values:{map:{doc:"The fill extrusion is translated relative to the map."},viewport:{doc:"The fill extrusion is translated relative to the viewport."}},doc:"Controls the frame of reference for `fill-extrusion-translate`.",default:"map",requires:["fill-extrusion-translate"],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"fill-extrusion-height":{type:"number",default:0,minimum:0,units:"meters",doc:"The height with which to extrude this layer.",transition:!0,"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{type:"number",default:0,minimum:0,units:"meters",doc:"The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.",transition:!0,requires:["fill-extrusion-height"],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{type:"boolean",default:!0,doc:"Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.",transition:!1,"sdk-support":{"basic functionality":{js:"0.50.0",android:"7.0.0",ios:"4.7.0",macos:"0.13.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_line:{"line-opacity":{type:"number",doc:"The opacity at which the line will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{type:"color",doc:"The color with which the line will be drawn.",default:"#000000",transition:!0,requires:[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.23.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{type:"enum",values:{map:{doc:"The line is translated relative to the map."},viewport:{doc:"The line is translated relative to the viewport."}},doc:"Controls the frame of reference for `line-translate`.",default:"map",requires:["line-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"line-width":{type:"number",default:1,minimum:0,transition:!0,units:"pixels",doc:"Stroke thickness.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{type:"number",default:0,minimum:0,doc:"Draws a line casing outside of a line\'s actual path. Value indicates the width of the inner gap.",transition:!0,units:"pixels","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{type:"number",default:0,doc:"The line\'s offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.",transition:!0,units:"pixels","sdk-support":{"basic functionality":{js:"0.12.1",android:"3.0.0",ios:"3.1.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Blur applied to the line, in pixels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{type:"array",value:"number",doc:"Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won\'t render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.",minimum:0,transition:!0,units:"line widths",requires:[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"line-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"line-gradient":{type:"color",doc:\'Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `"lineMetrics": true`.\',transition:!1,requires:[{"!":"line-pattern"},{source:"geojson",has:{lineMetrics:!0}}],"sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.4.0",macos:"0.11.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["line-progress"]},"property-type":"color-ramp"}},paint_circle:{"circle-radius":{type:"number",default:5,minimum:0,transition:!0,units:"pixels",doc:"Circle radius.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.18.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{type:"color",default:"#000000",doc:"The fill color of the circle.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.18.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{type:"number",default:0,doc:"Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.20.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{type:"number",doc:"The opacity at which the circle will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.20.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{type:"enum",values:{map:{doc:"The circle is translated relative to the map."},viewport:{doc:"The circle is translated relative to the viewport."}},doc:"Controls the frame of reference for `circle-translate`.",default:"map",requires:["circle-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{type:"enum",values:{map:{doc:"Circles are scaled according to their apparent distance to the camera."},viewport:{doc:"Circles are not scaled."}},default:"map",doc:"Controls the scaling behavior of the circle when the map is pitched.","sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{type:"enum",values:{map:{doc:"The circle is aligned to the plane of the map."},viewport:{doc:"The circle is aligned to the plane of the viewport."}},default:"viewport",doc:"Orientation of circle when map is pitched.","sdk-support":{"basic functionality":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"The width of the circle\'s stroke. Strokes are placed outside of the `circle-radius`.","sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{type:"color",default:"#000000",doc:"The stroke color of the circle.",transition:!0,"sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{type:"number",doc:"The opacity of the circle\'s stroke.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"}},paint_heatmap:{"heatmap-radius":{type:"number",default:30,minimum:1,transition:!0,units:"pixels",doc:"Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed. `queryRenderedFeatures` on heatmap layers will return points within this radius.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{type:"number",default:1,minimum:0,transition:!1,doc:"A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{type:"number",default:1,minimum:0,transition:!0,doc:"Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"heatmap-color":{type:"color",default:["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",.1,"royalblue",.3,"cyan",.5,"lime",.7,"yellow",1,"red"],doc:\'Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `["heatmap-density"]` as input.\',transition:!1,"sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{type:"number",doc:"The global opacity at which the heatmap layer will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_symbol:{"icon-opacity":{doc:"The opacity at which the icon will be drawn.",type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{type:"color",default:"#000000",transition:!0,doc:"The color of the icon. This can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,doc:"The color of the icon\'s halo. Icon halos can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Distance of halo to the icon outline.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Fade out the halo towards the outside.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"Distance that the icon\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{type:"enum",values:{map:{doc:"Icons are translated relative to the map."},viewport:{doc:"Icons are translated relative to the viewport."}},doc:"Controls the frame of reference for `icon-translate`.",default:"map",requires:["icon-image","icon-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-opacity":{type:"number",doc:"The opacity at which the text will be drawn.",default:1,minimum:0,maximum:1,transition:!0,requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{type:"color",doc:"The color with which the text will be drawn.",default:"#000000",transition:!0,overridable:!0,requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,doc:"The color of the text\'s halo, which helps it stand out from backgrounds.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"The halo\'s fadeout distance towards the outside.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"Distance that the text\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{type:"enum",values:{map:{doc:"The text is translated relative to the map."},viewport:{doc:"The text is translated relative to the viewport."}},doc:"Controls the frame of reference for `text-translate`.",default:"map",requires:["text-field","text-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_raster:{"raster-opacity":{type:"number",doc:"The opacity at which the image will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{type:"number",default:0,period:360,transition:!0,units:"degrees",doc:"Rotates hues around the color wheel.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{type:"number",doc:"Increase or reduce the brightness of the image. The value is the minimum brightness.",default:0,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{type:"number",doc:"Increase or reduce the brightness of the image. The value is the maximum brightness.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-saturation":{type:"number",doc:"Increase or reduce the saturation of the image.",default:0,minimum:-1,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-contrast":{type:"number",doc:"Increase or reduce the contrast of the image.",default:0,minimum:-1,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-resampling":{type:"enum",doc:"The resampling/interpolation method to use for overscaling, also known as texture magnification filter",values:{linear:{doc:"(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled"},nearest:{doc:"Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled"}},default:"linear","sdk-support":{"basic functionality":{js:"0.47.0",android:"6.3.0",ios:"4.2.0",macos:"0.9.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{type:"number",default:300,minimum:0,transition:!1,units:"milliseconds",doc:"Fade duration when a new tile is added.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_hillshade:{"hillshade-illumination-direction":{type:"number",default:335,minimum:0,maximum:359,doc:"The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.",transition:!1,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{type:"enum",values:{map:{doc:"The hillshade illumination is relative to the north direction."},viewport:{doc:"The hillshade illumination is relative to the top of the viewport."}},default:"viewport",doc:"Direction of light source when map is rotated.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{type:"number",doc:"Intensity of the hillshade",default:.5,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{type:"color",default:"#000000",doc:"The shading color of areas that face away from the light source.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{type:"color",default:"#FFFFFF",doc:"The shading color of areas that faces towards the light source.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{type:"color",default:"#000000",doc:"The shading color used to accentuate rugged terrain like sharp cliffs and gorges.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_background:{"background-color":{type:"color",default:"#000000",doc:"The color with which the background will be drawn.",transition:!0,requires:[{"!":"background-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"background-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"cross-faded"},"background-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity at which the background will be drawn.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_sky:{"sky-type":{type:"enum",values:{gradient:{doc:"Renders the sky with a gradient that can be configured with `sky-gradient-radius` and `sky-gradient`."},atmosphere:{doc:"Renders the sky with a simulated atmospheric scattering algorithm, the sun direction can be attached to the light position or explicitly set through `sky-atmosphere-sun`."}},default:"atmosphere",doc:"The type of the sky","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{type:"array",value:"number",length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,doc:"Position of the sun center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the sun relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the sun, where 0° is directly above, at zenith, and 90° at the horizon. When this property is ommitted, the sun center is directly inherited from the light position.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},requires:[{"sky-type":"atmosphere"}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{type:"number",requires:[{"sky-type":"atmosphere"}],default:10,minimum:0,maximum:100,transition:!1,doc:"Intensity of the sun as a light source in the atmosphere (on a scale from 0 to a 100). Setting higher values will brighten up the sky.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-gradient-center":{type:"array",requires:[{"sky-type":"gradient"}],value:"number",default:[0,0],length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,doc:"Position of the gradient center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the gradient center relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the gradient center, where 0° is directly above, at zenith, and 90° at the horizon.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{type:"number",requires:[{"sky-type":"gradient"}],default:90,minimum:0,maximum:180,transition:!1,doc:"The angular distance (measured in degrees) from `sky-gradient-center` up to which the gradient extends. A value of 180 causes the gradient to wrap around to the opposite direction from `sky-gradient-center`.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient":{type:"color",default:["interpolate",["linear"],["sky-radial-progress"],.8,"#87ceeb",1,"white"],doc:"Defines a radial color gradient with which to color the sky. The color values can be interpolated with an expression using `sky-radial-progress`. The range [0, 1] for the interpolant covers a radial distance (in degrees) of [0, `sky-gradient-radius`] centered at the position specified by `sky-gradient-center`.",transition:!1,requires:[{"sky-type":"gradient"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{type:"color",default:"white",doc:"A color applied to the atmosphere sun halo. The alpha channel describes how strongly the sun halo is represented in an atmosphere sky layer.",transition:!1,requires:[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-atmosphere-color":{type:"color",default:"white",doc:"A color used to tweak the main atmospheric scattering coefficients. Using white applies the default coefficients giving the natural blue color to the atmosphere. This color affects how heavily the corresponding wavelength is represented during scattering. The alpha channel describes the density of the atmosphere, with 1 maximum density and 0 no density.",transition:!1,requires:[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire sky layer.",transition:!0,"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},transition:{duration:{type:"number",default:300,minimum:0,units:"milliseconds",doc:"Time allotted for transitions to complete."},delay:{type:"number",default:0,minimum:0,units:"milliseconds",doc:"Length of time before a transition begins."}},"property-type":{"data-driven":{type:"property-type",doc:"Property is interpolable and can be represented using a property expression."},"cross-faded":{type:"property-type",doc:"Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms."},"cross-faded-data-driven":{type:"property-type",doc:"Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms. It can be represented using a property expression."},"color-ramp":{type:"property-type",doc:"Property should be specified using a color ramp from which the output color can be sampled based on a property calculation."},"data-constant":{type:"property-type",doc:"Property is interpolable but cannot be represented using a property expression."},constant:{type:"property-type",doc:"Property is constant across all zoom levels and property values."}},promoteId:{"*":{type:"string",doc:"A name of a feature property to use as ID for feature state."}}},wn="undefined"!=typeof undefinedThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof undefined?global:"undefined"!=typeof self?self:{};function xn(t){var e={exports:{}};return t(e,e.exports),e.exports}function kn(t,e){return Object.prototype.hasOwnProperty.call(t,e)}\n/*! https://mths.be/punycode v1.3.2 by @mathias */xn((function(t,e){!function(i){var n=e&&!e.nodeType&&e,r=t&&!t.nodeType&&t,o="object"==typeof wn&&wn;o.global!==o&&o.window!==o&&o.self!==o||(i=o);var s,a,l=2147483647,u=/^xn--/,c=/[^\\x20-\\x7E]/,h=/[\\x2E\\u3002\\uFF0E\\uFF61]/g,d={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},f=Math.floor,p=String.fromCharCode;function m(t){throw RangeError(d[t])}function y(t,e){for(var i=t.length,n=[];i--;)n[i]=e(t[i]);return n}function g(t,e){var i=t.split("@"),n="";return i.length>1&&(n=i[0]+"@",t=i[1]),n+y((t=t.replace(h,".")).split("."),e).join(".")}function b(t){for(var e,i,n=[],r=0,o=t.length;r<o;)(e=t.charCodeAt(r++))>=55296&&e<=56319&&r<o?56320==(64512&(i=t.charCodeAt(r++)))?n.push(((1023&e)<<10)+(1023&i)+65536):(n.push(e),r--):n.push(e);return n}function v(t){return y(t,(function(t){var e="";return t>65535&&(e+=p((t-=65536)>>>10&1023|55296),t=56320|1023&t),e+p(t)})).join("")}function w(t,e){return t+22+75*(t<26)-((0!=e)<<5)}function x(t,e,i){var n=0;for(t=i?f(t/700):t>>1,t+=f(t/e);t>455;n+=36)t=f(t/35);return f(n+36*t/(t+38))}function k(t){var e,i,n,r,o,s,a,u,c,h,d,p=[],y=t.length,g=0,b=128,w=72;for((i=t.lastIndexOf("-"))<0&&(i=0),n=0;n<i;++n)t.charCodeAt(n)>=128&&m("not-basic"),p.push(t.charCodeAt(n));for(r=i>0?i+1:0;r<y;){for(o=g,s=1,a=36;r>=y&&m("invalid-input"),((u=(d=t.charCodeAt(r++))-48<10?d-22:d-65<26?d-65:d-97<26?d-97:36)>=36||u>f((l-g)/s))&&m("overflow"),g+=u*s,!(u<(c=a<=w?1:a>=w+26?26:a-w));a+=36)s>f(l/(h=36-c))&&m("overflow"),s*=h;w=x(g-o,e=p.length+1,0==o),f(g/e)>l-b&&m("overflow"),b+=f(g/e),g%=e,p.splice(g++,0,b)}return v(p)}function M(t){var e,i,n,r,o,s,a,u,c,h,d,y,g,v,k,M=[];for(y=(t=b(t)).length,e=128,i=0,o=72,s=0;s<y;++s)(d=t[s])<128&&M.push(p(d));for(n=r=M.length,r&&M.push("-");n<y;){for(a=l,s=0;s<y;++s)(d=t[s])>=e&&d<a&&(a=d);for(a-e>f((l-i)/(g=n+1))&&m("overflow"),i+=(a-e)*g,e=a,s=0;s<y;++s)if((d=t[s])<e&&++i>l&&m("overflow"),d==e){for(u=i,c=36;!(u<(h=c<=o?1:c>=o+26?26:c-o));c+=36)M.push(p(w(h+(k=u-h)%(v=36-h),0))),u=f(k/v);M.push(p(w(u,0))),o=x(i,g,n==r),i=0,++n}++i,++e}return M.join("")}if(s={version:"1.3.2",ucs2:{decode:b,encode:v},decode:k,encode:M,toASCII:function(t){return g(t,(function(t){return c.test(t)?"xn--"+M(t):t}))},toUnicode:function(t){return g(t,(function(t){return u.test(t)?k(t.slice(4).toLowerCase()):t}))}},n&&r)if(t.exports==n)r.exports=s;else for(a in s)s.hasOwnProperty(a)&&(n[a]=s[a]);else i.punycode=s}(wn)}));var Mn=function(t,e,i,n){i=i||"=";var r={};if("string"!=typeof t||0===t.length)return r;var o=/\\+/g;t=t.split(e=e||"&");var s=1e3;n&&"number"==typeof n.maxKeys&&(s=n.maxKeys);var a=t.length;s>0&&a>s&&(a=s);for(var l=0;l<a;++l){var u,c,h,d,f=t[l].replace(o,"%20"),p=f.indexOf(i);p>=0?(u=f.substr(0,p),c=f.substr(p+1)):(u=f,c=""),h=decodeURIComponent(u),d=decodeURIComponent(c),kn(r,h)?Array.isArray(r[h])?r[h].push(d):r[h]=[r[h],d]:r[h]=d}return r},jn=function(t){switch(typeof t){case"string":return t;case"boolean":return t?"true":"false";case"number":return isFinite(t)?t:"";default:return""}},An=function(t,e,i,n){return e=e||"&",i=i||"=",null===t&&(t=void 0),"object"==typeof t?Object.keys(t).map((function(n){var r=encodeURIComponent(jn(n))+i;return Array.isArray(t[n])?t[n].map((function(t){return r+encodeURIComponent(jn(t))})).join(e):r+encodeURIComponent(jn(t[n]))})).join(e):n?encodeURIComponent(jn(n))+i+encodeURIComponent(jn(t)):""};function Fn(t,...e){for(const i of e)for(const e in i)t[e]=i[e];return t}xn((function(t,e){e.decode=e.parse=Mn,e.encode=e.stringify=An}));class Tn extends Error{constructor(t,e){super(e),this.message=e,this.key=t}}class zn{constructor(t,e=[]){this.parent=t,this.bindings={};for(const[t,i]of e)this.bindings[t]=i}concat(t){return new zn(this,t)}get(t){if(this.bindings[t])return this.bindings[t];if(this.parent)return this.parent.get(t);throw new Error(t+" not found in scope.")}has(t){return!!this.bindings[t]||!!this.parent&&this.parent.has(t)}}const Sn={kind:"null"},_n={kind:"number"},Pn={kind:"string"},In={kind:"boolean"},On={kind:"color"},En={kind:"object"},qn={kind:"value"},Rn={kind:"collator"},Cn={kind:"formatted"},Nn={kind:"resolvedImage"};function Ln(t,e){return{kind:"array",itemType:t,N:e}}function Dn(t){if("array"===t.kind){const e=Dn(t.itemType);return"number"==typeof t.N?`array<${e}, ${t.N}>`:"value"===t.itemType.kind?"array":`array<${e}>`}return t.kind}const Un=[Sn,_n,Pn,In,On,Cn,En,Ln(qn),Nn];function $n(t,e){if("error"===e.kind)return null;if("array"===t.kind){if("array"===e.kind&&(0===e.N&&"value"===e.itemType.kind||!$n(t.itemType,e.itemType))&&("number"!=typeof t.N||t.N===e.N))return null}else{if(t.kind===e.kind)return null;if("value"===t.kind)for(const t of Un)if(!$n(t,e))return null}return`Expected ${Dn(t)} but found ${Dn(e)} instead.`}function Wn(t,e){return e.some(e=>e.kind===t.kind)}function Jn(t,e){return e.some(e=>"null"===e?null===t:"array"===e?Array.isArray(t):"object"===e?t&&!Array.isArray(t)&&"object"==typeof t:e===typeof t)}var Hn=xn((function(t,e){var i={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 n(t){return(t=Math.round(t))<0?0:t>255?255:t}function r(t){return n("%"===t[t.length-1]?parseFloat(t)/100*255:parseInt(t))}function o(t){return function(t){return t<0?0:t>1?1:t}("%"===t[t.length-1]?parseFloat(t)/100:parseFloat(t))}function s(t,e,i){return i<0?i+=1:i>1&&(i-=1),6*i<1?t+(e-t)*i*6:2*i<1?e:3*i<2?t+(e-t)*(2/3-i)*6:t}try{e.parseCSSColor=function(t){var e,a=t.replace(/ /g,"").toLowerCase();if(a in i)return i[a].slice();if("#"===a[0])return 4===a.length?(e=parseInt(a.substr(1),16))>=0&&e<=4095?[(3840&e)>>4|(3840&e)>>8,240&e|(240&e)>>4,15&e|(15&e)<<4,1]:null:7===a.length&&(e=parseInt(a.substr(1),16))>=0&&e<=16777215?[(16711680&e)>>16,(65280&e)>>8,255&e,1]:null;var l=a.indexOf("("),u=a.indexOf(")");if(-1!==l&&u+1===a.length){var c=a.substr(0,l),h=a.substr(l+1,u-(l+1)).split(","),d=1;switch(c){case"rgba":if(4!==h.length)return null;d=o(h.pop());case"rgb":return 3!==h.length?null:[r(h[0]),r(h[1]),r(h[2]),d];case"hsla":if(4!==h.length)return null;d=o(h.pop());case"hsl":if(3!==h.length)return null;var f=(parseFloat(h[0])%360+360)%360/360,p=o(h[1]),m=o(h[2]),y=m<=.5?m*(p+1):m+p-m*p,g=2*m-y;return[n(255*s(g,y,f+1/3)),n(255*s(g,y,f)),n(255*s(g,y,f-1/3)),d];default:return null}}return null}}catch(t){}}));class Gn{constructor(t,e,i,n=1){this.r=t,this.g=e,this.b=i,this.a=n}static parse(t){if(!t)return;if(t instanceof Gn)return t;if("string"!=typeof t)return;const e=Hn.parseCSSColor(t);return e?new Gn(e[0]/255*e[3],e[1]/255*e[3],e[2]/255*e[3],e[3]):void 0}toString(){const[t,e,i,n]=this.toArray();return`rgba(${Math.round(t)},${Math.round(e)},${Math.round(i)},${n})`}toArray(){const{r:t,g:e,b:i,a:n}=this;return 0===n?[0,0,0,0]:[255*t/n,255*e/n,255*i/n,n]}}Gn.black=new Gn(0,0,0,1),Gn.white=new Gn(1,1,1,1),Gn.transparent=new Gn(0,0,0,0),Gn.red=new Gn(1,0,0,1),Gn.blue=new Gn(0,0,1,1);class Vn{constructor(t,e,i){this.sensitivity=t?e?"variant":"case":e?"accent":"base",this.locale=i,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})}compare(t,e){return this.collator.compare(t,e)}resolvedLocale(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale}}class Bn{constructor(t,e,i,n,r){this.text=t.normalize?t.normalize():t,this.image=e,this.scale=i,this.fontStack=n,this.textColor=r}}class Xn{constructor(t){this.sections=t}static fromString(t){return new Xn([new Bn(t,null,null,null,null)])}isEmpty(){return 0===this.sections.length||!this.sections.some(t=>0!==t.text.length||t.image&&0!==t.image.name.length)}static factory(t){return t instanceof Xn?t:Xn.fromString(t)}toString(){return 0===this.sections.length?"":this.sections.map(t=>t.text).join("")}serialize(){const t=["format"];for(const e of this.sections){if(e.image){t.push(["image",e.image.name]);continue}t.push(e.text);const i={};e.fontStack&&(i["text-font"]=["literal",e.fontStack.split(",")]),e.scale&&(i["font-scale"]=e.scale),e.textColor&&(i["text-color"]=["rgba"].concat(e.textColor.toArray())),t.push(i)}return t}}class Zn{constructor(t){this.name=t.name,this.available=t.available}toString(){return this.name}static fromString(t){return t?new Zn({name:t,available:!1}):null}serialize(){return["image",this.name]}}function Yn(t,e,i,n){return"number"==typeof t&&t>=0&&t<=255&&"number"==typeof e&&e>=0&&e<=255&&"number"==typeof i&&i>=0&&i<=255?void 0===n||"number"==typeof n&&n>=0&&n<=1?null:`Invalid rgba value [${[t,e,i,n].join(", ")}]: \'a\' must be between 0 and 1.`:`Invalid rgba value [${("number"==typeof n?[t,e,i,n]:[t,e,i]).join(", ")}]: \'r\', \'g\', and \'b\' must be between 0 and 255.`}function Kn(t){if(null===t)return!0;if("string"==typeof t)return!0;if("boolean"==typeof t)return!0;if("number"==typeof t)return!0;if(t instanceof Gn)return!0;if(t instanceof Vn)return!0;if(t instanceof Xn)return!0;if(t instanceof Zn)return!0;if(Array.isArray(t)){for(const e of t)if(!Kn(e))return!1;return!0}if("object"==typeof t){for(const e in t)if(!Kn(t[e]))return!1;return!0}return!1}function Qn(t){if(null===t)return Sn;if("string"==typeof t)return Pn;if("boolean"==typeof t)return In;if("number"==typeof t)return _n;if(t instanceof Gn)return On;if(t instanceof Vn)return Rn;if(t instanceof Xn)return Cn;if(t instanceof Zn)return Nn;if(Array.isArray(t)){const e=t.length;let i;for(const e of t){const t=Qn(e);if(i){if(i===t)continue;i=qn;break}i=t}return Ln(i||qn,e)}return En}function tr(t){const e=typeof t;return null===t?"":"string"===e||"number"===e||"boolean"===e?String(t):t instanceof Gn||t instanceof Xn||t instanceof Zn?t.toString():JSON.stringify(t)}class er{constructor(t,e){this.type=t,this.value=e}static parse(t,e){if(2!==t.length)return e.error(`\'literal\' expression requires exactly one argument, but found ${t.length-1} instead.`);if(!Kn(t[1]))return e.error("invalid value");const i=t[1];let n=Qn(i);const r=e.expectedType;return"array"!==n.kind||0!==n.N||!r||"array"!==r.kind||"number"==typeof r.N&&0!==r.N||(n=r),new er(n,i)}evaluate(){return this.value}eachChild(){}outputDefined(){return!0}serialize(){return"array"===this.type.kind||"object"===this.type.kind?["literal",this.value]:this.value instanceof Gn?["rgba"].concat(this.value.toArray()):this.value instanceof Xn?this.value.serialize():this.value}}class ir{constructor(t){this.name="ExpressionEvaluationError",this.message=t}toJSON(){return this.message}}const nr={string:Pn,number:_n,boolean:In,object:En};class rr{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");let i,n=1;const r=t[0];if("array"===r){let r,o;if(t.length>2){const i=t[1];if("string"!=typeof i||!(i in nr)||"object"===i)return e.error(\'The item type argument of "array" must be one of string, number, boolean\',1);r=nr[i],n++}else r=qn;if(t.length>3){if(null!==t[2]&&("number"!=typeof t[2]||t[2]<0||t[2]!==Math.floor(t[2])))return e.error(\'The length argument to "array" must be a positive integer literal\',2);o=t[2],n++}i=Ln(r,o)}else i=nr[r];const o=[];for(;n<t.length;n++){const i=e.parse(t[n],n,qn);if(!i)return null;o.push(i)}return new rr(i,o)}evaluate(t){for(let e=0;e<this.args.length;e++){const i=this.args[e].evaluate(t);if(!$n(this.type,Qn(i)))return i;if(e===this.args.length-1)throw new ir(`Expected value to be of type ${Dn(this.type)}, but found ${Dn(Qn(i))} instead.`)}return null}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){const t=this.type,e=[t.kind];if("array"===t.kind){const i=t.itemType;if("string"===i.kind||"number"===i.kind||"boolean"===i.kind){e.push(i.kind);const n=t.N;("number"==typeof n||this.args.length>1)&&e.push(n)}}return e.concat(this.args.map(t=>t.serialize()))}}class or{constructor(t){this.type=Cn,this.sections=t}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[1];if(!Array.isArray(i)&&"object"==typeof i)return e.error("First argument must be an image or text section.");const n=[];let r=!1;for(let i=1;i<=t.length-1;++i){const o=t[i];if(r&&"object"==typeof o&&!Array.isArray(o)){r=!1;let t=null;if(o["font-scale"]&&(t=e.parse(o["font-scale"],1,_n),!t))return null;let i=null;if(o["text-font"]&&(i=e.parse(o["text-font"],1,Ln(Pn)),!i))return null;let s=null;if(o["text-color"]&&(s=e.parse(o["text-color"],1,On),!s))return null;const a=n[n.length-1];a.scale=t,a.font=i,a.textColor=s}else{const o=e.parse(t[i],1,qn);if(!o)return null;const s=o.type.kind;if("string"!==s&&"value"!==s&&"null"!==s&&"resolvedImage"!==s)return e.error("Formatted text type must be \'string\', \'value\', \'image\' or \'null\'.");r=!0,n.push({content:o,scale:null,font:null,textColor:null})}}return new or(n)}evaluate(t){return new Xn(this.sections.map(e=>{const i=e.content.evaluate(t);return Qn(i)===Nn?new Bn("",i,null,null,null):new Bn(tr(i),null,e.scale?e.scale.evaluate(t):null,e.font?e.font.evaluate(t).join(","):null,e.textColor?e.textColor.evaluate(t):null)}))}eachChild(t){for(const e of this.sections)t(e.content),e.scale&&t(e.scale),e.font&&t(e.font),e.textColor&&t(e.textColor)}outputDefined(){return!1}serialize(){const t=["format"];for(const e of this.sections){t.push(e.content.serialize());const i={};e.scale&&(i["font-scale"]=e.scale.serialize()),e.font&&(i["text-font"]=e.font.serialize()),e.textColor&&(i["text-color"]=e.textColor.serialize()),t.push(i)}return t}}class sr{constructor(t){this.type=Nn,this.input=t}static parse(t,e){if(2!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,Pn);return i?new sr(i):e.error("No image name provided.")}evaluate(t){const e=this.input.evaluate(t),i=Zn.fromString(e);return i&&t.availableImages&&(i.available=t.availableImages.indexOf(e)>-1),i}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){return["image",this.input.serialize()]}}const ar={"to-boolean":In,"to-color":On,"to-number":_n,"to-string":Pn};class lr{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[0];if(("to-boolean"===i||"to-string"===i)&&2!==t.length)return e.error("Expected one argument.");const n=ar[i],r=[];for(let i=1;i<t.length;i++){const n=e.parse(t[i],i,qn);if(!n)return null;r.push(n)}return new lr(n,r)}evaluate(t){if("boolean"===this.type.kind)return Boolean(this.args[0].evaluate(t));if("color"===this.type.kind){let e,i;for(const n of this.args){if(e=n.evaluate(t),i=null,e instanceof Gn)return e;if("string"==typeof e){const i=t.parseColor(e);if(i)return i}else if(Array.isArray(e)&&(i=e.length<3||e.length>4?`Invalid rbga value ${JSON.stringify(e)}: expected an array containing either three or four numeric values.`:Yn(e[0],e[1],e[2],e[3]),!i))return new Gn(e[0]/255,e[1]/255,e[2]/255,e[3])}throw new ir(i||`Could not parse color from value \'${"string"==typeof e?e:String(JSON.stringify(e))}\'`)}if("number"===this.type.kind){let e=null;for(const i of this.args){if(e=i.evaluate(t),null===e)return 0;const n=Number(e);if(!isNaN(n))return n}throw new ir(`Could not convert ${JSON.stringify(e)} to number.`)}return"formatted"===this.type.kind?Xn.fromString(tr(this.args[0].evaluate(t))):"resolvedImage"===this.type.kind?Zn.fromString(tr(this.args[0].evaluate(t))):tr(this.args[0].evaluate(t))}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){if("formatted"===this.type.kind)return new or([{content:this.args[0],scale:null,font:null,textColor:null}]).serialize();if("resolvedImage"===this.type.kind)return new sr(this.args[0]).serialize();const t=["to-"+this.type.kind];return this.eachChild(e=>{t.push(e.serialize())}),t}}const ur=["Unknown","Point","LineString","Polygon"];class cr{constructor(){this.globals=null,this.feature=null,this.featureState=null,this.formattedSection=null,this.R={},this.availableImages=null,this.canonical=null,this.featureTileCoord=null,this.featureDistanceData=null}id(){return this.feature&&"id"in this.feature&&this.feature.id?this.feature.id:null}geometryType(){return this.feature?"number"==typeof this.feature.type?ur[this.feature.type]:this.feature.type:null}geometry(){return this.feature&&"geometry"in this.feature?this.feature.geometry:null}canonicalID(){return this.canonical}properties(){return this.feature&&this.feature.properties||{}}distanceFromCenter(){if(this.featureTileCoord&&this.featureDistanceData){const t=this.featureDistanceData.center,e=this.featureDistanceData.scale,{x:i,y:n}=this.featureTileCoord;return this.featureDistanceData.bearing[0]*(i*e-t[0])+this.featureDistanceData.bearing[1]*(n*e-t[1])}return 0}parseColor(t){let e=this.R[t];return e||(e=this.R[t]=Gn.parse(t)),e}}class hr{constructor(t,e,i,n){this.name=t,this.type=e,this.C=i,this.args=n}evaluate(t){return this.C(t,this.args)}eachChild(t){this.args.forEach(t)}outputDefined(){return!1}serialize(){return[this.name].concat(this.args.map(t=>t.serialize()))}static parse(t,e){const i=t[0],n=hr.definitions[i];if(!n)return e.error(`Unknown expression "${i}". If you wanted a literal array, use ["literal", [...]].`,0);const r=Array.isArray(n)?n[0]:n.type,o=Array.isArray(n)?[[n[1],n[2]]]:n.overloads,s=o.filter(([e])=>!Array.isArray(e)||e.length===t.length-1);let a=null;for(const[n,o]of s){a=new Or(e.registry,e.path,null,e.scope);const s=[];let l=!1;for(let e=1;e<t.length;e++){const i=t[e],r=Array.isArray(n)?n[e-1]:n.type,o=a.parse(i,1+s.length,r);if(!o){l=!0;break}s.push(o)}if(!l)if(Array.isArray(n)&&n.length!==s.length)a.error(`Expected ${n.length} arguments, but found ${s.length} instead.`);else{for(let t=0;t<s.length;t++){const e=Array.isArray(n)?n[t]:n.type,i=s[t];a.concat(t+1).checkSubtype(e,i.type)}if(0===a.errors.length)return new hr(i,r,o,s)}}if(1===s.length)e.errors.push(...a.errors);else{const i=(s.length?s:o).map(([t])=>{return e=t,Array.isArray(e)?`(${e.map(Dn).join(", ")})`:`(${Dn(e.type)}...)`;var e}).join(" | "),n=[];for(let i=1;i<t.length;i++){const r=e.parse(t[i],1+n.length);if(!r)return null;n.push(Dn(r.type))}e.error(`Expected arguments of type ${i}, but found (${n.join(", ")}) instead.`)}return null}static register(t,e){hr.definitions=e;for(const i in e)t[i]=hr}}class dr{constructor(t,e,i){this.type=Rn,this.locale=i,this.caseSensitive=t,this.diacriticSensitive=e}static parse(t,e){if(2!==t.length)return e.error("Expected one argument.");const i=t[1];if("object"!=typeof i||Array.isArray(i))return e.error("Collator options argument must be an object.");const n=e.parse(void 0!==i["case-sensitive"]&&i["case-sensitive"],1,In);if(!n)return null;const r=e.parse(void 0!==i["diacritic-sensitive"]&&i["diacritic-sensitive"],1,In);if(!r)return null;let o=null;return i.locale&&(o=e.parse(i.locale,1,Pn),!o)?null:new dr(n,r,o)}evaluate(t){return new Vn(this.caseSensitive.evaluate(t),this.diacriticSensitive.evaluate(t),this.locale?this.locale.evaluate(t):null)}eachChild(t){t(this.caseSensitive),t(this.diacriticSensitive),this.locale&&t(this.locale)}outputDefined(){return!1}serialize(){const t={};return t["case-sensitive"]=this.caseSensitive.serialize(),t["diacritic-sensitive"]=this.diacriticSensitive.serialize(),this.locale&&(t.locale=this.locale.serialize()),["collator",t]}}function fr(t,e){t[0]=Math.min(t[0],e[0]),t[1]=Math.min(t[1],e[1]),t[2]=Math.max(t[2],e[0]),t[3]=Math.max(t[3],e[1])}function pr(t,e){return!(t[0]<=e[0]||t[2]>=e[2]||t[1]<=e[1]||t[3]>=e[3])}function mr(t,e){const i=(180+t[0])/360,n=(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+t[1]*Math.PI/360)))/360,r=Math.pow(2,e.z);return[Math.round(i*r*8192),Math.round(n*r*8192)]}function yr(t,e,i){const n=t[0]-e[0],r=t[1]-e[1],o=t[0]-i[0],s=t[1]-i[1];return n*s-o*r==0&&n*o<=0&&r*s<=0}function gr(t,e){let i=!1;for(let s=0,a=e.length;s<a;s++){const a=e[s];for(let e=0,s=a.length;e<s-1;e++){if(yr(t,a[e],a[e+1]))return!1;(r=a[e])[1]>(n=t)[1]!=(o=a[e+1])[1]>n[1]&&n[0]<(o[0]-r[0])*(n[1]-r[1])/(o[1]-r[1])+r[0]&&(i=!i)}}var n,r,o;return i}function br(t,e){for(let i=0;i<e.length;i++)if(gr(t,e[i]))return!0;return!1}function vr(t,e,i,n){const r=n[0]-i[0],o=n[1]-i[1],s=(t[0]-i[0])*o-r*(t[1]-i[1]),a=(e[0]-i[0])*o-r*(e[1]-i[1]);return s>0&&a<0||s<0&&a>0}function wr(t,e,i){for(const u of i)for(let i=0;i<u.length-1;++i)if(void 0,void 0,0!=(a=[(s=u[i+1])[0]-(o=u[i])[0],s[1]-o[1]])[0]*(l=[(r=e)[0]-(n=t)[0],r[1]-n[1]])[1]-a[1]*l[0]&&vr(n,r,o,s)&&vr(o,s,n,r))return!0;var n,r,o,s,a,l;return!1}function xr(t,e){for(let i=0;i<t.length;++i)if(!gr(t[i],e))return!1;for(let i=0;i<t.length-1;++i)if(wr(t[i],t[i+1],e))return!1;return!0}function kr(t,e){for(let i=0;i<e.length;i++)if(xr(t,e[i]))return!0;return!1}function Mr(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=[];for(let n=0;n<t[r].length;n++){const s=mr(t[r][n],i);fr(e,s),o.push(s)}n.push(o)}return n}function jr(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=Mr(t[r],e,i);n.push(o)}return n}function Ar(t,e,i,n){if(t[0]<i[0]||t[0]>i[2]){const e=.5*n;let r=t[0]-i[0]>e?-n:i[0]-t[0]>e?n:0;0===r&&(r=t[0]-i[2]>e?-n:i[2]-t[0]>e?n:0),t[0]+=r}fr(e,t)}function Fr(t,e,i,n){const r=8192*Math.pow(2,n.z),o=[8192*n.x,8192*n.y],s=[];if(!t)return s;for(const n of t)for(const t of n){const n=[t.x+o[0],t.y+o[1]];Ar(n,e,i,r),s.push(n)}return s}function Tr(t,e,i,n){const r=8192*Math.pow(2,n.z),o=[8192*n.x,8192*n.y],s=[];if(!t)return s;for(const i of t){const t=[];for(const n of i){const i=[n.x+o[0],n.y+o[1]];fr(e,i),t.push(i)}s.push(t)}if(e[2]-e[0]<=r/2){(a=e)[0]=a[1]=1/0,a[2]=a[3]=-1/0;for(const t of s)for(const n of t)Ar(n,e,i,r)}var a;return s}class zr{constructor(t,e){this.type=In,this.geojson=t,this.geometries=e}static parse(t,e){if(2!==t.length)return e.error(`\'within\' expression requires exactly one argument, but found ${t.length-1} instead.`);if(Kn(t[1])){const e=t[1];if("FeatureCollection"===e.type)for(let t=0;t<e.features.length;++t){const i=e.features[t].geometry.type;if("Polygon"===i||"MultiPolygon"===i)return new zr(e,e.features[t].geometry)}else if("Feature"===e.type){const t=e.geometry.type;if("Polygon"===t||"MultiPolygon"===t)return new zr(e,e.geometry)}else if("Polygon"===e.type||"MultiPolygon"===e.type)return new zr(e,e)}return e.error("\'within\' expression requires valid geojson object that contains polygon geometry type.")}evaluate(t){if(null!=t.geometry()&&null!=t.canonicalID()){if("Point"===t.geometryType())return function(t,e){const i=[1/0,1/0,-1/0,-1/0],n=[1/0,1/0,-1/0,-1/0],r=t.canonicalID();if(!r)return!1;if("Polygon"===e.type){const o=Mr(e.coordinates,n,r),s=Fr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!gr(t,o))return!1}if("MultiPolygon"===e.type){const o=jr(e.coordinates,n,r),s=Fr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!br(t,o))return!1}return!0}(t,this.geometries);if("LineString"===t.geometryType())return function(t,e){const i=[1/0,1/0,-1/0,-1/0],n=[1/0,1/0,-1/0,-1/0],r=t.canonicalID();if(!r)return!1;if("Polygon"===e.type){const o=Mr(e.coordinates,n,r),s=Tr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!xr(t,o))return!1}if("MultiPolygon"===e.type){const o=jr(e.coordinates,n,r),s=Tr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!kr(t,o))return!1}return!0}(t,this.geometries)}return!1}eachChild(){}outputDefined(){return!0}serialize(){return["within",this.geojson]}}function Sr(t){if(t instanceof hr){if("get"===t.name&&1===t.args.length)return!1;if("feature-state"===t.name)return!1;if("has"===t.name&&1===t.args.length)return!1;if("properties"===t.name||"geometry-type"===t.name||"id"===t.name)return!1;if(/^filter-/.test(t.name))return!1}if(t instanceof zr)return!1;let e=!0;return t.eachChild(t=>{e&&!Sr(t)&&(e=!1)}),e}function _r(t){if(t instanceof hr&&"feature-state"===t.name)return!1;let e=!0;return t.eachChild(t=>{e&&!_r(t)&&(e=!1)}),e}function Pr(t,e){if(t instanceof hr&&e.indexOf(t.name)>=0)return!1;let i=!0;return t.eachChild(t=>{i&&!Pr(t,e)&&(i=!1)}),i}class Ir{constructor(t,e){this.type=e.type,this.name=t,this.boundExpression=e}static parse(t,e){if(2!==t.length||"string"!=typeof t[1])return e.error("\'var\' expression requires exactly one string literal argument.");const i=t[1];return e.scope.has(i)?new Ir(i,e.scope.get(i)):e.error(`Unknown variable "${i}". Make sure "${i}" has been bound in an enclosing "let" expression before using it.`,1)}evaluate(t){return this.boundExpression.evaluate(t)}eachChild(){}outputDefined(){return!1}serialize(){return["var",this.name]}}class Or{constructor(t,e=[],i,n=new zn,r=[]){this.registry=t,this.path=e,this.key=e.map(t=>`[${t}]`).join(""),this.scope=n,this.errors=r,this.expectedType=i}parse(t,e,i,n,r={}){return e?this.concat(e,i,n).L(t,r):this.L(t,r)}L(t,e){function i(t,e,i){return"assert"===i?new rr(e,[t]):"coerce"===i?new lr(e,[t]):t}if(null!==t&&"string"!=typeof t&&"boolean"!=typeof t&&"number"!=typeof t||(t=["literal",t]),Array.isArray(t)){if(0===t.length)return this.error(\'Expected an array with at least one element. If you wanted a literal array, use ["literal", []].\');const n=t[0];if("string"!=typeof n)return this.error(`Expression name must be a string, but found ${typeof n} instead. If you wanted a literal array, use ["literal", [...]].`,0),null;const r=this.registry[n];if(r){let n=r.parse(t,this);if(!n)return null;if(this.expectedType){const t=this.expectedType,r=n.type;if("string"!==t.kind&&"number"!==t.kind&&"boolean"!==t.kind&&"object"!==t.kind&&"array"!==t.kind||"value"!==r.kind)if("color"!==t.kind&&"formatted"!==t.kind&&"resolvedImage"!==t.kind||"value"!==r.kind&&"string"!==r.kind){if(this.checkSubtype(t,r))return null}else n=i(n,t,e.typeAnnotation||"coerce");else n=i(n,t,e.typeAnnotation||"assert")}if(!(n instanceof er)&&"resolvedImage"!==n.type.kind&&function t(e){if(e instanceof Ir)return t(e.boundExpression);if(e instanceof hr&&"error"===e.name)return!1;if(e instanceof dr)return!1;if(e instanceof zr)return!1;const i=e instanceof lr||e instanceof rr;let n=!0;return e.eachChild(e=>{n=i?n&&t(e):n&&e instanceof er}),!!n&&(Sr(e)&&Pr(e,["zoom","heatmap-density","line-progress","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center"]))}(n)){const e=new cr;try{n=new er(n.type,n.evaluate(e))}catch(t){return this.error(t.message),null}}return n}return this.error(`Unknown expression "${n}". If you wanted a literal array, use ["literal", [...]].`,0)}return this.error(void 0===t?"\'undefined\' value invalid. Use null instead.":"object"==typeof t?\'Bare objects invalid. Use ["literal", {...}] instead.\':`Expected an array, but found ${typeof t} instead.`)}concat(t,e,i){const n="number"==typeof t?this.path.concat(t):this.path,r=i?this.scope.concat(i):this.scope;return new Or(this.registry,n,e||null,r,this.errors)}error(t,...e){const i=`${this.key}${e.map(t=>`[${t}]`).join("")}`;this.errors.push(new Tn(i,t))}checkSubtype(t,e){const i=$n(t,e);return i&&this.error(i),i}}function Er(t,e){const i=t.length-1;let n,r,o=0,s=i,a=0;for(;o<=s;)if(a=Math.floor((o+s)/2),n=t[a],r=t[a+1],n<=e){if(a===i||e<r)return a;o=a+1}else{if(!(n>e))throw new ir("Input is not a number.");s=a-1}return 0}class qr{constructor(t,e,i){this.type=t,this.input=e,this.labels=[],this.outputs=[];for(const[t,e]of i)this.labels.push(t),this.outputs.push(e)}static parse(t,e){if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");const i=e.parse(t[1],1,_n);if(!i)return null;const n=[];let r=null;e.expectedType&&"value"!==e.expectedType.kind&&(r=e.expectedType);for(let i=1;i<t.length;i+=2){const o=1===i?-1/0:t[i],s=t[i+1],a=i,l=i+1;if("number"!=typeof o)return e.error(\'Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.\',a);if(n.length&&n[n.length-1][0]>=o)return e.error(\'Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.\',a);const u=e.parse(s,l,r);if(!u)return null;r=r||u.type,n.push([o,u])}return new qr(r,i,n)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const n=this.input.evaluate(t);if(n<=e[0])return i[0].evaluate(t);const r=e.length;return n>=e[r-1]?i[r-1].evaluate(t):i[Er(e,n)].evaluate(t)}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every(t=>t.outputDefined())}serialize(){const t=["step",this.input.serialize()];for(let e=0;e<this.labels.length;e++)e>0&&t.push(this.labels[e]),t.push(this.outputs[e].serialize());return t}}var Rr=Cr;function Cr(t,e,i,n){this.cx=3*t,this.bx=3*(i-t)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*e,this.by=3*(n-e)-this.cy,this.ay=1-this.cy-this.by,this.p1x=t,this.p1y=n,this.p2x=i,this.p2y=n}function Nr(t,e,i){return t*(1-i)+e*i}Cr.prototype.sampleCurveX=function(t){return((this.ax*t+this.bx)*t+this.cx)*t},Cr.prototype.sampleCurveY=function(t){return((this.ay*t+this.by)*t+this.cy)*t},Cr.prototype.sampleCurveDerivativeX=function(t){return(3*this.ax*t+2*this.bx)*t+this.cx},Cr.prototype.solveCurveX=function(t,e){var i,n,r,o,s;for(void 0===e&&(e=1e-6),r=t,s=0;s<8;s++){if(o=this.sampleCurveX(r)-t,Math.abs(o)<e)return r;var a=this.sampleCurveDerivativeX(r);if(Math.abs(a)<1e-6)break;r-=o/a}if((r=t)<(i=0))return i;if(r>(n=1))return n;for(;i<n;){if(o=this.sampleCurveX(r),Math.abs(o-t)<e)return r;t>o?i=r:n=r,r=.5*(n-i)+i}return r},Cr.prototype.solve=function(t,e){return this.sampleCurveY(this.solveCurveX(t,e))};var Lr=Object.freeze({__proto__:null,number:Nr,color:function(t,e,i){return new Gn(Nr(t.r,e.r,i),Nr(t.g,e.g,i),Nr(t.b,e.b,i),Nr(t.a,e.a,i))},array:function(t,e,i){return t.map((t,n)=>Nr(t,e[n],i))}});const Dr=6/29*3*(6/29),Ur=Math.PI/180,$r=180/Math.PI;function Wr(t){return t>.008856451679035631?Math.pow(t,1/3):t/Dr+4/29}function Jr(t){return t>6/29?t*t*t:Dr*(t-4/29)}function Hr(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Gr(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function Vr(t){const e=Gr(t.r),i=Gr(t.g),n=Gr(t.b),r=Wr((.4124564*e+.3575761*i+.1804375*n)/.95047),o=Wr((.2126729*e+.7151522*i+.072175*n)/1);return{l:116*o-16,a:500*(r-o),b:200*(o-Wr((.0193339*e+.119192*i+.9503041*n)/1.08883)),alpha:t.a}}function Br(t){let e=(t.l+16)/116,i=isNaN(t.a)?e:e+t.a/500,n=isNaN(t.b)?e:e-t.b/200;return e=1*Jr(e),i=.95047*Jr(i),n=1.08883*Jr(n),new Gn(Hr(3.2404542*i-1.5371385*e-.4985314*n),Hr(-.969266*i+1.8760108*e+.041556*n),Hr(.0556434*i-.2040259*e+1.0572252*n),t.alpha)}function Xr(t,e,i){const n=e-t;return t+i*(n>180||n<-180?n-360*Math.round(n/360):n)}const Zr={forward:Vr,reverse:Br,interpolate:function(t,e,i){return{l:Nr(t.l,e.l,i),a:Nr(t.a,e.a,i),b:Nr(t.b,e.b,i),alpha:Nr(t.alpha,e.alpha,i)}}},Yr={forward:function(t){const{l:e,a:i,b:n}=Vr(t),r=Math.atan2(n,i)*$r;return{h:r<0?r+360:r,c:Math.sqrt(i*i+n*n),l:e,alpha:t.a}},reverse:function(t){const e=t.h*Ur,i=t.c;return Br({l:t.l,a:Math.cos(e)*i,b:Math.sin(e)*i,alpha:t.alpha})},interpolate:function(t,e,i){return{h:Xr(t.h,e.h,i),c:Nr(t.c,e.c,i),l:Nr(t.l,e.l,i),alpha:Nr(t.alpha,e.alpha,i)}}};var Kr=Object.freeze({__proto__:null,lab:Zr,hcl:Yr});class Qr{constructor(t,e,i,n,r){this.type=t,this.operator=e,this.interpolation=i,this.input=n,this.labels=[],this.outputs=[];for(const[t,e]of r)this.labels.push(t),this.outputs.push(e)}static interpolationFactor(t,e,i,n){let r=0;if("exponential"===t.name)r=to(e,t.base,i,n);else if("linear"===t.name)r=to(e,1,i,n);else if("cubic-bezier"===t.name){const o=t.controlPoints;r=new Rr(o[0],o[1],o[2],o[3]).solve(to(e,1,i,n))}return r}static parse(t,e){let[i,n,r,...o]=t;if(!Array.isArray(n)||0===n.length)return e.error("Expected an interpolation type expression.",1);if("linear"===n[0])n={name:"linear"};else if("exponential"===n[0]){const t=n[1];if("number"!=typeof t)return e.error("Exponential interpolation requires a numeric base.",1,1);n={name:"exponential",base:t}}else{if("cubic-bezier"!==n[0])return e.error("Unknown interpolation type "+String(n[0]),1,0);{const t=n.slice(1);if(4!==t.length||t.some(t=>"number"!=typeof t||t<0||t>1))return e.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);n={name:"cubic-bezier",controlPoints:t}}}if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");if(r=e.parse(r,2,_n),!r)return null;const s=[];let a=null;"interpolate-hcl"===i||"interpolate-lab"===i?a=On:e.expectedType&&"value"!==e.expectedType.kind&&(a=e.expectedType);for(let t=0;t<o.length;t+=2){const i=o[t],n=o[t+1],r=t+3,l=t+4;if("number"!=typeof i)return e.error(\'Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.\',r);if(s.length&&s[s.length-1][0]>=i)return e.error(\'Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.\',r);const u=e.parse(n,l,a);if(!u)return null;a=a||u.type,s.push([i,u])}return"number"===a.kind||"color"===a.kind||"array"===a.kind&&"number"===a.itemType.kind&&"number"==typeof a.N?new Qr(a,i,n,r,s):e.error(`Type ${Dn(a)} is not interpolatable.`)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const n=this.input.evaluate(t);if(n<=e[0])return i[0].evaluate(t);const r=e.length;if(n>=e[r-1])return i[r-1].evaluate(t);const o=Er(e,n),s=Qr.interpolationFactor(this.interpolation,n,e[o],e[o+1]),a=i[o].evaluate(t),l=i[o+1].evaluate(t);return"interpolate"===this.operator?Lr[this.type.kind.toLowerCase()](a,l,s):"interpolate-hcl"===this.operator?Yr.reverse(Yr.interpolate(Yr.forward(a),Yr.forward(l),s)):Zr.reverse(Zr.interpolate(Zr.forward(a),Zr.forward(l),s))}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every(t=>t.outputDefined())}serialize(){let t;t="linear"===this.interpolation.name?["linear"]:"exponential"===this.interpolation.name?1===this.interpolation.base?["linear"]:["exponential",this.interpolation.base]:["cubic-bezier"].concat(this.interpolation.controlPoints);const e=[this.operator,t,this.input.serialize()];for(let t=0;t<this.labels.length;t++)e.push(this.labels[t],this.outputs[t].serialize());return e}}function to(t,e,i,n){const r=n-i,o=t-i;return 0===r?0:1===e?o/r:(Math.pow(e,o)-1)/(Math.pow(e,r)-1)}class eo{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expectected at least one argument.");let i=null;const n=e.expectedType;n&&"value"!==n.kind&&(i=n);const r=[];for(const n of t.slice(1)){const t=e.parse(n,1+r.length,i,void 0,{typeAnnotation:"omit"});if(!t)return null;i=i||t.type,r.push(t)}const o=n&&r.some(t=>$n(n,t.type));return new eo(o?qn:i,r)}evaluate(t){let e,i=null,n=0;for(const r of this.args){if(n++,i=r.evaluate(t),i&&i instanceof Zn&&!i.available&&(e||(e=i),i=null,n===this.args.length))return e;if(null!==i)break}return i}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){const t=["coalesce"];return this.eachChild(e=>{t.push(e.serialize())}),t}}class io{constructor(t,e){this.type=e.type,this.bindings=[].concat(t),this.result=e}evaluate(t){return this.result.evaluate(t)}eachChild(t){for(const e of this.bindings)t(e[1]);t(this.result)}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found ${t.length-1} instead.`);const i=[];for(let n=1;n<t.length-1;n+=2){const r=t[n];if("string"!=typeof r)return e.error(`Expected string, but found ${typeof r} instead.`,n);if(/[^a-zA-Z0-9_]/.test(r))return e.error("Variable names must contain only alphanumeric characters or \'_\'.",n);const o=e.parse(t[n+1],n+1);if(!o)return null;i.push([r,o])}const n=e.parse(t[t.length-1],t.length-1,e.expectedType,i);return n?new io(i,n):null}outputDefined(){return this.result.outputDefined()}serialize(){const t=["let"];for(const[e,i]of this.bindings)t.push(e,i.serialize());return t.push(this.result.serialize()),t}}class no{constructor(t,e,i){this.type=t,this.index=e,this.input=i}static parse(t,e){if(3!==t.length)return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,_n),n=e.parse(t[2],2,Ln(e.expectedType||qn));return i&&n?new no(n.type.itemType,i,n):null}evaluate(t){const e=this.index.evaluate(t),i=this.input.evaluate(t);if(e<0)throw new ir(`Array index out of bounds: ${e} < 0.`);if(e>=i.length)throw new ir(`Array index out of bounds: ${e} > ${i.length-1}.`);if(e!==Math.floor(e))throw new ir(`Array index must be an integer, but found ${e} instead.`);return i[e]}eachChild(t){t(this.index),t(this.input)}outputDefined(){return!1}serialize(){return["at",this.index.serialize(),this.input.serialize()]}}class ro{constructor(t,e){this.type=In,this.needle=t,this.haystack=e}static parse(t,e){if(3!==t.length)return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,qn);return i&&n?Wn(i.type,[In,Pn,_n,Sn,qn])?new ro(i,n):e.error(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(i.type)} instead`):null}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(null==i)return!1;if(!Jn(e,["boolean","string","number","null"]))throw new ir(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(Qn(e))} instead.`);if(!Jn(i,["string","array"]))throw new ir(`Expected second argument to be of type array or string, but found ${Dn(Qn(i))} instead.`);return i.indexOf(e)>=0}eachChild(t){t(this.needle),t(this.haystack)}outputDefined(){return!0}serialize(){return["in",this.needle.serialize(),this.haystack.serialize()]}}class oo{constructor(t,e,i){this.type=_n,this.needle=t,this.haystack=e,this.fromIndex=i}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,qn);if(!i||!n)return null;if(!Wn(i.type,[In,Pn,_n,Sn,qn]))return e.error(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,_n);return r?new oo(i,n,r):null}return new oo(i,n)}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(!Jn(e,["boolean","string","number","null"]))throw new ir(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(Qn(e))} instead.`);if(!Jn(i,["string","array"]))throw new ir(`Expected second argument to be of type array or string, but found ${Dn(Qn(i))} instead.`);if(this.fromIndex){const n=this.fromIndex.evaluate(t);return i.indexOf(e,n)}return i.indexOf(e)}eachChild(t){t(this.needle),t(this.haystack),this.fromIndex&&t(this.fromIndex)}outputDefined(){return!1}serialize(){if(null!=this.fromIndex&&void 0!==this.fromIndex){const t=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),t]}return["index-of",this.needle.serialize(),this.haystack.serialize()]}}class so{constructor(t,e,i,n,r,o){this.inputType=t,this.type=e,this.input=i,this.cases=n,this.outputs=r,this.otherwise=o}static parse(t,e){if(t.length<5)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if(t.length%2!=1)return e.error("Expected an even number of arguments.");let i,n;e.expectedType&&"value"!==e.expectedType.kind&&(n=e.expectedType);const r={},o=[];for(let s=2;s<t.length-1;s+=2){let a=t[s];const l=t[s+1];Array.isArray(a)||(a=[a]);const u=e.concat(s);if(0===a.length)return u.error("Expected at least one branch label.");for(const t of a){if("number"!=typeof t&&"string"!=typeof t)return u.error("Branch labels must be numbers or strings.");if("number"==typeof t&&Math.abs(t)>Number.MAX_SAFE_INTEGER)return u.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);if("number"==typeof t&&Math.floor(t)!==t)return u.error("Numeric branch labels must be integer values.");if(i){if(u.checkSubtype(i,Qn(t)))return null}else i=Qn(t);if(void 0!==r[String(t)])return u.error("Branch labels must be unique.");r[String(t)]=o.length}const c=e.parse(l,s,n);if(!c)return null;n=n||c.type,o.push(c)}const s=e.parse(t[1],1,qn);if(!s)return null;const a=e.parse(t[t.length-1],t.length-1,n);return a?"value"!==s.type.kind&&e.concat(1).checkSubtype(i,s.type)?null:new so(i,n,s,r,o,a):null}evaluate(t){const e=this.input.evaluate(t);return(Qn(e)===this.inputType&&this.outputs[this.cases[e]]||this.otherwise).evaluate(t)}eachChild(t){t(this.input),this.outputs.forEach(t),t(this.otherwise)}outputDefined(){return this.outputs.every(t=>t.outputDefined())&&this.otherwise.outputDefined()}serialize(){const t=["match",this.input.serialize()],e=Object.keys(this.cases).sort(),i=[],n={};for(const t of e){const e=n[this.cases[t]];void 0===e?(n[this.cases[t]]=i.length,i.push([this.cases[t],[t]])):i[e][1].push(t)}const r=t=>"number"===this.inputType.kind?Number(t):t;for(const[e,n]of i)t.push(1===n.length?r(n[0]):n.map(r)),t.push(this.outputs[e].serialize());return t.push(this.otherwise.serialize()),t}}class ao{constructor(t,e,i){this.type=t,this.branches=e,this.otherwise=i}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found only ${t.length-1}.`);if(t.length%2!=0)return e.error("Expected an odd number of arguments.");let i;e.expectedType&&"value"!==e.expectedType.kind&&(i=e.expectedType);const n=[];for(let r=1;r<t.length-1;r+=2){const o=e.parse(t[r],r,In);if(!o)return null;const s=e.parse(t[r+1],r+1,i);if(!s)return null;n.push([o,s]),i=i||s.type}const r=e.parse(t[t.length-1],t.length-1,i);return r?new ao(i,n,r):null}evaluate(t){for(const[e,i]of this.branches)if(e.evaluate(t))return i.evaluate(t);return this.otherwise.evaluate(t)}eachChild(t){for(const[e,i]of this.branches)t(e),t(i);t(this.otherwise)}outputDefined(){return this.branches.every(([t,e])=>e.outputDefined())&&this.otherwise.outputDefined()}serialize(){const t=["case"];return this.eachChild(e=>{t.push(e.serialize())}),t}}class lo{constructor(t,e,i,n){this.type=t,this.input=e,this.beginIndex=i,this.endIndex=n}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,_n);if(!i||!n)return null;if(!Wn(i.type,[Ln(qn),Pn,qn]))return e.error(`Expected first argument to be of type array or string, but found ${Dn(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,_n);return r?new lo(i.type,i,n,r):null}return new lo(i.type,i,n)}evaluate(t){const e=this.input.evaluate(t),i=this.beginIndex.evaluate(t);if(!Jn(e,["string","array"]))throw new ir(`Expected first argument to be of type array or string, but found ${Dn(Qn(e))} instead.`);if(this.endIndex){const n=this.endIndex.evaluate(t);return e.slice(i,n)}return e.slice(i)}eachChild(t){t(this.input),t(this.beginIndex),this.endIndex&&t(this.endIndex)}outputDefined(){return!1}serialize(){if(null!=this.endIndex&&void 0!==this.endIndex){const t=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),t]}return["slice",this.input.serialize(),this.beginIndex.serialize()]}}function uo(t,e){return"=="===t||"!="===t?"boolean"===e.kind||"string"===e.kind||"number"===e.kind||"null"===e.kind||"value"===e.kind:"string"===e.kind||"number"===e.kind||"value"===e.kind}function co(t,e,i,n){return 0===n.compare(e,i)}function ho(t,e,i){const n="=="!==t&&"!="!==t;return class r{constructor(t,e,i){this.type=In,this.lhs=t,this.rhs=e,this.collator=i,this.hasUntypedArgument="value"===t.type.kind||"value"===e.type.kind}static parse(t,e){if(3!==t.length&&4!==t.length)return e.error("Expected two or three arguments.");const i=t[0];let o=e.parse(t[1],1,qn);if(!o)return null;if(!uo(i,o.type))return e.concat(1).error(`"${i}" comparisons are not supported for type \'${Dn(o.type)}\'.`);let s=e.parse(t[2],2,qn);if(!s)return null;if(!uo(i,s.type))return e.concat(2).error(`"${i}" comparisons are not supported for type \'${Dn(s.type)}\'.`);if(o.type.kind!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return e.error(`Cannot compare types \'${Dn(o.type)}\' and \'${Dn(s.type)}\'.`);n&&("value"===o.type.kind&&"value"!==s.type.kind?o=new rr(s.type,[o]):"value"!==o.type.kind&&"value"===s.type.kind&&(s=new rr(o.type,[s])));let a=null;if(4===t.length){if("string"!==o.type.kind&&"string"!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return e.error("Cannot use collator to compare non-string types.");if(a=e.parse(t[3],3,Rn),!a)return null}return new r(o,s,a)}evaluate(r){const o=this.lhs.evaluate(r),s=this.rhs.evaluate(r);if(n&&this.hasUntypedArgument){const e=Qn(o),i=Qn(s);if(e.kind!==i.kind||"string"!==e.kind&&"number"!==e.kind)throw new ir(`Expected arguments for "${t}" to be (string, string) or (number, number), but found (${e.kind}, ${i.kind}) instead.`)}if(this.collator&&!n&&this.hasUntypedArgument){const t=Qn(o),i=Qn(s);if("string"!==t.kind||"string"!==i.kind)return e(r,o,s)}return this.collator?i(r,o,s,this.collator.evaluate(r)):e(r,o,s)}eachChild(t){t(this.lhs),t(this.rhs),this.collator&&t(this.collator)}outputDefined(){return!0}serialize(){const e=[t];return this.eachChild(t=>{e.push(t.serialize())}),e}}}const fo=ho("==",(function(t,e,i){return e===i}),co),po=ho("!=",(function(t,e,i){return e!==i}),(function(t,e,i,n){return!co(0,e,i,n)})),mo=ho("<",(function(t,e,i){return e<i}),(function(t,e,i,n){return n.compare(e,i)<0})),yo=ho(">",(function(t,e,i){return e>i}),(function(t,e,i,n){return n.compare(e,i)>0})),go=ho("<=",(function(t,e,i){return e<=i}),(function(t,e,i,n){return n.compare(e,i)<=0})),bo=ho(">=",(function(t,e,i){return e>=i}),(function(t,e,i,n){return n.compare(e,i)>=0}));class vo{constructor(t,e,i,n,r){this.type=Pn,this.number=t,this.locale=e,this.currency=i,this.minFractionDigits=n,this.maxFractionDigits=r}static parse(t,e){if(3!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,_n);if(!i)return null;const n=t[2];if("object"!=typeof n||Array.isArray(n))return e.error("NumberFormat options argument must be an object.");let r=null;if(n.locale&&(r=e.parse(n.locale,1,Pn),!r))return null;let o=null;if(n.currency&&(o=e.parse(n.currency,1,Pn),!o))return null;let s=null;if(n["min-fraction-digits"]&&(s=e.parse(n["min-fraction-digits"],1,_n),!s))return null;let a=null;return n["max-fraction-digits"]&&(a=e.parse(n["max-fraction-digits"],1,_n),!a)?null:new vo(i,r,o,s,a)}evaluate(t){return new Intl.NumberFormat(this.locale?this.locale.evaluate(t):[],{style:this.currency?"currency":"decimal",currency:this.currency?this.currency.evaluate(t):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(t):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(t):void 0}).format(this.number.evaluate(t))}eachChild(t){t(this.number),this.locale&&t(this.locale),this.currency&&t(this.currency),this.minFractionDigits&&t(this.minFractionDigits),this.maxFractionDigits&&t(this.maxFractionDigits)}outputDefined(){return!1}serialize(){const t={};return this.locale&&(t.locale=this.locale.serialize()),this.currency&&(t.currency=this.currency.serialize()),this.minFractionDigits&&(t["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(t["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),t]}}class wo{constructor(t){this.type=_n,this.input=t}static parse(t,e){if(2!==t.length)return e.error(`Expected 1 argument, but found ${t.length-1} instead.`);const i=e.parse(t[1],1);return i?"array"!==i.type.kind&&"string"!==i.type.kind&&"value"!==i.type.kind?e.error(`Expected argument of type string or array, but found ${Dn(i.type)} instead.`):new wo(i):null}evaluate(t){const e=this.input.evaluate(t);if("string"==typeof e)return e.length;if(Array.isArray(e))return e.length;throw new ir(`Expected value to be of type string or array, but found ${Dn(Qn(e))} instead.`)}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){const t=["length"];return this.eachChild(e=>{t.push(e.serialize())}),t}}const xo={"==":fo,"!=":po,">":yo,"<":mo,">=":bo,"<=":go,array:rr,at:no,boolean:rr,case:ao,coalesce:eo,collator:dr,format:or,image:sr,in:ro,"index-of":oo,interpolate:Qr,"interpolate-hcl":Qr,"interpolate-lab":Qr,length:wo,let:io,literal:er,match:so,number:rr,"number-format":vo,object:rr,slice:lo,step:qr,string:rr,"to-boolean":lr,"to-color":lr,"to-number":lr,"to-string":lr,var:Ir,within:zr};function ko(t,[e,i,n,r]){e=e.evaluate(t),i=i.evaluate(t),n=n.evaluate(t);const o=r?r.evaluate(t):1,s=Yn(e,i,n,o);if(s)throw new ir(s);return new Gn(e/255*o,i/255*o,n/255*o,o)}function Mo(t,e){return t in e}function jo(t,e){const i=e[t];return void 0===i?null:i}function Ao(t){return{type:t}}function Fo(t){return{result:"success",value:t}}function To(t){return{result:"error",value:t}}function zo(t){return!!t.expression&&t.expression.interpolated}function So(t){return t instanceof Number?"number":t instanceof String?"string":t instanceof Boolean?"boolean":Array.isArray(t)?"array":null===t?"null":typeof t}function _o(t){return"object"==typeof t&&null!==t&&!Array.isArray(t)}function Po(t){return t}function Io(t,e,i){return void 0!==t?t:void 0!==e?e:void 0!==i?i:void 0}function Oo(t,e,i,n,r){return Io(typeof i===r?n[i]:void 0,t.default,e.default)}function Eo(t,e,i){if("number"!==So(i))return Io(t.default,e.default);const n=t.stops.length;if(1===n)return t.stops[0][1];if(i<=t.stops[0][0])return t.stops[0][1];if(i>=t.stops[n-1][0])return t.stops[n-1][1];const r=Er(t.stops.map(t=>t[0]),i);return t.stops[r][1]}function qo(t,e,i){const n=void 0!==t.base?t.base:1;if("number"!==So(i))return Io(t.default,e.default);const r=t.stops.length;if(1===r)return t.stops[0][1];if(i<=t.stops[0][0])return t.stops[0][1];if(i>=t.stops[r-1][0])return t.stops[r-1][1];const o=Er(t.stops.map(t=>t[0]),i),s=function(t,e,i,n){const r=n-i,o=t-i;return 0===r?0:1===e?o/r:(Math.pow(e,o)-1)/(Math.pow(e,r)-1)}(i,n,t.stops[o][0],t.stops[o+1][0]),a=t.stops[o][1],l=t.stops[o+1][1];let u=Lr[e.type]||Po;if(t.colorSpace&&"rgb"!==t.colorSpace){const e=Kr[t.colorSpace];u=(t,i)=>e.reverse(e.interpolate(e.forward(t),e.forward(i),s))}return"function"==typeof a.evaluate?{evaluate(...t){const e=a.evaluate.apply(void 0,t),i=l.evaluate.apply(void 0,t);if(void 0!==e&&void 0!==i)return u(e,i,s)}}:u(a,l,s)}function Ro(t,e,i){return"color"===e.type?i=Gn.parse(i):"formatted"===e.type?i=Xn.fromString(i.toString()):"resolvedImage"===e.type?i=Zn.fromString(i.toString()):So(i)===e.type||"enum"===e.type&&e.values[i]||(i=void 0),Io(i,t.default,e.default)}hr.register(xo,{error:[{kind:"error"},[Pn],(t,[e])=>{throw new ir(e.evaluate(t))}],typeof:[Pn,[qn],(t,[e])=>Dn(Qn(e.evaluate(t)))],"to-rgba":[Ln(_n,4),[On],(t,[e])=>e.evaluate(t).toArray()],rgb:[On,[_n,_n,_n],ko],rgba:[On,[_n,_n,_n,_n],ko],has:{type:In,overloads:[[[Pn],(t,[e])=>Mo(e.evaluate(t),t.properties())],[[Pn,En],(t,[e,i])=>Mo(e.evaluate(t),i.evaluate(t))]]},get:{type:qn,overloads:[[[Pn],(t,[e])=>jo(e.evaluate(t),t.properties())],[[Pn,En],(t,[e,i])=>jo(e.evaluate(t),i.evaluate(t))]]},"feature-state":[qn,[Pn],(t,[e])=>jo(e.evaluate(t),t.featureState||{})],properties:[En,[],t=>t.properties()],"geometry-type":[Pn,[],t=>t.geometryType()],id:[qn,[],t=>t.id()],zoom:[_n,[],t=>t.globals.zoom],pitch:[_n,[],t=>t.globals.pitch||0],"distance-from-center":[_n,[],t=>t.distanceFromCenter()],"heatmap-density":[_n,[],t=>t.globals.heatmapDensity||0],"line-progress":[_n,[],t=>t.globals.lineProgress||0],"sky-radial-progress":[_n,[],t=>t.globals.skyRadialProgress||0],accumulated:[qn,[],t=>void 0===t.globals.accumulated?null:t.globals.accumulated],"+":[_n,Ao(_n),(t,e)=>{let i=0;for(const n of e)i+=n.evaluate(t);return i}],"*":[_n,Ao(_n),(t,e)=>{let i=1;for(const n of e)i*=n.evaluate(t);return i}],"-":{type:_n,overloads:[[[_n,_n],(t,[e,i])=>e.evaluate(t)-i.evaluate(t)],[[_n],(t,[e])=>-e.evaluate(t)]]},"/":[_n,[_n,_n],(t,[e,i])=>e.evaluate(t)/i.evaluate(t)],"%":[_n,[_n,_n],(t,[e,i])=>e.evaluate(t)%i.evaluate(t)],ln2:[_n,[],()=>Math.LN2],pi:[_n,[],()=>Math.PI],e:[_n,[],()=>Math.E],"^":[_n,[_n,_n],(t,[e,i])=>Math.pow(e.evaluate(t),i.evaluate(t))],sqrt:[_n,[_n],(t,[e])=>Math.sqrt(e.evaluate(t))],log10:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))/Math.LN10],ln:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))],log2:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))/Math.LN2],sin:[_n,[_n],(t,[e])=>Math.sin(e.evaluate(t))],cos:[_n,[_n],(t,[e])=>Math.cos(e.evaluate(t))],tan:[_n,[_n],(t,[e])=>Math.tan(e.evaluate(t))],asin:[_n,[_n],(t,[e])=>Math.asin(e.evaluate(t))],acos:[_n,[_n],(t,[e])=>Math.acos(e.evaluate(t))],atan:[_n,[_n],(t,[e])=>Math.atan(e.evaluate(t))],min:[_n,Ao(_n),(t,e)=>Math.min(...e.map(e=>e.evaluate(t)))],max:[_n,Ao(_n),(t,e)=>Math.max(...e.map(e=>e.evaluate(t)))],abs:[_n,[_n],(t,[e])=>Math.abs(e.evaluate(t))],round:[_n,[_n],(t,[e])=>{const i=e.evaluate(t);return i<0?-Math.round(-i):Math.round(i)}],floor:[_n,[_n],(t,[e])=>Math.floor(e.evaluate(t))],ceil:[_n,[_n],(t,[e])=>Math.ceil(e.evaluate(t))],"filter-==":[In,[Pn,qn],(t,[e,i])=>t.properties()[e.value]===i.value],"filter-id-==":[In,[qn],(t,[e])=>t.id()===e.value],"filter-type-==":[In,[Pn],(t,[e])=>t.geometryType()===e.value],"filter-<":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n<r}],"filter-id-<":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i<n}],"filter->":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>r}],"filter-id->":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>n}],"filter-<=":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n<=r}],"filter-id-<=":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i<=n}],"filter->=":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>=r}],"filter-id->=":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>=n}],"filter-has":[In,[qn],(t,[e])=>e.value in t.properties()],"filter-has-id":[In,[],t=>null!==t.id()&&void 0!==t.id()],"filter-type-in":[In,[Ln(Pn)],(t,[e])=>e.value.indexOf(t.geometryType())>=0],"filter-id-in":[In,[Ln(qn)],(t,[e])=>e.value.indexOf(t.id())>=0],"filter-in-small":[In,[Pn,Ln(qn)],(t,[e,i])=>i.value.indexOf(t.properties()[e.value])>=0],"filter-in-large":[In,[Pn,Ln(qn)],(t,[e,i])=>function(t,e,i,n){for(;i<=n;){const r=i+n>>1;if(e[r]===t)return!0;e[r]>t?n=r-1:i=r+1}return!1}(t.properties()[e.value],i.value,0,i.value.length-1)],all:{type:In,overloads:[[[In,In],(t,[e,i])=>e.evaluate(t)&&i.evaluate(t)],[Ao(In),(t,e)=>{for(const i of e)if(!i.evaluate(t))return!1;return!0}]]},any:{type:In,overloads:[[[In,In],(t,[e,i])=>e.evaluate(t)||i.evaluate(t)],[Ao(In),(t,e)=>{for(const i of e)if(i.evaluate(t))return!0;return!1}]]},"!":[In,[In],(t,[e])=>!e.evaluate(t)],"is-supported-script":[In,[Pn],(t,[e])=>{const i=t.globals&&t.globals.isSupportedScript;return!i||i(e.evaluate(t))}],upcase:[Pn,[Pn],(t,[e])=>e.evaluate(t).toUpperCase()],downcase:[Pn,[Pn],(t,[e])=>e.evaluate(t).toLowerCase()],concat:[Pn,Ao(qn),(t,e)=>e.map(e=>tr(e.evaluate(t))).join("")],"resolved-locale":[Pn,[Rn],(t,[e])=>e.evaluate(t).resolvedLocale()]});class Co{constructor(t,e){this.expression=t,this.D={},this.U=new cr,this.W=e?function(t){return"color"===t.type&&_o(t.default)?new Gn(0,0,0,0):"color"===t.type?Gn.parse(t.default)||null:void 0===t.default?null:t.default}(e):null,this.J=e&&"enum"===e.type?e.values:null}evaluateWithoutErrorHandling(t,e,i,n,r,o,s,a){return this.U.globals=t,this.U.feature=e,this.U.featureState=i,this.U.canonical=n||null,this.U.availableImages=r||null,this.U.formattedSection=o,this.U.featureTileCoord=s||null,this.U.featureDistanceData=a||null,this.expression.evaluate(this.U)}evaluate(t,e,i,n,r,o,s,a){this.U.globals=t,this.U.feature=e||null,this.U.featureState=i||null,this.U.canonical=n||null,this.U.availableImages=r||null,this.U.formattedSection=o||null,this.U.featureTileCoord=s||null,this.U.featureDistanceData=a||null;try{const t=this.expression.evaluate(this.U);if(null==t||"number"==typeof t&&t!=t)return this.W;if(this.J&&!(t in this.J))throw new ir(`Expected value to be one of ${Object.keys(this.J).map(t=>JSON.stringify(t)).join(", ")}, but found ${JSON.stringify(t)} instead.`);return t}catch(t){return this.D[t.message]||(this.D[t.message]=!0,"undefined"!=typeof console&&console.warn(t.message)),this.W}}}function No(t){return Array.isArray(t)&&t.length>0&&"string"==typeof t[0]&&t[0]in xo}function Lo(t,e){const i=new Or(xo,[],e?function(t){const e={color:On,string:Pn,number:_n,enum:Pn,boolean:In,formatted:Cn,resolvedImage:Nn};return"array"===t.type?Ln(e[t.value]||qn,t.length):e[t.type]}(e):void 0),n=i.parse(t,void 0,void 0,void 0,e&&"string"===e.type?{typeAnnotation:"coerce"}:void 0);return n?Fo(new Co(n,e)):To(i.errors)}class Do{constructor(t,e){this.kind=t,this.H=e,this.isStateDependent="constant"!==t&&!_r(e.expression)}evaluateWithoutErrorHandling(t,e,i,n,r,o){return this.H.evaluateWithoutErrorHandling(t,e,i,n,r,o)}evaluate(t,e,i,n,r,o){return this.H.evaluate(t,e,i,n,r,o)}}class Uo{constructor(t,e,i,n){this.kind=t,this.zoomStops=i,this.H=e,this.isStateDependent="camera"!==t&&!_r(e.expression),this.interpolationType=n}evaluateWithoutErrorHandling(t,e,i,n,r,o){return this.H.evaluateWithoutErrorHandling(t,e,i,n,r,o)}evaluate(t,e,i,n,r,o){return this.H.evaluate(t,e,i,n,r,o)}interpolationFactor(t,e,i){return this.interpolationType?Qr.interpolationFactor(this.interpolationType,t,e,i):0}}function $o(t,e){if("error"===(t=Lo(t,e)).result)return t;const i=t.value.expression,n=Sr(i);if(!n&&!function(t){return"data-driven"===t["property-type"]||"cross-faded-data-driven"===t["property-type"]}(e))return To([new Tn("","data expressions not supported")]);const r=Pr(i,["zoom","pitch","distance-from-center"]);if(!r&&!function(t){return!!t.expression&&t.expression.parameters.indexOf("zoom")>-1}(e))return To([new Tn("","zoom expressions not supported")]);const o=function t(e){let i=null;if(e instanceof io)i=t(e.result);else if(e instanceof eo){for(const n of e.args)if(i=t(n),i)break}else(e instanceof qr||e instanceof Qr)&&e.input instanceof hr&&"zoom"===e.input.name&&(i=e);return i instanceof Tn||e.eachChild(e=>{const n=t(e);n instanceof Tn?i=n:!i&&n?i=new Tn("",\'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.\'):i&&n&&i!==n&&(i=new Tn("",\'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.\'))}),i}(i);if(!o&&!r)return To([new Tn("",\'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.\')]);if(o instanceof Tn)return To([o]);if(o instanceof Qr&&!zo(e))return To([new Tn("",\'"interpolate" expressions cannot be used with this property\')]);if(!o)return Fo(new Do(n?"constant":"source",t.value));const s=o instanceof Qr?o.interpolation:void 0;return Fo(new Uo(n?"camera":"composite",t.value,o.labels,s))}class Wo{constructor(t,e){this.G=t,this.V=e,Fn(this,function t(e,i){const n="color"===i.type,r=e.stops&&"object"==typeof e.stops[0][0],o=r||!(r||void 0!==e.property),s=e.type||(zo(i)?"exponential":"interval");if(n&&((e=Fn({},e)).stops&&(e.stops=e.stops.map(t=>[t[0],Gn.parse(t[1])])),e.default=Gn.parse(e.default?e.default:i.default)),e.colorSpace&&"rgb"!==e.colorSpace&&!Kr[e.colorSpace])throw new Error("Unknown color space: "+e.colorSpace);let a,l,u;if("exponential"===s)a=qo;else if("interval"===s)a=Eo;else if("categorical"===s){a=Oo,l=Object.create(null);for(const t of e.stops)l[t[0]]=t[1];u=typeof e.stops[0][0]}else{if("identity"!==s)throw new Error(`Unknown function type "${s}"`);a=Ro}if(r){const n={},r=[];for(let t=0;t<e.stops.length;t++){const i=e.stops[t],o=i[0].zoom;void 0===n[o]&&(n[o]={zoom:o,type:e.type,property:e.property,default:e.default,stops:[]},r.push(o)),n[o].stops.push([i[0].value,i[1]])}const o=[];for(const e of r)o.push([n[e].zoom,t(n[e],i)]);const s={name:"linear"};return{kind:"composite",interpolationType:s,interpolationFactor:Qr.interpolationFactor.bind(void 0,s),zoomStops:o.map(t=>t[0]),evaluate:({zoom:t},n)=>qo({stops:o,base:e.base},i,t).evaluate(t,n)}}if(o){const t="exponential"===s?{name:"exponential",base:void 0!==e.base?e.base:1}:null;return{kind:"camera",interpolationType:t,interpolationFactor:Qr.interpolationFactor.bind(void 0,t),zoomStops:e.stops.map(t=>t[0]),evaluate:({zoom:t})=>a(e,i,t,l,u)}}return{kind:"source",evaluate(t,n){const r=n&&n.properties?n.properties[e.property]:void 0;return void 0===r?Io(e.default,i.default):a(e,i,r,l,u)}}}(this.G,this.V))}static deserialize(t){return new Wo(t.G,t.V)}static serialize(t){return{G:t.G,V:t.V}}}function Jo(t){if(Array.isArray(t))return t.map(Jo);if(t instanceof Object&&!(t instanceof Number||t instanceof String||t instanceof Boolean)){const e={};for(const i in t)e[i]=Jo(t[i]);return e}return function(t){return t instanceof Number||t instanceof String||t instanceof Boolean?t.valueOf():t}(t)}function Ho(t){if(!0===t||!1===t)return!0;if(!Array.isArray(t)||0===t.length)return!1;switch(t[0]){case"has":return t.length>=2&&"$id"!==t[1]&&"$type"!==t[1];case"in":return t.length>=3&&("string"!=typeof t[1]||Array.isArray(t[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==t.length||Array.isArray(t[1])||Array.isArray(t[2]);case"any":case"all":for(const e of t.slice(1))if(!Ho(e)&&"boolean"!=typeof e)return!1;return!0;default:return!0}}function Go(t){if(!Array.isArray(t))return!1;if(function(t){return"pitch"===t||"distance-from-center"===t}(t[0]))return!0;for(let e=1;e<t.length;e++)if(Go(t[e]))return!0;return!1}const Vo=new Set(["in","==","!=",">",">=","<","<=","to-boolean"]);function Bo(t,e){return t<e?-1:t>e?1:0}function Xo(t){if(!t)return!0;const e=t[0];return t.length<=1?"any"!==e:"=="===e?Zo(t[1],t[2],"=="):"!="===e?Qo(Zo(t[1],t[2],"==")):"<"===e||">"===e||"<="===e||">="===e?Zo(t[1],t[2],e):"any"===e?(i=t.slice(1),["any"].concat(i.map(Xo))):"all"===e?["all"].concat(t.slice(1).map(Xo)):"none"===e?["all"].concat(t.slice(1).map(Xo).map(Qo)):"in"===e?Yo(t[1],t.slice(2)):"!in"===e?Qo(Yo(t[1],t.slice(2))):"has"===e?Ko(t[1]):"!has"===e?Qo(Ko(t[1])):"within"!==e||t;var i}function Zo(t,e,i){switch(t){case"$type":return["filter-type-"+i,e];case"$id":return["filter-id-"+i,e];default:return["filter-"+i,t,e]}}function Yo(t,e){if(0===e.length)return!1;switch(t){case"$type":return["filter-type-in",["literal",e]];case"$id":return["filter-id-in",["literal",e]];default:return e.length>200&&!e.some(t=>typeof t!=typeof e[0])?["filter-in-large",t,["literal",e.sort(Bo)]]:["filter-in-small",t,["literal",e]]}}function Ko(t){switch(t){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",t]}}function Qo(t){return["!",t]}xn((function(t,e){var i=function(){var t=function(t,e,i,n){for(i=i||{},n=t.length;n--;i[t[n]]=e);return i},e=[1,12],i=[1,13],n=[1,9],r=[1,10],o=[1,11],s=[1,14],a=[1,15],l=[14,18,22,24],u=[18,22],c=[22,24],h={trace:function(){},yy:{},symbols_:{error:2,JSONString:3,STRING:4,JSONNumber:5,NUMBER:6,JSONNullLiteral:7,NULL:8,JSONBooleanLiteral:9,TRUE:10,FALSE:11,JSONText:12,JSONValue:13,EOF:14,JSONObject:15,JSONArray:16,"{":17,"}":18,JSONMemberList:19,JSONMember:20,":":21,",":22,"[":23,"]":24,JSONElementList:25,$accept:0,$end:1},terminals_:{2:"error",4:"STRING",6:"NUMBER",8:"NULL",10:"TRUE",11:"FALSE",14:"EOF",17:"{",18:"}",21:":",22:",",23:"[",24:"]"},productions_:[0,[3,1],[5,1],[7,1],[9,1],[9,1],[12,2],[13,1],[13,1],[13,1],[13,1],[13,1],[13,1],[15,2],[15,3],[20,3],[19,1],[19,3],[16,2],[16,3],[25,1],[25,3]],performAction:function(t,e,i,n,r,o,s){var a=o.length-1;switch(r){case 1:this.$=new String(t.replace(/\\\\(\\\\|")/g,"$1").replace(/\\\\n/g,"\\n").replace(/\\\\r/g,"\\r").replace(/\\\\t/g,"\\t").replace(/\\\\v/g,"\\v").replace(/\\\\f/g,"\\f").replace(/\\\\b/g,"\\b")),this.$.B=this.X.first_line;break;case 2:this.$=new Number(t),this.$.B=this.X.first_line;break;case 3:this.$=null;break;case 4:this.$=new Boolean(!0),this.$.B=this.X.first_line;break;case 5:this.$=new Boolean(!1),this.$.B=this.X.first_line;break;case 6:return this.$=o[a-1];case 13:this.$={},Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 14:case 19:this.$=o[a-1],Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 15:this.$=[o[a-2],o[a]];break;case 16:this.$={},this.$[o[a][0]]=o[a][1];break;case 17:this.$=o[a-2],o[a-2][o[a][0]]=o[a][1];break;case 18:this.$=[],Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 20:this.$=[o[a]];break;case 21:this.$=o[a-2],o[a-2].push(o[a])}},table:[{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,12:1,13:2,15:7,16:8,17:s,23:a},{1:[3]},{14:[1,16]},t(l,[2,7]),t(l,[2,8]),t(l,[2,9]),t(l,[2,10]),t(l,[2,11]),t(l,[2,12]),t(l,[2,3]),t(l,[2,4]),t(l,[2,5]),t([14,18,21,22,24],[2,1]),t(l,[2,2]),{3:20,4:e,18:[1,17],19:18,20:19},{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:23,15:7,16:8,17:s,23:a,24:[1,21],25:22},{1:[2,6]},t(l,[2,13]),{18:[1,24],22:[1,25]},t(u,[2,16]),{21:[1,26]},t(l,[2,18]),{22:[1,28],24:[1,27]},t(c,[2,20]),t(l,[2,14]),{3:20,4:e,20:29},{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:30,15:7,16:8,17:s,23:a},t(l,[2,19]),{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:31,15:7,16:8,17:s,23:a},t(u,[2,17]),t(u,[2,15]),t(c,[2,21])],defaultActions:{16:[2,6]},parseError:function(t,e){if(!e.recoverable)throw new Error(t);this.trace(t)},parse:function(t){var e=this,i=[0],n=[null],r=[],o=this.table,s="",a=0,l=0,u=2,c=1,h=r.slice.call(arguments,1),d=Object.create(this.lexer),f={yy:{}};for(var p in this.yy)Object.prototype.hasOwnProperty.call(this.yy,p)&&(f.yy[p]=this.yy[p]);d.setInput(t,f.yy),f.yy.lexer=d,f.yy.parser=this,void 0===d.yylloc&&(d.yylloc={});var m=d.yylloc;r.push(m);var y=d.options&&d.options.ranges;function g(){var t;return"number"!=typeof(t=d.lex()||c)&&(t=e.symbols_[t]||t),t}this.parseError="function"==typeof f.yy.parseError?f.yy.parseError:Object.getPrototypeOf(this).parseError;for(var b,v,w,x,k,M,j,A={};;){if(this.defaultActions[v=i[i.length-1]]?w=this.defaultActions[v]:(null==b&&(b=g()),w=o[v]&&o[v][b]),void 0===w||!w.length||!w[0]){var F="";for(k in j=[],o[v])this.terminals_[k]&&k>u&&j.push("\'"+this.terminals_[k]+"\'");F=d.showPosition?"Parse error on line "+(a+1)+":\\n"+d.showPosition()+"\\nExpecting "+j.join(", ")+", got \'"+(this.terminals_[b]||b)+"\'":"Parse error on line "+(a+1)+": Unexpected "+(b==c?"end of input":"\'"+(this.terminals_[b]||b)+"\'"),this.parseError(F,{text:d.match,token:this.terminals_[b]||b,line:d.yylineno,loc:m,expected:j})}if(w[0]instanceof Array&&w.length>1)throw new Error("Parse Error: multiple actions possible at state: "+v+", token: "+b);switch(w[0]){case 1:i.push(b),n.push(d.yytext),r.push(d.yylloc),i.push(w[1]),b=null,l=d.yyleng,s=d.yytext,a=d.yylineno,m=d.yylloc;break;case 2:if(A.$=n[n.length-(M=this.productions_[w[1]][1])],A.X={first_line:r[r.length-(M||1)].first_line,last_line:r[r.length-1].last_line,first_column:r[r.length-(M||1)].first_column,last_column:r[r.length-1].last_column},y&&(A.X.range=[r[r.length-(M||1)].range[0],r[r.length-1].range[1]]),void 0!==(x=this.performAction.apply(A,[s,l,a,f.yy,w[1],n,r].concat(h))))return x;M&&(i=i.slice(0,-1*M*2),n=n.slice(0,-1*M),r=r.slice(0,-1*M)),i.push(this.productions_[w[1]][0]),n.push(A.$),r.push(A.X),i.push(o[i[i.length-2]][i[i.length-1]]);break;case 3:return!0}}return!0}};function d(){this.yy={}}return h.lexer={EOF:1,parseError:function(t,e){if(!this.yy.parser)throw new Error(t);this.yy.parser.parseError(t,e)},setInput:function(t,e){return this.yy=e||this.yy||{},this.Z=t,this.Y=this.K=this.done=!1,this.yylineno=this.yyleng=0,this.yytext=this.matched=this.match="",this.conditionStack=["INITIAL"],this.yylloc={first_line:1,first_column:0,last_line:1,last_column:0},this.options.ranges&&(this.yylloc.range=[0,0]),this.offset=0,this},input:function(){var t=this.Z[0];return this.yytext+=t,this.yyleng++,this.offset++,this.match+=t,this.matched+=t,t.match(/(?:\\r\\n?|\\n).*/g)?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this.Z=this.Z.slice(1),t},unput:function(t){var e=t.length,i=t.split(/(?:\\r\\n?|\\n)/g);this.Z=t+this.Z,this.yytext=this.yytext.substr(0,this.yytext.length-e),this.offset-=e;var n=this.match.split(/(?:\\r\\n?|\\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),i.length-1&&(this.yylineno-=i.length-1);var r=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:i?(i.length===n.length?this.yylloc.first_column:0)+n[n.length-i.length].length-i[0].length:this.yylloc.first_column-e},this.options.ranges&&(this.yylloc.range=[r[0],r[0]+this.yyleng-e]),this.yyleng=this.yytext.length,this},more:function(){return this.Y=!0,this},reject:function(){return this.options.backtrack_lexer?(this.K=!0,this):this.parseError("Lexical error on line "+(this.yylineno+1)+". You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},less:function(t){this.unput(this.match.slice(t))},pastInput:function(){var t=this.matched.substr(0,this.matched.length-this.match.length);return(t.length>20?"...":"")+t.substr(-20).replace(/\\n/g,"")},upcomingInput:function(){var t=this.match;return t.length<20&&(t+=this.Z.substr(0,20-t.length)),(t.substr(0,20)+(t.length>20?"...":"")).replace(/\\n/g,"")},showPosition:function(){var t=this.pastInput(),e=new Array(t.length+1).join("-");return t+this.upcomingInput()+"\\n"+e+"^"},test_match:function(t,e){var i,n,r;if(this.options.backtrack_lexer&&(r={yylineno:this.yylineno,yylloc:{first_line:this.yylloc.first_line,last_line:this.last_line,first_column:this.yylloc.first_column,last_column:this.yylloc.last_column},yytext:this.yytext,match:this.match,matches:this.matches,matched:this.matched,yyleng:this.yyleng,offset:this.offset,Y:this.Y,Z:this.Z,yy:this.yy,conditionStack:this.conditionStack.slice(0),done:this.done},this.options.ranges&&(r.yylloc.range=this.yylloc.range.slice(0))),(n=t[0].match(/(?:\\r\\n?|\\n).*/g))&&(this.yylineno+=n.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:n?n[n.length-1].length-n[n.length-1].match(/\\r?\\n?/)[0].length:this.yylloc.last_column+t[0].length},this.yytext+=t[0],this.match+=t[0],this.matches=t,this.yyleng=this.yytext.length,this.options.ranges&&(this.yylloc.range=[this.offset,this.offset+=this.yyleng]),this.Y=!1,this.K=!1,this.Z=this.Z.slice(t[0].length),this.matched+=t[0],i=this.performAction.call(this,this.yy,this,e,this.conditionStack[this.conditionStack.length-1]),this.done&&this.Z&&(this.done=!1),i)return i;if(this.K){for(var o in r)this[o]=r[o];return!1}return!1},next:function(){if(this.done)return this.EOF;var t,e,i,n;this.Z||(this.done=!0),this.Y||(this.yytext="",this.match="");for(var r=this.tt(),o=0;o<r.length;o++)if((i=this.Z.match(this.rules[r[o]]))&&(!e||i[0].length>e[0].length)){if(e=i,n=o,this.options.backtrack_lexer){if(!1!==(t=this.test_match(i,r[o])))return t;if(this.K){e=!1;continue}return!1}if(!this.options.flex)break}return e?!1!==(t=this.test_match(e,r[n]))&&t:""===this.Z?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+". Unrecognized text.\\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){return this.next()||this.lex()},begin:function(t){this.conditionStack.push(t)},popState:function(){return this.conditionStack.length-1>0?this.conditionStack.pop():this.conditionStack[0]},tt:function(){return this.conditionStack.length&&this.conditionStack[this.conditionStack.length-1]?this.conditions[this.conditionStack[this.conditionStack.length-1]].rules:this.conditions.INITIAL.rules},topState:function(t){return(t=this.conditionStack.length-1-Math.abs(t||0))>=0?this.conditionStack[t]:"INITIAL"},pushState:function(t){this.begin(t)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(t,e,i,n){switch(i){case 0:break;case 1:return 6;case 2:return e.yytext=e.yytext.substr(1,e.yyleng-2),4;case 3:return 17;case 4:return 18;case 5:return 23;case 6:return 24;case 7:return 22;case 8:return 21;case 9:return 10;case 10:return 11;case 11:return 8;case 12:return 14;case 13:return"INVALID"}},rules:[/^(?:\\s+)/,/^(?:(-?([0-9]|[1-9][0-9]+))(\\.[0-9]+)?([eE][-+]?[0-9]+)?\\b)/,/^(?:"(?:\\\\[\\\\"bfnrt/]|\\\\u[a-fA-F0-9]{4}|[^\\\\\\0-\\x09\\x0a-\\x1f"])*")/,/^(?:\\{)/,/^(?:\\})/,/^(?:\\[)/,/^(?:\\])/,/^(?:,)/,/^(?::)/,/^(?:true\\b)/,/^(?:false\\b)/,/^(?:null\\b)/,/^(?:$)/,/^(?:.)/],conditions:{INITIAL:{rules:[0,1,2,3,4,5,6,7,8,9,10,11,12,13],inclusive:!0}}},d.prototype=h,h.Parser=d,new d}();e.parser=i,e.Parser=i.Parser,e.parse=function(){return i.parse.apply(i,arguments)}}));const ts={StyleExpression:Co,isExpression:No,isExpressionFilter:Ho,createExpression:Lo,createPropertyExpression:$o,normalizePropertyExpression:function(t,e){if(_o(t))return new Wo(t,e);if(No(t)){const i=$o(t,e);if("error"===i.result)throw new Error(i.value.map(t=>`${t.key}: ${t.message}`).join(", "));return i.value}{let i=t;return"string"==typeof t&&"color"===e.type&&(i=Gn.parse(t)),{kind:"constant",evaluate:()=>i}}},ZoomConstantExpression:Do,ZoomDependentExpression:Uo,StylePropertyFunction:Wo},{isExpressionFilter:es,isExpression:is,createExpression:ns}=ts,rs={};function os(t){if(!0===t)return function(){return!0};if(t&&t.condition){if("any"===t.type){const e=t.condition,i=[];for(let t=0;t<e.length;t++)i.push(os(e[t]));return t=>{for(let e=0;e<i.length;e++)if(i[e](t))return!0;return!1}}const e=os(t.condition);if(Zi(t.layer))return e;const i=e=>e.layer===t.layer;return(t,n)=>i(t)&&e(t,n)}if(es(t)){let e=function(t,e="fill"){if(null==t)return{filter:()=>!0,needGeometry:!1,needFeature:!1};Ho(t)||(t=Xo(t));const i=t;let n=!0;try{n=function(t){if(!Go(t))return t;let e=Jo(t);return function t(e){let i=!1;const n=[];if("case"===e[0]){for(let t=1;t<e.length-1;t+=2)i=i||Go(e[t]),n.push(e[t+1]);n.push(e[e.length-1])}else if("match"===e[0]){i=i||Go(e[1]);for(let t=2;t<e.length-1;t+=2)n.push(e[t+1]);n.push(e[e.length-1])}else if("step"===e[0]){i=i||Go(e[1]);for(let t=1;t<e.length-1;t+=2)n.push(e[t+1])}i&&(e.length=0,e.push("any",...n));for(let i=1;i<e.length;i++)t(e[i])}(e),e=function t(e){if(!Array.isArray(e))return e;const i=function(t){if(Vo.has(t[0]))for(let e=1;e<t.length;e++)if(Go(t[e]))return!0;return t}(e);return!0===i?i:i.map(e=>t(e))}(e),e}(i)}catch(t){console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\\nand paste the contents of this message in the report.\\nThank you!\\nFilter Expression:\\n${JSON.stringify(i,null,2)}\\n `)}const r=vn["filter_"+e],o=Lo(n,r);let s=null;if("error"===o.result)throw new Error(o.value.map(t=>`${t.key}: ${t.message}`).join(", "));s=(t,e,i)=>o.value.evaluate(t,e,{},i);let a=null,l=null;if(n!==i){const t=Lo(i,r);if("error"===t.result)throw new Error(t.value.map(t=>`${t.key}: ${t.message}`).join(", "));a=(e,i,n,r,o)=>t.value.evaluate(e,i,{},n,void 0,void 0,r,o),l=!Sr(t.value.expression)}return s=s,{filter:s,dynamicFilter:a||void 0,needGeometry:function t(e){if(!Array.isArray(e))return!1;if("within"===e[0])return!0;for(let i=1;i<e.length;i++)if(t(e[i]))return!0;return!1}(n),needFeature:!!l}}(t);return e=e&&e.filter,(t,i)=>(rs.zoom=i,e&&e(rs,t))}return Lt(t)}const ss={type:"string","property-type":"data-driven",expression:{parameters:["zoom","feature"]}};function as(t){const e=ns(t,ss);if("success"!==e.result)throw new Error(`Invalid maplibre spec expression: ${JSON.stringify(t)} (${e.value})`);return e.value}function ls(t){return is(t)}var us=Object.freeze({__proto__:null,compileStyle:function(t){return function t(e){if(!Array.isArray(e))return t([e]);const i=[];for(let t=0;t<e.length;t++){let n;n=!0===e[t].filter?function(){return!0}:os(e[t].filter),i.push(Xi({},e[t],{filter:n}))}return i}(t=t.map(t=>{const e=Xi({},t);return e.filter&&e.filter.value&&(e.filter=e.filter.value),e}))},compileFilter:os,createExpression:as,isExpression:ls});const cs={lineWidth:1,lineStrokeWidth:1,lineDx:1,lineDy:1,lineOpacity:1,linePatternAnimSpeed:1,markerWidth:1,markerHeight:1,markerDx:1,markerDy:1,markerSpacing:1,markerOpacity:1,markerRotation:1,textWrapWidth:1,textSpacing:1,textSize:1,textHaloRadius:1,textHaloOpacity:1,textDx:1,textDy:1,textOpacity:1,textRotation:1,polygonOpacity:1},hs=[],ds={},fs={},ps={},ms=[];class ys{static isAtlasLoaded(t,e={}){const{iconAtlas:i}=e;return!!(!t||i&&i.positions[t])}static genFnTypes(t){const e={};for(const i in t)if(ls(t[i])){const n=(i+"_Fn_0").trim(),r=(i+"Fn").trim();e[n]=as(t[i]),e[r]=(t,i)=>(ds.zoom=t,fs.properties=i,e[n].evaluateWithoutErrorHandling(ds,fs,ps,null,ms))}else if(on(t[i])){const n=(i+"_Fn_0").trim(),r=(i+"Fn").trim();cs[i]?(e[n]=a(t[i]),e[r]=(t,i)=>{const r=e[n](t,i);return on(r)?a(r)(t,i):r}):(e[n]=l(t[i]),e[r]=(t,i)=>{const r=e[n](t,i);return on(r)?l(r)(t,i):r})}return e}constructor(t,e,i){this.options=i,this.symbolDef=e,this.symbol=u(e,()=>[i.zoom]),this.styledVectors=[],this.properties={},this.et=ys.genFnTypes(this.symbolDef),on(this.symbolDef.visible)&&(this.it=a(this.symbolDef.visible)),i.atlas&&(this.iconAtlas=i.atlas.iconAtlas,this.glyphAtlas=i.atlas.glyphAtlas),this.features=this.nt(t)}needAltitudeAttribute(){return this.options.forceAltitudeAttribute||this.maxPosZ>=Math.pow(2,17)||this.options.positionType===Float32Array}getPositionFormat(){return this.needAltitudeAttribute()?[{type:Int16Array,width:2,name:"aPosition"},{type:Float32Array,width:1,name:"aAltitude"}]:[{type:Int16Array,width:3,name:"aPosition"}]}fillPosition(t,e,i,n){this.needAltitudeAttribute()?(t.aPosition.push(e,i),t.aAltitude.push(n)):(yn(hs,e,i,n),t.aPosition.push(...hs))}nt(t){if(!t.length)return t;const e="__fea_idx".trim();let i,n=0,r=t[n];for(;!r.geometry;)n++,r=t[n];if(Array.isArray(r.geometry)&&r.properties){let e=r.geometry[0];for(;Array.isArray(e);)e=e[0];e instanceof Ot&&(i=t)}if(!i)if(i=[],Array.isArray(r.geometry))for(let e=0;e<t.length;e++){const n=Xi({},t[e]);i.push(Bi(n))}else for(let n=0;n<t.length;n++){const r=t[n],o=Si(r);for(let t=0;t<o.length;t++){const n=o[t];n[e]=r[e],i.push(n)}}if(this.maxPosZ=0,!this.options.forceAltitudeAttribute){const t="line"===this.symbolDef.textPlacement;let e=0,n=!1;const{textPitchAlignmentFn:r}=this.et;!r&&t&&"map"===this.symbolDef.textPitchAlignment&&(n=!0);for(let o=0;o<i.length;o++){const s=bs(i[o]&&i[o].geometry);if(s>e&&(e=s),t&&!n&&r&&i[o].properties){const t=r(null,i[o].properties);"map"===t&&(n=t)}}this.hasMapPitchAlign=n,this.maxPosZ=e}const o=this.options.order;if(o){const t=[];for(let e=0;e<o.length;e++)o[e]&&t.push(os(o[e]));i=i.sort((e,i)=>{const n=t.length;let r=n,o=n;for(let s=0;s<n&&(t[s](e)&&(r=s),t[s](i)&&(o=s),!(r<n&&o<n));s++);return r-o})}return i}load(t=1){const e="__fea_idx".trim(),i="_debug_info".trim(),n=this.et,r=this.styledVectors;this.count=0;const o=this.features;if(!o||!o.length)return Promise.resolve(null);const s={},a={},l={zoom:this.options.zoom},c=u(this.symbolDef,()=>[l.zoom]);let h=0,d=o.length;const f=this.options.debugIndex;try{for(;h<d;h++){const t=o[h];if(!t||!t.geometry)continue;if(void 0!==f&&t[i].index!==f)continue;t.properties||(t.properties={}),t.properties.$layer=t.layer,t.properties.$type=t.type;const u=this.createStyledVector(t,c,n,l,s,a);u&&u.feature.geometry&&(u.featureIdx=void 0===t[e]?h:t[e],this.count++,r.push(u))}}catch(t){return Promise.reject(t)}return this.options.atlas?Promise.resolve(this.pack(t)):this.loadAtlas(s,a).then(()=>this.pack(t))}loadAtlas(t,e){return new Promise((i,n)=>{this.fetchAtlas(t,e,(t,e)=>{if(t)n(t);else{if(e){const{icons:t,glyphs:i}=e;if(t&&Object.keys(t).length){for(const e in t){const i=t[e],{width:n,height:r,data:o}=i.data;i.data=new Li({width:n,height:r},o)}this.iconAtlas=new Ui(t)}if(i&&Object.keys(i).length){for(const t in i){const e=i[t];for(const t in e){const i=e[t],{width:n,height:r,data:o}=i.bitmap;i.bitmap=new Ni({width:n,height:r},o)}}this.glyphAtlas=new Ji(i)}}i({glyphAtlas:this.glyphAtlas,iconAtlas:this.iconAtlas})}})})}fetchAtlas(t,e,i){Object.keys(t).length>0||Object.keys(e).length>0?this.options.requestor(t,e,i):i()}pack(t){if(!this.count)return null;if(null==t)throw new Error("layout scale is undefined");const e=this.createDataPack(this.styledVectors,t);if(!e)return null;e.properties=this.properties,this.empty&&(e.empty=!0);const i=e.buffers;delete e.buffers;const n={data:e,buffers:i};if(this.iconAtlas){const t=n.data.iconAtlas=gs(this.iconAtlas);if(t.glyphMap)for(const e in t.glyphMap)i.push(t.glyphMap[e].data.data.buffer);i.push(n.data.iconAtlas.image.data.buffer)}return this.glyphAtlas&&(n.data.glyphAtlas=gs(this.glyphAtlas),i.push(n.data.glyphAtlas.image.data.buffer)),n}createStyledVector(t,e,i,n){return new mn(t,e,i,n)}createDataPack(t,e){if(!t||!t.length)return null;this.maxIndex=0,this.maxPos=0,this.maxAltitude=0;const i=this.data={};let n=this.elements=[];const r=this.getFormat(Array.isArray(t[0])?t[0][0].symbol:t[0].symbol),o=this.needAltitudeAttribute()?2:3;for(let t=0;t<r.length;t++)i[r[t].name]=[];let s=[],a=0;const l=[];let u=0,c=!1;for(let n=0,r=t.length;n<r;n++){if(!t[n].feature.geometry)continue;const r=Array.isArray(t[n])?t[n][0].feature.id:t[n].feature.id;Yi(r)&&(Math.abs(r)>u&&(u=Math.abs(r)),r<0&&(c=!0));const h=this.data.aPosition.length;if(Array.isArray(t[n]))for(let i=0;i<t[n].length;i++)this.rt(t[n][i],e);else this.rt(t[n],e);const d=(i.aPosition.length-h)/o;for(let e=0;e<d;e++)s.push(t[n].featureIdx),Yi(r)&&l.push(r);a=Math.max(a,t[n].featureIdx)}if(this.hasElements()&&!n.length)return null;s=new(Vi(a))(s),r[0].type=this.options.positionType?this.options.positionType:Gi(this.maxPos);const h=this.options.center;if(h&&(h[0]||h[1])){const t=i.aPosition;for(let e=0;e<t.length;e+=o)t[e]-=h[0],t[e+1]-=h[1]}const d=function(t,e){const i={};for(let n=0;n<t.length;n++){const r=t[n],o=r.type,s=r.name;i[s]=o===Array?e[s]:new o(e[s])}return i}(r,i);d.aPickingId=s;const f=[];for(const t in d)f.push(d[t].buffer);n=new(Hi(this.maxIndex))(n),f.push(n.buffer);const p={data:d,indices:this.hasElements()?n:null,positionSize:o,buffers:f,symbolIndex:this.symbolDef.index||{index:0}};if(l.length){const t=c?Gi(u):Vi(u);p.featureIds=new t(l),f.push(p.featureIds.buffer)}else p.featureIds=[];return p}rt(t,e){this.it&&this.it.isZoomConstant&&!this.it(null,t.feature.properties)||this.placeVector(t,e,this.formatWidth)}addElements(...t){this.maxIndex=Math.max(this.maxIndex,...t),this.elements.push(...t)}hasElements(){return!0}getAltitude(t){const{altitudeProperty:e,defaultAltitude:i,altitudeScale:n}=this.options;let r=cn(t,e,i);return n&&(r*=n),this.maxAltitude=Math.max(this.maxAltitude,Math.abs(r)),r}getIconAtlasMaxValue(){const t=this.iconAtlas.positions;let e=0;for(const i in t)if(nn(t,i)){const{tl:n,displaySize:r}=t[i],o=Math.max(n[0],n[1],r[0]-1,r[1]-1);o>e&&(e=o)}return e}}function gs(t){let e=t.positions,i=t.image&&t.image.format||"alpha";if(t instanceof Ui){e={};for(const i in t.positions){const n=t.positions[i];e[i]={paddedRect:n.paddedRect,pixelRatio:n.pixelRatio,tl:n.tl,br:n.br,displaySize:n.displaySize}}i="rgba"}const n=t.image;return{image:{width:n.width,height:n.height,data:n.data,format:i},glyphMap:t.glyphMap,positions:e}}function bs(t){if(!t)return 0;let e=0;if(Array.isArray(t))for(let i=0;i<t.length;i++)if(Array.isArray(t[i])){const n=bs(t[i]);n>e&&(e=n)}else{const n=Math.abs(t[i].z||0);n>e&&(e=n)}else{const i=Math.abs(t.z||0);i>e&&(e=i)}return e}function vs(t,e,i,n){const r="__fn_textSize".trim();let o=t.textSize;if(Zi(e.textSize))return[16,16];t[r]&&(o=t[r]);const s=[];return s[0]=tn(o)?o(n,i):o,s[1]=s[0],s}function ws(t){const e=t.stops;let i=-1/0;for(let t=0;t<e.length;t++){let n=e[t][1];Ki(e[t][1])&&(n=ws(e[t][1])),n>i&&(i=n)}return i}function xs(t,e,i){return[e||"normal",i||"normal","24px",t||"monospace"].join(" ")}const ks=/\\{[\\w-]+(?:\\|[\\w-]+)*\\}/g;function Ms(t,e){return Qi(t)?t.replace(ks,(function(t){if(!e)return"";if((t=t.substring(1,t.length-1)).indexOf("|")>0){const i=t.split("|");for(let t=0;t<i.length;t++){const n=e[i[t]];if(!Zi(n))return n}return""}const i=e[t];return Zi(i)?"":Array.isArray(i)?i.join():i})):t}Object.freeze({__proto__:null,getSDFFont:xs,resolveText:Ms});const js=t=>t>=11904&&t<=12031,As=t=>t>=12032&&t<=12255,Fs=t=>t>=12272&&t<=12287,Ts=t=>t>=12288&&t<=12351,zs=t=>t>=12352&&t<=12447,Ss=t=>t>=12448&&t<=12543,_s=t=>t>=12544&&t<=12591,Ps=t=>t>=12704&&t<=12735,Is=t=>t>=12736&&t<=12783,Os=t=>t>=12784&&t<=12799,Es=t=>t>=12800&&t<=13055,qs=t=>t>=13056&&t<=13311,Rs=t=>t>=13312&&t<=19903,Cs=t=>t>=19968&&t<=40959,Ns=t=>t>=40960&&t<=42127,Ls=t=>t>=42128&&t<=42191,Ds=t=>t>=63744&&t<=64255,Us=t=>t>=64336&&t<=65023,$s=t=>t>=65040&&t<=65055,Ws=t=>t>=65072&&t<=65103,Js=t=>t>=65104&&t<=65135,Hs=t=>t>=65136&&t<=65279,Gs=t=>t>=65280&&t<=65519;function Vs(t){return!((t=>t>=1536&&t<=1791)(t)||(t=>t>=1872&&t<=1919)(t)||(t=>t>=2208&&t<=2303)(t)||Us(t)||Hs(t))}function Bs(t){return!!(746===t||747===t||!(t<4352)&&(Ps(t)||_s(t)||Ws(t)&&!(t>=65097&&t<=65103)||Ds(t)||qs(t)||js(t)||Is(t)||!(!Ts(t)||t>=12296&&t<=12305||t>=12308&&t<=12319||12336===t)||Rs(t)||Cs(t)||Es(t)||(t=>t>=12592&&t<=12687)(t)||(t=>t>=43360&&t<=43391)(t)||(t=>t>=55216&&t<=55295)(t)||(t=>t>=4352&&t<=4607)(t)||(t=>t>=44032&&t<=55215)(t)||zs(t)||Fs(t)||(t=>t>=12688&&t<=12703)(t)||As(t)||Os(t)||Ss(t)&&12540!==t||!(!Gs(t)||65288===t||65289===t||65293===t||t>=65306&&t<=65310||65339===t||65341===t||65343===t||t>=65371&&t<=65503||65507===t||t>=65512&&t<=65519)||!(!Js(t)||t>=65112&&t<=65118||t>=65123&&t<=65126)||(t=>t>=5120&&t<=5759)(t)||(t=>t>=6320&&t<=6399)(t)||$s(t)||(t=>t>=19904&&t<=19967)(t)||Ns(t)||Ls(t)))}function Xs(t){return!(Bs(t)||function(t){return!!((t=>t>=128&&t<=255)(t)&&(167===t||169===t||174===t||177===t||188===t||189===t||190===t||215===t||247===t)||(t=>t>=8192&&t<=8303)(t)&&(8214===t||8224===t||8225===t||8240===t||8241===t||8251===t||8252===t||8258===t||8263===t||8264===t||8265===t||8273===t)||(t=>t>=8448&&t<=8527)(t)||(t=>t>=8528&&t<=8591)(t)||(t=>t>=8960&&t<=9215)(t)&&(t>=8960&&t<=8967||t>=8972&&t<=8991||t>=8996&&t<=9e3||9003===t||t>=9085&&t<=9114||t>=9150&&t<=9165||9167===t||t>=9169&&t<=9179||t>=9186&&t<=9215)||(t=>t>=9216&&t<=9279)(t)&&9251!==t||(t=>t>=9280&&t<=9311)(t)||(t=>t>=9312&&t<=9471)(t)||(t=>t>=9632&&t<=9727)(t)||(t=>t>=9728&&t<=9983)(t)&&!(t>=9754&&t<=9759)||(t=>t>=11008&&t<=11263)(t)&&(t>=11026&&t<=11055||t>=11088&&t<=11097||t>=11192&&t<=11243)||Ts(t)||Ss(t)||(t=>t>=57344&&t<=63743)(t)||Ws(t)||Js(t)||Gs(t)||8734===t||8756===t||8757===t||t>=9984&&t<=10087||t>=10102&&t<=10131||65532===t||65533===t)}(t))}function Zs(t){return t>=1424&&t<=2303||Us(t)||Hs(t)}const Ys=[[9,9],[32,32],[5760,5760],[8192,8198],[8200,8202],[8287,12288],[6158,6158],[8203,8205]];function Ks(t){for(const e of Ys)if(t>=e[0]&&t<=e[1])return!0;return!1}const Qs={"!":"︕","#":"#",$:"$","%":"%","&":"&","(":"︵",")":"︶","*":"*","+":"+",",":"︐","-":"︲",".":"・","/":"/",":":"︓",";":"︔","<":"︿","=":"=",">":"﹀","?":"︖","@":"@","[":"﹇","\\\\":"\","]":"﹈","^":"^",ot:"︳","`":"`","{":"︷","|":"―","}":"︸","~":"~","¢":"¢","£":"£","¥":"¥","¦":"¦","¬":"¬","¯":" ̄","–":"︲","—":"︱","‘":"﹃","’":"﹄","“":"﹁","”":"﹂","…":"︙","‧":"・","₩":"₩","、":"︑","。":"︒","〈":"︿","〉":"﹀","《":"︽","》":"︾","「":"﹁","」":"﹂","『":"﹃","』":"﹄","【":"︻","】":"︼","〔":"︹","〕":"︺","〖":"︗","〗":"︘","!":"︕","(":"︵",")":"︶",",":"︐","-":"︲",".":"・",":":"︓",";":"︔","<":"︿",">":"﹀","?":"︖","[":"﹇","]":"﹈","_":"︳","{":"︷","|":"―","}":"︸","⦅":"︵","⦆":"︶","。":"︒","「":"﹁","」":"﹂"};function ta(t,e,i,n,r,o,s,a,l,u){let c=t.trim();2===u&&(c=function(t){let e="";for(let i=0;i<t.length;i++){const n=t.charCodeAt(i+1)||null,r=t.charCodeAt(i-1)||null;e+=n&&Xs(n)&&!Qs[t[i+1]]||r&&Xs(r)&&!Qs[t[i-1]]||!Qs[t[i]]?t[i]:Qs[t[i]]}return e}(c));const h=[],d={positionedGlyphs:h,text:c,top:a[1],bottom:a[1],left:a[0],right:a[0],writingMode:u};let f;return f=function(t,e){const i=[];let n=0;for(let r=0;r<e.length;r++){const o=e[r];i.push(t.substring(n,o)),n=o}return n<t.length&&i.push(t.substring(n,t.length)),i}(c,function(t,e,i,n){if(!i)return[];if(!t)return[];const r=[],o=function(t,e,i,n){let r=0;for(let i=0;i<t.length;i++){const o=n[t.charCodeAt(i)];o&&(r+=o.metrics.advance+e)}return r/Math.max(1,Math.ceil(r/i))}(t,e,i,n);let s=0;for(let i=0;i<t.length;i++){const l=t.charCodeAt(i),u=n[l];u&&!ea[l]&&(s+=u.metrics.advance+e),i<t.length-1&&(ia[l]||!((a=l)<11904)&&(Ps(a)||_s(a)||Ws(a)||Ds(a)||qs(a)||js(a)||Is(a)||Ts(a)||Rs(a)||Cs(a)||Es(a)||Gs(a)||zs(a)||Fs(a)||As(a)||Os(a)||Ss(a)||$s(a)||Ls(a)||Ns(a)))&&r.push(oa(i+1,s,o,r,ra(l,t.charCodeAt(i+1)),!1))}var a;return function t(e){return e?t(e.priorBreak).concat(e.index):[]}(oa(t.length,s,o,r,0,!0))}(c,s,i,e)),function(t,e,i,n,r,o,s,a,l){let u=0,c=8,h=0;const d=t.positionedGlyphs,f="right"===o?1:"left"===o?0:.5;for(let t=0;t<i.length;t++){let r=i[t];if(r=r.trim(),!r.length){c-=n;continue}const o=d.length;for(let t=0;t<r.length;t++){const i=r.charCodeAt(t),n=e[i];n&&(Bs(i)&&1!==s?(32!==i&&d.push({glyph:i,x:u,y:0,vertical:!0}),u+=l+a):(32!==i&&d.push({glyph:i,x:u,y:c,vertical:!1}),u+=n.metrics.advance+a))}d.length!==o&&(h=Math.max(u-a,h),aa(d,e,o,d.length-1,f)),u=0,c-=n}const{horizontalAlign:p,verticalAlign:m}=sa(r);!function(t,e,i,n,r,o,s){const a=(e-i)*r,l=-(-n*s+.5)*o;if(a||l)for(let e=0;e<t.length;e++)t[e].x+=a,t[e].y+=l}(d,f,p,m,h,n,i.length);const y=i.length*n;t.top+=-m*y,t.bottom=t.top+y,t.left+=-p*h,t.right=t.left+h}(d,e,f,n,r,o,u,s,l),!!h.length&&d}const ea={9:!0,10:!0,11:!0,12:!0,13:!0,32:!0},ia={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 na(t,e,i,n){const r=Math.pow(t-e,2);return n?t<e?r/2:2*r:r+Math.abs(i)*i}function ra(t,e){let i=0;return 10===t&&(i-=1e4),40!==t&&65288!==t||(i+=50),41!==e&&65289!==e||(i+=50),i}function oa(t,e,i,n,r,o){let s=null,a=na(e,i,r,o);for(let t=0;t<n.length;t++){const l=n[t],u=na(e-l.x,i,r,o)+l.badness;u<=a&&(s=l,a=u)}return{index:t,x:e,priorBreak:s,badness:a}}function sa(t){let e=.5,i=.5;switch(t){case"right":case"top-right":case"bottom-right":e=1;break;case"left":case"top-left":case"bottom-left":e=0}switch(t){case"bottom":case"bottom-right":case"bottom-left":i=1;break;case"top":case"top-right":case"top-left":i=0}return{horizontalAlign:e,verticalAlign:i}}function aa(t,e,i,n,r){if(!r)return;const o=e[t[n].glyph];if(o){const e=(t[n].x+o.metrics.advance)*r;if(!e)return;for(let r=i;r<=n;r++)t[r].x-=e}}function la(t){if(!function(t){for(const e of t)if(Zs(e.charCodeAt(0)))return!0;return!1}(t))return t;const e=[],i=[],n=[];let r=0,o=0,s=1,a=1;for(const l of t){const t=l.codePointAt(0);Ks(t)?(n.push(l),r++):(s=Zs(t)?-1:1,a!==s?(o=r,i.length&&(a>0&&i.reverse(),e.push(...i)),n.length&&(e.splice(o,0,...n),n.length=0),a=s,i.length=0):n.length&&(i.push(...n),n.length=0),i.push(l),r++)}return n.length&&i.push(...n),i.length&&(a>0&&i.reverse(),e.push(...i)),e.reverse().join("")}const ua=/\\{ *([\\w_]+) *\\}/g;class ca{constructor(t,e,i,n,r){this.feature=t,this.symbolDef=e,this.symbol=i,this.options=r,this.st=this.lt.bind(this),this.et=n}lt(t,e){return this.feature.properties[e]||"default"}getShape(t,e){if(this.ut)return this.ut;const{textHorizontalAlignmentFn:i,textVerticalAlignmentFn:n,markerHorizontalAlignmentFn:r,markerVerticalAlignmentFn:o,textWrapWidthFn:s}=this.et;let a;const l=this.symbol,u=this.getIconAndGlyph(),c=this.feature.properties;if(u&&u.glyph){const{font:t,text:r}=u.glyph;if(""===r)return null;const o=this.size[0]/24,h=24,d=l.textKeepUpright,f="map"===l.textRotationAlignment&&"line"===l.textPlacement&&!l.isIconText,p=e.glyphMap[t],m=ha(i?i(null,c):l.textHorizontalAlignment,n?n(null,c):l.textVerticalAlignment),y=1.2*h,g=function(t){for(let e=0;e<t.length;e++)if(!Vs(t.charAt(e).charCodeAt(0)))return!1;return!0}(r),b=g&&l.textLetterSpacing/o||0,v=[l.textDx/o||0,l.textDy/o||0],w=((s?s(null,c):l.textWrapWidth)||10*h)/o;a={},a.horizontal=ta(r,p,w,y,m,"center",b,v,h,1),g&&f&&d&&(a.vertical=ta(r,p,w,y,m,"center",b,v,h,2))}else if(u&&u.icon){if(!t.positions[u.icon.url])return null;const e=ha(r?r(null,c):l.markerHorizontalAlignment,o?o(null,c):l.markerVerticalAlignment);a=function(t,e){const{horizontalAlign:i,verticalAlign:n}=sa(e),r=-24*i,o=-24*n;return{image:t,top:o,bottom:o+24,left:r,right:r+24}}(t.positions[u.icon.url],e),this.size||(this.size=a.image.displaySize)}return this.ut=a,a}getIconAndGlyph(){if(this.iconGlyph)return this.iconGlyph;const{markerFileFn:t,markerTypeFn:e,markerPathFn:i,markerWidthFn:n,markerHeightFn:r,markerFillFn:o,markerFillPatternFileFn:l,markerFillOpacityFn:u,markerTextFitFn:c,markerTextFitPaddingFn:h,markerLineColorFn:d,markerLineWidthFn:f,markerLineOpacityFn:p,markerLineDasharrayFn:m,markerLinePatternFileFn:y,markerPathWidthFn:g,markerPathHeightFn:b,textNameFn:v,textFaceNameFn:w,textStyleFn:x,textWeightFn:k}=this.et,{zoom:M}=this.options,j={},A=this.symbol,F=this.feature.properties,T=t?t(null,F):A.markerFile,z=e?e(null,F):A.markerType,S=T||z||A.markerPath,_=!Zi(this.symbolDef.textName);let P;if(S){P=function(t,e,i,n,r,o){if(Zi(e.markerWidth)&&Zi(e.markerHeight))return null;const s="__fn_markerWidth".trim(),a="__fn_markerHeight".trim();let l=e.markerWidth||0,u=e.markerHeight||0;return Ki(l)&&("identity"!==l.type?l=ws(l):(l=t.markerWidth,t[s]&&(l=t[s](n,i)),Ki(l)&&(l="identity"===l.type?r(n,i):ws(l)))),Ki(u)&&("identity"!==u.type?u=ws(u):(u=t.markerHeight,t[a]&&(u=t[a](n,i)),Ki(u)&&(u="identity"===u.type?o(n,i):ws(u)))),[l,u]}(A,this.symbolDef,F,M,n,r)||[0,0];let t=A.markerTextFit;if(c&&(t=c(M,F)),t&&A.text&&"none"!==t){const e=A.text.textSize;let i=A.text.textName;s(i)&&(i=a(i)(M,F));const n=Ms(i,F);if(n){const i="__fn_textSize".trim(),r="__fn_textSize_0".trim();s(e)&&!A.text[i]&&(A.text[r]=a(e),A.text[i]=(t,e)=>{const i=A.text[r](t,e);return s(i)?a(i)(t,e):i});const o=vs(A.text,A.text,F,M);if("width"!==t&&"both"!==t||(P[0]=o[0]*n.length),"height"!==t&&"both"!==t||(P[1]=o[1]),o[0]&&o[1]){let t=A.markerTextFitPadding||[0,0,0,0];h&&(t=h(M,F)),P[0]+=t[1]+t[3],P[1]+=t[0]+t[2]}}else P[0]=P[1]=-1}}if(_&&(P=vs(A,this.symbolDef,F,M)),!P)return j;if(P[0]=Math.ceil(P[0]),P[1]=Math.ceil(P[1]),this.size=P,S&&P[0]>=0&&P[1]>=0){let t;if(z){const e={};if(e.markerType=z,"path"===z&&(e.markerPath=i?i(null,F):A.markerPath,e.markerPathWidth=g?g(null,F):A.markerPathWidth,e.markerPathHeight=b?b(null,F):A.markerPathHeight),n){const t=n(null,F);Zi(t)||(e.markerWidth=t)}else A.markerWidth>=0&&(e.markerWidth=A.markerWidth);if(r){const t=r(null,F);Zi(t)||(e.markerHeight=t)}else A.markerHeight>=0&&(e.markerHeight=A.markerHeight);if(o){const t=o(null,F);Zi(t)||(e.markerFill=t)}else A.markerFill&&(e.markerFill=A.markerFill);if(l){const t=l(null,F);Zi(t)||(e.markerFillPatternFile=t)}else A.markerFillPatternFile&&(e.markerFillPatternFile=A.markerFillPatternFile);if(u){const t=u(null,F);Zi(t)||(e.markerFillOpacity=t)}else A.markerFillOpacity>=0&&(e.markerFillOpacity=A.markerFillOpacity);if(d){const t=d(null,F);Zi(t)||(e.markerLineColor=t)}else A.markerLineColor&&(e.markerLineColor=A.markerLineColor);if(f){const t=f(null,F);Zi(t)||(e.markerLineWidth=t)}else A.markerLineWidth>=0&&(e.markerLineWidth=A.markerLineWidth);if(p){const t=p(null,F);Zi(t)||(e.markerLineOpacity=t)}else A.markerLineOpacity>=0&&(e.markerLineOpacity=A.markerLineOpacity);if(m){const t=m(null,F);Zi(t)||(e.markerLineDasharray=t)}else A.markerLineDasharray&&(e.markerLineDasharray=A.markerLineDasharray);if(y){const t=y(null,F);Zi(t)||(e.markerLinePatternFile=t)}else A.markerLinePatternFile&&(e.markerLinePatternFile=A.markerLinePatternFile);t="vector://"+JSON.stringify(e)}else t=T?T.replace(ua,this.st):A.markerPath?function(t,e,i){if(!t.markerPath)return null;let n=1;const r=function(t){const e={stroke:{stroke:t.markerLineColor,"stroke-width":t.markerLineWidth,"stroke-opacity":t.markerLineOpacity,"stroke-dasharray":null,"stroke-linecap":"butt","stroke-linejoin":"round"},fill:{fill:t.markerFill,"fill-opacity":t.markerFillOpacity}};return 0===e.stroke["stroke-width"]&&(e.stroke["stroke-opacity"]=0),e}(t);Yi(t.markerOpacity)&&(n=t.markerOpacity),Yi(t.opacity)&&(n*=t.opacity);const o={};if(r){for(const t in r.stroke)nn(r.stroke,t)&&(Zi(r.stroke[t])||(o[t]=r.stroke[t]));for(const t in r.fill)nn(r.fill,t)&&(Zi(r.fill[t])||(o[t]=r.fill[t]))}const s=Array.isArray(t.markerPath)?t.markerPath:[t.markerPath];let a;const l=[];for(let t=0;t<s.length;t++)a=Qi(s[t])?{path:s[t]}:s[t],a=Xi({},a,o),a.d=a.path,delete a.path,l.push(a);const u=[\'<svg version="1.1"\',\'xmlns="http://www.w3.org/2000/svg"\'];n<1&&u.push(\'opacity="\'+n+\'"\'),t.markerPathWidth&&t.markerPathHeight&&u.push(\'viewBox="0 0 \'+t.markerPathWidth+" "+t.markerPathHeight+\'"\'),u.push(\'preserveAspectRatio="none"\'),e&&u.push(\'width="\'+e+\'"\'),i&&u.push(\'height="\'+i+\'"\'),u.push("><defs></defs>");for(let t=0;t<l.length;t++){let e="<path ";for(const i in l[t])nn(l[t],i)&&(e+=" "+i+\'="\'+l[t][i]+\'"\');e+="></path>",u.push(e)}return u.push("</svg>"),"data:image/svg+xml;base64,"+btoa(u.join(" "))}(A,P[0],P[1]):null;j.icon={url:t,size:P}}if(_){const t=v?v(this.options.zoom,F):A.textName;if(t||0===t){const e=xs(w?w(null,F):A.textFaceName,x?x(null,F):A.textStyle,k?k(null,F):A.textWeight);let i=Ms(t,F);i&&i.length&&(i=la(i),j.glyph={font:e,text:i})}}return this.iconGlyph=j,j}}function ha(t,e){e&&"middle"!==e||(e="center"),t&&"middle"!==t||(t="center");let i="center"!==e?e:"";return i+="center"!==t?(i.length?"-":"")+t:"",i\n/*!\n * From mapbox-gl-js\n * MIT License\n * https://github.com/mapbox/mapbox-gl-js\n */}function da(t,e,i,n,r){const o=[];let s;for(let a=0;a<t.length;a++){const l=t[a];let u,c=!1;for(let t=0;t<l.length-1;t++){let a=l[t],h=l[t+1];a.x<e&&h.x<e||(a.x<e?(s=a,a=new Ot(e,a.y+(e-a.x)/(h.x-a.x)*(h.y-a.y)).P(),a.z=s.z+(e-s.x)/(h.x-s.x)*(h.z-s.z),c=!0):h.x<e&&(s=h,h=new Ot(e,a.y+(e-a.x)/(h.x-a.x)*(h.y-a.y)).P(),h.z=a.z+(e-a.x)/(s.x-a.x)*(s.z-a.z),c=!0),a.y<i&&h.y<i||(a.y<i?(s=a,a=new Ot(a.x+(i-a.y)/(h.y-a.y)*(h.x-a.x),i).P(),a.z=s.z+(i-s.y)/(h.y-s.y)*(h.z-s.z),c=!0):h.y<i&&(s=h,h=new Ot(a.x+(i-a.y)/(h.y-a.y)*(h.x-a.x),i).P(),h.z=a.z+(i-a.y)/(s.y-a.y)*(s.z-a.z),c=!0),a.x>=n&&h.x>=n||(a.x>=n?(s=a,a=new Ot(n,a.y+(n-a.x)/(h.x-a.x)*(h.y-a.y)).P(),a.z=s.z+(n-s.x)/(h.x-s.x)*(h.z-s.z),c=!0):h.x>=n&&(s=h,h=new Ot(n,a.y+(n-a.x)/(h.x-a.x)*(h.y-a.y)).P(),h.z=a.z+(n-a.x)/(s.x-a.x)*(s.z-a.z),c=!0),a.y>=r&&h.y>=r||(a.y>=r?(s=a,a=new Ot(a.x+(r-a.y)/(h.y-a.y)*(h.x-a.x),r).P(),a.z=s.z+(r-s.y)/(h.y-s.y)*(h.z-s.z),c=!0):h.y>=r&&(s=h,h=new Ot(a.x+(r-a.y)/(h.y-a.y)*(h.x-a.x),r).P(),h.z=a.z+(r-a.y)/(s.y-a.y)*(s.z-a.z),c=!0),u&&a.equals(u[u.length-1])||(u=[a],o.push(u)),c&&(u.clipped=!0),u.push(h)))))}}return o}class fa extends Ot{constructor(t,e,i,n){super(t,e),this.angle=i,void 0!==n&&(this.segment=n)}clone(){return new fa(this.x,this.y,this.angle,this.segment)}}\n/*!\n * From mapbox-gl-js\n * MIT License\n * https://github.com/mapbox/mapbox-gl-js\n */function pa(t,e,i,n,r){if(void 0===e.segment)return!0;let o=e,s=e.segment+1,a=0;for(;a>-i/2;){if(s--,s<0)return!1;a-=t[s].dist(o),o=t[s]}a+=t[s].dist(t[s+1]),s++;const l=[];let u=0;for(;a<i/2;){const e=t[s],i=t[s+1];if(!i)return!1;let o=t[s-1].angleTo(e)-e.angleTo(i);for(o=Math.abs((o+3*Math.PI)%(2*Math.PI)-Math.PI),l.push({distance:a,angleDelta:o}),u+=o;a-l[0].distance>n;)u-=l.shift().angleDelta;if(u>r)return!1;s++,a+=e.dist(i)}return!0}function ma(t,e,i,n,r,o,s,a,l,u,c){const h=function(t,e,i){return t?.6*e*i:0}(n,o,s),d=function(t,e){return Math.max(t?t.right-t.left:0,e?e.right-e.left:0)}(n,r),f=0===t[0].x||t[0].x===l||0===t[0].y||t[0].y===l;return e-d*s<e/4&&(e=d*s+e/4),function t(e,i,n,r,o,s,a,l,u,c,h){const d=s/2,f=function(t){let e=0;for(let i=0;i<t.length-1;i++)e+=t[i].dist(t[i+1]);return e}(e);let p=0,m=i-n,y=[];for(let t=0;t<e.length-1;t++){const i=e[t],a=e[t+1],l=i.dist(a),g=a.angleTo(i);for(;m+n<p+l;){m+=n;const b=(m-p)/l,v=ya(i.x,a.x,b),w=ya(i.y,a.y,b),x=ya(i.z||0,a.z||0,b);if(v>=0&&v<u&&w>=0&&w<u&&m-d>=0&&m+d<=f){const n=new fa(v,w,g,t);n.z=x,c&&(n.axis=[i.y-w,v-i.x],n.angleR=x===(i.z||0)?0:Math.atan(.9*(x-(i.z||0))*h/i.dist(n))),n.line=e,n.P(),r&&!pa(e,n,s,r,o)||y.push(n)}}p+=l}return l||y.length||a||(y=t(e,p/2,n,r,o,s,a,!0,u,c,h)),y}(t,f?e/2*a%e:(d/2+2*o)*s*a%e,e,h,i,d*s,f,!1,l,u,c)}function ya(t,e,i){return t*(1-i)+e*i}function ga(t,e){const i=t.length;if(i<=1)return[t];const n=[];let r,o;for(let e=0;e<i;e++){const i=ln(t[e]);0!==i&&(t[e].area=Math.abs(i),void 0===o&&(o=i<0),o===i<0?(r&&n.push(r),r=[t[e]]):r.push(t[e]))}if(r&&n.push(r),e>1)for(let t=0;t<n.length;t++)n[t].length<=e||(Xt(n[t],e,1,n[t].length-1,ba),n[t]=n[t].slice(0,e));return n}function ba(t,e){return e.area-t.area}function va(t,e,i){const n=e.distSqr(i);if(0===n)return t.distSqr(e);const r=((t.x-e.x)*(i.x-e.x)+(t.y-e.y)*(i.y-e.y))/n;return t.distSqr(r<0?e:r>1?i:i.sub(e).M(r).u(e))}function wa(t,e=1,i=!1){let n=1/0,r=1/0,o=-1/0,s=-1/0;const a=t[0];for(let t=0;t<a.length;t++){const e=a[t];(!t||e.x<n)&&(n=e.x),(!t||e.y<r)&&(r=e.y),(!t||e.x>o)&&(o=e.x),(!t||e.y>s)&&(s=e.y)}const l=Math.min(o-n,s-r);let u=l/2;const c=new Qt(null,xa);if(0===l)return new Ot(n,r);for(let e=n;e<o;e+=l)for(let i=r;i<s;i+=l)c.push(new ka(e+u,i+u,u,t));let h=function(t){let e=0,i=0,n=0;const r=t[0];for(let t=0,o=r.length,s=o-1;t<o;s=t++){const o=r[t],a=r[s],l=o.x*a.y-a.x*o.y;i+=(o.x+a.x)*l,n+=(o.y+a.y)*l,e+=3*l}return new ka(i/e,n/e,0,t)}(t),d=c.length;for(;c.length;){const n=c.pop();(n.d>h.d||!h.d)&&(h=n,i&&console.log("found best %d after %d probes",Math.round(1e4*n.d)/1e4,d)),n.max-h.d<=e||(u=n.h/2,c.push(new ka(n.p.x-u,n.p.y-u,u,t)),c.push(new ka(n.p.x+u,n.p.y-u,u,t)),c.push(new ka(n.p.x-u,n.p.y+u,u,t)),c.push(new ka(n.p.x+u,n.p.y+u,u,t)),d+=4)}return i&&(console.log("num probes: "+d),console.log("best distance: "+h.d)),h.p}function xa(t,e){return e.max-t.max}function ka(t,e,i,n){this.p=new Ot(t,e),this.h=i,this.d=function(t,e){let i=!1,n=1/0;for(let r=0;r<e.length;r++){const o=e[r];for(let e=0,r=o.length,s=r-1;e<r;s=e++){const r=o[e],a=o[s];r.y>t.y!=a.y>t.y&&t.x<(a.x-r.x)*(t.y-r.y)/(a.y-r.y)+r.x&&(i=!i),n=Math.min(n,va(t,r,a))}}return(i?1:-1)*Math.sqrt(n)}(this.p,n),this.max=this.d+this.h*Math.SQRT2}const Ma=45*Math.PI/100;function ja(t,e,i,n,r,o,s,a,l){const{feature:u,size:c,symbol:h}=t,d=c?24:0,f=n*(c?c[0]/d:1),p=[];if("line"===o){let t=u.geometry;r&&(t=da(u.geometry,0,0,r,r));for(let n=0;n<t.length;n++){const o=ma(t[n],s,Ma,h.isIconText?null:i.vertical||i.horizontal||i,null,d,h.isIconText?1:f,1,r||1/0,a,l);if(h.textPlacement&&!h.isIconText)for(let t=0;t<o.length;t++)o[t].startIndex=e.length/3;if(p.push.apply(p,o),h.textPlacement&&!h.isIconText)for(let i=0;i<t[n].length;i++)e.push(t[n][i].x,t[n][i].y,t[n][i].z||0)}}else if(3===u.type){const t=ga(u.geometry,0);for(let e=0;e<t.length;e++){const i=t[e];if("vertex"===o)for(let t=0;t<i.length;t++){const e=i[t];for(let t=0;t<e.length;t++)dn(e[t],r)||p.push(e[t])}else{const t=wa(i,16);dn(t,r)||p.push(t)}}}else if(2===u.type)for(let t=0;t<u.geometry.length;t++){const e=u.geometry[t];if("vertex"===o)for(let t=0;t<e.length;t++)dn(e[t],r)||p.push(e[t]);else dn(e[0],r)||p.push(e[0])}else if(1===u.type)for(let t=0;t<u.geometry.length;t++){const e=u.geometry[t];for(let t=0;t<e.length;t++){const i=e[t];dn(i,r)||p.push(i)}}return p}function Aa(t,e){const i={},n={},r=[];let o=0;function s(e){r.push(t[e]),o++}function a(t,e,i){const o=n[t];return delete n[t],n[e]=o,r[o].geometry[0].pop(),r[o].geometry[0]=r[o].geometry[0].concat(i[0]),o}function l(t,e,n){const o=i[e];return delete i[e],i[t]=o,r[o].geometry[0].shift(),r[o].geometry[0]=n[0].concat(r[o].geometry[0]),o}function u(t,e,i){const n=i?e[0][e[0].length-1]:e[0][0];return`${t}:${n.x}:${n.y}`}for(let c=0;c<t.length;c++){const h=t[c],d=h.geometry;if(!d)continue;const f=h.properties[e]?h.properties[e].toString():null;if(!f){s(c);continue}const p=u(f,d),m=u(f,d,!0);if(p in n&&m in i&&n[p]!==i[m]){const t=l(p,m,d),e=a(p,m,r[t].geometry);delete i[p],delete n[m],n[u(f,r[e].geometry,!0)]=e,r[t].geometry=null}else p in n?a(p,m,d):m in i?l(p,m,d):(s(c),i[p]=o-1,n[m]=o-1)}return r.filter(t=>t.geometry)}class Fa extends ys{static needMerge(t){return!!t&&t.mergeOnProperty&&("line"===t.textPlacement||"line"===t.markerPlacement)}static mergeLineFeatures(t,e,i){const n="__index".trim(),r=function(t,e,i){const n="__index".trim(),r=ys.genFnTypes(e),{mergeOnPropertyFn:o}=r;if(!e.mergeOnProperty||"line"!==e.textPlacement&&"line"!==e.markerPlacement)return[];if(!(fn(s=e.mergeOnProperty)||"string"!=typeof s&&(null===s.constructor||s.constructor!==String)||"line"!==e.textPlacement&&"line"!==e.markerPlacement))return[{features:t,property:e.mergeOnProperty}];var s;const a=[],l={},u=[];for(let r=0;r<t.length;r++){t[r][n]=r;const s=t[r].properties=t[r].properties||{};s.$layer=t[r].layer,s.$type=t[r].type;let c=e.markerPlacement;"line"!==c&&(c=e.textPlacement);const h=o?o(i,s):e.mergeOnProperty;"line"!==c||fn(h)?u.push(t[r]):(void 0===l[h]&&(l[h]=a.length,a.push({features:[],property:h})),a[l[h]].features.push(t[r]))}return u.length&&a.push({features:u}),a}(t,e,i);if(r.length){const e=[];for(let i=0;i<r.length;i++)e.push(r[i].property?Aa(r[i].features,r[i].property):t);if(1===e.length)return e[0];{let t=[];for(let i=0;i<e.length;i++)t=t.concat(e[i]);return t.sort((t,e)=>t[n]-e[n]),t}}}static splitPointSymbol(t,e=0){const i=[];if(Array.isArray(t)){const e=t;for(let t=0;t<e.length;t++)e[t]&&i.push(...Fa.splitPointSymbol(e[t],t));return i}let n=null,r=null;for(const e in t)0===e.indexOf("marker")?(n=n||{},n[e]=t[e]):0===e.indexOf("text")&&(r=r||{},r[e]=t[e]);return n&&(n.isIconText=!0,t.mergeOnProperty&&(n.mergeOnProperty=t.mergeOnProperty),i.push(n)),r&&(n&&(r.textPlacement=n.markerPlacement,r.textSpacing=n.markerSpacing,r.isIconText=!0),t.mergeOnProperty&&(r.mergeOnProperty=t.mergeOnProperty),i.push(r)),void 0!==t.visible&&(n&&(n.visible=t.visible),r&&(r.visible=t.visible)),n&&(n.markerTextFit&&r&&(n.text={},n.text.textName=r.textName,n.text.textSize=r.textSize),n.index={index:e,type:0}),r&&(r.index={index:e,type:1}),i}static isAtlasLoaded(t,e){const{icon:i,glyph:n}=t,{iconAtlas:r,glyphAtlas:o}=e;if(i&&(!r||!r.positions[i.url]))return!1;if(n){if(!o||!o.positions[n.font])return!1;const t=o.positions[n.font],{text:e}=n;for(let i=0;i<e.length;i++)if(!t[e.charCodeAt(i)])return!1}return!0}constructor(t,e,i){super(t,e,i)}createStyledVector(t,e,i,n,r,o){const s=new ca(t,this.symbolDef,e,i,n),a=s.getIconAndGlyph();if(a.icon&&!this.options.atlas){const{url:t,size:e}=a.icon;r[t]||(r[t]=a.icon.size),r[t][0]<e[0]&&(r[t][0]=e[0]),r[t][1]<e[1]&&(r[t][1]=e[1])}if(a.glyph&&!this.options.atlas){const{font:t,text:i}=a.glyph,n=o[t]=o[t]||{};for(let t=0;t<i.length;t++)n[i.charCodeAt(t)]=1;"line"===e.textPlacement&&(o.options={isCharsCompact:!1})}return this.options.allowEmptyPack||a.icon||a.glyph?s:null}getFormat(t){const e=void 0!==t.textName,i=e?this.getPackSDFFormat(t):this.getPackMarkerFormat();e?i.push(...this.ct()):i.push(...this.ht());const{markerOpacityFn:n,textOpacityFn:r,markerPitchAlignmentFn:o,textPitchAlignmentFn:s,markerRotationAlignmentFn:a,textRotationAlignmentFn:l,markerRotationFn:u,textRotationFn:c,markerAllowOverlapFn:h,textAllowOverlapFn:d,markerIgnorePlacementFn:f,textIgnorePlacementFn:p}=this.et;return(n||r)&&i.push({type:Uint8Array,width:1,name:"aColorOpacity"}),(o||s)&&i.push({type:Uint8Array,width:1,name:"aPitchAlign"}),(a||l)&&i.push({type:Uint8Array,width:1,name:"aRotationAlign"}),(u||c)&&i.push({type:Uint16Array,width:1,name:"aRotation"}),(h||d||f||p)&&i.push({type:Uint8Array,width:1,name:"aOverlap"}),i}dt(){return this.hasMapPitchAlign}ct(){const{textFillFn:t,textSizeFn:e,textHaloFillFn:i,textHaloRadiusFn:n,textHaloOpacityFn:r,textDxFn:o,textDyFn:s}=this.et,a=[];return t&&a.push({type:Uint8Array,width:4,name:"aTextFill"}),e&&a.push({type:Uint8Array,width:1,name:"aTextSize"}),i&&a.push({type:Uint8Array,width:4,name:"aTextHaloFill"}),n&&a.push({type:Uint8Array,width:1,name:"aTextHaloRadius"}),r&&a.push({type:Uint8Array,width:1,name:"aTextHaloOpacity"}),o&&a.push({type:Int8Array,width:1,name:"aTextDx"}),s&&a.push({type:Int8Array,width:1,name:"aTextDy"}),a}ht(){const{markerWidthFn:t,markerHeightFn:e,markerDxFn:i,markerDyFn:n}=this.et,r=[];return t&&r.push({type:Uint8Array,width:1,name:"aMarkerWidth"}),e&&r.push({type:Uint8Array,width:1,name:"aMarkerHeight"}),i&&r.push({type:Int8Array,width:1,name:"aMarkerDx"}),n&&r.push({type:Int8Array,width:1,name:"aMarkerDy"}),r}createDataPack(){if(!this.iconAtlas&&!this.glyphAtlas){if(!this.options.allowEmptyPack)return null;this.empty=!0}this.lineVertex=[];const t=super.createDataPack.apply(this,arguments);return t?(t.lineVertex=new Int16Array(this.lineVertex),t.buffers.push(t.lineVertex.buffer),t):null}placeVector(t,e){const i=t.getShape(this.iconAtlas,this.glyphAtlas);if(!this.options.allowEmptyPack&&!i)return;const n=this.ft(t,i,e);if(0===n.length)return;const r=this.data,o=this.needAltitudeAttribute()?2:3;let a=this.data.aPosition.length/o;const l=t.symbol,u=t.feature.properties,c="line"===l.textPlacement&&!l.isIconText,h=void 0!==l.textName,d=h&&c&&function(t){let e=0;for(let i=0;i<t.length;i++)if(Bs(t.charAt(i).charCodeAt(0)))e=0;else if(e++,e>=1)return!1;return!0}(t.getIconAndGlyph().glyph.text)?1:0,{textFillFn:f,textSizeFn:p,textHaloFillFn:m,textHaloRadiusFn:y,textHaloOpacityFn:g,textDxFn:b,textDyFn:v,textPitchAlignmentFn:w,textRotationAlignmentFn:x,textRotationFn:k,textAllowOverlapFn:M,textIgnorePlacementFn:j,textOpacityFn:A,markerWidthFn:F,markerHeightFn:T,markerDxFn:z,markerDyFn:S,markerPitchAlignmentFn:_,markerRotationAlignmentFn:P,markerRotationFn:I,markerAllowOverlapFn:O,markerIgnorePlacementFn:E,markerOpacityFn:q}=this.et;let R,C,N,L,D,U,$,W,J,H,G,V,B,X,Z,Y,K;if(h){const e=t.getIconAndGlyph().glyph.font;R=function(t,e,i){const n=t.positionedGlyphs,r=[];for(let o=0;o<n.length;o++){const s=n[o],a=i[s.glyph];if(!a)continue;const l=a.rect;if(!l)continue;const u=4,c=a.metrics.advance/2,h=a.metrics.height/2,d=e?[s.x+c,0]:[0,0],f=e?[0,s.y-h]:[s.x+c,s.y-h],p=a.metrics.left-u-c+f[0],m=a.metrics.top-u+f[1],y=p+l.w,g=m+l.h,b=new Ot(p,m),v=new Ot(y,m),w=new Ot(p,g),x=new Ot(y,g);if(e&&s.vertical){const t=new Ot(-c,c),e=-Math.PI/2,i=new Ot(5,0);b.F(e,t).u(i),v.F(e,t).u(i),w.F(e,t).u(i),x.F(e,t).u(i)}r.push({tl:b,tr:v,bl:w,br:x,tex:l,writingMode:t.writingMode,glyphOffset:d})}return r}(i.horizontal,c,this.glyphAtlas.positions[e]),f&&(C=f(null,u),s(C)?C=[0,0,0,0]:(C=Array.isArray(C)?C.map(t=>255*t):We(C).array(),3===C.length&&C.push(255))),p&&(N=p(this.options.zoom,u),fn(N)&&(N=14)),m&&(L=m(null,u),L=Array.isArray(L)?L.map(t=>255*t):We(L).array(),3===L.length&&L.push(255)),y&&(D=y(null,u)),g&&(U=255*g(null,u)),b&&($=b(null,u)||0),v&&(W=v(null,u)||0),w&&(B=+("map"===w(null,u))),x&&(X=+("map"===x(null,u))),k&&(Z=pn(k(null,u),0,360)*Math.PI/180)}else R=i?function(t){const e=t.image,i=t.top-1/e.pixelRatio,n=t.left-1/e.pixelRatio,r=t.bottom+1/e.pixelRatio,o=t.right+1/e.pixelRatio;let s,a,l,u;return s=new Ot(n,i),a=new Ot(o,i),l=new Ot(o,r),u=new Ot(n,r),[{tl:s,tr:a,bl:u,br:l,tex:{x:e.tl[0],y:e.tl[1],w:e.displaySize[0],h:e.displaySize[1]},writingMode:void 0,glyphOffset:[0,0]}]}(i):function(){const t=new Ot(0,0),e=new Ot(0,0),i=new Ot(0,0);return[{tl:t,tr:e,bl:new Ot(0,0),br:i,tex:{x:0,y:0,w:0,h:0},writingMode:void 0,glyphOffset:[0,0]}]}(),F&&(J=F(null,u)),T&&(H=T(null,u)),z&&(G=z(null,u)),S&&(V=S(null,u)),_&&(B=+("map"===_(null,u))),P&&(X=+("map"===P(null,u))),I&&(Z=pn(I(null,u),0,360)*Math.PI/180);const Q=O||M;Q&&(Y=Q(null,u)||0);const tt=E||j;let et;tt&&(K=tt(null,u)||0);const it=A||q;it&&(et=255*it(this.options.zoom,u));const nt=this.options.EXTENT,rt=R.length;for(let t=0;t<n.length;t++){const e=n[t],i=e.z||0;if(nt!==1/0&&dn(e,nt))continue;const o=e.x,s=e.y,l=R.length;for(let t=0;t<l;t++){const n=R[t],{tl:l,tr:u,bl:f,br:p,tex:m}=n;this.pt(r,o,s,i,10*l.x,10*l.y,m.x,m.y+m.h),h&&this.yt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.gt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.pt(r,o,s,i,10*u.x,10*u.y,m.x+m.w,m.y+m.h),h&&this.yt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.gt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.pt(r,o,s,i,10*f.x,10*f.y,m.x,m.y),h&&this.yt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.gt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.pt(r,o,s,i,10*p.x,10*p.y,m.x+m.w,m.y),h&&this.yt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.gt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.addElements(a,a+1,a+2),this.addElements(a+1,a+2,a+3),a+=4;const y=Math.max(Math.abs(o),Math.abs(s),Math.abs(i));y>this.maxPos&&(this.maxPos=y)}}}pt(t,e,i,n,r,o,s,a){this.fillPosition(t,e,i,n),t.aShape.push(r,o),t.aTexCoord.push(s,a)}yt(t,e,i,n,r,o,s,a){if(t.aCount.push(i),e){t.aGlyphOffset.push(n[0],n[1]),this.dt()&&t.aPitchRotation.push(s[0],s[1],a);const e=r.startIndex;t.aSegment.push(r.segment+e,e,r.line.length),t.aVertical.push(o)}}gt(t,e,i,n,r,o,s,a,l,u,c,h,d,f,p,m,y,g){const{textFillFn:b,textSizeFn:v,textHaloFillFn:w,textHaloRadiusFn:x,textHaloOpacityFn:k,textDxFn:M,textDyFn:j,textPitchAlignmentFn:A,textRotationAlignmentFn:F,textRotationFn:T,textAllowOverlapFn:z,textIgnorePlacementFn:S,textOpacityFn:_,markerWidthFn:P,markerHeightFn:I,markerDxFn:O,markerDyFn:E,markerPitchAlignmentFn:q,markerRotationAlignmentFn:R,markerRotationFn:C,markerAllowOverlapFn:N,markerIgnorePlacementFn:L,markerOpacityFn:D}=this.et;b&&t.aTextFill.push(...e),v&&t.aTextSize.push(i),w&&t.aTextHaloFill.push(...n),x&&t.aTextHaloRadius.push(r),k&&t.aTextHaloOpacity.push(o),M&&t.aTextDx.push(s),j&&t.aTextDy.push(a),P&&t.aMarkerWidth.push(l),I&&t.aMarkerHeight.push(u),O&&t.aMarkerDx.push(c),E&&t.aMarkerDy.push(h),(D||_)&&t.aColorOpacity.push(d),(A||q)&&t.aPitchAlign.push(f),(R||F)&&t.aRotationAlign.push(p),(C||T)&&t.aRotation.push(9362*m);const U=N||z,$=L||S;(U||$)&&t.aOverlap.push((U?8:0)+4*y+(($?2:0)+g)),r>0&&(this.properties.hasHalo=1)}ft(t,e,i){const{feature:n,symbol:r}=t,o=this.bt(t,r),s=n.properties,{markerSpacingFn:a,textSpacingFn:l}=this.et,u=((a?a(null,s):r.markerSpacing)||(l?l(null,s):r.textSpacing)||250)*i,c=this.options.altitudeToTileScale;return ja(t,this.lineVertex,e,i,this.options.EXTENT,o,u,this.dt(),c)}bt(t,e){return this.et.markerPlacementFn?this.et.markerPlacementFn(this.options.zoom,t.feature.properties):e.markerPlacement||e.textPlacement}getPackSDFFormat(t){if("line"!==t.textPlacement||t.isIconText)return[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"},{type:Uint8Array,width:1,name:"aCount"}];{const t=[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"},{type:Uint8Array,width:1,name:"aCount"},{type:Int16Array,width:2,name:"aGlyphOffset"},{type:Uint16Array,width:3,name:"aSegment"},{type:Uint8Array,width:1,name:"aVertical"}];return this.dt()&&t.push({type:Float32Array,width:3,name:"aPitchRotation"}),t}}getPackMarkerFormat(){return[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"}]}}class Ta{constructor(t){this.x=t.x,this.y=t.y,this.z=t.z||0}clone(){return new Ta(this)}S(){return this.j(this.mag()),this}j(t){return this.x/=t,this.y/=t,this.z/=t,this}_(){var t=this.y;return this.y=this.x,this.x=-t,this}mag(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}add(t){return this.clone().u(t)}sub(t){return this.clone().m(t)}u(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}m(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}equals(t){return this.x===t.x&&this.y===t.y&&this.z===t.z}mult(t){return this.clone().M(t)}M(t){return this.x*=t,this.y*=t,this.z*=t,this}dist(t){return Math.sqrt(this.distSqr(t))}distSqr(t){var e=t.x-this.x,i=t.y-this.y,n=t.z-this.z;return e*e+i*i+n*n}P(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}angleTo(t){return Math.atan2(this.y-t.y,this.x-t.x)}}const za=Math.cos(Math.PI/180*37.5),Sa=Math.pow(2,16)/1,_a=new Ot,Pa=new Ot,Ia=new Ot;class Oa extends ys{constructor(t,e,i){super(t,e,i);let n=!1;const{lineDasharrayFn:r,lineDashColorFn:o}=this.et;this.hasGradient=this.symbol.lineGradientProperty,r&&(n=function(t,e,i){for(let n=0;n<t.length;n++)if(i(e,t[n].properties))return!0;return!1}(t,this.options.zoom,r),n&&(this.dasharrayFn=r)),this.hasDasharray=Ra(this.symbol.lineDasharray)||n,this.hasDasharray&&o&&(this.dashColorFn=o)}createStyledVector(t,e,i,n,r){const o=new mn(t,e,i,n),s=o.getLineResource();return!this.options.atlas&&s&&(r[s]=[0,0]),o}getFormat(){const{lineWidthFn:t,lineStrokeWidthFn:e,lineStrokeColorFn:i,lineColorFn:n,lineOpacityFn:r,lineDxFn:o,lineDyFn:s,linePatternAnimSpeedFn:a,linePatternGapFn:l}=this.et,u=[...this.getPositionFormat()];if(u.push(this.iconAtlas||this.hasDasharray?{type:Int8Array,width:3,name:"aExtrude"}:{type:Int8Array,width:2,name:"aExtrude"}),u.push({type:this.options.positionType||Uint16Array,width:1,name:"aLinesofar"}),t&&u.push({type:Uint8Array,width:1,name:"aLineWidth"}),e&&u.push({type:Uint8Array,width:1,name:"aLineStrokeWidth"}),n&&u.push({type:Uint8Array,width:4,name:"aColor"}),i&&u.push({type:Uint8Array,width:4,name:"aStrokeColor"}),r&&u.push({type:Uint8Array,width:1,name:"aOpacity"}),this.dasharrayFn&&u.push({type:Uint8Array,width:4,name:"aDasharray"}),this.dashColorFn&&u.push({type:Uint8Array,width:4,name:"aDashColor"}),this.iconAtlas){const t=this.getIconAtlasMaxValue();u.push({type:t>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return(o||s)&&u.push({type:Int8Array,width:2,name:"aLineDxDy"}),(a||l)&&u.push({type:Int8Array,width:2,name:"aLinePattern"}),u}placeVector(t){const{lineJoinFn:e,lineCapFn:i,lineWidthFn:n,lineHeightFn:r,lineStrokeWidthFn:o,lineStrokeColorFn:a,lineColorFn:l,lineOpacityFn:u,lineDxFn:c,lineDyFn:h,linePatternAnimSpeedFn:d,linePatternGapFn:f}=this.et,p=this.symbol,m=t.feature,y=m.properties;let g=p.lineJoin||"miter",b=p.lineCap||"butt";if(e&&(g=e(this.options.zoom,y)||"miter"),i&&(b=i(this.options.zoom,y)||"butt"),n){let t=n(this.options.zoom,y);Zi(t)&&(t=4),this.feaLineWidth=+t}else this.feaLineWidth=+p.lineWidth;if(r){let t=r(this.options.zoom,y);Zi(t)&&(t=this.feaLineWidth),this.feaLineHeight=+t}else this.feaLineHeight=+p.lineHeight||this.feaLineWidth;if(o){let t=o(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineStrokeWidth=t}else this.feaLineStrokeWidth=p.lineStrokeWidth||0;if(l&&(this.feaColor=l(this.options.zoom,y)||[255,255,255,255],s(this.feaColor)?this.feaColor=[0,0,0,0]:(this.feaColor=Array.isArray(this.feaColor)?this.feaColor.map(t=>255*t):We(this.feaColor).array(),3===this.feaColor.length&&this.feaColor.push(255))),a&&(this.feaStrokeColor=a(this.options.zoom,y)||[0,0,0,255],s(this.feaStrokeColor)?this.feaStrokeColor=[0,0,0,0]:(this.feaStrokeColor=Array.isArray(this.feaStrokeColor)?this.feaStrokeColor.map(t=>255*t):We(this.feaStrokeColor).array(),3===this.feaStrokeColor.length&&this.feaStrokeColor.push(255))),u){let t=u(this.options.zoom,y);Zi(t)&&(t=1),this.feaOpacity=255*t}if(this.dasharrayFn){let t=this.dasharrayFn(this.options.zoom,y)||[0,0,0,0];if(t.length<4){const e=t;1===t.length?t=[e[0],e[0],e[0],e[0]]:2===t.length?t=[e[0],e[1],e[0],e[1]]:3===t.length&&(t=[e[0],e[1],e[2],e[2]])}this.feaDash=t}if(this.dashColorFn){let t=(this.dashColorFn?this.dashColorFn(this.options.zoom,y):this.symbol.lineDashColor)||[0,0,0,0];t=Array.isArray(t)?t.map(t=>255*t):We(t).array(),3===t.length&&t.push(255),this.feaDashColor=t}if(this.iconAtlas){const e=t.getLineResource(),i=this.iconAtlas.glyphMap[e];if(this.feaTexInfo=this.feaTexInfo||[0,0,0,0],i){const{tl:t,displaySize:i}=this.iconAtlas.positions[e];this.feaTexInfo[0]=t[0]+1,this.feaTexInfo[1]=t[1]+1,this.feaTexInfo[2]=i[0]-3,this.feaTexInfo[3]=i[1]-3}else this.feaTexInfo[0]=this.feaTexInfo[1]=this.feaTexInfo[2]=this.feaTexInfo[3]=0}if(c){let t=c(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineDx=t}if(h){let t=h(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineDy=t}if(d){let t=d(this.options.zoom,y);Zi(t)&&(t=0),0!==t&&(this.properties.hasPatternAnim=1),this.feaPatternAnimSpeed=t}if(f){let t=f(this.options.zoom,y);Zi(t)&&(t=0),this.feaLinePatternGap=t}const v=this.options.EXTENT;let w=m.geometry;if(v!==1/0){w=[];const t=[];for(let e=0;e<m.geometry.length;e++){t[0]=m.geometry[e];const i=da(t,-1,-1,v+1,v+1);if(3===m.type&&i.length>1){const t=i[0],e=i[i.length-1];t[0].equals(e[e.length-1])&&(i[0]=e.concat(t.slice(1)),i.length=i.length-1)}w.push(...i)}}const x=this.needAltitudeAttribute()?2:3;for(let t=0;t<w.length;t++)this.offset=this.data.aPosition.length/x,this.vt(w[t],m,g,b,2,1.05)}wt(){return this.iconAtlas&&this.feaTexInfo[2]&&this.feaTexInfo[3]}vt(t,e,i,n,r,o){const s=this.wt()||Ra(this.feaDash)||Ra(this.symbol.lineDasharray),a=this.options.isTube;a&&(t=t.map(t=>new Ta(t))),this.overscaling=1;const l=this.options.EXTENT;if(this.distance=0,this.scaledDistance=0,this.totalDistance=0,this.prevVertex=null,this.symbol.lineGradientProperty&&e.properties&&nn(e.properties,"mapbox_clip_start")&&nn(e.properties,"mapbox_clip_end")){this.clipStart=+e.properties.mapbox_clip_start,this.clipEnd=+e.properties.mapbox_clip_end;for(let e=0;e<t.length-1;e++)this.totalDistance+=t[e].dist(t[e+1]);this.updateScaledDistance()}const u=3===e.type&&!t.clipped;let c=t.length;for(;c>=2&&t[c-1].equals(t[c-2]);)c--;let h=0;for(;h<c-1&&t[h].equals(t[h+1]);)h++;if(c<(u?3:2))return;"bevel"===i&&(r=1.05);const d=this.overscaling<=16?15*l/(512*this.overscaling):0,f={vertexLength:0,primitiveLength:0,currentNormal:null};let p,m,y,g,b;this.e1=this.e2=-1,u&&(p=t[c-2],b=t[h].sub(p).S()._());for(let e=h;e<c;e++){if(y=e===c-1?u?t[h+1]:void 0:t[e+1],y&&t[e].equals(y))continue;b&&(g=b),p&&(m=p),p=t[e],b=y?y.sub(p).S()._():g,f.dir=m?p.sub(m).S():y.sub(p).S(),g=g||b,f.currentNormal=g;let l=g.add(b);0===l.x&&0===l.y||l.S();const v=g.x*b.x+g.y*b.y,w=l.x*b.x+l.y*b.y,x=0!==w?1/w:1/0,k=2*Math.sqrt(2-2*w),M=w<za&&m&&y,j=g.x*b.y-g.y*b.x>0;if(!a&&M&&e>h){const t=p.dist(m);if(t>2*d){const e=p.sub(p.sub(m).M(d/t).P());e.z=p.z,this.updateDistance(m,e),this.addCurrentVertex(e,g,0,0,f),m=e}}const A=m&&y;f.middleVertex=A;let F=A?i:u?"butt":n;if(A&&"round"===F&&(x<o?F="miter":x<=2&&(F="fakeround")),"miter"===F&&x>r&&!a&&(F="bevel"),"bevel"===F&&(x>2&&(F="flipbevel"),x<r&&(F="miter")),m&&this.updateDistance(m,p),"miter"===F)a?(this.addCurrentVertex(p,g,0,0,f),f.dir=y.sub(p).S(),this.addCurrentVertex(p,b,0,0,f)):(l.M(x),this.addCurrentVertex(p,l,0,0,f),s&&(f.currentNormal=b,this.addCurrentVertex(p,l,0,0,f)));else if("flipbevel"===F){if(x>100)l=b.mult(-1);else{const t=x*g.add(b).mag()/g.sub(b).mag();l._().M(t*(j?-1:1))}this.addCurrentVertex(p,l,0,0,f),this.addCurrentVertex(p,l.mult(-1),0,0,f)}else if("bevel"===F||"fakeround"===F){const t=-Math.sqrt(x*x-1),e=j?t:0,i=j?0:t;if(m&&this.addCurrentVertex(p,g,e,i,f),"fakeround"===F){const t=Math.round(180*k/Math.PI/20);for(let e=1;e<t;e++){let i=e/t;if(.5!==i){const t=i-.5;i+=i*t*(i-1)*((1.0904+v*(v*(3.55645-1.43519*v)-3.2452))*t*t+(.848013+v*(.215638*v-1.06021)))}const n=b.sub(g).M(i).u(g).S().M(j?-1:1);this.addHalfVertex(p,n.x,n.y,!1,j,0,f)}}y&&(f.currentNormal=b,this.addCurrentVertex(p,b,-e,-i,f))}else if("butt"===F)this.addCurrentVertex(p,l,0,0,f);else if("square"===F){const t=m?1:-1;this.addCurrentVertex(p,l,t,t,f)}else"round"===F&&(m&&(this.addCurrentVertex(p,g,0,0,f),this.addCurrentVertex(p,g,1,1,f,!0)),y&&(this.addCurrentVertex(p,b,-1,-1,f,!0),this.addCurrentVertex(p,b,0,0,f)));if(!a&&M&&e<c-1){const t=p.dist(y);if(t>2*d){const e=p.add(y.sub(p).M(d/t).P());e.z=p.z,this.updateDistance(p,e),this.addCurrentVertex(e,b,0,0,f),p=e}}}}addCurrentVertex(t,e,i,n,r,o=!1){const s=e.x+e.y*i,a=e.y-e.x*i,l=e.y*n-e.x,u=-e.y-e.x*n;let c=0,h=0;if(r.middleVertex){_a.x=s,_a.y=a,Pa.x=l,Pa.y=u;const t=r.currentNormal;if(c=La(t,_a),0===i&&0===n)h=-c;else{const e=Ia;e.x=t.x,e.y=t.y,e.M(-1),h=La(e,Pa)}}this.addHalfVertex(t,s,a,o,!1,i,r,c),this.addHalfVertex(t,l,u,o,!0,-n,r,h),this.prevVertex&&t.equals(this.prevVertex)||(this.prevVertex=t),this.distance>Sa/2&&0===this.totalDistance&&(this.distance=0,this.updateScaledDistance(),this.addCurrentVertex(t,e,i,n,r,o))}addHalfVertex({x:t,y:e,z:i},n,r,o,s,a,l,u){this.fillData(this.data,t,e,i||0,n,r,o,s,1*this.scaledDistance,u);const c=l.vertexLength++;this.e1>=0&&this.e2>=0&&(this.addElements(this.e1,this.e2,c),l.primitiveLength++),s?this.e2=c:this.e1=c}fillData(t,e,i,n,r,o,s,a,l,u){const{lineWidthFn:c,lineStrokeWidthFn:h,lineStrokeColorFn:d,lineColorFn:f,lineOpacityFn:p,lineDxFn:m,lineDyFn:y,linePatternAnimSpeedFn:g,linePatternGapFn:b}=this.et;this.fillPosition(t,e,i,n);let v=63*r;v=(Math.sign(v)||1)*((Math.floor(Math.abs(v))>>1<<1)+ +s);let w=63*o;w=(Math.sign(w)||1)*((Math.floor(Math.abs(w))>>1<<1)+ +a),t.aExtrude.push(v,w),(this.iconAtlas||this.hasDasharray)&&t.aExtrude.push(63*u),t.aLinesofar.push(l),c&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),h&&t.aLineStrokeWidth.push(Math.round(2*this.feaLineStrokeWidth)),f&&t.aColor.push(...this.feaColor),d&&t.aStrokeColor.push(...this.feaStrokeColor),p&&t.aOpacity.push(this.feaOpacity),this.dasharrayFn&&t.aDasharray.push(...this.feaDash),this.dashColorFn&&t.aDashColor.push(...this.feaDashColor),this.iconAtlas&&t.aTexInfo.push(...this.feaTexInfo),(m||y)&&t.aLineDxDy.push(this.feaLineDx||0,this.feaLineDy||0),(g||b)&&t.aLinePattern.push(127*(this.feaPatternAnimSpeed||0),10*(this.feaLinePatternGap||0)),this.maxPos=Math.max(this.maxPos,Math.abs(e)+1,Math.abs(i)+1)}addElements(t,e,i){super.addElements(this.offset+t,this.offset+e,this.offset+i)}xt(t){const e=this.options.EXTENT,i=this.elements;for(let n=0;n<i.length;n+=3)e!==1/0&&(qa(this.data.aPosition,i[n],i[n+1],3,e)||qa(this.data.aPosition,i[n+1],i[n+2],3,e))||t.push(i[n],i[n+1],i[n+2])}kt(t){if(t.length<=1)return t;const e=[],i=this.options.EXTENT;let n,r=!0;for(n=0;n<t.length-1;n++){const o=Ea(t[n],t[n+1],i);o&&r||(e.push(t[n]),r=o)}return r||e.push(t[n]),e}updateDistance(t,e){if(this.options.isTube){const i=t.dist(e),n=sn(this.options)*(e.z-t.z);this.distance+=Math.sqrt(i*i+n*n)}else this.distance+=t.dist(e);this.updateScaledDistance()}updateScaledDistance(){this.scaledDistance=this.totalDistance>0?(this.clipStart+(this.clipEnd-this.clipStart)*this.distance/this.totalDistance)*(Sa-1):this.distance}}function Ea(t,e,i){return i!==1/0&&(t.x<0&&e.x<0||t.x>i&&e.x>i||t.y<0&&e.y<0||t.y>i&&e.y>i)}function qa(t,e,i,n,r){if(r===1/0)return!1;const o=Math.floor(.5*t[e*n]),s=Math.floor(.5*t[e*n+1]),a=Math.floor(.5*t[i*n]),l=Math.floor(.5*t[i*n+1]);return o===a&&(o<0||o>r)&&s!==l||s===l&&(s<0||s>r)&&o!==a}function Ra(t){if(!Array.isArray(t))return!1;for(let e=0;e<t.length;e++)if(t[e])return!0;return!1}const Ca=new Ot(0,0),Na=new Ot(0,0);function La(t,e){const i=t.mag(),n=e.mag();Ca.x=e.x,Ca.y=e.y;const r=t.angleTo(Na),o=e.angleTo(Na);return Math.sign(o-r)*Math.sqrt(n*n-i*i)}class Da extends Oa{constructor(t,e,i){super(t,e,i),this.Mt=i.altitudeProperty}getFormat(){const{lineColorFn:t,lineWidthFn:e}=this.et,i=[{type:this.maxPosZ>=Math.pow(2,15)?Float32Array:Int16Array,width:3,name:"aPosition"},{type:Uint16Array,width:1,name:"aLinesofar"},{type:Uint8Array,width:1,name:"aUp"},{type:Int16Array,width:3,name:"aExtrudedPosition"},{type:Int8Array,width:2,name:"aExtrude"}];return t&&i.push({type:Uint8Array,width:4,name:"aColor"}),e&&i.push({type:Uint8Array,width:1,name:"aLineWidth"}),this.Mt&&i.push({type:Array,width:1,name:"aLineHeight"}),i}placeVector(t){const e=t.feature;if(this.Mt){const{altitudeScale:t,altitudeProperty:i,defaultAltitude:n,heightProperty:r,defaultHeight:o,minHeightProperty:s}=this.options,{altitude:a,height:l}=hn(e,t,i,n,r,o,s);this.feaAltitude=a,this.feaMinHeight=(a-l)/a*32767,a>this.maxAltitude&&(this.maxAltitude=a)}return super.placeVector(t)}needAltitudeAttribute(){return!1}vt(t,e,i,n,r,o){const s=this.data.aPosition.length/3;super.vt(t,e,i,n,r,o);const a=this.data.aPosition.length/3,l=this.data.aPosition.length/3-this.offset;if(3!==e.type&&l>0&&!1!==this.options.side){const t=!1!==this.options.top?1:0,e=t+4;let i=this.data.aPosition.length/3;for(const t in this.data){const e=this.data[t],n=e.length/i;for(let t=0;t<n;t++)e.push(e[s*n+3*n+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[s*r+r*e+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[s*r+r*(e+3)+t])}super.addElements(t+1,l+1,l),super.addElements(l,l+1,l+2);const n=this.data.aPosition.length/3-this.offset;i=this.data.aPosition.length/3;for(const t in this.data){const e=this.data[t],n=e.length/i;for(let t=0;t<n;t++)e.push(e[a*n-n+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[a*r-e*r-r+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[a*r-e*r-3*r+t])}super.addElements(n,l-3,n+1),super.addElements(l-3,n+2,n+1)}}fillData(t,e,i,n,r,o,s,a,l){const u=!1!==this.options.top,c=!1!==this.options.side,h=this.feaLineWidth||this.symbol.lineWidth/2*(this.options.EXTENT/this.options.tileSize),d=63*r,f=63*o,p=h*r+e,m=h*o+i;this.jt(t,e,i,r,o,s,a,l,p,m,d,f),c&&(u&&this.jt(t,e,i,r,o,s,a,l,p,m,d,f),this.jt(t,e,i,r,o,s,a,l,p,m,d,f),this.At(t,e,i,r,o,s,a,l,p,m,d,f),this.At(t,e,i,r,o,s,a,l,p,m,d,f)),this.maxPos=Math.max(this.maxPos,Math.abs(e),Math.abs(i))}jt(t,e,i,n,r,o,s,a,l,u,c,h){const{lineColorFn:d,lineWidthFn:f}=this.et;t.aPosition.push(e,i,32767),t.aLinesofar.push(a),t.aUp.push(+s),t.aExtrudedPosition.push(l,u,1),t.aExtrude.push(c,h),d&&t.aColor.push(...this.feaColor),f&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),this.Mt&&t.aLineHeight.push(this.feaAltitude)}At(t,e,i,n,r,o,s,a,l,u,c,h){const{lineColorFn:d,lineWidthFn:f}=this.et;t.aPosition.push(e,i,this.feaMinHeight||0),t.aLinesofar.push(a),t.aUp.push(+s),t.aExtrudedPosition.push(l,u,1),t.aExtrude.push(c,h),d&&t.aColor.push(...this.feaColor),f&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),this.Mt&&t.aLineHeight.push(this.feaAltitude)}addElements(t,e,i){const n=!1!==this.options.top,r=!1!==this.options.side,o=(n?1:0)+(r?4:0);if(t*=o,e*=o,this.data.aUp[this.offset+(i*=o)+4]){if(n&&super.addElements(e,t,i),r){const t=n?1:0;super.addElements(e+t,i+t,i+t+2),super.addElements(e+t+1,i+t+1+2,e+t+1+2)}}else if(n&&super.addElements(t,i,e),r){const e=n?1:0;super.addElements(t+e,t+e+2,i+e),super.addElements(t+e+1+2,i+e+1+2,i+e+1)}}createDataPack(t,e){this.maxAltitude=0;const i=super.createDataPack(t,e);if(!i)return i;const{data:n,indices:r}=i;this.getFormat().reduce((t,e)=>(t[e.name]={size:e.width},t),{}).aPickingId={size:1};const{aExtrudedPosition:o,aPosition:s,aLinesofar:a,aUp:l,aExtrude:u,aColor:c,aLineHeight:h,aLineWidth:d}=n,f={},p=Ye(o,r);let m,y=!0;for(let t=0;t<p.length;t++)p[t]=-p[t],p[t]%1!=0&&(y=!1);if(!1!==this.options.top&&this.symbol.material&&function(t){for(const e in t)if(e.indexOf("Texture")>=0&&t[e])return!0;return!1}(this.symbol.material)&&(m=function(t,e,i){const n=[];for(let r=0;r<t.length;r+=3){const t=e[r/3];n.push(t/256,i[r/3]?1:0)}return n}(o,a,l)),f.aPosition=s,m&&(f.aTexCoord0=new Float32Array(m)),f.aNormal=y?new Int8Array(p):new Float32Array(p),f.aPickingId=n.aPickingId,f.aExtrude=u,c&&(f.aColor=c),d&&(f.aLineWidth=d),h){const t=Gi(this.maxAltitude);f.aLineHeight=new t(h)}const g=[];for(const t in f)g.push(f[t].buffer);return i.data=f,i.buffers=g,i}}const Ua=Math.pow(2,16)/1;class $a extends ys{getFormat(){return[...this.getPositionFormat()]}placeVector(t){const e=t.feature,i=3===e.type,n=e.geometry,r=this.elements;i&&(this.elements=[]);const o=this.needAltitudeAttribute()?2:3;for(let t=0;t<n.length;t++)this.offset=this.data.aPosition.length/o,this.vt(n[t],e),i&&(this.xt(r),this.elements=[]);i&&(this.elements=r)}vt(t,e){const i=3===e.type;let n=t.length;for(;n>=2&&t[n-1].equals(t[n-2]);)n--;let r,o,s,a=0;for(;a<n-1&&t[a].equals(t[a+1]);)a++;if(!(n<(i?3:2))){this.distance=0,this.vertexLength=0,this.primitiveLength=0,this.e1=this.e2=this.e3=-1,i&&(r=t[n-2]);for(let e=a;e<n;e++)s=i&&e===n-1?t[a+1]:t[e+1],s&&t[e].equals(s)||(r&&(o=r),r=t[e],o&&(this.distance+=r.dist(o)),this.addCurrentVertex(r,this.distance))}}addCurrentVertex(t,e){const i=this.vertexLength++;this.addLineVertex(this.data,t,e),i>=1&&this.addElements(i-1,i),e>Ua&&(this.distance=0,this.addCurrentVertex(t,this.distance))}addLineVertex(t,e){this.fillPosition(t,e.x,e.y,e.z||0),this.maxPos=Math.max(this.maxPos,Math.abs(e.x),Math.abs(e.y))}addElements(t,e){super.addElements(this.offset+t,this.offset+e)}xt(t){const e=this.options.EXTENT,i=this.elements;for(let n=0;n<i.length;n+=2)un(this.data.aPosition,i[n],i[n+1],3,e)||t.push(i[n],i[n+1])}}const Wa=45*Math.PI/100;class Ja extends ys{getFormat(){return[...this.getPositionFormat()]}placeVector(t){const e=this.ft(t,this.symbol.markerSpacing||250,this.symbol.markerPlacement||"point");for(let t=0;t<e.length;t++){const i=e[t];this.fillPosition(this.data,i.x,i.y,i.z);const n=Math.max(Math.abs(i.x),Math.abs(i.y));n>this.maxPos&&(this.maxPos=n)}}ft(t,e,i){const n=t.feature,r=t.feature.type,o=this.options.EXTENT,s=[];if("line"===i){let t=n.geometry;o&&(t=da(n.geometry,0,0,o,o));for(let i=0;i<t.length;i++){const n=ma(t[i],e,Wa,null,null,24,1,1,o||1/0);s.push.apply(s,n)}}else if(3===r){const t=ga(n.geometry,0);for(let e=0;e<t.length;e++){const i=wa(t[e],16);dn(i,o)||s.push(i)}}else if(2===n.type)for(let t=0;t<n.geometry.length;t++){const e=n.geometry[t];dn(e[0],o)||s.push(e[0])}else if(1===n.type)for(let t=0;t<n.geometry.length;t++){const e=n.geometry[t];for(let t=0;t<e.length;t++){const i=e[t];dn(i,o)||s.push(i)}}return s}hasElements(){return!1}}\n/*!\n * from @turf/bboxClip\n * https://github.com/Turfjs/turf\n * MIT LICENSE\n */const Ha=[],Ga=[];function Va(t,e){var i,n,r,o,s,a,l;for(n=1;n<=8;n*=2){for(i=[],o=!(Xa(r=t[t.length-1],e)&n),s=0;s<t.length;s++){if((l=!(Xa(a=t[s],e)&n))!==o){const t=Ba(r,a,n,e);i.push(void 0!==a.x?new Ot(t[0],t[1]):t)}l&&i.push(a),r=a,o=l}if(!(t=i).length)break}return i}function Ba(t,e,i,n){return Ha[0]=void 0===t.x?t[0]:t.x,Ha[1]=void 0===t.y?t[1]:t.y,t=Ha,Ga[0]=void 0===e.x?e[0]:e.x,Ga[1]=void 0===e.y?e[1]:e.y,e=Ga,8&i?[t[0]+(e[0]-t[0])*(n[3]-t[1])/(e[1]-t[1]),n[3]]:4&i?[t[0]+(e[0]-t[0])*(n[1]-t[1])/(e[1]-t[1]),n[1]]:2&i?[n[2],t[1]+(e[1]-t[1])*(n[2]-t[0])/(e[0]-t[0])]:1&i?[n[0],t[1]+(e[1]-t[1])*(n[0]-t[0])/(e[0]-t[0])]:null}function Xa(t,e){Ha[0]=void 0===t.x?t[0]:t.x,Ha[1]=void 0===t.y?t[1]:t.y;var i=0;return(t=Ha)[0]<e[0]?i|=1:t[0]>e[2]&&(i|=2),t[1]<e[1]?i|=4:t[1]>e[3]&&(i|=8),i}class Za extends ys{constructor(...t){super(...t),this.lineElements=[]}createStyledVector(t,e,i,n,r){const o=new mn(t,e,i,n),s=o.getPolygonResource();return!this.options.atlas&&s&&(r[s]=[0,0]),o}getFormat(){const t=[...this.getPositionFormat()],{polygonFillFn:e,polygonOpacityFn:i,uvScaleFn:n,uvOffsetFn:r}=this.et;if(this.iconAtlas){const e=this.getIconAtlasMaxValue();t.push({type:e>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return e&&t.push({type:Uint8Array,width:4,name:"aColor"}),i&&t.push({type:Uint8Array,width:1,name:"aOpacity"}),n&&t.push({type:Uint16Array,width:2,name:"aUVScale"}),r&&t.push({type:Uint8Array,width:2,name:"aUVOffset"}),t}createDataPack(...t){this.maxLineIndex=0,this.lineElements=[];const e=super.createDataPack(...t);if(!e)return e;let i=this.lineElements;return i=new(Hi(this.maxLineIndex))(this.lineElements),e.lineIndices=i,e.buffers.push(i.buffer),e}placeVector(t,e){const i=t.feature;this.Ft(i.geometry,i,e)}Ft(t,e){let i,n,r,o;const{polygonFillFn:a,polygonOpacityFn:l,uvScaleFn:u,uvOffsetFn:c}=this.et,h=e.properties;a&&(i=a(this.options.zoom,h)||[255,255,255,255],s(i)?i=[0,0,0,0]:(i=Array.isArray(i)?i.map(t=>255*t):We(i).array(),3===i.length&&i.push(255))),l&&(n=l(this.options.zoom,h),Zi(n)&&(n=1),n*=255),u&&(r=u(this.options.zoom,h),Zi(r)&&(r=[1,1]),r=[255*r[0],255*r[1]]),c&&(o=c(this.options.zoom,h),Zi(o)&&(o=[0,0]),o=[255*o[0],255*o[1]]);const d=!!this.iconAtlas,f=ga(t,500),p=[0,0],m=[0,0];if(d){const{polygonPatternFileFn:t}=this.et,e=t?t(null,h):this.symbol.polygonPatternFile;if(this.iconAtlas.glyphMap[e]){const t=this.iconAtlas.positions[e];p[0]=t.tl[0]+1,p[1]=t.tl[1]+1,m[0]=t.displaySize[0]-3,m[1]=t.displaySize[1]-3}}const y=this.needAltitudeAttribute()?2:3,g=[-1,-1,e.extent+1,e.extent+1];for(let t=0;t<f.length;t++){const e=f[t],s=this.data.aPosition.length/y,a=[],l=[];for(let t=0;t<e.length;t++){let s=e[t];if(this.options.EXTENT!==1/0&&0===this.maxPosZ&&(s=Va(s,g)),0===s.length)continue;0!==t&&l.push(a.length/3);const u=this.lineElements.length;this.fillPosition(this.data,s[0].x,s[0].y,s[0].z||0),d&&this.data.aTexInfo.push(...p,...m),void 0!==i&&this.data.aColor.push(...i),void 0!==n&&this.data.aOpacity.push(n),void 0!==r&&this.data.aUVScale.push(...r),void 0!==o&&this.data.aUVOffset.push(...o),this.maxPos=Math.max(this.maxPos,Math.abs(s[0].x),Math.abs(s[0].y)),this.addLineElements(u+s.length-1,u),a.push(s[0].x),a.push(s[0].y),a.push(s[0].z||0);for(let t=1;t<s.length;t++)this.fillPosition(this.data,s[t].x,s[t].y,s[t].z||0),d&&this.data.aTexInfo.push(...p,...m),void 0!==i&&this.data.aColor.push(...i),void 0!==n&&this.data.aOpacity.push(n),void 0!==r&&this.data.aUVScale.push(...r),void 0!==o&&this.data.aUVOffset.push(...o),this.maxPos=Math.max(this.maxPos,Math.abs(s[t].x),Math.abs(s[t].y)),this.addLineElements(u+t-1,u+t),a.push(s[t].x),a.push(s[t].y),a.push(s[t].z||0)}const u=Ti(a,l,3);for(let t=0;t<u.length;t+=3)this.addElements(s+u[t],s+u[t+1],s+u[t+2])}}addLineElements(...t){this.maxLineIndex=Math.max(this.maxLineIndex,...t),this.lineElements.push(...t)}}const Ya=[{type:Int16Array,width:3,name:"aPosition"}];class Ka extends ys{getFormat(){return Ya}placeVector(t,e){const i=this.ft(t,e);if(0===i.length)return;const n=this.data,r=this.getAltitude(t.feature.properties);let o=n.aPosition.length/Ya[0].width;for(let t=0;t<i.length;t++){const e=i[t];n.aPosition.push(2*e.x+0,2*e.y+0,r),n.aPosition.push(2*e.x+1,2*e.y+0,r),n.aPosition.push(2*e.x+1,2*e.y+1,r),n.aPosition.push(2*e.x+0,2*e.y+1,r),this.addElements(o,o+1,o+2),this.addElements(o,o+2,o+3),o+=4;const s=Math.max(Math.abs(2*e.x+1),Math.abs(2*e.y+1));s>this.maxPos&&(this.maxPos=s)}}ft(t,e){const{feature:i,symbol:n}=t,r=this.bt(n),o=i.properties,{markerSpacingFn:s}=this.et,a=((s?s(null,o):n.markerSpacing)||250)*e;return ja(t,null,null,e,this.options.EXTENT,r,a)}bt(t){return t.markerPlacement}}class Qa extends Oa{constructor(t,e,i){(e=Xi({},e)).lineJoin="miter",e.lineCap="butt",super(t,e,i),this.options.radialSegments%2==1&&this.options.radialSegments--}getFormat(){const{lineWidthFn:t,lineColorFn:e,lineOpacityFn:i,linePatternAnimSpeedFn:n,linePatternGapFn:r}=this.et,o=[...this.getPositionFormat(),{type:Int8Array,size:4,name:"aTubeNormal"},{type:this.options.positionType||Uint16Array,width:1,name:"aLinesofar"}];if(this.iconAtlas){o.push({type:Int8Array,width:1,name:"aNormalDistance"});const t=this.getIconAtlasMaxValue();o.push({type:t>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return t&&o.push({type:Uint16Array,width:1,name:"aLineWidth"}),e&&o.push({type:Uint8Array,width:4,name:"aColor"}),i&&o.push({type:Uint8Array,width:1,name:"aOpacity"}),n&&o.push({type:Int8Array,width:1,name:"aLinePatternAnimSpeed"}),r&&o.push({type:Int8Array,width:1,name:"aLinePatternGap"}),o}addHalfVertex(t,e,i,n,r,o,s,a){const{x:l,y:u,z:c}=t,h=1*this.scaledDistance,d=this.options.radialSegments/2,{x:f,y:p,z:m}=s.dir,y=function(t,e,i,n,r,o,s,a){dt(tl,i,n,r),dt(el,o,s,0),gt(il,tl,el),mt(el,el),mt(il,il),nl[e]||(nl[e]=[]);const l=nl[e];for(var u=0;u<e;u++){const t=Math.PI*u/e,i=1-Math.abs(t-0)/(Math.PI/2);l[u]=l[u]||[],rl(el,il,l[u],1,t,i*(a?-1:1))}return l}(0,d,f,p,m,e,i,r);this.prevVertex&&this.fillTubeElements(r),this.fillData(this.data,l,u,c||0,y,r,h,a)}fillTubeElements(t){const e=this.options.radialSegments/2,i=this.needAltitudeAttribute()?2:3,n=this.data.aPosition.length/i;for(let i=0;i<e;i++){const r=i+n-2*e;let o,s;i===e-1&&t?(o=i+n-2*e+1,s=i+n-2*e-2*e+1):(o=i+n+1,s=i+n+1-2*e),super.addElements(i+n-this.offset,o-this.offset,r-this.offset),super.addElements(r-this.offset,o-this.offset,s-this.offset)}}fillData(t,e,i,n,r,o,s,a){const{lineWidthFn:l,lineColorFn:u,lineOpacityFn:c,linePatternAnimSpeedFn:h,linePatternGapFn:d}=this.et,f=r.length;for(let o=0;o<f;o++){if(this.fillPosition(t,e,i,n),xt(r[o],r[o],63),t.aTubeNormal.push(...r[o]),t.aLinesofar.push(s),this.iconAtlas&&(t.aNormalDistance.push(63*a),t.aTexInfo.push(...this.feaTexInfo)),l){const e=an(this.options.metric);let i=this.feaLineWidth*e;isNaN(i)&&(i=0),t.aLineWidth.push(Math.round(i))}u&&t.aColor.push(...this.feaColor),c&&t.aOpacity.push(this.feaOpacity),h&&t.aLinePatternAnimSpeed.push(127*(this.feaPatternAnimSpeed||0)),d&&t.aLinePatternGap.push(10*(this.feaLinePatternGap||0))}this.maxPos=Math.max(this.maxPos,Math.abs(e)+1,Math.abs(i)+1)}}const tl=[],el=[],il=[],nl={};function rl(t,e,i,n,r,o){return wt(i,n*(Math.cos(r)*t[0]+Math.sin(r)*e[0]),n*(Math.cos(r)*t[1]+Math.sin(r)*e[1]),n*(Math.cos(r)*t[2]+Math.sin(r)*e[2]),o),i}class ol extends Qa{addHalfVertex(t,e,i,n,r,o,s,a){const{x:l,y:u,z:c}=t,h=1*this.scaledDistance,{x:d,y:f,z:p}=s.dir,m=function(t,e,i,n,r,o,s,a){dt(al,i,n,r),dt(ll,o,s,0),gt(ul,al,ll),mt(ll,ll),mt(ul,ul),function(t,e,i){t[0]=e,t[1]=i}(sl,t,e);const l=zt(sl)/t,u=Math.atan(e/t);let c=Math.PI/2+(Math.PI/2-u);return cl[0]||(cl[0]=[]),rl(ll,ul,cl[0],l,c,a?1:-1),c+=2*u,cl[1]||(cl[1]=[]),rl(ll,ul,cl[1],l,c,a?1:-1),cl}(this.feaLineWidth,this.feaLineHeight,d,f,p,e,i,r);this.prevVertex&&this.fillTubeElements(r),this.fillData(this.data,l,u,c||0,m,r,h,a)}}const sl=[],al=[],ll=[],ul=[],cl=[];var hl=Object.freeze({__proto__:null,clipPolygon:Va,calculateSignedArea:ln,getFeaAltitudeAndHeight:hn,convertRTLText:la,packPosition:yn,unpackPosition:function(t,e,i,n){const r=(Math.sign(e)||1)*(Math.abs(e)%gn),o=(Math.sign(i)||1)*(Math.abs(i)%gn),s=Math.floor(Math.abs(e)/gn),a=Math.floor(Math.abs(i)/gn);return t[0]=r,t[1]=o,t[2]=Math.sign(n+1e-5)*(2*s+a)*bn+n,t}});const dl={polygonPatternFile:1,markerFile:1,markerPlacement:1,markerSpacing:1,textName:1,textStyle:1,textFaceName:1,textWeight:1,textPlacement:1,textSpacing:1,lineJoin:1,lineCap:1,linePatternFile:1};Object.assign({visible:1,textHorizontalAlignment:1,textVerticalAlignment:1,textWrapWidth:1,markerHorizontalAlignment:1,markerVerticalAlignment:1},dl),Object.assign({lineDasharray:1},dl);function fl(t,e,i,n,r,o,s,a,l,u,c,h,d,f,p){const m=e.length,y=r/3;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-o;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-s;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-o;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-s;r+=m,(i=i||[]).push(m/3);for(let e=0;e<i.length;e++){pl(y+(i[e-1]||0),y+i[e],t,m/3,a,n,l,u,c,h,d,f,p)}return r}function pl(t,e,i,n,r,o,s,a,l,u,c,h,d){const f=o.length;let p,m;for(let s=t,a=e;s<a-1;s++)p=s,m=s+1,it(i,p,m,r)||((s-t)%2==1&&(p+=2*n,m+=2*n),o.push(p+n,p,m),o.push(m,m+n,p+n));s&&function(t,e,i,n,r,o,s,a,l){let u,c=0,h=0,d=0,f=0;for(let p=n.length-1;p>=0;p--){const m=3*n[p],y=3*n[p]+1,g=3*n[p]+2,b=i[m],v=i[y],w=i[g];c||h||(c=Math.max(i[g],i[3*n[p-2]+2]),h=Math.min(i[g],i[3*n[p-2]+2]),u=c-h);let x=d;const k=p%6;0===t?(5===k&&(f=It(i,n,p,b,v)),x=2===k||3===k||4===k?d:d+f):1===t&&(2===k||3===k||4===k?x=0:5===k?(f=It(i,n,p,b,v),x=f):x=f);const M=x*s*a/r,j=w===c?0:u*l/o;e[m/3*2]=M,e[m/3*2+1]=-j,0===k&&(d+=f)}}(a,l,i,o.slice(f,o.length),u[0],u[1],c,h,d)}function ml(t,e,i,n,r,o,s,u,c,h){void 0===e.top&&(e.top=!0),void 0===e.side&&(e.side=!0);const{altitudeScale:d,altitudeProperty:f,defaultAltitude:p,heightProperty:y,minHeightProperty:g,defaultHeight:b,tangent:j,uv:A,uvScale:F,topUVMode:T,sideUVMode:z,top:S,side:_,topThickness:P}=e,I=function(t,e,{altitudeScale:i,altitudeProperty:n,defaultAltitude:r,heightProperty:o,minHeightProperty:s,defaultHeight:a},{side:l,top:u,topThickness:c,uvOrigin:h,uv:d,uvSize:f,topUVMode:p,sideUVMode:y,glScale:g,localScale:b,vScale:w},M){const j=e/t[0].extent,A=[],F=[],T=[],z=[],S=[],_=[],P=!!d,I=!!u,O=!!l,E=P?[]:null;function q(t,i,n,r){if(I){const r=Ti(z,n,3);if(0===r.length)return i;let o;v(S,z),i+=z.length;for(let e=2,i=r.length;e<i;e+=3)o=r[e-1],r[e-1]=r[e]+t/3,r[e]=o+t/3,r[e-2]+=t/3;v(_,r),P&&St(p||0,t,i,E,S,0,g,b,f[0],f[1]),c>0&&!O&&(i=fl(S,z,n,_,i,0,c,e,P,y||0,E,f,g,b,w))}return O&&(I&&(c=0),i=fl(S,z,n,_,i,c,r,e,P,y||0,E,f,g,b,w)),i}let R=0,C=0;const N=[-1,-1,e+1,e+1];let L=0,D=t.length;void 0!==M&&(L=M,D=M+1);let U=0,$=!1;for(;L<D;L++){const l=t[L],u=l.id;m(u)&&(Math.abs(u)>U&&(U=Math.abs(u)),u<0&&($=!0));const c=l.geometry,{altitude:h,height:d}=hl.getFeaAltitudeAndHeight(l,i,n,r,o,a,s);R=Math.max(Math.abs(h),R);const f=S.length;let p=C,y=[];z.length=0;for(let t=0,i=c.length;t<i;t++){const n=hl.calculateSignedArea(c[t])<0;!n&&t>0&&(C=q(p,C,y,d*j),z.length=0,y=[],p=C);let r=c[t];if(e!==1/0&&(r=hl.clipPolygon(r,N)),!r.length){t===i-1&&(C=q(p,C,y,d*j));continue}const o=r.length;Array.isArray(r[0])?r[0][0]===r[o-1][0]&&r[0][1]===r[o-1][1]||r.push([r[0][0],r[0][1]]):r[0].x===r[o-1].x&&r[0].y===r[o-1].y||r.push(r[0]),n&&y.push(z.length/3),et(z,z.length,r,j,h),t===i-1&&(C=q(p,C,y,d*j))}const g=S.length-f,b="__fea_idx".trim();for(let t=0;t<g/3;t++)F.push(void 0===l[b]?L:l[b]),A.push(L),m(u)&&T.push(u)}const W=x(F.length?F[F.length-1]:0),J={maxAltitude:R,vertices:new(k(Math.max(512,R)))(S),indices:_,pickingIds:new W(F),featureIndexes:A};if(T.length){const t=$?k(U):x(U);J.featureIds=new t(T)}else J.featureIds=[];return E&&(E.length=S.length/3*2,J.uvs=E),J}(t,i,{altitudeScale:d,altitudeProperty:f,defaultAltitude:p||0,heightProperty:y,minHeightProperty:g,defaultHeight:b||0},{top:S,side:_,topThickness:10*P||0,uv:A||j,uvSize:F?[.5*F[0],.5*F[1]]:[.5,.5],uvOrigin:n,topUVMode:T,sideUVMode:z,glScale:r,localScale:s,vScale:o},h),O=[],E=new(w(I.vertices.length/3))(I.indices);delete I.indices,O.push(E.buffer,I.vertices.buffer,I.pickingIds.buffer);const q=Ye(I.vertices,E);let R=!0;for(let t=0;t<q.length;t++)q[t]=-q[t],q[t]%1!=0&&(R=!1);if(I.normals=q,j){let t=function(t,e,i,n){const r=t.length/3,o=new Array(4*r),s=[],a=[];for(let t=0;t<r;t++)s[t]=[0,0,0],a[t]=[0,0,0];const l=[0,0,0],u=[0,0,0],c=[0,0,0],h=[0,0],d=[0,0],f=[0,0],p=[0,0,0],m=[0,0,0];function y(e,n,r){Ke(l,t,3*e),Ke(u,t,3*n),Ke(c,t,3*r),Qe(h,i,2*e),Qe(d,i,2*n),Qe(f,i,2*r);const o=u[0]-l[0],y=c[0]-l[0],g=u[1]-l[1],b=c[1]-l[1],v=u[2]-l[2],w=c[2]-l[2],x=d[0]-h[0],k=f[0]-h[0],M=d[1]-h[1],j=f[1]-h[1],A=1/(x*j-k*M);dt(p,(j*o-M*y)*A,(j*g-M*b)*A,(j*v-M*w)*A),dt(m,(x*y-k*o)*A,(x*b-k*g)*A,(x*w-k*v)*A),ft(s[e],s[e],p),ft(s[n],s[n],p),ft(s[r],s[r],p),ft(a[e],a[e],m),ft(a[n],a[n],m),ft(a[r],a[r],m)}for(let t=0,e=n.length;t<e;t+=3)y(n[t+0],n[t+1],n[t+2]);const g=[],b=[],v=[],w=[];let x,k,M;function j(t){Ke(v,e,3*t),ht(w,v),k=s[t],ht(g,k),bt(g,g,function(t,e,i){return t[0]=e[0]*i,t[1]=e[1]*i,t[2]=e[2]*i,t}(v,v,yt(v,k))),mt(g,g),gt(b,w,k),M=yt(b,a[t]),x=M<0?-1:1,o[4*t]=g[0],o[4*t+1]=g[1],o[4*t+2]=g[2],o[4*t+3]=x}for(let t=0,e=n.length;t<e;t+=3)j(n[t+0]),j(n[t+1]),j(n[t+2]);return o}(I.vertices,I.normals,I.uvs,E);t=function(t,e){const i=new Float32Array(e.length),n=[],r=[],o=[];for(let s=0;s<e.length;s+=4){const a=s/4*3;dt(r,t[a]||0,t[a+1]||0,t[a+2]||0),wt(n,e[s]||0,e[s+1]||0,e[s+2]||0,e[s+3]||0),Ze(o,r,n),vt(i.subarray(s,s+4),o)}return i}(I.normals,t),I.tangents=t,O.push(t.buffer),delete I.normals}if(I.normals&&(I.normals=R?new Int8Array(I.normals):new Float32Array(I.normals),O.push(I.normals.buffer)),I.uvs){const t=I.uvs;I.uvs=new Float32Array(t),O.push(I.uvs.buffer)}const C=function(t,e,i,n){const r={};if(M(e.polygonFill)){const o={},s=l(e.polygonFill),a=new Uint8Array(4*n.length);for(let e=0;e<n.length;e++){const r=t[n[e]],l=r.properties||{};l.$layer=r.layer,l.$type=r.type;let u=s(i,l);if(delete l.$layer,delete l.$type,Array.isArray(u)||(u=o[u]=o[u]||We(u).array()),Array.isArray(u)){for(let t=0;t<u.length;t++)yl[t]=255*u[t];3===u.length&&(yl[3]=255)}a[4*e]=yl[0],a[4*e+1]=yl[1],a[4*e+2]=yl[2],a[4*e+3]=yl[3]}r.aColor=a}if(M(e.polygonOpacity)){const o=a(e.polygonOpacity),s=new Uint8Array(n.length);for(let e=0;e<n.length;e++){const r=t[n[e]],a=r.properties||{};a.$layer=r.layer,a.$type=r.type;const l=o(i,a);delete a.$layer,delete a.$type,s[e]=255*l}r.aOpacity=s}return r}(t,u,c,I.featureIndexes),N={data:{data:{aPosition:I.vertices,aNormal:I.normals,aTexCoord0:I.uvs,aTangent:I.tangents,aPickingId:I.pickingIds},indices:E,properties:{maxAltitude:I.maxAltitude}},buffers:O};return I.featureIds.length?(N.data.featureIds=I.featureIds,O.push(N.data.featureIds.buffer)):N.data.featureIds=[],C.aColor&&(N.data.data.aColor=C.aColor,N.buffers.push(C.aColor.buffer)),C.aOpacity&&(N.data.data.aOpacity=C.aOpacity,N.buffers.push(C.aOpacity.buffer)),N}const yl=[];function gl(t,e,{altitudeScale:i,altitudeProperty:n,defaultAltitude:r,heightProperty:o,minHeightProperty:s,defaultHeight:a,bottom:l}){const u=l,c=e/t[0].extent,h=2*function(t,e){let i=0;for(let n=0,r=t.length;n<r;n++){const r=t[n];if(m(r.geometry[0][0])){const t=3*r.geometry.length;i+=e?2*t-6:t}else for(let t=0,n=r.geometry.length;t<n;t++){let n=3*r.geometry[t].length;3===r.type&&(n-=3),i+=e?2*n-6:n}}return i}(t)+3*t.length*2,d=[],f=new Int16Array(h),p=[];function y(t,i,n){const r=i-t,o=f.subarray(t,i),s=f.subarray(i,i+r);s.set(o);for(let t=2,e=s.length;t<e;t+=3)s[t]=o[t]-n;const a=t/3,l=r/3;let c,h;for(let t=a,i=l+a;t<i;t++)t<i-1?(c=t,h=t+1):(c=t,h=a),it(f,c,h,e)||(p.push(c,h),u&&p.push(c+l,h+l),bl(f,c,e)||p.push(c,c+l));return i+r}let g=0,b=0;const v="__fea_idx".trim();for(let e=0,l=t.length;e<l;e++){const l=t[e],u=l.geometry,{altitude:h,height:m}=hl.getFeaAltitudeAndHeight(l,i,n,r,o,a,s);b=Math.max(Math.abs(h),b);let w=g;for(let t=0,e=u.length;t<e;t++){let e=u[t];const i=e.length;e[0][0]===e[i-1][0]&&e[0][1]===e[i-1][1]&&(e=e.slice(0,i-1)),g=et(f,w,e,c,h),g=y(w,g,m*c),w=g}const x=p.length-d.length;for(let t=0;t<x;t++)d.push(l[v])}const M=new(w(p.reduce((t,e)=>Math.max(t,e),0)))(p),j=x(t.length);return{aPosition:new(k(Math.max(512,b)))(f),indices:M,aPickingId:new j(d)}}function bl(t,e,i){const n=t[3*e],r=t[3*e+1];return n<0||n>i||r<0||r>i}function vl(t,e,i){const n=gl(t,i,e),r=[n.aPosition.buffer,n.indices.buffer,n.aPickingId.buffer],o=n.indices;return delete n.indices,{data:{data:n,indices:o},buffers:r}}class wl{constructor(t,e,i,n,r){this.id=t,this.options=e,this.upload=i,this.Tt(e.style),this.requests={},this.zt=0,this.St=n,this.loadings=r}updateStyle(t,e){this.options.style=t,this.Tt(t),this.zt++,e()}updateOptions(t,e){this.options=f(this.options,t),e()}loadTile(t,e){const i=this.loadings,n=t.tileInfo.url,r=this.options.debugTile;if(r){const{x:i,y:n,z:o}=t.tileInfo;if(o!==r.z||i!==r.x||n!==r.y)return void e()}if(this.St.has(n)){const{features:r,layers:o}=this.St.get(n),s=i[n];if(delete i[n],!r||!r.length)return this._t(s),void e();if(s)for(let e=0;e<s.length;e++)this.Pt.call(s[e].ref,t,s[e].callback,n,o,r);this.Pt(t,e,n,o,r)}else i[n]?i[n].push({callback:e,ref:this}):(i[n]=[{callback:e,ref:this}],this.requests[n]=this.getTileFeatures(t.tileInfo,(e,r,o,s)=>{const a=i[n];if(delete i[n],this.checkIfCanceled(n))return delete this.requests[n],void this._t(a,null,{canceled:!0});if(delete this.requests[n],this.options.debug&&r)for(let e=0;e<r.length;e++)r[e]._debug_info={index:e,tileId:t.tileInfo.id};if(e)return e.loading||this.St.add(n,{features:[],layers:[]}),void this._t(a,e);if(!r||!r.length)return this.St.add(n,{features:[],layers:[]}),void this._t(a);if(this.St.add(n,{features:r,layers:o}),a)for(let e=0;e<a.length;e++)this.Pt.call(a[e].ref,t,a[e].callback,n,o,r,s)}))}Pt(t,e,i,n,r,o){this.It(n,r,t).then(t=>{t.canceled?e(null,{canceled:!0}):(t.data.style=this.zt,o&&f(t.data,o),e(null,t.data,t.buffers))}).catch(t=>{e(t)})}abortTile(t,e){delete this.requests[t],this.Ot(t),e()}Ot(t){const e=this.loadings[t];if(e)for(let t=0;t<e.length;t++)e[t].callback(null,{canceled:!0});delete this.loadings[t]}_t(t,e,i){if(t)for(let n=0;n<t.length;n++)t[n].callback(e,i)}checkIfCanceled(t){return!this.requests[t]}fetchIconGlyphs(t,e,i){this.upload("fetchIconGlyphs",{icons:t,glyphs:e},null,i)}It(t,e,i){if(!e.length)return Promise.resolve({data:null,buffers:[]});const{glScale:n,tileInfo:r}=i,o=!this.options.style.style.length&&!this.options.style.featureStyle.length;let s=this.pluginConfig.slice(0);o&&(s=this.Et(t)),this.featurePlugins&&v(s,this.featurePlugins);const a=e[0].extent,l=r.z,u={x:r.extent2d.xmin*n,y:r.extent2d.ymax*n},c=[],h=[],d=[],p=this.options,m=[],y={},g=[Promise.resolve(this.zt)];let b=0,x=-1;for(let t=0;t<s.length;t++){x++;const n=s[t];n.type!==b&&(x=0,b=n.type);const r=0===n.type?c:h;if(n.symbol&&!1===n.symbol.visible){r[x]=null;continue}const{tileFeatures:f,tileFeaIndexes:p}=this.qt(l,n.type,n.filter,e,y,t);if(!f.length){r[x]=null;continue}const v=w(p[p.length-1]);r[x]={styledFeatures:new v(p)},d.push({idx:t,typeIdx:x}),m.push(r[x].styledFeatures.buffer);let k=this.Rt(f,n,{extent:a,zoom:l,tilePoint:u,...i});o&&(k=k.then(t=>{if(!t)return null;if(t.data)t.data.layer=f[0].layer;else if(Array.isArray(t))for(let e=0;e<t.length;e++)t[e]&&t[e].data&&(t[e].data.layer=f[0].layer);return t})),g.push(k)}return Promise.all(g).then(([i,...n])=>{function r(t,e){if(void 0===t.data.ref&&(t.data.type=s[d[e].idx].renderPlugin.dataConfig.type,t.data.filter=s[d[e].idx].filter.def,t.buffers&&t.buffers.length))for(let e=0;e<t.buffers.length;e++)m.push(t.buffers[e])}if(i!==this.zt)return{canceled:!0};for(let t=0;t<n.length;t++){if(!n[t])continue;const e=n[t],i=0===s[d[t].idx].type?c:h;if(Array.isArray(e)){const n=[];for(let i=0;i<e.length;i++)e[i]&&(r(e[i],t),(void 0===e[i].data.ref||e[e[i].data.ref])&&n.push(e[i].data));n.length&&(i[d[t].typeIdx].data=n)}else r(e,t),i[d[t].typeIdx].data=e.data}const o={},l=t;if(p.features||p.schema){let t;for(let i=0,n=e.length;i<n;i++)if(t=e[i],l[t.layer].properties||(l[t.layer].properties=Ml(t.properties)),p.features&&t&&y[i])if("id"===p.features)o[i]=t.id;else{const e=f({},t);p.pickingGeometry||delete e.geometry,delete e.extent,delete e.properties.$layer,delete e.properties.$type,delete e.__index,o[i]=e}}return{data:{schema:l,data:c,featureData:h,extent:a,features:o},buffers:m}}).catch(t=>{console.error(t)})}Rt(t,e,i){let n=function(t,e){const i=e.customProperties;if(i)for(let t=0;t<i.length;t++)i[t].fn=us.compileFilter(i[t].filter);for(let e=0;e<t.length;e++)if(t[e]=f({},t[e]),i)for(let n=0;n<i.length;n++)if(i[n].fn(t[e])){t[e].geojson&&(t[e].properties=f({},t[e].properties)),f(t[e].properties,i[n].properties);break}return t}(t,e);const r=e.renderPlugin.dataConfig,o=e.symbol,s=this.options.tileSize[0],{extent:a,glScale:l,zScale:u,zoom:c,tilePoint:h,pointAtTileRes:d}=i,p=a/s,m=r.type,y=this.options.debugTile&&this.options.debugTile.index;if("3d-extrusion"===m){const t=jl(o);return t&&(r.uv=1,2===t&&(r.tangent=1)),Promise.all([Promise.resolve(ml(n,r,a,h,l,u,this.options.tileSize[1]/a,o,c,y))])}if("3d-wireframe"===m)return Promise.all([Promise.resolve(vl(n,r,a))]);if("point"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y,altitudeToTileScale:u*a/this.options.tileSize[1]/l}),e=Fa.splitPointSymbol(o);return Fa.needMerge(e[0])&&(n=Fa.mergeLineFeatures(n,e[0],c)),Promise.all(e.map(e=>new Fa(n,e,t).load(p)))}if("native-point"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Al(n,o,t,Ja,a/s)}if("line"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),tileRatio:p,zoom:c,debugIndex:y});return Al(n,o,t,Oa)}if("native-line"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Al(n,o,t,$a)}if("fill"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y});return Al(n,o,t,Za)}if("line-extrusion"===m){delete o.lineGradientProperty,o.lineJoin="miter",o.lineCap="butt";const t=jl(o);t&&(r.uv=1,2===t&&(r.tangent=1));const e=f({},r,{EXTENT:a,tileSize:s,zScale:u,glScale:l,zoom:c,debugIndex:y});if(t){const t=[];if(!1!==r.top){const i=f({},e);i.side=!1,t.push(new Da(n,o,i))}return!1!==r.side&&(e.side=!0,e.top=!1,t.push(new Da(n,o,e))),Promise.all(t.map(t=>t.load()))}return Promise.all([new Da(n,o,e).load()])}if("circle"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Al(n,o,t,Ka)}if("round-tube"===m||"square-tube"===m){const t="round-tube"===m?Qa:ol,e=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y,radialSegments:"round-tube"===m?r.radialSegments||8:4,pointAtTileRes:d,tileRatio:p,isTube:!0});return Al(n,o,e,t)}return Promise.resolve([])}qt(t,e,i,n,r){const o="__fea_idx".trim(),s=[],a=[],l=n.length;for(let u=0;u<l;u++)if((1===e||void 0===n[u].id||!this.styledFeatures[n[u].id])&&((!i.def||"default"===i.def)&&!r[u]||!0===i.def||i.def&&(void 0!==i.def.condition||Array.isArray(i.def))&&i(n[u],t))){r[u]=1;const t=f({},n[u]);if(t[o]=u,a.push(t),s.push(u),1===e)break}return{tileFeatures:a,tileFeaIndexes:s}}Tt(t){const{style:e,featureStyle:i}=t,n={};i.forEach(t=>{Array.isArray(t.id)?(t.id.forEach(t=>{n[t]=1}),t.filter=["in","$id",...t.id]):(n[t.id]=1,t.filter=["==","$id",t.id])});const r=us.compileStyle(e);for(let t=0;t<e.length;t++)r[t].filter&&(r[t].filter.def=e[t].filter?e[t].filter.value||e[t].filter:void 0),r[t].type=0;const o=[],s=us.compileStyle(i);for(let t=0;t<i.length;t++)s[t].type=1,s[t].filter.def=i[t].filter?i[t].filter.value||i[t].filter:void 0,s[t].renderPlugin&&o.push(s[t]);this.pluginConfig=r,this.featurePlugins=o,this.styledFeatures=n}Et(t){let e=this.Ct;this.Ct||(e=this.Ct={});const i=["","Point","LineString","Polygon","MultiPoint","MultiLineString","MultiPolygon"],n=[];for(const r in t){const o=r;if(!e[r]){const n=[];for(let e=0;e<t[r].types.length;e++){const s=t[r].types[e],a=["all",["==","$layer",o],["==","$type",i[s]]],l={filter:Lt(a),renderPlugin:xl(s),symbol:kl(s)};l.filter.def=a,l.type=0,n.push(l)}e[o]=n}n.push(...e[o])}return n}}function xl(t){switch(t){case 1:return{type:"native-point",dataConfig:{type:"native-point",only2D:!0}};case 2:return{type:"native-line",dataConfig:{type:"native-line",only2D:!0}};case 3:return{type:"fill",dataConfig:{type:"fill",only2D:!0}}}return null}function kl(t){switch(t){case 1:return{markerFill:"#f00",markerSize:10};case 2:return{lineColor:"#fff"};case 3:return{polygonFill:"#00f",polygonOpacity:.4}}return null}function Ml(t){if(Array.isArray(t)||!g(t))return{};const e={};for(const i in t){const n=t[i];p(n)?e[i]="string":m(n)?e[i]="number":!0===n||!1===n?e[i]="boolean":Array.isArray(n)?e[i]="array":e[i]="object"}return e}function jl(t){if(!t)return 0;let e=0;for(const i in t){if(("normalTexture"===i||"bumpTexture"===i)&&t[i])return 2;if(i.indexOf("Texture")>0&&t[i])e=1;else if(g(t[i])){const n=jl(t[i]);if(2===n)return n;1===n&&(e=1)}}return e}function Al(t,e,i,n,r){const o={},s=Array.isArray(e)?e:[e];let a=-1;for(let t=0;t<s.length;t++)o[t]=Fl(s[t]),!o[t]&&s[t]&&-1===a&&(a=t);const l=[];for(let e=0;e<s.length;e++)s[e]&&(s[e].index={index:e},o[e]||e===a?l.push(new n(t,s[e],i).load(r)):l.push({data:{ref:a,symbolIndex:{index:e}}}));return Promise.all(l)}function Fl(t){if(!t)return 0;for(const e in t)if(M(t[e]))return 1;return 0}function Tl(t,e){zl(t.geometry,e)}function zl(t,e){if(t)switch(t.type){case"Point":Sl(t.coordinates,e);break;case"MultiPoint":case"LineString":_l(t.coordinates,e);break;case"MultiLineString":case"Polygon":Pl(t.coordinates,e);break;case"MultiPolygon":!function(t,e){for(let i=0;i<t.length;i++)Pl(t[i],e)}(t.coordinates,e);break;case"GeometryCollection":for(let i=0;i<t.geometries.length;i++)zl(t.geometries[i],e)}}function Sl(t,e){e[0]=Math.min(e[0],t[0]),e[1]=Math.min(e[1],t[1]),e[2]=Math.max(e[2],t[0]),e[3]=Math.max(e[3],t[1])}function _l(t,e){for(let i=0;i<t.length;i++)Sl(t[i],e)}function Pl(t,e){for(let i=0;i<t.length;i++)_l(t[i],e)}class Il extends wl{constructor(t,e,i,n,r,o){super(t,e,i,n,r),(e=e||{}).extent||(e.extent=8192),this.zoomOffset=0,e.tileSize&&(this.zoomOffset=-function(t){if(Math.log2)return Math.log2(t);const e=Math.log(t)*Math.LOG2E,i=Math.round(e);return Math.abs(i-e)<1e-14?i:e}(e.tileSize[0]/256)),this.setData(e.data,o)}setData(t,e){if(delete this.index,!t)return void e();const i={maxZoom:24,tolerance:this.options.simplifyTolerance,extent:this.options.extent,buffer:this.options.tileBuffer||64,hasAltitude:!!this.options.hasAltitude,debug:0,lineMetrics:!0,indexMaxZoom:5,indexMaxPoints:1e5,disableFilter:!0};if(p(t)&&"{"!=t.substring(0,1)||t.url)A.getJSON(t.url?t.url:t,t.url?t:{},(t,n)=>{if(t&&e(t),!n)return void e(null,{extent:null,idMap:{}});const r=n,{first1000:o,idMap:s}=this.Nt(r);this.Lt(o,s,r,i,e)});else{"string"==typeof t&&(t=JSON.parse(t));const n=Array.isArray(t)?t:t.features;let r=n;n&&n.length>1e3&&(r=n.slice(0,1e3)),this.Lt(r,null,t,i,e)}}Lt(t,e,i,n,r){try{const o=t&&t.length?function(t){let e=[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY];switch(t.type){case"FeatureCollection":for(let i=0;i<t.features.length;i++)Tl(t.features[i],e);break;case"Feature":Tl(t,e);break;default:zl(t,e)}return e}({type:"FeatureCollection",features:t}):null;this.index=function(t,e){return new Q(t,e)}(i,this.options.geojsonvt||n),r(null,{extent:o,idMap:e})}catch(t){console.warn(t),r({error:t.message})}}Nt(t){const e=[],i={};let n=0;function r(t){t&&("Feature"!==t.type||t.geometry)&&(void 0!==t.id&&null!==t.id||(t.id=n++),i[t.id]=f({},t),t.geometry?(i[t.id].geometry=f({},t.geometry),i[t.id].geometry.coordinates=null):t.coordinates&&(i[t.id].coordinates=null),e.length<1e3&&e.push(t))}return Array.isArray(t)?t.forEach(t=>{r(t)}):t.features&&t.features.forEach(t=>{r(t)}),{first1000:e,idMap:i}}getTileFeatures(t,e){const i=[];if(!this.index)return setTimeout((function(){e({loading:!0})}),1),1;const n=this.index.getTile(t.z+this.zoomOffset,t.x,t.y);if(!n||0===n.features.length)return setTimeout((function(){e(null,i,[])}),1),1;const r=[];for(let t=0,e=n.features.length;t<e;t++){const e=n.features[t];let o=e.layer;void 0===o&&(o="0"),r[o]={types:{}};r[o].types[e.type]=1,e.tags=e.tags||{},i.push({type:e.type,layer:o,id:e.id,geometry:e.geometry,properties:e.tags,extent:this.options.extent,geojson:!0})}for(const t in r)r[t].types=Object.keys(r[t].types).map(t=>+t);return setTimeout((function(){e(null,i,r)}),1),1}onRemove(){delete this.index}}var Ol={\n/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nread:function(t,e,i,n,r){var o,s,a=8*r-n-1,l=(1<<a)-1,u=l>>1,c=-7,h=i?r-1:0,d=i?-1:1,f=t[e+h];for(h+=d,o=f&(1<<-c)-1,f>>=-c,c+=a;c>0;o=256*o+t[e+h],h+=d,c-=8);for(s=o&(1<<-c)-1,o>>=-c,c+=n;c>0;s=256*s+t[e+h],h+=d,c-=8);if(0===o)o=1-u;else{if(o===l)return s?NaN:1/0*(f?-1:1);s+=Math.pow(2,n),o-=u}return(f?-1:1)*s*Math.pow(2,o-n)},write:function(t,e,i,n,r,o){var s,a,l,u=8*o-r-1,c=(1<<u)-1,h=c>>1,d=23===r?Math.pow(2,-24)-Math.pow(2,-77):0,f=n?0:o-1,p=n?1:-1,m=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(a=isNaN(e)?1:0,s=c):(s=Math.floor(Math.log(e)/Math.LN2),e*(l=Math.pow(2,-s))<1&&(s--,l*=2),(e+=s+h>=1?d/l:d*Math.pow(2,1-h))*l>=2&&(s++,l/=2),s+h>=c?(a=0,s=c):s+h>=1?(a=(e*l-1)*Math.pow(2,r),s+=h):(a=e*Math.pow(2,h-1)*Math.pow(2,r),s=0));r>=8;t[i+f]=255&a,f+=p,a/=256,r-=8);for(s=s<<r|a,u+=r;u>0;t[i+f]=255&s,f+=p,s/=256,u-=8);t[i+f-p]|=128*m}},El=Rl,ql=Ol;function Rl(t){this.buf=ArrayBuffer.isView&&ArrayBuffer.isView(t)?t:new Uint8Array(t||0),this.pos=0,this.type=0,this.length=this.buf.length}Rl.Varint=0,Rl.Fixed64=1,Rl.Bytes=2,Rl.Fixed32=5;var Cl="undefined"==typeof TextDecoder?null:new TextDecoder("utf8");function Nl(t){return t.type===Rl.Bytes?t.readVarint()+t.pos:t.pos+1}function Ll(t,e,i){return i?4294967296*e+(t>>>0):4294967296*(e>>>0)+(t>>>0)}function Dl(t,e,i){var n=e<=16383?1:e<=2097151?2:e<=268435455?3:Math.floor(Math.log(e)/(7*Math.LN2));i.realloc(n);for(var r=i.pos-1;r>=t;r--)i.buf[r+n]=i.buf[r]}function Ul(t,e){for(var i=0;i<t.length;i++)e.writeVarint(t[i])}function $l(t,e){for(var i=0;i<t.length;i++)e.writeSVarint(t[i])}function Wl(t,e){for(var i=0;i<t.length;i++)e.writeFloat(t[i])}function Jl(t,e){for(var i=0;i<t.length;i++)e.writeDouble(t[i])}function Hl(t,e){for(var i=0;i<t.length;i++)e.writeBoolean(t[i])}function Gl(t,e){for(var i=0;i<t.length;i++)e.writeFixed32(t[i])}function Vl(t,e){for(var i=0;i<t.length;i++)e.writeSFixed32(t[i])}function Bl(t,e){for(var i=0;i<t.length;i++)e.writeFixed64(t[i])}function Xl(t,e){for(var i=0;i<t.length;i++)e.writeSFixed64(t[i])}function Zl(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+16777216*t[e+3]}function Yl(t,e,i){t[i]=e,t[i+1]=e>>>8,t[i+2]=e>>>16,t[i+3]=e>>>24}function Kl(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+(t[e+3]<<24)}Rl.prototype={destroy:function(){this.buf=null},readFields:function(t,e,i){for(i=i||this.length;this.pos<i;){var n=this.readVarint(),r=n>>3,o=this.pos;this.type=7&n,t(r,e,this),this.pos===o&&this.skip(n)}return e},readMessage:function(t,e){return this.readFields(t,e,this.readVarint()+this.pos)},readFixed32:function(){var t=Zl(this.buf,this.pos);return this.pos+=4,t},readSFixed32:function(){var t=Kl(this.buf,this.pos);return this.pos+=4,t},readFixed64:function(){var t=Zl(this.buf,this.pos)+4294967296*Zl(this.buf,this.pos+4);return this.pos+=8,t},readSFixed64:function(){var t=Zl(this.buf,this.pos)+4294967296*Kl(this.buf,this.pos+4);return this.pos+=8,t},readFloat:function(){var t=ql.read(this.buf,this.pos,!0,23,4);return this.pos+=4,t},readDouble:function(){var t=ql.read(this.buf,this.pos,!0,52,8);return this.pos+=8,t},readVarint:function(t){var e,i,n=this.buf;return e=127&(i=n[this.pos++]),i<128?e:(e|=(127&(i=n[this.pos++]))<<7,i<128?e:(e|=(127&(i=n[this.pos++]))<<14,i<128?e:(e|=(127&(i=n[this.pos++]))<<21,i<128?e:function(t,e,i){var n,r,o=i.buf;if(r=o[i.pos++],n=(112&r)>>4,r<128)return Ll(t,n,e);if(r=o[i.pos++],n|=(127&r)<<3,r<128)return Ll(t,n,e);if(r=o[i.pos++],n|=(127&r)<<10,r<128)return Ll(t,n,e);if(r=o[i.pos++],n|=(127&r)<<17,r<128)return Ll(t,n,e);if(r=o[i.pos++],n|=(127&r)<<24,r<128)return Ll(t,n,e);if(r=o[i.pos++],n|=(1&r)<<31,r<128)return Ll(t,n,e);throw new Error("Expected varint not more than 10 bytes")}(e|=(15&(i=n[this.pos]))<<28,t,this))))},readVarint64:function(){return this.readVarint(!0)},readSVarint:function(){var t=this.readVarint();return t%2==1?(t+1)/-2:t/2},readBoolean:function(){return Boolean(this.readVarint())},readString:function(){var t=this.readVarint()+this.pos,e=this.pos;return this.pos=t,t-e>=12&&Cl?function(t,e,i){return Cl.decode(t.subarray(e,i))}(this.buf,e,t):function(t,e,i){var n="",r=e;for(;r<i;){var o,s,a,l=t[r],u=null,c=l>239?4:l>223?3:l>191?2:1;if(r+c>i)break;1===c?l<128&&(u=l):2===c?128==(192&(o=t[r+1]))&&(u=(31&l)<<6|63&o)<=127&&(u=null):3===c?(o=t[r+1],s=t[r+2],128==(192&o)&&128==(192&s)&&((u=(15&l)<<12|(63&o)<<6|63&s)<=2047||u>=55296&&u<=57343)&&(u=null)):4===c&&(o=t[r+1],s=t[r+2],a=t[r+3],128==(192&o)&&128==(192&s)&&128==(192&a)&&((u=(15&l)<<18|(63&o)<<12|(63&s)<<6|63&a)<=65535||u>=1114112)&&(u=null)),null===u?(u=65533,c=1):u>65535&&(u-=65536,n+=String.fromCharCode(u>>>10&1023|55296),u=56320|1023&u),n+=String.fromCharCode(u),r+=c}return n}(this.buf,e,t)},readBytes:function(){var t=this.readVarint()+this.pos,e=this.buf.subarray(this.pos,t);return this.pos=t,e},readPackedVarint:function(t,e){if(this.type!==Rl.Bytes)return t.push(this.readVarint(e));var i=Nl(this);for(t=t||[];this.pos<i;)t.push(this.readVarint(e));return t},readPackedSVarint:function(t){if(this.type!==Rl.Bytes)return t.push(this.readSVarint());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readSVarint());return t},readPackedBoolean:function(t){if(this.type!==Rl.Bytes)return t.push(this.readBoolean());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readBoolean());return t},readPackedFloat:function(t){if(this.type!==Rl.Bytes)return t.push(this.readFloat());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readFloat());return t},readPackedDouble:function(t){if(this.type!==Rl.Bytes)return t.push(this.readDouble());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readDouble());return t},readPackedFixed32:function(t){if(this.type!==Rl.Bytes)return t.push(this.readFixed32());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readFixed32());return t},readPackedSFixed32:function(t){if(this.type!==Rl.Bytes)return t.push(this.readSFixed32());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed32());return t},readPackedFixed64:function(t){if(this.type!==Rl.Bytes)return t.push(this.readFixed64());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readFixed64());return t},readPackedSFixed64:function(t){if(this.type!==Rl.Bytes)return t.push(this.readSFixed64());var e=Nl(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed64());return t},skip:function(t){var e=7&t;if(e===Rl.Varint)for(;this.buf[this.pos++]>127;);else if(e===Rl.Bytes)this.pos=this.readVarint()+this.pos;else if(e===Rl.Fixed32)this.pos+=4;else{if(e!==Rl.Fixed64)throw new Error("Unimplemented type: "+e);this.pos+=8}},writeTag:function(t,e){this.writeVarint(t<<3|e)},realloc:function(t){for(var e=this.length||16;e<this.pos+t;)e*=2;if(e!==this.length){var i=new Uint8Array(e);i.set(this.buf),this.buf=i,this.length=e}},finish:function(){return this.length=this.pos,this.pos=0,this.buf.subarray(0,this.length)},writeFixed32:function(t){this.realloc(4),Yl(this.buf,t,this.pos),this.pos+=4},writeSFixed32:function(t){this.realloc(4),Yl(this.buf,t,this.pos),this.pos+=4},writeFixed64:function(t){this.realloc(8),Yl(this.buf,-1&t,this.pos),Yl(this.buf,Math.floor(t*(1/4294967296)),this.pos+4),this.pos+=8},writeSFixed64:function(t){this.realloc(8),Yl(this.buf,-1&t,this.pos),Yl(this.buf,Math.floor(t*(1/4294967296)),this.pos+4),this.pos+=8},writeVarint:function(t){(t=+t||0)>268435455||t<0?function(t,e){var i,n;t>=0?(i=t%4294967296|0,n=t/4294967296|0):(n=~(-t/4294967296),4294967295^(i=~(-t%4294967296))?i=i+1|0:(i=0,n=n+1|0));if(t>=0x10000000000000000||t<-0x10000000000000000)throw new Error("Given varint doesn\'t fit into 10 bytes");e.realloc(10),function(t,e,i){i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos]=127&t}(i,0,e),function(t,e){var i=(7&t)<<4;if(e.buf[e.pos++]|=i|((t>>>=3)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;e.buf[e.pos++]=127&t}(n,e)}(t,this):(this.realloc(4),this.buf[this.pos++]=127&t|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=t>>>7&127))))},writeSVarint:function(t){this.writeVarint(t<0?2*-t-1:2*t)},writeBoolean:function(t){this.writeVarint(Boolean(t))},writeString:function(t){t=String(t),this.realloc(4*t.length),this.pos++;var e=this.pos;this.pos=function(t,e,i){for(var n,r,o=0;o<e.length;o++){if((n=e.charCodeAt(o))>55295&&n<57344){if(!r){n>56319||o+1===e.length?(t[i++]=239,t[i++]=191,t[i++]=189):r=n;continue}if(n<56320){t[i++]=239,t[i++]=191,t[i++]=189,r=n;continue}n=r-55296<<10|n-56320|65536,r=null}else r&&(t[i++]=239,t[i++]=191,t[i++]=189,r=null);n<128?t[i++]=n:(n<2048?t[i++]=n>>6|192:(n<65536?t[i++]=n>>12|224:(t[i++]=n>>18|240,t[i++]=n>>12&63|128),t[i++]=n>>6&63|128),t[i++]=63&n|128)}return i}(this.buf,t,this.pos);var i=this.pos-e;i>=128&&Dl(e,i,this),this.pos=e-1,this.writeVarint(i),this.pos+=i},writeFloat:function(t){this.realloc(4),ql.write(this.buf,t,this.pos,!0,23,4),this.pos+=4},writeDouble:function(t){this.realloc(8),ql.write(this.buf,t,this.pos,!0,52,8),this.pos+=8},writeBytes:function(t){var e=t.length;this.writeVarint(e),this.realloc(e);for(var i=0;i<e;i++)this.buf[this.pos++]=t[i]},writeRawMessage:function(t,e){this.pos++;var i=this.pos;t(e,this);var n=this.pos-i;n>=128&&Dl(i,n,this),this.pos=i-1,this.writeVarint(n),this.pos+=n},writeMessage:function(t,e,i){this.writeTag(t,Rl.Bytes),this.writeRawMessage(e,i)},writePackedVarint:function(t,e){e.length&&this.writeMessage(t,Ul,e)},writePackedSVarint:function(t,e){e.length&&this.writeMessage(t,$l,e)},writePackedBoolean:function(t,e){e.length&&this.writeMessage(t,Hl,e)},writePackedFloat:function(t,e){e.length&&this.writeMessage(t,Wl,e)},writePackedDouble:function(t,e){e.length&&this.writeMessage(t,Jl,e)},writePackedFixed32:function(t,e){e.length&&this.writeMessage(t,Gl,e)},writePackedSFixed32:function(t,e){e.length&&this.writeMessage(t,Vl,e)},writePackedFixed64:function(t,e){e.length&&this.writeMessage(t,Bl,e)},writePackedSFixed64:function(t,e){e.length&&this.writeMessage(t,Xl,e)},writeBytesField:function(t,e){this.writeTag(t,Rl.Bytes),this.writeBytes(e)},writeFixed32Field:function(t,e){this.writeTag(t,Rl.Fixed32),this.writeFixed32(e)},writeSFixed32Field:function(t,e){this.writeTag(t,Rl.Fixed32),this.writeSFixed32(e)},writeFixed64Field:function(t,e){this.writeTag(t,Rl.Fixed64),this.writeFixed64(e)},writeSFixed64Field:function(t,e){this.writeTag(t,Rl.Fixed64),this.writeSFixed64(e)},writeVarintField:function(t,e){this.writeTag(t,Rl.Varint),this.writeVarint(e)},writeSVarintField:function(t,e){this.writeTag(t,Rl.Varint),this.writeSVarint(e)},writeStringField:function(t,e){this.writeTag(t,Rl.Bytes),this.writeString(e)},writeFloatField:function(t,e){this.writeTag(t,Rl.Fixed32),this.writeFloat(e)},writeDoubleField:function(t,e){this.writeTag(t,Rl.Fixed64),this.writeDouble(e)},writeBooleanField:function(t,e){this.writeVarintField(t,Boolean(e))}};var Ql=Ot,tu=eu;function eu(t,e,i,n,r){this.properties={},this.extent=i,this.type=0,this.Dt=t,this.Ut=-1,this.$t=n,this.Wt=r,t.readFields(iu,this,e)}function iu(t,e,i){1==t?e.id=i.readVarint():2==t?function(t,e){var i=t.readVarint()+t.pos;for(;t.pos<i;){var n=e.$t[t.readVarint()],r=e.Wt[t.readVarint()];e.properties[n]=r}}(i,e):3==t?e.type=i.readVarint():4==t&&(e.Ut=i.pos)}function nu(t){for(var e,i,n=0,r=0,o=t.length,s=o-1;r<o;s=r++)e=t[r],n+=((i=t[s]).x-e.x)*(e.y+i.y);return n}eu.types=["Unknown","Point","LineString","Polygon"],eu.prototype.loadGeometry=function(){var t=this.Dt;t.pos=this.Ut;for(var e,i=t.readVarint()+t.pos,n=1,r=0,o=0,s=0,a=[];t.pos<i;){if(r<=0){var l=t.readVarint();n=7&l,r=l>>3}if(r--,1===n||2===n)o+=t.readSVarint(),s+=t.readSVarint(),1===n&&(e&&a.push(e),e=[]),e.push(new Ql(o,s));else{if(7!==n)throw new Error("unknown command "+n);e&&e.push(e[0].clone())}}return e&&a.push(e),a},eu.prototype.bbox=function(){var t=this.Dt;t.pos=this.Ut;for(var e=t.readVarint()+t.pos,i=1,n=0,r=0,o=0,s=1/0,a=-1/0,l=1/0,u=-1/0;t.pos<e;){if(n<=0){var c=t.readVarint();i=7&c,n=c>>3}if(n--,1===i||2===i)(r+=t.readSVarint())<s&&(s=r),r>a&&(a=r),(o+=t.readSVarint())<l&&(l=o),o>u&&(u=o);else if(7!==i)throw new Error("unknown command "+i)}return[s,l,a,u]},eu.prototype.toGeoJSON=function(t,e,i){var n,r,o=this.extent*Math.pow(2,i),s=this.extent*t,a=this.extent*e,l=this.loadGeometry(),u=eu.types[this.type];function c(t){for(var e=0;e<t.length;e++){var i=t[e],n=180-360*(i.y+a)/o;t[e]=[360*(i.x+s)/o-180,360/Math.PI*Math.atan(Math.exp(n*Math.PI/180))-90]}}switch(this.type){case 1:var h=[];for(n=0;n<l.length;n++)h[n]=l[n][0];c(l=h);break;case 2:for(n=0;n<l.length;n++)c(l[n]);break;case 3:for(l=function(t){var e=t.length;if(e<=1)return[t];for(var i,n,r=[],o=0;o<e;o++){var s=nu(t[o]);0!==s&&(void 0===n&&(n=s<0),n===s<0?(i&&r.push(i),i=[t[o]]):i.push(t[o]))}i&&r.push(i);return r}(l),n=0;n<l.length;n++)for(r=0;r<l[n].length;r++)c(l[n][r])}1===l.length?l=l[0]:u="Multi"+u;var d={type:"Feature",geometry:{type:u,coordinates:l},properties:this.properties};return"id"in this&&(d.id=this.id),d};var ru=tu,ou=su;function su(t,e){this.version=1,this.name=null,this.extent=4096,this.length=0,this.Dt=t,this.$t=[],this.Wt=[],this.Jt=[],t.readFields(au,this,e),this.length=this.Jt.length}function au(t,e,i){15===t?e.version=i.readVarint():1===t?e.name=i.readString():5===t?e.extent=i.readVarint():2===t?e.Jt.push(i.pos):3===t?e.$t.push(i.readString()):4===t&&e.Wt.push(function(t){var e=null,i=t.readVarint()+t.pos;for(;t.pos<i;){var n=t.readVarint()>>3;e=1===n?t.readString():2===n?t.readFloat():3===n?t.readDouble():4===n?t.readVarint64():5===n?t.readVarint():6===n?t.readSVarint():7===n?t.readBoolean():null}return e}(i))}su.prototype.feature=function(t){if(t<0||t>=this.Jt.length)throw new Error("feature index out of bounds");this.Dt.pos=this.Jt[t];var e=this.Dt.readVarint()+this.Dt.pos;return new ru(this.Dt,e,this.extent,this.$t,this.Wt)};var lu=ou;function uu(t,e,i){if(3===t){var n=new lu(i,i.readVarint()+i.pos);n.length&&(e[n.name]=n)}}var cu=function(t,e){this.layers=t.readFields(uu,{},e)};class hu extends wl{constructor(t,e,i,n,r,o){super(t,e,i,n,r),e=e||{},o()}getTileFeatures(t,e){const i=t.url;return A.getArrayBuffer(i,(t,i)=>{if(t)return void e(t);let n;try{n=new cu(new El(i.data))}catch(t){return void e(t.message,[],[])}const r=[];if(!n.layers)return void e(null,r,[]);const o={};let s;for(const e in n.layers)if(a=n.layers,l=e,Object.prototype.hasOwnProperty.call(a,l)){o[e]={types:{}};const i=o[e].types;for(let o=0,a=n.layers[e].length;o<a;o++)try{s=n.layers[e].feature(o),i[s.type]=1,r.push({type:s.type,layer:e,geometry:s.loadGeometry(),properties:s.properties,extent:s.extent})}catch(t){console.warn("error when load vt geometry:",t)}}var a,l;for(const t in o)o[t].types=Object.keys(o[t].types).map(t=>+t);e(null,r,o,{byteLength:i.data.byteLength})})}abortTile(t,e){const i=this.requests[t];delete this.requests[t],i&&i.abort&&i.abort(),this.Ot(t),e()}onRemove(){for(const t in this.requests)this.requests[t].abort();this.requests={}}}let du=0;const fu=new class{constructor(t){this.max=t,this.reset()}reset(){return this.data={},this.order=[],this}clear(){this.reset()}add(t,e){return this.has(t)?(this.order.splice(this.order.indexOf(t),1),this.data[t]=e,this.order.push(t)):(this.data[t]=e,this.order.push(t),this.order.length>this.max&&this.getAndRemove(this.order[0])),this}has(t){return t in this.data}keys(){return this.order}getAndRemove(t){if(!this.has(t))return null;const e=this.data[t];return delete this.data[t],this.order.splice(this.order.indexOf(t),1),e}get(t){return this.has(t)?this.data[t]:null}remove(t){return this.has(t)?(delete this.data[t],this.order.splice(this.order.indexOf(t),1),this):this}setMaxSize(t){for(this.max=t;this.order.length>this.max;)this.getAndRemove(this.order[0]);return this}}(128),pu={};class mu{constructor(t){this.Ht={},this.Gt={},this.workerId=t}addLayer({actorId:t,mapId:e,layerId:i,params:n},r){if(this.Vt(e,i))return;const o=this.Bt(e,i),s=n.type,a=n.options,l=this.send.bind(this,t);this.Ht[o]="GeoJSONVectorTileLayer"===s?new Il(i,a,l,fu,pu,r):new hu(i,a,l,fu,pu,r)}removeLayer({mapId:t,layerId:e},i){const n=this.Vt(t,e),r=this.Bt(t,e);delete this.Ht[r],n&&(n.onRemove(i),this.Xt())}loadTile({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&r.loadTile(i,n)}abortTile({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&r.abortTile&&r.abortTile(i.url,n)}removeTile({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&r.removeTile(i,n)}updateStyle({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&(r.updateStyle(i,n),this.Xt())}updateOptions({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&(r.updateOptions(i,n),this.Xt())}setData({mapId:t,layerId:e,params:i},n){const r=this.Vt(t,e);r&&(r.setData(i.data,n),this.Xt())}receive(t){const e=t.callback,i=this.Gt[e];delete this.Gt[e],i&&t.error?i(new Error(t.error)):i&&i(null,t.data)}send(t,e,i,n,r){const o=r?`${t}-${du++}`:null;r&&(this.Gt[o]=r),postMessage({type:"<request>",workerId:this.workerId,actorId:t,command:e,params:i,callback:String(o)},n||[])}Bt(t,e){return`${t}-${e}`}Vt(t,e){const i=this.Bt(t,e);return this.Ht[i]}Xt(){const t=Object.keys(pu);for(let e=0;e<t.length;e++)delete pu[t[e]];fu.reset()}}t.initialize=function(){},t.onmessage=function(t,e){const i=t.data;if(this.dispatcher||(this.dispatcher=new mu(t.workerId)),"<response>"===t.type)this.dispatcher.workerId===t.workerId&&this.dispatcher.receive(t);else{const n=i.command;this.dispatcher[n]({actorId:t.actorId,mapId:i.mapId,layerId:i.layerId,params:i.params},(t,i,r)=>{t&&404!==t.status&&console.error(n,t),e(t,i,r)})}},Object.defineProperty(t,"Zt",{value:!0})}';
28
+ const N = 'function(t){function e(t,e){for(let i=0;i<t.stops.length;i++)if(e===t.stops[i][0])return t.stops[i][1];return t.default}function i(t,e){for(var i=0;i<t.stops.length&&!(e<t.stops[i][0]);i++);return t.stops[Math.max(i-1,0)][1]}function n(t,e){for(var i=void 0!==t.base?t.base:1,n=0;!(n>=t.stops.length||e<=t.stops[n][0]);)n++;return 0===n?t.stops[n][1]:n===t.stops.length?t.stops[n-1][1]:function t(e,i,n,r,s,a){return"function"==typeof s?function(){var o=s.apply(void 0,arguments),l=a.apply(void 0,arguments);return t(e,i,n,r,o,l)}:s.length?function(t,e,i,n,r,s){var a=[];for(let l=0;l<r.length;l++)a[l]=o(t,e,i,n,r[l],s[l]);return a}(e,i,n,r,s,a):o(e,i,n,r,s,a)}(e,i,t.stops[n-1][0],t.stops[n][0],t.stops[n-1][1],t.stops[n][1])}function r(t,e){return function(t,e,i){return void 0!==t?t:void 0!==e?e:void 0!==i?i:null}(e,t.default)}function o(t,e,i,n,r,o){var s,a=n-i,l=t-i;return r*(1-(s=1===e?l/a:(Math.pow(e,l)-1)/(Math.pow(e,a)-1)))+o*s}function s(t){return t&&"object"==typeof t&&(t.stops||t.property&&"identity"===t.type)}function a(t){return c(t,"exponential")}function l(t){return c(t,"interval")}function u(t,e){if(!t)return null;var i=!1;if(Array.isArray(t)){var n,r=[];for(let o=0;o<t.length;o++)(n=u(t[o],e))?(r.push(n),i=!0):r.push(t[o]);return i?r:t}var o,l={__fn_types_loaded:!0},c=[];for(o in t)t.hasOwnProperty(o)&&c.push(o);const h=function(t){Object.defineProperty(l,t,{get:function(){return this["__fn_"+t]||(this["__fn_"+t]=a(this["_"+t])),this["__fn_"+t].apply(this,e())},set:function(e){this["_"+t]=e},configurable:!0,enumerable:!0})};for(let e=0,n=c.length;e<n;e++)s(t[o=c[e]])?(i=!0,l["_"+o]=t[o],h(o)):l[o]=t[o];return i?l:t}function c(t,o){if(!s(t))return function(){return t};let a=!0,l=!0;const u=(t=JSON.parse(JSON.stringify(t))).stops;if(u)for(let t=0;t<u.length;t++)if(s(u[t][1])){const e=c(u[t][1],o);a=a&&e.isZoomConstant,l=l&&e.isFeatureConstant,u[t]=[u[t][0],e]}const h=function t(o,a){var l,u,c;if(s(o)){var h,d=o.stops&&"object"==typeof o.stops[0][0],f=d||void 0!==o.property,p=d||!f,m=o.type||a||"exponential";if("exponential"===m)h=n;else if("interval"===m)h=i;else if("categorical"===m)h=e;else{if("identity"!==m)throw new Error(\'Unknown function type "\'+m+\'"\');h=r}if(d){var y={},g=[];for(let t=0;t<o.stops.length;t++){var b=o.stops[t];void 0===y[b[0].zoom]&&(y[b[0].zoom]={zoom:b[0].zoom,type:o.type,property:o.property,default:o.default,stops:[]}),y[b[0].zoom].stops.push([b[0].value,b[1]])}for(let e in y)g.push([y[e].zoom,t(y[e])]);l=function(t,e){const i=n({stops:g,base:o.base},t)(t,e);return"function"==typeof i?i(t,e):i},u=!1,c=!1}else p?(l=function(t){const e=h(o,t);return"function"==typeof e?e(t):e},u=!0,c=!1):(l=function(t,e){const i=h(o,e?e[o.property]:null);return"function"==typeof i?i(t,e):i},u=!1,c=!0)}else l=function(){return o},u=!0,c=!0;return l.isZoomConstant=c,l.isFeatureConstant=u,l}(t,o);return h.isZoomConstant=a&&h.isZoomConstant,h.isFeatureConstant=l&&h.isFeatureConstant,h}let h=0;const d="function"==typeof Object.assign;function f(t,...e){if(d)return Object.assign(t,...e),t;for(let i=0;i<e.length;i++){const n=e[i];for(const e in n)t[e]=n[e]}return t}function p(t){return!b(t)&&("string"==typeof t||null!==t.constructor&&t.constructor===String)}function m(t){return"number"==typeof t&&!isNaN(t)}function y(t){return!b(t)&&("function"==typeof t||null!==t.constructor&&t.constructor===Function)}function g(t){return!Array.isArray(t)&&"object"==typeof t&&!!t}function b(t){return null==t}function v(t){for(let e=1;e<arguments.length;e++){const i=arguments[e];if(i)for(let e=0,n=i.length;e<n;e++)t.push(i[e])}return t.length}function w(t){return t<65536?Uint16Array:Uint32Array}function x(t){return t<256?Uint8Array:t<65536?Uint16Array:Uint32Array}function k(t){return(t=Math.abs(t))<128?Int8Array:t<32768?Int16Array:Float32Array}function M(t){return s(t)&&t.property}const j="function"==typeof fetch&&"function"==typeof AbortController,A={jsonp:function(t,e){const i="_maptalks_jsonp_"+h++;t.match(/\\?/)?t+="&callback="+i:t+="?callback="+i;let n=document.createElement("script");return n.type="text/javascript",n.src=t,window[i]=function(t){e(null,t),document.getElementsByTagName("head")[0].removeChild(n),n=null,delete window[i]},document.getElementsByTagName("head")[0].appendChild(n),this},get:function(t,e,i){if(y(e)){const t=i;i=e,e=t}(e=e||{}).method&&(e.method=e.method.toUpperCase());const n="POST"===e.method;if(j){const r=new AbortController,o={signal:r.signal,method:e.method||"GET",referrerPolicy:"origin"};return n&&(b(e.body)||(o.body=JSON.stringify(e.body))),b(e.headers)||(o.headers=e.headers),b(e.credentials)||(o.credentials=e.credentials),fetch(t,o).then(n=>{const r=this.t(n,e.returnJSON,e.responseType);r.message?(r.url=t,i(r)):r.then(t=>{"arraybuffer"===e.responseType?i(null,{data:t,cacheControl:n.headers.get("Cache-Control"),expires:n.headers.get("Expires"),contentType:n.headers.get("Content-Type")}):i(null,t)}).catch(t=>{t.code&&t.code===DOMException.ABORT_ERR||(console.error(t),i(t))})}).catch(t=>{t.code&&t.code===DOMException.ABORT_ERR||(console.error(t),i(t))}),r}{const r=A.o(i);if(r.open(e.method||"GET",t,!0),e){for(const t in e.headers)r.setRequestHeader(t,e.headers[t]);r.withCredentials="include"===e.credentials,e.responseType&&(r.responseType=e.responseType)}return r.send(n?e.body:null),r}},t:(t,e,i)=>200!==t.status?{status:t.status,statusText:t.statusText,message:`incorrect http request with status code(${t.status}): ${t.statusText}`}:"arraybuffer"===i?t.arrayBuffer():e?t.json():t.text(),s:function(t,e){return function(){if(4===t.readyState)if(200===t.status)if("arraybuffer"===t.responseType){0===t.response.byteLength?e({status:200,statusText:t.statusText,message:"http status 200 returned without content."}):e(null,{data:t.response,cacheControl:t.getResponseHeader("Cache-Control"),expires:t.getResponseHeader("Expires"),contentType:t.getResponseHeader("Content-Type")})}else e(null,t.responseText);else e({status:t.status,statusText:t.statusText,message:`incorrect http request with status code(${t.status}): ${t.statusText}`})}},o:function(t){let e;try{e=new XMLHttpRequest}catch(t){try{e=new ActiveXObject("Msxml2.XMLHTTP")}catch(t){try{e=new ActiveXObject("Microsoft.XMLHTTP")}catch(t){}}}return e.onreadystatechange=A.s(e,t),e},getArrayBuffer(t,e,i){if(y(e)){const t=i;i=e,e=t}return e||(e={}),e.responseType="arraybuffer",A.get(t,e,i)}};function F(t,e,i,n,r,o){let s=r-i,a=o-n;if(0!==s||0!==a){const l=((t-i)*s+(e-n)*a)/(s*s+a*a);l>1?(i=r,n=o):l>0&&(i+=s*l,n+=a*l)}return s=t-i,a=e-n,s*s+a*a}function T(t,e,i,n,r,o){const s={id:null==t?null:t,type:e,geometry:i,tags:n,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0};r&&(s.layer=r);return function(t,e){const i=t.geometry,n=t.type;if("Point"===n||"MultiPoint"===n||"LineString"===n)z(t,i,e);else if("Polygon"===n)z(t,i[0],e);else if("MultiLineString"===n)for(const n of i)z(t,n,e);else if("MultiPolygon"===n)for(const n of i)z(t,n[0],e)}(s,o?4:3),s}function z(t,e,i){for(let n=0;n<e.length;n+=i)t.minX=Math.min(t.minX,e[n]),t.minY=Math.min(t.minY,e[n+1]),t.maxX=Math.max(t.maxX,e[n]),t.maxY=Math.max(t.maxY,e[n+1])}function S(t,e,i,n){if(n.layer=e,"FeatureCollection"===i.type)for(let e=0;e<i.features.length;e++)_(t,i.features[e],n,e);else"Feature"===i.type?_(t,i,n):_(t,{geometry:i},n)}function _(t,e,i,n){if(!e.geometry)return;const r=e.geometry.coordinates,o=e.geometry.type,s=Math.pow(i.tolerance/((1<<i.maxZoom)*i.extent),2);let a=[],l=e.id;if(i.promoteId?l=e.properties[i.promoteId]:i.generateId&&(l=n||0),"Point"===o)P(r,a,i.hasAltitude);else if("MultiPoint"===o)for(const t of r)P(t,a,i.hasAltitude);else if("LineString"===o)I(r,a,s,!1,i.hasAltitude);else if("MultiLineString"===o){if(i.lineMetrics){for(const n of r)a=[],I(n,a,s,!1,i.hasAltitude),t.push(T(l,"LineString",a,e.properties,i.layer,i.hasAltitude));return}O(r,a,s,!1,i.hasAltitude)}else if("Polygon"===o)O(r,a,s,!0,i.hasAltitude);else{if("MultiPolygon"!==o){if("GeometryCollection"===o){for(const r of e.geometry.geometries)_(t,{id:l,geometry:r,properties:e.properties},i,n);return}throw new Error("Input data is not a valid GeoJSON object.")}for(const t of r){const e=[];O(t,e,s,!0,i.hasAltitude),a.push(e)}}t.push(T(l,o,a,e.properties,i.layer,i.hasAltitude))}function P(t,e,i){e.push(E(t[0]),q(t[1]),0),i&&(t.length>2?e.push(t[2]):e.push(0))}function I(t,e,i,n,r){let o,s,a=0;for(let i=0;i<t.length;i++){const l=E(t[i][0]),u=q(t[i][1]);e.push(l,u,0),r&&(t[i].length>2?e.push(t[i][2]):e.push(0)),i>0&&(a+=n?(o*u-l*s)/2:Math.sqrt(Math.pow(l-o,2)+Math.pow(u-s,2))),o=l,s=u}const l=r?4:3,u=e.length-l;e[2]=1,function t(e,i,n,r,o=3){let s=r;const a=n-i>>1;let l,u=n-i;const c=e[i],h=e[i+1],d=e[n],f=e[n+1];for(let t=i+o;t<n;t+=o){const i=F(e[t],e[t+1],c,h,d,f);if(i>s)l=t,s=i;else if(i===s){const e=Math.abs(t-a);e<u&&(l=t,u=e)}}s>r&&(l-i>o&&t(e,i,l,r,o),e[l+2]=s,n-l>o&&t(e,l,n,r,o))}(e,0,u,i,l),e[u+2]=1,e.size=Math.abs(a),e.start=0,e.end=e.size}function O(t,e,i,n,r){for(let o=0;o<t.length;o++){const s=[];I(t[o],s,i,n,r),e.push(s)}}function E(t){return t/360+.5}function q(t){const e=Math.sin(t*Math.PI/180),i=.5-.25*Math.log((1+e)/(1-e))/Math.PI;return i<0?0:i>1?1:i}function R(t,e,i,n,r,o,s,a){if(n/=e,o>=(i/=e)&&s<n)return t;if(s<i||o>=n)return null;const l=[];for(const e of t){const t=e.geometry;let o=e.type;const s=0===r?e.minX:e.minY,u=0===r?e.maxX:e.maxY;if(s>=i&&u<n){l.push(e);continue}if(u<i||s>=n)continue;let c=[];if("Point"===o||"MultiPoint"===o)C(t,c,i,n,r,a.hasAltitude);else if("LineString"===o)N(t,c,i,n,r,!1,a.lineMetrics,a.hasAltitude);else if("MultiLineString"===o)D(t,c,i,n,r,!1,a.hasAltitude);else if("Polygon"===o)D(t,c,i,n,r,!0,a.hasAltitude);else if("MultiPolygon"===o)for(const e of t){const t=[];D(e,t,i,n,r,!0,a.hasAltitude),t.length&&c.push(t)}if(c.length){if(a.lineMetrics&&"LineString"===o){for(const t of c)l.push(T(e.id,o,t,e.tags,e.layer,a.hasAltitude));continue}"LineString"!==o&&"MultiLineString"!==o||(1===c.length?(o="LineString",c=c[0]):o="MultiLineString"),"Point"!==o&&"MultiPoint"!==o||(o=3===c.length?"Point":"MultiPoint"),l.push(T(e.id,o,c,e.tags,e.layer,a.hasAltitude))}}return l.length?l:null}function C(t,e,i,n,r,o){const s=o?4:3;for(let a=0;a<t.length;a+=s){const s=t[a+r];s>=i&&s<=n&&(U(e,t[a],t[a+1],t[a+2]),o&&e.push(t[a+3]))}}function N(t,e,i,n,r,o,s,a){let l=L(t);const u=0===r?$:W;let c,h,d=t.start;const f=a?4:3;for(let p=0;p<t.length-f;p+=f){const m=t[p],y=t[p+1],g=t[p+2],b=t[p+f],v=t[p+f+1];let w,x;a&&(w=t[p+3],x=t[p+f+3]);const k=0===r?m:y,M=0===r?b:v;let j=!1;s&&(c=Math.sqrt(Math.pow(m-b,2)+Math.pow(y-v,2))),k<i?M>i&&(h=u(l,m,y,b,v,i),a&&l.push(J(w,x,h)),s&&(l.start=d+c*h)):k>n?M<n&&(h=u(l,m,y,b,v,n),a&&l.push(J(w,x,h)),s&&(l.start=d+c*h)):(U(l,m,y,g),a&&l.push(w)),M<i&&k>=i&&(h=u(l,m,y,b,v,i),a&&l.push(J(w,x,h)),j=!0),M>n&&k<=n&&(h=u(l,m,y,b,v,n),a&&l.push(J(w,x,h)),j=!0),!o&&j&&(s&&(l.end=d+c*h),e.push(l),l=L(t)),s&&(d+=c)}let p=t.length-f;const m=t[p],y=t[p+1],g=t[p+2],b=0===r?m:y;if(b>=i&&b<=n&&U(l,m,y,g),b>=i&&b<=n&&a){const e=t[p+3];l.push(e)}p=l.length-f,o&&p>=f&&(l[p]!==l[0]||l[p+1]!==l[1])&&(U(l,l[0],l[1],l[2]),a&&l.push(l[3])),l.length&&e.push(l)}function L(t){const e=[];return e.size=t.size,e.start=t.start,e.end=t.end,e}function D(t,e,i,n,r,o,s){for(const a of t)N(a,e,i,n,r,o,!1,s)}function U(t,e,i,n){t.push(e,i,n)}function $(t,e,i,n,r,o){const s=(o-e)/(n-e);return U(t,o,i+(r-i)*s,1),s}function W(t,e,i,n,r,o){const s=(o-i)/(r-i);return U(t,e+(n-e)*s,o,1),s}function J(t,e,i){return t+(e-t)*i}function H(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=t[r],s=o.type;let a;if("Point"===s||"MultiPoint"===s||"LineString"===s)a=G(o.geometry,e,i);else if("MultiLineString"===s||"Polygon"===s){a=[];for(const t of o.geometry)a.push(G(t,e,i))}else if("MultiPolygon"===s){a=[];for(const t of o.geometry){const n=[];for(const r of t)n.push(G(r,e,i));a.push(n)}}n.push(T(o.id,s,a,o.tags,o.layer,i))}return n}function G(t,e,i){const n=[];n.size=t.size,void 0!==t.start&&(n.start=t.start,n.end=t.end);const r=i?4:3;for(let o=0;o<t.length;o+=r)n.push(t[o]+e,t[o+1],t[o+2]),i&&n.push(t[o+3]);return n}function V(t,e,i){if(t.transformed)return t;const n=1<<t.z,r=t.x,o=t.y,s=i?3:2;for(const a of t.features){const t=a.geometry,l=a.type;if(a.geometry=[],1===l)for(let l=0;l<t.length;l+=s)a.geometry.push(B(t[l],t[l+1],e,n,r,o)),i&&a.geometry[a.geometry.length-1].push(t[l+2]);else for(let l=0;l<t.length;l++){const u=[];for(let a=0;a<t[l].length;a+=s)u.push(B(t[l][a],t[l][a+1],e,n,r,o)),i&&u[u.length-1].push(t[l][a+2]);a.geometry.push(u)}}return t.transformed=!0,t}function B(t,e,i,n,r,o){return[Math.round(i*(t*n-r)),Math.round(i*(e*n-o))]}function X(t,e,i,n,r){const o=e===r.maxZoom?0:r.tolerance/((1<<e)*r.extent),s={features:[],numPoints:0,numSimplified:0,numFeatures:t.length,source:null,x:i,y:n,z:e,transformed:!1,minX:2,minY:1,maxX:-1,maxY:0};for(const e of t)Z(s,e,o,r);return s}function Z(t,e,i,n){const r=e.geometry,o=e.type,s=[],a=n.hasAltitude?4:3;if(t.minX=Math.min(t.minX,e.minX),t.minY=Math.min(t.minY,e.minY),t.maxX=Math.max(t.maxX,e.maxX),t.maxY=Math.max(t.maxY,e.maxY),"Point"===o||"MultiPoint"===o)for(let e=0;e<r.length;e+=a)s.push(r[e],r[e+1]),n.hasAltitude&&s.push(r[e+3]),t.numPoints++,t.numSimplified++;else if("LineString"===o)Y(s,r,t,i,!1,!1,n);else if("MultiLineString"===o||"Polygon"===o)for(let e=0;e<r.length;e++)Y(s,r[e],t,i,"Polygon"===o,0===e,n);else if("MultiPolygon"===o)for(let e=0;e<r.length;e++){const o=r[e];for(let e=0;e<o.length;e++)Y(s,o[e],t,i,!0,0===e,n)}if(s.length){let i=e.tags||null;if("LineString"===o&&n.lineMetrics){i={};for(const t in e.tags)i[t]=e.tags[t];i.mapbox_clip_start=r.start/r.size,i.mapbox_clip_end=r.end/r.size}const a={geometry:s,type:"Polygon"===o||"MultiPolygon"===o?3:"LineString"===o||"MultiLineString"===o?2:1,tags:i};e.layer&&(a.layer=e.layer),null!==e.id&&(a.id=e.id),t.features.push(a)}}function Y(t,e,i,n,r,o,s){const a=n*n,{hasAltitude:l,disableFilter:u}=s,c=l?4:3;if(!u&&n>0&&e.size<(r?a:n))return void(i.numPoints+=e.length/c);const h=[];for(let t=0;t<e.length;t+=c)(0===n||e[t+2]>a)&&(i.numSimplified++,h.push(e[t],e[t+1]),l&&h.push(e[t+3])),i.numPoints++;r&&function(t,e,i){const n=i?3:2;let r=0;for(let e=0,i=t.length,o=i-n;e<i;o=e,e+=n)r+=(t[e]-t[o])*(t[e+1]+t[o+1]);if(r>0===e){const e=n,r=n-1,o=n-2;for(let s=0,a=t.length;s<a/2;s+=n){const n=t[s],l=t[s+1];let u;i&&(u=t[s+2]),t[s]=t[a-e-s],t[s+1]=t[a-r-s],i&&(t[s+2]=t[a-o-s]),t[a-e-s]=n,t[a-r-s]=l,i&&(t[a-o-s]=u)}}}(h,o,l),t.push(h)}A.getJSON=function(t,e,i){if(y(e)){const t=i;i=e,e=t}const n=function(t,e){const n="string"==typeof e?JSON.parse(e):e||null;i(t,n)};return e&&e.jsonp?A.jsonp(t,n):((e=e||{}).returnJSON=!0,A.get(t,e,n))};const K={maxZoom:14,indexMaxZoom:5,indexMaxPoints:1e5,tolerance:3,extent:4096,buffer:64,lineMetrics:!1,promoteId:null,generateId:!1,hasAltitude:!1,disableFilter:!1,debug:0};class Q{constructor(t,e){const i=(e=this.options=function(t,e){for(const i in e)t[i]=e[i];return t}(Object.create(K),e)).debug;if(i&&console.time("preprocess data"),e.maxZoom<0||e.maxZoom>24)throw new Error("maxZoom should be in the 0-24 range");if(e.promoteId&&e.generateId)throw new Error("promoteId and generateId cannot be used together.");let n=function(t,e){const i=[];if(Array.isArray(t)){for(let n=0;n<t.length;n++)S(i,t[n].layer,t[n].data,e);return i}if("FeatureCollection"===t.type)for(let n=0;n<t.features.length;n++)_(i,t.features[n],e,n);else"Feature"===t.type?_(i,t,e):_(i,{geometry:t},e);return i}(t,e);this.tiles={},this.tileCoords=[],i&&(console.timeEnd("preprocess data"),console.log("index: maxZoom: %d, maxPoints: %d",e.indexMaxZoom,e.indexMaxPoints),console.time("generate tiles"),this.stats={},this.total=0),n=function(t,e){const i=e.buffer/e.extent;let n=t;const r=R(t,1,-1-i,i,0,-1,2,e),o=R(t,1,1-i,2+i,0,-1,2,e);return(r||o)&&(n=R(t,1,-i,1+i,0,-1,2,e)||[],r&&(n=H(r,1,e.hasAltitude).concat(n)),o&&(n=n.concat(H(o,-1,e.hasAltitude)))),n}(n,e),n.length&&this.splitTile(n,0,0,0),i&&(n.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(t,e,i,n,r,o,s){const a=[t,e,i,n],l=this.options,u=l.debug;for(;a.length;){n=a.pop(),i=a.pop(),e=a.pop(),t=a.pop();const c=1<<e,h=tt(e,i,n);let d=this.tiles[h];if(!d&&(u>1&&console.time("creation"),d=this.tiles[h]=X(t,e,i,n,l),this.tileCoords.push({z:e,x:i,y:n}),u)){u>1&&(console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)",e,i,n,d.numFeatures,d.numPoints,d.numSimplified),console.timeEnd("creation"));const t="z"+e;this.stats[t]=(this.stats[t]||0)+1,this.total++}if(d.source=t,null==r){if(e===l.indexMaxZoom||d.numPoints<=l.indexMaxPoints)continue}else{if(e===l.maxZoom||e===r)continue;if(null!=r){const t=r-e;if(i!==o>>t||n!==s>>t)continue}}if(d.source=null,0===t.length)continue;u>1&&console.time("clipping");const f=.5*l.buffer/l.extent,p=.5-f,m=.5+f,y=1+f;let g=null,b=null,v=null,w=null,x=R(t,c,i-f,i+m,0,d.minX,d.maxX,l),k=R(t,c,i+p,i+y,0,d.minX,d.maxX,l);t=null,x&&(g=R(x,c,n-f,n+m,1,d.minY,d.maxY,l),b=R(x,c,n+p,n+y,1,d.minY,d.maxY,l),x=null),k&&(v=R(k,c,n-f,n+m,1,d.minY,d.maxY,l),w=R(k,c,n+p,n+y,1,d.minY,d.maxY,l),k=null),u>1&&console.timeEnd("clipping"),a.push(g||[],e+1,2*i,2*n),a.push(b||[],e+1,2*i,2*n+1),a.push(v||[],e+1,2*i+1,2*n),a.push(w||[],e+1,2*i+1,2*n+1)}}getTile(t,e,i){t=+t,e=+e,i=+i;const n=this.options,{extent:r,debug:o}=n,{hasAltitude:s}=n;if(t<0||t>24)return null;const a=1<<t,l=tt(t,e=e+a&a-1,i);if(this.tiles[l])return V(this.tiles[l],r,s);o>1&&console.log("drilling down to z%d-%d-%d",t,e,i);let u,c=t,h=e,d=i;for(;!u&&c>0;)c--,h>>=1,d>>=1,u=this.tiles[tt(c,h,d)];return u&&u.source?(o>1&&(console.log("found parent tile z%d-%d-%d",c,h,d),console.time("drilling down")),this.splitTile(u.source,c,h,d,t,e,i),o>1&&console.timeEnd("drilling down"),this.tiles[l]?V(this.tiles[l],r,s):null):null}}function tt(t,e,i){return 32*((1<<t)*i+e)+t}function et(t,e,i,n,r,o){const s=i&&Array.isArray(i[0]);for(let a=0,l=i.length;a<l;a++){t[e]=Math.round((s?i[a][0]:i[a].x)*n),t[e+1]=Math.round((s?i[a][1]:i[a].y)*n);let u=r||0;Array.isArray(r)&&(u=r[a]),u=u?Math.round(n*u):0,t[e+2]=u,e+=3,o&&0!==a&&a!==l-1&&(t[e]=t[e-3],t[e+1]=t[e-2],t[e+2]=t[e-1],e+=3)}return e}function it(t,e,i,n){const r=t[3*e],o=t[3*e+1],s=t[3*i],a=t[3*i+1];return r===s&&(r<0||r>n)||o===a&&(o<0||o>n)}class nt{constructor(t,e){this.x=t,this.y=e}clone(){return new nt(this.x,this.y)}normalize(){const t=this.length();this.x/=t,this.y/=t}negate(){this.x=-this.x,this.y=-this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}diff(t){return new nt(this.x-t.x,this.y-t.y)}distance(t){const e=this.x-t.x,i=this.y-t.y;return Math.sqrt(e*e+i*i)}dot(t){return this.x*t.x+this.y*t.y}equals(t){return this.x===t.x&&this.y===t.y}orthogonal(){return new nt(this.y,-this.x)}}function rt(t,e,i){const n=(e.x-t.x)*(i.y-t.y)-(e.y-t.y)*(i.x-t.x);return n>1e-5?1:n<-1e-5?2:0}function ot(t,e,i,n){const r=e.x*n.y-e.y*n.x,o=i.x-t.x,s=i.y-t.y,a=(o*n.y-s*n.x)/r;return new nt(t.x+a*e.x,t.y+a*e.y)}const st=[];function at(t,e,i){let n=0;const r=[];for(let o=e;o<i;o+=3)st[n]?(st[n].x=t[o],st[n].y=t[o+1]):st[n]=new nt(t[o],t[o+1]),r.push(st[n]),n++;const o=function(t){let e;this.UpdateOmbb=function(t,i,n,r,o,s,a,l){const u=ot(t,i,o,s),c=ot(n,r,o,s),h=ot(a,l,t,i),d=ot(a,l,n,r),f=u.distance(c)*u.distance(h);f<this.BestObbArea&&(e=[u,h,d,c],this.BestObbArea=f)},this.BestObbArea=Number.MAX_VALUE;const i=[];for(let e=0;e<t.length;e++)i.push(t[(e+1)%t.length].diff(t[e])),i[e].normalize();const n=new nt(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY),r=new nt(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY);let o,s,a,l;for(let e=0;e<t.length;e++){const i=t[e];i.x<n.x&&(n.x=i.x,o=e),i.x>r.x&&(r.x=i.x,s=e),i.y<n.y&&(n.y=i.y,l=e),i.y>r.y&&(r.y=i.y,a=e)}let u=new nt(0,-1),c=new nt(0,1),h=new nt(-1,0),d=new nt(1,0);for(let e=0;e<t.length;e++){const e=[Math.acos(u.dot(i[o])),Math.acos(c.dot(i[s])),Math.acos(h.dot(i[a])),Math.acos(d.dot(i[l]))];switch(e.indexOf(Math.min.apply(Math,e))){case 0:u=i[o].clone(),c=u.clone(),c.negate(),h=u.orthogonal(),d=h.clone(),d.negate(),o=(o+1)%t.length;break;case 1:c=i[s].clone(),u=c.clone(),u.negate(),h=u.orthogonal(),d=h.clone(),d.negate(),s=(s+1)%t.length;break;case 2:h=i[a].clone(),d=h.clone(),d.negate(),u=d.orthogonal(),c=u.clone(),c.negate(),a=(a+1)%t.length;break;case 3:d=i[l].clone(),h=d.clone(),h.negate(),u=d.orthogonal(),c=u.clone(),c.negate(),l=(l+1)%t.length}this.UpdateOmbb(t[o],u,t[s],c,t[a],h,t[l],d)}return e}(function(t){if(t.length<3)return t;let e=t[0];const i=[];for(let i=1;i<t.length;i++)(t[i].x<e.x||Math.abs(t[i].x-e.x)<1e-5&&t[i].y<e.y)&&(e=t[i]);let n=t[0];do{i.unshift(e.clone());for(let i=1;i<t.length;i++){const r=rt(e,n,t[i]);(n.equals(e)||1===r||0===r&&e.distance(t[i])>e.distance(n))&&(n=t[i])}e=n}while(!n.equals(i[i.length-1]));return i}(r)),s=o[0].distance(o[1]),a=o[1].distance(o[2]),l=o.map(t=>[t.x,t.y]);return l.push(+(a>s)),l}var lt="undefined"!=typeof Float32Array?Float32Array:Array;function ut(){var t=new lt(3);return lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t}function ct(t,e,i){var n=new lt(3);return n[0]=t,n[1]=e,n[2]=i,n}function ht(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function dt(t,e,i,n){return t[0]=e,t[1]=i,t[2]=n,t}function ft(t,e,i){return t[0]=e[0]+i[0],t[1]=e[1]+i[1],t[2]=e[2]+i[2],t}function pt(t,e,i){return t[0]=e[0]/i[0],t[1]=e[1]/i[1],t[2]=e[2]/i[2],t}function mt(t,e){var i=e[0],n=e[1],r=e[2],o=i*i+n*n+r*r;return o>0&&(o=1/Math.sqrt(o),t[0]=e[0]*o,t[1]=e[1]*o,t[2]=e[2]*o),t}function yt(t,e){return t[0]*e[0]+t[1]*e[1]+t[2]*e[2]}function gt(t,e,i){var n=e[0],r=e[1],o=e[2],s=i[0],a=i[1],l=i[2];return t[0]=r*l-o*a,t[1]=o*s-n*l,t[2]=n*a-r*s,t}var bt=function(t,e,i){return t[0]=e[0]-i[0],t[1]=e[1]-i[1],t[2]=e[2]-i[2],t};function vt(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t}function wt(t,e,i,n,r){return t[0]=e,t[1]=i,t[2]=n,t[3]=r,t}function xt(t,e,i){return t[0]=e[0]*i,t[1]=e[1]*i,t[2]=e[2]*i,t[3]=e[3]*i,t}function kt(){var t=new lt(4);return lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0),t[3]=1,t}function Mt(t,e){var i=e[0]+e[4]+e[8],n=void 0;if(i>0)n=Math.sqrt(i+1),t[3]=.5*n,n=.5/n,t[0]=(e[5]-e[7])*n,t[1]=(e[6]-e[2])*n,t[2]=(e[1]-e[3])*n;else{var r=0;e[4]>e[0]&&(r=1),e[8]>e[3*r+r]&&(r=2);var o=(r+1)%3,s=(r+2)%3;n=Math.sqrt(e[3*r+r]-e[3*o+o]-e[3*s+s]+1),t[r]=.5*n,n=.5/n,t[3]=(e[3*o+s]-e[3*s+o])*n,t[o]=(e[3*o+r]+e[3*r+o])*n,t[s]=(e[3*s+r]+e[3*r+s])*n}return t}ut(),function(){var t,e=(t=new lt(4),lt!=Float32Array&&(t[0]=0,t[1]=0,t[2]=0,t[3]=0),t)}();var jt,At=xt,Ft=function(t,e){var i=e[0],n=e[1],r=e[2],o=e[3],s=i*i+n*n+r*r+o*o;return s>0&&(s=1/Math.sqrt(s),t[0]=i*s,t[1]=n*s,t[2]=r*s,t[3]=o*s),t};function Tt(t,e){var i=e[0]-t[0],n=e[1]-t[1];return Math.sqrt(i*i+n*n)}ut(),ct(1,0,0),ct(0,1,0),kt(),kt(),jt=new lt(9),lt!=Float32Array&&(jt[1]=0,jt[2]=0,jt[3]=0,jt[5]=0,jt[6]=0,jt[7]=0),jt[0]=1,jt[4]=1,jt[8]=1;var zt=function(t){var e=t[0],i=t[1];return Math.sqrt(e*e+i*i)};function St(t,e,i,n,r,o,s,a,l,u){0===t?function(t,e,i,n,r,o,s,a,l){const u=[0,0];for(let r=t;r<e;r+=3){const t=r/3*2,e=n[r],c=n[r+1];i[t]=u[0]+e*o*s/a,i[t+1]=u[1]-c*o*s/l}}(e,i,n,r,0,s,a,l,u):1===t&&function(t,e,i,n){const r=at(n,t,e),o=r[4],s=r[o],a=r[o+1],l=r[o+2],u=(a[1]-s[1])/(a[0]-s[0]),c=(l[1]-a[1])/(l[0]-a[0]),h=Tt(s,a),d=Tt(a,l);for(let r=t;r<e;r+=3){const t=r/3*2,e=n[r],o=n[r+1];i[t]=Pt(e,o,s,u,h),i[t+1]=-Pt(e,o,a,c,d)}}(e,i,n,r)}!function(){var t=function(){var t=new lt(2);return lt!=Float32Array&&(t[0]=0,t[1]=0),t}()}();const _t=[];function Pt(t,e,i,n,r){return _t[0]=(n*n*i[0]+n*(e-i[1])+t)/(n*n+1),_t[1]=n*(_t[0]-i[0])+i[1],Tt(i,_t)/r}function It(t,e,i,n,r){const o=3*e[i-1],s=3*e[i-1]+1,a=t[o],l=t[s];return u=n,c=r,h=a,d=l,Math.sqrt((h-u)*(h-u)+(d-c)*(d-c));var u,c,h,d}"undefined"!=typeof undefinedThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof undefined?global:"undefined"!=typeof self&&self;var Ot=Et;function Et(t,e){this.x=t,this.y=e}function qt(t,e,i){i=i||{},this.w=t||64,this.h=e||64,this.autoResize=!!i.autoResize,this.shelves=[],this.freebins=[],this.stats={},this.bins={},this.maxId=0}function Rt(t,e,i){this.x=0,this.y=t,this.w=this.free=e,this.h=i}function Ct(t,e,i,n,r,o,s){this.id=t,this.x=e,this.y=i,this.w=n,this.h=r,this.maxw=o||n,this.maxh=s||r,this.refcount=0}\n/*!\n Feature Filter by\n\n (c) mapbox 2016 and maptalks 2018\n www.mapbox.com | www.maptalks.org\n License: MIT, header required.\n */Et.prototype={clone:function(){return new Et(this.x,this.y)},add:function(t){return this.clone().u(t)},sub:function(t){return this.clone().m(t)},multByPoint:function(t){return this.clone().v(t)},divByPoint:function(t){return this.clone().k(t)},mult:function(t){return this.clone().M(t)},div:function(t){return this.clone().j(t)},rotate:function(t){return this.clone().A(t)},rotateAround:function(t,e){return this.clone().F(t,e)},matMult:function(t){return this.clone().T(t)},unit:function(){return this.clone().S()},perp:function(){return this.clone()._()},round:function(){return this.clone().P()},mag:function(){return Math.sqrt(this.x*this.x+this.y*this.y)},equals:function(t){return this.x===t.x&&this.y===t.y},dist:function(t){return Math.sqrt(this.distSqr(t))},distSqr:function(t){var e=t.x-this.x,i=t.y-this.y;return e*e+i*i},angle:function(){return Math.atan2(this.y,this.x)},angleTo:function(t){return Math.atan2(this.y-t.y,this.x-t.x)},angleWith:function(t){return this.angleWithSep(t.x,t.y)},angleWithSep:function(t,e){return Math.atan2(this.x*e-this.y*t,this.x*t+this.y*e)},T:function(t){var e=t[0]*this.x+t[1]*this.y,i=t[2]*this.x+t[3]*this.y;return this.x=e,this.y=i,this},u:function(t){return this.x+=t.x,this.y+=t.y,this},m:function(t){return this.x-=t.x,this.y-=t.y,this},M:function(t){return this.x*=t,this.y*=t,this},j:function(t){return this.x/=t,this.y/=t,this},v:function(t){return this.x*=t.x,this.y*=t.y,this},k:function(t){return this.x/=t.x,this.y/=t.y,this},S:function(){return this.j(this.mag()),this},_:function(){var t=this.y;return this.y=this.x,this.x=-t,this},A:function(t){var e=Math.cos(t),i=Math.sin(t),n=e*this.x-i*this.y,r=i*this.x+e*this.y;return this.x=n,this.y=r,this},F:function(t,e){var i=Math.cos(t),n=Math.sin(t),r=e.x+i*(this.x-e.x)-n*(this.y-e.y),o=e.y+n*(this.x-e.x)+i*(this.y-e.y);return this.x=r,this.y=o,this},P:function(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}},Et.convert=function(t){return t instanceof Et?t:Array.isArray(t)?new Et(t[0],t[1]):t},qt.prototype.pack=function(t,e){t=[].concat(t),e=e||{};for(var i,n,r,o,s=[],a=0;a<t.length;a++)if(i=t[a].w||t[a].width,n=t[a].h||t[a].height,r=t[a].id,i&&n){if(!(o=this.packOne(i,n,r)))continue;e.inPlace&&(t[a].x=o.x,t[a].y=o.y,t[a].id=o.id),s.push(o)}return this.shrink(),s},qt.prototype.packOne=function(t,e,i){var n,r,o,s,a,l,u,c,h={freebin:-1,shelf:-1,waste:1/0},d=0;if("string"==typeof i||"number"==typeof i){if(n=this.getBin(i))return this.ref(n),n;"number"==typeof i&&(this.maxId=Math.max(i,this.maxId))}else i=++this.maxId;for(s=0;s<this.freebins.length;s++){if(e===(n=this.freebins[s]).maxh&&t===n.maxw)return this.allocFreebin(s,t,e,i);e>n.maxh||t>n.maxw||e<=n.maxh&&t<=n.maxw&&(o=n.maxw*n.maxh-t*e)<h.waste&&(h.waste=o,h.freebin=s)}for(s=0;s<this.shelves.length;s++)if(d+=(r=this.shelves[s]).h,!(t>r.free)){if(e===r.h)return this.allocShelf(s,t,e,i);e>r.h||e<r.h&&(o=(r.h-e)*t)<h.waste&&(h.freebin=-1,h.waste=o,h.shelf=s)}return-1!==h.freebin?this.allocFreebin(h.freebin,t,e,i):-1!==h.shelf?this.allocShelf(h.shelf,t,e,i):e<=this.h-d&&t<=this.w?(r=new Rt(d,this.w,e),this.allocShelf(this.shelves.push(r)-1,t,e,i)):this.autoResize?(a=l=this.h,((u=c=this.w)<=a||t>u)&&(c=2*Math.max(t,u)),(a<u||e>a)&&(l=2*Math.max(e,a)),this.resize(c,l),this.packOne(t,e,i)):null},qt.prototype.allocFreebin=function(t,e,i,n){var r=this.freebins.splice(t,1)[0];return r.id=n,r.w=e,r.h=i,r.refcount=0,this.bins[n]=r,this.ref(r),r},qt.prototype.allocShelf=function(t,e,i,n){var r=this.shelves[t].alloc(e,i,n);return this.bins[n]=r,this.ref(r),r},qt.prototype.shrink=function(){if(this.shelves.length>0){for(var t=0,e=0,i=0;i<this.shelves.length;i++){var n=this.shelves[i];e+=n.h,t=Math.max(n.w-n.free,t)}this.resize(t,e)}},qt.prototype.getBin=function(t){return this.bins[t]},qt.prototype.ref=function(t){if(1==++t.refcount){var e=t.h;this.stats[e]=1+(0|this.stats[e])}return t.refcount},qt.prototype.unref=function(t){return 0===t.refcount?0:(0==--t.refcount&&(this.stats[t.h]--,delete this.bins[t.id],this.freebins.push(t)),t.refcount)},qt.prototype.clear=function(){this.shelves=[],this.freebins=[],this.stats={},this.bins={},this.maxId=0},qt.prototype.resize=function(t,e){this.w=t,this.h=e;for(var i=0;i<this.shelves.length;i++)this.shelves[i].resize(t);return!0},Rt.prototype.alloc=function(t,e,i){if(t>this.free||e>this.h)return null;var n=this.x;return this.x+=t,this.free-=t,new Ct(i,n,this.y,t,e,t,this.h)},Rt.prototype.resize=function(t){return this.free+=t-this.w,this.w=t,!0};const Nt=["Unknown","Point","LineString","Polygon","MultiPoint","MultiLineString","MultiPolygon","GeometryCollection"];function Lt(t){return new Function("f","var p = (f && f.properties || {}); return "+Dt(t))}function Dt(t){if(!t)return"true";const e=t[0];if(t.length<=1)return"any"===e?"false":"true";return`(${"=="===e?$t(t[1],t[2],"===",!1):"!="===e?$t(t[1],t[2],"!==",!1):"<"===e||">"===e||"<="===e||">="===e?$t(t[1],t[2],e,!0):"any"===e?Wt(t.slice(1),"||"):"all"===e?Wt(t.slice(1),"&&"):"none"===e?Gt(Wt(t.slice(1),"||")):"in"===e?Jt(t[1],t.slice(2)):"!in"===e?Gt(Jt(t[1],t.slice(2))):"has"===e?Ht(t[1]):"!has"===e?Gt(Ht(t[1])):"true"})`}function Ut(t){return"$"===t[0]?"f."+t.substring(1):"p["+JSON.stringify(t)+"]"}function $t(t,e,i,n){const r=Ut(t),o="$type"===t?Nt.indexOf(e):JSON.stringify(e);return(n?`typeof ${r}=== typeof ${o}&&`:"")+r+i+o}function Wt(t,e){return t.map(Dt).join(e)}function Jt(t,e){"$type"===t&&(e=e.map(t=>Nt.indexOf(t)));const i=JSON.stringify(e.sort(Vt)),n=Ut(t);return e.length<=200?`${i}.indexOf(${n}) !== -1`:`function(v, a, i, j) {\\n while (i <= j) { var m = (i + j) >> 1;\\n if (a[m] === v) return true; if (a[m] > v) j = m - 1; else i = m + 1;\\n }\\n return false; }(${n}, ${i},0,${e.length-1})`}function Ht(t){return"$id"===t?\'"id" in f\':JSON.stringify(t)+" in p"}function Gt(t){return`!(${t})`}function Vt(t,e){return t<e?-1:t>e?1:0}var Bt={exports:{}};Bt.exports=function(){function t(t,e,i){var n=t[e];t[e]=t[i],t[i]=n}function e(t,e){return t<e?-1:t>e?1:0}return function(i,n,r,o,s){!function e(i,n,r,o,s){for(;o>r;){if(o-r>600){var a=o-r+1,l=n-r+1,u=Math.log(a),c=.5*Math.exp(2*u/3),h=.5*Math.sqrt(u*c*(a-c)/a)*(l-a/2<0?-1:1),d=Math.max(r,Math.floor(n-l*c/a+h)),f=Math.min(o,Math.floor(n+(a-l)*c/a+h));e(i,n,d,f,s)}var p=i[n],m=r,y=o;for(t(i,r,n),s(i[o],p)>0&&t(i,r,o);m<y;){for(t(i,m,y),m++,y--;s(i[m],p)<0;)m++;for(;s(i[y],p)>0;)y--}0===s(i[r],p)?t(i,r,y):(y++,t(i,y,o)),y<=n&&(r=y+1),n<=y&&(o=y-1)}}(i,n,r||0,o||i.length-1,s||e)}}();var Xt=Bt.exports,Zt={exports:{}};function Yt(t,e){if(!(this instanceof Yt))return new Yt(t,e);if(this.data=t||[],this.length=this.data.length,this.compare=e||Kt,this.length>0)for(var i=(this.length>>1)-1;i>=0;i--)this.I(i)}function Kt(t,e){return t<e?-1:t>e?1:0}Zt.exports=Yt,Zt.exports.default=Yt,Yt.prototype={push:function(t){this.data.push(t),this.length++,this.O(this.length-1)},pop:function(){if(0!==this.length){var t=this.data[0];return this.length--,this.length>0&&(this.data[0]=this.data[this.length],this.I(0)),this.data.pop(),t}},peek:function(){return this.data[0]},O:function(t){for(var e=this.data,i=this.compare,n=e[t];t>0;){var r=t-1>>1,o=e[r];if(i(n,o)>=0)break;e[t]=o,t=r}e[t]=n},I:function(t){for(var e=this.data,i=this.compare,n=this.length>>1,r=e[t];t<n;){var o=1+(t<<1),s=o+1,a=e[o];if(s<this.length&&i(e[s],a)<0&&(o=s,a=e[s]),i(a,r)>=0)break;e[t]=a,t=o}e[t]=r}};var Qt=Zt.exports,te={exports:{}},ee={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},ie={exports:{}},ne=function(t){return!(!t||"string"==typeof t)&&(t instanceof Array||Array.isArray(t)||t.length>=0&&(t.splice instanceof Function||Object.getOwnPropertyDescriptor(t,t.length-1)&&"String"!==t.constructor.name))},re=Array.prototype.concat,oe=Array.prototype.slice,se=ie.exports=function(t){for(var e=[],i=0,n=t.length;i<n;i++){var r=t[i];ne(r)?e=re.call(e,oe.call(r)):e.push(r)}return e};se.wrap=function(t){return function(){return t(se(arguments))}};var ae=ee,le=ie.exports,ue=Object.hasOwnProperty,ce={};for(var he in ae)ue.call(ae,he)&&(ce[ae[he]]=he);var de=te.exports={to:{},get:{}};function fe(t,e,i){return Math.min(Math.max(e,t),i)}function pe(t){var e=Math.round(t).toString(16).toUpperCase();return e.length<2?"0"+e:e}de.get=function(t){var e,i;switch(t.substring(0,3).toLowerCase()){case"hsl":e=de.get.hsl(t),i="hsl";break;case"hwb":e=de.get.hwb(t),i="hwb";break;default:e=de.get.rgb(t),i="rgb"}return e?{model:i,value:e}:null},de.get.rgb=function(t){if(!t)return null;var e,i,n,r=[0,0,0,1];if(e=t.match(/^#([a-f0-9]{6})([a-f0-9]{2})?$/i)){for(n=e[2],e=e[1],i=0;i<3;i++){var o=2*i;r[i]=parseInt(e.slice(o,o+2),16)}n&&(r[3]=parseInt(n,16)/255)}else if(e=t.match(/^#([a-f0-9]{3,4})$/i)){for(n=(e=e[1])[3],i=0;i<3;i++)r[i]=parseInt(e[i]+e[i],16);n&&(r[3]=parseInt(n+n,16)/255)}else if(e=t.match(/^rgba?\\(\\s*([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/)){for(i=0;i<3;i++)r[i]=parseInt(e[i+1],0);e[4]&&(e[5]?r[3]=.01*parseFloat(e[4]):r[3]=parseFloat(e[4]))}else{if(!(e=t.match(/^rgba?\\(\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/)))return(e=t.match(/^(\\w+)$/))?"transparent"===e[1]?[0,0,0,0]:ue.call(ae,e[1])?((r=ae[e[1]])[3]=1,r):null:null;for(i=0;i<3;i++)r[i]=Math.round(2.55*parseFloat(e[i+1]));e[4]&&(e[5]?r[3]=.01*parseFloat(e[4]):r[3]=parseFloat(e[4]))}for(i=0;i<3;i++)r[i]=fe(r[i],0,255);return r[3]=fe(r[3],0,1),r},de.get.hsl=function(t){if(!t)return null;var e=t.match(/^hsla?\\(\\s*([+-]?(?:\\d{0,3}\\.)?\\d+)(?:deg)?\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*(?:[,|\\/]\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/);if(e){var i=parseFloat(e[4]);return[(parseFloat(e[1])%360+360)%360,fe(parseFloat(e[2]),0,100),fe(parseFloat(e[3]),0,100),fe(isNaN(i)?1:i,0,1)]}return null},de.get.hwb=function(t){if(!t)return null;var e=t.match(/^hwb\\(\\s*([+-]?\\d{0,3}(?:\\.\\d+)?)(?:deg)?\\s*,\\s*([+-]?[\\d\\.]+)%\\s*,\\s*([+-]?[\\d\\.]+)%\\s*(?:,\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/);if(e){var i=parseFloat(e[4]);return[(parseFloat(e[1])%360+360)%360,fe(parseFloat(e[2]),0,100),fe(parseFloat(e[3]),0,100),fe(isNaN(i)?1:i,0,1)]}return null},de.to.hex=function(){var t=le(arguments);return"#"+pe(t[0])+pe(t[1])+pe(t[2])+(t[3]<1?pe(Math.round(255*t[3])):"")},de.to.rgb=function(){var t=le(arguments);return t.length<4||1===t[3]?"rgb("+Math.round(t[0])+", "+Math.round(t[1])+", "+Math.round(t[2])+")":"rgba("+Math.round(t[0])+", "+Math.round(t[1])+", "+Math.round(t[2])+", "+t[3]+")"},de.to.rgb.percent=function(){var t=le(arguments),e=Math.round(t[0]/255*100),i=Math.round(t[1]/255*100),n=Math.round(t[2]/255*100);return t.length<4||1===t[3]?"rgb("+e+"%, "+i+"%, "+n+"%)":"rgba("+e+"%, "+i+"%, "+n+"%, "+t[3]+")"},de.to.hsl=function(){var t=le(arguments);return t.length<4||1===t[3]?"hsl("+t[0]+", "+t[1]+"%, "+t[2]+"%)":"hsla("+t[0]+", "+t[1]+"%, "+t[2]+"%, "+t[3]+")"},de.to.hwb=function(){var t=le(arguments),e="";return t.length>=4&&1!==t[3]&&(e=", "+t[3]),"hwb("+t[0]+", "+t[1]+"%, "+t[2]+"%"+e+")"},de.to.keyword=function(t){return ce[t.slice(0,3)]};var me={exports:{}},ye=ee,ge={};for(var be in ye)ye.hasOwnProperty(be)&&(ge[ye[be]]=be);var ve=me.exports={rgb:{channels:3,labels:"rgb"},hsl:{channels:3,labels:"hsl"},hsv:{channels:3,labels:"hsv"},hwb:{channels:3,labels:"hwb"},cmyk:{channels:4,labels:"cmyk"},xyz:{channels:3,labels:"xyz"},lab:{channels:3,labels:"lab"},lch:{channels:3,labels:"lch"},hex:{channels:1,labels:["hex"]},keyword:{channels:1,labels:["keyword"]},ansi16:{channels:1,labels:["ansi16"]},ansi256:{channels:1,labels:["ansi256"]},hcg:{channels:3,labels:["h","c","g"]},apple:{channels:3,labels:["r16","g16","b16"]},gray:{channels:1,labels:["gray"]}};for(var we in ve)if(ve.hasOwnProperty(we)){if(!("channels"in ve[we]))throw new Error("missing channels property: "+we);if(!("labels"in ve[we]))throw new Error("missing channel labels property: "+we);if(ve[we].labels.length!==ve[we].channels)throw new Error("channel and label counts mismatch: "+we);var xe=ve[we].channels,ke=ve[we].labels;delete ve[we].channels,delete ve[we].labels,Object.defineProperty(ve[we],"channels",{value:xe}),Object.defineProperty(ve[we],"labels",{value:ke})}function Me(t,e){return Math.pow(t[0]-e[0],2)+Math.pow(t[1]-e[1],2)+Math.pow(t[2]-e[2],2)}ve.rgb.hsl=function(t){var e,i,n=t[0]/255,r=t[1]/255,o=t[2]/255,s=Math.min(n,r,o),a=Math.max(n,r,o),l=a-s;return a===s?e=0:n===a?e=(r-o)/l:r===a?e=2+(o-n)/l:o===a&&(e=4+(n-r)/l),(e=Math.min(60*e,360))<0&&(e+=360),i=(s+a)/2,[e,100*(a===s?0:i<=.5?l/(a+s):l/(2-a-s)),100*i]},ve.rgb.hsv=function(t){var e,i,n,r,o,s=t[0]/255,a=t[1]/255,l=t[2]/255,u=Math.max(s,a,l),c=u-Math.min(s,a,l),h=function(t){return(u-t)/6/c+.5};return 0===c?r=o=0:(o=c/u,e=h(s),i=h(a),n=h(l),s===u?r=n-i:a===u?r=1/3+e-n:l===u&&(r=2/3+i-e),r<0?r+=1:r>1&&(r-=1)),[360*r,100*o,100*u]},ve.rgb.hwb=function(t){var e=t[0],i=t[1],n=t[2];return[ve.rgb.hsl(t)[0],100*(1/255*Math.min(e,Math.min(i,n))),100*(n=1-1/255*Math.max(e,Math.max(i,n)))]},ve.rgb.cmyk=function(t){var e,i=t[0]/255,n=t[1]/255,r=t[2]/255;return[100*((1-i-(e=Math.min(1-i,1-n,1-r)))/(1-e)||0),100*((1-n-e)/(1-e)||0),100*((1-r-e)/(1-e)||0),100*e]},ve.rgb.keyword=function(t){var e=ge[t];if(e)return e;var i,n=1/0;for(var r in ye)if(ye.hasOwnProperty(r)){var o=Me(t,ye[r]);o<n&&(n=o,i=r)}return i},ve.keyword.rgb=function(t){return ye[t]},ve.rgb.xyz=function(t){var e=t[0]/255,i=t[1]/255,n=t[2]/255;return[100*(.4124*(e=e>.04045?Math.pow((e+.055)/1.055,2.4):e/12.92)+.3576*(i=i>.04045?Math.pow((i+.055)/1.055,2.4):i/12.92)+.1805*(n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92)),100*(.2126*e+.7152*i+.0722*n),100*(.0193*e+.1192*i+.9505*n)]},ve.rgb.lab=function(t){var e=ve.rgb.xyz(t),i=e[0],n=e[1],r=e[2];return n/=100,r/=108.883,i=(i/=95.047)>.008856?Math.pow(i,1/3):7.787*i+16/116,[116*(n=n>.008856?Math.pow(n,1/3):7.787*n+16/116)-16,500*(i-n),200*(n-(r=r>.008856?Math.pow(r,1/3):7.787*r+16/116))]},ve.hsl.rgb=function(t){var e,i,n,r,o,s=t[0]/360,a=t[1]/100,l=t[2]/100;if(0===a)return[o=255*l,o,o];e=2*l-(i=l<.5?l*(1+a):l+a-l*a),r=[0,0,0];for(var u=0;u<3;u++)(n=s+1/3*-(u-1))<0&&n++,n>1&&n--,o=6*n<1?e+6*(i-e)*n:2*n<1?i:3*n<2?e+(i-e)*(2/3-n)*6:e,r[u]=255*o;return r},ve.hsl.hsv=function(t){var e=t[0],i=t[1]/100,n=t[2]/100,r=i,o=Math.max(n,.01);return i*=(n*=2)<=1?n:2-n,r*=o<=1?o:2-o,[e,100*(0===n?2*r/(o+r):2*i/(n+i)),100*((n+i)/2)]},ve.hsv.rgb=function(t){var e=t[0]/60,i=t[1]/100,n=t[2]/100,r=Math.floor(e)%6,o=e-Math.floor(e),s=255*n*(1-i),a=255*n*(1-i*o),l=255*n*(1-i*(1-o));switch(n*=255,r){case 0:return[n,l,s];case 1:return[a,n,s];case 2:return[s,n,l];case 3:return[s,a,n];case 4:return[l,s,n];case 5:return[n,s,a]}},ve.hsv.hsl=function(t){var e,i,n,r=t[0],o=t[1]/100,s=t[2]/100,a=Math.max(s,.01);return n=(2-o)*s,i=o*a,[r,100*(i=(i/=(e=(2-o)*a)<=1?e:2-e)||0),100*(n/=2)]},ve.hwb.rgb=function(t){var e,i,n,r,o,s,a,l=t[0]/360,u=t[1]/100,c=t[2]/100,h=u+c;switch(h>1&&(u/=h,c/=h),n=6*l-(e=Math.floor(6*l)),0!=(1&e)&&(n=1-n),r=u+n*((i=1-c)-u),e){default:case 6:case 0:o=i,s=r,a=u;break;case 1:o=r,s=i,a=u;break;case 2:o=u,s=i,a=r;break;case 3:o=u,s=r,a=i;break;case 4:o=r,s=u,a=i;break;case 5:o=i,s=u,a=r}return[255*o,255*s,255*a]},ve.cmyk.rgb=function(t){var e=t[0]/100,i=t[1]/100,n=t[2]/100,r=t[3]/100;return[255*(1-Math.min(1,e*(1-r)+r)),255*(1-Math.min(1,i*(1-r)+r)),255*(1-Math.min(1,n*(1-r)+r))]},ve.xyz.rgb=function(t){var e,i,n,r=t[0]/100,o=t[1]/100,s=t[2]/100;return i=-.9689*r+1.8758*o+.0415*s,n=.0557*r+-.204*o+1.057*s,e=(e=3.2406*r+-1.5372*o+-.4986*s)>.0031308?1.055*Math.pow(e,1/2.4)-.055:12.92*e,i=i>.0031308?1.055*Math.pow(i,1/2.4)-.055:12.92*i,n=n>.0031308?1.055*Math.pow(n,1/2.4)-.055:12.92*n,[255*(e=Math.min(Math.max(0,e),1)),255*(i=Math.min(Math.max(0,i),1)),255*(n=Math.min(Math.max(0,n),1))]},ve.xyz.lab=function(t){var e=t[0],i=t[1],n=t[2];return i/=100,n/=108.883,e=(e/=95.047)>.008856?Math.pow(e,1/3):7.787*e+16/116,[116*(i=i>.008856?Math.pow(i,1/3):7.787*i+16/116)-16,500*(e-i),200*(i-(n=n>.008856?Math.pow(n,1/3):7.787*n+16/116))]},ve.lab.xyz=function(t){var e,i,n,r=t[0];e=t[1]/500+(i=(r+16)/116),n=i-t[2]/200;var o=Math.pow(i,3),s=Math.pow(e,3),a=Math.pow(n,3);return i=o>.008856?o:(i-16/116)/7.787,e=s>.008856?s:(e-16/116)/7.787,n=a>.008856?a:(n-16/116)/7.787,[e*=95.047,i*=100,n*=108.883]},ve.lab.lch=function(t){var e,i=t[0],n=t[1],r=t[2];return(e=360*Math.atan2(r,n)/2/Math.PI)<0&&(e+=360),[i,Math.sqrt(n*n+r*r),e]},ve.lch.lab=function(t){var e,i=t[0],n=t[1];return e=t[2]/360*2*Math.PI,[i,n*Math.cos(e),n*Math.sin(e)]},ve.rgb.ansi16=function(t){var e=t[0],i=t[1],n=t[2],r=1 in arguments?arguments[1]:ve.rgb.hsv(t)[2];if(0===(r=Math.round(r/50)))return 30;var o=30+(Math.round(n/255)<<2|Math.round(i/255)<<1|Math.round(e/255));return 2===r&&(o+=60),o},ve.hsv.ansi16=function(t){return ve.rgb.ansi16(ve.hsv.rgb(t),t[2])},ve.rgb.ansi256=function(t){var e=t[0],i=t[1],n=t[2];return e===i&&i===n?e<8?16:e>248?231:Math.round((e-8)/247*24)+232:16+36*Math.round(e/255*5)+6*Math.round(i/255*5)+Math.round(n/255*5)},ve.ansi16.rgb=function(t){var e=t%10;if(0===e||7===e)return t>50&&(e+=3.5),[e=e/10.5*255,e,e];var i=.5*(1+~~(t>50));return[(1&e)*i*255,(e>>1&1)*i*255,(e>>2&1)*i*255]},ve.ansi256.rgb=function(t){if(t>=232){var e=10*(t-232)+8;return[e,e,e]}var i;return t-=16,[Math.floor(t/36)/5*255,Math.floor((i=t%36)/6)/5*255,i%6/5*255]},ve.rgb.hex=function(t){var e=(((255&Math.round(t[0]))<<16)+((255&Math.round(t[1]))<<8)+(255&Math.round(t[2]))).toString(16).toUpperCase();return"000000".substring(e.length)+e},ve.hex.rgb=function(t){var e=t.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);if(!e)return[0,0,0];var i=e[0];3===e[0].length&&(i=i.split("").map((function(t){return t+t})).join(""));var n=parseInt(i,16);return[n>>16&255,n>>8&255,255&n]},ve.rgb.hcg=function(t){var e,i=t[0]/255,n=t[1]/255,r=t[2]/255,o=Math.max(Math.max(i,n),r),s=Math.min(Math.min(i,n),r),a=o-s;return e=a<=0?0:o===i?(n-r)/a%6:o===n?2+(r-i)/a:4+(i-n)/a+4,e/=6,[360*(e%=1),100*a,100*(a<1?s/(1-a):0)]},ve.hsl.hcg=function(t){var e=t[1]/100,i=t[2]/100,n=1,r=0;return(n=i<.5?2*e*i:2*e*(1-i))<1&&(r=(i-.5*n)/(1-n)),[t[0],100*n,100*r]},ve.hsv.hcg=function(t){var e=t[1]/100,i=t[2]/100,n=e*i,r=0;return n<1&&(r=(i-n)/(1-n)),[t[0],100*n,100*r]},ve.hcg.rgb=function(t){var e=t[0]/360,i=t[1]/100,n=t[2]/100;if(0===i)return[255*n,255*n,255*n];var r,o=[0,0,0],s=e%1*6,a=s%1,l=1-a;switch(Math.floor(s)){case 0:o[0]=1,o[1]=a,o[2]=0;break;case 1:o[0]=l,o[1]=1,o[2]=0;break;case 2:o[0]=0,o[1]=1,o[2]=a;break;case 3:o[0]=0,o[1]=l,o[2]=1;break;case 4:o[0]=a,o[1]=0,o[2]=1;break;default:o[0]=1,o[1]=0,o[2]=l}return r=(1-i)*n,[255*(i*o[0]+r),255*(i*o[1]+r),255*(i*o[2]+r)]},ve.hcg.hsv=function(t){var e=t[1]/100,i=e+t[2]/100*(1-e),n=0;return i>0&&(n=e/i),[t[0],100*n,100*i]},ve.hcg.hsl=function(t){var e=t[1]/100,i=t[2]/100*(1-e)+.5*e,n=0;return i>0&&i<.5?n=e/(2*i):i>=.5&&i<1&&(n=e/(2*(1-i))),[t[0],100*n,100*i]},ve.hcg.hwb=function(t){var e=t[1]/100,i=e+t[2]/100*(1-e);return[t[0],100*(i-e),100*(1-i)]},ve.hwb.hcg=function(t){var e=t[1]/100,i=1-t[2]/100,n=i-e,r=0;return n<1&&(r=(i-n)/(1-n)),[t[0],100*n,100*r]},ve.apple.rgb=function(t){return[t[0]/65535*255,t[1]/65535*255,t[2]/65535*255]},ve.rgb.apple=function(t){return[t[0]/255*65535,t[1]/255*65535,t[2]/255*65535]},ve.gray.rgb=function(t){return[t[0]/100*255,t[0]/100*255,t[0]/100*255]},ve.gray.hsl=ve.gray.hsv=function(t){return[0,0,t[0]]},ve.gray.hwb=function(t){return[0,100,t[0]]},ve.gray.cmyk=function(t){return[0,0,0,t[0]]},ve.gray.lab=function(t){return[t[0],0,0]},ve.gray.hex=function(t){var e=255&Math.round(t[0]/100*255),i=((e<<16)+(e<<8)+e).toString(16).toUpperCase();return"000000".substring(i.length)+i},ve.rgb.gray=function(t){return[(t[0]+t[1]+t[2])/3/255*100]};var je=me.exports;function Ae(t){var e=function(){for(var t={},e=Object.keys(je),i=e.length,n=0;n<i;n++)t[e[n]]={distance:-1,parent:null};return t}(),i=[t];for(e[t].distance=0;i.length;)for(var n=i.pop(),r=Object.keys(je[n]),o=r.length,s=0;s<o;s++){var a=r[s],l=e[a];-1===l.distance&&(l.distance=e[n].distance+1,l.parent=n,i.unshift(a))}return e}function Fe(t,e){return function(i){return e(t(i))}}function Te(t,e){for(var i=[e[t].parent,t],n=je[e[t].parent][t],r=e[t].parent;e[r].parent;)i.unshift(e[r].parent),n=Fe(je[e[r].parent][r],n),r=e[r].parent;return n.conversion=i,n}var ze=me.exports,Se=function(t){for(var e=Ae(t),i={},n=Object.keys(e),r=n.length,o=0;o<r;o++){var s=n[o];null!==e[s].parent&&(i[s]=Te(s,e))}return i},_e={};Object.keys(ze).forEach((function(t){_e[t]={},Object.defineProperty(_e[t],"channels",{value:ze[t].channels}),Object.defineProperty(_e[t],"labels",{value:ze[t].labels});var e=Se(t);Object.keys(e).forEach((function(i){var n=e[i];_e[t][i]=function(t){var e=function(e){if(null==e)return e;arguments.length>1&&(e=Array.prototype.slice.call(arguments));var i=t(e);if("object"==typeof i)for(var n=i.length,r=0;r<n;r++)i[r]=Math.round(i[r]);return i};return"conversion"in t&&(e.conversion=t.conversion),e}(n),_e[t][i].raw=function(t){var e=function(e){return null==e?e:(arguments.length>1&&(e=Array.prototype.slice.call(arguments)),t(e))};return"conversion"in t&&(e.conversion=t.conversion),e}(n)}))}));var Pe=_e,Ie=te.exports,Oe=Pe,Ee=[].slice,qe=["keyword","gray","hex"],Re={};Object.keys(Oe).forEach((function(t){Re[Ee.call(Oe[t].labels).sort().join("")]=t}));var Ce={};function Ne(t,e){if(!(this instanceof Ne))return new Ne(t,e);if(e&&e in qe&&(e=null),e&&!(e in Oe))throw new Error("Unknown model: "+e);var i,n;if(null==t)this.model="rgb",this.color=[0,0,0],this.valpha=1;else if(t instanceof Ne)this.model=t.model,this.color=t.color.slice(),this.valpha=t.valpha;else if("string"==typeof t){var r=Ie.get(t);if(null===r)throw new Error("Unable to parse color from string: "+t);this.model=r.model,n=Oe[this.model].channels,this.color=r.value.slice(0,n),this.valpha="number"==typeof r.value[n]?r.value[n]:1}else if(t.length){this.model=e||"rgb",n=Oe[this.model].channels;var o=Ee.call(t,0,n);this.color=$e(o,n),this.valpha="number"==typeof t[n]?t[n]:1}else if("number"==typeof t)t&=16777215,this.model="rgb",this.color=[t>>16&255,t>>8&255,255&t],this.valpha=1;else{this.valpha=1;var s=Object.keys(t);"alpha"in t&&(s.splice(s.indexOf("alpha"),1),this.valpha="number"==typeof t.alpha?t.alpha:0);var a=s.sort().join("");if(!(a in Re))throw new Error("Unable to parse color from object: "+JSON.stringify(t));this.model=Re[a];var l=Oe[this.model].labels,u=[];for(i=0;i<l.length;i++)u.push(t[l[i]]);this.color=$e(u)}if(Ce[this.model])for(n=Oe[this.model].channels,i=0;i<n;i++){var c=Ce[this.model][i];c&&(this.color[i]=c(this.color[i]))}this.valpha=Math.max(0,Math.min(1,this.valpha)),Object.freeze&&Object.freeze(this)}function Le(t,e,i){return(t=Array.isArray(t)?t:[t]).forEach((function(t){(Ce[t]||(Ce[t]=[]))[e]=i})),t=t[0],function(n){var r;return arguments.length?(i&&(n=i(n)),(r=this[t]()).color[e]=n,r):(r=this[t]().color[e],i&&(r=i(r)),r)}}function De(t){return function(e){return Math.max(0,Math.min(t,e))}}function Ue(t){return Array.isArray(t)?t:[t]}function $e(t,e){for(var i=0;i<e;i++)"number"!=typeof t[i]&&(t[i]=0);return t}Ne.prototype={toString:function(){return this.string()},toJSON:function(){return this[this.model]()},string:function(t){var e=this.model in Ie.to?this:this.rgb(),i=1===(e=e.round("number"==typeof t?t:1)).valpha?e.color:e.color.concat(this.valpha);return Ie.to[e.model](i)},percentString:function(t){var e=this.rgb().round("number"==typeof t?t:1),i=1===e.valpha?e.color:e.color.concat(this.valpha);return Ie.to.rgb.percent(i)},array:function(){return 1===this.valpha?this.color.slice():this.color.concat(this.valpha)},object:function(){for(var t={},e=Oe[this.model].channels,i=Oe[this.model].labels,n=0;n<e;n++)t[i[n]]=this.color[n];return 1!==this.valpha&&(t.alpha=this.valpha),t},unitArray:function(){var t=this.rgb().color;return t[0]/=255,t[1]/=255,t[2]/=255,1!==this.valpha&&t.push(this.valpha),t},unitObject:function(){var t=this.rgb().object();return t.r/=255,t.g/=255,t.b/=255,1!==this.valpha&&(t.alpha=this.valpha),t},round:function(t){return t=Math.max(t||0,0),new Ne(this.color.map(function(t){return function(e){return function(t,e){return Number(t.toFixed(e))}(e,t)}}(t)).concat(this.valpha),this.model)},alpha:function(t){return arguments.length?new Ne(this.color.concat(Math.max(0,Math.min(1,t))),this.model):this.valpha},red:Le("rgb",0,De(255)),green:Le("rgb",1,De(255)),blue:Le("rgb",2,De(255)),hue:Le(["hsl","hsv","hsl","hwb","hcg"],0,(function(t){return(t%360+360)%360})),saturationl:Le("hsl",1,De(100)),lightness:Le("hsl",2,De(100)),saturationv:Le("hsv",1,De(100)),value:Le("hsv",2,De(100)),chroma:Le("hcg",1,De(100)),gray:Le("hcg",2,De(100)),white:Le("hwb",1,De(100)),wblack:Le("hwb",2,De(100)),cyan:Le("cmyk",0,De(100)),magenta:Le("cmyk",1,De(100)),yellow:Le("cmyk",2,De(100)),black:Le("cmyk",3,De(100)),x:Le("xyz",0,De(100)),y:Le("xyz",1,De(100)),z:Le("xyz",2,De(100)),l:Le("lab",0,De(100)),a:Le("lab",1),b:Le("lab",2),keyword:function(t){return arguments.length?new Ne(t):Oe[this.model].keyword(this.color)},hex:function(t){return arguments.length?new Ne(t):Ie.to.hex(this.rgb().round().color)},rgbNumber:function(){var t=this.rgb().color;return(255&t[0])<<16|(255&t[1])<<8|255&t[2]},luminosity:function(){for(var t=this.rgb().color,e=[],i=0;i<t.length;i++){var n=t[i]/255;e[i]=n<=.03928?n/12.92:Math.pow((n+.055)/1.055,2.4)}return.2126*e[0]+.7152*e[1]+.0722*e[2]},contrast:function(t){var e=this.luminosity(),i=t.luminosity();return e>i?(e+.05)/(i+.05):(i+.05)/(e+.05)},level:function(t){var e=this.contrast(t);return e>=7.1?"AAA":e>=4.5?"AA":""},isDark:function(){var t=this.rgb().color;return(299*t[0]+587*t[1]+114*t[2])/1e3<128},isLight:function(){return!this.isDark()},negate:function(){for(var t=this.rgb(),e=0;e<3;e++)t.color[e]=255-t.color[e];return t},lighten:function(t){var e=this.hsl();return e.color[2]+=e.color[2]*t,e},darken:function(t){var e=this.hsl();return e.color[2]-=e.color[2]*t,e},saturate:function(t){var e=this.hsl();return e.color[1]+=e.color[1]*t,e},desaturate:function(t){var e=this.hsl();return e.color[1]-=e.color[1]*t,e},whiten:function(t){var e=this.hwb();return e.color[1]+=e.color[1]*t,e},blacken:function(t){var e=this.hwb();return e.color[2]+=e.color[2]*t,e},grayscale:function(){var t=this.rgb().color,e=.3*t[0]+.59*t[1]+.11*t[2];return Ne.rgb(e,e,e)},fade:function(t){return this.alpha(this.valpha-this.valpha*t)},opaquer:function(t){return this.alpha(this.valpha+this.valpha*t)},rotate:function(t){var e=this.hsl(),i=e.color[0];return i=(i=(i+t)%360)<0?360+i:i,e.color[0]=i,e},mix:function(t,e){if(!t||!t.rgb)throw new Error(\'Argument to "mix" was not a Color instance, but rather an instance of \'+typeof t);var i=t.rgb(),n=this.rgb(),r=void 0===e?.5:e,o=2*r-1,s=i.alpha()-n.alpha(),a=((o*s==-1?o:(o+s)/(1+o*s))+1)/2,l=1-a;return Ne.rgb(a*i.red()+l*n.red(),a*i.green()+l*n.green(),a*i.blue()+l*n.blue(),i.alpha()*r+n.alpha()*(1-r))}},Object.keys(Oe).forEach((function(t){if(-1===qe.indexOf(t)){var e=Oe[t].channels;Ne.prototype[t]=function(){if(this.model===t)return new Ne(this);if(arguments.length)return new Ne(arguments,t);var i="number"==typeof arguments[e]?e:this.valpha;return new Ne(Ue(Oe[this.model][t].raw(this.color)).concat(i),t)},Ne[t]=function(i){return"number"==typeof i&&(i=$e(Ee.call(arguments),e)),new Ne(i,t)}}}));var We=Ne;class Je{constructor(t,e){this.position=t,this.index=e,this.faces=[],this.neighbors=[]}addUniqueNeighbor(t){-1===this.neighbors.indexOf(t)&&this.neighbors.push(t)}}class He{constructor(t,e,i,n){this.a=n.a,this.b=n.b,this.c=n.c,this.v1=t,this.v2=e,this.v3=i,this.normal=[],this.computeNormal(),t.faces.push(this),t.addUniqueNeighbor(e),t.addUniqueNeighbor(i),e.faces.push(this),e.addUniqueNeighbor(t),e.addUniqueNeighbor(i),i.faces.push(this),i.addUniqueNeighbor(t),i.addUniqueNeighbor(e)}computeNormal(){const t=this.v1.position,e=this.v2.position,i=this.v3.position,n=gt([],bt([],i,e),bt([],t,e));mt(this.normal,n)}hasVertex(t){return t===this.v1||t===this.v2||t===this.v3}}\n/*!\n * Contains code from google filament\n * https://github.com/google/filament/\n * License Apache-2.0\n */const Ge=[],Ve=[],Be=[],Xe=[];function Ze(t,e,i){const n=gt(Ve,e,i);t=Mt(t,function(t,e,i,n,r,o,s,a,l,u){return t[0]=e,t[1]=i,t[2]=n,t[3]=r,t[4]=o,t[5]=s,t[6]=a,t[7]=l,t[8]=u,t}(Ge,i[0],i[1],i[2],...n,...e));if((t=function(t){return t[3]<0?At(t,t,-1):t}(t=Ft(t,t)))[3]<1/32767){t[3]=1/32767;const e=Math.sqrt(.9999999990686206);t[0]*=e,t[1]*=e,t[2]*=e}const r=i[3]>0?gt(Be,i,e):gt(Be,e,i);return yt(gt(Xe,i,e),r)<0&&At(t,t,-1),t}function Ye(t,e){const i=[],n=[];let r=0;for(r=0;r<t.length;r+=3){const e=new Je([t[r],t[r+1],t[r+2]],r/3);i.push(e)}if(!e.length){const t=e;e=[];for(let i=0;i<t;i++)e.push(i)}for(r=0;r<e.length/3;r++){const t={a:e[3*r],b:e[3*r+1],c:e[3*r+2]};new He(i[t.a],i[t.b],i[t.c],t)}const o=[],s=[0,0,0];for(r=0;r<i.length;r++){const t=i[r],e=t.index;dt(s,0,0,0);let a=t.faces.length;for(let e=0;e<a;e++)ft(s,s,t.faces[e].normal);a=a||1,dt(o,a,a,a),pt(s,s,o),n[3*e]=s[0],n[3*e+1]=s[1],n[3*e+2]=s[2]}return n}\n/*!\n * Contains code from THREE.JS\n * https://github.com/mrdoob/three.js/\n * License MIT\n * \n * Generate tangents per vertex.\n */function Ke(t,e,i){return t[0]=e[i],t[1]=e[i+1],t[2]=e[i+2],t}function Qe(t,e,i){return t[0]=e[i],t[1]=e[i+1],t}var ti={exports:{}};function ei(t,e,i){i=i||2;var n,r,o,s,a,l,u,c=e&&e.length,h=c?e[0]*i:t.length,d=ii(t,0,h,i,!0),f=[];if(!d||d.next===d.prev)return f;if(c&&(d=function(t,e,i,n){var r,o,s,a,l,u=[];for(r=0,o=e.length;r<o;r++)s=e[r]*n,a=r<o-1?e[r+1]*n:t.length,(l=ii(t,s,a,n,!1))===l.next&&(l.steiner=!0),u.push(fi(l));for(u.sort(ui),r=0;r<u.length;r++)i=ci(u[r],i);return i}(t,e,d,i)),t.length>80*i){n=o=t[0],r=s=t[1];for(var p=i;p<h;p+=i)(a=t[p])<n&&(n=a),(l=t[p+1])<r&&(r=l),a>o&&(o=a),l>s&&(s=l);u=0!==(u=Math.max(o-n,s-r))?32767/u:0}return ri(d,f,i,n,r,u,0),f}function ii(t,e,i,n,r){var o,s;if(r===Fi(t,e,i,n)>0)for(o=e;o<i;o+=n)s=Mi(o,t[o],t[o+1],s);else for(o=i-n;o>=e;o-=n)s=Mi(o,t[o],t[o+1],s);return s&&gi(s,s.next)&&(ji(s),s=s.next),s}function ni(t,e){if(!t)return t;e||(e=t);var i,n=t;do{if(i=!1,n.steiner||!gi(n,n.next)&&0!==yi(n.prev,n,n.next))n=n.next;else{if(ji(n),(n=e=n.prev)===n.next)break;i=!0}}while(i||n!==e);return e}function ri(t,e,i,n,r,o,s){if(t){!s&&o&&function(t,e,i,n){var r=t;do{0===r.z&&(r.z=di(r.x,r.y,e,i,n)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next}while(r!==t);r.prevZ.nextZ=null,r.prevZ=null,function(t){var e,i,n,r,o,s,a,l,u=1;do{for(i=t,t=null,o=null,s=0;i;){for(s++,n=i,a=0,e=0;e<u&&(a++,n=n.nextZ);e++);for(l=u;a>0||l>0&&n;)0!==a&&(0===l||!n||i.z<=n.z)?(r=i,i=i.nextZ,a--):(r=n,n=n.nextZ,l--),o?o.nextZ=r:t=r,r.prevZ=o,o=r;i=n}o.nextZ=null,u*=2}while(s>1)}(r)}(t,n,r,o);for(var a,l,u=t;t.prev!==t.next;)if(a=t.prev,l=t.next,o?si(t,n,r,o):oi(t))e.push(a.i/i|0),e.push(t.i/i|0),e.push(l.i/i|0),ji(t),t=l.next,u=l.next;else if((t=l)===u){s?1===s?ri(t=ai(ni(t),e,i),e,i,n,r,o,2):2===s&&li(t,e,i,n,r,o):ri(ni(t),e,i,n,r,o,1);break}}}function oi(t){var e=t.prev,i=t,n=t.next;if(yi(e,i,n)>=0)return!1;for(var r=e.x,o=i.x,s=n.x,a=e.y,l=i.y,u=n.y,c=r<o?r<s?r:s:o<s?o:s,h=a<l?a<u?a:u:l<u?l:u,d=r>o?r>s?r:s:o>s?o:s,f=a>l?a>u?a:u:l>u?l:u,p=n.next;p!==e;){if(p.x>=c&&p.x<=d&&p.y>=h&&p.y<=f&&pi(r,a,o,l,s,u,p.x,p.y)&&yi(p.prev,p,p.next)>=0)return!1;p=p.next}return!0}function si(t,e,i,n){var r=t.prev,o=t,s=t.next;if(yi(r,o,s)>=0)return!1;for(var a=r.x,l=o.x,u=s.x,c=r.y,h=o.y,d=s.y,f=a<l?a<u?a:u:l<u?l:u,p=c<h?c<d?c:d:h<d?h:d,m=a>l?a>u?a:u:l>u?l:u,y=c>h?c>d?c:d:h>d?h:d,g=di(f,p,e,i,n),b=di(m,y,e,i,n),v=t.prevZ,w=t.nextZ;v&&v.z>=g&&w&&w.z<=b;){if(v.x>=f&&v.x<=m&&v.y>=p&&v.y<=y&&v!==r&&v!==s&&pi(a,c,l,h,u,d,v.x,v.y)&&yi(v.prev,v,v.next)>=0)return!1;if(v=v.prevZ,w.x>=f&&w.x<=m&&w.y>=p&&w.y<=y&&w!==r&&w!==s&&pi(a,c,l,h,u,d,w.x,w.y)&&yi(w.prev,w,w.next)>=0)return!1;w=w.nextZ}for(;v&&v.z>=g;){if(v.x>=f&&v.x<=m&&v.y>=p&&v.y<=y&&v!==r&&v!==s&&pi(a,c,l,h,u,d,v.x,v.y)&&yi(v.prev,v,v.next)>=0)return!1;v=v.prevZ}for(;w&&w.z<=b;){if(w.x>=f&&w.x<=m&&w.y>=p&&w.y<=y&&w!==r&&w!==s&&pi(a,c,l,h,u,d,w.x,w.y)&&yi(w.prev,w,w.next)>=0)return!1;w=w.nextZ}return!0}function ai(t,e,i){var n=t;do{var r=n.prev,o=n.next.next;!gi(r,o)&&bi(r,n,n.next,o)&&xi(r,o)&&xi(o,r)&&(e.push(r.i/i|0),e.push(n.i/i|0),e.push(o.i/i|0),ji(n),ji(n.next),n=t=o),n=n.next}while(n!==t);return ni(n)}function li(t,e,i,n,r,o){var s=t;do{for(var a=s.next.next;a!==s.prev;){if(s.i!==a.i&&mi(s,a)){var l=ki(s,a);return s=ni(s,s.next),l=ni(l,l.next),ri(s,e,i,n,r,o,0),void ri(l,e,i,n,r,o,0)}a=a.next}s=s.next}while(s!==t)}function ui(t,e){return t.x-e.x}function ci(t,e){var i=function(t,e){var i,n=e,r=t.x,o=t.y,s=-1/0;do{if(o<=n.y&&o>=n.next.y&&n.next.y!==n.y){var a=n.x+(o-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(a<=r&&a>s&&(s=a,i=n.x<n.next.x?n:n.next,a===r))return i}n=n.next}while(n!==e);if(!i)return null;var l,u=i,c=i.x,h=i.y,d=1/0;n=i;do{r>=n.x&&n.x>=c&&r!==n.x&&pi(o<h?r:s,o,c,h,o<h?s:r,o,n.x,n.y)&&(l=Math.abs(o-n.y)/(r-n.x),xi(n,t)&&(l<d||l===d&&(n.x>i.x||n.x===i.x&&hi(i,n)))&&(i=n,d=l)),n=n.next}while(n!==u);return i}(t,e);if(!i)return e;var n=ki(i,t);return ni(n,n.next),ni(i,i.next)}function hi(t,e){return yi(t.prev,t,e.prev)<0&&yi(e.next,t,t.next)<0}function di(t,e,i,n,r){return(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-i)*r|0)|t<<8))|t<<4))|t<<2))|t<<1))|(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-n)*r|0)|e<<8))|e<<4))|e<<2))|e<<1))<<1}function fi(t){var e=t,i=t;do{(e.x<i.x||e.x===i.x&&e.y<i.y)&&(i=e),e=e.next}while(e!==t);return i}function pi(t,e,i,n,r,o,s,a){return(r-s)*(e-a)>=(t-s)*(o-a)&&(t-s)*(n-a)>=(i-s)*(e-a)&&(i-s)*(o-a)>=(r-s)*(n-a)}function mi(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!function(t,e){var i=t;do{if(i.i!==t.i&&i.next.i!==t.i&&i.i!==e.i&&i.next.i!==e.i&&bi(i,i.next,t,e))return!0;i=i.next}while(i!==t);return!1}(t,e)&&(xi(t,e)&&xi(e,t)&&function(t,e){var i=t,n=!1,r=(t.x+e.x)/2,o=(t.y+e.y)/2;do{i.y>o!=i.next.y>o&&i.next.y!==i.y&&r<(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x&&(n=!n),i=i.next}while(i!==t);return n}(t,e)&&(yi(t.prev,t,e.prev)||yi(t,e.prev,e))||gi(t,e)&&yi(t.prev,t,t.next)>0&&yi(e.prev,e,e.next)>0)}function yi(t,e,i){return(e.y-t.y)*(i.x-e.x)-(e.x-t.x)*(i.y-e.y)}function gi(t,e){return t.x===e.x&&t.y===e.y}function bi(t,e,i,n){var r=wi(yi(t,e,i)),o=wi(yi(t,e,n)),s=wi(yi(i,n,t)),a=wi(yi(i,n,e));return r!==o&&s!==a||(!(0!==r||!vi(t,i,e))||(!(0!==o||!vi(t,n,e))||(!(0!==s||!vi(i,t,n))||!(0!==a||!vi(i,e,n)))))}function vi(t,e,i){return e.x<=Math.max(t.x,i.x)&&e.x>=Math.min(t.x,i.x)&&e.y<=Math.max(t.y,i.y)&&e.y>=Math.min(t.y,i.y)}function wi(t){return t>0?1:t<0?-1:0}function xi(t,e){return yi(t.prev,t,t.next)<0?yi(t,e,t.next)>=0&&yi(t,t.prev,e)>=0:yi(t,e,t.prev)<0||yi(t,t.next,e)<0}function ki(t,e){var i=new Ai(t.i,t.x,t.y),n=new Ai(e.i,e.x,e.y),r=t.next,o=e.prev;return t.next=e,e.prev=t,i.next=r,r.prev=i,n.next=i,i.prev=n,o.next=n,n.prev=o,n}function Mi(t,e,i,n){var r=new Ai(t,e,i);return n?(r.next=n.next,r.prev=n,n.next.prev=r,n.next=r):(r.prev=r,r.next=r),r}function ji(t){t.next.prev=t.prev,t.prev.next=t.next,t.prevZ&&(t.prevZ.nextZ=t.nextZ),t.nextZ&&(t.nextZ.prevZ=t.prevZ)}function Ai(t,e,i){this.i=t,this.x=e,this.y=i,this.prev=null,this.next=null,this.z=0,this.prevZ=null,this.nextZ=null,this.steiner=!1}function Fi(t,e,i,n){for(var r=0,o=e,s=i-n;o<i;o+=n)r+=(t[s]-t[o])*(t[o+1]+t[s+1]),s=o;return r}ti.exports=ei,ti.exports.default=ei,ei.deviation=function(t,e,i,n){var r=e&&e.length,o=r?e[0]*i:t.length,s=Math.abs(Fi(t,0,o,i));if(r)for(var a=0,l=e.length;a<l;a++){var u=e[a]*i,c=a<l-1?e[a+1]*i:t.length;s-=Math.abs(Fi(t,u,c,i))}var h=0;for(a=0;a<n.length;a+=3){var d=n[a]*i,f=n[a+1]*i,p=n[a+2]*i;h+=Math.abs((t[d]-t[p])*(t[f+1]-t[d+1])-(t[d]-t[f])*(t[p+1]-t[d+1]))}return 0===s&&0===h?0:Math.abs((h-s)/s)},ei.flatten=function(t){for(var e=t[0][0].length,i={vertices:[],holes:[],dimensions:e},n=0,r=0;r<t.length;r++){for(var o=0;o<t[r].length;o++)for(var s=0;s<e;s++)i.vertices.push(t[r][o][s]);r>0&&(n+=t[r-1].length,i.holes.push(n))}return i};var Ti=ti.exports;\n/*!\n * @maptalks/vector-packer v0.72.5\n * LICENSE : UNLICENSED\n * (c) 2016-2022 maptalks.com\n */const zi={Point:1,LineString:2,Polygon:3,MultiPoint:4,MultiLineString:5,MultiPolygon:6};function Si(t,e={}){var i=[];if("FeatureCollection"===t.type)for(var n=0;n<t.features.length;n++)_i(i,t.features[n],e,n);else _i(i,"Feature"===t.type?t:{geometry:t},e);return i}function _i(t,e,i,n){if(e.geometry&&e.geometry.geometry){var r=e.geometry.coordinates,o=e.geometry.type,s=[],a=e.id;if(i.promoteId?a=e.properties[i.promoteId]:i.generateId&&(a=n||0),"Point"===o)Pi(r,s);else if("MultiPoint"===o)for(var l=0;l<r.length;l++)Pi(r[l],s);else if("LineString"===o)Oi([r],s);else if("MultiLineString"===o){if(i.lineMetrics){for(l=0;l<r.length;l++)Ii(r[l],s=[]),t.push(Ei(a,"LineString",s,e.properties));return}Oi(r,s)}else if("Polygon"===o)Oi(r,s);else{if("MultiPolygon"!==o){if("GeometryCollection"===o){for(l=0;l<e.geometry.geometries.length;l++)_i(t,{id:a,geometry:e.geometry.geometries[l],properties:e.properties},i,n);return}return void console.warn(`Input data type(${o}) is not a valid GeoJSON geometry type.`)}for(l=0;l<r.length;l++){var u=[];Oi(r[l],u),s.push(u)}}t.push(Ei(a,o,s,e.properties))}}function Pi(t,e){const i=new Ot(t[0],t[1]);i.z=100*(t[2]||0),e.push([i])}function Ii(t,e){for(let i=0;i<t.length;i++){const n=new Ot(t[i][0],t[i][1]);n.z=100*(t[i][2]||0),e.push(n)}}function Oi(t,e,i,n){for(var r=0;r<t.length;r++){var o=[];Ii(t[r],o),e.push(o)}}function Ei(t,e,i,n){return{id:void 0===t?null:t,type:zi[e],geometry:i,properties:n}}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n */function qi(t,{width:e,height:i},n,r){if(r){if(r.length!==e*i*n)throw new RangeError("mismatched image size")}else r=new Uint8Array(e*i*n);return t.width=e,t.height=i,t.data=r,t}function Ri(t,{width:e,height:i},n){if(e===t.width&&i===t.height)return;const r=qi({},{width:e,height:i},n);Ci(t,r,{x:0,y:0},{x:0,y:0},{width:Math.min(t.width,e),height:Math.min(t.height,i)},n),t.width=e,t.height=i,t.data=r.data}function Ci(t,e,i,n,r,o){if(0===r.width||0===r.height)return e;if(r.width>t.width||r.height>t.height||i.x>t.width-r.width||i.y>t.height-r.height)throw new RangeError("out of range source coordinates for image copy");if(r.width>e.width||r.height>e.height||n.x>e.width-r.width||n.y>e.height-r.height)throw new RangeError("out of range destination coordinates for image copy");const s=t.data,a=e.data;if(s===a)return e;for(let l=0;l<r.height;l++){const u=((i.y+l)*t.width+i.x)*o,c=((n.y+l)*e.width+n.x)*o;for(let t=0;t<r.width*o;t++)a[c+t]=s[u+t]}return e}class Ni{constructor(t,e){qi(this,t,1,e)}resize(t){Ri(this,t,1)}clone(){return new Ni({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(t,e,i,n,r){Ci(t,e,i,n,r,1)}}class Li{constructor(t,e){qi(this,t,4,e)}resize(t){Ri(this,t,4)}clone(){return new Li({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(t,e,i,n,r){Ci(t,e,i,n,r,4)}}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n */class Di{constructor(t,{pixelRatio:e}){this.paddedRect=t,this.pixelRatio=e||1}get tl(){return[this.paddedRect.x+1,this.paddedRect.y+1]}get br(){return[this.paddedRect.x+this.paddedRect.w-1,this.paddedRect.y+this.paddedRect.h-1]}get displaySize(){return[(this.paddedRect.w-2)/this.pixelRatio,(this.paddedRect.h-2)/this.pixelRatio]}}class Ui{constructor(t){this.glyphMap=t,this.build()}build(){const t=this.glyphMap,e={},i=new qt(0,0,{autoResize:!0}),n=[];for(const i in t){const r=t[i],o={x:0,y:0,w:r.data.width+2,h:r.data.height+2};n.push(o),e[i]=new Di(o,r)}if(i.pack(n,{inPlace:!0}),!$i(i.w)||!$i(i.h)){const t=Wi(i.w),e=Wi(i.h);i.resize(t,e)}const r=new Li({width:i.w,height:i.h});for(const i in t){const n=t[i],o=e[i].paddedRect;Li.copy(n.data,r,{x:0,y:0},{x:o.x+1,y:o.y+1},n.data)}this.image=r,this.positions=e}}function $i(t){return 0==(t&t-1)&&0!==t}function Wi(t){return Math.pow(2,Math.ceil(Math.log(t)/Math.LN2))}\n/*!\n * Codes from mapbox-gl-js\n * github.com/mapbox/mapbox-gl-js\n * MIT License\n * TODO 升级为potpack\n */class Ji{constructor(t){this.glyphMap=t,this.build()}build(){const t=this.glyphMap,e={},i=new qt(0,0,{autoResize:!0}),n=[];for(const i in t){const r=t[i],o=e[i]={};for(const t in r){const e=r[+t];if(!e||0===e.bitmap.width||0===e.bitmap.height)continue;const i={x:0,y:0,w:e.bitmap.width+2,h:e.bitmap.height+2};n.push(i),o[t]={rect:i,metrics:e.metrics}}}i.pack(n,{inPlace:!0});const r=new Ni({width:i.w,height:i.h});for(const i in t){const n=t[i];for(const t in n){const o=n[+t];if(!o||0===o.bitmap.width||0===o.bitmap.height)continue;const s=e[i][t].rect;Ni.copy(o.bitmap,r,{x:0,y:0},{x:s.x+1,y:s.y+1},o.bitmap)}}this.image=r,this.positions=e}}function Hi(t){return t<65536?Uint16Array:Uint32Array}function Gi(t){return(t=Math.abs(t))<128?Int8Array:t<32768?Int16Array:Float32Array}function Vi(t){return t<256?Uint8Array:t<65536?Uint16Array:Float32Array}function Bi(t){const e=t.type,i=[];if(1===e||4===e)for(let e=0;e<t.geometry.length;e++)Pi(t.geometry[e],i);else if(2===e)Oi(t.geometry,i);else if(3===e)Oi(t.geometry,i);else if(5===e)Oi(t.geometry,i);else if(6===e)for(let e=0;e<t.geometry.length;e++){const n=[];Oi(t.geometry[e],n),i.push(n)}return t.geometry=i,t}function Xi(t){for(let e=1;e<arguments.length;e++){const i=arguments[e];for(const e in i)t[e]=i[e]}return t}function Zi(t){return null==t}function Yi(t){return"number"==typeof t&&!isNaN(t)}function Ki(t){return"object"==typeof t&&!!t}function Qi(t){return!Zi(t)&&("string"==typeof t||null!==t.constructor&&t.constructor===String)}function tn(t){return!Zi(t)&&("function"==typeof t||null!==t.constructor&&t.constructor===Function)}const en=Object.prototype.hasOwnProperty;function nn(t,e){return en.call(t,e)}const rn=Math.PI/180;function on(t){return t&&s(t)&&t.property}function sn(t){const{pointAtTileRes:e,tileRatio:i}=t;return e*i}function an(t){return"centimeter"===t||"cm"===t?1:"millimeter"===t||"mm"===t?.1:100}function ln(t){let e=0;for(let i,n,r=0,o=t.length,s=o-1;r<o;s=r++)i=t[r],n=t[s],e+=void 0!==i.x?(n.x-i.x)*(i.y+n.y):(n[0]-i[0])*(i[1]+n[1]);return e}function un(t,e,i,n,r){const o=t[e*n],s=t[e*n+1],a=t[i*n],l=t[i*n+1];return o===a&&(o<0||o>r)&&s!==l||s===l&&(s<0||s>r)&&o!==a}function cn(t,e,i){let n=i;return e&&t&&(n=t[e]),void 0===n&&(n=i),100*(n||0)}function hn(t,e,i,n,r,o,s){e||0===e||(e=1);const a=cn(t.properties,i,n),l=a*e;let u=a;return r?u=cn(t.properties,r,o):s&&(u=a-cn(t.properties,s,0)),u*=e,{altitude:l,height:u}}function dn(t,e){return e<1/0&&(t.x<0||t.x>e||t.y<0||t.y>e)}function fn(t){return null==t}function pn(t,e,i){if(t===i||t===e)return t;const n=i-e;return((t-e)%n+n)%n+e}Object.freeze({__proto__:null,now:function(){return Date.now()},extend:Xi,isNil:Zi,isNumber:Yi,isInteger:function(t){return(0|t)===t},isObject:Ki,isString:Qi,isFunction:tn,hasOwn:nn,join:function(t,e){return t.join?t.join(e||","):Array.prototype.join.call(t,e||",")},toRadian:function(t){return t*rn},toDegree:function(t){return t/rn},evaluate:function(t,e,i){return tn(t)?t(void 0!==i?i:null,e):t},isFnTypeSymbol:on,getAltitudeToLocal:sn,getTubeSizeScale:an});class mn{constructor(t,e,i,n){this.feature=t,this.symbol=e,this.fnTypes=i,this.options=n}getPolygonResource(){let t=this.symbol.polygonPatternFile;const{polygonPatternFileFn:e}=this.fnTypes;return this.q(t,e)}getLineResource(){let t=this.symbol.linePatternFile;const{linePatternFileFn:e}=this.fnTypes;return this.q(t,e)}q(t,e){return e&&(t=e(this.options.zoom,this.feature.properties)),t}}function yn(t,e,i,n){const r=Math.abs(n)>>15,o=r>>1,s=r%2;let a=n%Math.pow(2,15);const l=e+(o<<14)*Math.sign(e),u=i+(s<<14)*Math.sign(i);return t[0]=l,t[1]=u,a=Math.round(a),t[2]=0===a?n<0?-1:0:a,t}const gn=Math.pow(2,14),bn=Math.pow(2,15);var vn={$version:8,$root:{version:{required:!0,type:"enum",values:[8],doc:"Style specification version number. Must be 8.",example:8},name:{type:"string",doc:"A human-readable name for the style.",example:"Bright"},metadata:{type:"*",doc:"Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},center:{type:"array",value:"number",doc:"Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:[-73.9749,40.7736]},zoom:{type:"number",doc:"Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:12.5},bearing:{type:"number",default:0,period:360,units:"degrees",doc:\'Default bearing, in degrees. The bearing is the compass direction that is "up"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\',example:29},pitch:{type:"number",default:0,units:"degrees",doc:"Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).",example:50},light:{type:"light",doc:"The global light source.",example:{anchor:"viewport",color:"white",intensity:.4}},terrain:{type:"terrain",doc:"A global modifier that elevates layers and markers based on a DEM data source."},fog:{type:"fog",doc:"A global effect that fades layers and markers based on their distance to the camera. The fog can be used to approximate the effect of atmosphere on distant objects and enhance the depth perception of the map when used with terrain or 3D features."},sources:{required:!0,type:"sources",doc:"Data source specifications.",example:{"mapbox-streets":{type:"vector",url:"mapbox://mapbox.mapbox-streets-v6"}}},sprite:{type:"string",doc:"A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",example:"mapbox://sprites/mapbox/bright-v8"},glyphs:{type:"string",doc:"A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).",example:"mapbox://fonts/mapbox/{fontstack}/{range}.pbf"},transition:{type:"transition",doc:"A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style\'s `transition` property.",example:{duration:300,delay:0}},projection:{type:"projection",doc:"The projection the map should be rendered in. Supported projections are Albers, Equal Earth, Equirectangular (WGS84), Lambert conformal conic, Mercator, Natural Earth, and Winkel Tripel. Terrain, fog, sky and CustomLayerInterface are not supported for projections other than mercator.",example:{name:"albers",center:[-154,50],parallels:[55,65]}},layers:{required:!0,type:"array",value:"layer",doc:"Layers will be drawn in the order of this array.",example:[{id:"water",source:"mapbox-streets","source-layer":"water",type:"fill",paint:{"fill-color":"#00ffff"}}]}},sources:{"*":{type:"source",doc:"Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided."}},source:["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],source_vector:{type:{required:!0,type:"enum",values:{vector:{doc:"A vector tile source."}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},scheme:{type:"enum",values:{xyz:{doc:"Slippy map tilenames scheme."},tms:{doc:"OSGeo spec scheme."}},default:"xyz",doc:"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},promoteId:{type:"promoteId",doc:"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{<sourceLayer>: <propertyName>}`. If specified as a string for a vector tile source, the same property is used across all its source layers."},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_raster:{type:{required:!0,type:"enum",values:{raster:{doc:"A raster tile source."}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},tileSize:{type:"number",default:512,units:"pixels",doc:"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},scheme:{type:"enum",values:{xyz:{doc:"Slippy map tilenames scheme."},tms:{doc:"OSGeo spec scheme."}},default:"xyz",doc:"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_raster_dem:{type:{required:!0,type:"enum",values:{"raster-dem":{doc:"A RGB-encoded raster DEM source"}},doc:"The type of the source."},url:{type:"string",doc:"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://<Tileset ID>`."},tiles:{type:"array",value:"string",doc:"An array of one or more tile source URLs, as in the TileJSON spec."},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129],doc:"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},minzoom:{type:"number",default:0,doc:"Minimum zoom level for which tiles are available, as in the TileJSON spec."},maxzoom:{type:"number",default:22,doc:"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},tileSize:{type:"number",default:512,units:"pixels",doc:"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},encoding:{type:"enum",values:{terrarium:{doc:"Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info."},mapbox:{doc:"Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info."}},default:"mapbox",doc:"The encoding used by this source. Mapbox Terrain RGB is used by default"},volatile:{type:"boolean",default:!1,doc:"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{android:"9.3.0",ios:"5.10.0"}}},"*":{type:"*",doc:"Other keys to configure the data source."}},source_geojson:{type:{required:!0,type:"enum",values:{geojson:{doc:"A GeoJSON data source."}},doc:"The data type of the GeoJSON source."},data:{type:"*",doc:"A URL to a GeoJSON file, or inline GeoJSON."},maxzoom:{type:"number",default:18,doc:"Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels)."},attribution:{type:"string",doc:"Contains an attribution to be displayed when the map is shown to a user."},buffer:{type:"number",default:128,maximum:512,minimum:0,doc:"Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance."},filter:{type:"*",doc:"An expression for filtering features prior to processing them for rendering."},tolerance:{type:"number",default:.375,doc:"Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance)."},cluster:{type:"boolean",default:!1,doc:"If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\\n * `cluster` Is `true` if the point is a cluster \\n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\\n * `point_count` Number of original points grouped into this cluster\\n * `point_count_abbreviated` An abbreviated point count"},clusterRadius:{type:"number",default:50,minimum:0,doc:"Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile."},clusterMaxZoom:{type:"number",doc:"Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered). Clusters are re-evaluated at integer zoom levels so setting clusterMaxZoom to 14 means the clusters will be displayed until z15."},clusterMinPoints:{type:"number",doc:"Minimum number of points necessary to form a cluster if clustering is enabled. Defaults to `2`."},clusterProperties:{type:"*",doc:\'An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{"property_name": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `"+"` or `"max"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\\n\\nExample: `{"sum": ["+", ["get", "scalerank"]]}`.\\n\\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `["accumulated"]` value, e.g.:\\n`{"sum": [["+", ["accumulated"], ["get", "sum"]], ["get", "scalerank"]]}`\'},lineMetrics:{type:"boolean",default:!1,doc:"Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values."},generateId:{type:"boolean",default:!1,doc:"Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values."},promoteId:{type:"promoteId",doc:"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{<sourceLayer>: <propertyName>}`."}},source_video:{type:{required:!0,type:"enum",values:{video:{doc:"A video data source."}},doc:"The data type of the video source."},urls:{required:!0,type:"array",value:"string",doc:"URLs to video content in order of preferred format."},coordinates:{required:!0,doc:"Corners of video specified in longitude, latitude pairs.",type:"array",length:4,value:{type:"array",length:2,value:"number",doc:"A single longitude, latitude pair."}}},source_image:{type:{required:!0,type:"enum",values:{image:{doc:"An image data source."}},doc:"The data type of the image source."},url:{required:!0,type:"string",doc:"URL that points to an image."},coordinates:{required:!0,doc:"Corners of image specified in longitude, latitude pairs.",type:"array",length:4,value:{type:"array",length:2,value:"number",doc:"A single longitude, latitude pair."}}},layer:{id:{type:"string",doc:"Unique layer name.",required:!0},type:{type:"enum",values:{fill:{doc:"A filled polygon with an optional stroked border.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},line:{doc:"A stroked line.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},symbol:{doc:"An icon or a text label.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},circle:{doc:"A filled circle.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},heatmap:{doc:"A heatmap.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"fill-extrusion":{doc:"An extruded (3D) polygon.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},raster:{doc:"Raster map textures such as satellite imagery.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},hillshade:{doc:"Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},background:{doc:"The background color or pattern of the map.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}}},sky:{doc:"A spherical dome around the map that is always rendered behind all other layers.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}}},doc:"Rendering type of this layer.",required:!0},metadata:{type:"*",doc:"Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},source:{type:"string",doc:"Name of a source description to be used for this layer. Required for all layer types except `background`."},"source-layer":{type:"string",doc:"Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources."},minzoom:{type:"number",minimum:0,maximum:24,doc:"The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden."},maxzoom:{type:"number",minimum:0,maximum:24,doc:"The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden."},filter:{type:"filter",doc:\'An expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `["feature-state", ...]` expression is not supported in filter expressions. The `["pitch"]` and `["distance-from-center"]` expressions are supported only for filter expressions on the symbol layer.\'},layout:{type:"layout",doc:"Layout properties for the layer."},paint:{type:"paint",doc:"Default paint properties for this layer."}},layout:["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],layout_background:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_sky:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"constant"}},layout_fill:{"fill-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"},"data-driven styling":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_circle:{"circle-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.2.0",ios:"5.9.0",macos:"0.16.0"},"data-driven styling":{js:"1.2.0",android:"9.2.0",ios:"5.9.0",macos:"0.16.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_heatmap:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},"property-type":"constant"}},"layout_fill-extrusion":{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},"property-type":"constant"}},layout_line:{"line-cap":{type:"enum",values:{butt:{doc:"A cap with a squared-off end which is drawn to the exact endpoint of the line."},round:{doc:"A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},square:{doc:"A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."}},default:"butt",doc:"The display of line endings.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-join":{type:"enum",values:{bevel:{doc:"A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."},round:{doc:"A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},miter:{doc:"A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet."}},default:"miter",doc:"The display of lines when joining.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{type:"number",default:2,doc:"Used to automatically convert miter joins to bevel joins for sharp angles.",requires:[{"line-join":"miter"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-round-limit":{type:"number",default:1.05,doc:"Used to automatically convert round joins to miter joins for shallow angles.",requires:[{"line-join":"round"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"},"data-driven styling":{js:"1.2.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_symbol:{"symbol-placement":{type:"enum",values:{point:{doc:"The label is placed at the point where the geometry is located."},line:{doc:"The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries."},"line-center":{doc:"The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries."}},default:"point",doc:"Label placement relative to its geometry.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`line-center` value":{js:"0.47.0",android:"6.4.0",ios:"4.3.0",macos:"0.10.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-spacing":{type:"number",default:250,minimum:1,units:"pixels",doc:"Distance between two symbol anchors.",requires:[{"symbol-placement":"line"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{type:"boolean",default:!1,doc:"If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don\'t have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer. When using a client that supports global collision detection, like Mapbox GL JS version 0.42.0 or greater, enabling this property is not needed to prevent clipped labels at tile boundaries.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{type:"number",doc:"Sorts features in ascending order based on this value. Features with lower sort keys are drawn and placed first. When `icon-allow-overlap` or `text-allow-overlap` is `false`, features with a lower sort key will have priority during placement. When `icon-allow-overlap` or `text-allow-overlap` is set to `true`, features with a higher sort key will overlap over features with a lower sort key.","sdk-support":{"basic functionality":{js:"0.53.0",android:"7.4.0",ios:"4.11.0",macos:"0.14.0"},"data-driven styling":{js:"0.53.0",android:"7.4.0",ios:"4.11.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{type:"enum",values:{auto:{doc:"Sorts symbols by `symbol-sort-key` if set. Otherwise, sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},"viewport-y":{doc:"Sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},source:{doc:"Sorts symbols by `symbol-sort-key` if set. Otherwise, no sorting is applied; symbols are rendered in the same order as the source data."}},default:"auto",doc:"Determines whether overlapping symbols in the same layer are rendered in the order that they appear in the data source or by their y-position relative to the viewport. To control the order and prioritization of symbols otherwise, use `symbol-sort-key`.","sdk-support":{"basic functionality":{js:"0.49.0",android:"6.6.0",ios:"4.5.0",macos:"0.12.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{type:"boolean",default:!1,doc:"If true, the icon will be visible even if it collides with other previously drawn symbols.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{type:"boolean",default:!1,doc:"If true, other symbols can be visible even if they collide with the icon.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-optional":{type:"boolean",default:!1,doc:"If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.",requires:["icon-image","text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{type:"enum",values:{map:{doc:"When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line."},viewport:{doc:"Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},auto:{doc:"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},default:"auto",doc:"In combination with `symbol-placement`, determines the rotation behavior of icons.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-size":{type:"number",default:1,minimum:0,units:"factor of the original icon size",doc:"Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{type:"enum",values:{none:{doc:"The icon is displayed at its intrinsic aspect ratio."},width:{doc:"The icon is scaled in the x-dimension to fit the width of the text."},height:{doc:"The icon is scaled in the y-dimension to fit the height of the text."},both:{doc:"The icon is scaled in both x- and y-dimensions."}},default:"none",doc:"Scales the icon to fit around the associated text.",requires:["icon-image","text-field"],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"},"stretchable icons":{js:"1.6.0",android:"9.2.0",ios:"5.8.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{type:"array",value:"number",length:4,default:[0,0,0,0],units:"pixels",doc:"Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.",requires:["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-image":{type:"resolvedImage",doc:"Name of image in sprite to use for drawing an image background.",tokens:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{type:"number",default:0,period:360,units:"degrees",doc:"Rotates the icon clockwise.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.21.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{type:"number",default:2,minimum:0,units:"pixels",doc:"Size of the additional area around the icon bounding box used for detecting symbol collisions.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{type:"boolean",default:!1,doc:"If true, the icon may be flipped to prevent it from being rendered upside-down.",requires:["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-offset":{type:"array",value:"number",length:2,default:[0,0],doc:"Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{type:"enum",values:{center:{doc:"The center of the icon is placed closest to the anchor."},left:{doc:"The left side of the icon is placed closest to the anchor."},right:{doc:"The right side of the icon is placed closest to the anchor."},top:{doc:"The top of the icon is placed closest to the anchor."},bottom:{doc:"The bottom of the icon is placed closest to the anchor."},"top-left":{doc:"The top left corner of the icon is placed closest to the anchor."},"top-right":{doc:"The top right corner of the icon is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the icon is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the icon is placed closest to the anchor."}},default:"center",doc:"Part of the icon placed closest to the anchor.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{type:"enum",values:{map:{doc:"The icon is aligned to the plane of the map."},viewport:{doc:"The icon is aligned to the plane of the viewport."},auto:{doc:"Automatically matches the value of `icon-rotation-alignment`."}},default:"auto",doc:"Orientation of icon when map is pitched.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{type:"enum",values:{map:{doc:"The text is aligned to the plane of the map."},viewport:{doc:"The text is aligned to the plane of the viewport."},auto:{doc:"Automatically matches the value of `text-rotation-alignment`."}},default:"auto",doc:"Orientation of text when map is pitched.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{type:"enum",values:{map:{doc:"When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line."},viewport:{doc:"Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},auto:{doc:"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},default:"auto",doc:"In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"`auto` value":{js:"0.25.0",android:"4.2.0",ios:"3.4.0",macos:"0.3.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-field":{type:"formatted",default:"",tokens:!0,doc:"Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options. SDF images are not supported in formatted text and will be ignored.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-font":{type:"array",value:"string",default:["Open Sans Regular","Arial Unicode MS Regular"],doc:"Font stack to use for displaying text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-size":{type:"number",default:16,minimum:0,units:"pixels",doc:"Font size.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{type:"number",default:10,minimum:0,units:"ems",doc:"The maximum line width for text wrapping.",requires:["text-field",{"symbol-placement":["point"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{type:"number",default:1.2,units:"ems",doc:"Text leading value for multi-line text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{type:"number",default:0,units:"ems",doc:"Text tracking amount.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.40.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-justify":{type:"enum",values:{auto:{doc:"The text is aligned towards the anchor position."},left:{doc:"The text is aligned to the left."},center:{doc:"The text is centered."},right:{doc:"The text is aligned to the right."}},default:"center",doc:"Text justification options.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"},auto:{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{type:"number",units:"ems",default:0,doc:"Radial offset of text, in the direction of the symbol\'s anchor. Useful in combination with `text-variable-anchor`, which defaults to using the two-dimensional `text-offset` if present.","sdk-support":{"basic functionality":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"},"data-driven styling":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},requires:["text-field"],"property-type":"data-driven",expression:{interpolated:!0,parameters:["zoom","feature"]}},"text-variable-anchor":{type:"array",value:"enum",values:{center:{doc:"The center of the text is placed closest to the anchor."},left:{doc:"The left side of the text is placed closest to the anchor."},right:{doc:"The right side of the text is placed closest to the anchor."},top:{doc:"The top of the text is placed closest to the anchor."},bottom:{doc:"The bottom of the text is placed closest to the anchor."},"top-left":{doc:"The top left corner of the text is placed closest to the anchor."},"top-right":{doc:"The top right corner of the text is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the text is placed closest to the anchor."}},requires:["text-field",{"symbol-placement":["point"]}],doc:"To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the renderer will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` or the two-dimensional `text-offset`.","sdk-support":{"basic functionality":{js:"0.54.0",android:"7.4.0",ios:"4.10.0",macos:"0.14.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-anchor":{type:"enum",values:{center:{doc:"The center of the text is placed closest to the anchor."},left:{doc:"The left side of the text is placed closest to the anchor."},right:{doc:"The right side of the text is placed closest to the anchor."},top:{doc:"The top of the text is placed closest to the anchor."},bottom:{doc:"The bottom of the text is placed closest to the anchor."},"top-left":{doc:"The top left corner of the text is placed closest to the anchor."},"top-right":{doc:"The top right corner of the text is placed closest to the anchor."},"bottom-left":{doc:"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{doc:"The bottom right corner of the text is placed closest to the anchor."}},default:"center",doc:"Part of the text placed closest to the anchor.",requires:["text-field",{"!":"text-variable-anchor"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{type:"number",default:45,units:"degrees",doc:"Maximum angle change between adjacent characters.",requires:["text-field",{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-writing-mode":{type:"array",value:"enum",values:{horizontal:{doc:"If a text\'s language supports horizontal writing mode, symbols would be laid out horizontally."},vertical:{doc:"If a text\'s language supports vertical writing mode, symbols would be laid out vertically."}},doc:"The property allows control over a symbol\'s orientation. Note that the property values act as a hint, so that a symbol whose language doesn’t support the provided orientation will be laid out in its natural orientation. Example: English point symbol will be rendered horizontally even if array value contains single \'vertical\' enum value. For symbol with point placement, the order of elements in an array define priority order for the placement of an orientation variant. For symbol with line placement, the default text writing mode is either [\'horizontal\', \'vertical\'] or [\'vertical\', \'horizontal\'], the order doesn\'t affect the placement.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"1.3.0",android:"8.3.0",ios:"5.3.0",macos:"0.15.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotate":{type:"number",default:0,period:360,units:"degrees",doc:"Rotates the text clockwise.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-padding":{type:"number",default:2,minimum:0,units:"pixels",doc:"Size of the additional area around the text bounding box used for detecting symbol collisions.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-keep-upright":{type:"boolean",default:!0,doc:"If true, the text may be flipped vertically to prevent it from being rendered upside-down.",requires:["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-transform":{type:"enum",values:{none:{doc:"The text is not altered."},uppercase:{doc:"Forces all letters to be displayed in uppercase."},lowercase:{doc:"Forces all letters to be displayed in lowercase."}},default:"none",doc:"Specifies how to capitalize text, similar to the CSS `text-transform` property.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-offset":{type:"array",doc:"Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up. If used with text-variable-anchor, input values will be taken as absolute values. Offsets along the x- and y-axis will be applied automatically based on the anchor position.",value:"number",units:"ems",length:2,default:[0,0],requires:["text-field",{"!":"text-radial-offset"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.35.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{type:"boolean",default:!1,doc:"If true, the text will be visible even if it collides with other previously drawn symbols.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{type:"boolean",default:!1,doc:"If true, other symbols can be visible even if they collide with the text.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-optional":{type:"boolean",default:!1,doc:"If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.",requires:["text-field","icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_raster:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},"property-type":"constant"}},layout_hillshade:{visibility:{type:"enum",values:{visible:{doc:"The layer is shown."},none:{doc:"The layer is not shown."}},default:"visible",doc:"Whether this layer is displayed.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},"property-type":"constant"}},filter:{type:"array",value:"*",doc:"A filter selects specific features from a layer."},filter_symbol:{type:"boolean",doc:\'Expression which determines whether or not to display a symbol. Symbols support dynamic filtering, meaning this expression can use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature","pitch","distance-from-center"]}},filter_fill:{type:"boolean",doc:\'Expression which determines whether or not to display a polygon. Fill layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_line:{type:"boolean",doc:\'Expression which determines whether or not to display a Polygon or LineString. Line layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_circle:{type:"boolean",doc:\'Expression which determines whether or not to display a circle. Circle layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},"filter_fill-extrusion":{type:"boolean",doc:\'Expression which determines whether or not to display a Polygon. Fill-extrusion layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_heatmap:{type:"boolean",doc:\'Expression used to determine whether a point is being displayed or not. Heatmap layer does NOT support dynamic filtering, meaning this expression can NOT use the `["pitch"]` and `["distance-from-center"]` expressions to reference the current state of the view.\',default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_operator:{type:"enum",values:{"==":{doc:\'`["==", key, value]` equality: `feature[key] = value`\'},"!=":{doc:\'`["!=", key, value]` inequality: `feature[key] ≠ value`\'},">":{doc:\'`[">", key, value]` greater than: `feature[key] > value`\'},">=":{doc:\'`[">=", key, value]` greater than or equal: `feature[key] ≥ value`\'},"<":{doc:\'`["<", key, value]` less than: `feature[key] < value`\'},"<=":{doc:\'`["<=", key, value]` less than or equal: `feature[key] ≤ value`\'},in:{doc:\'`["in", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`\'},"!in":{doc:\'`["!in", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`\'},all:{doc:\'`["all", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`\'},any:{doc:\'`["any", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`\'},none:{doc:\'`["none", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`\'},has:{doc:\'`["has", key]` `feature[key]` exists\'},"!has":{doc:\'`["!has", key]` `feature[key]` does not exist\'},within:{doc:\'`["within", object]` feature geometry is within object geometry\'}},doc:"The filter operator."},geometry_type:{type:"enum",values:{Point:{doc:"Filter to point geometries."},LineString:{doc:"Filter to line geometries."},Polygon:{doc:"Filter to polygon geometries."}},doc:"The geometry type for the filter to select."},function:{expression:{type:"expression",doc:"An expression."},stops:{type:"array",doc:"An array of stops.",value:"function_stop"},base:{type:"number",default:1,minimum:0,doc:"The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly."},property:{type:"string",doc:"The name of a feature property to use as the function input.",default:"$zoom"},type:{type:"enum",values:{identity:{doc:"Return the input value as the output value."},exponential:{doc:"Generate an output by interpolating between stops just less than and just greater than the function input."},interval:{doc:"Return the output value of the stop just less than the function input."},categorical:{doc:"Return the output value of the stop equal to the function input."}},doc:"The interpolation strategy to use in function evaluation.",default:"exponential"},colorSpace:{type:"enum",values:{rgb:{doc:"Use the RGB color space to interpolate color values"},lab:{doc:"Use the LAB color space to interpolate color values."},hcl:{doc:"Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually."}},doc:"The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.",default:"rgb"},default:{type:"*",required:!1,doc:"A value to serve as a fallback function result when a value isn\'t otherwise available. It is used in the following circumstances:\\n* In categorical functions, when the feature value does not match any of the stop domain values.\\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\\nIf no default is provided, the style property\'s default is used in these circumstances."}},function_stop:{type:"array",minimum:0,maximum:24,value:["number","color"],length:2,doc:"Zoom level and value pair."},expression:{type:"array",value:"*",minimum:1,doc:"An expression defines a function that can be used for data-driven style properties or feature filters."},expression_name:{doc:"",type:"enum",values:{let:{doc:\'Binds expressions to named variables, which can then be referenced in the result expression using ["var", "variable_name"].\',group:"Variable binding","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},var:{doc:\'References variable bound using "let".\',group:"Variable binding","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},literal:{doc:"Provides a literal array or object value.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},array:{doc:"Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},at:{doc:"Retrieves an item from an array.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},in:{doc:"Determines whether an item exists in an array or a substring exists in a string. In the specific case when the second and third arguments are string literals, you must wrap at least one of them in a [`literal`](#types-literal) expression to hint correct interpretation to the [type system](#type-system).",group:"Lookup","sdk-support":{"basic functionality":{js:"1.6.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}}},"index-of":{doc:"Returns the first position at which an item can be found in an array or a substring can be found in a string, or `-1` if the input cannot be found. Accepts an optional index from where to begin the search.",group:"Lookup","sdk-support":{"basic functionality":{js:"1.10.0"}}},slice:{doc:"Returns an item from an array or a substring from a string from a specified start index, or between a start index and an end index if set. The return value is inclusive of the start index but not of the end index.",group:"Lookup","sdk-support":{"basic functionality":{js:"1.10.0"}}},case:{doc:"Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},match:{doc:\'Selects the output for which the label value matches the input value, or the fallback value if no match is found. The input can be any expression (for example, `["get", "building_type"]`). Each label must be unique, and must be either:\\n - a single literal value; or\\n - an array of literal values, the values of which must be all strings or all numbers (for example `[100, 101]` or `["c", "b"]`).\\n\\nThe input matches if any of the values in the array matches using strict equality, similar to the `"in"` operator.\\nIf the input type does not match the type of the labels, the result will be the fallback value.\',group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},coalesce:{doc:"Evaluates each expression in turn until the first valid value is obtained. Invalid values are `null` and [`\'image\'`](#types-image) expressions that are unavailable in the style. If all values are invalid, `coalesce` returns the first value listed.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},step:{doc:\'Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first output if the input is less than the first stop.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},interpolate:{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). The `input` may be any numeric expression (e.g., `["get", "population"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array<number>`, or `color`.\\n\\nInterpolation types:\\n- `["linear"]`: Interpolates linearly between the pair of stops just less than and just greater than the input.\\n- `["exponential", base]`: Interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\\n- `["cubic-bezier", x1, y1, x2, y2]`: Interpolates using the cubic bezier curve defined by the given control points.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"interpolate-hcl":{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.49.0"}}},"interpolate-lab":{doc:\'Produces continuous, smooth results by interpolating between pairs of input and output values ("stops"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.\',group:"Ramps, scales, curves","sdk-support":{"basic functionality":{js:"0.49.0"}}},ln2:{doc:"Returns mathematical constant ln(2).",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},pi:{doc:"Returns the mathematical constant pi.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},e:{doc:"Returns the mathematical constant e.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},typeof:{doc:"Returns a string describing the type of the given value.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},string:{doc:"Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},number:{doc:"Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},boolean:{doc:"Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},object:{doc:"Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},collator:{doc:"Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.",group:"Types","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},format:{doc:\'Returns a `formatted` string for displaying mixed-format text in the `text-field` property. The input may contain a string literal or expression, including an [`\\\'image\\\'`](#types-image) expression. Strings may be followed by a style override object that supports the following properties:\\n- `"text-font"`: Overrides the font stack specified by the root layout property.\\n- `"text-color"`: Overrides the color specified by the root paint property.\\n- `"font-scale"`: Applies a scaling factor on `text-size` as specified by the root layout property.\',group:"Types","sdk-support":{"basic functionality":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"text-font":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"font-scale":{js:"0.48.0",android:"6.7.0",ios:"4.6.0",macos:"0.12.0"},"text-color":{js:"1.3.0",android:"7.3.0",ios:"4.10.0",macos:"0.14.0"},image:{js:"1.6.0",android:"8.6.0",ios:"5.7.0",macos:"0.15.0"}}},image:{doc:"Returns a [`ResolvedImage`](/mapbox-gl-js/style-spec/types/#resolvedimage) for use in [`icon-image`](/mapbox-gl-js/style-spec/layers/#layout-symbol-icon-image), `*-pattern` entries, and as a section in the [`\'format\'`](#types-format) expression. A [`\'coalesce\'`](#coalesce) expression containing `image` expressions will evaluate to the first listed image that is currently in the style. This validation process is synchronous and requires the image to have been added to the style before requesting it in the `\'image\'` argument.",group:"Types","sdk-support":{"basic functionality":{js:"1.4.0",android:"8.6.0",ios:"5.7.0",macos:"0.15.0"}}},"number-format":{doc:"Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.",group:"Types","sdk-support":{"basic functionality":{js:"0.54.0",android:"8.4.0",ios:"5.4.0",macos:"0.15.0"}}},"to-string":{doc:\'Converts the input value to a string. If the input is `null`, the result is `""`. If the input is a [`boolean`](#types-boolean), the result is `"true"` or `"false"`. If the input is a number, it is converted to a string as specified by the ["NumberToString" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a [`color`](#color), it is converted to a string of the form `"rgba(r,g,b,a)"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. If the input is an [`\\\'image\\\'`](#types-image) expression, `\\\'to-string\\\'` returns the image name. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.\',group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-number":{doc:\'Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the ["ToNumber Applied to the String Type" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\',group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-boolean":{doc:"Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-rgba":{doc:"Returns a four-element array containing the input color\'s red, green, blue, and alpha components, in that order.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"to-color":{doc:"Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.",group:"Types","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},rgb:{doc:"Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},rgba:{doc:"Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.",group:"Color","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},get:{doc:"Retrieves a property value from the current feature\'s properties, or from another object if a second argument is provided. Returns `null` if the requested property is missing.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},has:{doc:"Tests for the presence of an property value in the current feature\'s properties, or from another object if a second argument is provided.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},length:{doc:"Returns the length of an array or string.",group:"Lookup","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},properties:{doc:\'Returns the feature properties object. Note that in some cases, it may be more efficient to use `["get", "property_name"]` directly.\',group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"feature-state":{doc:"Retrieves a property value from the current feature\'s state. Returns `null` if the requested property is not present on the feature\'s state. A feature\'s state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Features are identified by their `id` attribute, which must be an integer or a string that can be cast to an integer. Note that [\\"feature-state\\"] can only be used with paint properties that support data-driven styling.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.46.0"}}},"geometry-type":{doc:"Returns the feature\'s geometry type: `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`. `Multi*` feature types are only returned in GeoJSON sources. When working with vector tile sources, use the singular forms.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},id:{doc:"Returns the feature\'s id, if it has one.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},zoom:{doc:\'Returns the current zoom level. Note that in style layout and paint properties, ["zoom"] may only appear as the input to a top-level "step" or "interpolate" expression.\',group:"Camera","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},pitch:{doc:\'Returns the current pitch in degrees. `["pitch"]` may only be used in the `filter` expression for a `symbol` layer.\',group:"Camera","sdk-support":{"basic functionality":{js:"2.6.0"}}},"distance-from-center":{doc:\'Returns the distance of a `symbol` instance from the center of the map. The distance is measured in pixels divided by the height of the map container. It measures 0 at the center, decreases towards the camera and increase away from the camera. For example, if the height of the map is 1000px, a value of -1 means 1000px away from the center towards the camera, and a value of 1 means a distance of 1000px away from the camera from the center. `["distance-from-center"]` may only be used in the `filter` expression for a `symbol` layer.\',group:"Camera","sdk-support":{"basic functionality":{js:"2.6.0"}}},"heatmap-density":{doc:"Returns the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.",group:"Heatmap","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"line-progress":{doc:"Returns the progress along a gradient line. Can only be used in the `line-gradient` property.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.6.0",macos:"0.12.0"}}},"sky-radial-progress":{doc:"Returns the distance of a point on the sky from the sun position. Returns 0 at sun position and 1 when the distance reaches `sky-gradient-radius`. Can only be used in the `sky-gradient` property.",group:"sky","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}},accumulated:{doc:"Returns the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.",group:"Feature data","sdk-support":{"basic functionality":{js:"0.53.0",android:"8.4.0",ios:"5.5.0",macos:"0.15.0"}}},"+":{doc:"Returns the sum of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"*":{doc:"Returns the product of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"-":{doc:"For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"/":{doc:"Returns the result of floating point division of the first input by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"%":{doc:"Returns the remainder after integer division of the first input by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"^":{doc:"Returns the result of raising the first input to the power specified by the second.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},sqrt:{doc:"Returns the square root of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.42.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},log10:{doc:"Returns the base-ten logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},ln:{doc:"Returns the natural logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},log2:{doc:"Returns the base-two logarithm of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},sin:{doc:"Returns the sine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},cos:{doc:"Returns the cosine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},tan:{doc:"Returns the tangent of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},asin:{doc:"Returns the arcsine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},acos:{doc:"Returns the arccosine of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},atan:{doc:"Returns the arctangent of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},min:{doc:"Returns the minimum value of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},max:{doc:"Returns the maximum value of the inputs.",group:"Math","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},round:{doc:\'Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `["round", -1.5]` evaluates to -2.\',group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},abs:{doc:"Returns the absolute value of the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},ceil:{doc:"Returns the smallest integer that is greater than or equal to the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},floor:{doc:"Returns the largest integer that is less than or equal to the input.",group:"Math","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},distance:{doc:"Returns the shortest distance in meters between the evaluated feature and the input geometry. The input value can be a valid GeoJSON of type `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Distance values returned may vary in precision due to loss in precision from encoding geometries, particularly below zoom level 13.",group:"Math","sdk-support":{"basic functionality":{android:"9.2.0",ios:"5.9.0",macos:"0.16.0"}}},"==":{doc:"Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"!=":{doc:"Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},">":{doc:"Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"<":{doc:"Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},">=":{doc:"Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},"<=":{doc:"Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},collator:{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}},all:{doc:"Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},any:{doc:"Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"!":{doc:"Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.",group:"Decision","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},within:{doc:"Returns `true` if the evaluated feature is fully contained inside a boundary of the input geometry, `false` otherwise. The input value can be a valid GeoJSON of type `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Supported features for evaluation:\\n- `Point`: Returns `false` if a point is on the boundary or falls outside the boundary.\\n- `LineString`: Returns `false` if any part of a line falls outside the boundary, the line intersects the boundary, or a line\'s endpoint is on the boundary.",group:"Decision","sdk-support":{"basic functionality":{js:"1.9.0",android:"9.1.0",ios:"5.8.0",macos:"0.15.0"}}},"is-supported-script":{doc:"Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).",group:"String","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.6.0"}}},upcase:{doc:"Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},downcase:{doc:"Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},concat:{doc:"Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.",group:"String","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}}},"resolved-locale":{doc:"Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.",group:"String","sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.2.0",macos:"0.9.0"}}}}},fog:{range:{type:"array",default:[.5,10],minimum:-20,maximum:20,length:2,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},doc:"The start and end distance range in which fog fades from fully transparent to fully opaque. The distance to the point at the center of the map is defined as zero, so that negative range values are closer to the camera, and positive values are farther away.",example:[.5,10],"sdk-support":{"basic functionality":{js:"2.3.0"}}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"The color of the fog. Using opacity is recommended only for smoothly transitioning fog on/off as anything less than 100% opacity results in more tiles loaded and drawn.","sdk-support":{"basic functionality":{js:"2.3.0"}}},"horizon-blend":{type:"number","property-type":"data-constant",default:.1,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Horizon blend applies a smooth fade from the color of the fog to the color of the sky. A value of zero leaves a sharp transition from fog to sky. Increasing the value blends the color of fog into increasingly high angles of the sky.","sdk-support":{"basic functionality":{js:"2.3.0"}}}},light:{anchor:{type:"enum",default:"viewport",values:{map:{doc:"The position of the light source is aligned to the rotation of the map."},viewport:{doc:"The position of the light source is aligned to the rotation of the viewport."}},"property-type":"data-constant",transition:!1,expression:{interpolated:!1,parameters:["zoom"]},doc:"Whether extruded geometries are lit relative to the map or viewport.",example:"map","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},position:{type:"array",default:[1.15,210,30],length:3,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},doc:"Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).",example:[1.5,90,80],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Color tint for lighting extruded geometries.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}},intensity:{type:"number","property-type":"data-constant",default:.5,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}}}},projection:{name:{type:"enum",values:{albers:{doc:"An Albers equal-area projection centered on the continental United States. You can configure the projection for a different region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},equalEarth:{doc:"An Equal Earth projection."},equirectangular:{doc:"An Equirectangular projection. This projection is very similar to the Plate Carrée projection."},lambertConformalConic:{doc:"A Lambert conformal conic projection. You can configure the projection for a region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},mercator:{doc:"The Mercator projection is the default projection."},naturalEarth:{doc:"A Natural Earth projection."},winkelTripel:{doc:"A Winkel Tripel projection."}},default:"mercator",doc:"The name of the projection to be used for rendering the map.",required:!0,"sdk-support":{"basic functionality":{js:"2.6.0"}}},center:{type:"array",length:2,value:"number","property-type":"data-constant",transition:!1,doc:"The reference longitude and latitude of the projection. `center` takes the form of [lng, lat]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic). All other projections are centered on [0, 0].",example:[-96,37.5],requires:[{name:["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{js:"2.6.0"}}},parallels:{type:"array",length:2,value:"number","property-type":"data-constant",transition:!1,doc:"The standard parallels of the projection, denoting the desired latitude range with minimal distortion. `parallels` takes the form of [lat0, lat1]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic).",example:[29.5,45.5],requires:[{name:["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{js:"2.6.0"}}}},terrain:{source:{type:"string",doc:"Name of a source of `raster_dem` type to be used for terrain elevation.",required:!0,"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}},exaggeration:{type:"number","property-type":"data-constant",default:1,minimum:0,maximum:1e3,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,doc:"Exaggerates the elevation of the terrain by multiplying the data from the DEM with this value.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}}}},paint:["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],paint_fill:{"fill-antialias":{type:"boolean",default:!0,doc:"Whether or not the fill should be antialiased.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.21.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{type:"color",default:"#000000",doc:"The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color\'s opacity will not affect the opacity of the 1px stroke, if it is used.",transition:!0,requires:[{"!":"fill-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.19.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{type:"color",doc:"The outline color of the fill. Matches the value of `fill-color` if unspecified.",transition:!0,requires:[{"!":"fill-pattern"},{"fill-antialias":!0}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.19.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{type:"enum",values:{map:{doc:"The fill is translated relative to the map."},viewport:{doc:"The fill is translated relative to the viewport."}},doc:"Controls the frame of reference for `fill-translate`.",default:"map",requires:["fill-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.",transition:!0,"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{type:"color",default:"#000000",doc:"The base color of the extruded fill. The extrusion\'s surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.",transition:!0,requires:[{"!":"fill-extrusion-pattern"}],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{type:"enum",values:{map:{doc:"The fill extrusion is translated relative to the map."},viewport:{doc:"The fill extrusion is translated relative to the viewport."}},doc:"Controls the frame of reference for `fill-extrusion-translate`.",default:"map",requires:["fill-extrusion-translate"],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"fill-extrusion-height":{type:"number",default:0,minimum:0,units:"meters",doc:"The height with which to extrude this layer.",transition:!0,"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{type:"number",default:0,minimum:0,units:"meters",doc:"The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.",transition:!0,requires:["fill-extrusion-height"],"sdk-support":{"basic functionality":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"},"data-driven styling":{js:"0.27.0",android:"5.1.0",ios:"3.6.0",macos:"0.5.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{type:"boolean",default:!0,doc:"Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.",transition:!1,"sdk-support":{"basic functionality":{js:"0.50.0",android:"7.0.0",ios:"4.7.0",macos:"0.13.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_line:{"line-opacity":{type:"number",doc:"The opacity at which the line will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{type:"color",doc:"The color with which the line will be drawn.",default:"#000000",transition:!0,requires:[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.23.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{type:"enum",values:{map:{doc:"The line is translated relative to the map."},viewport:{doc:"The line is translated relative to the viewport."}},doc:"Controls the frame of reference for `line-translate`.",default:"map",requires:["line-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"line-width":{type:"number",default:1,minimum:0,transition:!0,units:"pixels",doc:"Stroke thickness.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{type:"number",default:0,minimum:0,doc:"Draws a line casing outside of a line\'s actual path. Value indicates the width of the inner gap.",transition:!0,units:"pixels","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{type:"number",default:0,doc:"The line\'s offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.",transition:!0,units:"pixels","sdk-support":{"basic functionality":{js:"0.12.1",android:"3.0.0",ios:"3.1.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Blur applied to the line, in pixels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{type:"array",value:"number",doc:"Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won\'t render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.",minimum:0,transition:!0,units:"line widths",requires:[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"2.3.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"line-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.49.0",android:"6.5.0",macos:"0.11.0",ios:"4.4.0"}},expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"cross-faded-data-driven"},"line-gradient":{type:"color",doc:\'Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `"lineMetrics": true`.\',transition:!1,requires:[{"!":"line-pattern"},{source:"geojson",has:{lineMetrics:!0}}],"sdk-support":{"basic functionality":{js:"0.45.0",android:"6.5.0",ios:"4.4.0",macos:"0.11.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["line-progress"]},"property-type":"color-ramp"}},paint_circle:{"circle-radius":{type:"number",default:5,minimum:0,transition:!0,units:"pixels",doc:"Circle radius.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.18.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{type:"color",default:"#000000",doc:"The fill color of the circle.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.18.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{type:"number",default:0,doc:"Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.20.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{type:"number",doc:"The opacity at which the circle will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.20.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{type:"enum",values:{map:{doc:"The circle is translated relative to the map."},viewport:{doc:"The circle is translated relative to the viewport."}},doc:"Controls the frame of reference for `circle-translate`.",default:"map",requires:["circle-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{type:"enum",values:{map:{doc:"Circles are scaled according to their apparent distance to the camera."},viewport:{doc:"Circles are not scaled."}},default:"map",doc:"Controls the scaling behavior of the circle when the map is pitched.","sdk-support":{"basic functionality":{js:"0.21.0",android:"4.2.0",ios:"3.4.0",macos:"0.2.1"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{type:"enum",values:{map:{doc:"The circle is aligned to the plane of the map."},viewport:{doc:"The circle is aligned to the plane of the viewport."}},default:"viewport",doc:"Orientation of circle when map is pitched.","sdk-support":{"basic functionality":{js:"0.39.0",android:"5.2.0",ios:"3.7.0",macos:"0.6.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"The width of the circle\'s stroke. Strokes are placed outside of the `circle-radius`.","sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{type:"color",default:"#000000",doc:"The stroke color of the circle.",transition:!0,"sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{type:"number",doc:"The opacity of the circle\'s stroke.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"},"data-driven styling":{js:"0.29.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"}},paint_heatmap:{"heatmap-radius":{type:"number",default:30,minimum:1,transition:!0,units:"pixels",doc:"Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed. `queryRenderedFeatures` on heatmap layers will return points within this radius.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{type:"number",default:1,minimum:0,transition:!1,doc:"A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{type:"number",default:1,minimum:0,transition:!0,doc:"Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.","sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"heatmap-color":{type:"color",default:["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",.1,"royalblue",.3,"cyan",.5,"lime",.7,"yellow",1,"red"],doc:\'Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `["heatmap-density"]` as input.\',transition:!1,"sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{type:"number",doc:"The global opacity at which the heatmap layer will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.41.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_symbol:{"icon-opacity":{doc:"The opacity at which the icon will be drawn.",type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{type:"color",default:"#000000",transition:!0,doc:"The color of the icon. This can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,doc:"The color of the icon\'s halo. Icon halos can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Distance of halo to the icon outline.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Fade out the halo towards the outside.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"Distance that the icon\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",requires:["icon-image"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{type:"enum",values:{map:{doc:"Icons are translated relative to the map."},viewport:{doc:"Icons are translated relative to the viewport."}},doc:"Controls the frame of reference for `icon-translate`.",default:"map",requires:["icon-image","icon-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-opacity":{type:"number",doc:"The opacity at which the text will be drawn.",default:1,minimum:0,maximum:1,transition:!0,requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{type:"color",doc:"The color with which the text will be drawn.",default:"#000000",transition:!0,overridable:!0,requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,doc:"The color of the text\'s halo, which helps it stand out from backgrounds.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",doc:"The halo\'s fadeout distance towards the outside.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{js:"0.33.0",android:"5.0.0",ios:"3.5.0",macos:"0.4.0"}},expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",doc:"Distance that the text\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.",requires:["text-field"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{type:"enum",values:{map:{doc:"The text is translated relative to the map."},viewport:{doc:"The text is translated relative to the viewport."}},doc:"Controls the frame of reference for `text-translate`.",default:"map",requires:["text-field","text-translate"],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_raster:{"raster-opacity":{type:"number",doc:"The opacity at which the image will be drawn.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{type:"number",default:0,period:360,transition:!0,units:"degrees",doc:"Rotates hues around the color wheel.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{type:"number",doc:"Increase or reduce the brightness of the image. The value is the minimum brightness.",default:0,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{type:"number",doc:"Increase or reduce the brightness of the image. The value is the maximum brightness.",default:1,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-saturation":{type:"number",doc:"Increase or reduce the saturation of the image.",default:0,minimum:-1,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-contrast":{type:"number",doc:"Increase or reduce the contrast of the image.",default:0,minimum:-1,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-resampling":{type:"enum",doc:"The resampling/interpolation method to use for overscaling, also known as texture magnification filter",values:{linear:{doc:"(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled"},nearest:{doc:"Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled"}},default:"linear","sdk-support":{"basic functionality":{js:"0.47.0",android:"6.3.0",ios:"4.2.0",macos:"0.9.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{type:"number",default:300,minimum:0,transition:!1,units:"milliseconds",doc:"Fade duration when a new tile is added.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_hillshade:{"hillshade-illumination-direction":{type:"number",default:335,minimum:0,maximum:359,doc:"The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.",transition:!1,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{type:"enum",values:{map:{doc:"The hillshade illumination is relative to the north direction."},viewport:{doc:"The hillshade illumination is relative to the top of the viewport."}},default:"viewport",doc:"Direction of light source when map is rotated.","sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{type:"number",doc:"Intensity of the hillshade",default:.5,minimum:0,maximum:1,transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{type:"color",default:"#000000",doc:"The shading color of areas that face away from the light source.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{type:"color",default:"#FFFFFF",doc:"The shading color of areas that faces towards the light source.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{type:"color",default:"#000000",doc:"The shading color used to accentuate rugged terrain like sharp cliffs and gorges.",transition:!0,"sdk-support":{"basic functionality":{js:"0.43.0",android:"6.0.0",ios:"4.0.0",macos:"0.7.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_background:{"background-color":{type:"color",default:"#000000",doc:"The color with which the background will be drawn.",transition:!0,requires:[{"!":"background-pattern"}],"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"background-pattern":{type:"resolvedImage",transition:!0,doc:"Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"},"data-driven styling":{}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"cross-faded"},"background-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity at which the background will be drawn.",transition:!0,"sdk-support":{"basic functionality":{js:"0.10.0",android:"2.0.1",ios:"2.0.0",macos:"0.1.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_sky:{"sky-type":{type:"enum",values:{gradient:{doc:"Renders the sky with a gradient that can be configured with `sky-gradient-radius` and `sky-gradient`."},atmosphere:{doc:"Renders the sky with a simulated atmospheric scattering algorithm, the sun direction can be attached to the light position or explicitly set through `sky-atmosphere-sun`."}},default:"atmosphere",doc:"The type of the sky","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{type:"array",value:"number",length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,doc:"Position of the sun center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the sun relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the sun, where 0° is directly above, at zenith, and 90° at the horizon. When this property is ommitted, the sun center is directly inherited from the light position.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},requires:[{"sky-type":"atmosphere"}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{type:"number",requires:[{"sky-type":"atmosphere"}],default:10,minimum:0,maximum:100,transition:!1,doc:"Intensity of the sun as a light source in the atmosphere (on a scale from 0 to a 100). Setting higher values will brighten up the sky.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-gradient-center":{type:"array",requires:[{"sky-type":"gradient"}],value:"number",default:[0,0],length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,doc:"Position of the gradient center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the gradient center relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the gradient center, where 0° is directly above, at zenith, and 90° at the horizon.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{type:"number",requires:[{"sky-type":"gradient"}],default:90,minimum:0,maximum:180,transition:!1,doc:"The angular distance (measured in degrees) from `sky-gradient-center` up to which the gradient extends. A value of 180 causes the gradient to wrap around to the opposite direction from `sky-gradient-center`.","sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient":{type:"color",default:["interpolate",["linear"],["sky-radial-progress"],.8,"#87ceeb",1,"white"],doc:"Defines a radial color gradient with which to color the sky. The color values can be interpolated with an expression using `sky-radial-progress`. The range [0, 1] for the interpolant covers a radial distance (in degrees) of [0, `sky-gradient-radius`] centered at the position specified by `sky-gradient-center`.",transition:!1,requires:[{"sky-type":"gradient"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"},"data-driven styling":{}},expression:{interpolated:!0,parameters:["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{type:"color",default:"white",doc:"A color applied to the atmosphere sun halo. The alpha channel describes how strongly the sun halo is represented in an atmosphere sky layer.",transition:!1,requires:[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-atmosphere-color":{type:"color",default:"white",doc:"A color used to tweak the main atmospheric scattering coefficients. Using white applies the default coefficients giving the natural blue color to the atmosphere. This color affects how heavily the corresponding wavelength is represented during scattering. The alpha channel describes the density of the atmosphere, with 1 maximum density and 0 no density.",transition:!1,requires:[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},"property-type":"data-constant"},"sky-opacity":{type:"number",default:1,minimum:0,maximum:1,doc:"The opacity of the entire sky layer.",transition:!0,"sdk-support":{"basic functionality":{js:"2.0.0",ios:"10.0.0",android:"10.0.0"}},expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},transition:{duration:{type:"number",default:300,minimum:0,units:"milliseconds",doc:"Time allotted for transitions to complete."},delay:{type:"number",default:0,minimum:0,units:"milliseconds",doc:"Length of time before a transition begins."}},"property-type":{"data-driven":{type:"property-type",doc:"Property is interpolable and can be represented using a property expression."},"cross-faded":{type:"property-type",doc:"Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms."},"cross-faded-data-driven":{type:"property-type",doc:"Property is non-interpolable; rather, its values will be cross-faded to smoothly transition between integer zooms. It can be represented using a property expression."},"color-ramp":{type:"property-type",doc:"Property should be specified using a color ramp from which the output color can be sampled based on a property calculation."},"data-constant":{type:"property-type",doc:"Property is interpolable but cannot be represented using a property expression."},constant:{type:"property-type",doc:"Property is constant across all zoom levels and property values."}},promoteId:{"*":{type:"string",doc:"A name of a feature property to use as ID for feature state."}}},wn="undefined"!=typeof undefinedThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof undefined?global:"undefined"!=typeof self?self:{};function xn(t){var e={exports:{}};return t(e,e.exports),e.exports}function kn(t,e){return Object.prototype.hasOwnProperty.call(t,e)}\n/*! https://mths.be/punycode v1.3.2 by @mathias */xn((function(t,e){!function(i){var n=e&&!e.nodeType&&e,r=t&&!t.nodeType&&t,o="object"==typeof wn&&wn;o.global!==o&&o.window!==o&&o.self!==o||(i=o);var s,a,l=2147483647,u=/^xn--/,c=/[^\\x20-\\x7E]/,h=/[\\x2E\\u3002\\uFF0E\\uFF61]/g,d={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},f=Math.floor,p=String.fromCharCode;function m(t){throw RangeError(d[t])}function y(t,e){for(var i=t.length,n=[];i--;)n[i]=e(t[i]);return n}function g(t,e){var i=t.split("@"),n="";return i.length>1&&(n=i[0]+"@",t=i[1]),n+y((t=t.replace(h,".")).split("."),e).join(".")}function b(t){for(var e,i,n=[],r=0,o=t.length;r<o;)(e=t.charCodeAt(r++))>=55296&&e<=56319&&r<o?56320==(64512&(i=t.charCodeAt(r++)))?n.push(((1023&e)<<10)+(1023&i)+65536):(n.push(e),r--):n.push(e);return n}function v(t){return y(t,(function(t){var e="";return t>65535&&(e+=p((t-=65536)>>>10&1023|55296),t=56320|1023&t),e+p(t)})).join("")}function w(t,e){return t+22+75*(t<26)-((0!=e)<<5)}function x(t,e,i){var n=0;for(t=i?f(t/700):t>>1,t+=f(t/e);t>455;n+=36)t=f(t/35);return f(n+36*t/(t+38))}function k(t){var e,i,n,r,o,s,a,u,c,h,d,p=[],y=t.length,g=0,b=128,w=72;for((i=t.lastIndexOf("-"))<0&&(i=0),n=0;n<i;++n)t.charCodeAt(n)>=128&&m("not-basic"),p.push(t.charCodeAt(n));for(r=i>0?i+1:0;r<y;){for(o=g,s=1,a=36;r>=y&&m("invalid-input"),((u=(d=t.charCodeAt(r++))-48<10?d-22:d-65<26?d-65:d-97<26?d-97:36)>=36||u>f((l-g)/s))&&m("overflow"),g+=u*s,!(u<(c=a<=w?1:a>=w+26?26:a-w));a+=36)s>f(l/(h=36-c))&&m("overflow"),s*=h;w=x(g-o,e=p.length+1,0==o),f(g/e)>l-b&&m("overflow"),b+=f(g/e),g%=e,p.splice(g++,0,b)}return v(p)}function M(t){var e,i,n,r,o,s,a,u,c,h,d,y,g,v,k,M=[];for(y=(t=b(t)).length,e=128,i=0,o=72,s=0;s<y;++s)(d=t[s])<128&&M.push(p(d));for(n=r=M.length,r&&M.push("-");n<y;){for(a=l,s=0;s<y;++s)(d=t[s])>=e&&d<a&&(a=d);for(a-e>f((l-i)/(g=n+1))&&m("overflow"),i+=(a-e)*g,e=a,s=0;s<y;++s)if((d=t[s])<e&&++i>l&&m("overflow"),d==e){for(u=i,c=36;!(u<(h=c<=o?1:c>=o+26?26:c-o));c+=36)M.push(p(w(h+(k=u-h)%(v=36-h),0))),u=f(k/v);M.push(p(w(u,0))),o=x(i,g,n==r),i=0,++n}++i,++e}return M.join("")}if(s={version:"1.3.2",ucs2:{decode:b,encode:v},decode:k,encode:M,toASCII:function(t){return g(t,(function(t){return c.test(t)?"xn--"+M(t):t}))},toUnicode:function(t){return g(t,(function(t){return u.test(t)?k(t.slice(4).toLowerCase()):t}))}},n&&r)if(t.exports==n)r.exports=s;else for(a in s)s.hasOwnProperty(a)&&(n[a]=s[a]);else i.punycode=s}(wn)}));var Mn=function(t,e,i,n){i=i||"=";var r={};if("string"!=typeof t||0===t.length)return r;var o=/\\+/g;t=t.split(e=e||"&");var s=1e3;n&&"number"==typeof n.maxKeys&&(s=n.maxKeys);var a=t.length;s>0&&a>s&&(a=s);for(var l=0;l<a;++l){var u,c,h,d,f=t[l].replace(o,"%20"),p=f.indexOf(i);p>=0?(u=f.substr(0,p),c=f.substr(p+1)):(u=f,c=""),h=decodeURIComponent(u),d=decodeURIComponent(c),kn(r,h)?Array.isArray(r[h])?r[h].push(d):r[h]=[r[h],d]:r[h]=d}return r},jn=function(t){switch(typeof t){case"string":return t;case"boolean":return t?"true":"false";case"number":return isFinite(t)?t:"";default:return""}},An=function(t,e,i,n){return e=e||"&",i=i||"=",null===t&&(t=void 0),"object"==typeof t?Object.keys(t).map((function(n){var r=encodeURIComponent(jn(n))+i;return Array.isArray(t[n])?t[n].map((function(t){return r+encodeURIComponent(jn(t))})).join(e):r+encodeURIComponent(jn(t[n]))})).join(e):n?encodeURIComponent(jn(n))+i+encodeURIComponent(jn(t)):""};function Fn(t,...e){for(const i of e)for(const e in i)t[e]=i[e];return t}xn((function(t,e){e.decode=e.parse=Mn,e.encode=e.stringify=An}));class Tn extends Error{constructor(t,e){super(e),this.message=e,this.key=t}}class zn{constructor(t,e=[]){this.parent=t,this.bindings={};for(const[t,i]of e)this.bindings[t]=i}concat(t){return new zn(this,t)}get(t){if(this.bindings[t])return this.bindings[t];if(this.parent)return this.parent.get(t);throw new Error(t+" not found in scope.")}has(t){return!!this.bindings[t]||!!this.parent&&this.parent.has(t)}}const Sn={kind:"null"},_n={kind:"number"},Pn={kind:"string"},In={kind:"boolean"},On={kind:"color"},En={kind:"object"},qn={kind:"value"},Rn={kind:"collator"},Cn={kind:"formatted"},Nn={kind:"resolvedImage"};function Ln(t,e){return{kind:"array",itemType:t,N:e}}function Dn(t){if("array"===t.kind){const e=Dn(t.itemType);return"number"==typeof t.N?`array<${e}, ${t.N}>`:"value"===t.itemType.kind?"array":`array<${e}>`}return t.kind}const Un=[Sn,_n,Pn,In,On,Cn,En,Ln(qn),Nn];function $n(t,e){if("error"===e.kind)return null;if("array"===t.kind){if("array"===e.kind&&(0===e.N&&"value"===e.itemType.kind||!$n(t.itemType,e.itemType))&&("number"!=typeof t.N||t.N===e.N))return null}else{if(t.kind===e.kind)return null;if("value"===t.kind)for(const t of Un)if(!$n(t,e))return null}return`Expected ${Dn(t)} but found ${Dn(e)} instead.`}function Wn(t,e){return e.some(e=>e.kind===t.kind)}function Jn(t,e){return e.some(e=>"null"===e?null===t:"array"===e?Array.isArray(t):"object"===e?t&&!Array.isArray(t)&&"object"==typeof t:e===typeof t)}var Hn=xn((function(t,e){var i={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 n(t){return(t=Math.round(t))<0?0:t>255?255:t}function r(t){return n("%"===t[t.length-1]?parseFloat(t)/100*255:parseInt(t))}function o(t){return function(t){return t<0?0:t>1?1:t}("%"===t[t.length-1]?parseFloat(t)/100:parseFloat(t))}function s(t,e,i){return i<0?i+=1:i>1&&(i-=1),6*i<1?t+(e-t)*i*6:2*i<1?e:3*i<2?t+(e-t)*(2/3-i)*6:t}try{e.parseCSSColor=function(t){var e,a=t.replace(/ /g,"").toLowerCase();if(a in i)return i[a].slice();if("#"===a[0])return 4===a.length?(e=parseInt(a.substr(1),16))>=0&&e<=4095?[(3840&e)>>4|(3840&e)>>8,240&e|(240&e)>>4,15&e|(15&e)<<4,1]:null:7===a.length&&(e=parseInt(a.substr(1),16))>=0&&e<=16777215?[(16711680&e)>>16,(65280&e)>>8,255&e,1]:null;var l=a.indexOf("("),u=a.indexOf(")");if(-1!==l&&u+1===a.length){var c=a.substr(0,l),h=a.substr(l+1,u-(l+1)).split(","),d=1;switch(c){case"rgba":if(4!==h.length)return null;d=o(h.pop());case"rgb":return 3!==h.length?null:[r(h[0]),r(h[1]),r(h[2]),d];case"hsla":if(4!==h.length)return null;d=o(h.pop());case"hsl":if(3!==h.length)return null;var f=(parseFloat(h[0])%360+360)%360/360,p=o(h[1]),m=o(h[2]),y=m<=.5?m*(p+1):m+p-m*p,g=2*m-y;return[n(255*s(g,y,f+1/3)),n(255*s(g,y,f)),n(255*s(g,y,f-1/3)),d];default:return null}}return null}}catch(t){}}));class Gn{constructor(t,e,i,n=1){this.r=t,this.g=e,this.b=i,this.a=n}static parse(t){if(!t)return;if(t instanceof Gn)return t;if("string"!=typeof t)return;const e=Hn.parseCSSColor(t);return e?new Gn(e[0]/255*e[3],e[1]/255*e[3],e[2]/255*e[3],e[3]):void 0}toString(){const[t,e,i,n]=this.toArray();return`rgba(${Math.round(t)},${Math.round(e)},${Math.round(i)},${n})`}toArray(){const{r:t,g:e,b:i,a:n}=this;return 0===n?[0,0,0,0]:[255*t/n,255*e/n,255*i/n,n]}}Gn.black=new Gn(0,0,0,1),Gn.white=new Gn(1,1,1,1),Gn.transparent=new Gn(0,0,0,0),Gn.red=new Gn(1,0,0,1),Gn.blue=new Gn(0,0,1,1);class Vn{constructor(t,e,i){this.sensitivity=t?e?"variant":"case":e?"accent":"base",this.locale=i,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})}compare(t,e){return this.collator.compare(t,e)}resolvedLocale(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale}}class Bn{constructor(t,e,i,n,r){this.text=t.normalize?t.normalize():t,this.image=e,this.scale=i,this.fontStack=n,this.textColor=r}}class Xn{constructor(t){this.sections=t}static fromString(t){return new Xn([new Bn(t,null,null,null,null)])}isEmpty(){return 0===this.sections.length||!this.sections.some(t=>0!==t.text.length||t.image&&0!==t.image.name.length)}static factory(t){return t instanceof Xn?t:Xn.fromString(t)}toString(){return 0===this.sections.length?"":this.sections.map(t=>t.text).join("")}serialize(){const t=["format"];for(const e of this.sections){if(e.image){t.push(["image",e.image.name]);continue}t.push(e.text);const i={};e.fontStack&&(i["text-font"]=["literal",e.fontStack.split(",")]),e.scale&&(i["font-scale"]=e.scale),e.textColor&&(i["text-color"]=["rgba"].concat(e.textColor.toArray())),t.push(i)}return t}}class Zn{constructor(t){this.name=t.name,this.available=t.available}toString(){return this.name}static fromString(t){return t?new Zn({name:t,available:!1}):null}serialize(){return["image",this.name]}}function Yn(t,e,i,n){return"number"==typeof t&&t>=0&&t<=255&&"number"==typeof e&&e>=0&&e<=255&&"number"==typeof i&&i>=0&&i<=255?void 0===n||"number"==typeof n&&n>=0&&n<=1?null:`Invalid rgba value [${[t,e,i,n].join(", ")}]: \'a\' must be between 0 and 1.`:`Invalid rgba value [${("number"==typeof n?[t,e,i,n]:[t,e,i]).join(", ")}]: \'r\', \'g\', and \'b\' must be between 0 and 255.`}function Kn(t){if(null===t)return!0;if("string"==typeof t)return!0;if("boolean"==typeof t)return!0;if("number"==typeof t)return!0;if(t instanceof Gn)return!0;if(t instanceof Vn)return!0;if(t instanceof Xn)return!0;if(t instanceof Zn)return!0;if(Array.isArray(t)){for(const e of t)if(!Kn(e))return!1;return!0}if("object"==typeof t){for(const e in t)if(!Kn(t[e]))return!1;return!0}return!1}function Qn(t){if(null===t)return Sn;if("string"==typeof t)return Pn;if("boolean"==typeof t)return In;if("number"==typeof t)return _n;if(t instanceof Gn)return On;if(t instanceof Vn)return Rn;if(t instanceof Xn)return Cn;if(t instanceof Zn)return Nn;if(Array.isArray(t)){const e=t.length;let i;for(const e of t){const t=Qn(e);if(i){if(i===t)continue;i=qn;break}i=t}return Ln(i||qn,e)}return En}function tr(t){const e=typeof t;return null===t?"":"string"===e||"number"===e||"boolean"===e?String(t):t instanceof Gn||t instanceof Xn||t instanceof Zn?t.toString():JSON.stringify(t)}class er{constructor(t,e){this.type=t,this.value=e}static parse(t,e){if(2!==t.length)return e.error(`\'literal\' expression requires exactly one argument, but found ${t.length-1} instead.`);if(!Kn(t[1]))return e.error("invalid value");const i=t[1];let n=Qn(i);const r=e.expectedType;return"array"!==n.kind||0!==n.N||!r||"array"!==r.kind||"number"==typeof r.N&&0!==r.N||(n=r),new er(n,i)}evaluate(){return this.value}eachChild(){}outputDefined(){return!0}serialize(){return"array"===this.type.kind||"object"===this.type.kind?["literal",this.value]:this.value instanceof Gn?["rgba"].concat(this.value.toArray()):this.value instanceof Xn?this.value.serialize():this.value}}class ir{constructor(t){this.name="ExpressionEvaluationError",this.message=t}toJSON(){return this.message}}const nr={string:Pn,number:_n,boolean:In,object:En};class rr{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");let i,n=1;const r=t[0];if("array"===r){let r,o;if(t.length>2){const i=t[1];if("string"!=typeof i||!(i in nr)||"object"===i)return e.error(\'The item type argument of "array" must be one of string, number, boolean\',1);r=nr[i],n++}else r=qn;if(t.length>3){if(null!==t[2]&&("number"!=typeof t[2]||t[2]<0||t[2]!==Math.floor(t[2])))return e.error(\'The length argument to "array" must be a positive integer literal\',2);o=t[2],n++}i=Ln(r,o)}else i=nr[r];const o=[];for(;n<t.length;n++){const i=e.parse(t[n],n,qn);if(!i)return null;o.push(i)}return new rr(i,o)}evaluate(t){for(let e=0;e<this.args.length;e++){const i=this.args[e].evaluate(t);if(!$n(this.type,Qn(i)))return i;if(e===this.args.length-1)throw new ir(`Expected value to be of type ${Dn(this.type)}, but found ${Dn(Qn(i))} instead.`)}return null}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){const t=this.type,e=[t.kind];if("array"===t.kind){const i=t.itemType;if("string"===i.kind||"number"===i.kind||"boolean"===i.kind){e.push(i.kind);const n=t.N;("number"==typeof n||this.args.length>1)&&e.push(n)}}return e.concat(this.args.map(t=>t.serialize()))}}class or{constructor(t){this.type=Cn,this.sections=t}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[1];if(!Array.isArray(i)&&"object"==typeof i)return e.error("First argument must be an image or text section.");const n=[];let r=!1;for(let i=1;i<=t.length-1;++i){const o=t[i];if(r&&"object"==typeof o&&!Array.isArray(o)){r=!1;let t=null;if(o["font-scale"]&&(t=e.parse(o["font-scale"],1,_n),!t))return null;let i=null;if(o["text-font"]&&(i=e.parse(o["text-font"],1,Ln(Pn)),!i))return null;let s=null;if(o["text-color"]&&(s=e.parse(o["text-color"],1,On),!s))return null;const a=n[n.length-1];a.scale=t,a.font=i,a.textColor=s}else{const o=e.parse(t[i],1,qn);if(!o)return null;const s=o.type.kind;if("string"!==s&&"value"!==s&&"null"!==s&&"resolvedImage"!==s)return e.error("Formatted text type must be \'string\', \'value\', \'image\' or \'null\'.");r=!0,n.push({content:o,scale:null,font:null,textColor:null})}}return new or(n)}evaluate(t){return new Xn(this.sections.map(e=>{const i=e.content.evaluate(t);return Qn(i)===Nn?new Bn("",i,null,null,null):new Bn(tr(i),null,e.scale?e.scale.evaluate(t):null,e.font?e.font.evaluate(t).join(","):null,e.textColor?e.textColor.evaluate(t):null)}))}eachChild(t){for(const e of this.sections)t(e.content),e.scale&&t(e.scale),e.font&&t(e.font),e.textColor&&t(e.textColor)}outputDefined(){return!1}serialize(){const t=["format"];for(const e of this.sections){t.push(e.content.serialize());const i={};e.scale&&(i["font-scale"]=e.scale.serialize()),e.font&&(i["text-font"]=e.font.serialize()),e.textColor&&(i["text-color"]=e.textColor.serialize()),t.push(i)}return t}}class sr{constructor(t){this.type=Nn,this.input=t}static parse(t,e){if(2!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,Pn);return i?new sr(i):e.error("No image name provided.")}evaluate(t){const e=this.input.evaluate(t),i=Zn.fromString(e);return i&&t.availableImages&&(i.available=t.availableImages.indexOf(e)>-1),i}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){return["image",this.input.serialize()]}}const ar={"to-boolean":In,"to-color":On,"to-number":_n,"to-string":Pn};class lr{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[0];if(("to-boolean"===i||"to-string"===i)&&2!==t.length)return e.error("Expected one argument.");const n=ar[i],r=[];for(let i=1;i<t.length;i++){const n=e.parse(t[i],i,qn);if(!n)return null;r.push(n)}return new lr(n,r)}evaluate(t){if("boolean"===this.type.kind)return Boolean(this.args[0].evaluate(t));if("color"===this.type.kind){let e,i;for(const n of this.args){if(e=n.evaluate(t),i=null,e instanceof Gn)return e;if("string"==typeof e){const i=t.parseColor(e);if(i)return i}else if(Array.isArray(e)&&(i=e.length<3||e.length>4?`Invalid rbga value ${JSON.stringify(e)}: expected an array containing either three or four numeric values.`:Yn(e[0],e[1],e[2],e[3]),!i))return new Gn(e[0]/255,e[1]/255,e[2]/255,e[3])}throw new ir(i||`Could not parse color from value \'${"string"==typeof e?e:String(JSON.stringify(e))}\'`)}if("number"===this.type.kind){let e=null;for(const i of this.args){if(e=i.evaluate(t),null===e)return 0;const n=Number(e);if(!isNaN(n))return n}throw new ir(`Could not convert ${JSON.stringify(e)} to number.`)}return"formatted"===this.type.kind?Xn.fromString(tr(this.args[0].evaluate(t))):"resolvedImage"===this.type.kind?Zn.fromString(tr(this.args[0].evaluate(t))):tr(this.args[0].evaluate(t))}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){if("formatted"===this.type.kind)return new or([{content:this.args[0],scale:null,font:null,textColor:null}]).serialize();if("resolvedImage"===this.type.kind)return new sr(this.args[0]).serialize();const t=["to-"+this.type.kind];return this.eachChild(e=>{t.push(e.serialize())}),t}}const ur=["Unknown","Point","LineString","Polygon"];class cr{constructor(){this.globals=null,this.feature=null,this.featureState=null,this.formattedSection=null,this.R={},this.availableImages=null,this.canonical=null,this.featureTileCoord=null,this.featureDistanceData=null}id(){return this.feature&&"id"in this.feature&&this.feature.id?this.feature.id:null}geometryType(){return this.feature?"number"==typeof this.feature.type?ur[this.feature.type]:this.feature.type:null}geometry(){return this.feature&&"geometry"in this.feature?this.feature.geometry:null}canonicalID(){return this.canonical}properties(){return this.feature&&this.feature.properties||{}}distanceFromCenter(){if(this.featureTileCoord&&this.featureDistanceData){const t=this.featureDistanceData.center,e=this.featureDistanceData.scale,{x:i,y:n}=this.featureTileCoord;return this.featureDistanceData.bearing[0]*(i*e-t[0])+this.featureDistanceData.bearing[1]*(n*e-t[1])}return 0}parseColor(t){let e=this.R[t];return e||(e=this.R[t]=Gn.parse(t)),e}}class hr{constructor(t,e,i,n){this.name=t,this.type=e,this.C=i,this.args=n}evaluate(t){return this.C(t,this.args)}eachChild(t){this.args.forEach(t)}outputDefined(){return!1}serialize(){return[this.name].concat(this.args.map(t=>t.serialize()))}static parse(t,e){const i=t[0],n=hr.definitions[i];if(!n)return e.error(`Unknown expression "${i}". If you wanted a literal array, use ["literal", [...]].`,0);const r=Array.isArray(n)?n[0]:n.type,o=Array.isArray(n)?[[n[1],n[2]]]:n.overloads,s=o.filter(([e])=>!Array.isArray(e)||e.length===t.length-1);let a=null;for(const[n,o]of s){a=new Or(e.registry,e.path,null,e.scope);const s=[];let l=!1;for(let e=1;e<t.length;e++){const i=t[e],r=Array.isArray(n)?n[e-1]:n.type,o=a.parse(i,1+s.length,r);if(!o){l=!0;break}s.push(o)}if(!l)if(Array.isArray(n)&&n.length!==s.length)a.error(`Expected ${n.length} arguments, but found ${s.length} instead.`);else{for(let t=0;t<s.length;t++){const e=Array.isArray(n)?n[t]:n.type,i=s[t];a.concat(t+1).checkSubtype(e,i.type)}if(0===a.errors.length)return new hr(i,r,o,s)}}if(1===s.length)e.errors.push(...a.errors);else{const i=(s.length?s:o).map(([t])=>{return e=t,Array.isArray(e)?`(${e.map(Dn).join(", ")})`:`(${Dn(e.type)}...)`;var e}).join(" | "),n=[];for(let i=1;i<t.length;i++){const r=e.parse(t[i],1+n.length);if(!r)return null;n.push(Dn(r.type))}e.error(`Expected arguments of type ${i}, but found (${n.join(", ")}) instead.`)}return null}static register(t,e){hr.definitions=e;for(const i in e)t[i]=hr}}class dr{constructor(t,e,i){this.type=Rn,this.locale=i,this.caseSensitive=t,this.diacriticSensitive=e}static parse(t,e){if(2!==t.length)return e.error("Expected one argument.");const i=t[1];if("object"!=typeof i||Array.isArray(i))return e.error("Collator options argument must be an object.");const n=e.parse(void 0!==i["case-sensitive"]&&i["case-sensitive"],1,In);if(!n)return null;const r=e.parse(void 0!==i["diacritic-sensitive"]&&i["diacritic-sensitive"],1,In);if(!r)return null;let o=null;return i.locale&&(o=e.parse(i.locale,1,Pn),!o)?null:new dr(n,r,o)}evaluate(t){return new Vn(this.caseSensitive.evaluate(t),this.diacriticSensitive.evaluate(t),this.locale?this.locale.evaluate(t):null)}eachChild(t){t(this.caseSensitive),t(this.diacriticSensitive),this.locale&&t(this.locale)}outputDefined(){return!1}serialize(){const t={};return t["case-sensitive"]=this.caseSensitive.serialize(),t["diacritic-sensitive"]=this.diacriticSensitive.serialize(),this.locale&&(t.locale=this.locale.serialize()),["collator",t]}}function fr(t,e){t[0]=Math.min(t[0],e[0]),t[1]=Math.min(t[1],e[1]),t[2]=Math.max(t[2],e[0]),t[3]=Math.max(t[3],e[1])}function pr(t,e){return!(t[0]<=e[0]||t[2]>=e[2]||t[1]<=e[1]||t[3]>=e[3])}function mr(t,e){const i=(180+t[0])/360,n=(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+t[1]*Math.PI/360)))/360,r=Math.pow(2,e.z);return[Math.round(i*r*8192),Math.round(n*r*8192)]}function yr(t,e,i){const n=t[0]-e[0],r=t[1]-e[1],o=t[0]-i[0],s=t[1]-i[1];return n*s-o*r==0&&n*o<=0&&r*s<=0}function gr(t,e){let i=!1;for(let s=0,a=e.length;s<a;s++){const a=e[s];for(let e=0,s=a.length;e<s-1;e++){if(yr(t,a[e],a[e+1]))return!1;(r=a[e])[1]>(n=t)[1]!=(o=a[e+1])[1]>n[1]&&n[0]<(o[0]-r[0])*(n[1]-r[1])/(o[1]-r[1])+r[0]&&(i=!i)}}var n,r,o;return i}function br(t,e){for(let i=0;i<e.length;i++)if(gr(t,e[i]))return!0;return!1}function vr(t,e,i,n){const r=n[0]-i[0],o=n[1]-i[1],s=(t[0]-i[0])*o-r*(t[1]-i[1]),a=(e[0]-i[0])*o-r*(e[1]-i[1]);return s>0&&a<0||s<0&&a>0}function wr(t,e,i){for(const u of i)for(let i=0;i<u.length-1;++i)if(void 0,void 0,0!=(a=[(s=u[i+1])[0]-(o=u[i])[0],s[1]-o[1]])[0]*(l=[(r=e)[0]-(n=t)[0],r[1]-n[1]])[1]-a[1]*l[0]&&vr(n,r,o,s)&&vr(o,s,n,r))return!0;var n,r,o,s,a,l;return!1}function xr(t,e){for(let i=0;i<t.length;++i)if(!gr(t[i],e))return!1;for(let i=0;i<t.length-1;++i)if(wr(t[i],t[i+1],e))return!1;return!0}function kr(t,e){for(let i=0;i<e.length;i++)if(xr(t,e[i]))return!0;return!1}function Mr(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=[];for(let n=0;n<t[r].length;n++){const s=mr(t[r][n],i);fr(e,s),o.push(s)}n.push(o)}return n}function jr(t,e,i){const n=[];for(let r=0;r<t.length;r++){const o=Mr(t[r],e,i);n.push(o)}return n}function Ar(t,e,i,n){if(t[0]<i[0]||t[0]>i[2]){const e=.5*n;let r=t[0]-i[0]>e?-n:i[0]-t[0]>e?n:0;0===r&&(r=t[0]-i[2]>e?-n:i[2]-t[0]>e?n:0),t[0]+=r}fr(e,t)}function Fr(t,e,i,n){const r=8192*Math.pow(2,n.z),o=[8192*n.x,8192*n.y],s=[];if(!t)return s;for(const n of t)for(const t of n){const n=[t.x+o[0],t.y+o[1]];Ar(n,e,i,r),s.push(n)}return s}function Tr(t,e,i,n){const r=8192*Math.pow(2,n.z),o=[8192*n.x,8192*n.y],s=[];if(!t)return s;for(const i of t){const t=[];for(const n of i){const i=[n.x+o[0],n.y+o[1]];fr(e,i),t.push(i)}s.push(t)}if(e[2]-e[0]<=r/2){(a=e)[0]=a[1]=1/0,a[2]=a[3]=-1/0;for(const t of s)for(const n of t)Ar(n,e,i,r)}var a;return s}class zr{constructor(t,e){this.type=In,this.geojson=t,this.geometries=e}static parse(t,e){if(2!==t.length)return e.error(`\'within\' expression requires exactly one argument, but found ${t.length-1} instead.`);if(Kn(t[1])){const e=t[1];if("FeatureCollection"===e.type)for(let t=0;t<e.features.length;++t){const i=e.features[t].geometry.type;if("Polygon"===i||"MultiPolygon"===i)return new zr(e,e.features[t].geometry)}else if("Feature"===e.type){const t=e.geometry.type;if("Polygon"===t||"MultiPolygon"===t)return new zr(e,e.geometry)}else if("Polygon"===e.type||"MultiPolygon"===e.type)return new zr(e,e)}return e.error("\'within\' expression requires valid geojson object that contains polygon geometry type.")}evaluate(t){if(null!=t.geometry()&&null!=t.canonicalID()){if("Point"===t.geometryType())return function(t,e){const i=[1/0,1/0,-1/0,-1/0],n=[1/0,1/0,-1/0,-1/0],r=t.canonicalID();if(!r)return!1;if("Polygon"===e.type){const o=Mr(e.coordinates,n,r),s=Fr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!gr(t,o))return!1}if("MultiPolygon"===e.type){const o=jr(e.coordinates,n,r),s=Fr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!br(t,o))return!1}return!0}(t,this.geometries);if("LineString"===t.geometryType())return function(t,e){const i=[1/0,1/0,-1/0,-1/0],n=[1/0,1/0,-1/0,-1/0],r=t.canonicalID();if(!r)return!1;if("Polygon"===e.type){const o=Mr(e.coordinates,n,r),s=Tr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!xr(t,o))return!1}if("MultiPolygon"===e.type){const o=jr(e.coordinates,n,r),s=Tr(t.geometry(),i,n,r);if(!pr(i,n))return!1;for(const t of s)if(!kr(t,o))return!1}return!0}(t,this.geometries)}return!1}eachChild(){}outputDefined(){return!0}serialize(){return["within",this.geojson]}}function Sr(t){if(t instanceof hr){if("get"===t.name&&1===t.args.length)return!1;if("feature-state"===t.name)return!1;if("has"===t.name&&1===t.args.length)return!1;if("properties"===t.name||"geometry-type"===t.name||"id"===t.name)return!1;if(/^filter-/.test(t.name))return!1}if(t instanceof zr)return!1;let e=!0;return t.eachChild(t=>{e&&!Sr(t)&&(e=!1)}),e}function _r(t){if(t instanceof hr&&"feature-state"===t.name)return!1;let e=!0;return t.eachChild(t=>{e&&!_r(t)&&(e=!1)}),e}function Pr(t,e){if(t instanceof hr&&e.indexOf(t.name)>=0)return!1;let i=!0;return t.eachChild(t=>{i&&!Pr(t,e)&&(i=!1)}),i}class Ir{constructor(t,e){this.type=e.type,this.name=t,this.boundExpression=e}static parse(t,e){if(2!==t.length||"string"!=typeof t[1])return e.error("\'var\' expression requires exactly one string literal argument.");const i=t[1];return e.scope.has(i)?new Ir(i,e.scope.get(i)):e.error(`Unknown variable "${i}". Make sure "${i}" has been bound in an enclosing "let" expression before using it.`,1)}evaluate(t){return this.boundExpression.evaluate(t)}eachChild(){}outputDefined(){return!1}serialize(){return["var",this.name]}}class Or{constructor(t,e=[],i,n=new zn,r=[]){this.registry=t,this.path=e,this.key=e.map(t=>`[${t}]`).join(""),this.scope=n,this.errors=r,this.expectedType=i}parse(t,e,i,n,r={}){return e?this.concat(e,i,n).L(t,r):this.L(t,r)}L(t,e){function i(t,e,i){return"assert"===i?new rr(e,[t]):"coerce"===i?new lr(e,[t]):t}if(null!==t&&"string"!=typeof t&&"boolean"!=typeof t&&"number"!=typeof t||(t=["literal",t]),Array.isArray(t)){if(0===t.length)return this.error(\'Expected an array with at least one element. If you wanted a literal array, use ["literal", []].\');const n=t[0];if("string"!=typeof n)return this.error(`Expression name must be a string, but found ${typeof n} instead. If you wanted a literal array, use ["literal", [...]].`,0),null;const r=this.registry[n];if(r){let n=r.parse(t,this);if(!n)return null;if(this.expectedType){const t=this.expectedType,r=n.type;if("string"!==t.kind&&"number"!==t.kind&&"boolean"!==t.kind&&"object"!==t.kind&&"array"!==t.kind||"value"!==r.kind)if("color"!==t.kind&&"formatted"!==t.kind&&"resolvedImage"!==t.kind||"value"!==r.kind&&"string"!==r.kind){if(this.checkSubtype(t,r))return null}else n=i(n,t,e.typeAnnotation||"coerce");else n=i(n,t,e.typeAnnotation||"assert")}if(!(n instanceof er)&&"resolvedImage"!==n.type.kind&&function t(e){if(e instanceof Ir)return t(e.boundExpression);if(e instanceof hr&&"error"===e.name)return!1;if(e instanceof dr)return!1;if(e instanceof zr)return!1;const i=e instanceof lr||e instanceof rr;let n=!0;return e.eachChild(e=>{n=i?n&&t(e):n&&e instanceof er}),!!n&&(Sr(e)&&Pr(e,["zoom","heatmap-density","line-progress","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center"]))}(n)){const e=new cr;try{n=new er(n.type,n.evaluate(e))}catch(t){return this.error(t.message),null}}return n}return this.error(`Unknown expression "${n}". If you wanted a literal array, use ["literal", [...]].`,0)}return this.error(void 0===t?"\'undefined\' value invalid. Use null instead.":"object"==typeof t?\'Bare objects invalid. Use ["literal", {...}] instead.\':`Expected an array, but found ${typeof t} instead.`)}concat(t,e,i){const n="number"==typeof t?this.path.concat(t):this.path,r=i?this.scope.concat(i):this.scope;return new Or(this.registry,n,e||null,r,this.errors)}error(t,...e){const i=`${this.key}${e.map(t=>`[${t}]`).join("")}`;this.errors.push(new Tn(i,t))}checkSubtype(t,e){const i=$n(t,e);return i&&this.error(i),i}}function Er(t,e){const i=t.length-1;let n,r,o=0,s=i,a=0;for(;o<=s;)if(a=Math.floor((o+s)/2),n=t[a],r=t[a+1],n<=e){if(a===i||e<r)return a;o=a+1}else{if(!(n>e))throw new ir("Input is not a number.");s=a-1}return 0}class qr{constructor(t,e,i){this.type=t,this.input=e,this.labels=[],this.outputs=[];for(const[t,e]of i)this.labels.push(t),this.outputs.push(e)}static parse(t,e){if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");const i=e.parse(t[1],1,_n);if(!i)return null;const n=[];let r=null;e.expectedType&&"value"!==e.expectedType.kind&&(r=e.expectedType);for(let i=1;i<t.length;i+=2){const o=1===i?-1/0:t[i],s=t[i+1],a=i,l=i+1;if("number"!=typeof o)return e.error(\'Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.\',a);if(n.length&&n[n.length-1][0]>=o)return e.error(\'Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.\',a);const u=e.parse(s,l,r);if(!u)return null;r=r||u.type,n.push([o,u])}return new qr(r,i,n)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const n=this.input.evaluate(t);if(n<=e[0])return i[0].evaluate(t);const r=e.length;return n>=e[r-1]?i[r-1].evaluate(t):i[Er(e,n)].evaluate(t)}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every(t=>t.outputDefined())}serialize(){const t=["step",this.input.serialize()];for(let e=0;e<this.labels.length;e++)e>0&&t.push(this.labels[e]),t.push(this.outputs[e].serialize());return t}}var Rr=Cr;function Cr(t,e,i,n){this.cx=3*t,this.bx=3*(i-t)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*e,this.by=3*(n-e)-this.cy,this.ay=1-this.cy-this.by,this.p1x=t,this.p1y=n,this.p2x=i,this.p2y=n}function Nr(t,e,i){return t*(1-i)+e*i}Cr.prototype.sampleCurveX=function(t){return((this.ax*t+this.bx)*t+this.cx)*t},Cr.prototype.sampleCurveY=function(t){return((this.ay*t+this.by)*t+this.cy)*t},Cr.prototype.sampleCurveDerivativeX=function(t){return(3*this.ax*t+2*this.bx)*t+this.cx},Cr.prototype.solveCurveX=function(t,e){var i,n,r,o,s;for(void 0===e&&(e=1e-6),r=t,s=0;s<8;s++){if(o=this.sampleCurveX(r)-t,Math.abs(o)<e)return r;var a=this.sampleCurveDerivativeX(r);if(Math.abs(a)<1e-6)break;r-=o/a}if((r=t)<(i=0))return i;if(r>(n=1))return n;for(;i<n;){if(o=this.sampleCurveX(r),Math.abs(o-t)<e)return r;t>o?i=r:n=r,r=.5*(n-i)+i}return r},Cr.prototype.solve=function(t,e){return this.sampleCurveY(this.solveCurveX(t,e))};var Lr=Object.freeze({__proto__:null,number:Nr,color:function(t,e,i){return new Gn(Nr(t.r,e.r,i),Nr(t.g,e.g,i),Nr(t.b,e.b,i),Nr(t.a,e.a,i))},array:function(t,e,i){return t.map((t,n)=>Nr(t,e[n],i))}});const Dr=6/29*3*(6/29),Ur=Math.PI/180,$r=180/Math.PI;function Wr(t){return t>.008856451679035631?Math.pow(t,1/3):t/Dr+4/29}function Jr(t){return t>6/29?t*t*t:Dr*(t-4/29)}function Hr(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function Gr(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function Vr(t){const e=Gr(t.r),i=Gr(t.g),n=Gr(t.b),r=Wr((.4124564*e+.3575761*i+.1804375*n)/.95047),o=Wr((.2126729*e+.7151522*i+.072175*n)/1);return{l:116*o-16,a:500*(r-o),b:200*(o-Wr((.0193339*e+.119192*i+.9503041*n)/1.08883)),alpha:t.a}}function Br(t){let e=(t.l+16)/116,i=isNaN(t.a)?e:e+t.a/500,n=isNaN(t.b)?e:e-t.b/200;return e=1*Jr(e),i=.95047*Jr(i),n=1.08883*Jr(n),new Gn(Hr(3.2404542*i-1.5371385*e-.4985314*n),Hr(-.969266*i+1.8760108*e+.041556*n),Hr(.0556434*i-.2040259*e+1.0572252*n),t.alpha)}function Xr(t,e,i){const n=e-t;return t+i*(n>180||n<-180?n-360*Math.round(n/360):n)}const Zr={forward:Vr,reverse:Br,interpolate:function(t,e,i){return{l:Nr(t.l,e.l,i),a:Nr(t.a,e.a,i),b:Nr(t.b,e.b,i),alpha:Nr(t.alpha,e.alpha,i)}}},Yr={forward:function(t){const{l:e,a:i,b:n}=Vr(t),r=Math.atan2(n,i)*$r;return{h:r<0?r+360:r,c:Math.sqrt(i*i+n*n),l:e,alpha:t.a}},reverse:function(t){const e=t.h*Ur,i=t.c;return Br({l:t.l,a:Math.cos(e)*i,b:Math.sin(e)*i,alpha:t.alpha})},interpolate:function(t,e,i){return{h:Xr(t.h,e.h,i),c:Nr(t.c,e.c,i),l:Nr(t.l,e.l,i),alpha:Nr(t.alpha,e.alpha,i)}}};var Kr=Object.freeze({__proto__:null,lab:Zr,hcl:Yr});class Qr{constructor(t,e,i,n,r){this.type=t,this.operator=e,this.interpolation=i,this.input=n,this.labels=[],this.outputs=[];for(const[t,e]of r)this.labels.push(t),this.outputs.push(e)}static interpolationFactor(t,e,i,n){let r=0;if("exponential"===t.name)r=to(e,t.base,i,n);else if("linear"===t.name)r=to(e,1,i,n);else if("cubic-bezier"===t.name){const o=t.controlPoints;r=new Rr(o[0],o[1],o[2],o[3]).solve(to(e,1,i,n))}return r}static parse(t,e){let[i,n,r,...o]=t;if(!Array.isArray(n)||0===n.length)return e.error("Expected an interpolation type expression.",1);if("linear"===n[0])n={name:"linear"};else if("exponential"===n[0]){const t=n[1];if("number"!=typeof t)return e.error("Exponential interpolation requires a numeric base.",1,1);n={name:"exponential",base:t}}else{if("cubic-bezier"!==n[0])return e.error("Unknown interpolation type "+String(n[0]),1,0);{const t=n.slice(1);if(4!==t.length||t.some(t=>"number"!=typeof t||t<0||t>1))return e.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);n={name:"cubic-bezier",controlPoints:t}}}if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");if(r=e.parse(r,2,_n),!r)return null;const s=[];let a=null;"interpolate-hcl"===i||"interpolate-lab"===i?a=On:e.expectedType&&"value"!==e.expectedType.kind&&(a=e.expectedType);for(let t=0;t<o.length;t+=2){const i=o[t],n=o[t+1],r=t+3,l=t+4;if("number"!=typeof i)return e.error(\'Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.\',r);if(s.length&&s[s.length-1][0]>=i)return e.error(\'Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.\',r);const u=e.parse(n,l,a);if(!u)return null;a=a||u.type,s.push([i,u])}return"number"===a.kind||"color"===a.kind||"array"===a.kind&&"number"===a.itemType.kind&&"number"==typeof a.N?new Qr(a,i,n,r,s):e.error(`Type ${Dn(a)} is not interpolatable.`)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const n=this.input.evaluate(t);if(n<=e[0])return i[0].evaluate(t);const r=e.length;if(n>=e[r-1])return i[r-1].evaluate(t);const o=Er(e,n),s=Qr.interpolationFactor(this.interpolation,n,e[o],e[o+1]),a=i[o].evaluate(t),l=i[o+1].evaluate(t);return"interpolate"===this.operator?Lr[this.type.kind.toLowerCase()](a,l,s):"interpolate-hcl"===this.operator?Yr.reverse(Yr.interpolate(Yr.forward(a),Yr.forward(l),s)):Zr.reverse(Zr.interpolate(Zr.forward(a),Zr.forward(l),s))}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every(t=>t.outputDefined())}serialize(){let t;t="linear"===this.interpolation.name?["linear"]:"exponential"===this.interpolation.name?1===this.interpolation.base?["linear"]:["exponential",this.interpolation.base]:["cubic-bezier"].concat(this.interpolation.controlPoints);const e=[this.operator,t,this.input.serialize()];for(let t=0;t<this.labels.length;t++)e.push(this.labels[t],this.outputs[t].serialize());return e}}function to(t,e,i,n){const r=n-i,o=t-i;return 0===r?0:1===e?o/r:(Math.pow(e,o)-1)/(Math.pow(e,r)-1)}class eo{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expectected at least one argument.");let i=null;const n=e.expectedType;n&&"value"!==n.kind&&(i=n);const r=[];for(const n of t.slice(1)){const t=e.parse(n,1+r.length,i,void 0,{typeAnnotation:"omit"});if(!t)return null;i=i||t.type,r.push(t)}const o=n&&r.some(t=>$n(n,t.type));return new eo(o?qn:i,r)}evaluate(t){let e,i=null,n=0;for(const r of this.args){if(n++,i=r.evaluate(t),i&&i instanceof Zn&&!i.available&&(e||(e=i),i=null,n===this.args.length))return e;if(null!==i)break}return i}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every(t=>t.outputDefined())}serialize(){const t=["coalesce"];return this.eachChild(e=>{t.push(e.serialize())}),t}}class io{constructor(t,e){this.type=e.type,this.bindings=[].concat(t),this.result=e}evaluate(t){return this.result.evaluate(t)}eachChild(t){for(const e of this.bindings)t(e[1]);t(this.result)}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found ${t.length-1} instead.`);const i=[];for(let n=1;n<t.length-1;n+=2){const r=t[n];if("string"!=typeof r)return e.error(`Expected string, but found ${typeof r} instead.`,n);if(/[^a-zA-Z0-9_]/.test(r))return e.error("Variable names must contain only alphanumeric characters or \'_\'.",n);const o=e.parse(t[n+1],n+1);if(!o)return null;i.push([r,o])}const n=e.parse(t[t.length-1],t.length-1,e.expectedType,i);return n?new io(i,n):null}outputDefined(){return this.result.outputDefined()}serialize(){const t=["let"];for(const[e,i]of this.bindings)t.push(e,i.serialize());return t.push(this.result.serialize()),t}}class no{constructor(t,e,i){this.type=t,this.index=e,this.input=i}static parse(t,e){if(3!==t.length)return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,_n),n=e.parse(t[2],2,Ln(e.expectedType||qn));return i&&n?new no(n.type.itemType,i,n):null}evaluate(t){const e=this.index.evaluate(t),i=this.input.evaluate(t);if(e<0)throw new ir(`Array index out of bounds: ${e} < 0.`);if(e>=i.length)throw new ir(`Array index out of bounds: ${e} > ${i.length-1}.`);if(e!==Math.floor(e))throw new ir(`Array index must be an integer, but found ${e} instead.`);return i[e]}eachChild(t){t(this.index),t(this.input)}outputDefined(){return!1}serialize(){return["at",this.index.serialize(),this.input.serialize()]}}class ro{constructor(t,e){this.type=In,this.needle=t,this.haystack=e}static parse(t,e){if(3!==t.length)return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,qn);return i&&n?Wn(i.type,[In,Pn,_n,Sn,qn])?new ro(i,n):e.error(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(i.type)} instead`):null}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(null==i)return!1;if(!Jn(e,["boolean","string","number","null"]))throw new ir(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(Qn(e))} instead.`);if(!Jn(i,["string","array"]))throw new ir(`Expected second argument to be of type array or string, but found ${Dn(Qn(i))} instead.`);return i.indexOf(e)>=0}eachChild(t){t(this.needle),t(this.haystack)}outputDefined(){return!0}serialize(){return["in",this.needle.serialize(),this.haystack.serialize()]}}class oo{constructor(t,e,i){this.type=_n,this.needle=t,this.haystack=e,this.fromIndex=i}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,qn);if(!i||!n)return null;if(!Wn(i.type,[In,Pn,_n,Sn,qn]))return e.error(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,_n);return r?new oo(i,n,r):null}return new oo(i,n)}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(!Jn(e,["boolean","string","number","null"]))throw new ir(`Expected first argument to be of type boolean, string, number or null, but found ${Dn(Qn(e))} instead.`);if(!Jn(i,["string","array"]))throw new ir(`Expected second argument to be of type array or string, but found ${Dn(Qn(i))} instead.`);if(this.fromIndex){const n=this.fromIndex.evaluate(t);return i.indexOf(e,n)}return i.indexOf(e)}eachChild(t){t(this.needle),t(this.haystack),this.fromIndex&&t(this.fromIndex)}outputDefined(){return!1}serialize(){if(null!=this.fromIndex&&void 0!==this.fromIndex){const t=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),t]}return["index-of",this.needle.serialize(),this.haystack.serialize()]}}class so{constructor(t,e,i,n,r,o){this.inputType=t,this.type=e,this.input=i,this.cases=n,this.outputs=r,this.otherwise=o}static parse(t,e){if(t.length<5)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if(t.length%2!=1)return e.error("Expected an even number of arguments.");let i,n;e.expectedType&&"value"!==e.expectedType.kind&&(n=e.expectedType);const r={},o=[];for(let s=2;s<t.length-1;s+=2){let a=t[s];const l=t[s+1];Array.isArray(a)||(a=[a]);const u=e.concat(s);if(0===a.length)return u.error("Expected at least one branch label.");for(const t of a){if("number"!=typeof t&&"string"!=typeof t)return u.error("Branch labels must be numbers or strings.");if("number"==typeof t&&Math.abs(t)>Number.MAX_SAFE_INTEGER)return u.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);if("number"==typeof t&&Math.floor(t)!==t)return u.error("Numeric branch labels must be integer values.");if(i){if(u.checkSubtype(i,Qn(t)))return null}else i=Qn(t);if(void 0!==r[String(t)])return u.error("Branch labels must be unique.");r[String(t)]=o.length}const c=e.parse(l,s,n);if(!c)return null;n=n||c.type,o.push(c)}const s=e.parse(t[1],1,qn);if(!s)return null;const a=e.parse(t[t.length-1],t.length-1,n);return a?"value"!==s.type.kind&&e.concat(1).checkSubtype(i,s.type)?null:new so(i,n,s,r,o,a):null}evaluate(t){const e=this.input.evaluate(t);return(Qn(e)===this.inputType&&this.outputs[this.cases[e]]||this.otherwise).evaluate(t)}eachChild(t){t(this.input),this.outputs.forEach(t),t(this.otherwise)}outputDefined(){return this.outputs.every(t=>t.outputDefined())&&this.otherwise.outputDefined()}serialize(){const t=["match",this.input.serialize()],e=Object.keys(this.cases).sort(),i=[],n={};for(const t of e){const e=n[this.cases[t]];void 0===e?(n[this.cases[t]]=i.length,i.push([this.cases[t],[t]])):i[e][1].push(t)}const r=t=>"number"===this.inputType.kind?Number(t):t;for(const[e,n]of i)t.push(1===n.length?r(n[0]):n.map(r)),t.push(this.outputs[e].serialize());return t.push(this.otherwise.serialize()),t}}class ao{constructor(t,e,i){this.type=t,this.branches=e,this.otherwise=i}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found only ${t.length-1}.`);if(t.length%2!=0)return e.error("Expected an odd number of arguments.");let i;e.expectedType&&"value"!==e.expectedType.kind&&(i=e.expectedType);const n=[];for(let r=1;r<t.length-1;r+=2){const o=e.parse(t[r],r,In);if(!o)return null;const s=e.parse(t[r+1],r+1,i);if(!s)return null;n.push([o,s]),i=i||s.type}const r=e.parse(t[t.length-1],t.length-1,i);return r?new ao(i,n,r):null}evaluate(t){for(const[e,i]of this.branches)if(e.evaluate(t))return i.evaluate(t);return this.otherwise.evaluate(t)}eachChild(t){for(const[e,i]of this.branches)t(e),t(i);t(this.otherwise)}outputDefined(){return this.branches.every(([t,e])=>e.outputDefined())&&this.otherwise.outputDefined()}serialize(){const t=["case"];return this.eachChild(e=>{t.push(e.serialize())}),t}}class lo{constructor(t,e,i,n){this.type=t,this.input=e,this.beginIndex=i,this.endIndex=n}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,qn),n=e.parse(t[2],2,_n);if(!i||!n)return null;if(!Wn(i.type,[Ln(qn),Pn,qn]))return e.error(`Expected first argument to be of type array or string, but found ${Dn(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,_n);return r?new lo(i.type,i,n,r):null}return new lo(i.type,i,n)}evaluate(t){const e=this.input.evaluate(t),i=this.beginIndex.evaluate(t);if(!Jn(e,["string","array"]))throw new ir(`Expected first argument to be of type array or string, but found ${Dn(Qn(e))} instead.`);if(this.endIndex){const n=this.endIndex.evaluate(t);return e.slice(i,n)}return e.slice(i)}eachChild(t){t(this.input),t(this.beginIndex),this.endIndex&&t(this.endIndex)}outputDefined(){return!1}serialize(){if(null!=this.endIndex&&void 0!==this.endIndex){const t=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),t]}return["slice",this.input.serialize(),this.beginIndex.serialize()]}}function uo(t,e){return"=="===t||"!="===t?"boolean"===e.kind||"string"===e.kind||"number"===e.kind||"null"===e.kind||"value"===e.kind:"string"===e.kind||"number"===e.kind||"value"===e.kind}function co(t,e,i,n){return 0===n.compare(e,i)}function ho(t,e,i){const n="=="!==t&&"!="!==t;return class r{constructor(t,e,i){this.type=In,this.lhs=t,this.rhs=e,this.collator=i,this.hasUntypedArgument="value"===t.type.kind||"value"===e.type.kind}static parse(t,e){if(3!==t.length&&4!==t.length)return e.error("Expected two or three arguments.");const i=t[0];let o=e.parse(t[1],1,qn);if(!o)return null;if(!uo(i,o.type))return e.concat(1).error(`"${i}" comparisons are not supported for type \'${Dn(o.type)}\'.`);let s=e.parse(t[2],2,qn);if(!s)return null;if(!uo(i,s.type))return e.concat(2).error(`"${i}" comparisons are not supported for type \'${Dn(s.type)}\'.`);if(o.type.kind!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return e.error(`Cannot compare types \'${Dn(o.type)}\' and \'${Dn(s.type)}\'.`);n&&("value"===o.type.kind&&"value"!==s.type.kind?o=new rr(s.type,[o]):"value"!==o.type.kind&&"value"===s.type.kind&&(s=new rr(o.type,[s])));let a=null;if(4===t.length){if("string"!==o.type.kind&&"string"!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return e.error("Cannot use collator to compare non-string types.");if(a=e.parse(t[3],3,Rn),!a)return null}return new r(o,s,a)}evaluate(r){const o=this.lhs.evaluate(r),s=this.rhs.evaluate(r);if(n&&this.hasUntypedArgument){const e=Qn(o),i=Qn(s);if(e.kind!==i.kind||"string"!==e.kind&&"number"!==e.kind)throw new ir(`Expected arguments for "${t}" to be (string, string) or (number, number), but found (${e.kind}, ${i.kind}) instead.`)}if(this.collator&&!n&&this.hasUntypedArgument){const t=Qn(o),i=Qn(s);if("string"!==t.kind||"string"!==i.kind)return e(r,o,s)}return this.collator?i(r,o,s,this.collator.evaluate(r)):e(r,o,s)}eachChild(t){t(this.lhs),t(this.rhs),this.collator&&t(this.collator)}outputDefined(){return!0}serialize(){const e=[t];return this.eachChild(t=>{e.push(t.serialize())}),e}}}const fo=ho("==",(function(t,e,i){return e===i}),co),po=ho("!=",(function(t,e,i){return e!==i}),(function(t,e,i,n){return!co(0,e,i,n)})),mo=ho("<",(function(t,e,i){return e<i}),(function(t,e,i,n){return n.compare(e,i)<0})),yo=ho(">",(function(t,e,i){return e>i}),(function(t,e,i,n){return n.compare(e,i)>0})),go=ho("<=",(function(t,e,i){return e<=i}),(function(t,e,i,n){return n.compare(e,i)<=0})),bo=ho(">=",(function(t,e,i){return e>=i}),(function(t,e,i,n){return n.compare(e,i)>=0}));class vo{constructor(t,e,i,n,r){this.type=Pn,this.number=t,this.locale=e,this.currency=i,this.minFractionDigits=n,this.maxFractionDigits=r}static parse(t,e){if(3!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,_n);if(!i)return null;const n=t[2];if("object"!=typeof n||Array.isArray(n))return e.error("NumberFormat options argument must be an object.");let r=null;if(n.locale&&(r=e.parse(n.locale,1,Pn),!r))return null;let o=null;if(n.currency&&(o=e.parse(n.currency,1,Pn),!o))return null;let s=null;if(n["min-fraction-digits"]&&(s=e.parse(n["min-fraction-digits"],1,_n),!s))return null;let a=null;return n["max-fraction-digits"]&&(a=e.parse(n["max-fraction-digits"],1,_n),!a)?null:new vo(i,r,o,s,a)}evaluate(t){return new Intl.NumberFormat(this.locale?this.locale.evaluate(t):[],{style:this.currency?"currency":"decimal",currency:this.currency?this.currency.evaluate(t):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(t):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(t):void 0}).format(this.number.evaluate(t))}eachChild(t){t(this.number),this.locale&&t(this.locale),this.currency&&t(this.currency),this.minFractionDigits&&t(this.minFractionDigits),this.maxFractionDigits&&t(this.maxFractionDigits)}outputDefined(){return!1}serialize(){const t={};return this.locale&&(t.locale=this.locale.serialize()),this.currency&&(t.currency=this.currency.serialize()),this.minFractionDigits&&(t["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(t["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),t]}}class wo{constructor(t){this.type=_n,this.input=t}static parse(t,e){if(2!==t.length)return e.error(`Expected 1 argument, but found ${t.length-1} instead.`);const i=e.parse(t[1],1);return i?"array"!==i.type.kind&&"string"!==i.type.kind&&"value"!==i.type.kind?e.error(`Expected argument of type string or array, but found ${Dn(i.type)} instead.`):new wo(i):null}evaluate(t){const e=this.input.evaluate(t);if("string"==typeof e)return e.length;if(Array.isArray(e))return e.length;throw new ir(`Expected value to be of type string or array, but found ${Dn(Qn(e))} instead.`)}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){const t=["length"];return this.eachChild(e=>{t.push(e.serialize())}),t}}const xo={"==":fo,"!=":po,">":yo,"<":mo,">=":bo,"<=":go,array:rr,at:no,boolean:rr,case:ao,coalesce:eo,collator:dr,format:or,image:sr,in:ro,"index-of":oo,interpolate:Qr,"interpolate-hcl":Qr,"interpolate-lab":Qr,length:wo,let:io,literal:er,match:so,number:rr,"number-format":vo,object:rr,slice:lo,step:qr,string:rr,"to-boolean":lr,"to-color":lr,"to-number":lr,"to-string":lr,var:Ir,within:zr};function ko(t,[e,i,n,r]){e=e.evaluate(t),i=i.evaluate(t),n=n.evaluate(t);const o=r?r.evaluate(t):1,s=Yn(e,i,n,o);if(s)throw new ir(s);return new Gn(e/255*o,i/255*o,n/255*o,o)}function Mo(t,e){return t in e}function jo(t,e){const i=e[t];return void 0===i?null:i}function Ao(t){return{type:t}}function Fo(t){return{result:"success",value:t}}function To(t){return{result:"error",value:t}}function zo(t){return!!t.expression&&t.expression.interpolated}function So(t){return t instanceof Number?"number":t instanceof String?"string":t instanceof Boolean?"boolean":Array.isArray(t)?"array":null===t?"null":typeof t}function _o(t){return"object"==typeof t&&null!==t&&!Array.isArray(t)}function Po(t){return t}function Io(t,e,i){return void 0!==t?t:void 0!==e?e:void 0!==i?i:void 0}function Oo(t,e,i,n,r){return Io(typeof i===r?n[i]:void 0,t.default,e.default)}function Eo(t,e,i){if("number"!==So(i))return Io(t.default,e.default);const n=t.stops.length;if(1===n)return t.stops[0][1];if(i<=t.stops[0][0])return t.stops[0][1];if(i>=t.stops[n-1][0])return t.stops[n-1][1];const r=Er(t.stops.map(t=>t[0]),i);return t.stops[r][1]}function qo(t,e,i){const n=void 0!==t.base?t.base:1;if("number"!==So(i))return Io(t.default,e.default);const r=t.stops.length;if(1===r)return t.stops[0][1];if(i<=t.stops[0][0])return t.stops[0][1];if(i>=t.stops[r-1][0])return t.stops[r-1][1];const o=Er(t.stops.map(t=>t[0]),i),s=function(t,e,i,n){const r=n-i,o=t-i;return 0===r?0:1===e?o/r:(Math.pow(e,o)-1)/(Math.pow(e,r)-1)}(i,n,t.stops[o][0],t.stops[o+1][0]),a=t.stops[o][1],l=t.stops[o+1][1];let u=Lr[e.type]||Po;if(t.colorSpace&&"rgb"!==t.colorSpace){const e=Kr[t.colorSpace];u=(t,i)=>e.reverse(e.interpolate(e.forward(t),e.forward(i),s))}return"function"==typeof a.evaluate?{evaluate(...t){const e=a.evaluate.apply(void 0,t),i=l.evaluate.apply(void 0,t);if(void 0!==e&&void 0!==i)return u(e,i,s)}}:u(a,l,s)}function Ro(t,e,i){return"color"===e.type?i=Gn.parse(i):"formatted"===e.type?i=Xn.fromString(i.toString()):"resolvedImage"===e.type?i=Zn.fromString(i.toString()):So(i)===e.type||"enum"===e.type&&e.values[i]||(i=void 0),Io(i,t.default,e.default)}hr.register(xo,{error:[{kind:"error"},[Pn],(t,[e])=>{throw new ir(e.evaluate(t))}],typeof:[Pn,[qn],(t,[e])=>Dn(Qn(e.evaluate(t)))],"to-rgba":[Ln(_n,4),[On],(t,[e])=>e.evaluate(t).toArray()],rgb:[On,[_n,_n,_n],ko],rgba:[On,[_n,_n,_n,_n],ko],has:{type:In,overloads:[[[Pn],(t,[e])=>Mo(e.evaluate(t),t.properties())],[[Pn,En],(t,[e,i])=>Mo(e.evaluate(t),i.evaluate(t))]]},get:{type:qn,overloads:[[[Pn],(t,[e])=>jo(e.evaluate(t),t.properties())],[[Pn,En],(t,[e,i])=>jo(e.evaluate(t),i.evaluate(t))]]},"feature-state":[qn,[Pn],(t,[e])=>jo(e.evaluate(t),t.featureState||{})],properties:[En,[],t=>t.properties()],"geometry-type":[Pn,[],t=>t.geometryType()],id:[qn,[],t=>t.id()],zoom:[_n,[],t=>t.globals.zoom],pitch:[_n,[],t=>t.globals.pitch||0],"distance-from-center":[_n,[],t=>t.distanceFromCenter()],"heatmap-density":[_n,[],t=>t.globals.heatmapDensity||0],"line-progress":[_n,[],t=>t.globals.lineProgress||0],"sky-radial-progress":[_n,[],t=>t.globals.skyRadialProgress||0],accumulated:[qn,[],t=>void 0===t.globals.accumulated?null:t.globals.accumulated],"+":[_n,Ao(_n),(t,e)=>{let i=0;for(const n of e)i+=n.evaluate(t);return i}],"*":[_n,Ao(_n),(t,e)=>{let i=1;for(const n of e)i*=n.evaluate(t);return i}],"-":{type:_n,overloads:[[[_n,_n],(t,[e,i])=>e.evaluate(t)-i.evaluate(t)],[[_n],(t,[e])=>-e.evaluate(t)]]},"/":[_n,[_n,_n],(t,[e,i])=>e.evaluate(t)/i.evaluate(t)],"%":[_n,[_n,_n],(t,[e,i])=>e.evaluate(t)%i.evaluate(t)],ln2:[_n,[],()=>Math.LN2],pi:[_n,[],()=>Math.PI],e:[_n,[],()=>Math.E],"^":[_n,[_n,_n],(t,[e,i])=>Math.pow(e.evaluate(t),i.evaluate(t))],sqrt:[_n,[_n],(t,[e])=>Math.sqrt(e.evaluate(t))],log10:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))/Math.LN10],ln:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))],log2:[_n,[_n],(t,[e])=>Math.log(e.evaluate(t))/Math.LN2],sin:[_n,[_n],(t,[e])=>Math.sin(e.evaluate(t))],cos:[_n,[_n],(t,[e])=>Math.cos(e.evaluate(t))],tan:[_n,[_n],(t,[e])=>Math.tan(e.evaluate(t))],asin:[_n,[_n],(t,[e])=>Math.asin(e.evaluate(t))],acos:[_n,[_n],(t,[e])=>Math.acos(e.evaluate(t))],atan:[_n,[_n],(t,[e])=>Math.atan(e.evaluate(t))],min:[_n,Ao(_n),(t,e)=>Math.min(...e.map(e=>e.evaluate(t)))],max:[_n,Ao(_n),(t,e)=>Math.max(...e.map(e=>e.evaluate(t)))],abs:[_n,[_n],(t,[e])=>Math.abs(e.evaluate(t))],round:[_n,[_n],(t,[e])=>{const i=e.evaluate(t);return i<0?-Math.round(-i):Math.round(i)}],floor:[_n,[_n],(t,[e])=>Math.floor(e.evaluate(t))],ceil:[_n,[_n],(t,[e])=>Math.ceil(e.evaluate(t))],"filter-==":[In,[Pn,qn],(t,[e,i])=>t.properties()[e.value]===i.value],"filter-id-==":[In,[qn],(t,[e])=>t.id()===e.value],"filter-type-==":[In,[Pn],(t,[e])=>t.geometryType()===e.value],"filter-<":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n<r}],"filter-id-<":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i<n}],"filter->":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>r}],"filter-id->":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>n}],"filter-<=":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n<=r}],"filter-id-<=":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i<=n}],"filter->=":[In,[Pn,qn],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>=r}],"filter-id->=":[In,[qn],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>=n}],"filter-has":[In,[qn],(t,[e])=>e.value in t.properties()],"filter-has-id":[In,[],t=>null!==t.id()&&void 0!==t.id()],"filter-type-in":[In,[Ln(Pn)],(t,[e])=>e.value.indexOf(t.geometryType())>=0],"filter-id-in":[In,[Ln(qn)],(t,[e])=>e.value.indexOf(t.id())>=0],"filter-in-small":[In,[Pn,Ln(qn)],(t,[e,i])=>i.value.indexOf(t.properties()[e.value])>=0],"filter-in-large":[In,[Pn,Ln(qn)],(t,[e,i])=>function(t,e,i,n){for(;i<=n;){const r=i+n>>1;if(e[r]===t)return!0;e[r]>t?n=r-1:i=r+1}return!1}(t.properties()[e.value],i.value,0,i.value.length-1)],all:{type:In,overloads:[[[In,In],(t,[e,i])=>e.evaluate(t)&&i.evaluate(t)],[Ao(In),(t,e)=>{for(const i of e)if(!i.evaluate(t))return!1;return!0}]]},any:{type:In,overloads:[[[In,In],(t,[e,i])=>e.evaluate(t)||i.evaluate(t)],[Ao(In),(t,e)=>{for(const i of e)if(i.evaluate(t))return!0;return!1}]]},"!":[In,[In],(t,[e])=>!e.evaluate(t)],"is-supported-script":[In,[Pn],(t,[e])=>{const i=t.globals&&t.globals.isSupportedScript;return!i||i(e.evaluate(t))}],upcase:[Pn,[Pn],(t,[e])=>e.evaluate(t).toUpperCase()],downcase:[Pn,[Pn],(t,[e])=>e.evaluate(t).toLowerCase()],concat:[Pn,Ao(qn),(t,e)=>e.map(e=>tr(e.evaluate(t))).join("")],"resolved-locale":[Pn,[Rn],(t,[e])=>e.evaluate(t).resolvedLocale()]});class Co{constructor(t,e){this.expression=t,this.D={},this.U=new cr,this.W=e?function(t){return"color"===t.type&&_o(t.default)?new Gn(0,0,0,0):"color"===t.type?Gn.parse(t.default)||null:void 0===t.default?null:t.default}(e):null,this.J=e&&"enum"===e.type?e.values:null}evaluateWithoutErrorHandling(t,e,i,n,r,o,s,a){return this.U.globals=t,this.U.feature=e,this.U.featureState=i,this.U.canonical=n||null,this.U.availableImages=r||null,this.U.formattedSection=o,this.U.featureTileCoord=s||null,this.U.featureDistanceData=a||null,this.expression.evaluate(this.U)}evaluate(t,e,i,n,r,o,s,a){this.U.globals=t,this.U.feature=e||null,this.U.featureState=i||null,this.U.canonical=n||null,this.U.availableImages=r||null,this.U.formattedSection=o||null,this.U.featureTileCoord=s||null,this.U.featureDistanceData=a||null;try{const t=this.expression.evaluate(this.U);if(null==t||"number"==typeof t&&t!=t)return this.W;if(this.J&&!(t in this.J))throw new ir(`Expected value to be one of ${Object.keys(this.J).map(t=>JSON.stringify(t)).join(", ")}, but found ${JSON.stringify(t)} instead.`);return t}catch(t){return this.D[t.message]||(this.D[t.message]=!0,"undefined"!=typeof console&&console.warn(t.message)),this.W}}}function No(t){return Array.isArray(t)&&t.length>0&&"string"==typeof t[0]&&t[0]in xo}function Lo(t,e){const i=new Or(xo,[],e?function(t){const e={color:On,string:Pn,number:_n,enum:Pn,boolean:In,formatted:Cn,resolvedImage:Nn};return"array"===t.type?Ln(e[t.value]||qn,t.length):e[t.type]}(e):void 0),n=i.parse(t,void 0,void 0,void 0,e&&"string"===e.type?{typeAnnotation:"coerce"}:void 0);return n?Fo(new Co(n,e)):To(i.errors)}class Do{constructor(t,e){this.kind=t,this.H=e,this.isStateDependent="constant"!==t&&!_r(e.expression)}evaluateWithoutErrorHandling(t,e,i,n,r,o){return this.H.evaluateWithoutErrorHandling(t,e,i,n,r,o)}evaluate(t,e,i,n,r,o){return this.H.evaluate(t,e,i,n,r,o)}}class Uo{constructor(t,e,i,n){this.kind=t,this.zoomStops=i,this.H=e,this.isStateDependent="camera"!==t&&!_r(e.expression),this.interpolationType=n}evaluateWithoutErrorHandling(t,e,i,n,r,o){return this.H.evaluateWithoutErrorHandling(t,e,i,n,r,o)}evaluate(t,e,i,n,r,o){return this.H.evaluate(t,e,i,n,r,o)}interpolationFactor(t,e,i){return this.interpolationType?Qr.interpolationFactor(this.interpolationType,t,e,i):0}}function $o(t,e){if("error"===(t=Lo(t,e)).result)return t;const i=t.value.expression,n=Sr(i);if(!n&&!function(t){return"data-driven"===t["property-type"]||"cross-faded-data-driven"===t["property-type"]}(e))return To([new Tn("","data expressions not supported")]);const r=Pr(i,["zoom","pitch","distance-from-center"]);if(!r&&!function(t){return!!t.expression&&t.expression.parameters.indexOf("zoom")>-1}(e))return To([new Tn("","zoom expressions not supported")]);const o=function t(e){let i=null;if(e instanceof io)i=t(e.result);else if(e instanceof eo){for(const n of e.args)if(i=t(n),i)break}else(e instanceof qr||e instanceof Qr)&&e.input instanceof hr&&"zoom"===e.input.name&&(i=e);return i instanceof Tn||e.eachChild(e=>{const n=t(e);n instanceof Tn?i=n:!i&&n?i=new Tn("",\'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.\'):i&&n&&i!==n&&(i=new Tn("",\'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.\'))}),i}(i);if(!o&&!r)return To([new Tn("",\'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.\')]);if(o instanceof Tn)return To([o]);if(o instanceof Qr&&!zo(e))return To([new Tn("",\'"interpolate" expressions cannot be used with this property\')]);if(!o)return Fo(new Do(n?"constant":"source",t.value));const s=o instanceof Qr?o.interpolation:void 0;return Fo(new Uo(n?"camera":"composite",t.value,o.labels,s))}class Wo{constructor(t,e){this.G=t,this.V=e,Fn(this,function t(e,i){const n="color"===i.type,r=e.stops&&"object"==typeof e.stops[0][0],o=r||!(r||void 0!==e.property),s=e.type||(zo(i)?"exponential":"interval");if(n&&((e=Fn({},e)).stops&&(e.stops=e.stops.map(t=>[t[0],Gn.parse(t[1])])),e.default=Gn.parse(e.default?e.default:i.default)),e.colorSpace&&"rgb"!==e.colorSpace&&!Kr[e.colorSpace])throw new Error("Unknown color space: "+e.colorSpace);let a,l,u;if("exponential"===s)a=qo;else if("interval"===s)a=Eo;else if("categorical"===s){a=Oo,l=Object.create(null);for(const t of e.stops)l[t[0]]=t[1];u=typeof e.stops[0][0]}else{if("identity"!==s)throw new Error(`Unknown function type "${s}"`);a=Ro}if(r){const n={},r=[];for(let t=0;t<e.stops.length;t++){const i=e.stops[t],o=i[0].zoom;void 0===n[o]&&(n[o]={zoom:o,type:e.type,property:e.property,default:e.default,stops:[]},r.push(o)),n[o].stops.push([i[0].value,i[1]])}const o=[];for(const e of r)o.push([n[e].zoom,t(n[e],i)]);const s={name:"linear"};return{kind:"composite",interpolationType:s,interpolationFactor:Qr.interpolationFactor.bind(void 0,s),zoomStops:o.map(t=>t[0]),evaluate:({zoom:t},n)=>qo({stops:o,base:e.base},i,t).evaluate(t,n)}}if(o){const t="exponential"===s?{name:"exponential",base:void 0!==e.base?e.base:1}:null;return{kind:"camera",interpolationType:t,interpolationFactor:Qr.interpolationFactor.bind(void 0,t),zoomStops:e.stops.map(t=>t[0]),evaluate:({zoom:t})=>a(e,i,t,l,u)}}return{kind:"source",evaluate(t,n){const r=n&&n.properties?n.properties[e.property]:void 0;return void 0===r?Io(e.default,i.default):a(e,i,r,l,u)}}}(this.G,this.V))}static deserialize(t){return new Wo(t.G,t.V)}static serialize(t){return{G:t.G,V:t.V}}}function Jo(t){if(Array.isArray(t))return t.map(Jo);if(t instanceof Object&&!(t instanceof Number||t instanceof String||t instanceof Boolean)){const e={};for(const i in t)e[i]=Jo(t[i]);return e}return function(t){return t instanceof Number||t instanceof String||t instanceof Boolean?t.valueOf():t}(t)}function Ho(t){if(!0===t||!1===t)return!0;if(!Array.isArray(t)||0===t.length)return!1;switch(t[0]){case"has":return t.length>=2&&"$id"!==t[1]&&"$type"!==t[1];case"in":return t.length>=3&&("string"!=typeof t[1]||Array.isArray(t[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==t.length||Array.isArray(t[1])||Array.isArray(t[2]);case"any":case"all":for(const e of t.slice(1))if(!Ho(e)&&"boolean"!=typeof e)return!1;return!0;default:return!0}}function Go(t){if(!Array.isArray(t))return!1;if(function(t){return"pitch"===t||"distance-from-center"===t}(t[0]))return!0;for(let e=1;e<t.length;e++)if(Go(t[e]))return!0;return!1}const Vo=new Set(["in","==","!=",">",">=","<","<=","to-boolean"]);function Bo(t,e){return t<e?-1:t>e?1:0}function Xo(t){if(!t)return!0;const e=t[0];return t.length<=1?"any"!==e:"=="===e?Zo(t[1],t[2],"=="):"!="===e?Qo(Zo(t[1],t[2],"==")):"<"===e||">"===e||"<="===e||">="===e?Zo(t[1],t[2],e):"any"===e?(i=t.slice(1),["any"].concat(i.map(Xo))):"all"===e?["all"].concat(t.slice(1).map(Xo)):"none"===e?["all"].concat(t.slice(1).map(Xo).map(Qo)):"in"===e?Yo(t[1],t.slice(2)):"!in"===e?Qo(Yo(t[1],t.slice(2))):"has"===e?Ko(t[1]):"!has"===e?Qo(Ko(t[1])):"within"!==e||t;var i}function Zo(t,e,i){switch(t){case"$type":return["filter-type-"+i,e];case"$id":return["filter-id-"+i,e];default:return["filter-"+i,t,e]}}function Yo(t,e){if(0===e.length)return!1;switch(t){case"$type":return["filter-type-in",["literal",e]];case"$id":return["filter-id-in",["literal",e]];default:return e.length>200&&!e.some(t=>typeof t!=typeof e[0])?["filter-in-large",t,["literal",e.sort(Bo)]]:["filter-in-small",t,["literal",e]]}}function Ko(t){switch(t){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",t]}}function Qo(t){return["!",t]}xn((function(t,e){var i=function(){var t=function(t,e,i,n){for(i=i||{},n=t.length;n--;i[t[n]]=e);return i},e=[1,12],i=[1,13],n=[1,9],r=[1,10],o=[1,11],s=[1,14],a=[1,15],l=[14,18,22,24],u=[18,22],c=[22,24],h={trace:function(){},yy:{},symbols_:{error:2,JSONString:3,STRING:4,JSONNumber:5,NUMBER:6,JSONNullLiteral:7,NULL:8,JSONBooleanLiteral:9,TRUE:10,FALSE:11,JSONText:12,JSONValue:13,EOF:14,JSONObject:15,JSONArray:16,"{":17,"}":18,JSONMemberList:19,JSONMember:20,":":21,",":22,"[":23,"]":24,JSONElementList:25,$accept:0,$end:1},terminals_:{2:"error",4:"STRING",6:"NUMBER",8:"NULL",10:"TRUE",11:"FALSE",14:"EOF",17:"{",18:"}",21:":",22:",",23:"[",24:"]"},productions_:[0,[3,1],[5,1],[7,1],[9,1],[9,1],[12,2],[13,1],[13,1],[13,1],[13,1],[13,1],[13,1],[15,2],[15,3],[20,3],[19,1],[19,3],[16,2],[16,3],[25,1],[25,3]],performAction:function(t,e,i,n,r,o,s){var a=o.length-1;switch(r){case 1:this.$=new String(t.replace(/\\\\(\\\\|")/g,"$1").replace(/\\\\n/g,"\\n").replace(/\\\\r/g,"\\r").replace(/\\\\t/g,"\\t").replace(/\\\\v/g,"\\v").replace(/\\\\f/g,"\\f").replace(/\\\\b/g,"\\b")),this.$.B=this.X.first_line;break;case 2:this.$=new Number(t),this.$.B=this.X.first_line;break;case 3:this.$=null;break;case 4:this.$=new Boolean(!0),this.$.B=this.X.first_line;break;case 5:this.$=new Boolean(!1),this.$.B=this.X.first_line;break;case 6:return this.$=o[a-1];case 13:this.$={},Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 14:case 19:this.$=o[a-1],Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 15:this.$=[o[a-2],o[a]];break;case 16:this.$={},this.$[o[a][0]]=o[a][1];break;case 17:this.$=o[a-2],o[a-2][o[a][0]]=o[a][1];break;case 18:this.$=[],Object.defineProperty(this.$,"B",{value:this.X.first_line,enumerable:!1});break;case 20:this.$=[o[a]];break;case 21:this.$=o[a-2],o[a-2].push(o[a])}},table:[{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,12:1,13:2,15:7,16:8,17:s,23:a},{1:[3]},{14:[1,16]},t(l,[2,7]),t(l,[2,8]),t(l,[2,9]),t(l,[2,10]),t(l,[2,11]),t(l,[2,12]),t(l,[2,3]),t(l,[2,4]),t(l,[2,5]),t([14,18,21,22,24],[2,1]),t(l,[2,2]),{3:20,4:e,18:[1,17],19:18,20:19},{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:23,15:7,16:8,17:s,23:a,24:[1,21],25:22},{1:[2,6]},t(l,[2,13]),{18:[1,24],22:[1,25]},t(u,[2,16]),{21:[1,26]},t(l,[2,18]),{22:[1,28],24:[1,27]},t(c,[2,20]),t(l,[2,14]),{3:20,4:e,20:29},{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:30,15:7,16:8,17:s,23:a},t(l,[2,19]),{3:5,4:e,5:6,6:i,7:3,8:n,9:4,10:r,11:o,13:31,15:7,16:8,17:s,23:a},t(u,[2,17]),t(u,[2,15]),t(c,[2,21])],defaultActions:{16:[2,6]},parseError:function(t,e){if(!e.recoverable)throw new Error(t);this.trace(t)},parse:function(t){var e=this,i=[0],n=[null],r=[],o=this.table,s="",a=0,l=0,u=2,c=1,h=r.slice.call(arguments,1),d=Object.create(this.lexer),f={yy:{}};for(var p in this.yy)Object.prototype.hasOwnProperty.call(this.yy,p)&&(f.yy[p]=this.yy[p]);d.setInput(t,f.yy),f.yy.lexer=d,f.yy.parser=this,void 0===d.yylloc&&(d.yylloc={});var m=d.yylloc;r.push(m);var y=d.options&&d.options.ranges;function g(){var t;return"number"!=typeof(t=d.lex()||c)&&(t=e.symbols_[t]||t),t}this.parseError="function"==typeof f.yy.parseError?f.yy.parseError:Object.getPrototypeOf(this).parseError;for(var b,v,w,x,k,M,j,A={};;){if(this.defaultActions[v=i[i.length-1]]?w=this.defaultActions[v]:(null==b&&(b=g()),w=o[v]&&o[v][b]),void 0===w||!w.length||!w[0]){var F="";for(k in j=[],o[v])this.terminals_[k]&&k>u&&j.push("\'"+this.terminals_[k]+"\'");F=d.showPosition?"Parse error on line "+(a+1)+":\\n"+d.showPosition()+"\\nExpecting "+j.join(", ")+", got \'"+(this.terminals_[b]||b)+"\'":"Parse error on line "+(a+1)+": Unexpected "+(b==c?"end of input":"\'"+(this.terminals_[b]||b)+"\'"),this.parseError(F,{text:d.match,token:this.terminals_[b]||b,line:d.yylineno,loc:m,expected:j})}if(w[0]instanceof Array&&w.length>1)throw new Error("Parse Error: multiple actions possible at state: "+v+", token: "+b);switch(w[0]){case 1:i.push(b),n.push(d.yytext),r.push(d.yylloc),i.push(w[1]),b=null,l=d.yyleng,s=d.yytext,a=d.yylineno,m=d.yylloc;break;case 2:if(A.$=n[n.length-(M=this.productions_[w[1]][1])],A.X={first_line:r[r.length-(M||1)].first_line,last_line:r[r.length-1].last_line,first_column:r[r.length-(M||1)].first_column,last_column:r[r.length-1].last_column},y&&(A.X.range=[r[r.length-(M||1)].range[0],r[r.length-1].range[1]]),void 0!==(x=this.performAction.apply(A,[s,l,a,f.yy,w[1],n,r].concat(h))))return x;M&&(i=i.slice(0,-1*M*2),n=n.slice(0,-1*M),r=r.slice(0,-1*M)),i.push(this.productions_[w[1]][0]),n.push(A.$),r.push(A.X),i.push(o[i[i.length-2]][i[i.length-1]]);break;case 3:return!0}}return!0}};function d(){this.yy={}}return h.lexer={EOF:1,parseError:function(t,e){if(!this.yy.parser)throw new Error(t);this.yy.parser.parseError(t,e)},setInput:function(t,e){return this.yy=e||this.yy||{},this.Z=t,this.Y=this.K=this.done=!1,this.yylineno=this.yyleng=0,this.yytext=this.matched=this.match="",this.conditionStack=["INITIAL"],this.yylloc={first_line:1,first_column:0,last_line:1,last_column:0},this.options.ranges&&(this.yylloc.range=[0,0]),this.offset=0,this},input:function(){var t=this.Z[0];return this.yytext+=t,this.yyleng++,this.offset++,this.match+=t,this.matched+=t,t.match(/(?:\\r\\n?|\\n).*/g)?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this.Z=this.Z.slice(1),t},unput:function(t){var e=t.length,i=t.split(/(?:\\r\\n?|\\n)/g);this.Z=t+this.Z,this.yytext=this.yytext.substr(0,this.yytext.length-e),this.offset-=e;var n=this.match.split(/(?:\\r\\n?|\\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),i.length-1&&(this.yylineno-=i.length-1);var r=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:i?(i.length===n.length?this.yylloc.first_column:0)+n[n.length-i.length].length-i[0].length:this.yylloc.first_column-e},this.options.ranges&&(this.yylloc.range=[r[0],r[0]+this.yyleng-e]),this.yyleng=this.yytext.length,this},more:function(){return this.Y=!0,this},reject:function(){return this.options.backtrack_lexer?(this.K=!0,this):this.parseError("Lexical error on line "+(this.yylineno+1)+". You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},less:function(t){this.unput(this.match.slice(t))},pastInput:function(){var t=this.matched.substr(0,this.matched.length-this.match.length);return(t.length>20?"...":"")+t.substr(-20).replace(/\\n/g,"")},upcomingInput:function(){var t=this.match;return t.length<20&&(t+=this.Z.substr(0,20-t.length)),(t.substr(0,20)+(t.length>20?"...":"")).replace(/\\n/g,"")},showPosition:function(){var t=this.pastInput(),e=new Array(t.length+1).join("-");return t+this.upcomingInput()+"\\n"+e+"^"},test_match:function(t,e){var i,n,r;if(this.options.backtrack_lexer&&(r={yylineno:this.yylineno,yylloc:{first_line:this.yylloc.first_line,last_line:this.last_line,first_column:this.yylloc.first_column,last_column:this.yylloc.last_column},yytext:this.yytext,match:this.match,matches:this.matches,matched:this.matched,yyleng:this.yyleng,offset:this.offset,Y:this.Y,Z:this.Z,yy:this.yy,conditionStack:this.conditionStack.slice(0),done:this.done},this.options.ranges&&(r.yylloc.range=this.yylloc.range.slice(0))),(n=t[0].match(/(?:\\r\\n?|\\n).*/g))&&(this.yylineno+=n.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:n?n[n.length-1].length-n[n.length-1].match(/\\r?\\n?/)[0].length:this.yylloc.last_column+t[0].length},this.yytext+=t[0],this.match+=t[0],this.matches=t,this.yyleng=this.yytext.length,this.options.ranges&&(this.yylloc.range=[this.offset,this.offset+=this.yyleng]),this.Y=!1,this.K=!1,this.Z=this.Z.slice(t[0].length),this.matched+=t[0],i=this.performAction.call(this,this.yy,this,e,this.conditionStack[this.conditionStack.length-1]),this.done&&this.Z&&(this.done=!1),i)return i;if(this.K){for(var o in r)this[o]=r[o];return!1}return!1},next:function(){if(this.done)return this.EOF;var t,e,i,n;this.Z||(this.done=!0),this.Y||(this.yytext="",this.match="");for(var r=this.tt(),o=0;o<r.length;o++)if((i=this.Z.match(this.rules[r[o]]))&&(!e||i[0].length>e[0].length)){if(e=i,n=o,this.options.backtrack_lexer){if(!1!==(t=this.test_match(i,r[o])))return t;if(this.K){e=!1;continue}return!1}if(!this.options.flex)break}return e?!1!==(t=this.test_match(e,r[n]))&&t:""===this.Z?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+". Unrecognized text.\\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){return this.next()||this.lex()},begin:function(t){this.conditionStack.push(t)},popState:function(){return this.conditionStack.length-1>0?this.conditionStack.pop():this.conditionStack[0]},tt:function(){return this.conditionStack.length&&this.conditionStack[this.conditionStack.length-1]?this.conditions[this.conditionStack[this.conditionStack.length-1]].rules:this.conditions.INITIAL.rules},topState:function(t){return(t=this.conditionStack.length-1-Math.abs(t||0))>=0?this.conditionStack[t]:"INITIAL"},pushState:function(t){this.begin(t)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(t,e,i,n){switch(i){case 0:break;case 1:return 6;case 2:return e.yytext=e.yytext.substr(1,e.yyleng-2),4;case 3:return 17;case 4:return 18;case 5:return 23;case 6:return 24;case 7:return 22;case 8:return 21;case 9:return 10;case 10:return 11;case 11:return 8;case 12:return 14;case 13:return"INVALID"}},rules:[/^(?:\\s+)/,/^(?:(-?([0-9]|[1-9][0-9]+))(\\.[0-9]+)?([eE][-+]?[0-9]+)?\\b)/,/^(?:"(?:\\\\[\\\\"bfnrt/]|\\\\u[a-fA-F0-9]{4}|[^\\\\\\0-\\x09\\x0a-\\x1f"])*")/,/^(?:\\{)/,/^(?:\\})/,/^(?:\\[)/,/^(?:\\])/,/^(?:,)/,/^(?::)/,/^(?:true\\b)/,/^(?:false\\b)/,/^(?:null\\b)/,/^(?:$)/,/^(?:.)/],conditions:{INITIAL:{rules:[0,1,2,3,4,5,6,7,8,9,10,11,12,13],inclusive:!0}}},d.prototype=h,h.Parser=d,new d}();e.parser=i,e.Parser=i.Parser,e.parse=function(){return i.parse.apply(i,arguments)}}));const ts={StyleExpression:Co,isExpression:No,isExpressionFilter:Ho,createExpression:Lo,createPropertyExpression:$o,normalizePropertyExpression:function(t,e){if(_o(t))return new Wo(t,e);if(No(t)){const i=$o(t,e);if("error"===i.result)throw new Error(i.value.map(t=>`${t.key}: ${t.message}`).join(", "));return i.value}{let i=t;return"string"==typeof t&&"color"===e.type&&(i=Gn.parse(t)),{kind:"constant",evaluate:()=>i}}},ZoomConstantExpression:Do,ZoomDependentExpression:Uo,StylePropertyFunction:Wo},{isExpressionFilter:es,isExpression:is,createExpression:ns}=ts,rs={};function os(t){if(!0===t)return function(){return!0};if(t&&t.condition){if("any"===t.type){const e=t.condition,i=[];for(let t=0;t<e.length;t++)i.push(os(e[t]));return(t,e)=>{for(let n=0;n<i.length;n++)if(i[n](t,e))return!0;return!1}}const e=os(t.condition);if(Zi(t.layer))return e;const i=e=>e.layer===t.layer;return(t,n)=>i(t)&&e(t,n)}if(es(t)){let e=function(t,e="fill"){if(null==t)return{filter:()=>!0,needGeometry:!1,needFeature:!1};Ho(t)||(t=Xo(t));const i=t;let n=!0;try{n=function(t){if(!Go(t))return t;let e=Jo(t);return function t(e){let i=!1;const n=[];if("case"===e[0]){for(let t=1;t<e.length-1;t+=2)i=i||Go(e[t]),n.push(e[t+1]);n.push(e[e.length-1])}else if("match"===e[0]){i=i||Go(e[1]);for(let t=2;t<e.length-1;t+=2)n.push(e[t+1]);n.push(e[e.length-1])}else if("step"===e[0]){i=i||Go(e[1]);for(let t=1;t<e.length-1;t+=2)n.push(e[t+1])}i&&(e.length=0,e.push("any",...n));for(let i=1;i<e.length;i++)t(e[i])}(e),e=function t(e){if(!Array.isArray(e))return e;const i=function(t){if(Vo.has(t[0]))for(let e=1;e<t.length;e++)if(Go(t[e]))return!0;return t}(e);return!0===i?i:i.map(e=>t(e))}(e),e}(i)}catch(t){console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\\nand paste the contents of this message in the report.\\nThank you!\\nFilter Expression:\\n${JSON.stringify(i,null,2)}\\n `)}const r=vn["filter_"+e],o=Lo(n,r);let s=null;if("error"===o.result)throw new Error(o.value.map(t=>`${t.key}: ${t.message}`).join(", "));s=(t,e,i)=>o.value.evaluate(t,e,{},i);let a=null,l=null;if(n!==i){const t=Lo(i,r);if("error"===t.result)throw new Error(t.value.map(t=>`${t.key}: ${t.message}`).join(", "));a=(e,i,n,r,o)=>t.value.evaluate(e,i,{},n,void 0,void 0,r,o),l=!Sr(t.value.expression)}return s=s,{filter:s,dynamicFilter:a||void 0,needGeometry:function t(e){if(!Array.isArray(e))return!1;if("within"===e[0])return!0;for(let i=1;i<e.length;i++)if(t(e[i]))return!0;return!1}(n),needFeature:!!l}}(t);return e=e&&e.filter,(t,i)=>(rs.zoom=i,e&&e(rs,t))}return Lt(t)}const ss={type:"number","property-type":"data-driven",expression:{parameters:["zoom","feature"]}};function as(t,e){ss.type=e||"number";const i=ns(t,ss);if("success"!==i.result)throw new Error(`Invalid maplibre spec expression: ${JSON.stringify(t)} (${i.value})`);return i.value}function ls(t){return is(t)}const us={lineWidth:1,lineStrokeWidth:1,lineDx:1,lineDy:1,lineOpacity:1,linePatternAnimSpeed:1,markerWidth:1,markerHeight:1,markerDx:1,markerDy:1,markerSpacing:1,markerOpacity:1,markerRotation:1,textWrapWidth:1,textSpacing:1,textSize:1,textHaloRadius:1,textHaloOpacity:1,textDx:1,textDy:1,textOpacity:1,textRotation:1,polygonOpacity:1};function cs(t){return us[t]}function hs(t){return"textName"===t||"textPlacement"===t||"markerPlacement"===t||"markerFile"===t?"string":cs(t)?"number":"color"}var ds=Object.freeze({__proto__:null,compileStyle:function(t){return function t(e){if(!Array.isArray(e))return t([e]);const i=[];for(let t=0;t<e.length;t++){let n;n=!0===e[t].filter?function(){return!0}:os(e[t].filter),i.push(Xi({},e[t],{filter:n}))}return i}(t=t.map(t=>{const e=Xi({},t);return e.filter&&e.filter.value&&(e.filter=e.filter.value),e}))},compileFilter:os,createExpression:as,isExpression:ls,isInterpolated:cs,getExpressionType:hs});const fs=[],ps={},ms={},ys={},gs=[];class bs{static isAtlasLoaded(t,e={}){const{iconAtlas:i}=e;return!!(!t||i&&i.positions[t])}static genFnTypes(t){const e={};for(const i in t)if(ls(t[i])){const n=(i+"_Fn_0").trim(),r=(i+"Fn").trim(),o=hs(i);e[n]=as(t[i],o),e[r]=(t,i)=>{let r;ps.zoom=t,ms.properties=i;try{r=e[n].evaluateWithoutErrorHandling(ps,ms,ys,null,gs)}catch(t){return null}return r}}else if(on(t[i])){const n=(i+"_Fn_0").trim(),r=(i+"Fn").trim();cs(i)?(e[n]=a(t[i]),e[r]=(t,i)=>{const r=e[n](t,i);return on(r)?a(r)(t,i):r}):(e[n]=l(t[i]),e[r]=(t,i)=>{const r=e[n](t,i);return on(r)?l(r)(t,i):r})}return e}constructor(t,e,i){this.options=i,this.symbolDef=e,this.symbol=u(e,()=>[i.zoom]),this.styledVectors=[],this.properties={},this.et=i.fnTypes||bs.genFnTypes(this.symbolDef),on(this.symbolDef.visible)&&(this.it=a(this.symbolDef.visible)),i.atlas&&(this.iconAtlas=i.atlas.iconAtlas,this.glyphAtlas=i.atlas.glyphAtlas),this.features=this.nt(t)}needAltitudeAttribute(){return this.options.forceAltitudeAttribute||this.maxPosZ>=Math.pow(2,17)||this.options.positionType===Float32Array}getPositionFormat(){return this.needAltitudeAttribute()?[{type:Int16Array,width:2,name:"aPosition"},{type:Float32Array,width:1,name:"aAltitude"}]:[{type:Int16Array,width:3,name:"aPosition"}]}fillPosition(t,e,i,n){this.needAltitudeAttribute()?(t.aPosition.push(e,i),t.aAltitude.push(n)):(yn(fs,e,i,n),t.aPosition.push(...fs))}nt(t){if(!t.length)return t;const e="__fea_idx".trim();let i,n=0,r=t[n];for(;!r.geometry;)n++,r=t[n];if(Array.isArray(r.geometry)&&r.properties){let e=r.geometry[0];for(;Array.isArray(e);)e=e[0];e instanceof Ot&&(i=t)}if(!i)if(i=[],Array.isArray(r.geometry))for(let e=0;e<t.length;e++){const n=Xi({},t[e]);i.push(Bi(n))}else for(let n=0;n<t.length;n++){const r=t[n],o=Si(r);for(let t=0;t<o.length;t++){const n=o[t];n[e]=r[e],i.push(n)}}if(this.maxPosZ=0,!this.options.forceAltitudeAttribute){const t="line"===this.symbolDef.textPlacement;let e=0,n=!1;const{textPitchAlignmentFn:r}=this.et;!r&&t&&"map"===this.symbolDef.textPitchAlignment&&(n=!0);for(let o=0;o<i.length;o++){const s=ws(i[o]&&i[o].geometry);if(s>e&&(e=s),t&&!n&&r&&i[o].properties){const t=r(null,i[o].properties);"map"===t&&(n=t)}}this.hasMapPitchAlign=n,this.maxPosZ=e}const o=this.options.order;if(o){const t=[];for(let e=0;e<o.length;e++)o[e]&&t.push(os(o[e]));i=i.sort((e,i)=>{const n=t.length;let r=n,o=n;for(let s=0;s<n&&(t[s](e)&&(r=s),t[s](i)&&(o=s),!(r<n&&o<n));s++);return r-o})}return i}load(t=1){const e="__fea_idx".trim(),i="_debug_info".trim(),n=this.et,r=this.styledVectors;this.count=0;const o=this.features;if(!o||!o.length)return Promise.resolve(null);const s={},a={},l={zoom:this.options.zoom},c=u(this.symbolDef,()=>[l.zoom]);let h=0,d=o.length;const f=this.options.debugIndex;try{for(;h<d;h++){const t=o[h];if(!t||!t.geometry)continue;if(void 0!==f&&t[i].index!==f)continue;t.properties||(t.properties={}),t.properties.$layer=t.layer,t.properties.$type=t.type;const u=this.createStyledVector(t,c,n,l,s,a);u&&u.feature.geometry&&(u.featureIdx=void 0===t[e]?h:t[e],this.count++,r.push(u))}}catch(t){return Promise.reject(t)}return this.options.atlas?Promise.resolve(this.pack(t)):this.loadAtlas(s,a).then(()=>this.pack(t))}loadAtlas(t,e){return new Promise((i,n)=>{this.fetchAtlas(t,e,(t,e)=>{if(t)n(t);else{if(e){const{icons:t,glyphs:i}=e;if(t&&Object.keys(t).length){for(const e in t){const i=t[e],{width:n,height:r,data:o}=i.data;i.data=new Li({width:n,height:r},o)}this.iconAtlas=new Ui(t)}if(i&&Object.keys(i).length){for(const t in i){const e=i[t];for(const t in e){const i=e[t],{width:n,height:r,data:o}=i.bitmap;i.bitmap=new Ni({width:n,height:r},o)}}this.glyphAtlas=new Ji(i)}}i({glyphAtlas:this.glyphAtlas,iconAtlas:this.iconAtlas})}})})}fetchAtlas(t,e,i){Object.keys(t).length>0||Object.keys(e).length>0?this.options.requestor(t,e,i):i()}pack(t){if(!this.count)return null;if(null==t)throw new Error("layout scale is undefined");const e=this.createDataPack(this.styledVectors,t);if(!e)return null;e.properties=this.properties,this.empty&&(e.empty=!0);const i=e.buffers;delete e.buffers;const n={data:e,buffers:i};if(this.iconAtlas){const t=n.data.iconAtlas=vs(this.iconAtlas);if(t.glyphMap)for(const e in t.glyphMap)i.push(t.glyphMap[e].data.data.buffer);i.push(n.data.iconAtlas.image.data.buffer)}return this.glyphAtlas&&(n.data.glyphAtlas=vs(this.glyphAtlas),i.push(n.data.glyphAtlas.image.data.buffer)),n}createStyledVector(t,e,i,n){return new mn(t,e,i,n)}createDataPack(t,e){if(!t||!t.length)return null;this.maxIndex=0,this.maxPos=0,this.maxAltitude=0;const i=this.data={};let n=this.elements=[];const r=this.getFormat(Array.isArray(t[0])?t[0][0].symbol:t[0].symbol),o=this.needAltitudeAttribute()?2:3;for(let t=0;t<r.length;t++)i[r[t].name]=[];let s=[],a=0;const l=[];let u=0,c=!1;for(let n=0,r=t.length;n<r;n++){if(!t[n].feature.geometry)continue;const r=Array.isArray(t[n])?t[n][0].feature.id:t[n].feature.id;Yi(r)&&(Math.abs(r)>u&&(u=Math.abs(r)),r<0&&(c=!0));const h=this.data.aPosition.length;if(Array.isArray(t[n]))for(let i=0;i<t[n].length;i++)this.rt(t[n][i],e);else this.rt(t[n],e);const d=(i.aPosition.length-h)/o;for(let e=0;e<d;e++)s.push(t[n].featureIdx),Yi(r)&&l.push(r);a=Math.max(a,t[n].featureIdx)}if(this.hasElements()&&!n.length)return null;s=new(Vi(a))(s),r[0].type=this.options.positionType?this.options.positionType:Gi(this.maxPos);const h=this.options.center;if(h&&(h[0]||h[1])){const t=i.aPosition;for(let e=0;e<t.length;e+=o)t[e]-=h[0],t[e+1]-=h[1]}const d=function(t,e){const i={};for(let n=0;n<t.length;n++){const r=t[n],o=r.type,s=r.name;i[s]=o===Array?e[s]:new o(e[s])}return i}(r,i);d.aPickingId=s;const f=[];for(const t in d)f.push(d[t].buffer);n=new(Hi(this.maxIndex))(n),f.push(n.buffer);const p={data:d,indices:this.hasElements()?n:null,positionSize:o,buffers:f,symbolIndex:this.symbolDef.index||{index:0}};if(l.length){const t=c?Gi(u):Vi(u);p.featureIds=new t(l),f.push(p.featureIds.buffer)}else p.featureIds=[];return p}rt(t,e){this.it&&this.it.isZoomConstant&&!this.it(null,t.feature.properties)||this.placeVector(t,e,this.formatWidth)}addElements(...t){this.maxIndex=Math.max(this.maxIndex,...t),this.elements.push(...t)}hasElements(){return!0}getAltitude(t){const{altitudeProperty:e,defaultAltitude:i,altitudeScale:n}=this.options;let r=cn(t,e,i);return n&&(r*=n),this.maxAltitude=Math.max(this.maxAltitude,Math.abs(r)),r}getIconAtlasMaxValue(){const t=this.iconAtlas.positions;let e=0;for(const i in t)if(nn(t,i)){const{tl:n,displaySize:r}=t[i],o=Math.max(n[0],n[1],r[0]-1,r[1]-1);o>e&&(e=o)}return e}}function vs(t){let e=t.positions,i=t.image&&t.image.format||"alpha";if(t instanceof Ui){e={};for(const i in t.positions){const n=t.positions[i];e[i]={paddedRect:n.paddedRect,pixelRatio:n.pixelRatio,tl:n.tl,br:n.br,displaySize:n.displaySize}}i="rgba"}const n=t.image;return{image:{width:n.width,height:n.height,data:n.data,format:i},glyphMap:t.glyphMap,positions:e}}function ws(t){if(!t)return 0;let e=0;if(Array.isArray(t))for(let i=0;i<t.length;i++)if(Array.isArray(t[i])){const n=ws(t[i]);n>e&&(e=n)}else{const n=Math.abs(t[i].z||0);n>e&&(e=n)}else{const i=Math.abs(t.z||0);i>e&&(e=i)}return e}function xs(t,e,i,n){const r="__fn_textSize".trim();let o=t.textSize;if(Zi(e.textSize))return[16,16];t[r]&&(o=t[r]);const s=[];return s[0]=tn(o)?o(n,i):o,s[1]=s[0],s}function ks(t){const e=t.stops;let i=-1/0;for(let t=0;t<e.length;t++){let n=e[t][1];Ki(e[t][1])&&(n=ks(e[t][1])),n>i&&(i=n)}return i}function Ms(t,e,i){return[e||"normal",i||"normal","24px",t||"monospace"].join(" ")}const js=/\\{[\\w-]+(?:\\|[\\w-]+)*\\}/g;function As(t,e){return Qi(t)?t.replace(js,(function(t){if(!e)return"";if((t=t.substring(1,t.length-1)).indexOf("|")>0){const i=t.split("|");for(let t=0;t<i.length;t++){const n=e[i[t]];if(!Zi(n))return n}return""}const i=e[t];return Zi(i)?"":Array.isArray(i)?i.join():i})):t}Object.freeze({__proto__:null,getSDFFont:Ms,resolveText:As});const Fs=t=>t>=11904&&t<=12031,Ts=t=>t>=12032&&t<=12255,zs=t=>t>=12272&&t<=12287,Ss=t=>t>=12288&&t<=12351,_s=t=>t>=12352&&t<=12447,Ps=t=>t>=12448&&t<=12543,Is=t=>t>=12544&&t<=12591,Os=t=>t>=12704&&t<=12735,Es=t=>t>=12736&&t<=12783,qs=t=>t>=12784&&t<=12799,Rs=t=>t>=12800&&t<=13055,Cs=t=>t>=13056&&t<=13311,Ns=t=>t>=13312&&t<=19903,Ls=t=>t>=19968&&t<=40959,Ds=t=>t>=40960&&t<=42127,Us=t=>t>=42128&&t<=42191,$s=t=>t>=63744&&t<=64255,Ws=t=>t>=64336&&t<=65023,Js=t=>t>=65040&&t<=65055,Hs=t=>t>=65072&&t<=65103,Gs=t=>t>=65104&&t<=65135,Vs=t=>t>=65136&&t<=65279,Bs=t=>t>=65280&&t<=65519;function Xs(t){return!((t=>t>=1536&&t<=1791)(t)||(t=>t>=1872&&t<=1919)(t)||(t=>t>=2208&&t<=2303)(t)||Ws(t)||Vs(t))}function Zs(t){return!!(746===t||747===t||!(t<4352)&&(Os(t)||Is(t)||Hs(t)&&!(t>=65097&&t<=65103)||$s(t)||Cs(t)||Fs(t)||Es(t)||!(!Ss(t)||t>=12296&&t<=12305||t>=12308&&t<=12319||12336===t)||Ns(t)||Ls(t)||Rs(t)||(t=>t>=12592&&t<=12687)(t)||(t=>t>=43360&&t<=43391)(t)||(t=>t>=55216&&t<=55295)(t)||(t=>t>=4352&&t<=4607)(t)||(t=>t>=44032&&t<=55215)(t)||_s(t)||zs(t)||(t=>t>=12688&&t<=12703)(t)||Ts(t)||qs(t)||Ps(t)&&12540!==t||!(!Bs(t)||65288===t||65289===t||65293===t||t>=65306&&t<=65310||65339===t||65341===t||65343===t||t>=65371&&t<=65503||65507===t||t>=65512&&t<=65519)||!(!Gs(t)||t>=65112&&t<=65118||t>=65123&&t<=65126)||(t=>t>=5120&&t<=5759)(t)||(t=>t>=6320&&t<=6399)(t)||Js(t)||(t=>t>=19904&&t<=19967)(t)||Ds(t)||Us(t)))}function Ys(t){return!(Zs(t)||function(t){return!!((t=>t>=128&&t<=255)(t)&&(167===t||169===t||174===t||177===t||188===t||189===t||190===t||215===t||247===t)||(t=>t>=8192&&t<=8303)(t)&&(8214===t||8224===t||8225===t||8240===t||8241===t||8251===t||8252===t||8258===t||8263===t||8264===t||8265===t||8273===t)||(t=>t>=8448&&t<=8527)(t)||(t=>t>=8528&&t<=8591)(t)||(t=>t>=8960&&t<=9215)(t)&&(t>=8960&&t<=8967||t>=8972&&t<=8991||t>=8996&&t<=9e3||9003===t||t>=9085&&t<=9114||t>=9150&&t<=9165||9167===t||t>=9169&&t<=9179||t>=9186&&t<=9215)||(t=>t>=9216&&t<=9279)(t)&&9251!==t||(t=>t>=9280&&t<=9311)(t)||(t=>t>=9312&&t<=9471)(t)||(t=>t>=9632&&t<=9727)(t)||(t=>t>=9728&&t<=9983)(t)&&!(t>=9754&&t<=9759)||(t=>t>=11008&&t<=11263)(t)&&(t>=11026&&t<=11055||t>=11088&&t<=11097||t>=11192&&t<=11243)||Ss(t)||Ps(t)||(t=>t>=57344&&t<=63743)(t)||Hs(t)||Gs(t)||Bs(t)||8734===t||8756===t||8757===t||t>=9984&&t<=10087||t>=10102&&t<=10131||65532===t||65533===t)}(t))}function Ks(t){return t>=1424&&t<=2303||Ws(t)||Vs(t)}const Qs=[[9,9],[32,32],[5760,5760],[8192,8198],[8200,8202],[8287,12288],[6158,6158],[8203,8205]];function ta(t){for(const e of Qs)if(t>=e[0]&&t<=e[1])return!0;return!1}const ea={"!":"︕","#":"#",$:"$","%":"%","&":"&","(":"︵",")":"︶","*":"*","+":"+",",":"︐","-":"︲",".":"・","/":"/",":":"︓",";":"︔","<":"︿","=":"=",">":"﹀","?":"︖","@":"@","[":"﹇","\\\\":"\","]":"﹈","^":"^",ot:"︳","`":"`","{":"︷","|":"―","}":"︸","~":"~","¢":"¢","£":"£","¥":"¥","¦":"¦","¬":"¬","¯":" ̄","–":"︲","—":"︱","‘":"﹃","’":"﹄","“":"﹁","”":"﹂","…":"︙","‧":"・","₩":"₩","、":"︑","。":"︒","〈":"︿","〉":"﹀","《":"︽","》":"︾","「":"﹁","」":"﹂","『":"﹃","』":"﹄","【":"︻","】":"︼","〔":"︹","〕":"︺","〖":"︗","〗":"︘","!":"︕","(":"︵",")":"︶",",":"︐","-":"︲",".":"・",":":"︓",";":"︔","<":"︿",">":"﹀","?":"︖","[":"﹇","]":"﹈","_":"︳","{":"︷","|":"―","}":"︸","⦅":"︵","⦆":"︶","。":"︒","「":"﹁","」":"﹂"};function ia(t,e,i,n,r,o,s,a,l,u){let c=t.trim();2===u&&(c=function(t){let e="";for(let i=0;i<t.length;i++){const n=t.charCodeAt(i+1)||null,r=t.charCodeAt(i-1)||null;e+=n&&Ys(n)&&!ea[t[i+1]]||r&&Ys(r)&&!ea[t[i-1]]||!ea[t[i]]?t[i]:ea[t[i]]}return e}(c));const h=[],d={positionedGlyphs:h,text:c,top:a[1],bottom:a[1],left:a[0],right:a[0],writingMode:u};let f;return f=function(t,e){const i=[];let n=0;for(let r=0;r<e.length;r++){const o=e[r];i.push(t.substring(n,o)),n=o}return n<t.length&&i.push(t.substring(n,t.length)),i}(c,function(t,e,i,n){if(!i)return[];if(!t)return[];const r=[],o=function(t,e,i,n){let r=0;for(let i=0;i<t.length;i++){const o=n[t.charCodeAt(i)];o&&(r+=o.metrics.advance+e)}return r/Math.max(1,Math.ceil(r/i))}(t,e,i,n);let s=0;for(let i=0;i<t.length;i++){const l=t.charCodeAt(i),u=n[l];u&&!na[l]&&(s+=u.metrics.advance+e),i<t.length-1&&(ra[l]||!((a=l)<11904)&&(Os(a)||Is(a)||Hs(a)||$s(a)||Cs(a)||Fs(a)||Es(a)||Ss(a)||Ns(a)||Ls(a)||Rs(a)||Bs(a)||_s(a)||zs(a)||Ts(a)||qs(a)||Ps(a)||Js(a)||Us(a)||Ds(a)))&&r.push(aa(i+1,s,o,r,sa(l,t.charCodeAt(i+1)),!1))}var a;return function t(e){return e?t(e.priorBreak).concat(e.index):[]}(aa(t.length,s,o,r,0,!0))}(c,s,i,e)),function(t,e,i,n,r,o,s,a,l){let u=0,c=8,h=0;const d=t.positionedGlyphs,f="right"===o?1:"left"===o?0:.5;for(let t=0;t<i.length;t++){let r=i[t];if(r=r.trim(),!r.length){c-=n;continue}const o=d.length;for(let t=0;t<r.length;t++){const i=r.charCodeAt(t),n=e[i];n&&(Zs(i)&&1!==s?(32!==i&&d.push({glyph:i,x:u,y:0,vertical:!0}),u+=l+a):(32!==i&&d.push({glyph:i,x:u,y:c,vertical:!1}),u+=n.metrics.advance+a))}d.length!==o&&(h=Math.max(u-a,h),ua(d,e,o,d.length-1,f)),u=0,c-=n}const{horizontalAlign:p,verticalAlign:m}=la(r);!function(t,e,i,n,r,o,s){const a=(e-i)*r,l=-(-n*s+.5)*o;if(a||l)for(let e=0;e<t.length;e++)t[e].x+=a,t[e].y+=l}(d,f,p,m,h,n,i.length);const y=i.length*n;t.top+=-m*y,t.bottom=t.top+y,t.left+=-p*h,t.right=t.left+h}(d,e,f,n,r,o,u,s,l),!!h.length&&d}const na={9:!0,10:!0,11:!0,12:!0,13:!0,32:!0},ra={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 oa(t,e,i,n){const r=Math.pow(t-e,2);return n?t<e?r/2:2*r:r+Math.abs(i)*i}function sa(t,e){let i=0;return 10===t&&(i-=1e4),40!==t&&65288!==t||(i+=50),41!==e&&65289!==e||(i+=50),i}function aa(t,e,i,n,r,o){let s=null,a=oa(e,i,r,o);for(let t=0;t<n.length;t++){const l=n[t],u=oa(e-l.x,i,r,o)+l.badness;u<=a&&(s=l,a=u)}return{index:t,x:e,priorBreak:s,badness:a}}function la(t){let e=.5,i=.5;switch(t){case"right":case"top-right":case"bottom-right":e=1;break;case"left":case"top-left":case"bottom-left":e=0}switch(t){case"bottom":case"bottom-right":case"bottom-left":i=1;break;case"top":case"top-right":case"top-left":i=0}return{horizontalAlign:e,verticalAlign:i}}function ua(t,e,i,n,r){if(!r)return;const o=e[t[n].glyph];if(o){const e=(t[n].x+o.metrics.advance)*r;if(!e)return;for(let r=i;r<=n;r++)t[r].x-=e}}function ca(t){if(!function(t){for(const e of t)if(Ks(e.charCodeAt(0)))return!0;return!1}(t))return t;const e=[],i=[],n=[];let r=0,o=0,s=1,a=1;for(const l of t){const t=l.codePointAt(0);ta(t)?(n.push(l),r++):(s=Ks(t)?-1:1,a!==s?(o=r,i.length&&(a>0&&i.reverse(),e.push(...i)),n.length&&(e.splice(o,0,...n),n.length=0),a=s,i.length=0):n.length&&(i.push(...n),n.length=0),i.push(l),r++)}return n.length&&i.push(...n),i.length&&(a>0&&i.reverse(),e.push(...i)),e.reverse().join("")}const ha=/\\{ *([\\w_]+) *\\}/g;class da{constructor(t,e,i,n,r){this.feature=t,this.symbolDef=e,this.symbol=i,this.options=r,this.st=this.lt.bind(this),this.et=n}lt(t,e){return this.feature.properties[e]||"default"}getShape(t,e){if(this.ut)return this.ut;const{textHorizontalAlignmentFn:i,textVerticalAlignmentFn:n,markerHorizontalAlignmentFn:r,markerVerticalAlignmentFn:o,textWrapWidthFn:s}=this.et;let a;const l=this.symbol,u=this.getIconAndGlyph(),c=this.feature.properties;if(u&&u.glyph){const{font:t,text:r}=u.glyph;if(""===r)return null;const o=this.size[0]/24,h=24,d=l.textKeepUpright,f="map"===l.textRotationAlignment&&"line"===l.textPlacement&&!l.isIconText,p=e.glyphMap[t],m=fa(i?i(null,c):l.textHorizontalAlignment,n?n(null,c):l.textVerticalAlignment),y=1.2*h,g=function(t){for(let e=0;e<t.length;e++)if(!Xs(t.charAt(e).charCodeAt(0)))return!1;return!0}(r),b=g&&l.textLetterSpacing/o||0,v=[l.textDx/o||0,l.textDy/o||0],w=((s?s(null,c):l.textWrapWidth)||10*h)/o;a={},a.horizontal=ia(r,p,w,y,m,"center",b,v,h,1),g&&f&&d&&(a.vertical=ia(r,p,w,y,m,"center",b,v,h,2))}else if(u&&u.icon){if(!t.positions[u.icon.url])return null;const e=fa(r?r(null,c):l.markerHorizontalAlignment,o?o(null,c):l.markerVerticalAlignment);a=function(t,e){const{horizontalAlign:i,verticalAlign:n}=la(e),r=-24*i,o=-24*n;return{image:t,top:o,bottom:o+24,left:r,right:r+24}}(t.positions[u.icon.url],e),this.size||(this.size=a.image.displaySize)}return this.ut=a,a}getIconAndGlyph(){if(this.iconGlyph)return this.iconGlyph;const{markerFileFn:t,markerTypeFn:e,markerPathFn:i,markerWidthFn:n,markerHeightFn:r,markerFillFn:o,markerFillPatternFileFn:l,markerFillOpacityFn:u,markerTextFitFn:c,markerTextFitPaddingFn:h,markerLineColorFn:d,markerLineWidthFn:f,markerLineOpacityFn:p,markerLineDasharrayFn:m,markerLinePatternFileFn:y,markerPathWidthFn:g,markerPathHeightFn:b,textNameFn:v,textFaceNameFn:w,textStyleFn:x,textWeightFn:k}=this.et,{zoom:M}=this.options,j={},A=this.symbol,F=this.feature.properties,T=t?t(null,F):A.markerFile,z=e?e(null,F):A.markerType,S=T||z||A.markerPath,_=!Zi(this.symbolDef.textName);let P;if(S){P=function(t,e,i,n,r,o){if(Zi(e.markerWidth)&&Zi(e.markerHeight))return null;const s="__fn_markerWidth".trim(),a="__fn_markerHeight".trim();let l=e.markerWidth||0,u=e.markerHeight||0;return Ki(l)&&("identity"!==l.type?l=ks(l):(l=t.markerWidth,t[s]&&(l=t[s](n,i)),Ki(l)&&(l="identity"===l.type?r(n,i):ks(l)))),Ki(u)&&("identity"!==u.type?u=ks(u):(u=t.markerHeight,t[a]&&(u=t[a](n,i)),Ki(u)&&(u="identity"===u.type?o(n,i):ks(u)))),[l,u]}(A,this.symbolDef,F,M,n,r)||[0,0];let t=A.markerTextFit;if(c&&(t=c(M,F)),t&&A.text&&"none"!==t){const e=A.text.textSize;let i=A.text.textName;s(i)&&(i=a(i)(M,F));const n=As(i,F);if(n){const i="__fn_textSize".trim(),r="__fn_textSize_0".trim();s(e)&&!A.text[i]&&(A.text[r]=a(e),A.text[i]=(t,e)=>{const i=A.text[r](t,e);return s(i)?a(i)(t,e):i});const o=xs(A.text,A.text,F,M);if("width"!==t&&"both"!==t||(P[0]=o[0]*n.length),"height"!==t&&"both"!==t||(P[1]=o[1]),o[0]&&o[1]){let t=A.markerTextFitPadding||[0,0,0,0];h&&(t=h(M,F)),P[0]+=t[1]+t[3],P[1]+=t[0]+t[2]}}else P[0]=P[1]=-1}}if(_&&(P=xs(A,this.symbolDef,F,M)),!P)return j;if(P[0]=Math.ceil(P[0]),P[1]=Math.ceil(P[1]),this.size=P,S&&P[0]>=0&&P[1]>=0){let t;if(z){const e={};if(e.markerType=z,"path"===z&&(e.markerPath=i?i(null,F):A.markerPath,e.markerPathWidth=g?g(null,F):A.markerPathWidth,e.markerPathHeight=b?b(null,F):A.markerPathHeight),n){const t=n(null,F);Zi(t)||(e.markerWidth=t)}else A.markerWidth>=0&&(e.markerWidth=A.markerWidth);if(r){const t=r(null,F);Zi(t)||(e.markerHeight=t)}else A.markerHeight>=0&&(e.markerHeight=A.markerHeight);if(o){const t=o(null,F);Zi(t)||(e.markerFill=t)}else A.markerFill&&(e.markerFill=A.markerFill);if(l){const t=l(null,F);Zi(t)||(e.markerFillPatternFile=t)}else A.markerFillPatternFile&&(e.markerFillPatternFile=A.markerFillPatternFile);if(u){const t=u(null,F);Zi(t)||(e.markerFillOpacity=t)}else A.markerFillOpacity>=0&&(e.markerFillOpacity=A.markerFillOpacity);if(d){const t=d(null,F);Zi(t)||(e.markerLineColor=t)}else A.markerLineColor&&(e.markerLineColor=A.markerLineColor);if(f){const t=f(null,F);Zi(t)||(e.markerLineWidth=t)}else A.markerLineWidth>=0&&(e.markerLineWidth=A.markerLineWidth);if(p){const t=p(null,F);Zi(t)||(e.markerLineOpacity=t)}else A.markerLineOpacity>=0&&(e.markerLineOpacity=A.markerLineOpacity);if(m){const t=m(null,F);Zi(t)||(e.markerLineDasharray=t)}else A.markerLineDasharray&&(e.markerLineDasharray=A.markerLineDasharray);if(y){const t=y(null,F);Zi(t)||(e.markerLinePatternFile=t)}else A.markerLinePatternFile&&(e.markerLinePatternFile=A.markerLinePatternFile);t="vector://"+JSON.stringify(e)}else t=T?T.replace(ha,this.st):A.markerPath?function(t,e,i){if(!t.markerPath)return null;let n=1;const r=function(t){const e={stroke:{stroke:t.markerLineColor,"stroke-width":t.markerLineWidth,"stroke-opacity":t.markerLineOpacity,"stroke-dasharray":null,"stroke-linecap":"butt","stroke-linejoin":"round"},fill:{fill:t.markerFill,"fill-opacity":t.markerFillOpacity}};return 0===e.stroke["stroke-width"]&&(e.stroke["stroke-opacity"]=0),e}(t);Yi(t.markerOpacity)&&(n=t.markerOpacity),Yi(t.opacity)&&(n*=t.opacity);const o={};if(r){for(const t in r.stroke)nn(r.stroke,t)&&(Zi(r.stroke[t])||(o[t]=r.stroke[t]));for(const t in r.fill)nn(r.fill,t)&&(Zi(r.fill[t])||(o[t]=r.fill[t]))}const s=Array.isArray(t.markerPath)?t.markerPath:[t.markerPath];let a;const l=[];for(let t=0;t<s.length;t++)a=Qi(s[t])?{path:s[t]}:s[t],a=Xi({},a,o),a.d=a.path,delete a.path,l.push(a);const u=[\'<svg version="1.1"\',\'xmlns="http://www.w3.org/2000/svg"\'];n<1&&u.push(\'opacity="\'+n+\'"\'),t.markerPathWidth&&t.markerPathHeight&&u.push(\'viewBox="0 0 \'+t.markerPathWidth+" "+t.markerPathHeight+\'"\'),u.push(\'preserveAspectRatio="none"\'),e&&u.push(\'width="\'+e+\'"\'),i&&u.push(\'height="\'+i+\'"\'),u.push("><defs></defs>");for(let t=0;t<l.length;t++){let e="<path ";for(const i in l[t])nn(l[t],i)&&(e+=" "+i+\'="\'+l[t][i]+\'"\');e+="></path>",u.push(e)}return u.push("</svg>"),"data:image/svg+xml;base64,"+btoa(u.join(" "))}(A,P[0],P[1]):null;j.icon={url:t,size:P}}if(_){const t=v?v(this.options.zoom,F):A.textName;if(t||0===t){const e=Ms(w?w(null,F):A.textFaceName,x?x(null,F):A.textStyle,k?k(null,F):A.textWeight);let i=As(t,F);i&&i.length&&(i=ca(i),j.glyph={font:e,text:i})}}return this.iconGlyph=j,j}}function fa(t,e){e&&"middle"!==e||(e="center"),t&&"middle"!==t||(t="center");let i="center"!==e?e:"";return i+="center"!==t?(i.length?"-":"")+t:"",i\n/*!\n * From mapbox-gl-js\n * MIT License\n * https://github.com/mapbox/mapbox-gl-js\n */}function pa(t,e,i,n,r){const o=[];let s;for(let a=0;a<t.length;a++){const l=t[a];let u,c=!1;for(let t=0;t<l.length-1;t++){let a=l[t],h=l[t+1];a.x<e&&h.x<e||(a.x<e?(s=a,a=new Ot(e,a.y+(e-a.x)/(h.x-a.x)*(h.y-a.y)).P(),a.z=s.z+(e-s.x)/(h.x-s.x)*(h.z-s.z),c=!0):h.x<e&&(s=h,h=new Ot(e,a.y+(e-a.x)/(h.x-a.x)*(h.y-a.y)).P(),h.z=a.z+(e-a.x)/(s.x-a.x)*(s.z-a.z),c=!0),a.y<i&&h.y<i||(a.y<i?(s=a,a=new Ot(a.x+(i-a.y)/(h.y-a.y)*(h.x-a.x),i).P(),a.z=s.z+(i-s.y)/(h.y-s.y)*(h.z-s.z),c=!0):h.y<i&&(s=h,h=new Ot(a.x+(i-a.y)/(h.y-a.y)*(h.x-a.x),i).P(),h.z=a.z+(i-a.y)/(s.y-a.y)*(s.z-a.z),c=!0),a.x>=n&&h.x>=n||(a.x>=n?(s=a,a=new Ot(n,a.y+(n-a.x)/(h.x-a.x)*(h.y-a.y)).P(),a.z=s.z+(n-s.x)/(h.x-s.x)*(h.z-s.z),c=!0):h.x>=n&&(s=h,h=new Ot(n,a.y+(n-a.x)/(h.x-a.x)*(h.y-a.y)).P(),h.z=a.z+(n-a.x)/(s.x-a.x)*(s.z-a.z),c=!0),a.y>=r&&h.y>=r||(a.y>=r?(s=a,a=new Ot(a.x+(r-a.y)/(h.y-a.y)*(h.x-a.x),r).P(),a.z=s.z+(r-s.y)/(h.y-s.y)*(h.z-s.z),c=!0):h.y>=r&&(s=h,h=new Ot(a.x+(r-a.y)/(h.y-a.y)*(h.x-a.x),r).P(),h.z=a.z+(r-a.y)/(s.y-a.y)*(s.z-a.z),c=!0),u&&a.equals(u[u.length-1])||(u=[a],o.push(u)),c&&(u.clipped=!0),u.push(h)))))}}return o}class ma extends Ot{constructor(t,e,i,n){super(t,e),this.angle=i,void 0!==n&&(this.segment=n)}clone(){return new ma(this.x,this.y,this.angle,this.segment)}}\n/*!\n * From mapbox-gl-js\n * MIT License\n * https://github.com/mapbox/mapbox-gl-js\n */function ya(t,e,i,n,r){if(void 0===e.segment)return!0;let o=e,s=e.segment+1,a=0;for(;a>-i/2;){if(s--,s<0)return!1;a-=t[s].dist(o),o=t[s]}a+=t[s].dist(t[s+1]),s++;const l=[];let u=0;for(;a<i/2;){const e=t[s],i=t[s+1];if(!i)return!1;let o=t[s-1].angleTo(e)-e.angleTo(i);for(o=Math.abs((o+3*Math.PI)%(2*Math.PI)-Math.PI),l.push({distance:a,angleDelta:o}),u+=o;a-l[0].distance>n;)u-=l.shift().angleDelta;if(u>r)return!1;s++,a+=e.dist(i)}return!0}function ga(t,e,i,n,r,o,s,a,l,u,c){const h=function(t,e,i){return t?.6*e*i:0}(n,o,s),d=function(t,e){return Math.max(t?t.right-t.left:0,e?e.right-e.left:0)}(n,r),f=0===t[0].x||t[0].x===l||0===t[0].y||t[0].y===l;return e-d*s<e/4&&(e=d*s+e/4),function t(e,i,n,r,o,s,a,l,u,c,h){const d=s/2,f=function(t){let e=0;for(let i=0;i<t.length-1;i++)e+=t[i].dist(t[i+1]);return e}(e);let p=0,m=i-n,y=[];for(let t=0;t<e.length-1;t++){const i=e[t],a=e[t+1],l=i.dist(a),g=a.angleTo(i);for(;m+n<p+l;){m+=n;const b=(m-p)/l,v=ba(i.x,a.x,b),w=ba(i.y,a.y,b),x=ba(i.z||0,a.z||0,b);if(v>=0&&v<u&&w>=0&&w<u&&m-d>=0&&m+d<=f){const n=new ma(v,w,g,t);n.z=x,c&&(n.axis=[i.y-w,v-i.x],n.angleR=x===(i.z||0)?0:Math.atan(.9*(x-(i.z||0))*h/i.dist(n))),n.line=e,n.P(),r&&!ya(e,n,s,r,o)||y.push(n)}}p+=l}return l||y.length||a||(y=t(e,p/2,n,r,o,s,a,!0,u,c,h)),y}(t,f?e/2*a%e:(d/2+2*o)*s*a%e,e,h,i,d*s,f,!1,l,u,c)}function ba(t,e,i){return t*(1-i)+e*i}function va(t,e){const i=t.length;if(i<=1)return[t];const n=[];let r,o;for(let e=0;e<i;e++){const i=ln(t[e]);0!==i&&(t[e].area=Math.abs(i),void 0===o&&(o=i<0),o===i<0?(r&&n.push(r),r=[t[e]]):r.push(t[e]))}if(r&&n.push(r),e>1)for(let t=0;t<n.length;t++)n[t].length<=e||(Xt(n[t],e,1,n[t].length-1,wa),n[t]=n[t].slice(0,e));return n}function wa(t,e){return e.area-t.area}function xa(t,e,i){const n=e.distSqr(i);if(0===n)return t.distSqr(e);const r=((t.x-e.x)*(i.x-e.x)+(t.y-e.y)*(i.y-e.y))/n;return t.distSqr(r<0?e:r>1?i:i.sub(e).M(r).u(e))}function ka(t,e=1,i=!1){let n=1/0,r=1/0,o=-1/0,s=-1/0;const a=t[0];for(let t=0;t<a.length;t++){const e=a[t];(!t||e.x<n)&&(n=e.x),(!t||e.y<r)&&(r=e.y),(!t||e.x>o)&&(o=e.x),(!t||e.y>s)&&(s=e.y)}const l=Math.min(o-n,s-r);let u=l/2;const c=new Qt(null,Ma);if(0===l)return new Ot(n,r);for(let e=n;e<o;e+=l)for(let i=r;i<s;i+=l)c.push(new ja(e+u,i+u,u,t));let h=function(t){let e=0,i=0,n=0;const r=t[0];for(let t=0,o=r.length,s=o-1;t<o;s=t++){const o=r[t],a=r[s],l=o.x*a.y-a.x*o.y;i+=(o.x+a.x)*l,n+=(o.y+a.y)*l,e+=3*l}return new ja(i/e,n/e,0,t)}(t),d=c.length;for(;c.length;){const n=c.pop();(n.d>h.d||!h.d)&&(h=n,i&&console.log("found best %d after %d probes",Math.round(1e4*n.d)/1e4,d)),n.max-h.d<=e||(u=n.h/2,c.push(new ja(n.p.x-u,n.p.y-u,u,t)),c.push(new ja(n.p.x+u,n.p.y-u,u,t)),c.push(new ja(n.p.x-u,n.p.y+u,u,t)),c.push(new ja(n.p.x+u,n.p.y+u,u,t)),d+=4)}return i&&(console.log("num probes: "+d),console.log("best distance: "+h.d)),h.p}function Ma(t,e){return e.max-t.max}function ja(t,e,i,n){this.p=new Ot(t,e),this.h=i,this.d=function(t,e){let i=!1,n=1/0;for(let r=0;r<e.length;r++){const o=e[r];for(let e=0,r=o.length,s=r-1;e<r;s=e++){const r=o[e],a=o[s];r.y>t.y!=a.y>t.y&&t.x<(a.x-r.x)*(t.y-r.y)/(a.y-r.y)+r.x&&(i=!i),n=Math.min(n,xa(t,r,a))}}return(i?1:-1)*Math.sqrt(n)}(this.p,n),this.max=this.d+this.h*Math.SQRT2}const Aa=45*Math.PI/100;function Fa(t,e,i,n,r,o,s,a,l){const{feature:u,size:c,symbol:h}=t,d=c?24:0,f=n*(c?c[0]/d:1),p=[];if("line"===o){let t=u.geometry;r&&(t=pa(u.geometry,0,0,r,r));for(let n=0;n<t.length;n++){const o=ga(t[n],s,Aa,h.isIconText?null:i.vertical||i.horizontal||i,null,d,h.isIconText?1:f,1,r||1/0,a,l);if(h.textPlacement&&!h.isIconText)for(let t=0;t<o.length;t++)o[t].startIndex=e.length/3;if(p.push.apply(p,o),h.textPlacement&&!h.isIconText)for(let i=0;i<t[n].length;i++)e.push(t[n][i].x,t[n][i].y,t[n][i].z||0)}}else if(3===u.type){const t=va(u.geometry,0);for(let e=0;e<t.length;e++){const i=t[e];if("vertex"===o)for(let t=0;t<i.length;t++){const e=i[t];for(let t=0;t<e.length;t++)dn(e[t],r)||p.push(e[t])}else{const t=ka(i,16);dn(t,r)||p.push(t)}}}else if(2===u.type)for(let t=0;t<u.geometry.length;t++){const e=u.geometry[t];if("vertex"===o)for(let t=0;t<e.length;t++)dn(e[t],r)||p.push(e[t]);else dn(e[0],r)||p.push(e[0])}else if(1===u.type)for(let t=0;t<u.geometry.length;t++){const e=u.geometry[t];for(let t=0;t<e.length;t++){const i=e[t];dn(i,r)||p.push(i)}}return p}function Ta(t,e){const i={},n={},r=[];let o=0;function s(e){r.push(t[e]),o++}function a(t,e,i){const o=n[t];return delete n[t],n[e]=o,r[o].geometry[0].pop(),r[o].geometry[0]=r[o].geometry[0].concat(i[0]),o}function l(t,e,n){const o=i[e];return delete i[e],i[t]=o,r[o].geometry[0].shift(),r[o].geometry[0]=n[0].concat(r[o].geometry[0]),o}function u(t,e,i){const n=i?e[0][e[0].length-1]:e[0][0];return`${t}:${n.x}:${n.y}`}for(let c=0;c<t.length;c++){const h=t[c],d=h.geometry;if(!d)continue;const f=h.properties[e]?h.properties[e].toString():null;if(!f){s(c);continue}const p=u(f,d),m=u(f,d,!0);if(p in n&&m in i&&n[p]!==i[m]){const t=l(p,m,d),e=a(p,m,r[t].geometry);delete i[p],delete n[m],n[u(f,r[e].geometry,!0)]=e,r[t].geometry=null}else p in n?a(p,m,d):m in i?l(p,m,d):(s(c),i[p]=o-1,n[m]=o-1)}return r.filter(t=>t.geometry)}class za extends bs{static needMerge(t,e,i){if(!t)return!1;let n="line"===t.textPlacement||"line"===t.markerPlacement;return n||(e.textPlacementFn&&(n="line"===e.textPlacementFn(i)),e.markerPlacementFn&&(n="line"===e.markerPlacementFn(i))),t.mergeOnProperty&&n}static mergeLineFeatures(t,e,i,n){const r="__index".trim();let o=e.textPlacement,s=e.markerPlacement;i.textPlacementFn&&(o=i.textPlacementFn(n)),i.markerPlacementFn&&(s=i.markerPlacementFn(n));const a=function(t,e,i,n,r){const o="__index".trim(),s=bs.genFnTypes(e),{mergeOnPropertyFn:a}=s;if(!e.mergeOnProperty||"line"!==n&&"line"!==i)return[];if(!(fn(l=e.mergeOnProperty)||"string"!=typeof l&&(null===l.constructor||l.constructor!==String)||"line"!==n&&"line"!==i))return[{features:t,property:e.mergeOnProperty}];var l;const u=[],c={},h=[];for(let s=0;s<t.length;s++){t[s][o]=s;const l=t[s].properties=t[s].properties||{};l.$layer=t[s].layer,l.$type=t[s].type;let d=i;"line"!==d&&(d=n);const f=a?a(r,l):e.mergeOnProperty;"line"!==d||fn(f)?h.push(t[s]):(void 0===c[f]&&(c[f]=u.length,u.push({features:[],property:f})),u[c[f]].features.push(t[s]))}return h.length&&u.push({features:h}),u}(t,e,s,o,n);if(a.length){const e=[];for(let i=0;i<a.length;i++)e.push(a[i].property?Ta(a[i].features,a[i].property):t);if(1===e.length)return e[0];{let t=[];for(let i=0;i<e.length;i++)t=t.concat(e[i]);return t.sort((t,e)=>t[r]-e[r]),t}}}static splitPointSymbol(t,e=0){const i=[];if(Array.isArray(t)){const e=t;for(let t=0;t<e.length;t++)e[t]&&i.push(...za.splitPointSymbol(e[t],t));return i}let n=null,r=null;for(const e in t)0===e.indexOf("marker")?(n=n||{},n[e]=t[e]):0===e.indexOf("text")&&(r=r||{},r[e]=t[e]);return n&&(n.isIconText=!0,t.mergeOnProperty&&(n.mergeOnProperty=t.mergeOnProperty),i.push(n)),r&&(n&&(r.textPlacement=n.markerPlacement,r.textSpacing=n.markerSpacing,r.isIconText=!0),t.mergeOnProperty&&(r.mergeOnProperty=t.mergeOnProperty),i.push(r)),void 0!==t.visible&&(n&&(n.visible=t.visible),r&&(r.visible=t.visible)),n&&(n.markerTextFit&&r&&(n.text={},n.text.textName=r.textName,n.text.textSize=r.textSize),n.index={index:e,type:0}),r&&(r.index={index:e,type:1}),i}static isAtlasLoaded(t,e){const{icon:i,glyph:n}=t,{iconAtlas:r,glyphAtlas:o}=e;if(i&&(!r||!r.positions[i.url]))return!1;if(n){if(!o||!o.positions[n.font])return!1;const t=o.positions[n.font],{text:e}=n;for(let i=0;i<e.length;i++)if(!t[e.charCodeAt(i)])return!1}return!0}constructor(t,e,i){super(t,e,i),this.ct=e.textPlacement,this.et.textPlacementFn&&(this.ct=this.et.textPlacementFn(this.options.zoom))}createStyledVector(t,e,i,n,r,o){const s=new da(t,this.symbolDef,e,i,n),a=s.getIconAndGlyph();if(a.icon&&!this.options.atlas){const{url:t,size:e}=a.icon;r[t]||(r[t]=a.icon.size),r[t][0]<e[0]&&(r[t][0]=e[0]),r[t][1]<e[1]&&(r[t][1]=e[1])}if(a.glyph&&!this.options.atlas){const{font:t,text:e}=a.glyph,i=o[t]=o[t]||{};for(let t=0;t<e.length;t++)i[e.charCodeAt(t)]=1;"line"===this.ct&&(o.options={isCharsCompact:!1})}return this.options.allowEmptyPack||a.icon||a.glyph?s:null}getFormat(t){const e=void 0!==t.textName,i=e?this.getPackSDFFormat(t):this.getPackMarkerFormat();e?i.push(...this.ht()):i.push(...this.dt());const{markerOpacityFn:n,textOpacityFn:r,markerPitchAlignmentFn:o,textPitchAlignmentFn:s,markerRotationAlignmentFn:a,textRotationAlignmentFn:l,markerRotationFn:u,textRotationFn:c,markerAllowOverlapFn:h,textAllowOverlapFn:d,markerIgnorePlacementFn:f,textIgnorePlacementFn:p}=this.et;return(n||r)&&i.push({type:Uint8Array,width:1,name:"aColorOpacity"}),(o||s)&&i.push({type:Uint8Array,width:1,name:"aPitchAlign"}),(a||l)&&i.push({type:Uint8Array,width:1,name:"aRotationAlign"}),(u||c)&&i.push({type:Uint16Array,width:1,name:"aRotation"}),(h||d||f||p)&&i.push({type:Uint8Array,width:1,name:"aOverlap"}),i}ft(){return this.hasMapPitchAlign}ht(){const{textFillFn:t,textSizeFn:e,textHaloFillFn:i,textHaloRadiusFn:n,textHaloOpacityFn:r,textDxFn:o,textDyFn:s}=this.et,a=[];return t&&a.push({type:Uint8Array,width:4,name:"aTextFill"}),e&&a.push({type:Uint8Array,width:1,name:"aTextSize"}),i&&a.push({type:Uint8Array,width:4,name:"aTextHaloFill"}),n&&a.push({type:Uint8Array,width:1,name:"aTextHaloRadius"}),r&&a.push({type:Uint8Array,width:1,name:"aTextHaloOpacity"}),o&&a.push({type:Int8Array,width:1,name:"aTextDx"}),s&&a.push({type:Int8Array,width:1,name:"aTextDy"}),a}dt(){const{markerWidthFn:t,markerHeightFn:e,markerDxFn:i,markerDyFn:n}=this.et,r=[];return t&&r.push({type:Uint8Array,width:1,name:"aMarkerWidth"}),e&&r.push({type:Uint8Array,width:1,name:"aMarkerHeight"}),i&&r.push({type:Int8Array,width:1,name:"aMarkerDx"}),n&&r.push({type:Int8Array,width:1,name:"aMarkerDy"}),r}createDataPack(){if(!this.iconAtlas&&!this.glyphAtlas){if(!this.options.allowEmptyPack)return null;this.empty=!0}this.lineVertex=[];const t=super.createDataPack.apply(this,arguments);return t?(t.lineVertex=new Int16Array(this.lineVertex),t.buffers.push(t.lineVertex.buffer),t):null}placeVector(t,e){const i=t.getShape(this.iconAtlas,this.glyphAtlas);if(!this.options.allowEmptyPack&&!i)return;const n=this.pt(t,i,e);if(0===n.length)return;const r=this.data,o=this.needAltitudeAttribute()?2:3;let a=this.data.aPosition.length/o;const l=t.symbol,u=t.feature.properties,c="line"===this.ct&&!l.isIconText,h=void 0!==l.textName,d=h&&c&&function(t){let e=0;for(let i=0;i<t.length;i++)if(Zs(t.charAt(i).charCodeAt(0)))e=0;else if(e++,e>=1)return!1;return!0}(t.getIconAndGlyph().glyph.text)?1:0,{textFillFn:f,textSizeFn:p,textHaloFillFn:m,textHaloRadiusFn:y,textHaloOpacityFn:g,textDxFn:b,textDyFn:v,textPitchAlignmentFn:w,textRotationAlignmentFn:x,textRotationFn:k,textAllowOverlapFn:M,textIgnorePlacementFn:j,textOpacityFn:A,markerWidthFn:F,markerHeightFn:T,markerDxFn:z,markerDyFn:S,markerPitchAlignmentFn:_,markerRotationAlignmentFn:P,markerRotationFn:I,markerAllowOverlapFn:O,markerIgnorePlacementFn:E,markerOpacityFn:q}=this.et;let R,C,N,L,D,U,$,W,J,H,G,V,B,X,Z,Y,K;if(h){const e=t.getIconAndGlyph().glyph.font;R=function(t,e,i){const n=t.positionedGlyphs,r=[];for(let o=0;o<n.length;o++){const s=n[o],a=i[s.glyph];if(!a)continue;const l=a.rect;if(!l)continue;const u=4,c=a.metrics.advance/2,h=a.metrics.height/2,d=e?[s.x+c,0]:[0,0],f=e?[0,s.y-h]:[s.x+c,s.y-h],p=a.metrics.left-u-c+f[0],m=a.metrics.top-u+f[1],y=p+l.w,g=m+l.h,b=new Ot(p,m),v=new Ot(y,m),w=new Ot(p,g),x=new Ot(y,g);if(e&&s.vertical){const t=new Ot(-c,c),e=-Math.PI/2,i=new Ot(5,0);b.F(e,t).u(i),v.F(e,t).u(i),w.F(e,t).u(i),x.F(e,t).u(i)}r.push({tl:b,tr:v,bl:w,br:x,tex:l,writingMode:t.writingMode,glyphOffset:d})}return r}(i.horizontal,c,this.glyphAtlas.positions[e]),f&&(C=f(null,u),s(C)?C=[0,0,0,0]:(C=Array.isArray(C)?C.map(t=>255*t):We(C).array(),3===C.length&&C.push(255))),p&&(N=p(this.options.zoom,u),fn(N)&&(N=14)),m&&(L=m(null,u),L=Array.isArray(L)?L.map(t=>255*t):We(L).array(),3===L.length&&L.push(255)),y&&(D=y(null,u)),g&&(U=255*g(null,u)),b&&($=b(null,u)||0),v&&(W=v(null,u)||0),w&&(B=+("map"===w(null,u))),x&&(X=+("map"===x(null,u))),k&&(Z=pn(k(null,u),0,360)*Math.PI/180)}else R=i?function(t){const e=t.image,i=t.top-1/e.pixelRatio,n=t.left-1/e.pixelRatio,r=t.bottom+1/e.pixelRatio,o=t.right+1/e.pixelRatio;let s,a,l,u;return s=new Ot(n,i),a=new Ot(o,i),l=new Ot(o,r),u=new Ot(n,r),[{tl:s,tr:a,bl:u,br:l,tex:{x:e.tl[0],y:e.tl[1],w:e.displaySize[0],h:e.displaySize[1]},writingMode:void 0,glyphOffset:[0,0]}]}(i):function(){const t=new Ot(0,0),e=new Ot(0,0),i=new Ot(0,0);return[{tl:t,tr:e,bl:new Ot(0,0),br:i,tex:{x:0,y:0,w:0,h:0},writingMode:void 0,glyphOffset:[0,0]}]}(),F&&(J=F(null,u)),T&&(H=T(null,u)),z&&(G=z(null,u)),S&&(V=S(null,u)),_&&(B=+("map"===_(null,u))),P&&(X=+("map"===P(null,u))),I&&(Z=pn(I(null,u),0,360)*Math.PI/180);const Q=O||M;Q&&(Y=Q(null,u)||0);const tt=E||j;let et;tt&&(K=tt(null,u)||0);const it=A||q;it&&(et=255*it(this.options.zoom,u));const nt=this.options.EXTENT,rt=R.length;for(let t=0;t<n.length;t++){const e=n[t],i=e.z||0;if(nt!==1/0&&dn(e,nt))continue;const o=e.x,s=e.y,l=R.length;for(let t=0;t<l;t++){const n=R[t],{tl:l,tr:u,bl:f,br:p,tex:m}=n;this.yt(r,o,s,i,10*l.x,10*l.y,m.x,m.y+m.h),h&&this.gt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.bt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.yt(r,o,s,i,10*u.x,10*u.y,m.x+m.w,m.y+m.h),h&&this.gt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.bt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.yt(r,o,s,i,10*f.x,10*f.y,m.x,m.y),h&&this.gt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.bt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.yt(r,o,s,i,10*p.x,10*p.y,m.x+m.w,m.y),h&&this.gt(r,c,rt,n.glyphOffset,e,d,e.axis,e.angleR),this.bt(r,C,N,L,D,U,$,W,J,H,G,V,et,B,X,Z,Y,K),this.addElements(a,a+1,a+2),this.addElements(a+1,a+2,a+3),a+=4;const y=Math.max(Math.abs(o),Math.abs(s),Math.abs(i));y>this.maxPos&&(this.maxPos=y)}}}yt(t,e,i,n,r,o,s,a){this.fillPosition(t,e,i,n),t.aShape.push(r,o),t.aTexCoord.push(s,a)}gt(t,e,i,n,r,o,s,a){if(t.aCount.push(i),e){t.aGlyphOffset.push(n[0],n[1]),this.ft()&&t.aPitchRotation.push(s[0],s[1],a);const e=r.startIndex;t.aSegment.push(r.segment+e,e,r.line.length),t.aVertical.push(o)}}bt(t,e,i,n,r,o,s,a,l,u,c,h,d,f,p,m,y,g){const{textFillFn:b,textSizeFn:v,textHaloFillFn:w,textHaloRadiusFn:x,textHaloOpacityFn:k,textDxFn:M,textDyFn:j,textPitchAlignmentFn:A,textRotationAlignmentFn:F,textRotationFn:T,textAllowOverlapFn:z,textIgnorePlacementFn:S,textOpacityFn:_,markerWidthFn:P,markerHeightFn:I,markerDxFn:O,markerDyFn:E,markerPitchAlignmentFn:q,markerRotationAlignmentFn:R,markerRotationFn:C,markerAllowOverlapFn:N,markerIgnorePlacementFn:L,markerOpacityFn:D}=this.et;b&&t.aTextFill.push(...e),v&&t.aTextSize.push(i),w&&t.aTextHaloFill.push(...n),x&&t.aTextHaloRadius.push(r),k&&t.aTextHaloOpacity.push(o),M&&t.aTextDx.push(s),j&&t.aTextDy.push(a),P&&t.aMarkerWidth.push(l),I&&t.aMarkerHeight.push(u),O&&t.aMarkerDx.push(c),E&&t.aMarkerDy.push(h),(D||_)&&t.aColorOpacity.push(d),(A||q)&&t.aPitchAlign.push(f),(R||F)&&t.aRotationAlign.push(p),(C||T)&&t.aRotation.push(9362*m);const U=N||z,$=L||S;(U||$)&&t.aOverlap.push((U?8:0)+4*y+(($?2:0)+g)),r>0&&(this.properties.hasHalo=1)}pt(t,e,i){const{feature:n,symbol:r}=t,o=this.vt(t,r),s=n.properties,{markerSpacingFn:a,textSpacingFn:l}=this.et,u=((a?a(null,s):r.markerSpacing)||(l?l(null,s):r.textSpacing)||250)*i,c=this.options.altitudeToTileScale;return Fa(t,this.lineVertex,e,i,this.options.EXTENT,o,u,this.ft(),c)}vt(t,e){return this.et.markerPlacementFn?this.et.markerPlacementFn(this.options.zoom,t.feature.properties):e.markerPlacement||this.ct}getPackSDFFormat(t){if("line"!==this.ct||t.isIconText)return[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"},{type:Uint8Array,width:1,name:"aCount"}];{const t=[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"},{type:Uint8Array,width:1,name:"aCount"},{type:Int16Array,width:2,name:"aGlyphOffset"},{type:Uint16Array,width:3,name:"aSegment"},{type:Uint8Array,width:1,name:"aVertical"}];return this.ft()&&t.push({type:Float32Array,width:3,name:"aPitchRotation"}),t}}getPackMarkerFormat(){return[...this.getPositionFormat(),{type:Int16Array,width:2,name:"aShape"},{type:Uint16Array,width:2,name:"aTexCoord"}]}}class Sa{constructor(t){this.x=t.x,this.y=t.y,this.z=t.z||0}clone(){return new Sa(this)}S(){return this.j(this.mag()),this}j(t){return this.x/=t,this.y/=t,this.z/=t,this}_(){var t=this.y;return this.y=this.x,this.x=-t,this}mag(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}add(t){return this.clone().u(t)}sub(t){return this.clone().m(t)}u(t){return this.x+=t.x,this.y+=t.y,this.z+=t.z,this}m(t){return this.x-=t.x,this.y-=t.y,this.z-=t.z,this}equals(t){return this.x===t.x&&this.y===t.y&&this.z===t.z}mult(t){return this.clone().M(t)}M(t){return this.x*=t,this.y*=t,this.z*=t,this}dist(t){return Math.sqrt(this.distSqr(t))}distSqr(t){var e=t.x-this.x,i=t.y-this.y,n=t.z-this.z;return e*e+i*i+n*n}P(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}angleTo(t){return Math.atan2(this.y-t.y,this.x-t.x)}}const _a=Math.cos(Math.PI/180*37.5),Pa=Math.pow(2,16)/1,Ia=new Ot,Oa=new Ot,Ea=new Ot;class qa extends bs{constructor(t,e,i){super(t,e,i);let n=!1;const{lineDasharrayFn:r,lineDashColorFn:o}=this.et;this.hasGradient=this.symbol.lineGradientProperty,r&&(n=function(t,e,i){for(let n=0;n<t.length;n++)if(i(e,t[n].properties))return!0;return!1}(t,this.options.zoom,r),n&&(this.dasharrayFn=r)),this.hasDasharray=Na(this.symbol.lineDasharray)||n,this.hasDasharray&&o&&(this.dashColorFn=o)}createStyledVector(t,e,i,n,r){const o=new mn(t,e,i,n),s=o.getLineResource();return!this.options.atlas&&s&&(r[s]=[0,0]),o}getFormat(){const{lineWidthFn:t,lineStrokeWidthFn:e,lineStrokeColorFn:i,lineColorFn:n,lineOpacityFn:r,lineDxFn:o,lineDyFn:s,linePatternAnimSpeedFn:a,linePatternGapFn:l}=this.et,u=[...this.getPositionFormat()];if(u.push(this.iconAtlas||this.hasDasharray?{type:Int8Array,width:3,name:"aExtrude"}:{type:Int8Array,width:2,name:"aExtrude"}),u.push({type:this.options.positionType||Uint16Array,width:1,name:"aLinesofar"}),t&&u.push({type:Uint8Array,width:1,name:"aLineWidth"}),e&&u.push({type:Uint8Array,width:1,name:"aLineStrokeWidth"}),n&&u.push({type:Uint8Array,width:4,name:"aColor"}),i&&u.push({type:Uint8Array,width:4,name:"aStrokeColor"}),r&&u.push({type:Uint8Array,width:1,name:"aOpacity"}),this.dasharrayFn&&u.push({type:Uint8Array,width:4,name:"aDasharray"}),this.dashColorFn&&u.push({type:Uint8Array,width:4,name:"aDashColor"}),this.iconAtlas){const t=this.getIconAtlasMaxValue();u.push({type:t>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return(o||s)&&u.push({type:Int8Array,width:2,name:"aLineDxDy"}),(a||l)&&u.push({type:Int8Array,width:2,name:"aLinePattern"}),u}placeVector(t){const{lineJoinFn:e,lineCapFn:i,lineWidthFn:n,lineHeightFn:r,lineStrokeWidthFn:o,lineStrokeColorFn:a,lineColorFn:l,lineOpacityFn:u,lineDxFn:c,lineDyFn:h,linePatternAnimSpeedFn:d,linePatternGapFn:f}=this.et,p=this.symbol,m=t.feature,y=m.properties;let g=p.lineJoin||"miter",b=p.lineCap||"butt";if(e&&(g=e(this.options.zoom,y)||"miter"),i&&(b=i(this.options.zoom,y)||"butt"),n){let t=n(this.options.zoom,y);Zi(t)&&(t=4),this.feaLineWidth=+t}else this.feaLineWidth=+p.lineWidth;if(r){let t=r(this.options.zoom,y);Zi(t)&&(t=this.feaLineWidth),this.feaLineHeight=+t}else this.feaLineHeight=+p.lineHeight||this.feaLineWidth;if(o){let t=o(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineStrokeWidth=t}else this.feaLineStrokeWidth=p.lineStrokeWidth||0;if(l&&(this.feaColor=l(this.options.zoom,y)||[255,255,255,255],s(this.feaColor)?this.feaColor=[0,0,0,0]:(this.feaColor=Array.isArray(this.feaColor)?this.feaColor.map(t=>255*t):We(this.feaColor).array(),3===this.feaColor.length&&this.feaColor.push(255))),a&&(this.feaStrokeColor=a(this.options.zoom,y)||[0,0,0,255],s(this.feaStrokeColor)?this.feaStrokeColor=[0,0,0,0]:(this.feaStrokeColor=Array.isArray(this.feaStrokeColor)?this.feaStrokeColor.map(t=>255*t):We(this.feaStrokeColor).array(),3===this.feaStrokeColor.length&&this.feaStrokeColor.push(255))),u){let t=u(this.options.zoom,y);Zi(t)&&(t=1),this.feaOpacity=255*t}if(this.dasharrayFn){let t=this.dasharrayFn(this.options.zoom,y)||[0,0,0,0];if(t.length<4){const e=t;1===t.length?t=[e[0],e[0],e[0],e[0]]:2===t.length?t=[e[0],e[1],e[0],e[1]]:3===t.length&&(t=[e[0],e[1],e[2],e[2]])}this.feaDash=t}if(this.dashColorFn){let t=(this.dashColorFn?this.dashColorFn(this.options.zoom,y):this.symbol.lineDashColor)||[0,0,0,0];t=Array.isArray(t)?t.map(t=>255*t):We(t).array(),3===t.length&&t.push(255),this.feaDashColor=t}if(this.iconAtlas){const e=t.getLineResource(),i=this.iconAtlas.glyphMap[e];if(this.feaTexInfo=this.feaTexInfo||[0,0,0,0],i){const{tl:t,displaySize:i}=this.iconAtlas.positions[e];this.feaTexInfo[0]=t[0]+1,this.feaTexInfo[1]=t[1]+1,this.feaTexInfo[2]=i[0]-3,this.feaTexInfo[3]=i[1]-3}else this.feaTexInfo[0]=this.feaTexInfo[1]=this.feaTexInfo[2]=this.feaTexInfo[3]=0}if(c){let t=c(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineDx=t}if(h){let t=h(this.options.zoom,y);Zi(t)&&(t=0),this.feaLineDy=t}if(d){let t=d(this.options.zoom,y);Zi(t)&&(t=0),0!==t&&(this.properties.hasPatternAnim=1),this.feaPatternAnimSpeed=t}if(f){let t=f(this.options.zoom,y);Zi(t)&&(t=0),this.feaLinePatternGap=t}const v=this.options.EXTENT;let w=m.geometry;if(v!==1/0){w=[];const t=[];for(let e=0;e<m.geometry.length;e++){t[0]=m.geometry[e];const i=pa(t,-1,-1,v+1,v+1);if(3===m.type&&i.length>1){const t=i[0],e=i[i.length-1];t[0].equals(e[e.length-1])&&(i[0]=e.concat(t.slice(1)),i.length=i.length-1)}w.push(...i)}}const x=this.needAltitudeAttribute()?2:3;for(let t=0;t<w.length;t++)this.offset=this.data.aPosition.length/x,this.wt(w[t],m,g,b,2,1.05)}xt(){return this.iconAtlas&&this.feaTexInfo[2]&&this.feaTexInfo[3]}wt(t,e,i,n,r,o){const s=this.xt()||Na(this.feaDash)||Na(this.symbol.lineDasharray),a=this.options.isTube;a&&(t=t.map(t=>new Sa(t))),this.overscaling=1;const l=this.options.EXTENT;if(this.distance=0,this.scaledDistance=0,this.totalDistance=0,this.prevVertex=null,this.symbol.lineGradientProperty&&e.properties&&nn(e.properties,"mapbox_clip_start")&&nn(e.properties,"mapbox_clip_end")){this.clipStart=+e.properties.mapbox_clip_start,this.clipEnd=+e.properties.mapbox_clip_end;for(let e=0;e<t.length-1;e++)this.totalDistance+=t[e].dist(t[e+1]);this.updateScaledDistance()}const u=3===e.type&&!t.clipped;let c=t.length;for(;c>=2&&t[c-1].equals(t[c-2]);)c--;let h=0;for(;h<c-1&&t[h].equals(t[h+1]);)h++;if(c<(u?3:2))return;"bevel"===i&&(r=1.05);const d=this.overscaling<=16?15*l/(512*this.overscaling):0,f={vertexLength:0,primitiveLength:0,currentNormal:null};let p,m,y,g,b;this.e1=this.e2=-1,u&&(p=t[c-2],b=t[h].sub(p).S()._());for(let e=h;e<c;e++){if(y=e===c-1?u?t[h+1]:void 0:t[e+1],y&&t[e].equals(y))continue;b&&(g=b),p&&(m=p),p=t[e],b=y?y.sub(p).S()._():g,f.dir=m?p.sub(m).S():y.sub(p).S(),g=g||b,f.currentNormal=g;let l=g.add(b);0===l.x&&0===l.y||l.S();const v=g.x*b.x+g.y*b.y,w=l.x*b.x+l.y*b.y,x=0!==w?1/w:1/0,k=2*Math.sqrt(2-2*w),M=w<_a&&m&&y,j=g.x*b.y-g.y*b.x>0;if(!a&&M&&e>h){const t=p.dist(m);if(t>2*d){const e=p.sub(p.sub(m).M(d/t).P());e.z=p.z,this.updateDistance(m,e),this.addCurrentVertex(e,g,0,0,f),m=e}}const A=m&&y;f.middleVertex=A;let F=A?i:u?"butt":n;if(A&&"round"===F&&(x<o?F="miter":x<=2&&(F="fakeround")),"miter"===F&&x>r&&!a&&(F="bevel"),"bevel"===F&&(x>2&&(F="flipbevel"),x<r&&(F="miter")),m&&this.updateDistance(m,p),"miter"===F)a?(this.addCurrentVertex(p,g,0,0,f),f.dir=y.sub(p).S(),this.addCurrentVertex(p,b,0,0,f)):(l.M(x),this.addCurrentVertex(p,l,0,0,f),s&&(f.currentNormal=b,this.addCurrentVertex(p,l,0,0,f)));else if("flipbevel"===F){if(x>100)l=b.mult(-1);else{const t=x*g.add(b).mag()/g.sub(b).mag();l._().M(t*(j?-1:1))}this.addCurrentVertex(p,l,0,0,f),this.addCurrentVertex(p,l.mult(-1),0,0,f)}else if("bevel"===F||"fakeround"===F){const t=-Math.sqrt(x*x-1),e=j?t:0,i=j?0:t;if(m&&this.addCurrentVertex(p,g,e,i,f),"fakeround"===F){const t=Math.round(180*k/Math.PI/20);for(let e=1;e<t;e++){let i=e/t;if(.5!==i){const t=i-.5;i+=i*t*(i-1)*((1.0904+v*(v*(3.55645-1.43519*v)-3.2452))*t*t+(.848013+v*(.215638*v-1.06021)))}const n=b.sub(g).M(i).u(g).S().M(j?-1:1);this.addHalfVertex(p,n.x,n.y,!1,j,0,f)}}y&&(f.currentNormal=b,this.addCurrentVertex(p,b,-e,-i,f))}else if("butt"===F)this.addCurrentVertex(p,l,0,0,f);else if("square"===F){const t=m?1:-1;this.addCurrentVertex(p,l,t,t,f)}else"round"===F&&(m&&(this.addCurrentVertex(p,g,0,0,f),this.addCurrentVertex(p,g,1,1,f,!0)),y&&(this.addCurrentVertex(p,b,-1,-1,f,!0),this.addCurrentVertex(p,b,0,0,f)));if(!a&&M&&e<c-1){const t=p.dist(y);if(t>2*d){const e=p.add(y.sub(p).M(d/t).P());e.z=p.z,this.updateDistance(p,e),this.addCurrentVertex(e,b,0,0,f),p=e}}}}addCurrentVertex(t,e,i,n,r,o=!1){const s=e.x+e.y*i,a=e.y-e.x*i,l=e.y*n-e.x,u=-e.y-e.x*n;let c=0,h=0;if(r.middleVertex){Ia.x=s,Ia.y=a,Oa.x=l,Oa.y=u;const t=r.currentNormal;if(c=Ua(t,Ia),0===i&&0===n)h=-c;else{const e=Ea;e.x=t.x,e.y=t.y,e.M(-1),h=Ua(e,Oa)}}this.addHalfVertex(t,s,a,o,!1,i,r,c),this.addHalfVertex(t,l,u,o,!0,-n,r,h),this.prevVertex&&t.equals(this.prevVertex)||(this.prevVertex=t),this.distance>Pa/2&&0===this.totalDistance&&(this.distance=0,this.updateScaledDistance(),this.addCurrentVertex(t,e,i,n,r,o))}addHalfVertex({x:t,y:e,z:i},n,r,o,s,a,l,u){this.fillData(this.data,t,e,i||0,n,r,o,s,1*this.scaledDistance,u);const c=l.vertexLength++;this.e1>=0&&this.e2>=0&&(this.addElements(this.e1,this.e2,c),l.primitiveLength++),s?this.e2=c:this.e1=c}fillData(t,e,i,n,r,o,s,a,l,u){const{lineWidthFn:c,lineStrokeWidthFn:h,lineStrokeColorFn:d,lineColorFn:f,lineOpacityFn:p,lineDxFn:m,lineDyFn:y,linePatternAnimSpeedFn:g,linePatternGapFn:b}=this.et;this.fillPosition(t,e,i,n);let v=63*r;v=(Math.sign(v)||1)*((Math.floor(Math.abs(v))>>1<<1)+ +s);let w=63*o;w=(Math.sign(w)||1)*((Math.floor(Math.abs(w))>>1<<1)+ +a),t.aExtrude.push(v,w),(this.iconAtlas||this.hasDasharray)&&t.aExtrude.push(63*u),t.aLinesofar.push(l),c&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),h&&t.aLineStrokeWidth.push(Math.round(2*this.feaLineStrokeWidth)),f&&t.aColor.push(...this.feaColor),d&&t.aStrokeColor.push(...this.feaStrokeColor),p&&t.aOpacity.push(this.feaOpacity),this.dasharrayFn&&t.aDasharray.push(...this.feaDash),this.dashColorFn&&t.aDashColor.push(...this.feaDashColor),this.iconAtlas&&t.aTexInfo.push(...this.feaTexInfo),(m||y)&&t.aLineDxDy.push(this.feaLineDx||0,this.feaLineDy||0),(g||b)&&t.aLinePattern.push(127*(this.feaPatternAnimSpeed||0),10*(this.feaLinePatternGap||0)),this.maxPos=Math.max(this.maxPos,Math.abs(e)+1,Math.abs(i)+1)}addElements(t,e,i){super.addElements(this.offset+t,this.offset+e,this.offset+i)}kt(t){const e=this.options.EXTENT,i=this.elements;for(let n=0;n<i.length;n+=3)e!==1/0&&(Ca(this.data.aPosition,i[n],i[n+1],3,e)||Ca(this.data.aPosition,i[n+1],i[n+2],3,e))||t.push(i[n],i[n+1],i[n+2])}Mt(t){if(t.length<=1)return t;const e=[],i=this.options.EXTENT;let n,r=!0;for(n=0;n<t.length-1;n++){const o=Ra(t[n],t[n+1],i);o&&r||(e.push(t[n]),r=o)}return r||e.push(t[n]),e}updateDistance(t,e){if(this.options.isTube){const i=t.dist(e),n=sn(this.options)*(e.z-t.z);this.distance+=Math.sqrt(i*i+n*n)}else this.distance+=t.dist(e);this.updateScaledDistance()}updateScaledDistance(){this.scaledDistance=this.totalDistance>0?(this.clipStart+(this.clipEnd-this.clipStart)*this.distance/this.totalDistance)*(Pa-1):this.distance}}function Ra(t,e,i){return i!==1/0&&(t.x<0&&e.x<0||t.x>i&&e.x>i||t.y<0&&e.y<0||t.y>i&&e.y>i)}function Ca(t,e,i,n,r){if(r===1/0)return!1;const o=Math.floor(.5*t[e*n]),s=Math.floor(.5*t[e*n+1]),a=Math.floor(.5*t[i*n]),l=Math.floor(.5*t[i*n+1]);return o===a&&(o<0||o>r)&&s!==l||s===l&&(s<0||s>r)&&o!==a}function Na(t){if(!Array.isArray(t))return!1;for(let e=0;e<t.length;e++)if(t[e])return!0;return!1}const La=new Ot(0,0),Da=new Ot(0,0);function Ua(t,e){const i=t.mag(),n=e.mag();La.x=e.x,La.y=e.y;const r=t.angleTo(Da),o=e.angleTo(Da);return Math.sign(o-r)*Math.sqrt(n*n-i*i)}class $a extends qa{constructor(t,e,i){super(t,e,i),this.jt=i.altitudeProperty}getFormat(){const{lineColorFn:t,lineWidthFn:e}=this.et,i=[{type:this.maxPosZ>=Math.pow(2,15)?Float32Array:Int16Array,width:3,name:"aPosition"},{type:Uint16Array,width:1,name:"aLinesofar"},{type:Uint8Array,width:1,name:"aUp"},{type:Int16Array,width:3,name:"aExtrudedPosition"},{type:Int8Array,width:2,name:"aExtrude"}];return t&&i.push({type:Uint8Array,width:4,name:"aColor"}),e&&i.push({type:Uint8Array,width:1,name:"aLineWidth"}),this.jt&&i.push({type:Array,width:1,name:"aLineHeight"}),i}placeVector(t){const e=t.feature;if(this.jt){const{altitudeScale:t,altitudeProperty:i,defaultAltitude:n,heightProperty:r,defaultHeight:o,minHeightProperty:s}=this.options,{altitude:a,height:l}=hn(e,t,i,n,r,o,s);this.feaAltitude=a,this.feaMinHeight=(a-l)/a*32767,a>this.maxAltitude&&(this.maxAltitude=a)}return super.placeVector(t)}needAltitudeAttribute(){return!1}wt(t,e,i,n,r,o){const s=this.data.aPosition.length/3;super.wt(t,e,i,n,r,o);const a=this.data.aPosition.length/3,l=this.data.aPosition.length/3-this.offset;if(3!==e.type&&l>0&&!1!==this.options.side){const t=!1!==this.options.top?1:0,e=t+4;let i=this.data.aPosition.length/3;for(const t in this.data){const e=this.data[t],n=e.length/i;for(let t=0;t<n;t++)e.push(e[s*n+3*n+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[s*r+r*e+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[s*r+r*(e+3)+t])}super.addElements(t+1,l+1,l),super.addElements(l,l+1,l+2);const n=this.data.aPosition.length/3-this.offset;i=this.data.aPosition.length/3;for(const t in this.data){const e=this.data[t],n=e.length/i;for(let t=0;t<n;t++)e.push(e[a*n-n+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[a*r-e*r-r+t])}i=this.data.aPosition.length/3;for(const t in this.data){const n=this.data[t],r=n.length/i;for(let t=0;t<r;t++)n.push(n[a*r-e*r-3*r+t])}super.addElements(n,l-3,n+1),super.addElements(l-3,n+2,n+1)}}fillData(t,e,i,n,r,o,s,a,l){const u=!1!==this.options.top,c=!1!==this.options.side,h=this.feaLineWidth||this.symbol.lineWidth/2*(this.options.EXTENT/this.options.tileSize),d=63*r,f=63*o,p=h*r+e,m=h*o+i;this.At(t,e,i,r,o,s,a,l,p,m,d,f),c&&(u&&this.At(t,e,i,r,o,s,a,l,p,m,d,f),this.At(t,e,i,r,o,s,a,l,p,m,d,f),this.Ft(t,e,i,r,o,s,a,l,p,m,d,f),this.Ft(t,e,i,r,o,s,a,l,p,m,d,f)),this.maxPos=Math.max(this.maxPos,Math.abs(e),Math.abs(i))}At(t,e,i,n,r,o,s,a,l,u,c,h){const{lineColorFn:d,lineWidthFn:f}=this.et;t.aPosition.push(e,i,32767),t.aLinesofar.push(a),t.aUp.push(+s),t.aExtrudedPosition.push(l,u,1),t.aExtrude.push(c,h),d&&t.aColor.push(...this.feaColor),f&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),this.jt&&t.aLineHeight.push(this.feaAltitude)}Ft(t,e,i,n,r,o,s,a,l,u,c,h){const{lineColorFn:d,lineWidthFn:f}=this.et;t.aPosition.push(e,i,this.feaMinHeight||0),t.aLinesofar.push(a),t.aUp.push(+s),t.aExtrudedPosition.push(l,u,1),t.aExtrude.push(c,h),d&&t.aColor.push(...this.feaColor),f&&t.aLineWidth.push(Math.round(2*this.feaLineWidth)),this.jt&&t.aLineHeight.push(this.feaAltitude)}addElements(t,e,i){const n=!1!==this.options.top,r=!1!==this.options.side,o=(n?1:0)+(r?4:0);if(t*=o,e*=o,this.data.aUp[this.offset+(i*=o)+4]){if(n&&super.addElements(e,t,i),r){const t=n?1:0;super.addElements(e+t,i+t,i+t+2),super.addElements(e+t+1,i+t+1+2,e+t+1+2)}}else if(n&&super.addElements(t,i,e),r){const e=n?1:0;super.addElements(t+e,t+e+2,i+e),super.addElements(t+e+1+2,i+e+1+2,i+e+1)}}createDataPack(t,e){this.maxAltitude=0;const i=super.createDataPack(t,e);if(!i)return i;const{data:n,indices:r}=i;this.getFormat().reduce((t,e)=>(t[e.name]={size:e.width},t),{}).aPickingId={size:1};const{aExtrudedPosition:o,aPosition:s,aLinesofar:a,aUp:l,aExtrude:u,aColor:c,aLineHeight:h,aLineWidth:d}=n,f={},p=Ye(o,r);let m,y=!0;for(let t=0;t<p.length;t++)p[t]=-p[t],p[t]%1!=0&&(y=!1);if(!1!==this.options.top&&this.symbol.material&&function(t){for(const e in t)if(e.indexOf("Texture")>=0&&t[e])return!0;return!1}(this.symbol.material)&&(m=function(t,e,i){const n=[];for(let r=0;r<t.length;r+=3){const t=e[r/3];n.push(t/256,i[r/3]?1:0)}return n}(o,a,l)),f.aPosition=s,m&&(f.aTexCoord0=new Float32Array(m)),f.aNormal=y?new Int8Array(p):new Float32Array(p),f.aPickingId=n.aPickingId,f.aExtrude=u,c&&(f.aColor=c),d&&(f.aLineWidth=d),h){const t=Gi(this.maxAltitude);f.aLineHeight=new t(h)}const g=[];for(const t in f)g.push(f[t].buffer);return i.data=f,i.buffers=g,i}}const Wa=Math.pow(2,16)/1;class Ja extends bs{getFormat(){return[...this.getPositionFormat()]}placeVector(t){const e=t.feature,i=3===e.type,n=e.geometry,r=this.elements;i&&(this.elements=[]);const o=this.needAltitudeAttribute()?2:3;for(let t=0;t<n.length;t++)this.offset=this.data.aPosition.length/o,this.wt(n[t],e),i&&(this.kt(r),this.elements=[]);i&&(this.elements=r)}wt(t,e){const i=3===e.type;let n=t.length;for(;n>=2&&t[n-1].equals(t[n-2]);)n--;let r,o,s,a=0;for(;a<n-1&&t[a].equals(t[a+1]);)a++;if(!(n<(i?3:2))){this.distance=0,this.vertexLength=0,this.primitiveLength=0,this.e1=this.e2=this.e3=-1,i&&(r=t[n-2]);for(let e=a;e<n;e++)s=i&&e===n-1?t[a+1]:t[e+1],s&&t[e].equals(s)||(r&&(o=r),r=t[e],o&&(this.distance+=r.dist(o)),this.addCurrentVertex(r,this.distance))}}addCurrentVertex(t,e){const i=this.vertexLength++;this.addLineVertex(this.data,t,e),i>=1&&this.addElements(i-1,i),e>Wa&&(this.distance=0,this.addCurrentVertex(t,this.distance))}addLineVertex(t,e){this.fillPosition(t,e.x,e.y,e.z||0),this.maxPos=Math.max(this.maxPos,Math.abs(e.x),Math.abs(e.y))}addElements(t,e){super.addElements(this.offset+t,this.offset+e)}kt(t){const e=this.options.EXTENT,i=this.elements;for(let n=0;n<i.length;n+=2)un(this.data.aPosition,i[n],i[n+1],3,e)||t.push(i[n],i[n+1])}}const Ha=45*Math.PI/100;class Ga extends bs{getFormat(){return[...this.getPositionFormat()]}placeVector(t){const e=this.pt(t,this.symbol.markerSpacing||250,this.symbol.markerPlacement||"point");for(let t=0;t<e.length;t++){const i=e[t];this.fillPosition(this.data,i.x,i.y,i.z);const n=Math.max(Math.abs(i.x),Math.abs(i.y));n>this.maxPos&&(this.maxPos=n)}}pt(t,e,i){const n=t.feature,r=t.feature.type,o=this.options.EXTENT,s=[];if("line"===i){let t=n.geometry;o&&(t=pa(n.geometry,0,0,o,o));for(let i=0;i<t.length;i++){const n=ga(t[i],e,Ha,null,null,24,1,1,o||1/0);s.push.apply(s,n)}}else if(3===r){const t=va(n.geometry,0);for(let e=0;e<t.length;e++){const i=ka(t[e],16);dn(i,o)||s.push(i)}}else if(2===n.type)for(let t=0;t<n.geometry.length;t++){const e=n.geometry[t];dn(e[0],o)||s.push(e[0])}else if(1===n.type)for(let t=0;t<n.geometry.length;t++){const e=n.geometry[t];for(let t=0;t<e.length;t++){const i=e[t];dn(i,o)||s.push(i)}}return s}hasElements(){return!1}}\n/*!\n * from @turf/bboxClip\n * https://github.com/Turfjs/turf\n * MIT LICENSE\n */const Va=[],Ba=[];function Xa(t,e){var i,n,r,o,s,a,l;for(n=1;n<=8;n*=2){for(i=[],o=!(Ya(r=t[t.length-1],e)&n),s=0;s<t.length;s++){if((l=!(Ya(a=t[s],e)&n))!==o){const t=Za(r,a,n,e);i.push(void 0!==a.x?new Ot(t[0],t[1]):t)}l&&i.push(a),r=a,o=l}if(!(t=i).length)break}return i}function Za(t,e,i,n){return Va[0]=void 0===t.x?t[0]:t.x,Va[1]=void 0===t.y?t[1]:t.y,t=Va,Ba[0]=void 0===e.x?e[0]:e.x,Ba[1]=void 0===e.y?e[1]:e.y,e=Ba,8&i?[t[0]+(e[0]-t[0])*(n[3]-t[1])/(e[1]-t[1]),n[3]]:4&i?[t[0]+(e[0]-t[0])*(n[1]-t[1])/(e[1]-t[1]),n[1]]:2&i?[n[2],t[1]+(e[1]-t[1])*(n[2]-t[0])/(e[0]-t[0])]:1&i?[n[0],t[1]+(e[1]-t[1])*(n[0]-t[0])/(e[0]-t[0])]:null}function Ya(t,e){Va[0]=void 0===t.x?t[0]:t.x,Va[1]=void 0===t.y?t[1]:t.y;var i=0;return(t=Va)[0]<e[0]?i|=1:t[0]>e[2]&&(i|=2),t[1]<e[1]?i|=4:t[1]>e[3]&&(i|=8),i}class Ka extends bs{constructor(...t){super(...t),this.lineElements=[]}createStyledVector(t,e,i,n,r){const o=new mn(t,e,i,n),s=o.getPolygonResource();return!this.options.atlas&&s&&(r[s]=[0,0]),o}getFormat(){const t=[...this.getPositionFormat()],{polygonFillFn:e,polygonOpacityFn:i,uvScaleFn:n,uvOffsetFn:r}=this.et;if(this.iconAtlas){const e=this.getIconAtlasMaxValue();t.push({type:e>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return e&&t.push({type:Uint8Array,width:4,name:"aColor"}),i&&t.push({type:Uint8Array,width:1,name:"aOpacity"}),n&&t.push({type:Uint16Array,width:2,name:"aUVScale"}),r&&t.push({type:Uint8Array,width:2,name:"aUVOffset"}),t}createDataPack(...t){this.maxLineIndex=0,this.lineElements=[];const e=super.createDataPack(...t);if(!e)return e;let i=this.lineElements;return i=new(Hi(this.maxLineIndex))(this.lineElements),e.lineIndices=i,e.buffers.push(i.buffer),e}placeVector(t,e){const i=t.feature;this.Tt(i.geometry,i,e)}Tt(t,e){let i,n,r,o;const{polygonFillFn:a,polygonOpacityFn:l,uvScaleFn:u,uvOffsetFn:c}=this.et,h=e.properties;a&&(i=a(this.options.zoom,h)||[255,255,255,255],s(i)?i=[0,0,0,0]:(i=Array.isArray(i)?i.map(t=>255*t):We(i).array(),3===i.length&&i.push(255))),l&&(n=l(this.options.zoom,h),Zi(n)&&(n=1),n*=255),u&&(r=u(this.options.zoom,h),Zi(r)&&(r=[1,1]),r=[255*r[0],255*r[1]]),c&&(o=c(this.options.zoom,h),Zi(o)&&(o=[0,0]),o=[255*o[0],255*o[1]]);const d=!!this.iconAtlas,f=va(t,500),p=[0,0],m=[0,0];if(d){const{polygonPatternFileFn:t}=this.et,e=t?t(null,h):this.symbol.polygonPatternFile;if(this.iconAtlas.glyphMap[e]){const t=this.iconAtlas.positions[e];p[0]=t.tl[0]+1,p[1]=t.tl[1]+1,m[0]=t.displaySize[0]-3,m[1]=t.displaySize[1]-3}}const y=this.needAltitudeAttribute()?2:3,g=[-1,-1,e.extent+1,e.extent+1];for(let t=0;t<f.length;t++){const e=f[t],s=this.data.aPosition.length/y,a=[],l=[];for(let t=0;t<e.length;t++){let s=e[t];if(this.options.EXTENT!==1/0&&0===this.maxPosZ&&(s=Xa(s,g)),0===s.length)continue;0!==t&&l.push(a.length/3);const u=this.lineElements.length;this.fillPosition(this.data,s[0].x,s[0].y,s[0].z||0),d&&this.data.aTexInfo.push(...p,...m),void 0!==i&&this.data.aColor.push(...i),void 0!==n&&this.data.aOpacity.push(n),void 0!==r&&this.data.aUVScale.push(...r),void 0!==o&&this.data.aUVOffset.push(...o),this.maxPos=Math.max(this.maxPos,Math.abs(s[0].x),Math.abs(s[0].y)),this.addLineElements(u+s.length-1,u),a.push(s[0].x),a.push(s[0].y),a.push(s[0].z||0);for(let t=1;t<s.length;t++)this.fillPosition(this.data,s[t].x,s[t].y,s[t].z||0),d&&this.data.aTexInfo.push(...p,...m),void 0!==i&&this.data.aColor.push(...i),void 0!==n&&this.data.aOpacity.push(n),void 0!==r&&this.data.aUVScale.push(...r),void 0!==o&&this.data.aUVOffset.push(...o),this.maxPos=Math.max(this.maxPos,Math.abs(s[t].x),Math.abs(s[t].y)),this.addLineElements(u+t-1,u+t),a.push(s[t].x),a.push(s[t].y),a.push(s[t].z||0)}const u=Ti(a,l,3);for(let t=0;t<u.length;t+=3)this.addElements(s+u[t],s+u[t+1],s+u[t+2])}}addLineElements(...t){this.maxLineIndex=Math.max(this.maxLineIndex,...t),this.lineElements.push(...t)}}const Qa=[{type:Int16Array,width:3,name:"aPosition"}];class tl extends bs{getFormat(){return Qa}placeVector(t,e){const i=this.pt(t,e);if(0===i.length)return;const n=this.data,r=this.getAltitude(t.feature.properties);let o=n.aPosition.length/Qa[0].width;for(let t=0;t<i.length;t++){const e=i[t];n.aPosition.push(2*e.x+0,2*e.y+0,r),n.aPosition.push(2*e.x+1,2*e.y+0,r),n.aPosition.push(2*e.x+1,2*e.y+1,r),n.aPosition.push(2*e.x+0,2*e.y+1,r),this.addElements(o,o+1,o+2),this.addElements(o,o+2,o+3),o+=4;const s=Math.max(Math.abs(2*e.x+1),Math.abs(2*e.y+1));s>this.maxPos&&(this.maxPos=s)}}pt(t,e){const{feature:i,symbol:n}=t,r=this.vt(t,n),o=i.properties,{markerSpacingFn:s}=this.et,a=((s?s(null,o):n.markerSpacing)||250)*e;return Fa(t,null,null,e,this.options.EXTENT,r,a)}vt(t,e){return this.et.markerPlacementFn?this.et.markerPlacementFn(this.options.zoom,t.feature.properties):e.markerPlacement}}class el extends qa{constructor(t,e,i){(e=Xi({},e)).lineJoin="miter",e.lineCap="butt",super(t,e,i),this.options.radialSegments%2==1&&this.options.radialSegments--}getFormat(){const{lineWidthFn:t,lineColorFn:e,lineOpacityFn:i,linePatternAnimSpeedFn:n,linePatternGapFn:r}=this.et,o=[...this.getPositionFormat(),{type:Int8Array,size:4,name:"aTubeNormal"},{type:this.options.positionType||Uint16Array,width:1,name:"aLinesofar"}];if(this.iconAtlas){o.push({type:Int8Array,width:1,name:"aNormalDistance"});const t=this.getIconAtlasMaxValue();o.push({type:t>255?Uint16Array:Uint8Array,width:4,name:"aTexInfo"})}return t&&o.push({type:Uint16Array,width:1,name:"aLineWidth"}),e&&o.push({type:Uint8Array,width:4,name:"aColor"}),i&&o.push({type:Uint8Array,width:1,name:"aOpacity"}),n&&o.push({type:Int8Array,width:1,name:"aLinePatternAnimSpeed"}),r&&o.push({type:Int8Array,width:1,name:"aLinePatternGap"}),o}addHalfVertex(t,e,i,n,r,o,s,a){const{x:l,y:u,z:c}=t,h=1*this.scaledDistance,d=this.options.radialSegments/2,{x:f,y:p,z:m}=s.dir,y=function(t,e,i,n,r,o,s,a){dt(il,i,n,r),dt(nl,o,s,0),gt(rl,il,nl),mt(nl,nl),mt(rl,rl),ol[e]||(ol[e]=[]);const l=ol[e];for(var u=0;u<e;u++){const t=Math.PI*u/e,i=1-Math.abs(t-0)/(Math.PI/2);l[u]=l[u]||[],sl(nl,rl,l[u],1,t,i*(a?-1:1))}return l}(0,d,f,p,m,e,i,r);this.prevVertex&&this.fillTubeElements(r),this.fillData(this.data,l,u,c||0,y,r,h,a)}fillTubeElements(t){const e=this.options.radialSegments/2,i=this.needAltitudeAttribute()?2:3,n=this.data.aPosition.length/i;for(let i=0;i<e;i++){const r=i+n-2*e;let o,s;i===e-1&&t?(o=i+n-2*e+1,s=i+n-2*e-2*e+1):(o=i+n+1,s=i+n+1-2*e),super.addElements(i+n-this.offset,o-this.offset,r-this.offset),super.addElements(r-this.offset,o-this.offset,s-this.offset)}}fillData(t,e,i,n,r,o,s,a){const{lineWidthFn:l,lineColorFn:u,lineOpacityFn:c,linePatternAnimSpeedFn:h,linePatternGapFn:d}=this.et,f=r.length;for(let o=0;o<f;o++){if(this.fillPosition(t,e,i,n),xt(r[o],r[o],63),t.aTubeNormal.push(...r[o]),t.aLinesofar.push(s),this.iconAtlas&&(t.aNormalDistance.push(63*a),t.aTexInfo.push(...this.feaTexInfo)),l){const e=an(this.options.metric);let i=this.feaLineWidth*e;isNaN(i)&&(i=0),t.aLineWidth.push(Math.round(i))}u&&t.aColor.push(...this.feaColor),c&&t.aOpacity.push(this.feaOpacity),h&&t.aLinePatternAnimSpeed.push(127*(this.feaPatternAnimSpeed||0)),d&&t.aLinePatternGap.push(10*(this.feaLinePatternGap||0))}this.maxPos=Math.max(this.maxPos,Math.abs(e)+1,Math.abs(i)+1)}}const il=[],nl=[],rl=[],ol={};function sl(t,e,i,n,r,o){return wt(i,n*(Math.cos(r)*t[0]+Math.sin(r)*e[0]),n*(Math.cos(r)*t[1]+Math.sin(r)*e[1]),n*(Math.cos(r)*t[2]+Math.sin(r)*e[2]),o),i}class al extends el{addHalfVertex(t,e,i,n,r,o,s,a){const{x:l,y:u,z:c}=t,h=1*this.scaledDistance,{x:d,y:f,z:p}=s.dir,m=function(t,e,i,n,r,o,s,a){dt(ul,i,n,r),dt(cl,o,s,0),gt(hl,ul,cl),mt(cl,cl),mt(hl,hl),function(t,e,i){t[0]=e,t[1]=i}(ll,t,e);const l=zt(ll)/t,u=Math.atan(e/t);let c=Math.PI/2+(Math.PI/2-u);return dl[0]||(dl[0]=[]),sl(cl,hl,dl[0],l,c,a?1:-1),c+=2*u,dl[1]||(dl[1]=[]),sl(cl,hl,dl[1],l,c,a?1:-1),dl}(this.feaLineWidth,this.feaLineHeight,d,f,p,e,i,r);this.prevVertex&&this.fillTubeElements(r),this.fillData(this.data,l,u,c||0,m,r,h,a)}}const ll=[],ul=[],cl=[],hl=[],dl=[];var fl=Object.freeze({__proto__:null,clipPolygon:Xa,calculateSignedArea:ln,getFeaAltitudeAndHeight:hn,convertRTLText:ca,packPosition:yn,unpackPosition:function(t,e,i,n){const r=(Math.sign(e)||1)*(Math.abs(e)%gn),o=(Math.sign(i)||1)*(Math.abs(i)%gn),s=Math.floor(Math.abs(e)/gn),a=Math.floor(Math.abs(i)/gn);return t[0]=r,t[1]=o,t[2]=Math.sign(n+1e-5)*(2*s+a)*bn+n,t}});const pl={polygonPatternFile:1,markerFile:1,markerPlacement:1,markerSpacing:1,textName:1,textStyle:1,textFaceName:1,textWeight:1,textPlacement:1,textSpacing:1,lineJoin:1,lineCap:1,linePatternFile:1};Object.assign({visible:1,textHorizontalAlignment:1,textVerticalAlignment:1,textWrapWidth:1,markerHorizontalAlignment:1,markerVerticalAlignment:1},pl),Object.assign({lineDasharray:1},pl);function ml(t,e,i,n,r,o,s,a,l,u,c,h,d,f,p){const m=e.length,y=r/3;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-o;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-s;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-o;r+=m;for(let i=2,n=m;i<n;i+=3)t[r+i-2]=e[i-2],t[r+i-1]=e[i-1],t[r+i-0]=e[i]-s;r+=m,(i=i||[]).push(m/3);for(let e=0;e<i.length;e++){yl(y+(i[e-1]||0),y+i[e],t,m/3,a,n,l,u,c,h,d,f,p)}return r}function yl(t,e,i,n,r,o,s,a,l,u,c,h,d){const f=o.length;let p,m;for(let s=t,a=e;s<a-1;s++)p=s,m=s+1,it(i,p,m,r)||((s-t)%2==1&&(p+=2*n,m+=2*n),o.push(p+n,p,m),o.push(m,m+n,p+n));s&&function(t,e,i,n,r,o,s,a,l){let u,c=0,h=0,d=0,f=0;for(let p=n.length-1;p>=0;p--){const m=3*n[p],y=3*n[p]+1,g=3*n[p]+2,b=i[m],v=i[y],w=i[g];c||h||(c=Math.max(i[g],i[3*n[p-2]+2]),h=Math.min(i[g],i[3*n[p-2]+2]),u=c-h);let x=d;const k=p%6;0===t?(5===k&&(f=It(i,n,p,b,v)),x=2===k||3===k||4===k?d:d+f):1===t&&(2===k||3===k||4===k?x=0:5===k?(f=It(i,n,p,b,v),x=f):x=f);const M=x*s*a/r,j=w===c?0:u*l/o;e[m/3*2]=M,e[m/3*2+1]=-j,0===k&&(d+=f)}}(a,l,i,o.slice(f,o.length),u[0],u[1],c,h,d)}function gl(t,e,i,n,r,o,s,u,c,h){void 0===e.top&&(e.top=!0),void 0===e.side&&(e.side=!0);const{altitudeScale:d,altitudeProperty:f,defaultAltitude:p,heightProperty:y,minHeightProperty:g,defaultHeight:b,tangent:j,uv:A,uvScale:F,topUVMode:T,sideUVMode:z,top:S,side:_,topThickness:P}=e,I=function(t,e,{altitudeScale:i,altitudeProperty:n,defaultAltitude:r,heightProperty:o,minHeightProperty:s,defaultHeight:a},{side:l,top:u,topThickness:c,uvOrigin:h,uv:d,uvSize:f,topUVMode:p,sideUVMode:y,glScale:g,localScale:b,vScale:w},M){const j=e/t[0].extent,A=[],F=[],T=[],z=[],S=[],_=[],P=!!d,I=!!u,O=!!l,E=P?[]:null;function q(t,i,n,r){if(I){const r=Ti(z,n,3);if(0===r.length)return i;let o;v(S,z),i+=z.length;for(let e=2,i=r.length;e<i;e+=3)o=r[e-1],r[e-1]=r[e]+t/3,r[e]=o+t/3,r[e-2]+=t/3;v(_,r),P&&St(p||0,t,i,E,S,0,g,b,f[0],f[1]),c>0&&!O&&(i=ml(S,z,n,_,i,0,c,e,P,y||0,E,f,g,b,w))}return O&&(I&&(c=0),i=ml(S,z,n,_,i,c,r,e,P,y||0,E,f,g,b,w)),i}let R=0,C=0;const N=[-1,-1,e+1,e+1];let L=0,D=t.length;void 0!==M&&(L=M,D=M+1);let U=0,$=!1;for(;L<D;L++){const l=t[L],u=l.id;m(u)&&(Math.abs(u)>U&&(U=Math.abs(u)),u<0&&($=!0));const c=l.geometry,{altitude:h,height:d}=fl.getFeaAltitudeAndHeight(l,i,n,r,o,a,s);R=Math.max(Math.abs(h),R);const f=S.length;let p=C,y=[];z.length=0;for(let t=0,i=c.length;t<i;t++){const n=fl.calculateSignedArea(c[t])<0;!n&&t>0&&(C=q(p,C,y,d*j),z.length=0,y=[],p=C);let r=c[t];if(e!==1/0&&(r=fl.clipPolygon(r,N)),!r.length){t===i-1&&(C=q(p,C,y,d*j));continue}const o=r.length;Array.isArray(r[0])?r[0][0]===r[o-1][0]&&r[0][1]===r[o-1][1]||r.push([r[0][0],r[0][1]]):r[0].x===r[o-1].x&&r[0].y===r[o-1].y||r.push(r[0]),n&&y.push(z.length/3),et(z,z.length,r,j,h),t===i-1&&(C=q(p,C,y,d*j))}const g=S.length-f,b="__fea_idx".trim();for(let t=0;t<g/3;t++)F.push(void 0===l[b]?L:l[b]),A.push(L),m(u)&&T.push(u)}const W=x(F.length?F[F.length-1]:0),J={maxAltitude:R,vertices:new(k(Math.max(512,R)))(S),indices:_,pickingIds:new W(F),featureIndexes:A};if(T.length){const t=$?k(U):x(U);J.featureIds=new t(T)}else J.featureIds=[];return E&&(E.length=S.length/3*2,J.uvs=E),J}(t,i,{altitudeScale:d,altitudeProperty:f,defaultAltitude:p||0,heightProperty:y,minHeightProperty:g,defaultHeight:b||0},{top:S,side:_,topThickness:10*P||0,uv:A||j,uvSize:F?[.5*F[0],.5*F[1]]:[.5,.5],uvOrigin:n,topUVMode:T,sideUVMode:z,glScale:r,localScale:s,vScale:o},h),O=[],E=new(w(I.vertices.length/3))(I.indices);delete I.indices,O.push(E.buffer,I.vertices.buffer,I.pickingIds.buffer);const q=Ye(I.vertices,E);let R=!0;for(let t=0;t<q.length;t++)q[t]=-q[t],q[t]%1!=0&&(R=!1);if(I.normals=q,j){let t=function(t,e,i,n){const r=t.length/3,o=new Array(4*r),s=[],a=[];for(let t=0;t<r;t++)s[t]=[0,0,0],a[t]=[0,0,0];const l=[0,0,0],u=[0,0,0],c=[0,0,0],h=[0,0],d=[0,0],f=[0,0],p=[0,0,0],m=[0,0,0];function y(e,n,r){Ke(l,t,3*e),Ke(u,t,3*n),Ke(c,t,3*r),Qe(h,i,2*e),Qe(d,i,2*n),Qe(f,i,2*r);const o=u[0]-l[0],y=c[0]-l[0],g=u[1]-l[1],b=c[1]-l[1],v=u[2]-l[2],w=c[2]-l[2],x=d[0]-h[0],k=f[0]-h[0],M=d[1]-h[1],j=f[1]-h[1],A=1/(x*j-k*M);dt(p,(j*o-M*y)*A,(j*g-M*b)*A,(j*v-M*w)*A),dt(m,(x*y-k*o)*A,(x*b-k*g)*A,(x*w-k*v)*A),ft(s[e],s[e],p),ft(s[n],s[n],p),ft(s[r],s[r],p),ft(a[e],a[e],m),ft(a[n],a[n],m),ft(a[r],a[r],m)}for(let t=0,e=n.length;t<e;t+=3)y(n[t+0],n[t+1],n[t+2]);const g=[],b=[],v=[],w=[];let x,k,M;function j(t){Ke(v,e,3*t),ht(w,v),k=s[t],ht(g,k),bt(g,g,function(t,e,i){return t[0]=e[0]*i,t[1]=e[1]*i,t[2]=e[2]*i,t}(v,v,yt(v,k))),mt(g,g),gt(b,w,k),M=yt(b,a[t]),x=M<0?-1:1,o[4*t]=g[0],o[4*t+1]=g[1],o[4*t+2]=g[2],o[4*t+3]=x}for(let t=0,e=n.length;t<e;t+=3)j(n[t+0]),j(n[t+1]),j(n[t+2]);return o}(I.vertices,I.normals,I.uvs,E);t=function(t,e){const i=new Float32Array(e.length),n=[],r=[],o=[];for(let s=0;s<e.length;s+=4){const a=s/4*3;dt(r,t[a]||0,t[a+1]||0,t[a+2]||0),wt(n,e[s]||0,e[s+1]||0,e[s+2]||0,e[s+3]||0),Ze(o,r,n),vt(i.subarray(s,s+4),o)}return i}(I.normals,t),I.tangents=t,O.push(t.buffer),delete I.normals}if(I.normals&&(I.normals=R?new Int8Array(I.normals):new Float32Array(I.normals),O.push(I.normals.buffer)),I.uvs){const t=I.uvs;I.uvs=new Float32Array(t),O.push(I.uvs.buffer)}const C=function(t,e,i,n){const r={};if(M(e.polygonFill)){const o={},s=l(e.polygonFill),a=new Uint8Array(4*n.length);for(let e=0;e<n.length;e++){const r=t[n[e]],l=r.properties||{};l.$layer=r.layer,l.$type=r.type;let u=s(i,l);if(delete l.$layer,delete l.$type,Array.isArray(u)||(u=o[u]=o[u]||We(u).array()),Array.isArray(u)){for(let t=0;t<u.length;t++)bl[t]=255*u[t];3===u.length&&(bl[3]=255)}a[4*e]=bl[0],a[4*e+1]=bl[1],a[4*e+2]=bl[2],a[4*e+3]=bl[3]}r.aColor=a}if(M(e.polygonOpacity)){const o=a(e.polygonOpacity),s=new Uint8Array(n.length);for(let e=0;e<n.length;e++){const r=t[n[e]],a=r.properties||{};a.$layer=r.layer,a.$type=r.type;const l=o(i,a);delete a.$layer,delete a.$type,s[e]=255*l}r.aOpacity=s}return r}(t,u,c,I.featureIndexes),N={data:{data:{aPosition:I.vertices,aNormal:I.normals,aTexCoord0:I.uvs,aTangent:I.tangents,aPickingId:I.pickingIds},indices:E,properties:{maxAltitude:I.maxAltitude}},buffers:O};return I.featureIds.length?(N.data.featureIds=I.featureIds,O.push(N.data.featureIds.buffer)):N.data.featureIds=[],C.aColor&&(N.data.data.aColor=C.aColor,N.buffers.push(C.aColor.buffer)),C.aOpacity&&(N.data.data.aOpacity=C.aOpacity,N.buffers.push(C.aOpacity.buffer)),N}const bl=[];function vl(t,e,{altitudeScale:i,altitudeProperty:n,defaultAltitude:r,heightProperty:o,minHeightProperty:s,defaultHeight:a,bottom:l}){const u=l,c=e/t[0].extent,h=2*function(t,e){let i=0;for(let n=0,r=t.length;n<r;n++){const r=t[n];if(m(r.geometry[0][0])){const t=3*r.geometry.length;i+=e?2*t-6:t}else for(let t=0,n=r.geometry.length;t<n;t++){let n=3*r.geometry[t].length;3===r.type&&(n-=3),i+=e?2*n-6:n}}return i}(t)+3*t.length*2,d=[],f=new Int16Array(h),p=[];function y(t,i,n){const r=i-t,o=f.subarray(t,i),s=f.subarray(i,i+r);s.set(o);for(let t=2,e=s.length;t<e;t+=3)s[t]=o[t]-n;const a=t/3,l=r/3;let c,h;for(let t=a,i=l+a;t<i;t++)t<i-1?(c=t,h=t+1):(c=t,h=a),it(f,c,h,e)||(p.push(c,h),u&&p.push(c+l,h+l),wl(f,c,e)||p.push(c,c+l));return i+r}let g=0,b=0;const v="__fea_idx".trim();for(let e=0,l=t.length;e<l;e++){const l=t[e],u=l.geometry,{altitude:h,height:m}=fl.getFeaAltitudeAndHeight(l,i,n,r,o,a,s);b=Math.max(Math.abs(h),b);let w=g;for(let t=0,e=u.length;t<e;t++){let e=u[t];const i=e.length;e[0][0]===e[i-1][0]&&e[0][1]===e[i-1][1]&&(e=e.slice(0,i-1)),g=et(f,w,e,c,h),g=y(w,g,m*c),w=g}const x=p.length-d.length;for(let t=0;t<x;t++)d.push(l[v])}const M=new(w(p.reduce((t,e)=>Math.max(t,e),0)))(p),j=x(t.length);return{aPosition:new(k(Math.max(512,b)))(f),indices:M,aPickingId:new j(d)}}function wl(t,e,i){const n=t[3*e],r=t[3*e+1];return n<0||n>i||r<0||r>i}function xl(t,e,i){const n=vl(t,i,e),r=[n.aPosition.buffer,n.indices.buffer,n.aPickingId.buffer],o=n.indices;return delete n.indices,{data:{data:n,indices:o},buffers:r}}class kl{constructor(t,e,i,n,r){this.id=t,this.options=e,this.upload=i,this.zt(e.style),this.requests={},this.St=0,this._t=n,this.loadings=r}updateStyle(t,e){this.options.style=t,this.zt(t),this.St++,e()}updateOptions(t,e){this.options=f(this.options,t),e()}loadTile(t,e){const i=this.loadings,n=t.tileInfo.url,r=this.options.debugTile;if(r){const{x:i,y:n,z:o}=t.tileInfo;if(o!==r.z||i!==r.x||n!==r.y)return void e()}if(this._t.has(n)){const{features:r,layers:o}=this._t.get(n),s=i[n];if(delete i[n],!r||!r.length)return this.Pt(s),void e();if(s)for(let e=0;e<s.length;e++)this.It.call(s[e].ref,t,s[e].callback,n,o,r);this.It(t,e,n,o,r)}else i[n]?i[n].push({callback:e,ref:this}):(i[n]=[{callback:e,ref:this}],this.requests[n]=this.getTileFeatures(t.tileInfo,(e,r,o,s)=>{const a=i[n];if(delete i[n],this.checkIfCanceled(n))return delete this.requests[n],void this.Pt(a,null,{canceled:!0});if(delete this.requests[n],this.options.debug&&r)for(let e=0;e<r.length;e++)r[e]._debug_info={index:e,tileId:t.tileInfo.id};if(e)return e.loading||this._t.add(n,{features:[],layers:[]}),void this.Pt(a,e);if(!r||!r.length)return this._t.add(n,{features:[],layers:[]}),void this.Pt(a);if(this._t.add(n,{features:r,layers:o}),a)for(let e=0;e<a.length;e++)this.It.call(a[e].ref,t,a[e].callback,n,o,r,s)}))}It(t,e,i,n,r,o){this.Ot(n,r,t).then(t=>{t.canceled?e(null,{canceled:!0}):(t.data.style=this.St,o&&f(t.data,o),e(null,t.data,t.buffers))}).catch(t=>{e(t)})}abortTile(t,e){delete this.requests[t],this.Et(t),e()}Et(t){const e=this.loadings[t];if(e)for(let t=0;t<e.length;t++)e[t].callback(null,{canceled:!0});delete this.loadings[t]}Pt(t,e,i){if(t)for(let n=0;n<t.length;n++)t[n].callback(e,i)}checkIfCanceled(t){return!this.requests[t]}fetchIconGlyphs(t,e,i){this.upload("fetchIconGlyphs",{icons:t,glyphs:e},null,i)}Ot(t,e,i){if(!e.length)return Promise.resolve({data:null,buffers:[]});const{glScale:n,tileInfo:r}=i,o=!this.options.style.style.length&&!this.options.style.featureStyle.length;let s=this.pluginConfig.slice(0);o&&(s=this.qt(t)),this.featurePlugins&&v(s,this.featurePlugins);const a=e[0].extent,l=r.z,u={x:r.extent2d.xmin*n,y:r.extent2d.ymax*n},c=[],h=[],d=[],p=this.options,m=[],y={},g=[Promise.resolve(this.St)];let b=0,x=-1;for(let t=0;t<s.length;t++){x++;const n=s[t];n.type!==b&&(x=0,b=n.type);const r=0===n.type?c:h;if(n.symbol&&!1===n.symbol.visible){r[x]=null;continue}const{tileFeatures:f,tileFeaIndexes:p}=this.Rt(l,n.type,n.filter,e,y,t);if(!f.length){r[x]=null;continue}const v=w(p[p.length-1]);r[x]={styledFeatures:new v(p)},d.push({idx:t,typeIdx:x}),m.push(r[x].styledFeatures.buffer);let k=this.Ct(f,n,{extent:a,zoom:l,tilePoint:u,...i});o&&(k=k.then(t=>{if(!t)return null;if(t.data)t.data.layer=f[0].layer;else if(Array.isArray(t))for(let e=0;e<t.length;e++)t[e]&&t[e].data&&(t[e].data.layer=f[0].layer);return t})),g.push(k)}return Promise.all(g).then(([i,...n])=>{function r(t,e){if(void 0===t.data.ref&&(t.data.type=s[d[e].idx].renderPlugin.dataConfig.type,t.data.filter=s[d[e].idx].filter.def,t.buffers&&t.buffers.length))for(let e=0;e<t.buffers.length;e++)m.push(t.buffers[e])}if(i!==this.St)return{canceled:!0};for(let t=0;t<n.length;t++){if(!n[t])continue;const e=n[t],i=0===s[d[t].idx].type?c:h;if(Array.isArray(e)){const n=[];for(let i=0;i<e.length;i++)e[i]&&(r(e[i],t),(void 0===e[i].data.ref||e[e[i].data.ref])&&n.push(e[i].data));n.length&&(i[d[t].typeIdx].data=n)}else r(e,t),i[d[t].typeIdx].data=e.data}const o={},l=t;if(p.features||p.schema){let t;for(let i=0,n=e.length;i<n;i++)if(t=e[i],l[t.layer].properties||(l[t.layer].properties=Al(t.properties)),p.features&&t&&y[i])if("id"===p.features)o[i]=t.id;else{const e=f({},t);p.pickingGeometry||delete e.geometry,delete e.extent,delete e.properties.$layer,delete e.properties.$type,delete e.__index,o[i]=e}}return{data:{schema:l,data:c,featureData:h,extent:a,features:o},buffers:m}}).catch(t=>{console.error(t)})}Ct(t,e,i){let n=function(t,e,i){const n=i.customProperties;if(n)for(let t=0;t<n.length;t++)n[t].fn=ds.compileFilter(n[t].filter);for(let i=0;i<t.length;i++)if(t[i]=f({},t[i]),n)for(let r=0;r<n.length;r++)if(n[r].fn(t[i],e)){t[i].geojson&&(t[i].properties=f({},t[i].properties)),f(t[i].properties,n[r].properties);break}return t}(t,i.tileInfo.z,e);const r=e.renderPlugin.dataConfig,o=e.symbol,s=this.options.tileSize[0],{extent:a,glScale:l,zScale:u,zoom:c,tilePoint:h,pointAtTileRes:d}=i,p=a/s,m=r.type,y=this.options.debugTile&&this.options.debugTile.index;if("3d-extrusion"===m){const t=Fl(o);return t&&(r.uv=1,2===t&&(r.tangent=1)),Promise.all([Promise.resolve(gl(n,r,a,h,l,u,this.options.tileSize[1]/a,o,c,y))])}if("3d-wireframe"===m)return Promise.all([Promise.resolve(xl(n,r,a))]);if("point"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y,altitudeToTileScale:u*a/this.options.tileSize[1]/l}),e=za.splitPointSymbol(o),i=bs.genFnTypes(e[0]);return za.needMerge(e[0],i,c)&&(n=za.mergeLineFeatures(n,e[0],i,c)),Promise.all(e.map((e,r)=>(0===r?t.fnTypes=i:delete t.fnTypes,new za(n,e,t).load(p))))}if("native-point"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Tl(n,o,t,Ga,a/s)}if("line"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),tileRatio:p,zoom:c,debugIndex:y});return Tl(n,o,t,qa)}if("native-line"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Tl(n,o,t,Ja)}if("fill"===m){const t=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y});return Tl(n,o,t,Ka)}if("line-extrusion"===m){delete o.lineGradientProperty,o.lineJoin="miter",o.lineCap="butt";const t=Fl(o);t&&(r.uv=1,2===t&&(r.tangent=1));const e=f({},r,{EXTENT:a,tileSize:s,zScale:u,glScale:l,zoom:c,debugIndex:y});if(t){const t=[];if(!1!==r.top){const i=f({},e);i.side=!1,t.push(new $a(n,o,i))}return!1!==r.side&&(e.side=!0,e.top=!1,t.push(new $a(n,o,e))),Promise.all(t.map(t=>t.load()))}return Promise.all([new $a(n,o,e).load()])}if("circle"===m){const t=f({},r,{EXTENT:a,zoom:c,debugIndex:y});return Tl(n,o,t,tl)}if("round-tube"===m||"square-tube"===m){const t="round-tube"===m?el:al,e=f({},r,{EXTENT:a,requestor:this.fetchIconGlyphs.bind(this),zoom:c,debugIndex:y,radialSegments:"round-tube"===m?r.radialSegments||8:4,pointAtTileRes:d,tileRatio:p,isTube:!0});return Tl(n,o,e,t)}return Promise.resolve([])}Rt(t,e,i,n,r){const o="__fea_idx".trim(),s=[],a=[],l=n.length;for(let u=0;u<l;u++)if((1===e||void 0===n[u].id||!this.styledFeatures[n[u].id])&&((!i.def||"default"===i.def)&&!r[u]||!0===i.def||i.def&&(void 0!==i.def.condition||Array.isArray(i.def))&&i(n[u],t))){r[u]=1;const t=f({},n[u]);if(t[o]=u,a.push(t),s.push(u),1===e)break}return{tileFeatures:a,tileFeaIndexes:s}}zt(t){const{style:e,featureStyle:i}=t,n={};i.forEach(t=>{Array.isArray(t.id)?(t.id.forEach(t=>{n[t]=1}),t.filter=["in","$id",...t.id]):(n[t.id]=1,t.filter=["==","$id",t.id])});const r=ds.compileStyle(e);for(let t=0;t<e.length;t++)r[t].filter&&(r[t].filter.def=e[t].filter?e[t].filter.value||e[t].filter:void 0),r[t].type=0;const o=[],s=ds.compileStyle(i);for(let t=0;t<i.length;t++)s[t].type=1,s[t].filter.def=i[t].filter?i[t].filter.value||i[t].filter:void 0,s[t].renderPlugin&&o.push(s[t]);this.pluginConfig=r,this.featurePlugins=o,this.styledFeatures=n}qt(t){let e=this.Nt;this.Nt||(e=this.Nt={});const i=["","Point","LineString","Polygon","MultiPoint","MultiLineString","MultiPolygon"],n=[];for(const r in t){const o=r;if(!e[r]){const n=[];for(let e=0;e<t[r].types.length;e++){const s=t[r].types[e],a=["all",["==","$layer",o],["==","$type",i[s]]],l={filter:Lt(a),renderPlugin:Ml(s),symbol:jl(s)};l.filter.def=a,l.type=0,n.push(l)}e[o]=n}n.push(...e[o])}return n}}function Ml(t){switch(t){case 1:return{type:"native-point",dataConfig:{type:"native-point",only2D:!0}};case 2:return{type:"native-line",dataConfig:{type:"native-line",only2D:!0}};case 3:return{type:"fill",dataConfig:{type:"fill",only2D:!0}}}return null}function jl(t){switch(t){case 1:return{markerFill:"#f00",markerSize:10};case 2:return{lineColor:"#fff"};case 3:return{polygonFill:"#00f",polygonOpacity:.4}}return null}function Al(t){if(Array.isArray(t)||!g(t))return{};const e={};for(const i in t){const n=t[i];p(n)?e[i]="string":m(n)?e[i]="number":!0===n||!1===n?e[i]="boolean":Array.isArray(n)?e[i]="array":e[i]="object"}return e}function Fl(t){if(!t)return 0;let e=0;for(const i in t){if(("normalTexture"===i||"bumpTexture"===i)&&t[i])return 2;if(i.indexOf("Texture")>0&&t[i])e=1;else if(g(t[i])){const n=Fl(t[i]);if(2===n)return n;1===n&&(e=1)}}return e}function Tl(t,e,i,n,r){const o={},s=Array.isArray(e)?e:[e];let a=-1;for(let t=0;t<s.length;t++)o[t]=zl(s[t]),!o[t]&&s[t]&&-1===a&&(a=t);const l=[];for(let e=0;e<s.length;e++)s[e]&&(s[e].index={index:e},o[e]||e===a?l.push(new n(t,s[e],i).load(r)):l.push({data:{ref:a,symbolIndex:{index:e}}}));return Promise.all(l)}function zl(t){if(!t)return 0;for(const e in t)if(M(t[e]))return 1;return 0}function Sl(t,e){_l(t.geometry,e)}function _l(t,e){if(t)switch(t.type){case"Point":Pl(t.coordinates,e);break;case"MultiPoint":case"LineString":Il(t.coordinates,e);break;case"MultiLineString":case"Polygon":Ol(t.coordinates,e);break;case"MultiPolygon":!function(t,e){for(let i=0;i<t.length;i++)Ol(t[i],e)}(t.coordinates,e);break;case"GeometryCollection":for(let i=0;i<t.geometries.length;i++)_l(t.geometries[i],e)}}function Pl(t,e){e[0]=Math.min(e[0],t[0]),e[1]=Math.min(e[1],t[1]),e[2]=Math.max(e[2],t[0]),e[3]=Math.max(e[3],t[1])}function Il(t,e){for(let i=0;i<t.length;i++)Pl(t[i],e)}function Ol(t,e){for(let i=0;i<t.length;i++)Il(t[i],e)}class El extends kl{constructor(t,e,i,n,r,o){super(t,e,i,n,r),(e=e||{}).extent||(e.extent=8192),this.zoomOffset=0,e.tileSize&&(this.zoomOffset=-function(t){if(Math.log2)return Math.log2(t);const e=Math.log(t)*Math.LOG2E,i=Math.round(e);return Math.abs(i-e)<1e-14?i:e}(e.tileSize[0]/256)),this.setData(e.data,o)}setData(t,e){if(delete this.index,!t)return void e();const i={maxZoom:24,tolerance:this.options.simplifyTolerance,extent:this.options.extent,buffer:this.options.tileBuffer||64,hasAltitude:!!this.options.hasAltitude,debug:0,lineMetrics:!0,indexMaxZoom:5,indexMaxPoints:1e5,disableFilter:!0};if(p(t)&&"{"!=t.substring(0,1)||t.url)A.getJSON(t.url?t.url:t,t.url?t:{},(t,n)=>{if(t&&e(t),!n)return void e(null,{extent:null,idMap:{}});const r=n,{first1000:o,idMap:s}=this.Lt(r);this.Dt(o,s,r,i,e)});else{"string"==typeof t&&(t=JSON.parse(t));const n=Array.isArray(t)?t:t.features;let r=n;n&&n.length>1e3&&(r=n.slice(0,1e3)),this.Dt(r,null,t,i,e)}}Dt(t,e,i,n,r){try{const o=t&&t.length?function(t){let e=[Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY,Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY];switch(t.type){case"FeatureCollection":for(let i=0;i<t.features.length;i++)Sl(t.features[i],e);break;case"Feature":Sl(t,e);break;default:_l(t,e)}return e}({type:"FeatureCollection",features:t}):null;this.index=function(t,e){return new Q(t,e)}(i,this.options.geojsonvt||n),r(null,{extent:o,idMap:e})}catch(t){console.warn(t),r({error:t.message})}}Lt(t){const e=[],i={};let n=0;function r(t){t&&("Feature"!==t.type||t.geometry)&&(void 0!==t.id&&null!==t.id||(t.id=n++),i[t.id]=f({},t),t.geometry?(i[t.id].geometry=f({},t.geometry),i[t.id].geometry.coordinates=null):t.coordinates&&(i[t.id].coordinates=null),e.length<1e3&&e.push(t))}return Array.isArray(t)?t.forEach(t=>{r(t)}):t.features&&t.features.forEach(t=>{r(t)}),{first1000:e,idMap:i}}getTileFeatures(t,e){const i=[];if(!this.index)return setTimeout((function(){e({loading:!0})}),1),1;const n=this.index.getTile(t.z+this.zoomOffset,t.x,t.y);if(!n||0===n.features.length)return setTimeout((function(){e(null,i,[])}),1),1;const r=[];for(let t=0,e=n.features.length;t<e;t++){const e=n.features[t];let o=e.layer;void 0===o&&(o="0"),r[o]={types:{}};r[o].types[e.type]=1,e.tags=e.tags||{},i.push({type:e.type,layer:o,id:e.id,geometry:e.geometry,properties:e.tags,extent:this.options.extent,geojson:!0})}for(const t in r)r[t].types=Object.keys(r[t].types).map(t=>+t);return setTimeout((function(){e(null,i,r)}),1),1}onRemove(){delete this.index}}var ql={\n/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nread:function(t,e,i,n,r){var o,s,a=8*r-n-1,l=(1<<a)-1,u=l>>1,c=-7,h=i?r-1:0,d=i?-1:1,f=t[e+h];for(h+=d,o=f&(1<<-c)-1,f>>=-c,c+=a;c>0;o=256*o+t[e+h],h+=d,c-=8);for(s=o&(1<<-c)-1,o>>=-c,c+=n;c>0;s=256*s+t[e+h],h+=d,c-=8);if(0===o)o=1-u;else{if(o===l)return s?NaN:1/0*(f?-1:1);s+=Math.pow(2,n),o-=u}return(f?-1:1)*s*Math.pow(2,o-n)},write:function(t,e,i,n,r,o){var s,a,l,u=8*o-r-1,c=(1<<u)-1,h=c>>1,d=23===r?Math.pow(2,-24)-Math.pow(2,-77):0,f=n?0:o-1,p=n?1:-1,m=e<0||0===e&&1/e<0?1:0;for(e=Math.abs(e),isNaN(e)||e===1/0?(a=isNaN(e)?1:0,s=c):(s=Math.floor(Math.log(e)/Math.LN2),e*(l=Math.pow(2,-s))<1&&(s--,l*=2),(e+=s+h>=1?d/l:d*Math.pow(2,1-h))*l>=2&&(s++,l/=2),s+h>=c?(a=0,s=c):s+h>=1?(a=(e*l-1)*Math.pow(2,r),s+=h):(a=e*Math.pow(2,h-1)*Math.pow(2,r),s=0));r>=8;t[i+f]=255&a,f+=p,a/=256,r-=8);for(s=s<<r|a,u+=r;u>0;t[i+f]=255&s,f+=p,s/=256,u-=8);t[i+f-p]|=128*m}},Rl=Nl,Cl=ql;function Nl(t){this.buf=ArrayBuffer.isView&&ArrayBuffer.isView(t)?t:new Uint8Array(t||0),this.pos=0,this.type=0,this.length=this.buf.length}Nl.Varint=0,Nl.Fixed64=1,Nl.Bytes=2,Nl.Fixed32=5;var Ll="undefined"==typeof TextDecoder?null:new TextDecoder("utf8");function Dl(t){return t.type===Nl.Bytes?t.readVarint()+t.pos:t.pos+1}function Ul(t,e,i){return i?4294967296*e+(t>>>0):4294967296*(e>>>0)+(t>>>0)}function $l(t,e,i){var n=e<=16383?1:e<=2097151?2:e<=268435455?3:Math.floor(Math.log(e)/(7*Math.LN2));i.realloc(n);for(var r=i.pos-1;r>=t;r--)i.buf[r+n]=i.buf[r]}function Wl(t,e){for(var i=0;i<t.length;i++)e.writeVarint(t[i])}function Jl(t,e){for(var i=0;i<t.length;i++)e.writeSVarint(t[i])}function Hl(t,e){for(var i=0;i<t.length;i++)e.writeFloat(t[i])}function Gl(t,e){for(var i=0;i<t.length;i++)e.writeDouble(t[i])}function Vl(t,e){for(var i=0;i<t.length;i++)e.writeBoolean(t[i])}function Bl(t,e){for(var i=0;i<t.length;i++)e.writeFixed32(t[i])}function Xl(t,e){for(var i=0;i<t.length;i++)e.writeSFixed32(t[i])}function Zl(t,e){for(var i=0;i<t.length;i++)e.writeFixed64(t[i])}function Yl(t,e){for(var i=0;i<t.length;i++)e.writeSFixed64(t[i])}function Kl(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+16777216*t[e+3]}function Ql(t,e,i){t[i]=e,t[i+1]=e>>>8,t[i+2]=e>>>16,t[i+3]=e>>>24}function tu(t,e){return(t[e]|t[e+1]<<8|t[e+2]<<16)+(t[e+3]<<24)}Nl.prototype={destroy:function(){this.buf=null},readFields:function(t,e,i){for(i=i||this.length;this.pos<i;){var n=this.readVarint(),r=n>>3,o=this.pos;this.type=7&n,t(r,e,this),this.pos===o&&this.skip(n)}return e},readMessage:function(t,e){return this.readFields(t,e,this.readVarint()+this.pos)},readFixed32:function(){var t=Kl(this.buf,this.pos);return this.pos+=4,t},readSFixed32:function(){var t=tu(this.buf,this.pos);return this.pos+=4,t},readFixed64:function(){var t=Kl(this.buf,this.pos)+4294967296*Kl(this.buf,this.pos+4);return this.pos+=8,t},readSFixed64:function(){var t=Kl(this.buf,this.pos)+4294967296*tu(this.buf,this.pos+4);return this.pos+=8,t},readFloat:function(){var t=Cl.read(this.buf,this.pos,!0,23,4);return this.pos+=4,t},readDouble:function(){var t=Cl.read(this.buf,this.pos,!0,52,8);return this.pos+=8,t},readVarint:function(t){var e,i,n=this.buf;return e=127&(i=n[this.pos++]),i<128?e:(e|=(127&(i=n[this.pos++]))<<7,i<128?e:(e|=(127&(i=n[this.pos++]))<<14,i<128?e:(e|=(127&(i=n[this.pos++]))<<21,i<128?e:function(t,e,i){var n,r,o=i.buf;if(r=o[i.pos++],n=(112&r)>>4,r<128)return Ul(t,n,e);if(r=o[i.pos++],n|=(127&r)<<3,r<128)return Ul(t,n,e);if(r=o[i.pos++],n|=(127&r)<<10,r<128)return Ul(t,n,e);if(r=o[i.pos++],n|=(127&r)<<17,r<128)return Ul(t,n,e);if(r=o[i.pos++],n|=(127&r)<<24,r<128)return Ul(t,n,e);if(r=o[i.pos++],n|=(1&r)<<31,r<128)return Ul(t,n,e);throw new Error("Expected varint not more than 10 bytes")}(e|=(15&(i=n[this.pos]))<<28,t,this))))},readVarint64:function(){return this.readVarint(!0)},readSVarint:function(){var t=this.readVarint();return t%2==1?(t+1)/-2:t/2},readBoolean:function(){return Boolean(this.readVarint())},readString:function(){var t=this.readVarint()+this.pos,e=this.pos;return this.pos=t,t-e>=12&&Ll?function(t,e,i){return Ll.decode(t.subarray(e,i))}(this.buf,e,t):function(t,e,i){var n="",r=e;for(;r<i;){var o,s,a,l=t[r],u=null,c=l>239?4:l>223?3:l>191?2:1;if(r+c>i)break;1===c?l<128&&(u=l):2===c?128==(192&(o=t[r+1]))&&(u=(31&l)<<6|63&o)<=127&&(u=null):3===c?(o=t[r+1],s=t[r+2],128==(192&o)&&128==(192&s)&&((u=(15&l)<<12|(63&o)<<6|63&s)<=2047||u>=55296&&u<=57343)&&(u=null)):4===c&&(o=t[r+1],s=t[r+2],a=t[r+3],128==(192&o)&&128==(192&s)&&128==(192&a)&&((u=(15&l)<<18|(63&o)<<12|(63&s)<<6|63&a)<=65535||u>=1114112)&&(u=null)),null===u?(u=65533,c=1):u>65535&&(u-=65536,n+=String.fromCharCode(u>>>10&1023|55296),u=56320|1023&u),n+=String.fromCharCode(u),r+=c}return n}(this.buf,e,t)},readBytes:function(){var t=this.readVarint()+this.pos,e=this.buf.subarray(this.pos,t);return this.pos=t,e},readPackedVarint:function(t,e){if(this.type!==Nl.Bytes)return t.push(this.readVarint(e));var i=Dl(this);for(t=t||[];this.pos<i;)t.push(this.readVarint(e));return t},readPackedSVarint:function(t){if(this.type!==Nl.Bytes)return t.push(this.readSVarint());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readSVarint());return t},readPackedBoolean:function(t){if(this.type!==Nl.Bytes)return t.push(this.readBoolean());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readBoolean());return t},readPackedFloat:function(t){if(this.type!==Nl.Bytes)return t.push(this.readFloat());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readFloat());return t},readPackedDouble:function(t){if(this.type!==Nl.Bytes)return t.push(this.readDouble());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readDouble());return t},readPackedFixed32:function(t){if(this.type!==Nl.Bytes)return t.push(this.readFixed32());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readFixed32());return t},readPackedSFixed32:function(t){if(this.type!==Nl.Bytes)return t.push(this.readSFixed32());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed32());return t},readPackedFixed64:function(t){if(this.type!==Nl.Bytes)return t.push(this.readFixed64());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readFixed64());return t},readPackedSFixed64:function(t){if(this.type!==Nl.Bytes)return t.push(this.readSFixed64());var e=Dl(this);for(t=t||[];this.pos<e;)t.push(this.readSFixed64());return t},skip:function(t){var e=7&t;if(e===Nl.Varint)for(;this.buf[this.pos++]>127;);else if(e===Nl.Bytes)this.pos=this.readVarint()+this.pos;else if(e===Nl.Fixed32)this.pos+=4;else{if(e!==Nl.Fixed64)throw new Error("Unimplemented type: "+e);this.pos+=8}},writeTag:function(t,e){this.writeVarint(t<<3|e)},realloc:function(t){for(var e=this.length||16;e<this.pos+t;)e*=2;if(e!==this.length){var i=new Uint8Array(e);i.set(this.buf),this.buf=i,this.length=e}},finish:function(){return this.length=this.pos,this.pos=0,this.buf.subarray(0,this.length)},writeFixed32:function(t){this.realloc(4),Ql(this.buf,t,this.pos),this.pos+=4},writeSFixed32:function(t){this.realloc(4),Ql(this.buf,t,this.pos),this.pos+=4},writeFixed64:function(t){this.realloc(8),Ql(this.buf,-1&t,this.pos),Ql(this.buf,Math.floor(t*(1/4294967296)),this.pos+4),this.pos+=8},writeSFixed64:function(t){this.realloc(8),Ql(this.buf,-1&t,this.pos),Ql(this.buf,Math.floor(t*(1/4294967296)),this.pos+4),this.pos+=8},writeVarint:function(t){(t=+t||0)>268435455||t<0?function(t,e){var i,n;t>=0?(i=t%4294967296|0,n=t/4294967296|0):(n=~(-t/4294967296),4294967295^(i=~(-t%4294967296))?i=i+1|0:(i=0,n=n+1|0));if(t>=0x10000000000000000||t<-0x10000000000000000)throw new Error("Given varint doesn\'t fit into 10 bytes");e.realloc(10),function(t,e,i){i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos]=127&t}(i,0,e),function(t,e){var i=(7&t)<<4;if(e.buf[e.pos++]|=i|((t>>>=3)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;if(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),!t)return;e.buf[e.pos++]=127&t}(n,e)}(t,this):(this.realloc(4),this.buf[this.pos++]=127&t|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=t>>>7&127))))},writeSVarint:function(t){this.writeVarint(t<0?2*-t-1:2*t)},writeBoolean:function(t){this.writeVarint(Boolean(t))},writeString:function(t){t=String(t),this.realloc(4*t.length),this.pos++;var e=this.pos;this.pos=function(t,e,i){for(var n,r,o=0;o<e.length;o++){if((n=e.charCodeAt(o))>55295&&n<57344){if(!r){n>56319||o+1===e.length?(t[i++]=239,t[i++]=191,t[i++]=189):r=n;continue}if(n<56320){t[i++]=239,t[i++]=191,t[i++]=189,r=n;continue}n=r-55296<<10|n-56320|65536,r=null}else r&&(t[i++]=239,t[i++]=191,t[i++]=189,r=null);n<128?t[i++]=n:(n<2048?t[i++]=n>>6|192:(n<65536?t[i++]=n>>12|224:(t[i++]=n>>18|240,t[i++]=n>>12&63|128),t[i++]=n>>6&63|128),t[i++]=63&n|128)}return i}(this.buf,t,this.pos);var i=this.pos-e;i>=128&&$l(e,i,this),this.pos=e-1,this.writeVarint(i),this.pos+=i},writeFloat:function(t){this.realloc(4),Cl.write(this.buf,t,this.pos,!0,23,4),this.pos+=4},writeDouble:function(t){this.realloc(8),Cl.write(this.buf,t,this.pos,!0,52,8),this.pos+=8},writeBytes:function(t){var e=t.length;this.writeVarint(e),this.realloc(e);for(var i=0;i<e;i++)this.buf[this.pos++]=t[i]},writeRawMessage:function(t,e){this.pos++;var i=this.pos;t(e,this);var n=this.pos-i;n>=128&&$l(i,n,this),this.pos=i-1,this.writeVarint(n),this.pos+=n},writeMessage:function(t,e,i){this.writeTag(t,Nl.Bytes),this.writeRawMessage(e,i)},writePackedVarint:function(t,e){e.length&&this.writeMessage(t,Wl,e)},writePackedSVarint:function(t,e){e.length&&this.writeMessage(t,Jl,e)},writePackedBoolean:function(t,e){e.length&&this.writeMessage(t,Vl,e)},writePackedFloat:function(t,e){e.length&&this.writeMessage(t,Hl,e)},writePackedDouble:function(t,e){e.length&&this.writeMessage(t,Gl,e)},writePackedFixed32:function(t,e){e.length&&this.writeMessage(t,Bl,e)},writePackedSFixed32:function(t,e){e.length&&this.writeMessage(t,Xl,e)},writePackedFixed64:function(t,e){e.length&&this.writeMessage(t,Zl,e)},writePackedSFixed64:function(t,e){e.length&&this.writeMessage(t,Yl,e)},writeBytesField:function(t,e){this.writeTag(t,Nl.Bytes),this.writeBytes(e)},writeFixed32Field:function(t,e){this.writeTag(t,Nl.Fixed32),this.writeFixed32(e)},writeSFixed32Field:function(t,e){this.writeTag(t,Nl.Fixed32),this.writeSFixed32(e)},writeFixed64Field:function(t,e){this.writeTag(t,Nl.Fixed64),this.writeFixed64(e)},writeSFixed64Field:function(t,e){this.writeTag(t,Nl.Fixed64),this.writeSFixed64(e)},writeVarintField:function(t,e){this.writeTag(t,Nl.Varint),this.writeVarint(e)},writeSVarintField:function(t,e){this.writeTag(t,Nl.Varint),this.writeSVarint(e)},writeStringField:function(t,e){this.writeTag(t,Nl.Bytes),this.writeString(e)},writeFloatField:function(t,e){this.writeTag(t,Nl.Fixed32),this.writeFloat(e)},writeDoubleField:function(t,e){this.writeTag(t,Nl.Fixed64),this.writeDouble(e)},writeBooleanField:function(t,e){this.writeVarintField(t,Boolean(e))}};var eu=Ot,iu=nu;function nu(t,e,i,n,r){this.properties={},this.extent=i,this.type=0,this.Ut=t,this.$t=-1,this.Wt=n,this.Jt=r,t.readFields(ru,this,e)}function ru(t,e,i){1==t?e.id=i.readVarint():2==t?function(t,e){var i=t.readVarint()+t.pos;for(;t.pos<i;){var n=e.Wt[t.readVarint()],r=e.Jt[t.readVarint()];e.properties[n]=r}}(i,e):3==t?e.type=i.readVarint():4==t&&(e.$t=i.pos)}function ou(t){for(var e,i,n=0,r=0,o=t.length,s=o-1;r<o;s=r++)e=t[r],n+=((i=t[s]).x-e.x)*(e.y+i.y);return n}nu.types=["Unknown","Point","LineString","Polygon"],nu.prototype.loadGeometry=function(){var t=this.Ut;t.pos=this.$t;for(var e,i=t.readVarint()+t.pos,n=1,r=0,o=0,s=0,a=[];t.pos<i;){if(r<=0){var l=t.readVarint();n=7&l,r=l>>3}if(r--,1===n||2===n)o+=t.readSVarint(),s+=t.readSVarint(),1===n&&(e&&a.push(e),e=[]),e.push(new eu(o,s));else{if(7!==n)throw new Error("unknown command "+n);e&&e.push(e[0].clone())}}return e&&a.push(e),a},nu.prototype.bbox=function(){var t=this.Ut;t.pos=this.$t;for(var e=t.readVarint()+t.pos,i=1,n=0,r=0,o=0,s=1/0,a=-1/0,l=1/0,u=-1/0;t.pos<e;){if(n<=0){var c=t.readVarint();i=7&c,n=c>>3}if(n--,1===i||2===i)(r+=t.readSVarint())<s&&(s=r),r>a&&(a=r),(o+=t.readSVarint())<l&&(l=o),o>u&&(u=o);else if(7!==i)throw new Error("unknown command "+i)}return[s,l,a,u]},nu.prototype.toGeoJSON=function(t,e,i){var n,r,o=this.extent*Math.pow(2,i),s=this.extent*t,a=this.extent*e,l=this.loadGeometry(),u=nu.types[this.type];function c(t){for(var e=0;e<t.length;e++){var i=t[e],n=180-360*(i.y+a)/o;t[e]=[360*(i.x+s)/o-180,360/Math.PI*Math.atan(Math.exp(n*Math.PI/180))-90]}}switch(this.type){case 1:var h=[];for(n=0;n<l.length;n++)h[n]=l[n][0];c(l=h);break;case 2:for(n=0;n<l.length;n++)c(l[n]);break;case 3:for(l=function(t){var e=t.length;if(e<=1)return[t];for(var i,n,r=[],o=0;o<e;o++){var s=ou(t[o]);0!==s&&(void 0===n&&(n=s<0),n===s<0?(i&&r.push(i),i=[t[o]]):i.push(t[o]))}i&&r.push(i);return r}(l),n=0;n<l.length;n++)for(r=0;r<l[n].length;r++)c(l[n][r])}1===l.length?l=l[0]:u="Multi"+u;var d={type:"Feature",geometry:{type:u,coordinates:l},properties:this.properties};return"id"in this&&(d.id=this.id),d};var su=iu,au=lu;function lu(t,e){this.version=1,this.name=null,this.extent=4096,this.length=0,this.Ut=t,this.Wt=[],this.Jt=[],this.Ht=[],t.readFields(uu,this,e),this.length=this.Ht.length}function uu(t,e,i){15===t?e.version=i.readVarint():1===t?e.name=i.readString():5===t?e.extent=i.readVarint():2===t?e.Ht.push(i.pos):3===t?e.Wt.push(i.readString()):4===t&&e.Jt.push(function(t){var e=null,i=t.readVarint()+t.pos;for(;t.pos<i;){var n=t.readVarint()>>3;e=1===n?t.readString():2===n?t.readFloat():3===n?t.readDouble():4===n?t.readVarint64():5===n?t.readVarint():6===n?t.readSVarint():7===n?t.readBoolean():null}return e}(i))}lu.prototype.feature=function(t){if(t<0||t>=this.Ht.length)throw new Error("feature index out of bounds");this.Ut.pos=this.Ht[t];var e=this.Ut.readVarint()+this.Ut.pos;return new su(this.Ut,e,this.extent,this.Wt,this.Jt)};var cu=au;function hu(t,e,i){if(3===t){var n=new cu(i,i.readVarint()+i.pos);n.length&&(e[n.name]=n)}}var du=function(t,e){this.layers=t.readFields(hu,{},e)};class fu extends kl{constructor(t,e,i,n,r,o){super(t,e,i,n,r),e=e||{},o()}getTileFeatures(t,e){const i=t.url;return A.getArrayBuffer(i,(t,i)=>{if(t)return void e(t);let n;try{n=new du(new Rl(i.data))}catch(t){return void e(t.message,[],[])}const r=[];if(!n.layers)return void e(null,r,[]);const o={};let s;for(const e in n.layers)if(a=n.layers,l=e,Object.prototype.hasOwnProperty.call(a,l)){o[e]={types:{}};const i=o[e].types;for(let o=0,a=n.layers[e].length;o<a;o++)try{s=n.layers[e].feature(o),i[s.type]=1,r.push({type:s.type,layer:e,geometry:s.loadGeometry(),properties:s.properties,extent:s.extent})}catch(t){console.warn("error when load vt geometry:",t)}}var a,l;for(const t in o)o[t].types=Object.keys(o[t].types).map(t=>+t);e(null,r,o,{byteLength:i.data.byteLength})})}abortTile(t,e){const i=this.requests[t];delete this.requests[t],i&&i.abort&&i.abort(),this.Et(t),e()}onRemove(){for(const t in this.requests)this.requests[t].abort();this.requests={}}}let pu=0;const mu=new class{constructor(t){this.max=t,this.reset()}reset(){return this.data={},this.order=[],this}clear(){this.reset()}add(t,e){return this.has(t)?(this.order.splice(this.order.indexOf(t),1),this.data[t]=e,this.order.push(t)):(this.data[t]=e,this.order.push(t),this.order.length>this.max&&this.getAndRemove(this.order[0])),this}has(t){return t in this.data}keys(){return this.order}getAndRemove(t){if(!this.has(t))return null;const e=this.data[t];return delete this.data[t],this.order.splice(this.order.indexOf(t),1),e}get(t){return this.has(t)?this.data[t]:null}remove(t){return this.has(t)?(delete this.data[t],this.order.splice(this.order.indexOf(t),1),this):this}setMaxSize(t){for(this.max=t;this.order.length>this.max;)this.getAndRemove(this.order[0]);return this}}(128),yu={};class gu{constructor(t){this.Gt={},this.Vt={},this.workerId=t}addLayer({actorId:t,mapId:e,layerId:i,params:n},r){if(this.Bt(e,i))return;const o=this.Xt(e,i),s=n.type,a=n.options,l=this.send.bind(this,t);this.Gt[o]="GeoJSONVectorTileLayer"===s?new El(i,a,l,mu,yu,r):new fu(i,a,l,mu,yu,r)}removeLayer({mapId:t,layerId:e},i){const n=this.Bt(t,e),r=this.Xt(t,e);delete this.Gt[r],n&&(n.onRemove(i),this.Zt())}loadTile({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&r.loadTile(i,n)}abortTile({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&r.abortTile&&r.abortTile(i.url,n)}removeTile({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&r.removeTile(i,n)}updateStyle({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&(r.updateStyle(i,n),this.Zt())}updateOptions({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&(r.updateOptions(i,n),this.Zt())}setData({mapId:t,layerId:e,params:i},n){const r=this.Bt(t,e);r&&(r.setData(i.data,n),this.Zt())}receive(t){const e=t.callback,i=this.Vt[e];delete this.Vt[e],i&&t.error?i(new Error(t.error)):i&&i(null,t.data)}send(t,e,i,n,r){const o=r?`${t}-${pu++}`:null;r&&(this.Vt[o]=r),postMessage({type:"<request>",workerId:this.workerId,actorId:t,command:e,params:i,callback:String(o)},n||[])}Xt(t,e){return`${t}-${e}`}Bt(t,e){const i=this.Xt(t,e);return this.Gt[i]}Zt(){const t=Object.keys(yu);for(let e=0;e<t.length;e++)delete yu[t[e]];mu.reset()}}t.initialize=function(){},t.onmessage=function(t,e){const i=t.data;if(this.dispatcher||(this.dispatcher=new gu(t.workerId)),"<response>"===t.type)this.dispatcher.workerId===t.workerId&&this.dispatcher.receive(t);else{const n=i.command;this.dispatcher[n]({actorId:t.actorId,mapId:i.mapId,layerId:i.layerId,params:i.params},(t,i,r)=>{t&&404!==t.status&&console.error(n,t),e(t,i,r)})}},Object.defineProperty(t,"Yt",{value:!0})}';
29
29
 
30
- let N = 0;
30
+ let D = 0;
31
31
 
32
- function R() {
33
- return N++;
32
+ function L() {
33
+ return D++;
34
34
  }
35
35
 
36
- const L = "function" == typeof Object.assign;
36
+ const R = "function" == typeof Object.assign;
37
37
 
38
38
  function H(t, ...e) {
39
- if (L) return Object.assign(t, ...e), t;
39
+ if (R) return Object.assign(t, ...e), t;
40
40
  for (let i = 0; i < e.length; i++) {
41
41
  const n = e[i];
42
42
  for (const e in n) t[e] = n[e];
@@ -80,11 +80,11 @@ function $(t, e) {
80
80
 
81
81
  const X = [ "GeoJSONVectorTileLayer" ];
82
82
 
83
- class Y extends t.worker.Actor {
83
+ class J extends t.worker.Actor {
84
84
  constructor(t, e) {
85
85
  super(t);
86
86
  const i = e.getMap().id;
87
- this.t = e, this.i = i, this.o = "vt_" + R();
87
+ this.t = e, this.i = i, this.o = "vt_" + L();
88
88
  const n = e.getJSONType();
89
89
  this.s = X.indexOf(n) >= 0, this.l = {}, this.h = new g({
90
90
  iconErrorUrl: e.options.iconErrorUrl,
@@ -194,7 +194,7 @@ class Y extends t.worker.Actor {
194
194
  }
195
195
  }
196
196
 
197
- const J = {};
197
+ const Y = {};
198
198
 
199
199
  class Z {
200
200
  constructor(t, e, i) {
@@ -312,29 +312,29 @@ class it {
312
312
  aPosition: tt
313
313
  }, null, tt.length / 2, {
314
314
  positionSize: 2
315
- })).generateBuffers(t), this.C = new i.Scene, this.F = [], this.j = 0, this.D = e,
315
+ })).generateBuffers(t), this.C = new i.Scene, this.F = [], this.j = 0, this.N = e,
316
316
  this.g = n, this._(t);
317
317
  }
318
318
  start() {
319
319
  this.j = 0, this.C.clear();
320
320
  }
321
321
  add(t, e, i) {
322
- const o = this.N(i);
322
+ const o = this.D(i);
323
323
  o.setUniform("ref", t), n.set(et, e, e, 1);
324
324
  const s = o.localTransform;
325
325
  r.fromScaling(s, et), r.mul(s, i, s), o.setLocalTransform(s), this.C.addMesh(o);
326
326
  }
327
327
  render(t) {
328
- this.R.render(this.L, {
328
+ this.L.render(this.R, {
329
329
  projViewMatrix: this.g.projViewMatrix
330
330
  }, this.C, t);
331
331
  }
332
- N() {
332
+ D() {
333
333
  const t = this.j++;
334
334
  return this.F[t] || (this.F[t] = new i.Mesh(this.O)), this.F[t];
335
335
  }
336
336
  _(t) {
337
- const e = this.D, n = {
337
+ const e = this.N, n = {
338
338
  viewport: {
339
339
  x: 0,
340
340
  y: 0,
@@ -362,7 +362,7 @@ class it {
362
362
  },
363
363
  colorMask: [ !1, !1, !1, !1 ]
364
364
  };
365
- this.L = new i.MeshShader({
365
+ this.R = new i.MeshShader({
366
366
  vert: "\n#define SHADER_NAME TILE_STENCIL_VERT\nattribute vec2 aPosition;\nuniform mat4 projViewModelMatrix;\n\nvoid main()\n{\n gl_Position = projViewModelMatrix * vec4(aPosition, 0.0, 1.0);\n}\n",
367
367
  frag: "\n#define SHADER_NAME TILE_STENCIL_FRAG\nvoid main()\n{\n gl_FragColor = vec4(1.0, 0.0, 0.0, 0.1);\n}\n",
368
368
  uniforms: [ {
@@ -374,12 +374,12 @@ class it {
374
374
  }
375
375
  } ],
376
376
  extraCommandProps: n
377
- }), this.R = new i.Renderer(t);
377
+ }), this.L = new i.Renderer(t);
378
378
  }
379
379
  remove() {
380
380
  this.O.dispose();
381
381
  for (let t = 0; t < this.F.length; t++) this.F[t].dispose();
382
- this.F.length = 0, this.L.dispose();
382
+ this.F.length = 0, this.R.dispose();
383
383
  }
384
384
  }
385
385
 
@@ -440,7 +440,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
440
440
  const n = 0 === t ? this.plugins : this.featurePlugins;
441
441
  if (!n || !n[e]) return;
442
442
  this.B = !0;
443
- const r = this.layer.W(), o = this.layer.Y(t, r);
443
+ const r = this.layer.W(), o = this.layer.J(t, r);
444
444
  n[e].config = o[e].renderPlugin, n[e].updateSceneConfig({
445
445
  sceneConfig: i
446
446
  }), this.setToRedraw();
@@ -452,7 +452,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
452
452
  updateSymbol(t, e, i) {
453
453
  const n = 0 === t ? this.plugins : this.featurePlugins;
454
454
  if (!n || !n[e]) return !1;
455
- const r = this.layer.W(), o = this.layer.Y(t, r), s = n[e];
455
+ const r = this.layer.W(), o = this.layer.J(t, r), s = n[e];
456
456
  s.style = o[e];
457
457
  const a = s.updateSymbol(i, o[e].symbol);
458
458
  return this.setToRedraw(), a;
@@ -461,14 +461,14 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
461
461
  if (this.U.length) return !0;
462
462
  const t = super.needToRedraw();
463
463
  if (!t) {
464
- const t = this.J();
464
+ const t = this.Y();
465
465
  for (let e = 0; e < t.length; e++) if (t[e] && t[e].needToRedraw()) return !0;
466
466
  }
467
467
  return t;
468
468
  }
469
469
  needRetireFrames() {
470
470
  if (this.B) return !0;
471
- const t = this.J();
471
+ const t = this.Y();
472
472
  for (let e = 0; e < t.length; e++) if (t[e] && t[e].needToRetireFrames()) return !0;
473
473
  return !1;
474
474
  }
@@ -494,7 +494,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
494
494
  });
495
495
  }
496
496
  tt() {
497
- this.q || (this.q = new Y("@maptalks/vt", this.layer));
497
+ this.q || (this.q = new J("@maptalks/vt", this.layer));
498
498
  this.q.addLayer((t, e) => {
499
499
  this.layer && (this.ready = !0, this.layer.onWorkerReady(t, e), this.layer.fire("workerready"),
500
500
  this.setToRedraw());
@@ -525,12 +525,12 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
525
525
  this.it !== t && this.ut(t), this.dt(t), this.completeRender(), this.it = t) : this.completeRender()) : this.completeRender();
526
526
  }
527
527
  nt() {
528
- this.J().forEach((t, e) => {
528
+ this.Y().forEach((t, e) => {
529
529
  t.renderIndex = e;
530
530
  });
531
531
  }
532
532
  ut() {
533
- const t = this.J();
533
+ const t = this.Y();
534
534
  this.ft = [];
535
535
  let e = +!!this.layer.getGroundConfig().enable;
536
536
  t.forEach((t, i) => {
@@ -550,7 +550,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
550
550
  }
551
551
  getShadowMeshes() {
552
552
  const t = [];
553
- return this.J().forEach((e, i) => {
553
+ return this.Y().forEach((e, i) => {
554
554
  if (!e) return;
555
555
  if (!this.vt(i)) return;
556
556
  const n = e.getShadowMeshes();
@@ -597,7 +597,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
597
597
  if (delete this.V[t], e) {
598
598
  if (e.status && 404 === e.status) for (let t = 0; t < o.length; t++) {
599
599
  const e = o[t];
600
- this.onTileError(J, e);
600
+ this.onTileError(Y, e);
601
601
  }
602
602
  return;
603
603
  }
@@ -685,7 +685,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
685
685
  o = !0);
686
686
  } else {
687
687
  const s = n.W();
688
- if (r = n.Y(t, s)[e], !r.renderPlugin) {
688
+ if (r = n.J(t, s)[e], !r.renderPlugin) {
689
689
  o = !0;
690
690
  const {plugin: t, symbol: n, renderPlugin: s} = this.Pt(i.type);
691
691
  this.plugins[e] = t, r.symbol = n, r.renderPlugin = s;
@@ -696,7 +696,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
696
696
  isUpdated: o
697
697
  };
698
698
  }
699
- J(t) {
699
+ Y(t) {
700
700
  let e = this.plugins || [];
701
701
  return this.layer.isDefaultRender() && this.Mt && (e = [], t ? t.layers && t.layers.forEach(t => {
702
702
  const i = ("plugin_" + t.type).trim();
@@ -717,7 +717,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
717
717
  }
718
718
  ht(t) {
719
719
  const e = this.layer.isDefaultRender() && this.Mt, i = this.lt;
720
- this.J().forEach((n, r) => {
720
+ this.Y().forEach((n, r) => {
721
721
  if (!n) return;
722
722
  if (!this.vt(r)) return;
723
723
  const o = e ? n.defaultSymbol : n.style && n.style.symbol, s = {
@@ -734,7 +734,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
734
734
  });
735
735
  }
736
736
  dt(t) {
737
- const e = this.lt, i = e.renderMode, n = e && e.renderTarget && e.renderTarget.fbo, r = this.getMap().cameraPosition, o = this.J();
737
+ const e = this.lt, i = e.renderMode, n = e && e.renderTarget && e.renderTarget.fbo, r = this.getMap().cameraPosition, o = this.Y();
738
738
  this.layer.options.collision ? o.forEach(e => {
739
739
  if (!ut(e)) return;
740
740
  if (i && "default" !== i && !e.supportRenderMode(i)) return;
@@ -805,20 +805,20 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
805
805
  const e = this.isEnableTileStencil(), i = this.getCurrentTileZoom();
806
806
  let n = this.jt;
807
807
  n || (n = this.jt = new it(this.regl, this.canvas, this.getMap())), n.start();
808
- const {tiles: r} = this.Dt;
809
- let {parentTiles: o, childTiles: s} = this.Dt, a = 1;
808
+ const {tiles: r} = this.Nt;
809
+ let {parentTiles: o, childTiles: s} = this.Nt, a = 1;
810
810
  s = s.sort(ct);
811
- for (let t = 0; t < s.length; t++) this.Nt(s[t].info, e ? a : this.getTileLevelValue(s[t].info.z, i)),
811
+ for (let t = 0; t < s.length; t++) this.Dt(s[t].info, e ? a : this.getTileLevelValue(s[t].info.z, i)),
812
812
  a++;
813
813
  o = o.sort(ct);
814
- for (let t = 0; t < o.length; t++) this.Nt(o[t].info, e ? a : this.getTileLevelValue(o[t].info.z, i)),
814
+ for (let t = 0; t < o.length; t++) this.Dt(o[t].info, e ? a : this.getTileLevelValue(o[t].info.z, i)),
815
815
  a++;
816
816
  const l = r.sort(ct);
817
- for (let t = l.length - 1; t >= 0; t--) this.Nt(l[t].info, e ? a : this.getTileLevelValue(l[t].info.z, i)),
817
+ for (let t = l.length - 1; t >= 0; t--) this.Dt(l[t].info, e ? a : this.getTileLevelValue(l[t].info.z, i)),
818
818
  a++;
819
819
  n.render(t);
820
820
  }
821
- Nt(t, e) {
821
+ Dt(t, e) {
822
822
  const i = at.set(t.extent2d.xmin, t.extent2d.ymax), n = t.transform = t.transform || this.calculateTileMatrix(i, t.z, t.extent);
823
823
  t.stencilRef = e, this.jt.add(e, t.extent, n);
824
824
  }
@@ -829,7 +829,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
829
829
  for (let t = 0; t < e.length; t++) this.bt[e[t].info.id] = 1;
830
830
  for (let t = 0; t < i.length; t++) this.xt[i[t].info.id] = 1;
831
831
  for (let t = 0; t < n.length; t++) this.xt[n[t].info.id] = 1;
832
- this.Dt = t;
832
+ this.Nt = t;
833
833
  }
834
834
  isEnableTileStencil() {
835
835
  return this.layer.isOnly2D();
@@ -838,7 +838,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
838
838
  if (!e.cache) return;
839
839
  const i = e.cache, n = at.set(t.extent2d.xmin, t.extent2d.ymax), r = t.transform = t.transform || this.calculateTileMatrix(n, t.z, t.extent), o = t.tileTranslationMatrix = t.tileTranslationMatrix || this.calculateTileTranslationMatrix(n, t.z), s = [];
840
840
  W(s, e.data), W(s, e.featureData);
841
- this.J(e).forEach((n, a) => {
841
+ this.Y(e).forEach((n, a) => {
842
842
  if (!n) return;
843
843
  const l = this.vt(a);
844
844
  if (!s[a] || !l) return;
@@ -863,13 +863,13 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
863
863
  c.redraw && this.setToRedraw();
864
864
  }), this.setCanvasUpdated();
865
865
  }
866
- Rt(t, e) {
866
+ Lt(t, e) {
867
867
  if (!e.loadTime || e.At) return;
868
868
  let i = e.cache;
869
869
  i || (i = e.cache = {});
870
870
  const n = at.set(t.extent2d.xmin, t.extent2d.ymax), r = t.transform = t.transform || this.calculateTileMatrix(n, t.z, e.extent), o = t.tileTranslationMatrix = t.tileTranslationMatrix || this.calculateTileTranslationMatrix(n, t.z), s = [];
871
871
  W(s, e.data), W(s, e.featureData);
872
- this.J(e).forEach((n, a) => {
872
+ this.Y(e).forEach((n, a) => {
873
873
  if (!n) return;
874
874
  const l = this.vt(a);
875
875
  if (!s[a] || !l) return;
@@ -897,12 +897,12 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
897
897
  const e = this.layer.options.meshLimitPerFrame, i = this.U;
898
898
  for (;i.length && t < e; ) {
899
899
  const {tileData: e, tileInfo: n} = i.shift();
900
- this.onTileLoad(e, n), this.Rt(n, e), t++;
900
+ this.onTileLoad(e, n), this.Lt(n, e), t++;
901
901
  }
902
902
  }
903
903
  pick(t, e, i) {
904
904
  const n = [];
905
- return this.J().forEach((r, o) => {
905
+ return this.Y().forEach((r, o) => {
906
906
  if (!r) return;
907
907
  if (!this.vt(o)) return;
908
908
  const s = r.pick(t, e, i.tolerance);
@@ -935,7 +935,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
935
935
  super.resizeCanvas(t);
936
936
  const e = this.canvas;
937
937
  e && (!this.pickingFBO || this.pickingFBO.width === e.width && this.pickingFBO.height === e.height || this.pickingFBO.resize(e.width, e.height),
938
- this.J().forEach(t => {
938
+ this.Y().forEach(t => {
939
939
  t && t.resize(e.width, e.height);
940
940
  }));
941
941
  }
@@ -947,7 +947,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
947
947
  this.$();
948
948
  }
949
949
  $() {
950
- this.J().forEach(t => {
950
+ this.Y().forEach(t => {
951
951
  t.remove();
952
952
  }), this.plugins = [];
953
953
  }
@@ -961,19 +961,19 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
961
961
  const i = t.renderPlugin;
962
962
  if (!i) return null;
963
963
  if (!i.type) throw new Error("invalid plugin type for style at " + e);
964
- const n = this.Lt(i);
964
+ const n = this.Rt(i);
965
965
  return n.style = t, n;
966
966
  }), n = [];
967
967
  return e.forEach((t, e) => {
968
968
  const i = t.renderPlugin;
969
969
  if (!i) return null;
970
970
  if (!i.type) throw new Error("invalid plugin type for features at " + e);
971
- const r = this.Lt(i);
971
+ const r = this.Rt(i);
972
972
  return r.style = t, n.push(r), r;
973
973
  }), this.plugins = i, this.featurePlugins = n, this.layer.fire("pluginsinited"),
974
974
  i;
975
975
  }
976
- Lt(t) {
976
+ Rt(t) {
977
977
  const e = this.layer.constructor.getPlugins()[t.type];
978
978
  if (!e) throw new Error(`Plugin for (${t.type}) is not loaded.`);
979
979
  const i = new e;
@@ -1069,7 +1069,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
1069
1069
  };
1070
1070
  }
1071
1071
  return null;
1072
- }(t), n = this.Lt(e);
1072
+ }(t), n = this.Rt(e);
1073
1073
  return n.defaultSymbol = i, {
1074
1074
  plugin: n,
1075
1075
  symbol: i,
@@ -1107,12 +1107,12 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
1107
1107
  this.gt = !0, this.setToRedraw();
1108
1108
  }
1109
1109
  paintOutlineAll(t) {
1110
- const e = this.J();
1110
+ const e = this.Y();
1111
1111
  for (let i = 0; i < e.length; i++) e[i].outlineAll(t);
1112
1112
  }
1113
1113
  paintOutline(t, e, i) {
1114
1114
  if (!G(e)) {
1115
- const n = e, r = this.J();
1115
+ const n = e, r = this.Y();
1116
1116
  if (!r[n] || r[n].painter && !r[n].painter.isVisible()) return;
1117
1117
  return void r[n].outline(t, i);
1118
1118
  }
@@ -1123,7 +1123,7 @@ class lt extends t.renderer.TileLayerCanvasRenderer {
1123
1123
  }
1124
1124
  }
1125
1125
  paintBatchOutline(t, e) {
1126
- const i = this.J();
1126
+ const i = this.Y();
1127
1127
  !i[e] || i[e].painter && !i[e].painter.isVisible() || i[e].outlineAll(t);
1128
1128
  }
1129
1129
  cancelOutline() {
@@ -1183,7 +1183,7 @@ lt.include({
1183
1183
 
1184
1184
  const ft = "function" == typeof fetch && "function" == typeof AbortController, pt = {
1185
1185
  jsonp: function(t, e) {
1186
- const i = "_maptalks_jsonp_" + R();
1186
+ const i = "_maptalks_jsonp_" + L();
1187
1187
  t.match(/\?/) ? t += "&callback=" + i : t += "?callback=" + i;
1188
1188
  let n = document.createElement("script");
1189
1189
  return n.type = "text/javascript", n.src = t, window[i] = function(t) {
@@ -1404,9 +1404,9 @@ class vt extends t.TileLayer {
1404
1404
  } else e.push(H({}, t[i]));
1405
1405
  }
1406
1406
  return e;
1407
- }(t.featureStyle), this.Yt = t.style || [];
1407
+ }(t.featureStyle), this.Jt = t.style || [];
1408
1408
  const e = t.background || {};
1409
- this.Jt = {
1409
+ this.Yt = {
1410
1410
  enable: e.enable || !1,
1411
1411
  color: xt(e.color) || [ 0, 0, 0, 0 ],
1412
1412
  opacity: wt(e.opacity, 1),
@@ -1453,7 +1453,7 @@ class vt extends t.TileLayer {
1453
1453
  return t ? (t.cancelOutline(), this) : this;
1454
1454
  }
1455
1455
  Zt() {
1456
- t.Util.convertStylePath(this.Yt, this.Wt), t.Util.convertStylePath(this.$t, this.Wt);
1456
+ t.Util.convertStylePath(this.Jt, this.Wt), t.Util.convertStylePath(this.$t, this.Wt);
1457
1457
  }
1458
1458
  updateSceneConfig(t, e) {
1459
1459
  return this.te(0, t, e);
@@ -1462,7 +1462,7 @@ class vt extends t.TileLayer {
1462
1462
  return this.te(1, t, i, e);
1463
1463
  }
1464
1464
  te(t, e, i, n) {
1465
- const r = this.Y(t);
1465
+ const r = this.J(t);
1466
1466
  if (!r) return this;
1467
1467
  let o, s = e;
1468
1468
  if (r[e].renderPlugin.sceneConfig || (r[e].renderPlugin.sceneConfig = {}), H(r[e].renderPlugin.sceneConfig, i),
@@ -1475,7 +1475,7 @@ class vt extends t.TileLayer {
1475
1475
  const t = this.options.style[e].renderPlugin;
1476
1476
  t.sceneConfig || (t.sceneConfig = {}), H(t.sceneConfig, i);
1477
1477
  } else {
1478
- const r = this.Y(t, this.options.style);
1478
+ const r = this.J(t, this.options.style);
1479
1479
  let o;
1480
1480
  void 0 !== n ? (At(r, e, n), o = r[e].style[n].renderPlugin) : (_t(r, e), o = r[e].renderPlugin),
1481
1481
  o.sceneConfig || (o.sceneConfig = {}), H(o.sceneConfig, i);
@@ -1497,14 +1497,14 @@ class vt extends t.TileLayer {
1497
1497
  return this.ee(1, t, i, e);
1498
1498
  }
1499
1499
  ee(t, e, i, n) {
1500
- const r = this.Y(t);
1500
+ const r = this.J(t);
1501
1501
  if (!r) return this;
1502
1502
  let o, s = e;
1503
1503
  void 0 !== n ? (At(this.Bt, e, n), s = this.Bt[e].style[n].Xt, o = r[s].renderPlugin.dataConfig) : (_t(r, e),
1504
1504
  o = r[e].renderPlugin.dataConfig);
1505
1505
  const a = H({}, o);
1506
1506
  if (H(o, i), Array.isArray(this.options.style)) H(this.options.style[e].renderPlugin.dataConfig, i); else {
1507
- const r = this.Y(t, this.options.style);
1507
+ const r = this.J(t, this.options.style);
1508
1508
  let o;
1509
1509
  void 0 !== n ? (At(r, e, n), o = r[e].style[n].renderPlugin) : (_t(r, e), o = r[e].renderPlugin),
1510
1510
  o.dataConfig || (o.dataConfig = {}), H(o.dataConfig, i);
@@ -1530,7 +1530,7 @@ class vt extends t.TileLayer {
1530
1530
  return this.ie(1, t, i, e);
1531
1531
  }
1532
1532
  ie(e, i, n, r) {
1533
- const o = this.Y(e);
1533
+ const o = this.J(e);
1534
1534
  if (!o) return this;
1535
1535
  let s = i;
1536
1536
  void 0 !== r && (At(this.Bt, i, r), s = this.Bt[i].style[r].Xt);
@@ -1552,7 +1552,7 @@ class vt extends t.TileLayer {
1552
1552
  for (const e in n) B(n, e) && (!t.Util.isObject(n[e]) || Array.isArray(n[e]) || n[e].stops ? o[e] = n[e] : (o[e] || (o[e] = {}),
1553
1553
  H(o[e], n[e])));
1554
1554
  let u = l.options.style;
1555
- Array.isArray(u) || (u = l.Y(e, l.options.style));
1555
+ Array.isArray(u) || (u = l.J(e, l.options.style));
1556
1556
  const d = JSON.parse(JSON.stringify(o));
1557
1557
  return void 0 !== r ? (At(u, i, r), void 0 === s ? u[i].style[r].symbol = d : u[i].style[r].symbol[s] = d) : (_t(u, i),
1558
1558
  void 0 === s ? u[i].symbol = d : u[i].symbol[s] = d), c;
@@ -1575,19 +1575,19 @@ class vt extends t.TileLayer {
1575
1575
  symbol: n
1576
1576
  }), this;
1577
1577
  }
1578
- Y(t, e) {
1578
+ J(t, e) {
1579
1579
  if (e) {
1580
1580
  return 0 === t ? e.style : e.featureStyle;
1581
1581
  }
1582
- return 0 === t ? this.Yt : this.$t;
1582
+ return 0 === t ? this.Jt : this.$t;
1583
1583
  }
1584
1584
  isDefaultRender() {
1585
1585
  return !!this.re && this.options.defaultRendering;
1586
1586
  }
1587
1587
  validateStyle() {
1588
1588
  this.oe = !0, this.re = !1;
1589
- let t = this.Yt;
1590
- this.options.style || (this.re = !0, t = this.Yt = []), Array.isArray(t) || (t = this.Yt = [ t ]);
1589
+ let t = this.Jt;
1590
+ this.options.style || (this.re = !0, t = this.Jt = []), Array.isArray(t) || (t = this.Jt = [ t ]);
1591
1591
  for (let e = 0; e < t.length; e++) {
1592
1592
  let i = t[e].filter;
1593
1593
  if (i && i.value && (i = i.value), void 0 !== i && "default" !== i && !0 !== i && !Array.isArray(i) && void 0 === i.condition) throw new Error(`Invalid filter at ${e} : ${JSON.stringify(i)}`);
@@ -1598,7 +1598,7 @@ class vt extends t.TileLayer {
1598
1598
  return this.options.style ? JSON.parse(JSON.stringify(this.options.style)) : null;
1599
1599
  }
1600
1600
  addRenderStyle(t, e) {
1601
- let i = this.Yt;
1601
+ let i = this.Jt;
1602
1602
  return i ? t < 0 || t >= i.length ? i.push(e) : i.splice(t, 0, e) : i = [ e ], this.qt({
1603
1603
  $root: this.Gt,
1604
1604
  style: i,
@@ -1606,7 +1606,7 @@ class vt extends t.TileLayer {
1606
1606
  }), this;
1607
1607
  }
1608
1608
  updateRenderStyle(t, e) {
1609
- let i = this.Yt;
1609
+ let i = this.Jt;
1610
1610
  return !i || t < 0 || t >= i.length || (i.splice(t, 1, e), this.qt({
1611
1611
  $root: this.Gt,
1612
1612
  style: i,
@@ -1618,7 +1618,7 @@ class vt extends t.TileLayer {
1618
1618
  return this.updateRenderStyle(i, e);
1619
1619
  }
1620
1620
  removeRenderStyle(t) {
1621
- let e = this.Yt;
1621
+ let e = this.Jt;
1622
1622
  return !e || t < 0 || t >= e.length || (e.splice(t, 1), this.qt({
1623
1623
  $root: this.Gt,
1624
1624
  style: e,
@@ -1630,19 +1630,17 @@ class vt extends t.TileLayer {
1630
1630
  return this.removeRenderStyle(e);
1631
1631
  }
1632
1632
  addFeatureStyle(t) {
1633
- if (!t) return this;
1634
- const e = t.id;
1635
- return this.updateFeatureStyleById(e, t.style), this;
1633
+ return t ? (this.updateFeatureStyleById(t), this) : this;
1636
1634
  }
1637
1635
  updateFeatureStyleById(t) {
1638
1636
  if (!t) return this;
1639
1637
  const e = t.id;
1640
1638
  if (G(e)) return this;
1641
- const i = this.getFeatureStyleIndex(e), n = this.Bt;
1639
+ const i = this.getFeatureStyleIndex(e), n = this.Bt || [];
1642
1640
  return i < 0 ? n.push(t) : n[i] = t, this.qt({
1643
1641
  $root: this.Gt,
1644
- style: this.Yt,
1645
- featureStyle: t
1642
+ style: this.Jt,
1643
+ featureStyle: n
1646
1644
  }), this;
1647
1645
  }
1648
1646
  removeFeatureStyleById(t) {
@@ -1651,7 +1649,7 @@ class vt extends t.TileLayer {
1651
1649
  const i = this.Bt.splice(e, 1);
1652
1650
  return this.qt({
1653
1651
  $root: this.Gt,
1654
- style: this.Yt,
1652
+ style: this.Jt,
1655
1653
  featureStyle: i
1656
1654
  }), this;
1657
1655
  }
@@ -1663,7 +1661,7 @@ class vt extends t.TileLayer {
1663
1661
  return -1;
1664
1662
  }
1665
1663
  ne(t) {
1666
- const e = this.Yt;
1664
+ const e = this.Jt;
1667
1665
  if (!e) return -1;
1668
1666
  for (let i = 0; i < e.length; i++) if (e[i].name === t) return i;
1669
1667
  throw new Error("No style defined with name: " + t);
@@ -1690,8 +1688,8 @@ class vt extends t.TileLayer {
1690
1688
  }
1691
1689
  W() {
1692
1690
  return {
1693
- background: this.Jt,
1694
- style: this.Yt || [],
1691
+ background: this.Yt,
1692
+ style: this.Jt || [],
1695
1693
  featureStyle: this.$t || []
1696
1694
  };
1697
1695
  }
@@ -2325,7 +2323,7 @@ const Ot = {
2325
2323
  }
2326
2324
  }, Ft = new t.Point(0, 0), zt = "_vector3dlayer_id", jt = "_line_gradient_property".trim();
2327
2325
 
2328
- function Dt(e, i, n) {
2326
+ function Nt(e, i, n) {
2329
2327
  const r = "__fea_idx".trim(), o = e.getMap(), s = o.getGLRes();
2330
2328
  let a = e.getCoordinates();
2331
2329
  const l = [];
@@ -2353,7 +2351,7 @@ function Dt(e, i, n) {
2353
2351
  if (Array.isArray(u) && u.length) {
2354
2352
  const t = [], o = u.length;
2355
2353
  for (let s = 0; s < o; s++) {
2356
- const a = s === o - 1 ? c : H({}, c), f = Nt(u[s], a);
2354
+ const a = s === o - 1 ? c : H({}, c), f = Dt(u[s], a);
2357
2355
  for (const t in u[s]) if (B(u[s], t)) {
2358
2356
  a[("_symbol_" + t).trim()] = u[s][t];
2359
2357
  }
@@ -2371,7 +2369,7 @@ function Dt(e, i, n) {
2371
2369
  return t;
2372
2370
  }
2373
2371
  if (u) {
2374
- const t = Nt(u, c);
2372
+ const t = Dt(u, c);
2375
2373
  for (const t in u) if (B(u, t)) {
2376
2374
  c[("_symbol_" + t).trim()] = u[t];
2377
2375
  }
@@ -2388,15 +2386,15 @@ function Dt(e, i, n) {
2388
2386
  return p[r] = f, p;
2389
2387
  }
2390
2388
 
2391
- function Nt(t, e) {
2389
+ function Dt(t, e) {
2392
2390
  const i = t.lineGradientProperty;
2393
2391
  return i && (e[jt] = e[i], e.mapbox_clip_start = 0, e.mapbox_clip_end = 1, delete e[i]),
2394
2392
  i;
2395
2393
  }
2396
2394
 
2397
- let Rt = 1;
2395
+ let Lt = 1;
2398
2396
 
2399
- const Lt = "_symbol_".trim(), Ht = "__fea_idx".trim();
2397
+ const Rt = "_symbol_".trim(), Ht = "__fea_idx".trim();
2400
2398
 
2401
2399
  let Vt = new Float32Array(1);
2402
2400
 
@@ -2426,16 +2424,16 @@ class Ut extends t.renderer.CanvasRenderer {
2426
2424
  const t = this.je;
2427
2425
  delete this.je, this.Ce(t), this.Fe = !1;
2428
2426
  }
2429
- if (!this.meshes && !this.De && !this.Ne) return void this.completeRender();
2430
- this.Re && (this.Le(), this.Re = !1), this.He(), this.rt = t, this.lt = e || {};
2427
+ if (!this.meshes && !this.Ne && !this.De) return void this.completeRender();
2428
+ this.Le && (this.Re(), this.Le = !1), this.He(), this.rt = t, this.lt = e || {};
2431
2429
  const n = this.lt.renderMode, r = !n || "default" === n, o = this.Ve();
2432
2430
  let s = 0;
2433
- 0 === this.layer.options.meshRenderOrder && this.Ue(o, s++, n), this.Ne && (r || this.Ie.supportRenderMode(n)) && (this.Ie.startFrame(o),
2434
- this.Ie.addMesh(this.Ne, null, {
2431
+ 0 === this.layer.options.meshRenderOrder && this.Ue(o, s++, n), this.De && (r || this.Ie.supportRenderMode(n)) && (this.Ie.startFrame(o),
2432
+ this.Ie.addMesh(this.De, null, {
2435
2433
  bloom: this.lt.bloom
2436
2434
  }), this.Ie.prepareRender(o), o.polygonOffsetIndex = s++, this.Ie.render(o)), 1 === this.layer.options.meshRenderOrder && this.Ue(o, s++, n),
2437
- this.De && (r || this.Pe.supportRenderMode(n)) && (i.options.collision && i.clearCollisionIndex(),
2438
- this.Pe.startFrame(o), this.Pe.addMesh(this.De, null, {
2435
+ this.Ne && (r || this.Pe.supportRenderMode(n)) && (i.options.collision && i.clearCollisionIndex(),
2436
+ this.Pe.startFrame(o), this.Pe.addMesh(this.Ne, null, {
2439
2437
  bloom: this.lt.bloom
2440
2438
  }), this.Pe.prepareRender(o), i.options.collision && this.Pe.updateCollision(o),
2441
2439
  this.Pe.render(o)), (r || e && e.isFinalRender) && (this.completeRender(), this.layer.fire("canvasisdirty"));
@@ -2483,18 +2481,18 @@ class Ut extends t.renderer.CanvasRenderer {
2483
2481
  const a = this.features[s];
2484
2482
  if (Array.isArray(a)) for (let r = 0; r < a.length; r++) {
2485
2483
  const o = a[r], s = o[Ht];
2486
- (!t || t[s] || e && (!e || e[s])) && (o.visible || (this.Re = !0), this.We(o.geometry, n),
2484
+ (!t || t[s] || e && (!e || e[s])) && (o.visible || (this.Le = !0), this.We(o.geometry, n),
2487
2485
  i.push(o));
2488
2486
  } else {
2489
- a.visible || (this.Re = !0);
2487
+ a.visible || (this.Le = !0);
2490
2488
  const r = a[Ht];
2491
2489
  if (t && !t[r] && (!e || e && !e[r])) continue;
2492
2490
  this.We(a.geometry, n), i.push(a);
2493
2491
  }
2494
2492
  }
2495
2493
  return i.length || (this.meshes && this.painter && (this.painter.deleteMesh(this.meshes),
2496
- delete this.meshes), this.De && (this.Pe.deleteMesh(this.De), delete this.De), this.Ne && (this.Ie.deleteMesh(this.Ne),
2497
- delete this.Ne)), n[3] && (n[0] /= n[3], n[1] /= n[3]), {
2494
+ delete this.meshes), this.Ne && (this.Pe.deleteMesh(this.Ne), delete this.Ne), this.De && (this.Ie.deleteMesh(this.De),
2495
+ delete this.De)), n[3] && (n[0] /= n[3], n[1] /= n[3]), {
2498
2496
  features: i,
2499
2497
  center: n
2500
2498
  };
@@ -2563,7 +2561,7 @@ class Ut extends t.renderer.CanvasRenderer {
2563
2561
  const e = !this.$e("win-intel-gpu-crash");
2564
2562
  this.u = new v(e => {
2565
2563
  t.getMap().getRenderer().callInNextFrame(e);
2566
- }, t.options.glyphSdfLimitPerFrame, e), this.requestor = this.Xe.bind(this), this.Ye = this.Je.bind(this);
2564
+ }, t.options.glyphSdfLimitPerFrame, e), this.requestor = this.Xe.bind(this), this.Je = this.Ye.bind(this);
2567
2565
  }
2568
2566
  Xe(t, e, i) {
2569
2567
  const n = [];
@@ -2574,7 +2572,7 @@ class Ut extends t.renderer.CanvasRenderer {
2574
2572
  }, n);
2575
2573
  });
2576
2574
  }
2577
- Je(t, e, i) {
2575
+ Ye(t, e, i) {
2578
2576
  this.u.getGlyphs(e, (e, n) => {
2579
2577
  if (e) throw e;
2580
2578
  const r = n.buffers || [];
@@ -2589,22 +2587,22 @@ class Ut extends t.renderer.CanvasRenderer {
2589
2587
  }
2590
2588
  Oe(t) {
2591
2589
  const e = Object.keys(this.we), i = Object.keys(this.Ae);
2592
- if (!e.length && !i.length) return void (this.De && (this.Pe.deleteMesh(this.De),
2593
- delete this.De));
2590
+ if (!e.length && !i.length) return void (this.Ne && (this.Pe.deleteMesh(this.Ne),
2591
+ delete this.Ne));
2594
2592
  const {features: o, center: s} = this.Ge(this.we, this.Ae), a = [], l = [];
2595
2593
  for (let t = 0; t < o.length; t++) {
2596
2594
  const e = o[t][Ht];
2597
2595
  this.we[e] && a.push(o[t]), this.Ae[e] && l.push(o[t]);
2598
2596
  }
2599
- if (!a.length && !l.length) return void (this.De && (this.Pe.deleteMesh(this.De),
2600
- delete this.De));
2601
- const h = this.Re;
2597
+ if (!a.length && !l.length) return void (this.Ne && (this.Pe.deleteMesh(this.Ne),
2598
+ delete this.Ne));
2599
+ const h = this.Le;
2602
2600
  this.Ze = s;
2603
2601
  const c = this.Ke(a, l, t, s);
2604
2602
  this.ze = {};
2605
2603
  const u = [], d = [];
2606
2604
  this.Qe = !0, Promise.all(c).then(t => {
2607
- if (this.De && (this.Pe.deleteMesh(this.De), delete this.De), !t || !t.length) return void this.setToRedraw();
2605
+ if (this.Ne && (this.Pe.deleteMesh(this.Ne), delete this.Ne), !t || !t.length) return void this.setToRedraw();
2608
2606
  const e = this.Pe.createGeometries(t.map(t => t && t.data), this.be);
2609
2607
  for (let i = 0; i < e.length; i++) this.Be(e[i].geometry, t[i] && t[i].data);
2610
2608
  const i = t[0] && t[0].data.iconAtlas, o = t[0] && t[0].data.glyphAtlas || t[1] && t[1].data.glyphAtlas;
@@ -2613,12 +2611,12 @@ class Ut extends t.renderer.CanvasRenderer {
2613
2611
  r.translate(a, a, n.set(d, s[0], s[1], 0)), r.scale(a, a, n.set(u, 1, 1, this.ot));
2614
2612
  const l = this.Pe.createMeshes(e, a);
2615
2613
  for (let t = 0; t < l.length; t++) l[t].geometry.properties.originElements = l[t].geometry.properties.elements.slice(),
2616
- l[t].setUniform("level", 0), l[t].material.set("flipY", 1), l[t].properties.meshKey = Rt++;
2617
- this.De = l, h && (this.Re = !0), this.Qe = !1, this.setToRedraw();
2614
+ l[t].setUniform("level", 0), l[t].material.set("flipY", 1), l[t].properties.meshKey = Lt++;
2615
+ this.Ne = l, h && (this.Le = !0), this.Qe = !1, this.setToRedraw();
2618
2616
  });
2619
2617
  }
2620
- Le() {
2621
- if (this.De && (this.ti(this.De[0], this.we), this.ti(this.De[1], this.Ae)), this.Ne) for (let t = 0; t < this.Ne.length; t++) this.ti(this.Ne[t], this._e);
2618
+ Re() {
2619
+ if (this.Ne && (this.ti(this.Ne[0], this.we), this.ti(this.Ne[1], this.Ae)), this.De) for (let t = 0; t < this.De.length; t++) this.ti(this.De[t], this._e);
2622
2620
  if (this.meshes) for (let t = 0; t < this.meshes.length; t++) this.ti(this.meshes[t], this.be);
2623
2621
  }
2624
2622
  ti(t, e) {
@@ -2635,7 +2633,7 @@ class Ut extends t.renderer.CanvasRenderer {
2635
2633
  const r = {
2636
2634
  zoom: this.getMap().getZoom(),
2637
2635
  EXTENT: 1 / 0,
2638
- requestor: this.Ye,
2636
+ requestor: this.Je,
2639
2637
  atlas: i,
2640
2638
  center: n,
2641
2639
  positionType: Float32Array,
@@ -2650,7 +2648,7 @@ class Ut extends t.renderer.CanvasRenderer {
2650
2648
  const e = t._getInternalSymbol(), i = {
2651
2649
  zoom: this.getMap().getZoom()
2652
2650
  }, n = this.ii(t);
2653
- if (!this.De) return !1;
2651
+ if (!this.Ne) return !1;
2654
2652
  let r = this.features[n];
2655
2653
  Array.isArray(r) || (r = [ r ]);
2656
2654
  const o = [], s = [], a = this.getMap().getZoom();
@@ -2666,7 +2664,7 @@ class Ut extends t.renderer.CanvasRenderer {
2666
2664
  const e = r[t][Ht];
2667
2665
  this.we[e] && o.push(r[t]), this.Ae[e] && s.push(r[t]);
2668
2666
  }
2669
- const c = r[0].id, u = this.Ke(o, s, this.ze, this.Ze), d = this.De;
2667
+ const c = r[0].id, u = this.Ke(o, s, this.ze, this.Ze), d = this.Ne;
2670
2668
  return Promise.all(u).then(t => {
2671
2669
  for (let e = 0; e < t.length; e++) {
2672
2670
  if (!t[e]) continue;
@@ -2683,7 +2681,7 @@ class Ut extends t.renderer.CanvasRenderer {
2683
2681
  }), !0;
2684
2682
  }
2685
2683
  ri(t) {
2686
- return this.oi(t, this.Ne, this.je, this.si, this.Ie, A, Et, this.ai);
2684
+ return this.oi(t, this.De, this.je, this.si, this.Ie, A, Et, this.ai);
2687
2685
  }
2688
2686
  oi(t, e, i, n, r, o, s, a) {
2689
2687
  if (!e) return !1;
@@ -2739,15 +2737,15 @@ class Ut extends t.renderer.CanvasRenderer {
2739
2737
  }), !0;
2740
2738
  }
2741
2739
  Ce(t) {
2742
- if (!Object.keys(this._e).length) return void (this.Ne && (this.Ie.deleteMesh(this.Ne),
2743
- delete this.Ne));
2740
+ if (!Object.keys(this._e).length) return void (this.De && (this.Ie.deleteMesh(this.De),
2741
+ delete this.De));
2744
2742
  const {features: e, center: i} = this.Ge(this._e);
2745
2743
  if (!e.length) return;
2746
- const n = this.Re;
2744
+ const n = this.Le;
2747
2745
  this.si = i;
2748
2746
  const r = this.ai(e), o = H({}, Et), s = r.map((e, n) => this.createMesh(this.Ie, A, o, e, t && t[n], i));
2749
2747
  this.li = !0, Promise.all(s).then(t => {
2750
- this.Ne && this.Ie.deleteMesh(this.Ne);
2748
+ this.De && this.Ie.deleteMesh(this.De);
2751
2749
  const e = [], i = [];
2752
2750
  for (let n = 0; n < t.length; n++) {
2753
2751
  const r = t[n] && t[n].meshes;
@@ -2759,14 +2757,14 @@ class Ut extends t.renderer.CanvasRenderer {
2759
2757
  i[n] = t[n].atlas;
2760
2758
  }
2761
2759
  }
2762
- this.Ne = e, this.je = i, n && (this.Re = n), this.li = !1, this.setToRedraw();
2760
+ this.De = e, this.je = i, n && (this.Le = n), this.li = !1, this.setToRedraw();
2763
2761
  });
2764
2762
  }
2765
2763
  ai(t) {
2766
- const e = (Lt + "lineDasharray").trim(), i = (Lt + "linePatternFile").trim(), n = [], r = [], o = [];
2764
+ const e = (Rt + "lineDasharray").trim(), i = (Rt + "linePatternFile").trim(), n = [], r = [], o = [];
2767
2765
  for (let s = 0; s < t.length; s++) {
2768
2766
  const a = t[s], l = a.properties && a.properties[e];
2769
- l && Jt(l) ? o.push(a) : a.properties && a.properties[i] ? r.push(a) : n.push(a);
2767
+ l && Yt(l) ? o.push(a) : a.properties && a.properties[i] ? r.push(a) : n.push(a);
2770
2768
  }
2771
2769
  return [ r, o, n ];
2772
2770
  }
@@ -2792,7 +2790,7 @@ class Ut extends t.renderer.CanvasRenderer {
2792
2790
  ii(t) {
2793
2791
  void 0 === t[zt] && (t[zt] = this.j++);
2794
2792
  const e = t[zt];
2795
- this.features[e] && this.ui(e), this.features[e] = Dt(t, this.Se, this.features[e]);
2793
+ this.features[e] && this.ui(e), this.features[e] = Nt(t, this.Se, this.features[e]);
2796
2794
  const i = this.features[e];
2797
2795
  return this.di(i, e), this.ve[e] = t, e;
2798
2796
  }
@@ -2807,13 +2805,13 @@ class Ut extends t.renderer.CanvasRenderer {
2807
2805
  const r = {
2808
2806
  feature: t[i]
2809
2807
  };
2810
- Wt(t[i]) && (this.we[n] = r), Bt(t[i]) && (this.Ae[n] = r), Yt(t[i]) && (this._e[n] = r);
2808
+ Wt(t[i]) && (this.we[n] = r), Bt(t[i]) && (this.Ae[n] = r), Jt(t[i]) && (this._e[n] = r);
2811
2809
  } else {
2812
2810
  t[zt] = e;
2813
2811
  const i = {
2814
2812
  feature: t
2815
2813
  }, n = t[Ht];
2816
- Wt(t) && (this.we[n] = i), Bt(t) && (this.Ae[n] = i), Yt(t) && (this._e[n] = i),
2814
+ Wt(t) && (this.we[n] = i), Bt(t) && (this.Ae[n] = i), Jt(t) && (this._e[n] = i),
2817
2815
  this.be[n] = i;
2818
2816
  }
2819
2817
  }
@@ -2890,7 +2888,7 @@ class Ut extends t.renderer.CanvasRenderer {
2890
2888
  } else this.mi(e); else this.mi(e);
2891
2889
  }
2892
2890
  onGeometryShapeChange(t) {
2893
- const e = t.target._getParent() || t.target, i = Dt(e, {
2891
+ const e = t.target._getParent() || t.target, i = Nt(e, {
2894
2892
  id: 0
2895
2893
  }).geometry, n = e[zt], r = this.features[n];
2896
2894
  if (function t(e, i) {
@@ -2899,7 +2897,7 @@ class Ut extends t.renderer.CanvasRenderer {
2899
2897
  for (let n = 0; n < e.length; n++) if (!t(e[0], i[0])) return !1;
2900
2898
  } else if (Array.isArray(e[0]) || Array.isArray(i[0])) return !1;
2901
2899
  return !0;
2902
- }(i, (Array.isArray(r) ? r[0] : r).geometry)) return this.Ne && (this.Fe = !0),
2900
+ }(i, (Array.isArray(r) ? r[0] : r).geometry)) return this.De && (this.Fe = !0),
2903
2901
  void this.onGeometryPositionChange(t);
2904
2902
  this.ci([ e ]), this.hi(), qt(this);
2905
2903
  }
@@ -2931,11 +2929,11 @@ class Ut extends t.renderer.CanvasRenderer {
2931
2929
  }
2932
2930
  }
2933
2931
  gi() {
2934
- this.Re = !0;
2932
+ this.Le = !0;
2935
2933
  }
2936
2934
  onGeometryPropertiesChange(t) {
2937
2935
  const e = t.target, i = e[zt];
2938
- this.features[i] = Dt(e, this.Se), this.di(this.features[i], i), this.ni(), qt(this);
2936
+ this.features[i] = Nt(e, this.Se), this.di(this.features[i], i), this.ni(), qt(this);
2939
2937
  }
2940
2938
  createContext() {
2941
2939
  const t = this.canvas.gl && this.canvas.gl.wrap;
@@ -3050,21 +3048,21 @@ function Gt(t) {
3050
3048
  }
3051
3049
 
3052
3050
  function Wt({properties: t}) {
3053
- const e = (Lt + "markerFile").trim(), i = (Lt + "markerType").trim();
3051
+ const e = (Rt + "markerFile").trim(), i = (Rt + "markerType").trim();
3054
3052
  return t[e] || t[i];
3055
3053
  }
3056
3054
 
3057
3055
  function Bt({properties: t}) {
3058
- return t[(Lt + "textName").trim()];
3056
+ return t[(Rt + "textName").trim()];
3059
3057
  }
3060
3058
 
3061
- const $t = (Lt + "lineWidth").trim(), Xt = "_line_gradient_property".trim();
3059
+ const $t = (Rt + "lineWidth").trim(), Xt = "_line_gradient_property".trim();
3062
3060
 
3063
- function Yt(t) {
3061
+ function Jt(t) {
3064
3062
  return 2 === t.type && !t.properties[Xt] && void 0 !== t.properties[$t] || 3 === t.type && void 0 !== t.properties[$t];
3065
3063
  }
3066
3064
 
3067
- function Jt(t) {
3065
+ function Yt(t) {
3068
3066
  if (!Array.isArray(t)) return 0;
3069
3067
  let e = 0;
3070
3068
  for (let i = 0; i < t.length; i++) e += t[i];
@@ -3072,9 +3070,9 @@ function Jt(t) {
3072
3070
  }
3073
3071
 
3074
3072
  function Zt(t, e) {
3075
- if (Object.keys(t).sort().join() !== Object.keys(e.properties || {}).filter(t => 0 === t.indexOf(Lt)).map(t => t.substring(Lt.length)).sort().join()) return !1;
3073
+ if (Object.keys(t).sort().join() !== Object.keys(e.properties || {}).filter(t => 0 === t.indexOf(Rt)).map(t => t.substring(Rt.length)).sort().join()) return !1;
3076
3074
  for (const i in t) if (B(t, i)) {
3077
- const n = (Lt + i).trim();
3075
+ const n = (Rt + i).trim();
3078
3076
  if (p(t[i]) !== p(e.properties[n])) return !1;
3079
3077
  }
3080
3078
  return !0;
@@ -3152,7 +3150,7 @@ te.registerRenderer("gl", class extends Ut {
3152
3150
  buildMesh() {
3153
3151
  let {features: t, center: e} = this.Ge();
3154
3152
  if (t = t.filter(t => !!t.properties[ee]), !t.length) return;
3155
- const i = this.Re;
3153
+ const i = this.Le;
3156
3154
  this.xi = e;
3157
3155
  const n = H({}, this.painterSymbol), r = this.createMesh(this.painter, A, n, t, null, e);
3158
3156
  this.pi = !0, r.then(t => {
@@ -3162,7 +3160,7 @@ te.registerRenderer("gl", class extends Ut {
3162
3160
  e.push(...n);
3163
3161
  for (let t = 0; t < n.length; t++) n[t].feaGroupIndex = 0, n[t].geometry.properties.originElements = n[t].geometry.properties.elements.slice();
3164
3162
  }
3165
- this.meshes = e, i && (this.Re = i), this.pi = !1, this.setToRedraw();
3163
+ this.meshes = e, i && (this.Le = i), this.pi = !1, this.setToRedraw();
3166
3164
  });
3167
3165
  }
3168
3166
  }), te.registerRenderer("canvas", null);
@@ -3210,7 +3208,7 @@ ie.registerRenderer("gl", class extends Ut {
3210
3208
  buildMesh(t) {
3211
3209
  const {features: e, center: i} = this.Ge();
3212
3210
  if (!e.length) return;
3213
- const n = this.Re;
3211
+ const n = this.Le;
3214
3212
  this.xi = i;
3215
3213
  const r = this.wi(e), o = H({}, ne), s = r.map((e, n) => this.createMesh(this.painter, S, o, e, t && t[n], i));
3216
3214
  this.pi = !0, Promise.all(s).then(t => {
@@ -3225,7 +3223,7 @@ ie.registerRenderer("gl", class extends Ut {
3225
3223
  i[n] = t[n].atlas;
3226
3224
  }
3227
3225
  }
3228
- this.meshes = e, this.atlas = i, n && (this.Re = n), this.pi = !1, this.setToRedraw();
3226
+ this.meshes = e, this.atlas = i, n && (this.Le = n), this.pi = !1, this.setToRedraw();
3229
3227
  });
3230
3228
  }
3231
3229
  wi(t) {
@@ -3315,7 +3313,7 @@ function ae(t, e) {
3315
3313
  for (let e = 0; e < s.length; e++) s[e] && s[e].geometry && (n = !0, s[e].geometry.properties.features = o,
3316
3314
  this.Be(s[e].geometry, t));
3317
3315
  }
3318
- let a = this.N(o);
3316
+ let a = this.D(o);
3319
3317
  if (!a) {
3320
3318
  const {meshes: e, retire: i} = this.Pi(s, t);
3321
3319
  n || (n = i), a = e;
@@ -3352,7 +3350,7 @@ function ae(t, e) {
3352
3350
  if (!s) return re;
3353
3351
  let a = !1;
3354
3352
  const l = this.Ti(t);
3355
- let h = this.N(l);
3353
+ let h = this.D(l);
3356
3354
  if (!h) {
3357
3355
  const {meshes: e, retire: i} = this.Pi(s, t);
3358
3356
  a || (a = i), h = e;
@@ -3458,7 +3456,7 @@ function ae(t, e) {
3458
3456
  const e = t.tileInfo;
3459
3457
  return e.meshKey || (e.meshKey = se++), e.meshKey;
3460
3458
  },
3461
- N: function(t) {
3459
+ D: function(t) {
3462
3460
  return this.Ai[t];
3463
3461
  },
3464
3462
  Ci(t, e) {
@@ -3622,17 +3620,17 @@ function Me(t, e, i) {
3622
3620
  const {attrName: o, symbolName: s, evaluate: a, related: l} = i, h = (ke + o + "Index").trim();
3623
3621
  let c = t.data[o];
3624
3622
  if (!c) {
3625
- if (De(e[s])) {
3623
+ if (Ne(e[s])) {
3626
3624
  c = t.data[o] = new i.type(i.width * r.length), Pe(t, e, i);
3627
3625
  return ze(o, t, t.properties[h], a), c;
3628
3626
  }
3629
3627
  return null;
3630
3628
  }
3631
- return De(e[s]) || function(t, e) {
3629
+ return Ne(e[s]) || function(t, e) {
3632
3630
  if (!Array.isArray(t)) return !1;
3633
- for (let i = 0; i < t.length; i++) if (De(e[t[i]])) return !0;
3631
+ for (let i = 0; i < t.length; i++) if (Ne(e[t[i]])) return !0;
3634
3632
  return !1;
3635
- }(l, e) ? (De(e[s]) && Pe(t, e, i), c) : (c && c.buffer && c.buffer.destroy && c.buffer.destroy(),
3633
+ }(l, e) ? (Ne(e[s]) && Pe(t, e, i), c) : (c && c.buffer && c.buffer.destroy && c.buffer.destroy(),
3636
3634
  delete t.data[o], Ie(t, o), null);
3637
3635
  }
3638
3636
 
@@ -3766,18 +3764,18 @@ function je(t, e, i, n, r, o, s) {
3766
3764
  } else t[n] !== l && (be(t, l, n, r), t.dirty = !0);
3767
3765
  }
3768
3766
 
3769
- function De(t) {
3767
+ function Ne(t) {
3770
3768
  return T.isFnTypeSymbol(t);
3771
3769
  }
3772
3770
 
3773
- const {loginIBLResOnCanvas: Ne, logoutIBLResOnCanvas: Re, getIBLResOnCanvas: Le} = i.pbr.PBRUtils, He = [], Ve = [], Ue = t => 0 === t.getUniform("level"), qe = t => t.getUniform("level") > 0;
3771
+ const {loginIBLResOnCanvas: De, logoutIBLResOnCanvas: Le, getIBLResOnCanvas: Re} = i.pbr.PBRUtils, He = [], Ve = [], Ue = t => 0 === t.getUniform("level"), qe = t => t.getUniform("level") > 0;
3774
3772
 
3775
3773
  class Ge {
3776
3774
  constructor(t, e, n, r, o, s) {
3777
3775
  this.regl = t, this.layer = e, this.canvas = e.getRenderer().canvas, this.sceneConfig = r || {},
3778
3776
  this.dataConfig = s || {}, this.pluginIndex = o, this.scene = new i.Scene, this.pickingFBO = e.getRenderer().pickingFBO,
3779
- this.Di = new le, this.level0Filter = Ue, this.levelNFilter = qe, this.loginTextureCache(),
3780
- this.symbolDef = Array.isArray(n) ? n.map(t => fe(t)) : [ fe(n) ], this.Ni(), this.pickingViewport = {
3777
+ this.Ni = new le, this.level0Filter = Ue, this.levelNFilter = qe, this.loginTextureCache(),
3778
+ this.symbolDef = Array.isArray(n) ? n.map(t => fe(t)) : [ fe(n) ], this.Di(), this.pickingViewport = {
3781
3779
  x: 0,
3782
3780
  y: 0,
3783
3781
  width: () => this.canvas ? this.canvas.width : 1,
@@ -3792,7 +3790,7 @@ class Ge {
3792
3790
  return i.getTileLevelValue && i.getTileLevelValue(t, e) || 0;
3793
3791
  }
3794
3792
  isVisible() {
3795
- const t = this.Ri;
3793
+ const t = this.Li;
3796
3794
  if (t.length) for (let e = 0; e < t.length; e++) if (t[e] && !t[e].isFeatureConstant) return !0;
3797
3795
  const e = this.getSymbols();
3798
3796
  for (let t = 0; t < e.length; t++) {
@@ -3804,7 +3802,7 @@ class Ge {
3804
3802
  isMeshVisible(t) {
3805
3803
  const e = t && t.properties && t.properties.symbolIndex;
3806
3804
  if (!e) return !1;
3807
- const i = this.Ri, n = e.index;
3805
+ const i = this.Li, n = e.index;
3808
3806
  let r;
3809
3807
  if (i[n]) {
3810
3808
  if (!i[n].isFeatureConstant) return !0;
@@ -3813,7 +3811,7 @@ class Ge {
3813
3811
  return !1 !== r && 0 !== r;
3814
3812
  }
3815
3813
  needToRedraw() {
3816
- return this.Li;
3814
+ return this.Ri;
3817
3815
  }
3818
3816
  needToRetireFrames() {
3819
3817
  return this.B;
@@ -3913,11 +3911,11 @@ class Ge {
3913
3911
  this.Vi = t;
3914
3912
  const i = this.getUniformValues(e, t);
3915
3913
  return this.callShader(i, t), {
3916
- redraw: this.Li
3914
+ redraw: this.Ri
3917
3915
  };
3918
3916
  }
3919
3917
  setToRedraw(t) {
3920
- t && (this.B = t), this.Li = !0;
3918
+ t && (this.B = t), this.Ri = !0;
3921
3919
  }
3922
3920
  callShader(t, e) {
3923
3921
  this.callCurrentTileShader(t, e), this.callBackgroundTileShader(t, e);
@@ -3997,7 +3995,7 @@ class Ge {
3997
3995
  }
3998
3996
  }
3999
3997
  startFrame(t) {
4000
- this.Ui || (this.init(t), this.Ui = !0), this.it !== t.timestamp && (this.Li = !1,
3998
+ this.Ui || (this.init(t), this.Ui = !0), this.it !== t.timestamp && (this.Ri = !1,
4001
3999
  this.B = !1), this.scene.clear();
4002
4000
  }
4003
4001
  resize() {}
@@ -4042,7 +4040,7 @@ class Ge {
4042
4040
  enumerable: !0
4043
4041
  }) : r[t] = s[t];
4044
4042
  }
4045
- return p(i.visible) && (this.Ri[t] = m(i.visible)), n;
4043
+ return p(i.visible) && (this.Li[t] = m(i.visible)), n;
4046
4044
  }
4047
4045
  getSymbolDef(t) {
4048
4046
  return this.symbolDef[t.index];
@@ -4054,11 +4052,11 @@ class Ge {
4054
4052
  const e = t.index;
4055
4053
  return this.$i[e];
4056
4054
  }
4057
- Ni() {
4055
+ Di() {
4058
4056
  const t = this.getMap(), e = () => [ t.getZoom() ];
4059
- this.$i = [], this.Ri = [];
4057
+ this.$i = [], this.Li = [];
4060
4058
  for (let t = 0; t < this.symbolDef.length; t++) this.$i[t] = f(he({}, this.symbolDef[t]), e),
4061
- this.symbolDef[t] && p(this.symbolDef[t].visible) && (this.Ri[t] = m(this.symbolDef[t].visible));
4059
+ this.symbolDef[t] && p(this.symbolDef[t].visible) && (this.Li[t] = m(this.symbolDef[t].visible));
4062
4060
  }
4063
4061
  getFnTypeConfig(t) {
4064
4062
  this.Wi || (this.Wi = []);
@@ -4079,7 +4077,7 @@ class Ge {
4079
4077
  }), e[t].count++;
4080
4078
  }
4081
4079
  logoutTextureCache() {
4082
- const t = "__gl_textures".trim(), e = this.getMap(), i = this.Yi;
4080
+ const t = "__gl_textures".trim(), e = this.getMap(), i = this.Ji;
4083
4081
  if (i) for (const n in i) Ae(i, n) && e[t][n] && (e[t][n].count--, e[t][n].count <= 0 && delete e[t][n]);
4084
4082
  e[t].count--, e[t].count <= 0 && (e[t] = {});
4085
4083
  }
@@ -4093,13 +4091,13 @@ class Ge {
4093
4091
  r ? r.data = e : r = n[i][t] = {
4094
4092
  data: e,
4095
4093
  count: 0
4096
- }, this.Yi || (this.Yi = {}), r.data.then || this.Yi[t] || (r.count++, this.Yi[t] = 1);
4094
+ }, this.Ji || (this.Ji = {}), r.data.then || this.Ji[t] || (r.count++, this.Ji[t] = 1);
4097
4095
  }
4098
4096
  disposeCachedTexture(t) {
4099
4097
  let e;
4100
- if (e = "string" == typeof t ? t : t.url, !this.Yi || !this.Yi[e]) return;
4098
+ if (e = "string" == typeof t ? t : t.url, !this.Ji || !this.Ji[e]) return;
4101
4099
  const i = "__gl_textures".trim();
4102
- delete this.Yi[e];
4100
+ delete this.Ji[e];
4103
4101
  const n = this.getMap();
4104
4102
  n[i][e] && (n[i][e].count--, n[i][e].count <= 0 && delete n[i][e]);
4105
4103
  }
@@ -4112,7 +4110,7 @@ class Ge {
4112
4110
  supportRenderMode(t) {
4113
4111
  return "taa" === t || "fxaa" === t;
4114
4112
  }
4115
- Ji(t) {
4113
+ Yi(t) {
4116
4114
  const e = this.scene.getMeshes();
4117
4115
  if (!e.length) return;
4118
4116
  const i = e.map(t => ({
@@ -4120,15 +4118,15 @@ class Ge {
4120
4118
  level: t.getUniform("level"),
4121
4119
  mesh: t
4122
4120
  })).sort(this.Zi), n = this.getMap().projViewMatrix;
4123
- this.Di.start(t);
4121
+ this.Ni.start(t);
4124
4122
  const o = {};
4125
4123
  for (let e = 0; e < i.length; e++) {
4126
4124
  const s = i[e].mesh;
4127
4125
  let a = o[s.properties.tile.id];
4128
- void 0 === a && (r.multiply(He, n, i[e].transform), a = this.Di.write(t, He), o[s.properties.tile.id] = a),
4126
+ void 0 === a && (r.multiply(He, n, i[e].transform), a = this.Ni.write(t, He), o[s.properties.tile.id] = a),
4129
4127
  s.setUniform("ref", a);
4130
4128
  }
4131
- this.Di.end(t), this.regl.Ki();
4129
+ this.Ni.end(t), this.regl.Ki();
4132
4130
  }
4133
4131
  Zi(t, e) {
4134
4132
  return e.level - t.level;
@@ -4224,15 +4222,15 @@ class Ge {
4224
4222
  }
4225
4223
  getIBLRes() {
4226
4224
  const t = this.layer.getRenderer().canvas;
4227
- return Le(t);
4225
+ return Re(t);
4228
4226
  }
4229
4227
  createIBLTextures() {
4230
4228
  const t = this.layer.getRenderer().canvas;
4231
- Ne(t, this.regl, this.getMap()), this.setToRedraw(!0), this.layer.fire("iblupdated");
4229
+ De(t, this.regl, this.getMap()), this.setToRedraw(!0), this.layer.fire("iblupdated");
4232
4230
  }
4233
4231
  disposeIBLTextures() {
4234
4232
  const t = this.layer.getRenderer().canvas;
4235
- Re(t, this.getMap());
4233
+ Le(t, this.getMap());
4236
4234
  }
4237
4235
  evaluateInFnTypeConfig(t, e, i, n, r) {
4238
4236
  let o = this.nn;
@@ -4323,7 +4321,7 @@ class $e extends Ge {
4323
4321
 
4324
4322
  var Xe = "#ifdef HAS_ALTITUDE\nattribute vec2 aPosition;\nattribute float aAltitude;\n#else\nattribute vec3 aPosition;\n#endif\nuniform mat4 projViewModelMatrix;\n#include <fbo_picking_vert>\n#include <vt_position_vert>\nvoid main() {\n vec3 c = unpackVTPosition();\n gl_Position = projViewModelMatrix * vec4(c, 1.);\n fbo_picking_setData(gl_Position.w, true);\n}";
4325
4323
 
4326
- function Ye(t, e, i) {
4324
+ function Je(t, e, i) {
4327
4325
  const n = e, r = {
4328
4326
  width: n.width,
4329
4327
  height: n.height,
@@ -4340,7 +4338,7 @@ function Ye(t, e, i) {
4340
4338
  return t.texture(r);
4341
4339
  }
4342
4340
 
4343
- const Je = {
4341
+ const Ye = {
4344
4342
  polygonFill: [ 1, 1, 1, 1 ],
4345
4343
  polygonOpacity: 1,
4346
4344
  uvScale: [ 1, 1 ],
@@ -4366,9 +4364,9 @@ class Ze extends $e {
4366
4364
  tileExtent: o.properties.tileExtent,
4367
4365
  tileRatio: o.properties.tileRatio
4368
4366
  }, c = this.getSymbol(s);
4369
- if (pe(h, "polygonFill", c, "polygonFill", Je.polygonFill, ge(this.colorCache)),
4370
- pe(h, "polygonOpacity", c, "polygonOpacity", Je.polygonOpacity), pe(h, "uvScale", c, "uvScale", Je.uvScale),
4371
- pe(h, "uvOffset", c, "uvOffset", Je.uvOffset), void 0 === a) {
4367
+ if (pe(h, "polygonFill", c, "polygonFill", Ye.polygonFill, ge(this.colorCache)),
4368
+ pe(h, "polygonOpacity", c, "polygonOpacity", Ye.polygonOpacity), pe(h, "uvScale", c, "uvScale", Ye.uvScale),
4369
+ pe(h, "uvOffset", c, "uvOffset", Ye.uvOffset), void 0 === a) {
4372
4370
  const t = this.getSymbolDef(s), e = this.getFnTypeConfig(s);
4373
4371
  Te(o, t, e), o.generateBuffers(this.regl);
4374
4372
  }
@@ -4380,10 +4378,10 @@ class Ze extends $e {
4380
4378
  get: function() {
4381
4379
  return o.properties.tileResolution / t.getResolution();
4382
4380
  }
4383
- }), h.polygonPatternFile = Ye(this.regl, u, !1), h.atlasSize = [ u.width, u.height ],
4381
+ }), h.polygonPatternFile = Je(this.regl, u, !1), h.atlasSize = [ u.width, u.height ],
4384
4382
  this.drawDebugAtlas(u);
4385
4383
  }
4386
- const d = new i.Material(h, Je), f = new i.Mesh(o, d, {
4384
+ const d = new i.Material(h, Ye), f = new i.Mesh(o, d, {
4387
4385
  disableVAO: !0,
4388
4386
  castShadow: !1,
4389
4387
  picking: !0
@@ -4566,7 +4564,7 @@ class Qe extends $e {
4566
4564
  return e || [ 0, 0, 0, 0 ];
4567
4565
  }), pe(l, "lineDashColor", a, "lineDashColor", [ 0, 0, 0, 0 ], ge(this.colorCache));
4568
4566
  const h = n.properties.iconAtlas, c = n.data.aPosition instanceof Int16Array;
4569
- h && (l.linePatternFile = Ye(this.regl, h, !1), l.atlasSize = h ? [ h.width, h.height ] : [ 0, 0 ],
4567
+ h && (l.linePatternFile = Je(this.regl, h, !1), l.atlasSize = h ? [ h.width, h.height ] : [ 0, 0 ],
4570
4568
  l.flipY = c ? -1 : 1, this.drawDebugAtlas(h)), void 0 === o && n.generateBuffers(this.regl);
4571
4569
  const u = new i.Material(l), d = new i.Mesh(n, u, {
4572
4570
  castShadow: !1,
@@ -4603,9 +4601,9 @@ class Qe extends $e {
4603
4601
  }
4604
4602
  setMeshDefines(t, e, i) {
4605
4603
  e.data.aOpacity && (t.HAS_OPACITY = 1), e.data.aLineWidth && (t.HAS_LINE_WIDTH = 1),
4606
- e.data.aLineStrokeWidth && (t.HAS_STROKE_WIDTH = 1), De(i.lineDx) && (t.HAS_LINE_DX = 1),
4607
- De(i.lineDy) && (t.HAS_LINE_DY = 1), De(i.linePatternAnimSpeed) && (t.HAS_PATTERN_ANIM = 1),
4608
- De(i.linePatternGap) && (t.HAS_PATTERN_GAP = 1);
4604
+ e.data.aLineStrokeWidth && (t.HAS_STROKE_WIDTH = 1), Ne(i.lineDx) && (t.HAS_LINE_DX = 1),
4605
+ Ne(i.lineDy) && (t.HAS_LINE_DY = 1), Ne(i.linePatternAnimSpeed) && (t.HAS_PATTERN_ANIM = 1),
4606
+ Ne(i.linePatternGap) && (t.HAS_PATTERN_GAP = 1);
4609
4607
  }
4610
4608
  paint(t) {
4611
4609
  t.states && t.states.includesChanged.shadow && (this.shader.dispose(), this.createShader(t)),
@@ -5031,7 +5029,7 @@ class ui extends $e {
5031
5029
  if (f && o.options.debugCollision && this.addCollisionDebugBox(f.boxes, f.collides ? 0 : 1),
5032
5030
  y || v) {
5033
5031
  const {mesh: t, start: e} = i[0], n = this.getSymbol(t.properties.symbolIndex);
5034
- !this.jn(n, t, e) && f && f.boxes && this.Dn(f.boxes, t);
5032
+ !this.jn(n, t, e) && f && f.boxes && this.Nn(f.boxes, t);
5035
5033
  }
5036
5034
  if (y) {
5037
5035
  const t = li[0] = 255 * g;
@@ -5047,9 +5045,9 @@ class ui extends $e {
5047
5045
  }
5048
5046
  setCollisionOpacity(t, e, i, n, r) {
5049
5047
  const o = e[n], s = e[r - 1];
5050
- this.Nn(t, i, o, s);
5048
+ this.Dn(t, i, o, s);
5051
5049
  }
5052
- Nn(t, e, i, n) {
5050
+ Dn(t, e, i, n) {
5053
5051
  const {aOpacity: r} = t.geometry.properties;
5054
5052
  if (!r) return;
5055
5053
  const o = i;
@@ -5066,7 +5064,7 @@ class ui extends $e {
5066
5064
  return i - Math.abs(this.On(t)[e]) < n;
5067
5065
  }
5068
5066
  In(t, e, i, n, r, o, s) {
5069
- const a = this.getSymbol(t.properties.symbolIndex), l = this.jn(a, t, e[n]), h = this.Rn(a, t, e[n]);
5067
+ const a = this.getSymbol(t.properties.symbolIndex), l = this.jn(a, t, e[n]), h = this.Ln(a, t, e[n]);
5070
5068
  if (!1 === this.sceneConfig.collision || l && h) return ci;
5071
5069
  const c = this.isBoxCollides(t, e, i, n, r, o, s);
5072
5070
  return h && (c.collides = 0, c.isAllowOverlap = 1), c;
@@ -5078,14 +5076,14 @@ class ui extends $e {
5078
5076
  const r = n[i], o = r % 8;
5079
5077
  return r < 2 ? 1 == +t[this.propIgnorePlacement] : o % 2;
5080
5078
  }
5081
- Rn(t, e, i) {
5079
+ Ln(t, e, i) {
5082
5080
  if (!1 === this.sceneConfig.collision) return !0;
5083
5081
  const n = e.geometry.properties.aOverlap;
5084
5082
  if (!n) return 1 == +t[this.propAllowOverlap];
5085
5083
  const r = n[i], o = r >> 2;
5086
5084
  return r < 2 ? 1 == +t[this.propAllowOverlap] : o % 2;
5087
5085
  }
5088
- Dn(t) {
5086
+ Nn(t) {
5089
5087
  if (Array.isArray(t[0])) for (let e = 0; e < t.length; e++) this.insertCollisionBox(t[e]); else this.insertCollisionBox(t);
5090
5088
  }
5091
5089
  Fn(t, e, i, n) {
@@ -5103,15 +5101,15 @@ class ui extends $e {
5103
5101
  h;
5104
5102
  }
5105
5103
  On(t) {
5106
- this.Ln || (this.Ln = {});
5104
+ this.Rn || (this.Rn = {});
5107
5105
  const {meshKey: e} = t.properties;
5108
- if (!this.Ln[e]) {
5106
+ if (!this.Rn[e]) {
5109
5107
  const {frameTimestamp: t} = this.cn;
5110
- this.Ln[e] = {
5108
+ this.Rn[e] = {
5111
5109
  timestamp: t
5112
5110
  };
5113
5111
  }
5114
- return this.Ln[e];
5112
+ return this.Rn[e];
5115
5113
  }
5116
5114
  Hn(t) {
5117
5115
  if (!this.Vn) return void (this.Vn = t);
@@ -5134,10 +5132,10 @@ class ui extends $e {
5134
5132
  if (t) {
5135
5133
  if (Array.isArray(t)) for (let e = 0; e < t.length; e++) {
5136
5134
  const i = t[e].properties.meshKey;
5137
- this.gn && delete this.gn.tags[i], this.Ln && delete this.Ln[i];
5135
+ this.gn && delete this.gn.tags[i], this.Rn && delete this.Rn[i];
5138
5136
  } else {
5139
5137
  const e = t.properties.meshKey;
5140
- this.gn && delete this.gn.tags[e], this.Ln && delete this.Ln[e];
5138
+ this.gn && delete this.gn.tags[e], this.Rn && delete this.Rn[e];
5141
5139
  }
5142
5140
  super.deleteMesh(t, e);
5143
5141
  }
@@ -5176,9 +5174,9 @@ class ui extends $e {
5176
5174
  return !1 !== this.sceneConfig.collision || this.kn;
5177
5175
  }
5178
5176
  updateCollision(t) {
5179
- super.updateCollision(t), this.wn(), this.Xn(), this.Yn && this.Yn.length && (this.Jn(),
5180
- this.Yn && (this.setToRedraw(), this.scene.addMesh(this.Yn)));
5181
- (this.getMap().isZooming() || this.Yn && this.Yn.length) && (this.Zn(), this.Kn(this.scene.getMeshes()));
5177
+ super.updateCollision(t), this.wn(), this.Xn(), this.Jn && this.Jn.length && (this.Yn(),
5178
+ this.Jn && (this.setToRedraw(), this.scene.addMesh(this.Jn)));
5179
+ (this.getMap().isZooming() || this.Jn && this.Jn.length) && (this.Zn(), this.Kn(this.scene.getMeshes()));
5182
5180
  }
5183
5181
  paint(t) {
5184
5182
  const e = super.paint(t);
@@ -5188,13 +5186,13 @@ class ui extends $e {
5188
5186
  this.callCurrentTileShader(t, e), this.shouldIgnoreBackground() || this.callBackgroundTileShader(t, e);
5189
5187
  }
5190
5188
  shouldIgnoreBackground() {
5191
- return !this.getMap().isZooming() && !this.Yn;
5189
+ return !this.getMap().isZooming() && !this.Jn;
5192
5190
  }
5193
5191
  Xn() {
5194
5192
  const t = this.getMap(), e = t.isZooming();
5195
5193
  if (!e && this.Pn) {
5196
5194
  const t = this.layer.getRenderer();
5197
- this.Yn = this.scene.getMeshes().filter(e => !t.isForeground(e) && !e.properties.isLinePlacement);
5195
+ this.Jn = this.scene.getMeshes().filter(e => !t.isForeground(e) && !e.properties.isLinePlacement);
5198
5196
  } else e && !this.Pn && (this.tr = t.getResolution());
5199
5197
  if (e) this.er && (clearTimeout(this.er), delete this.Cn, delete this.er), this.Cn = this.tr && t.getResolution() > this.tr; else if (this.Pn && !this.er) {
5200
5198
  let {fadeOutDelay: t, fadingDuration: e} = this.sceneConfig;
@@ -5253,17 +5251,17 @@ class ui extends $e {
5253
5251
  }
5254
5252
  });
5255
5253
  }
5256
- Jn() {
5254
+ Yn() {
5257
5255
  let {fadeOutDelay: t, fadingDuration: e} = this.sceneConfig;
5258
5256
  de(t) && (t = ai), de(e) && (e = oi);
5259
5257
  const i = this.layer.getRenderer(), n = i.getCurrentTileZoom(), r = i.getFrameTimestamp(), o = [];
5260
- for (let s = 0; s < this.Yn.length; s++) {
5261
- const a = this.Yn[s], l = a.properties.tile;
5258
+ for (let s = 0; s < this.Jn.length; s++) {
5259
+ const a = this.Jn[s], l = a.properties.tile;
5262
5260
  !a.En && i.isBackTile(l.id) && (a.En = r);
5263
5261
  const h = l.z - n > 0 ? 2 * (l.z - n) - 1 : 2 * (n - l.z);
5264
5262
  a.properties.level = h, a.setUniform("level", h), i.isForeground(a) || a.En && r - a.En > t + e ? delete a.En : o.push(a);
5265
5263
  }
5266
- delete this.Yn, o.length && (this.Yn = o);
5264
+ delete this.Jn, o.length && (this.Jn = o);
5267
5265
  }
5268
5266
  isEnableCollision() {
5269
5267
  return this.layer.options.collision && !1 !== this.sceneConfig.collision;
@@ -5417,7 +5415,7 @@ function Si(t, e, i, n, r) {
5417
5415
 
5418
5416
  const Ti = [], Mi = [], Pi = [], Ii = [], Oi = [], Ci = [], Ei = [], Fi = [], zi = [ 1, -1 ], ji = [ 1, 1 ];
5419
5417
 
5420
- function Di(t, e, i, r, o) {
5418
+ function Ni(t, e, i, r, o) {
5421
5419
  const s = e.material.uniforms, a = o.cameraToCenterDistance, l = e.geometry.properties, c = this.getSymbol(l.symbolIndex), u = e.geometry.desc.positionSize, d = l.aAnchor, f = n.set(Ti, d[i * u], d[i * u + 1], 2 === u ? 0 : d[i * u + 2]);
5422
5420
  let p = yi(Mi, f, r, o.width, o.height);
5423
5421
  const m = p[2];
@@ -5433,12 +5431,12 @@ function Di(t, e, i, r, o) {
5433
5431
  de(z) && (z = 15);
5434
5432
  let j = w ? w[i] : c.markerHeight;
5435
5433
  de(j) && (j = 15);
5436
- const D = h.set(ji, z / 24, j / 24);
5437
- h.mul(O, O, D), h.mul(C, C, D), h.mul(E, E, D), h.mul(F, F, D);
5438
- let N = k ? k[i] / 9362 : -(c.markerRotation || 0) * Math.PI / 180;
5439
- const R = o.getBearing() * Math.PI / 180;
5440
- if (R * P || N) {
5441
- const t = Si(Pi, N, R, P, M);
5434
+ const N = h.set(ji, z / 24, j / 24);
5435
+ h.mul(O, O, N), h.mul(C, C, N), h.mul(E, E, N), h.mul(F, F, N);
5436
+ let D = k ? k[i] / 9362 : -(c.markerRotation || 0) * Math.PI / 180;
5437
+ const L = o.getBearing() * Math.PI / 180;
5438
+ if (L * P || D) {
5439
+ const t = Si(Pi, D, L, P, M);
5442
5440
  O = h.transformMat2(O, O, t), C = h.transformMat2(C, C, t), E = h.transformMat2(E, E, t),
5443
5441
  F = h.transformMat2(F, F, t);
5444
5442
  }
@@ -5447,7 +5445,7 @@ function Di(t, e, i, r, o) {
5447
5445
  t;
5448
5446
  }
5449
5447
 
5450
- const Ni = [], Ri = [], Li = [], Hi = [], Vi = [], Ui = [], qi = [ 1, -1 ];
5448
+ const Di = [], Li = [], Ri = [], Hi = [], Vi = [], Ui = [], qi = [ 1, -1 ];
5451
5449
 
5452
5450
  function Gi(t, e, i, r, o, s, a, l, c) {
5453
5451
  const u = r.material.uniforms, d = c.cameraToCenterDistance, f = r.geometry.properties, p = this.getSymbol(f.symbolIndex), m = "line" === p.textPlacement && !we(p), y = i[2];
@@ -5459,9 +5457,9 @@ function Gi(t, e, i, r, o, s, a, l, c) {
5459
5457
  if (m) {
5460
5458
  const {aOffset: r, aShape: o} = f, s = r.length !== o.length;
5461
5459
  let d, p, m, v;
5462
- if (s ? (d = n.set(Ri, r[3 * a] / 10, r[3 * a + 1] / 10, r[3 * a + 2] / 10), p = n.set(Li, r[3 * a + 3] / 10, r[3 * a + 4] / 10, r[3 * a + 5] / 10),
5463
- m = n.set(Hi, r[3 * a + 6] / 10, r[3 * a + 7] / 10, r[3 * a + 8] / 10), v = n.set(Vi, r[3 * a + 9] / 10, r[3 * a + 10] / 10, r[3 * a + 11] / 10)) : (d = h.set(Ri, r[2 * a] / 10, r[2 * a + 1] / 10),
5464
- p = h.set(Li, r[2 * a + 2] / 10, r[2 * a + 3] / 10), m = h.set(Hi, r[2 * a + 4] / 10, r[2 * a + 5] / 10),
5460
+ if (s ? (d = n.set(Li, r[3 * a] / 10, r[3 * a + 1] / 10, r[3 * a + 2] / 10), p = n.set(Ri, r[3 * a + 3] / 10, r[3 * a + 4] / 10, r[3 * a + 5] / 10),
5461
+ m = n.set(Hi, r[3 * a + 6] / 10, r[3 * a + 7] / 10, r[3 * a + 8] / 10), v = n.set(Vi, r[3 * a + 9] / 10, r[3 * a + 10] / 10, r[3 * a + 11] / 10)) : (d = h.set(Li, r[2 * a] / 10, r[2 * a + 1] / 10),
5462
+ p = h.set(Ri, r[2 * a + 2] / 10, r[2 * a + 3] / 10), m = h.set(Hi, r[2 * a + 4] / 10, r[2 * a + 5] / 10),
5465
5463
  v = h.set(Vi, r[2 * a + 6] / 10, r[2 * a + 7] / 10)), 1 === S) {
5466
5464
  const i = $(c.getResolution(), c);
5467
5465
  _i(t, e, d, p, m, v, l, M, u, c, y, g, s, i);
@@ -5469,13 +5467,13 @@ function Gi(t, e, i, r, o, s, a, l, c) {
5469
5467
  ki(t, i, d, p, m, v, M, g);
5470
5468
  } else {
5471
5469
  const {aShape: n} = f;
5472
- let r = h.set(Ri, n[2 * a] / 10, n[2 * a + 1] / 10), s = h.set(Li, n[2 * a + 2] / 10, n[2 * a + 3] / 10), d = h.set(Hi, n[2 * a + 4] / 10, n[2 * a + 5] / 10), v = h.set(Vi, n[2 * a + 6] / 10, n[2 * a + 7] / 10);
5470
+ let r = h.set(Li, n[2 * a] / 10, n[2 * a + 1] / 10), s = h.set(Ri, n[2 * a + 2] / 10, n[2 * a + 3] / 10), d = h.set(Hi, n[2 * a + 4] / 10, n[2 * a + 5] / 10), v = h.set(Vi, n[2 * a + 6] / 10, n[2 * a + 7] / 10);
5473
5471
  0 === u.flipY && 1 === S && (h.multiply(r, r, qi), h.multiply(s, s, qi), h.multiply(d, d, qi),
5474
5472
  h.multiply(v, v, qi));
5475
5473
  let b = A ? -A[a] / 9362 : -(p.textRotation || 0) * Math.PI / 180;
5476
5474
  const x = m ? 0 : c.getBearing() * Math.PI / 180;
5477
5475
  if (b || x) {
5478
- const t = Si(Ni, b, x, T, S);
5476
+ const t = Si(Di, b, x, T, S);
5479
5477
  r = h.transformMat2(r, r, t), s = h.transformMat2(s, s, t), d = h.transformMat2(d, d, t),
5480
5478
  v = h.transformMat2(v, v, t);
5481
5479
  }
@@ -5548,14 +5546,14 @@ function $i(t, e, n, r, o, s, a, l, h) {
5548
5546
  e.properties.aAltitude = e.properties[t] || new u.constructor(u);
5549
5547
  }
5550
5548
  }
5551
- const d = Ye(t, u, !1), f = {
5549
+ const d = Je(t, u, !1), f = {
5552
5550
  flipY: 0,
5553
5551
  tileResolution: e.properties.tileResolution,
5554
5552
  tileRatio: e.properties.tileRatio,
5555
5553
  texture: d,
5556
5554
  texSize: [ u.width, u.height ]
5557
5555
  };
5558
- Yi(e, f, o);
5556
+ Ji(e, f, o);
5559
5557
  let p = !1;
5560
5558
  o.textOpacity < 1 && (p = !0), e.properties.memorySize = e.getMemorySize(), e.generateBuffers(t, {
5561
5559
  excludeElementsInVAO: !0
@@ -5577,7 +5575,7 @@ function $i(t, e, n, r, o, s, a, l, h) {
5577
5575
  texSize: [ u.width, u.height ],
5578
5576
  isHalo: 0
5579
5577
  };
5580
- Yi(e, t, o);
5578
+ Ji(e, t, o);
5581
5579
  const r = new i.Material(t, Bi), s = new i.Mesh(e, r, {
5582
5580
  disableVAO: !0,
5583
5581
  transparent: p,
@@ -5636,7 +5634,7 @@ function Xi(t, e, i) {
5636
5634
  }
5637
5635
  }
5638
5636
 
5639
- function Yi(t, e, i) {
5637
+ function Ji(t, e, i) {
5640
5638
  void 0 === e.isHalo && (e.isHalo = 1), pe(e, "textOpacity", i, "textOpacity", Bi.textOpacity),
5641
5639
  pe(e, "textFill", i, "textFill", Bi.textFill, ge()), pe(e, "textHaloFill", i, "textHaloFill", Bi.textHaloFill, ge()),
5642
5640
  pe(e, "textHaloBlur", i, "textHaloBlur", Bi.textHaloBlur), pe(e, "textHaloRadius", i, "textHaloRadius", Bi.textHaloRadius),
@@ -5647,7 +5645,7 @@ function Yi(t, e, i) {
5647
5645
  pe(e, "textDy", i, "textDy", Bi.textDy), pe(e, "textRotation", i, "textRotation", Bi.textRotation, t => t * Math.PI / 180);
5648
5646
  }
5649
5647
 
5650
- function Ji(t, e) {
5648
+ function Yi(t, e) {
5651
5649
  const i = t.getRenderer().canvas;
5652
5650
  return {
5653
5651
  uniforms: [ {
@@ -6309,7 +6307,7 @@ class An extends ui {
6309
6307
  pe(u, "markerWidth", o, "markerWidth", 15), pe(u, "markerHeight", o, "markerHeight", 15),
6310
6308
  pe(u, "markerDx", o, "markerDx", 0), pe(u, "markerDy", o, "markerDy", 0), pe(u, "markerRotation", o, "markerRotation", 0, t => t * Math.PI / 180),
6311
6309
  pe(u, "pitchWithMap", o, "markerPitchAlignment", 0, t => "map" === t ? 1 : 0), pe(u, "rotateWithMap", o, "markerRotationAlignment", 0, t => "map" === t ? 1 : 0),
6312
- u.iconTex = c ? Ye(t, c, !1) : null, u.texSize = c ? [ c.width, c.height ] : [ 0, 0 ],
6310
+ u.iconTex = c ? Je(t, c, !1) : null, u.texSize = c ? [ c.width, c.height ] : [ 0, 0 ],
6313
6311
  e.generateBuffers(t, {
6314
6312
  excludeElementsInVAO: !0
6315
6313
  });
@@ -6522,7 +6520,7 @@ class An extends ui {
6522
6520
  for (let i = n; i < r; i += 6) {
6523
6521
  const n = a[u] = a[u] || [];
6524
6522
  u++;
6525
- const r = Di.call(this, n, t, e[i], o, s);
6523
+ const r = Ni.call(this, n, t, e[i], o, s);
6526
6524
  if (!h) {
6527
6525
  const t = this.isCollides(r);
6528
6526
  1 === t ? h = 1 : -1 === t && c++;
@@ -6583,7 +6581,7 @@ class An extends ui {
6583
6581
  } ],
6584
6582
  extraCommandProps: n
6585
6583
  }), this.shader.version = 300;
6586
- const {uniforms: o, extraCommandProps: s} = Ji.call(this, this.layer, this.sceneConfig), a = this.xr || {};
6584
+ const {uniforms: o, extraCommandProps: s} = Yi.call(this, this.layer, this.sceneConfig), a = this.xr || {};
6587
6585
  if (this.Tr = new i.MeshShader({
6588
6586
  vert: an,
6589
6587
  frag: ln,
@@ -6669,16 +6667,16 @@ Sn.prototype = {
6669
6667
  return this.clone().jr(t);
6670
6668
  },
6671
6669
  multByPoint: function(t) {
6672
- return this.clone().Dr(t);
6670
+ return this.clone().Nr(t);
6673
6671
  },
6674
6672
  divByPoint: function(t) {
6675
- return this.clone().Nr(t);
6673
+ return this.clone().Dr(t);
6676
6674
  },
6677
6675
  mult: function(t) {
6678
- return this.clone().Rr(t);
6676
+ return this.clone().Lr(t);
6679
6677
  },
6680
6678
  div: function(t) {
6681
- return this.clone().Lr(t);
6679
+ return this.clone().Rr(t);
6682
6680
  },
6683
6681
  rotate: function(t) {
6684
6682
  return this.clone().Hr(t);
@@ -6733,20 +6731,20 @@ Sn.prototype = {
6733
6731
  jr: function(t) {
6734
6732
  return this.x -= t.x, this.y -= t.y, this;
6735
6733
  },
6736
- Rr: function(t) {
6734
+ Lr: function(t) {
6737
6735
  return this.x *= t, this.y *= t, this;
6738
6736
  },
6739
- Lr: function(t) {
6737
+ Rr: function(t) {
6740
6738
  return this.x /= t, this.y /= t, this;
6741
6739
  },
6742
- Dr: function(t) {
6740
+ Nr: function(t) {
6743
6741
  return this.x *= t.x, this.y *= t.y, this;
6744
6742
  },
6745
- Nr: function(t) {
6743
+ Dr: function(t) {
6746
6744
  return this.x /= t.x, this.y /= t.y, this;
6747
6745
  },
6748
6746
  qr: function() {
6749
- return this.Lr(this.mag()), this;
6747
+ return this.Rr(this.mag()), this;
6750
6748
  },
6751
6749
  Gr: function() {
6752
6750
  var t = this.y;
@@ -6782,7 +6780,7 @@ function In(t, e, i, r, o, s, a, l) {
6782
6780
  x.x = b.x, x.y = b.y, b.x = e[3 * v], b.y = e[3 * v + 1], w += A, A = x.dist(b) / u;
6783
6781
  }
6784
6782
  const _ = (g - w) / A, k = b.sub(x), S = k.mult(_).zr(x);
6785
- S.zr(k.qr().Gr().Rr(o * p));
6783
+ S.zr(k.qr().Gr().Lr(o * p));
6786
6784
  const T = m + Math.atan2(b.y - x.y, b.x - x.x);
6787
6785
  return t[0] = (S.x - i[0]) / u, t[1] = (S.y - i[1]) / u, t[2] = T, t;
6788
6786
  }(t, r, s, b, v[0], v[1], x[0], x[1], x[2], i / 24, l, a);
@@ -6811,36 +6809,42 @@ const zn = function(t) {
6811
6809
  }, jn = function(t) {
6812
6810
  const e = this.layer.getRenderer(), i = this.getSymbol(t.properties.symbolIndex);
6813
6811
  return !this.ur(t) && !e.isForeground(t) && "line" !== i.textPlacement;
6814
- }, Dn = function(t) {
6812
+ }, Nn = function(t) {
6815
6813
  const e = this.layer.getRenderer(), i = this.getSymbol(t.properties.symbolIndex);
6816
6814
  return !this.ur(t) && e.isTileNearCamera(t) && "line" === i.textPlacement;
6817
- }, Nn = function(t) {
6815
+ }, Dn = function(t) {
6818
6816
  const e = this.layer.getRenderer(), i = this.getSymbol(t.properties.symbolIndex);
6819
6817
  return !this.ur(t) && !e.isForeground(t) && "line" === i.textPlacement;
6820
- }, Rn = [ 0, 0, 3 ], Ln = [], Hn = [], Vn = [], Un = [], qn = [], Gn = [], Wn = [], Bn = [], $n = [], Xn = [ 1, -1 ], Yn = new Int16Array(3), Jn = [], Zn = [], Kn = [], Qn = [], tr = [], er = [], ir = {}, nr = {}, rr = {}, or = [];
6818
+ }, Ln = [ 0, 0, 3 ], Rn = [], Hn = [], Vn = [], Un = [], qn = [], Gn = [], Wn = [], Bn = [], $n = [], Xn = [ 1, -1 ], Jn = new Int16Array(3), Yn = [], Zn = [], Kn = [], Qn = [], tr = [], er = [], ir = {}, nr = {}, rr = {}, or = [];
6821
6819
 
6822
6820
  class sr extends ui {
6823
6821
  constructor(t, e, i, n, r) {
6824
6822
  super(t, e, i, n, r), this.propAllowOverlap = "textAllowOverlap", this.propIgnorePlacement = "textIgnorePlacement",
6825
- this.colorCache = {}, this.Br = zn.bind(this), this.$r = jn.bind(this), this.Xr = Dn.bind(this),
6826
- this.Yr = Nn.bind(this), this.isLabelCollides = nn.bind(this), this.Jr();
6823
+ this.colorCache = {}, this.Br = zn.bind(this), this.$r = jn.bind(this), this.Xr = Nn.bind(this),
6824
+ this.Jr = Dn.bind(this), this.isLabelCollides = nn.bind(this), this.Yr();
6827
6825
  }
6828
- Jr() {
6826
+ Yr() {
6829
6827
  this.Zr = [];
6830
6828
  for (let t = 0; t < this.symbolDef.length; t++) {
6831
6829
  const e = this.symbolDef[t];
6832
6830
  if (I.isExpression(e.textName)) {
6833
- const i = I.createExpression(e.textName);
6831
+ const i = I.createExpression(e.textName, "string");
6834
6832
  this.Zr[t] = (t, e) => {
6833
+ let n;
6835
6834
  ir.zoom = t, nr.properties = e;
6836
- return i.evaluateWithoutErrorHandling(ir, nr, rr, null, or);
6835
+ try {
6836
+ n = i.evaluateWithoutErrorHandling(ir, nr, rr, null, or);
6837
+ } catch (t) {
6838
+ n = null;
6839
+ }
6840
+ return n;
6837
6841
  };
6838
6842
  } else p(e.textName) && (this.Zr[t] = m(e.textName));
6839
6843
  }
6840
6844
  }
6841
6845
  updateSymbol(...t) {
6842
6846
  const e = super.updateSymbol(...t);
6843
- return this.Jr(), e;
6847
+ return this.Yr(), e;
6844
6848
  }
6845
6849
  shouldDeleteMeshOnUpdateSymbol(t) {
6846
6850
  if (!Array.isArray(t)) return (0 === t.textHaloRadius || 0 === this.symbolDef[0].textHaloRadius) && t.textHaloRadius !== this.symbolDef[0].textHaloRadius;
@@ -6883,7 +6887,7 @@ class sr extends ui {
6883
6887
  }
6884
6888
  callBackgroundTileShader(t, e) {
6885
6889
  this.shader.filter = e.sceneFilter ? [ this.$r, e.sceneFilter ] : this.$r, this.renderer.render(this.shader, t, this.scene, this.getRenderFBO(e)),
6886
- this.io.filter = e.sceneFilter ? [ this.Yr, e.sceneFilter ] : this.Yr, this.renderer.render(this.io, t, this.scene, this.getRenderFBO(e));
6890
+ this.io.filter = e.sceneFilter ? [ this.Jr, e.sceneFilter ] : this.Jr, this.renderer.render(this.io, t, this.scene, this.getRenderFBO(e));
6887
6891
  }
6888
6892
  eo() {
6889
6893
  let t = this.scene.getMeshes();
@@ -6937,7 +6941,7 @@ class sr extends ui {
6937
6941
  if (!s) return;
6938
6942
  const a = 1 === t.material.uniforms.pitchWithMap, l = o.elements;
6939
6943
  if (!a) {
6940
- const e = r.multiply(Ln, i.projViewMatrix, t.localTransform), n = new Array(s.length);
6944
+ const e = r.multiply(Rn, i.projViewMatrix, t.localTransform), n = new Array(s.length);
6941
6945
  s = this.ro(n, s, e, i.width, i.height);
6942
6946
  }
6943
6947
  const h = this.$n(), c = n.properties.visElemts = n.properties.visElemts || new l.constructor(l.length);
@@ -6963,7 +6967,7 @@ class sr extends ui {
6963
6967
  return this.to[o] = s, s;
6964
6968
  }
6965
6969
  forEachBox(t, e) {
6966
- const i = this.getMap(), n = r.multiply(Ln, i.projViewMatrix, t.localTransform), {collideIds: o, aCount: s, features: a, elements: l} = t.geometry.properties, h = o, c = this.isEnableUniquePlacement(), u = this.hr(1);
6970
+ const i = this.getMap(), n = r.multiply(Rn, i.projViewMatrix, t.localTransform), {collideIds: o, aCount: s, features: a, elements: l} = t.geometry.properties, h = o, c = this.isEnableUniquePlacement(), u = this.hr(1);
6967
6971
  u[0].allElements = l, u[0].mesh = t;
6968
6972
  let d = 0, f = l[0], p = 0, m = h[f];
6969
6973
  for (let i = 0; i <= l.length; i += 6) if (f = l[i], h[f] !== m || i === l.length) {
@@ -6992,35 +6996,35 @@ class sr extends ui {
6992
6996
  let M = !0;
6993
6997
  const I = e[i], O = e[o - 1], C = w ? w[I] : t.properties.textSize, E = this.so(t, C, s, I, O, k, T, u);
6994
6998
  if (null === E) return ar(g, e, i, o), !1;
6995
- const F = O - I <= 3, z = t.material.uniforms, j = 1 === z.pitchWithMap, D = Math.floor(E / 2), N = E % 2;
6999
+ const F = O - I <= 3, z = t.material.uniforms, j = 1 === z.pitchWithMap, N = Math.floor(E / 2), D = E % 2;
6996
7000
  for (let a = i; a < o; a += 6) {
6997
7001
  const l = e[a];
6998
7002
  let u;
6999
- if (u = D || a !== i || F ? D || a !== o - 6 || F ? In.call(this, Hn, t, C, s, l, k, T, D) : er : tr,
7003
+ if (u = N || a !== i || F ? N || a !== o - 6 || F ? In.call(this, Hn, t, C, s, l, k, T, N) : er : tr,
7000
7004
  !u) {
7001
7005
  M = !1, d || ar(g, e, i, o);
7002
7006
  break;
7003
7007
  }
7004
7008
  let f = u[2];
7005
- N && (f -= Math.PI / 2);
7009
+ D && (f -= Math.PI / 2);
7006
7010
  const p = Si(Wn, f, 0, z.rotateWithMap, z.pitchWithMap), m = g.length > y.length;
7007
7011
  let v;
7008
7012
  if (m) {
7009
7013
  n.set(Qn, x[3 * l], x[3 * l + 1], 0);
7010
7014
  const t = n.normalize(Qn, Qn), e = -x[3 * l + 2];
7011
7015
  if (e) {
7012
- const i = c.setAxisAngle(Jn, t, e);
7013
- r.fromTranslation(Zn, Rn), r.fromQuat(Kn, i), v = r.multiply(Kn, Kn, Zn);
7016
+ const i = c.setAxisAngle(Yn, t, e);
7017
+ r.fromTranslation(Zn, Ln), r.fromQuat(Kn, i), v = r.multiply(Kn, Kn, Zn);
7014
7018
  }
7015
7019
  }
7016
7020
  for (let t = 0; t < 4; t++) {
7017
7021
  const e = 2 * (l + t);
7018
7022
  h.set(Bn, y[e] / 10, y[e + 1] / 10), h.scale(Bn, Bn, C / 24), h.transformMat2(Bn, Bn, p),
7019
7023
  j ? (h.multiply(Bn, Bn, Xn), h.add($n, Bn, u), m && ($n[2] = 0, v && n.transformMat4($n, $n, v))) : (h.multiply($n, u, Xn),
7020
- h.add($n, Bn, $n)), Yn[0] = 10 * $n[0], Yn[1] = 10 * $n[1], m && (Yn[2] = 10 * $n[2]);
7024
+ h.add($n, Bn, $n)), Jn[0] = 10 * $n[0], Jn[1] = 10 * $n[1], m && (Jn[2] = 10 * $n[2]);
7021
7025
  const i = (m ? 3 : 2) * (l + t);
7022
- (g[i] !== Yn[0] || g[i + 1] !== Yn[1] || m && g[i + 2] !== Yn[2]) && (g.dirty = !0,
7023
- g[i] = Yn[0], g[i + 1] = Yn[1], m && (g[i + 2] = Yn[2]));
7026
+ (g[i] !== Jn[0] || g[i + 1] !== Jn[1] || m && g[i + 2] !== Jn[2]) && (g.dirty = !0,
7027
+ g[i] = Jn[0], g[i + 1] = Jn[1], m && (g[i + 2] = Jn[2]));
7024
7028
  }
7025
7029
  }
7026
7030
  return M;
@@ -7046,7 +7050,7 @@ class sr extends ui {
7046
7050
  init() {
7047
7051
  const t = this.regl;
7048
7052
  this.renderer = new i.Renderer(t);
7049
- const {uniforms: e, extraCommandProps: n} = Ji.call(this, this.layer, this.sceneConfig);
7053
+ const {uniforms: e, extraCommandProps: n} = Yi.call(this, this.layer, this.sceneConfig);
7050
7054
  this.shader = new i.MeshShader({
7051
7055
  vert: an,
7052
7056
  frag: ln,
@@ -7930,7 +7934,7 @@ class Mr extends $e {
7930
7934
  pe(u, "linePatternGap", l, "linePatternGap", 0), pe(u, "metallicFactor", l, "metallicFactor", 0),
7931
7935
  pe(u, "roughnessFactor", l, "roughnessFactor", .4), pe(u, "uvScale", l, "uvScale", [ 1, 1 ]);
7932
7936
  const d = r.properties.iconAtlas, f = r.data.aPosition instanceof Int16Array;
7933
- d && (u.linePatternFile = Ye(this.regl, d, !1), u.atlasSize = d ? [ d.width, d.height ] : [ 0, 0 ],
7937
+ d && (u.linePatternFile = Je(this.regl, d, !1), u.atlasSize = d ? [ d.width, d.height ] : [ 0, 0 ],
7934
7938
  u.flipY = f ? -1 : 1, this.drawDebugAtlas(d)), void 0 === s && r.generateBuffers(this.regl);
7935
7939
  const p = new i.pbr.StandardMaterial(u), m = new i.Mesh(r, p, {
7936
7940
  castShadow: !1,
@@ -7946,7 +7950,7 @@ class Mr extends $e {
7946
7950
  }
7947
7951
  setMeshDefines(t, e, i) {
7948
7952
  e.data.aOpacity && (t.HAS_OPACITY = 1), e.data.aLineWidth && (t.HAS_LINE_WIDTH = 1),
7949
- De(i.linePatternAnimSpeed) && (t.HAS_PATTERN_ANIM = 1), De(i.linePatternGap) && (t.HAS_PATTERN_GAP = 1);
7953
+ Ne(i.linePatternAnimSpeed) && (t.HAS_PATTERN_ANIM = 1), Ne(i.linePatternGap) && (t.HAS_PATTERN_GAP = 1);
7950
7954
  }
7951
7955
  paint(t) {
7952
7956
  t.states && t.states.includesChanged.shadow && (this.shader.dispose(), this.createShader(t)),
@@ -8117,7 +8121,7 @@ class Mr extends $e {
8117
8121
  }
8118
8122
  }
8119
8123
 
8120
- const Pr = [], Ir = [], Or = [ 0, 0, 0 ], Cr = [ 0, 0, 0 ], Er = [ 1, 1, 1 ], Fr = [], zr = [ 1, 1, 1, 1 ], jr = [], Dr = t => class extends t {
8124
+ const Pr = [], Ir = [], Or = [ 0, 0, 0 ], Cr = [ 0, 0, 0 ], Er = [ 1, 1, 1 ], Fr = [], zr = [ 1, 1, 1, 1 ], jr = [], Nr = t => class extends t {
8121
8125
  constructor(t, e, n, r, o) {
8122
8126
  super(t, e, n, r, o), this.So = !1, this.scene.sortFunction = this.sortByCommandKey,
8123
8127
  this.To = [], this.Mo = new i.GLTFManager(t), this.Po();
@@ -8310,19 +8314,19 @@ const Pr = [], Ir = [], Or = [ 0, 0, 0 ], Cr = [ 0, 0, 0 ], Er = [ 1, 1, 1 ], Fr
8310
8314
  }
8311
8315
  };
8312
8316
 
8313
- class Nr extends(Dr(xr)){
8317
+ class Dr extends(Nr(xr)){
8314
8318
  getMaterialClazz(t) {
8315
8319
  return t.diffuseFactor ? i.PhongSpecularGlossinessMaterial : i.PhongMaterial;
8316
8320
  }
8317
8321
  }
8318
8322
 
8319
- class Rr extends(Dr(kr)){
8323
+ class Lr extends(Nr(kr)){
8320
8324
  getMaterialClazz(t) {
8321
8325
  return t.specularGlossinessTexture || t.diffuseTexture ? i.pbr.StandardSpecularGlossinessMaterial : i.pbr.StandardMaterial;
8322
8326
  }
8323
8327
  }
8324
8328
 
8325
- const {getPBRUniforms: Lr} = i.pbr.PBRUtils, Hr = {
8329
+ const {getPBRUniforms: Rr} = i.pbr.PBRUtils, Hr = {
8326
8330
  color: [ 2.0303, 2.028, 2.028 ],
8327
8331
  direction: [ 0, -.2717, -1 ]
8328
8332
  }, Vr = {
@@ -8351,7 +8355,7 @@ class qr extends $e {
8351
8355
  callShader(t, e) {
8352
8356
  super.callShader(t, e), this.transformWater();
8353
8357
  const i = this.jo(this.getMap(), e);
8354
- this.renderer.render(this.Do, i, this.No, this.getRenderFBO(e));
8358
+ this.renderer.render(this.No, i, this.Do, this.getRenderFBO(e));
8355
8359
  }
8356
8360
  addMesh(t, e) {
8357
8361
  this.ln(t, e), super.addMesh(...arguments);
@@ -8361,14 +8365,14 @@ class qr extends $e {
8361
8365
  for (let i = 0; i < t.length; i++) t[i].ssr = e ? 1 : 0;
8362
8366
  }
8363
8367
  paint(t) {
8364
- t.states && t.states.includesChanged && (this.shader.dispose(), this.Do.dispose(),
8368
+ t.states && t.states.includesChanged && (this.shader.dispose(), this.No.dispose(),
8365
8369
  this.rn(t));
8366
- const e = !!t.ssr && this.getSymbol(Vr).ssr, i = this.Do, n = i.shaderDefines;
8370
+ const e = !!t.ssr && this.getSymbol(Vr).ssr, i = this.No, n = i.shaderDefines;
8367
8371
  if (e) {
8368
8372
  const e = he({}, n, t.ssr.defines);
8369
8373
  i.shaderDefines = e;
8370
8374
  }
8371
- this.updateIBLDefines(i), this.Ro.ssr = e ? 1 : 0, super.paint(t), e && (i.shaderDefines = n);
8375
+ this.updateIBLDefines(i), this.Lo.ssr = e ? 1 : 0, super.paint(t), e && (i.shaderDefines = n);
8372
8376
  }
8373
8377
  init(t) {
8374
8378
  this.createIBLTextures();
@@ -8386,9 +8390,9 @@ class qr extends $e {
8386
8390
  extraCommandProps: {
8387
8391
  viewport: this.pickingViewport
8388
8392
  }
8389
- }, this.pickingFBO) ]), this.Lo();
8393
+ }, this.pickingFBO) ]), this.Ro();
8390
8394
  }
8391
- Lo() {
8395
+ Ro() {
8392
8396
  const t = this.regl;
8393
8397
  this.Ho = t.texture(2), this.Vo = [ 2, 2 ];
8394
8398
  const e = this.getSymbol({
@@ -8521,7 +8525,7 @@ class qr extends $e {
8521
8525
  enable: !1
8522
8526
  }
8523
8527
  };
8524
- o.push(...i.SsrPass.getUniformDeclares()), this.Do = new i.MeshShader({
8528
+ o.push(...i.SsrPass.getUniformDeclares()), this.No = new i.MeshShader({
8525
8529
  vert: "#define SHADER_NAME WATER\nuniform mat4 modelMatrix;\nuniform mat4 projViewModelMatrix;\nattribute vec3 aPosition;\nattribute vec2 aTexCoord;\nuniform vec2 uvOffset;\nuniform vec2 noiseUvOffset;\nuniform vec2 uvScale;\nvarying vec2 vUv;\nvarying vec2 vNoiseUv;\nvarying vec3 vPos;\nvarying mat3 vTbnMatrix;\n#ifdef HAS_SSR\nuniform mat4 modelViewMatrix;\nvarying vec4 vViewVertex;\n#endif\nmat3 c(in vec3 d) {\n vec3 t = normalize(cross(d, vec3(.0, 1., .0)));\n vec3 e = normalize(cross(d, t));\n return mat3(t, e, d);\n}\n#if defined(HAS_SHADOWING)\n#include <vsm_shadow_vert>\n#endif\nconst vec3 f = vec3(0., 0., 1.);\nvoid main(void) {\n vec4 h = vec4(aPosition, 1.);\n vec4 i = modelMatrix * h;\n vPos = i.xyz;\n vTbnMatrix = c(f);\n gl_Position = projViewModelMatrix * h;\n vUv = aTexCoord * uvScale + uvOffset;\n vNoiseUv = aTexCoord * uvScale * TIME_NOISE_TEXTURE_REPEAT + noiseUvOffset;\n#ifdef HAS_SSR\nvec4 j = modelViewMatrix * h;\n vViewVertex = j;\n#endif\n#if defined(HAS_SHADOWING)\nshadow_computeShadowPars(h);\n#endif\n}",
8526
8530
  frag: "#define SHADER_NAME WATER\nprecision highp float;\nprecision highp sampler2D;\n#include <hsv_frag>\nuniform vec3 hsv;\nuniform float contrast;\n#if defined(HAS_SHADOWING)\n#include <vsm_shadow_frag>\n#endif\n#if defined(HAS_IBL_LIGHTING)\nuniform vec3 hdrHSV;\nuniform samplerCube prefilterMap;\nuniform sampler2D brdfLUT;\nuniform float rgbmRange;\nuniform mat3 uEnvironmentTransform;\nuniform vec3 diffuseSPH[9];\nvec3 c(const in vec3 d) {\n vec3 e = uEnvironmentTransform * d;\n float x = e.x;\n float y = e.y;\n float z = e.z;\n vec3 f = (diffuseSPH[0] + diffuseSPH[1] * x + diffuseSPH[2] * y + diffuseSPH[3] * z + diffuseSPH[4] * z * x + diffuseSPH[5] * y * z + diffuseSPH[6] * y * x + diffuseSPH[7] * (3. * z * z - 1.) + diffuseSPH[8] * (x * x - y * y));\n if(length(hdrHSV) > .0) {\n f = hsv_apply(f, hdrHSV);\n }\n return max(f, vec3(.0));\n}\nvec3 h(const in vec3 i, const in float j, const in float k, const in float l) {\n vec4 rgba = texture2D(brdfLUT, vec2(k, j));\n float b = (rgba[3] * 65280.0 + rgba[2] * 255.);\n float a = (rgba[1] * 65280.0 + rgba[0] * 255.);\n const float m = 1. / 65535.;\n return (i * a + b * l) * m;\n}\n#else\nuniform vec3 ambientColor;\n#endif\nstruct PBRShadingWater {\n float NdotL;\n float NdotV;\n float NdotH;\n float VdotH;\n float LdotH;\n float VdotN;\n};\nvec3 o(const in vec4 u, const in float v) {\n if(v <= .0)\n return u.rgb;\n return v * u.rgb * u.a;\n}\n#ifdef HAS_SSR\nvarying vec4 vViewVertex;\nuniform mat3 modelViewNormalMatrix;\nuniform sampler2D TextureDepth;\nuniform highp vec2 outSize;\nuniform float ssrFactor;\nuniform float ssrQuality;\nuniform sampler2D TextureReflected;\nuniform highp mat4 projMatrix;\nuniform mat4 invProjMatrix;\nuniform vec4 outputFovInfo[2];\nuniform mat4 reprojViewProjMatrix;\nuniform vec2 cameraNearFar;\nfloat A(const in vec4 B) {\n return B.r + B.g / 255.;\n}\nfloat C(const in vec2 D, const in float E) {\n vec3 F = vec3(.06711056, .00583715, 52.9829189);\n return fract(F.z * fract(dot(D.xy + E * vec2(47., 17.) * .695, F.xy))) * .5;\n}\nvec3 G(const in float H, const in float I, const in vec2 J) {\n float K = min(I - .01, H);\n float L = floor(K);\n float M = min(I, L + 1.);\n float N = pow(2., M);\n vec2 O = 2. * N / J;\n if(K - L > .5)\n N *= 2.;\n return vec3(O, N);\n}\nvec2 P(const in vec2 Q, const in vec3 R) {\n vec2 S = max(R.xy, min(1. - R.xy, Q));\n return vec2(2. * S.x, R.z - 1. - S.y) / R.z;\n}\nvec3 T(const in mat4 U, const in vec3 V) {\n vec4 W = U * vec4(V, 1.);\n return vec3(.5 + .5 * W.xy / W.w, W.w);\n}\nvec3 X(const in float Y, const in vec2 S) {\n return texture2D(TextureReflected, S).rgb;\n}\nfloat Z(float ba) {\n highp mat4 U = projMatrix;\n highp float z = ba * 2. - 1.;\n return -U[3].z / (z + U[2].z);\n}\nfloat bb(const vec2 S) {\n float ba = A(texture2D(TextureDepth, S));\n return ba;\n}\nvec3 bc(const in float E, const in vec3 bd, const in vec3 be, const in vec3 bf, const in vec3 bg, const in float bh) {\n vec2 bi;\n bi.x = C(gl_FragCoord.yx, E);\n bi.y = fract(bi.x * 52.9829189);\n bi.y = mix(bi.y, 1., .7);\n float bj = 2. * 3.14159 * bi.x;\n float bk = pow(max(bi.y, .000001), bh / (2. - bh));\n float bl = sqrt(1. - bk * bk);\n vec3 bm = vec3(bl * cos(bj), bl * sin(bj), bk);\n bm = bm.x * bd + bm.y * be + bm.z * bf;\n return normalize((2. * dot(bg, bm)) * bm - bg);\n}\nfloat bn(const in float E) {\n return (C(gl_FragCoord.xy, E) - .5);\n}\nvec3 bo(const in vec3 bp, const in float bq, const in vec3 br) {\n vec3 bs = T(projMatrix, vViewVertex.xyz + br * bq);\n bs.z = 1. / bs.z;\n bs -= bp;\n float bt = min(1., .99 * (1. - bp.x) / max(1e-5, bs.x));\n float bu = min(1., .99 * (1. - bp.y) / max(1e-5, bs.y));\n float bv = min(1., .99 * bp.x / max(1e-5, -bs.x));\n float bw = min(1., .99 * bp.y / max(1e-5, -bs.y));\n return bs * min(bt, bu) * min(bv, bw);\n}\nfloat bx(const in vec3 bp, const in vec3 bs, inout float by, inout float bz) {\n float bA = (bz + by) * .5;\n vec3 bB = bp + bs * bA;\n float z = bb(bB.xy);\n float ba = Z(z);\n float bC = -1. / bB.z;\n by = ba > bC ? by : bA;\n bz = ba > bC ? bA : bz;\n return bA;\n}\nvec4 bD(const in vec3 bp, const in float bq, in float bE, const in vec3 br, const in float j, const in float E) {\n const int bF = 20;\n float bG = 1. / float(bF);\n bE *= bG;\n vec3 bs = bo(bp, bq, br);\n float bH = bG;\n vec3 bI = vec3(.0, bH, 1.);\n vec3 bB;\n float z, ba, bC, bJ, bK, bL;\n bool bM;\n float bN = 1.;\n float bA;\n for(int bO = 0; bO < bF; bO++) {\n bB = bp + bs * bI.y;\n z = bb(bB.xy);\n ba = Z(z);\n bC = -1. / bB.z;\n bJ = bC - ba;\n bJ *= clamp(sign(abs(bJ) - bq * bG * bG), .0, 1.);\n bM = abs(bJ + bE) < bE;\n bK = clamp(bI.x / (bI.x - bJ), .0, 1.);\n bL = bM ? bI.y + bK * bG - bG : 1.;\n bI.z = min(bI.z, bL);\n bI.x = bJ;\n if(bM) {\n float by = bI.y - bG;\n float bz = bI.y;\n bA = bx(bp, bs, by, bz);\n bA = bx(bp, bs, by, bz);\n bA = bx(bp, bs, by, bz);\n bN = bA;\n break;\n }\n bI.y += bG;\n }\n return vec4(bp + bs * bN, 1. - bN);\n}\nvec3 bP(in vec4 bQ, const in float bR, const in vec3 bS, const in vec3 bT, const in float j) {\n vec4 bU = mix(outputFovInfo[0], outputFovInfo[1], bQ.x);\n bQ.xyz = vec3(mix(bU.xy, bU.zw, bQ.y), 1.) * -1. / bQ.z;\n bQ.xyz = (reprojViewProjMatrix * vec4(bQ.xyz, 1.)).xyw;\n bQ.xy /= bQ.z;\n float bV = clamp(6. - 6. * max(abs(bQ.x), abs(bQ.y)), .0, 1.);\n bQ.xy = .5 + .5 * bQ.xy;\n return vec3(bQ.xy, 1.);\n}\nvec3 ssr(const in vec3 bS, const in vec3 bT, const in float j, const in vec3 d, const in vec3 bg) {\n float bW = .0;\n vec4 f = vec4(.0);\n float bh = j * j;\n bh = bh * bh;\n vec3 bX = abs(d.z) < .999 ? vec3(.0, .0, 1.) : vec3(1., .0, .0);\n vec3 bd = normalize(cross(bX, d));\n vec3 be = cross(d, bd);\n float bR = ssrFactor * clamp(-4. * dot(bg, d) + 3.8, .0, 1.);\n bR *= clamp(4.7 - j * 5., .0, 1.);\n vec3 bp = T(projMatrix, vViewVertex.xyz);\n bp.z = 1. / bp.z;\n vec3 br = bc(bW, bd, be, d, bg, bh);\n float bq = mix(cameraNearFar.y + vViewVertex.z, -vViewVertex.z - cameraNearFar.x, br.z * .5 + .5);\n float bE = .5 * bq;\n vec4 bQ;\n if(dot(br, d) > .001 && bR > .0) {\n bQ = bD(bp, bq, bE, br, j, bW);\n if(bQ.w > .0)\n return bP(bQ, bR, bS, bT, j);\n \n }\n return vec3(.0);\n}\n#endif\nconst vec3 bY = vec3(0., 0., 1.);\nuniform mat4 viewMatrix;\nuniform sampler2D normalTexture;\nuniform sampler2D heightTexture;\nuniform vec4 waveParams;\nuniform vec2 waterDir;\nuniform vec4 waterBaseColor;\nuniform vec3 lightDirection;\nuniform vec3 lightColor;\nuniform vec3 camPos;\nuniform float timeElapsed;\nvarying vec2 vUv;\nvarying vec2 vNoiseUv;\nvarying vec3 vPos;\nvarying mat3 vTbnMatrix;\nfloat bZ(vec3 e, float ca) {\n float cb = max(.015, ca);\n return max((e.x + e.y) * .3303545 / cb + .3303545, .0);\n}\nconst vec2 cc = vec2(6. / 25., 5. / 24.);\nvec2 cd(sampler2D ce, vec2 S) {\n return 2. * texture2D(ce, S).rg - 1.;\n}\nfloat cf(vec2 S) {\n return texture2D(heightTexture, S).b;\n}\nvec3 cg(sampler2D ce, vec2 S) {\n return 2. * texture2D(ce, S).rgb - 1.;\n}\nfloat ch(vec2 S, float ci) {\n return fract(ci);\n}\nfloat cj(vec2 S, float ci) {\n float ck = ch(S, ci);\n return 1. - abs(1. - 2. * ck);\n}\nvec3 cl(sampler2D cm, vec2 S, float ci, float cn) {\n float co = waveParams[2];\n float cp = waveParams[3];\n vec2 cq = cd(cm, S) * co;\n float ck = ch(S, ci + cn);\n float cr = cj(S, ci + cn);\n vec2 f = S;\n f -= cq * (ck + cp);\n f += cn;\n f += (ci - ck) * cc;\n return vec3(f, cr);\n}\nconst float cs = 7.77;\nvec3 ct(sampler2D cu, sampler2D cv, vec2 cw, vec2 cx, float ci) {\n float ca = waveParams[0];\n vec2 cy = ci * -cx;\n float cz = cf(vNoiseUv) * cs;\n vec3 cA = cl(cv, cw + cy, ci + cz, .0);\n vec3 cB = cl(cv, cw + cy, ci + cz, .5);\n vec3 cC = cg(cu, cA.xy) * cA.z;\n vec3 cD = cg(cu, cB.xy) * cB.z;\n vec3 cE = normalize(cC + cD);\n cE.xy *= ca;\n cE.z = sqrt(1. - dot(cE.xy, cE.xy));\n return cE;\n}\nvec4 cF(vec2 cw, float cG) {\n float cH = waveParams[1];\n vec3 d = ct(normalTexture, heightTexture, cw * cH, waterDir, cG);\n float cI = bZ(d, waveParams[0]);\n return vec4(d, cI);\n}\nconst float cJ = 3.141592653589793;\nconst float cK = 1. / cJ;\nconst float cL = .3183098861837907;\nconst float cM = 1.570796326794897;\nconst float cN = .4;\nfloat cO = 2.2;\nvec3 cP(float cQ, vec3 cR, float l) {\n return cR + (l - cR) * pow(1. - cQ, 5.);\n}\nfloat cS(float cT, float j) {\n float cU = j * j;\n float cV = cT * cT;\n float cW = pow((cV * (cU - 1.) + 1.), cO) * cJ;\n return cU / cW;\n}\nfloat cX(float cY) {\n return .25 / (cY * cY);\n}\nvec3 cZ(const vec3 x) {\n return (x * (2.51 * x + .03)) / (x * (2.43 * x + .59) + .14);\n}\nconst float da = 2.2;\nconst float db = .4545454545;\nvec4 dc(vec4 u) {\n return vec4(pow(u.rgb, vec3(db)), u.w);\n}\nvec3 dd(vec3 u) {\n return pow(u, vec3(da));\n}\nconst vec3 de = vec3(.02, 1., 5.);\nconst vec2 df = vec2(.02, .1);\nconst float j = .06;\nconst float dg = 1.7;\nconst vec3 dh = vec3(0, .6, .9);\nconst vec3 di = vec3(.72, .92, 1.);\nconst float dj = .65;\nconst float dk = 300000.0;\nconst float dl = 500000.0;\nconst float dm = .775;\nconst float dn = .8;\nPBRShadingWater dp;\nvec3 dq(in PBRShadingWater dr, float j, vec3 ds, float dt) {\n vec3 du = cP(dr.VdotH, ds, dt);\n float dv = cS(dr.NdotH, j);\n float dw = cX(dr.LdotH);\n float dx = mix(j + .045, j + .385, 1. - dr.VdotH);\n float dy = 1.2;\n float dz = cS(dr.NdotH, dx) * dy;\n return ((dv + dz) * dw) * du;\n}\nvec3 dA(float dg, float dB, vec3 dh, float dC) {\n return dg * (.075 * dh * pow(dB, 4.) + 50. * pow(dB, 23.)) * dC;\n}\nvec3 dD(in float bk, in vec3 dE, in vec3 dF) {\n float dG = pow((1. - bk), de[2]);\n return mix(dF, dE, dG);\n}\nvec3 dH(in vec3 e, in vec3 dI, in float dJ, in float j) {\n \n#ifdef HAS_IBL_LIGHTING\nvec3 dK = reflect(-dI, e);\n vec4 dL = textureCube(prefilterMap, uEnvironmentTransform * dK);\n float dM = clamp(1. + dot(dK, e), .0, 1.);\n dL *= dM * dM;\n vec3 i = o(dL, rgbmRange);\n vec3 dN = c(e);\n float l = clamp(50.0 * waterBaseColor.g, .0, 1.);\n vec3 dO = h(waterBaseColor.rgb, j, dot(e, dI), l);\n return i * dO + dN;\n#else\nvec3 dP = dd(di);\n vec3 dQ = dd(dh);\n vec3 di = dD(dJ, dP, dQ);\n return di;\n#endif\n}\nvec3 dR(in vec3 e, in vec3 dI, in vec3 dS, vec3 u, in vec3 dT, in vec3 dU, in float dV, float dW, vec3 dX) {\n float dY = 0.;\n vec3 dZ = dd(u);\n vec3 bm = normalize(dS + dI);\n dp.NdotL = clamp(dot(e, dS), .0, 1.);\n dp.NdotV = clamp(dot(e, dI), .001, 1.);\n dp.VdotN = clamp(dot(dI, e), .001, 1.);\n dp.NdotH = clamp(dot(e, bm), .0, 1.);\n dp.VdotH = clamp(dot(dI, bm), .0, 1.);\n dp.LdotH = clamp(dot(dS, bm), .0, 1.);\n float dJ = max(dot(dU, dI), .0);\n vec3 di = dH(e, dI, dJ, j);\n float ea = max(dot(dU, dS), .0);\n float eb = .1 + ea * .9;\n di *= eb;\n float ec = clamp(dV, .8, 1.);\n vec3 ed = cP(dp.VdotN, vec3(de[0]), de[1]);\n vec3 ee = ed * di * ec;\n vec3 ef = dZ * mix(di, ea * dT * cK, 2. / 3.) * ec;\n vec3 i = vec3(.0);\n if(dJ > .0 && ea > .0) {\n vec3 eg = dq(dp, j, vec3(df[0]), df[1]);\n vec3 eh = dT * cK * dV;\n i = dp.NdotL * eh * eg;\n }\n vec3 cI = vec3(.0);\n if(dJ > .0) {\n cI = dA(dg, dW, dh, eb);\n }\n vec3 ei = vec3(.0);\n#ifdef HAS_SSR\nfloat ej = smoothstep(dl, dk, -dX.z);\n mat4 ek = viewMatrix;\n vec4 el = vec4(dX.xyz, 1.);\n vec3 em = normalize(el.xyz);\n vec4 en = ek * vec4(e, .0);\n vec3 eo = normalize(en.xyz);\n vec4 ep = ek * vec4(dU, .0);\n float eq = pow(max(dot(-em, ep.xyz), .0), cN);\n vec3 er = mix(ep.xyz, eo, eq);\n vec3 es = ssr(vec3(.0), vec3(1.), j, normalize(er), -normalize(vViewVertex.xyz));\n if(es.z > .0) {\n vec2 et = smoothstep(.3, .6, abs(vec2(.5) - es.xy));\n dY = dm * clamp(1. - 1.3 * et.y, .0, 1.) * ej;\n vec3 eu = X(.0, es.xy);\n ei = dd(eu) * dY * ed.y * dj;\n }\n#endif\nfloat ev = mix(dn, dn * .5, dY);\n return cZ((1. - dY) * ee + ei + ef * ev + i + cI);\n}\nvoid main() {\n vec3 dU = bY;\n vec4 ew = cF(vUv, timeElapsed);\n vec3 e = normalize(vTbnMatrix * ew.xyz);\n vec3 dI = -normalize(vPos - camPos);\n vec3 dS = normalize(-lightDirection);\n#if defined(HAS_SHADOWING)\nfloat dV = shadow_computeShadow();\n#else\nfloat dV = 1.;\n#endif\nvec4 ex = viewMatrix * vec4(vPos, 1.);\n vec4 ey = vec4(dR(e, dI, dS, waterBaseColor.rgb, lightColor, dU, dV, ew.w, ex.xyz), waterBaseColor.a);\n gl_FragColor = dc(ey);\n if(contrast != 1.) {\n gl_FragColor = contrastMatrix(contrast) * gl_FragColor;\n }\n if(length(hsv) > .0) {\n gl_FragColor = hsv_apply(gl_FragColor, hsv);\n }\n}",
8527
8531
  defines: s,
@@ -8538,7 +8542,7 @@ class qr extends $e {
8538
8542
  };
8539
8543
  }
8540
8544
  jo(t, e) {
8541
- const {iblTexes: i, dfgLUT: n} = this.getIBLRes(), r = Lr(t, i, n, e && e.ssr, e && e.jitter), o = t.getLightManager();
8545
+ const {iblTexes: i, dfgLUT: n} = this.getIBLRes(), r = Rr(t, i, n, e && e.ssr, e && e.jitter), o = t.getLightManager();
8542
8546
  let s = o && o.getDirectionalLight() || {};
8543
8547
  const l = o && o.getAmbientLight() || {}, h = this.getSymbol(Vr), c = this.Wo = this.Wo || [], u = this.Bo = this.Bo || [];
8544
8548
  a.set(u, .09, h.uvScale || 3, .03, -.5);
@@ -8561,23 +8565,23 @@ class qr extends $e {
8561
8565
  }
8562
8566
  delete() {
8563
8567
  super.delete(), this.Ho && (this.Ho.destroy(), delete this.Ho), this.Uo && this.Uo.destroy(),
8564
- this.Go && this.Go.destroy(), this.shader && this.shader.dispose(), this.Do && this.Do.dispose(),
8565
- this.Ro && (this.Ro.geometry.dispose(), this.Ro.material && this.Ro.material.dispose(),
8566
- this.Ro.dispose(), delete this.Ro), this.disposeIBLTextures();
8568
+ this.Go && this.Go.destroy(), this.shader && this.shader.dispose(), this.No && this.No.dispose(),
8569
+ this.Lo && (this.Lo.geometry.dispose(), this.Lo.material && this.Lo.material.dispose(),
8570
+ this.Lo.dispose(), delete this.Lo), this.disposeIBLTextures();
8567
8571
  }
8568
8572
  createGround() {
8569
8573
  const t = new i.Plane;
8570
8574
  t.data.aTexCoord = new Uint8Array([ 0, 1, 1, 1, 0, 0, 1, 0 ]), t.generateBuffers(this.renderer.regl),
8571
- this.Ro = new i.Mesh(t, null, {
8575
+ this.Lo = new i.Mesh(t, null, {
8572
8576
  castShadow: !1
8573
- }), this.No = new i.Scene([ this.Ro ]);
8577
+ }), this.Do = new i.Scene([ this.Lo ]);
8574
8578
  }
8575
8579
  transformWater() {
8576
- const t = this.getMap(), e = o.getGroundTransform(this.Ro.localTransform, t);
8577
- this.Ro.setLocalTransform(e);
8580
+ const t = this.getMap(), e = o.getGroundTransform(this.Lo.localTransform, t);
8581
+ this.Lo.setLocalTransform(e);
8578
8582
  const i = t._get2DExtentAtRes(t.getGLRes()), n = i.getWidth(), r = i.getHeight(), s = t.cameraLookAt, a = s[0] - n, l = s[1] + r, h = this.Vo, c = a / h[0], u = l / h[1], d = c % 1, f = u % 1, p = .3737 * c % 1, m = .3737 * u % 1, y = i.getWidth() / h[0] * 2, g = i.getHeight() / h[1] * 2;
8579
- this.Ro.setUniform("uvOffset", [ d, f ]), this.Ro.setUniform("noiseUvOffset", [ p, m ]),
8580
- this.Ro.setUniform("uvScale", [ y, -g ]);
8583
+ this.Lo.setUniform("uvOffset", [ d, f ]), this.Lo.setUniform("noiseUvOffset", [ p, m ]),
8584
+ this.Lo.setUniform("uvScale", [ y, -g ]);
8581
8585
  }
8582
8586
  }
8583
8587
 
@@ -8602,13 +8606,13 @@ const Xr = ae("icon", An);
8602
8606
 
8603
8607
  Xr.registerAt(vt);
8604
8608
 
8605
- const Yr = ae("text", sr);
8609
+ const Jr = ae("text", sr);
8606
8610
 
8607
- Yr.registerAt(vt);
8611
+ Jr.registerAt(vt);
8608
8612
 
8609
- const Jr = ae("native-line", fr);
8613
+ const Yr = ae("native-line", fr);
8610
8614
 
8611
- Jr.registerAt(vt);
8615
+ Yr.registerAt(vt);
8612
8616
 
8613
8617
  ae("native-point", ur).registerAt(vt);
8614
8618
 
@@ -8628,11 +8632,11 @@ const to = ae("tube", Mr);
8628
8632
 
8629
8633
  to.registerAt(vt);
8630
8634
 
8631
- const eo = ae("gltf-phong", Nr);
8635
+ const eo = ae("gltf-phong", Dr);
8632
8636
 
8633
8637
  eo.registerAt(vt);
8634
8638
 
8635
- const io = ae("gltf-lit", Rr);
8639
+ const io = ae("gltf-lit", Lr);
8636
8640
 
8637
8641
  io.registerAt(vt);
8638
8642
 
@@ -8719,18 +8723,18 @@ const ro = ae("water", qr);
8719
8723
  ro.registerAt(vt), It.registerPainter("lit", kr), It.registerPainter("icon", An),
8720
8724
  It.registerPainter("fill", Ze), It.registerPainter("line", Qe), It.registerPainter("line-gradient", ti),
8721
8725
  It.registerPainter("water", qr), It.registerPainter("tube", Mr), i.ShaderLib.register("vt_position_vert", "#ifdef HAS_ALTITUDE\n vec3 unpackVTPosition() {\n return vec3(aPosition, aAltitude);\n }\n#else\n float position_modValue = 16384.0;\n float position_delta = 0.00001;\n vec3 unpackVTPosition() {\n float z = aPosition.z;\n vec2 pos = sign(aPosition.xy + position_delta) * mod(abs(aPosition.xy), position_modValue);\n vec2 highs = floor(abs(aPosition.xy) / position_modValue);\n float altitude = sign(z + position_delta) * (highs.x * 2.0 + highs.y) * pow(2.0, 15.0) + z;\n return vec3(pos, altitude);\n }\n#endif"),
8722
- vt.VERSION = "0.72.1", It.VERSION = "0.72.1";
8726
+ vt.VERSION = "0.72.5", It.VERSION = "0.72.5";
8723
8727
 
8724
8728
  if (e.mat4.create(), e.transcoders) {
8725
8729
  const i = t.Map.VERSION;
8726
8730
  if (i.indexOf("1.0.0-beta") >= 0 || i.indexOf("1.0.0-alpha") >= 0) {
8727
- const i = e.transcoders.inject(D);
8731
+ const i = e.transcoders.inject(N);
8728
8732
  t.registerWorkerAdapter("@maptalks/vt", i);
8729
8733
  } else t.registerWorkerAdapter("@maptalks/vt", (function() {
8730
- return e.transcoders.inject(D);
8734
+ return e.transcoders.inject(N);
8731
8735
  }));
8732
- } else t.registerWorkerAdapter("@maptalks/vt", D);
8736
+ } else t.registerWorkerAdapter("@maptalks/vt", N);
8733
8737
 
8734
- export { Ze as FillPainter, Wr as FillPlugin, eo as GLTFPhongPlugin, io as GLTFStandardPlugin, Tt as GeoJSONVectorTileLayer, no as HeatmapPlugin, An as IconPainter, Xr as IconPlugin, $r as LineGradientPlugin, Qe as LinePainter, Br as LinePlugin, te as LineStringLayer, Qr as LitPlugin, kt as MapboxVectorTileLayer, fr as NativeLinePainter, Jr as NativeLinePlugin, ur as NativePointPainter, xr as PhongPainter, Zr as PhongPlugin, Qt as PointLayer, ie as PolygonLayer, sr as TextPainter, Yr as TextPlugin, to as TubePlugin, It as Vector3DLayer, vt as VectorTileLayer, lt as VectorTileLayerRenderer, ro as WaterPlugin, Ar as WireframePainter, Kr as WireframePlugin };
8738
+ export { Ze as FillPainter, Wr as FillPlugin, eo as GLTFPhongPlugin, io as GLTFStandardPlugin, Tt as GeoJSONVectorTileLayer, no as HeatmapPlugin, An as IconPainter, Xr as IconPlugin, $r as LineGradientPlugin, Qe as LinePainter, Br as LinePlugin, te as LineStringLayer, Qr as LitPlugin, kt as MapboxVectorTileLayer, fr as NativeLinePainter, Yr as NativeLinePlugin, ur as NativePointPainter, xr as PhongPainter, Zr as PhongPlugin, Qt as PointLayer, ie as PolygonLayer, sr as TextPainter, Jr as TextPlugin, to as TubePlugin, It as Vector3DLayer, vt as VectorTileLayer, lt as VectorTileLayerRenderer, ro as WaterPlugin, Ar as WireframePainter, Kr as WireframePlugin };
8735
8739
 
8736
- "undefined" != typeof console && console.log("@maptalks/vt v0.72.1");
8740
+ "undefined" != typeof console && console.log("@maptalks/vt v0.72.5");