@qratilabs/qrati-connect 2.23.9 → 2.24.0
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.
- package/README.md +84 -54
- package/element/2CMH9VMM.js +4 -0
- package/element/BKDqpSN62.js +3 -0
- package/element/{lrjV8c1G2.js → BM9ujORR2.js} +1 -1
- package/element/{BqHk5hDM.js → BOQzjiMV.js} +3 -3
- package/element/{BYEF5Khs.js → BOqkzZ92.js} +1 -1
- package/element/{-p_JqYFM2.js → BP2rYgya2.js} +9 -9
- package/element/BZu3c37u.js +1 -0
- package/element/{srDF4VyG.js → Bb7nx5xF.js} +1 -1
- package/element/Bh8kXbe92.js +93 -0
- package/{umd/BvNf2yif2.js → element/Bow6F3212.js} +29 -29
- package/{umd/BkvtmX4K.js → element/BsYbcfkG.js} +1 -1
- package/element/{C8_zGNAf.js → C12iSy3L.js} +1 -1
- package/element/{D9NypPiv.js → C3dOFk9A.js} +1 -1
- package/element/C52SUIvC2.js +35 -0
- package/element/{DIYUC8M3.js → CAETItHr.js} +1 -1
- package/element/{Cb1JRT_1.js → CATr-3VW.js} +1 -1
- package/element/{Byk0pccK.js → CFnGGYmq.js} +1 -1
- package/element/CHTzn6mh2.js +4 -0
- package/element/CL_evx_l.js +1 -0
- package/element/{e_wwJ5wx2.js → CLdpUOLk2.js} +4 -4
- package/element/{qWp4ucdT.js → CM46vluW.js} +1 -1
- package/{umd/BtN9y353.js → element/CVRTTCyF.js} +1 -1
- package/{umd/9QY9BKOL2.js → element/CWhnvMey2.js} +8 -8
- package/{umd/B14kCOq8.js → element/CZ9iaxjO.js} +1 -1
- package/element/CaX2xgrP.js +41 -0
- package/element/{b6CwQBFC.js → ChJXhA9c.js} +5 -5
- package/element/{4VTPoA38.js → CqBk9L5O.js} +1 -1
- package/{umd/CiiNqDJq.js → element/CsfDBJh72.js} +1 -1
- package/element/{_ty2jtjs.js → D35mTuTT.js} +1 -1
- package/element/D5TKEdBd2.js +3 -0
- package/element/{CCLXmMXp.js → DF0LxcV7.js} +1 -1
- package/element/{DvTRhlvs.js → DGGc10Cy.js} +1 -1
- package/element/{ekog7y-V.js → DGbyGc8b.js} +1 -1
- package/element/DN26AtHL2.js +4 -0
- package/element/{DsvRTvCp.js → DWBbTgnB.js} +1 -1
- package/element/{BQuhYd4G2.js → DZtaQWVG2.js} +1 -1
- package/{umd/D0VKfxwE.js → element/DdOwRfWG.js} +2 -2
- package/element/DkG0zv7_2.js +9 -0
- package/{umd/gk4TX_a62.js → element/DlRUi0u42.js} +1 -1
- package/element/{DXx41__x2.js → DlqJDAie2.js} +1 -1
- package/element/DnIueBGr2.js +1 -0
- package/element/{BglDIiFp.js → DnQ6XaLR.js} +2 -2
- package/element/DrrpB4Om.js +1 -0
- package/element/DtRwaUYF2.js +85 -0
- package/element/{CSO2IaJ1.js → LYboLIEU.js} +2 -2
- package/{umd/DNG5BSHx2.js → element/N4HKgEC52.js} +1 -1
- package/element/Rcen6i0h.js +80 -0
- package/element/{MpvHkxaz2.js → Z0-Tddye2.js} +1 -1
- package/element/dT6WSX65.js +1 -0
- package/element/h4ZjZXfe2.js +1 -0
- package/element/kiL9JENf2.js +3 -0
- package/element/{BdOzsWR32.js → lcKuIs2T2.js} +1 -1
- package/element/{DdmVPlUC2.js → mIANlVHi2.js} +1 -1
- package/element/mQzpzQ_t.js +3 -0
- package/element/web.es.js +26 -105
- package/package.json +3 -15
- package/react/index.d.mts +182 -6
- package/react/index.d.ts +182 -6
- package/element/9QY9BKOL2.js +0 -8
- package/element/B14kCOq8.js +0 -2
- package/element/BItJQVdK.js +0 -41
- package/element/BYoa-kpQ2.js +0 -9
- package/element/Be1e_ATJ.js +0 -1
- package/element/BfkCwRAR2.js +0 -3
- package/element/BkvtmX4K.js +0 -2
- package/element/BsT0vqml.js +0 -1
- package/element/BtN9y353.js +0 -1
- package/element/BvNf2yif2.js +0 -39
- package/element/C030L_Hu2.js +0 -4
- package/element/C0MGOytI.js +0 -1
- package/element/C3tT7YRo2.js +0 -37
- package/element/C3uDEVBt.js +0 -1
- package/element/CJ5ChvJ52.js +0 -93
- package/element/CiiNqDJq.js +0 -3
- package/element/CnoPTYOO.js +0 -1
- package/element/D0VKfxwE.js +0 -10
- package/element/D4apO9G62.js +0 -4
- package/element/DB1jhaAe2.js +0 -85
- package/element/DNG5BSHx2.js +0 -2
- package/element/LJWh_4Di.js +0 -2
- package/element/gjXXuILV2.js +0 -3
- package/element/gk4TX_a62.js +0 -7
- package/element/qNDy94Dr2.js +0 -3
- package/element/styles.css +0 -288
- package/umd/-p_JqYFM2.js +0 -14
- package/umd/4VTPoA38.js +0 -1
- package/umd/BCTYvPrD.js +0 -1
- package/umd/BItJQVdK.js +0 -41
- package/umd/BQuhYd4G2.js +0 -2
- package/umd/BYEF5Khs.js +0 -1
- package/umd/BYoa-kpQ2.js +0 -9
- package/umd/BdOzsWR32.js +0 -9
- package/umd/Be1e_ATJ.js +0 -1
- package/umd/BfkCwRAR2.js +0 -3
- package/umd/BglDIiFp.js +0 -3
- package/umd/BkIDQGIs.js +0 -1
- package/umd/Bki5T_lb.js +0 -1
- package/umd/BqHk5hDM.js +0 -9
- package/umd/BsT0vqml.js +0 -1
- package/umd/Byk0pccK.js +0 -1
- package/umd/C030L_Hu2.js +0 -4
- package/umd/C0MGOytI.js +0 -1
- package/umd/C3tT7YRo2.js +0 -37
- package/umd/C3uDEVBt.js +0 -1
- package/umd/C8_zGNAf.js +0 -1
- package/umd/CCLXmMXp.js +0 -3
- package/umd/CJ5ChvJ52.js +0 -93
- package/umd/CSO2IaJ1.js +0 -2
- package/umd/Cb1JRT_1.js +0 -1
- package/umd/CfMNBPpx2.js +0 -1
- package/umd/CgUphJWo.js +0 -1
- package/umd/Cko4QHwX.js +0 -1
- package/umd/CnoPTYOO.js +0 -1
- package/umd/D4apO9G62.js +0 -4
- package/umd/D9NypPiv.js +0 -7
- package/umd/DB1jhaAe2.js +0 -85
- package/umd/DIYUC8M3.js +0 -2
- package/umd/DXx41__x2.js +0 -2
- package/umd/DdmVPlUC2.js +0 -13
- package/umd/DsvRTvCp.js +0 -8
- package/umd/DvTRhlvs.js +0 -2
- package/umd/LJWh_4Di.js +0 -2
- package/umd/MpvHkxaz2.js +0 -16
- package/umd/_ty2jtjs.js +0 -2
- package/umd/b6CwQBFC.js +0 -5
- package/umd/e_wwJ5wx2.js +0 -5
- package/umd/ekog7y-V.js +0 -1
- package/umd/gjXXuILV2.js +0 -3
- package/umd/index.d.ts +0 -14
- package/umd/lrjV8c1G2.js +0 -8
- package/umd/qNDy94Dr2.js +0 -3
- package/umd/qWp4ucdT.js +0 -1
- package/umd/rtH8O6Hc.js +0 -1
- package/umd/srDF4VyG.js +0 -9
- package/umd/web.es.js +0 -122
- package/umd/web.umd.js +0 -1
package/umd/LJWh_4Di.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{t as e}from"./Cko4QHwX.js";var t=/* @__PURE__ */e((e,t)=>{var i,r;i=e,r=function(){let e,t,i;function r(r,n){if(e)if(t){const r={};e(void 0,r),i=n(r);const o="self.onerror = function() { console.error('An error occurred while parsing the WebWorker bundle. This is most likely due to improper transpilation by Babel; please see https://docs.mapbox.com/mapbox-gl-js/guides/install/#transpiling'); }; var sharedChunk = {}; ("+e+")(undefined, sharedChunk); ("+t+")(undefined, sharedChunk); self.onerror = null;";typeof window<"u"&&window&&window.URL&&window.URL.createObjectURL&&(i.workerUrl=window.URL.createObjectURL(new Blob([o],{type:"text/javascript"})))}else t=n;else e=n}return r(0,function(e,t){var i=1e-6,r="undefined"!=typeof Float32Array?Float32Array:Array;function n(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=i*o-n*r;return s?(e[0]=o*(s=1/s),e[1]=-r*s,e[2]=-n*s,e[3]=i*s,e):null}function o(){var e=new r(9);return r!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[5]=0,e[6]=0,e[7]=0),e[0]=1,e[4]=1,e[8]=1,e}function s(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=t[4],a=t[5],l=t[6],c=t[7],h=t[8];return e[0]=s*h-a*c,e[1]=n*c-r*h,e[2]=r*a-n*s,e[3]=a*l-o*h,e[4]=i*h-n*l,e[5]=n*o-i*a,e[6]=o*c-s*l,e[7]=r*l-i*c,e[8]=i*s-r*o,e}function a(e,t,i){var r=t[0],n=t[1],o=t[2],s=t[3],a=t[4],l=t[5],c=t[6],h=t[7],u=t[8],d=i[0],p=i[1],f=i[2],m=i[3],_=i[4],g=i[5],y=i[6],x=i[7],v=i[8];return e[0]=d*r+p*s+f*c,e[1]=d*n+p*a+f*h,e[2]=d*o+p*l+f*u,e[3]=m*r+_*s+g*c,e[4]=m*n+_*a+g*h,e[5]=m*o+_*l+g*u,e[6]=y*r+x*s+v*c,e[7]=y*n+x*a+v*h,e[8]=y*o+x*l+v*u,e}function l(){var e=new r(16);return r!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function c(e){var t=new r(16);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t[6]=e[6],t[7]=e[7],t[8]=e[8],t[9]=e[9],t[10]=e[10],t[11]=e[11],t[12]=e[12],t[13]=e[13],t[14]=e[14],t[15]=e[15],t}function h(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function u(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=t[4],a=t[5],l=t[6],c=t[7],h=t[8],u=t[9],d=t[10],p=t[11],f=t[12],m=t[13],_=t[14],g=t[15],y=i*a-r*s,x=i*l-n*s,v=i*c-o*s,b=r*l-n*a,w=r*c-o*a,T=n*c-o*l,S=h*m-u*f,I=h*_-d*f,E=h*g-p*f,A=u*_-d*m,M=u*g-p*m,C=d*g-p*_,P=y*C-x*M+v*A+b*E-w*I+T*S;return P?(e[0]=(a*C-l*M+c*A)*(P=1/P),e[1]=(n*M-r*C-o*A)*P,e[2]=(m*T-_*w+g*b)*P,e[3]=(d*w-u*T-p*b)*P,e[4]=(l*E-s*C-c*I)*P,e[5]=(i*C-n*E+o*I)*P,e[6]=(_*v-f*T-g*x)*P,e[7]=(h*T-d*v+p*x)*P,e[8]=(s*M-a*E+c*S)*P,e[9]=(r*E-i*M-o*S)*P,e[10]=(f*w-m*v+g*y)*P,e[11]=(u*v-h*w-p*y)*P,e[12]=(a*I-s*A-l*S)*P,e[13]=(i*A-r*I+n*S)*P,e[14]=(m*x-f*b-_*y)*P,e[15]=(h*b-u*x+d*y)*P,e):null}function d(e,t,i){var r=t[0],n=t[1],o=t[2],s=t[3],a=t[4],l=t[5],c=t[6],h=t[7],u=t[8],d=t[9],p=t[10],f=t[11],m=t[12],_=t[13],g=t[14],y=t[15],x=i[0],v=i[1],b=i[2],w=i[3];return e[0]=x*r+v*a+b*u+w*m,e[1]=x*n+v*l+b*d+w*_,e[2]=x*o+v*c+b*p+w*g,e[3]=x*s+v*h+b*f+w*y,e[4]=(x=i[4])*r+(v=i[5])*a+(b=i[6])*u+(w=i[7])*m,e[5]=x*n+v*l+b*d+w*_,e[6]=x*o+v*c+b*p+w*g,e[7]=x*s+v*h+b*f+w*y,e[8]=(x=i[8])*r+(v=i[9])*a+(b=i[10])*u+(w=i[11])*m,e[9]=x*n+v*l+b*d+w*_,e[10]=x*o+v*c+b*p+w*g,e[11]=x*s+v*h+b*f+w*y,e[12]=(x=i[12])*r+(v=i[13])*a+(b=i[14])*u+(w=i[15])*m,e[13]=x*n+v*l+b*d+w*_,e[14]=x*o+v*c+b*p+w*g,e[15]=x*s+v*h+b*f+w*y,e}function p(e,t,i){var r,n,o,s,a,l,c,h,u,d,p,f,m=i[0],_=i[1],g=i[2];return t===e?(e[12]=t[0]*m+t[4]*_+t[8]*g+t[12],e[13]=t[1]*m+t[5]*_+t[9]*g+t[13],e[14]=t[2]*m+t[6]*_+t[10]*g+t[14],e[15]=t[3]*m+t[7]*_+t[11]*g+t[15]):(n=t[1],o=t[2],s=t[3],a=t[4],l=t[5],c=t[6],h=t[7],u=t[8],d=t[9],p=t[10],f=t[11],e[0]=r=t[0],e[1]=n,e[2]=o,e[3]=s,e[4]=a,e[5]=l,e[6]=c,e[7]=h,e[8]=u,e[9]=d,e[10]=p,e[11]=f,e[12]=r*m+a*_+u*g+t[12],e[13]=n*m+l*_+d*g+t[13],e[14]=o*m+c*_+p*g+t[14],e[15]=s*m+h*_+f*g+t[15]),e}function f(e,t,i){var r=i[0],n=i[1],o=i[2];return e[0]=t[0]*r,e[1]=t[1]*r,e[2]=t[2]*r,e[3]=t[3]*r,e[4]=t[4]*n,e[5]=t[5]*n,e[6]=t[6]*n,e[7]=t[7]*n,e[8]=t[8]*o,e[9]=t[9]*o,e[10]=t[10]*o,e[11]=t[11]*o,e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e}function m(e,t,i){var r=Math.sin(i),n=Math.cos(i),o=t[4],s=t[5],a=t[6],l=t[7],c=t[8],h=t[9],u=t[10],d=t[11];return t!==e&&(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[4]=o*n+c*r,e[5]=s*n+h*r,e[6]=a*n+u*r,e[7]=l*n+d*r,e[8]=c*n-o*r,e[9]=h*n-s*r,e[10]=u*n-a*r,e[11]=d*n-l*r,e}function _(e,t,i){var r=Math.sin(i),n=Math.cos(i),o=t[0],s=t[1],a=t[2],l=t[3],c=t[8],h=t[9],u=t[10],d=t[11];return t!==e&&(e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[0]=o*n-c*r,e[1]=s*n-h*r,e[2]=a*n-u*r,e[3]=l*n-d*r,e[8]=o*r+c*n,e[9]=s*r+h*n,e[10]=a*r+u*n,e[11]=l*r+d*n,e}function g(e,t,i){var r=Math.sin(i),n=Math.cos(i),o=t[0],s=t[1],a=t[2],l=t[3],c=t[4],h=t[5],u=t[6],d=t[7];return t!==e&&(e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15]),e[0]=o*n+c*r,e[1]=s*n+h*r,e[2]=a*n+u*r,e[3]=l*n+d*r,e[4]=c*n-o*r,e[5]=h*n-s*r,e[6]=u*n-a*r,e[7]=d*n-l*r,e}function y(e,t){return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=1,e[11]=0,e[12]=t[0],e[13]=t[1],e[14]=t[2],e[15]=1,e}function x(e,t){return e[0]=t[0],e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=t[1],e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=t[2],e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}function v(e,t,r){var n,o,s,a=r[0],l=r[1],c=r[2],h=Math.sqrt(a*a+l*l+c*c);return h<i?null:(a*=h=1/h,l*=h,c*=h,n=Math.sin(t),o=Math.cos(t),e[0]=a*a*(s=1-o)+o,e[1]=l*a*s+c*n,e[2]=c*a*s-l*n,e[3]=0,e[4]=a*l*s-c*n,e[5]=l*l*s+o,e[6]=c*l*s+a*n,e[7]=0,e[8]=a*c*s+l*n,e[9]=l*c*s-a*n,e[10]=c*c*s+o,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e)}function b(e,t){var i=t[0],r=t[1],n=t[2],o=t[4],s=t[5],a=t[6],l=t[8],c=t[9],h=t[10];return e[0]=Math.sqrt(i*i+r*r+n*n),e[1]=Math.sqrt(o*o+s*s+a*a),e[2]=Math.sqrt(l*l+c*c+h*h),e}function w(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=i+i,a=r+r,l=n+n,c=i*s,h=r*s,u=r*a,d=n*s,p=n*a,f=n*l,m=o*s,_=o*a,g=o*l;return e[0]=1-u-f,e[1]=h+g,e[2]=d-_,e[3]=0,e[4]=h-g,e[5]=1-c-f,e[6]=p+m,e[7]=0,e[8]=d+_,e[9]=p-m,e[10]=1-c-u,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e}var T=d;function S(){var e=new r(3);return r!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function I(e){var t=new r(3);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t}function E(e){var t=e[0],i=e[1],r=e[2];return Math.sqrt(t*t+i*i+r*r)}function A(e,t,i){var n=new r(3);return n[0]=e,n[1]=t,n[2]=i,n}function M(e,t,i,r){return e[0]=t,e[1]=i,e[2]=r,e}function C(e,t,i){return e[0]=t[0]+i[0],e[1]=t[1]+i[1],e[2]=t[2]+i[2],e}function P(e,t,i){return e[0]=t[0]-i[0],e[1]=t[1]-i[1],e[2]=t[2]-i[2],e}function D(e,t,i){return e[0]=t[0]*i[0],e[1]=t[1]*i[1],e[2]=t[2]*i[2],e}function R(e,t,i){return e[0]=Math.min(t[0],i[0]),e[1]=Math.min(t[1],i[1]),e[2]=Math.min(t[2],i[2]),e}function z(e,t,i){return e[0]=Math.max(t[0],i[0]),e[1]=Math.max(t[1],i[1]),e[2]=Math.max(t[2],i[2]),e}function L(e,t,i){return e[0]=t[0]*i,e[1]=t[1]*i,e[2]=t[2]*i,e}function F(e,t,i,r){return e[0]=t[0]+i[0]*r,e[1]=t[1]+i[1]*r,e[2]=t[2]+i[2]*r,e}function O(e,t){var i=t[0]-e[0],r=t[1]-e[1],n=t[2]-e[2];return Math.sqrt(i*i+r*r+n*n)}function B(e,t){var i=t[0]-e[0],r=t[1]-e[1],n=t[2]-e[2];return i*i+r*r+n*n}function k(e){var t=e[0],i=e[1],r=e[2];return t*t+i*i+r*r}function N(e,t){return e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e}function U(e,t){var i=t[0],r=t[1],n=t[2],o=i*i+r*r+n*n;return o>0&&(o=1/Math.sqrt(o)),e[0]=t[0]*o,e[1]=t[1]*o,e[2]=t[2]*o,e}function V(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function j(e,t,i){var r=t[0],n=t[1],o=t[2],s=i[0],a=i[1],l=i[2];return e[0]=n*l-o*a,e[1]=o*s-r*l,e[2]=r*a-n*s,e}function G(e,t,i,r){var n=t[0],o=t[1],s=t[2];return e[0]=n+r*(i[0]-n),e[1]=o+r*(i[1]-o),e[2]=s+r*(i[2]-s),e}function H(e,t,i){var r=t[0],n=t[1],o=t[2],s=i[3]*r+i[7]*n+i[11]*o+i[15];return e[0]=(i[0]*r+i[4]*n+i[8]*o+i[12])/(s=s||1),e[1]=(i[1]*r+i[5]*n+i[9]*o+i[13])/s,e[2]=(i[2]*r+i[6]*n+i[10]*o+i[14])/s,e}function $(e,t,i){var r=t[0],n=t[1],o=t[2];return e[0]=r*i[0]+n*i[3]+o*i[6],e[1]=r*i[1]+n*i[4]+o*i[7],e[2]=r*i[2]+n*i[5]+o*i[8],e}function q(e,t,i){var r=i[0],n=i[1],o=i[2],s=i[3],a=t[0],l=t[1],c=t[2],h=n*c-o*l,u=o*a-r*c,d=r*l-n*a;return e[0]=a+s*(h+=h)+n*(d+=d)-o*(u+=u),e[1]=l+s*u+o*h-r*d,e[2]=c+s*d+r*u-n*h,e}function Z(e){return e[0]=0,e[1]=0,e[2]=0,e}function W(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]}var X=P,Y=D,J=E;function K(){var e=new r(4);return r!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e}function Q(e,t,i){return e[0]=t[0]*i,e[1]=t[1]*i,e[2]=t[2]*i,e[3]=t[3]*i,e}function ee(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=i*i+r*r+n*n+o*o;return s>0&&(s=1/Math.sqrt(s)),e[0]=i*s,e[1]=r*s,e[2]=n*s,e[3]=o*s,e}function te(e,t,i){var r=t[0],n=t[1],o=t[2],s=t[3];return e[0]=i[0]*r+i[4]*n+i[8]*o+i[12]*s,e[1]=i[1]*r+i[5]*n+i[9]*o+i[13]*s,e[2]=i[2]*r+i[6]*n+i[10]*o+i[14]*s,e[3]=i[3]*r+i[7]*n+i[11]*o+i[15]*s,e}function ie(){var e=new r(4);return r!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e[3]=1,e}function re(e){return e[0]=0,e[1]=0,e[2]=0,e[3]=1,e}function ne(e,t,i){i*=.5;var r=t[0],n=t[1],o=t[2],s=t[3],a=Math.sin(i),l=Math.cos(i);return e[0]=r*l+s*a,e[1]=n*l+o*a,e[2]=o*l-n*a,e[3]=s*l-r*a,e}function oe(e,t,i){i*=.5;var r=t[0],n=t[1],o=t[2],s=t[3],a=Math.sin(i),l=Math.cos(i);return e[0]=r*l-o*a,e[1]=n*l+s*a,e[2]=o*l+r*a,e[3]=s*l-n*a,e}S(),K();var se,ae,le,ce=ee,he=(se=S(),ae=A(1,0,0),le=A(0,1,0),function(e,t,i){var r=V(t,i);return r<-.999999?(j(se,ae,t),J(se)<1e-6&&j(se,le,t),U(se,se),function(e,t,i){i*=.5;var r=Math.sin(i);e[0]=r*t[0],e[1]=r*t[1],e[2]=r*t[2],e[3]=Math.cos(i)}(e,se,Math.PI),e):r>.999999?(e[0]=0,e[1]=0,e[2]=0,e[3]=1,e):(j(se,t,i),e[0]=se[0],e[1]=se[1],e[2]=se[2],e[3]=1+r,ce(e,e))});function ue(){var e=new r(2);return r!=Float32Array&&(e[0]=0,e[1]=0),e}function de(e,t){var i=new r(2);return i[0]=e,i[1]=t,i}function pe(e,t,i){return e[0]=t,e[1]=i,e}function fe(e,t,i){return e[0]=t[0]+i[0],e[1]=t[1]+i[1],e}function me(e,t,i){return e[0]=t[0]-i[0],e[1]=t[1]-i[1],e}function _e(e,t,i){return e[0]=t[0]*i,e[1]=t[1]*i,e}function ge(e){var t=e[0],i=e[1];return Math.sqrt(t*t+i*i)}function ye(e,t){var i=t[0],r=t[1],n=i*i+r*r;return n>0&&(n=1/Math.sqrt(n)),e[0]=t[0]*n,e[1]=t[1]*n,e}function xe(e,t){return e[0]*t[0]+e[1]*t[1]}ie(),ie(),o();var ve,be,we=me;function Te(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}ue();var Se=Te(function(){if(be)return ve;function e(e,t,i,r){this.cx=3*e,this.bx=3*(i-e)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*t,this.by=3*(r-t)-this.cy,this.ay=1-this.cy-this.by,this.p1x=e,this.p1y=t,this.p2x=i,this.p2y=r}return be=1,ve=e,e.prototype={sampleCurveX:function(e){return((this.ax*e+this.bx)*e+this.cx)*e},sampleCurveY:function(e){return((this.ay*e+this.by)*e+this.cy)*e},sampleCurveDerivativeX:function(e){return(3*this.ax*e+2*this.bx)*e+this.cx},solveCurveX:function(e,t){if(void 0===t&&(t=1e-6),e<0)return 0;if(e>1)return 1;for(var i=e,r=0;r<8;r++){var n=this.sampleCurveX(i)-e;if(Math.abs(n)<t)return i;var o=this.sampleCurveDerivativeX(i);if(Math.abs(o)<1e-6)break;i-=n/o}var s=0,a=1;for(i=e,r=0;r<20&&(n=this.sampleCurveX(i),!(Math.abs(n-e)<t));r++)e>n?s=i:a=i,i=.5*(a-s)+s;return i},solve:function(e,t){return this.sampleCurveY(this.solveCurveX(e,t))}},ve}());function Ie(e,t){this.x=e,this.y=t}function Ee(e,t){if(Array.isArray(e)){if(!Array.isArray(t)||e.length!==t.length)return!1;for(let i=0;i<e.length;i++)if(!Ee(e[i],t[i]))return!1;return!0}if("object"==typeof e&&null!==e&&null!==t){if("object"!=typeof t)return!1;if(Object.keys(e).length!==Object.keys(t).length)return!1;for(const i in e)if(!Ee(e[i],t[i]))return!1;return!0}return e===t}Ie.prototype={clone(){return new Ie(this.x,this.y)},add(e){return this.clone()._add(e)},sub(e){return this.clone()._sub(e)},multByPoint(e){return this.clone()._multByPoint(e)},divByPoint(e){return this.clone()._divByPoint(e)},mult(e){return this.clone()._mult(e)},div(e){return this.clone()._div(e)},rotate(e){return this.clone()._rotate(e)},rotateAround(e,t){return this.clone()._rotateAround(e,t)},matMult(e){return this.clone()._matMult(e)},unit(){return this.clone()._unit()},perp(){return this.clone()._perp()},round(){return this.clone()._round()},mag(){return Math.sqrt(this.x*this.x+this.y*this.y)},equals(e){return this.x===e.x&&this.y===e.y},dist(e){return Math.sqrt(this.distSqr(e))},distSqr(e){const t=e.x-this.x,i=e.y-this.y;return t*t+i*i},angle(){return Math.atan2(this.y,this.x)},angleTo(e){return Math.atan2(this.y-e.y,this.x-e.x)},angleWith(e){return this.angleWithSep(e.x,e.y)},angleWithSep(e,t){return Math.atan2(this.x*t-this.y*e,this.x*e+this.y*t)},_matMult(e){const t=e[2]*this.x+e[3]*this.y;return this.x=e[0]*this.x+e[1]*this.y,this.y=t,this},_add(e){return this.x+=e.x,this.y+=e.y,this},_sub(e){return this.x-=e.x,this.y-=e.y,this},_mult(e){return this.x*=e,this.y*=e,this},_div(e){return this.x/=e,this.y/=e,this},_multByPoint(e){return this.x*=e.x,this.y*=e.y,this},_divByPoint(e){return this.x/=e.x,this.y/=e.y,this},_unit(){return this._div(this.mag()),this},_perp(){const e=this.y;return this.y=this.x,this.x=-e,this},_rotate(e){const t=Math.cos(e),i=Math.sin(e),r=i*this.x+t*this.y;return this.x=t*this.x-i*this.y,this.y=r,this},_rotateAround(e,t){const i=Math.cos(e),r=Math.sin(e),n=t.y+r*(this.x-t.x)+i*(this.y-t.y);return this.x=t.x+i*(this.x-t.x)-r*(this.y-t.y),this.y=n,this},_round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this},constructor:Ie},Ie.convert=function(e){if(e instanceof Ie)return e;if(Array.isArray(e))return new Ie(+e[0],+e[1]);if(void 0!==e.x&&void 0!==e.y)return new Ie(+e.x,+e.y);throw new Error("Expected [x, y] or {x, y} point format")};const Ae=Math.PI/180,Me=180/Math.PI,Ce=/^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i,Pe=/\b(iPad|iPhone|iPod)\b/,De=/CPU (OS|iPhone OS) (15_4|15_5) like Mac OS X/;function Re(e){return e*Ae}function ze(e){return e*Me}const Le=[[0,0],[1,0],[1,1],[0,1]];function Fe(e){if(e<=0)return 0;if(e>=1)return 1;const t=e*e,i=t*e;return 4*(e<.5?i:3*(e-t)+i-.75)}function Oe(e,t,i,r){const n=new Se(e,t,i,r);return function(e){return n.solve(e)}}const Be=Oe(.25,.1,.25,1);function ke(e,t,i){return Math.min(i,Math.max(t,e))}function Ne(e,t,i){return(i=ke((i-e)/(t-e),0,1))*i*(3-2*i)}function Ue(e,t,i){const r=i-t,n=((e-t)%r+r)%r+t;return n===t?i:n}function Ve(e,t,i){if(!e.length)return i(null,[]);let r=e.length;const n=new Array(e.length);let o=null;e.forEach((e,s)=>{t(e,(e,t)=>{e&&(o=e),n[s]=t,0===--r&&i(o,n)})})}function je(e,t){const i={};for(let r=0;r<t.length;r++){const n=t[r];n in e&&(i[n]=e[n])}return i}let Ge=1;function He(){return Ge++}function $e(e){return e<=1?1:Math.pow(2,Math.ceil(Math.log2(e)))}function qe(e,t){e.forEach(e=>{t[e]&&(t[e]=t[e].bind(t))})}function Ze(e,t,i){const r={};for(const n in e)r[n]=t.call(this,e[n],n,e);return r}function We(e,t,i){const r={};for(const n in e)t.call(this,e[n],n,e)&&(r[n]=e[n]);return r}function Xe(e){return Array.isArray(e)?e.map(Xe):"object"==typeof e&&e?Ze(e,Xe):e}function Ye(e,t){for(let i=0;i<e.length;i++)if(t.includes(e[i]))return!0;return!1}const Je={};function Ke(e){Je[e]||("undefined"!=typeof console&&console.warn(e),Je[e]=!0)}function Qe(e,t,i){return(i.y-e.y)*(t.x-e.x)>(t.y-e.y)*(i.x-e.x)}function et(e){let t=0;for(let i,r,n=0,o=e.length,s=o-1;n<o;s=n++)i=e[n],r=e[s],t+=(r.x-i.x)*(i.y+r.y);return t}function tt([e,t,i]){const r=Re(t+90),n=Re(i);return{x:e*Math.cos(r)*Math.sin(n),y:e*Math.sin(r)*Math.sin(n),z:e*Math.cos(n),azimuthal:t,polar:i}}function it(e){return("undefined"!=typeof self||void 0!==e)&&"undefined"!=typeof WorkerGlobalScope&&(void 0!==e?e:self)instanceof WorkerGlobalScope}function rt(e){const t={};if(e.replace(/(?:^|(?:\s*\,\s*))([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g,(e,i,r,n)=>{const o=r||n;return t[i]=!o||o.toLowerCase(),""}),t["max-age"]){const e=parseInt(t["max-age"],10);isNaN(e)?delete t["max-age"]:t["max-age"]=e}return t}let nt,ot=null;function st(e,t){return[e[4*t],e[4*t+1],e[4*t+2],e[4*t+3]]}function at(e,t,i,r){for(;t<i;){const n=t+i>>1;e[n]<r?t=n+1:i=n}return t}function lt(e,t,i,r){for(;t<i;){const n=t+i>>1;e[n]<=r?t=n+1:i=n}return t}function ct(e){return e>0?1/(1.001-e):1+e}function ht(e){return e>0?1-1/(1.001-e):-e}function ut(e,t,i){return(e-t.min)*(i.max-i.min)/(t.max-t.min)+i.min}const dt={API_URL:"https://api.mapbox.com",API_URL_REGEX:/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/|\?|$)/i,API_TILEJSON_REGEX:/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/v[0-9]*\/.*\.json.*$)/i,API_SPRITE_REGEX:/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/styles\/v[0-9]*\/)(.*\/sprite.*\..*$)/i,API_FONTS_REGEX:/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/fonts\/v[0-9]*\/)(.*\.pbf.*$)/i,API_STYLE_REGEX:/^((https?:)?\/\/)?([^\/]+\.)?mapbox\.c(n|om)(\/styles\/v[0-9]*\/)(.*$)/i,API_CDN_URL_REGEX:/^((https?:)?\/\/)?api\.mapbox\.c(n|om)(\/mapbox-gl-js\/)(.*$)/i,get EVENTS_URL(){if(!dt.API_URL)return null;try{const e=new URL(dt.API_URL);return"api.mapbox.cn"===e.hostname?"https://events.mapbox.cn/events/v2":"api.mapbox.com"===e.hostname?"https://events.mapbox.com/events/v2":null}catch(e){return null}},SESSION_PATH:"/map-sessions/v1",FEEDBACK_URL:"https://apps.mapbox.com/feedback",TILE_URL_VERSION:"v4",RASTER_URL_PREFIX:"raster/v1",RASTERARRAYS_URL_PREFIX:"rasterarrays/v1",REQUIRE_ACCESS_TOKEN:!0,ACCESS_TOKEN:null,DEFAULT_STYLE:"mapbox://styles/mapbox/standard",MAX_PARALLEL_IMAGE_REQUESTS:16,DRACO_URL:"/mapbox-gl-js/draco_decoder_gltf_v1.5.6.wasm",MESHOPT_URL:"/mapbox-gl-js/meshopt_base_v0.20.wasm",MESHOPT_SIMD_URL:"/mapbox-gl-js/meshopt_simd_v0.20.wasm",BUILDING_GEN_URL:"/mapbox-gl-js/building-gen/building_gen_v1.2.4.wasm",GLYPHS_URL:"mapbox://fonts/mapbox/{fontstack}/{range}.pbf",TILES3D_URL_PREFIX:"3dtiles/v1",TILE_PROVIDER_URLS:Object.assign(Object.create(null),{pmtiles:"/mapbox-gl-js/plugins/mapbox-gl-pmtiles-provider/v0.0.2/mapbox-gl-pmtiles-provider.js"})};function pt(){return new URL(dt.DRACO_URL,dt.API_URL).href}function ft(){if("object"!=typeof WebAssembly)throw new Error("WebAssembly not supported, cannot instantiate meshoptimizer");return new URL(function(){if(void 0===nt){if("object"!=typeof WebAssembly)return!1;const e=new Uint8Array([0,97,115,109,1,0,0,0,1,4,1,96,0,0,3,3,2,0,0,5,3,1,0,1,12,1,0,10,22,2,12,0,65,0,65,0,65,0,252,10,0,0,11,7,0,65,0,253,15,26,11]);nt=WebAssembly.validate(e)}return nt}()?dt.MESHOPT_SIMD_URL:dt.MESHOPT_URL,dt.API_URL).href}function mt(){return new URL(dt.BUILDING_GEN_URL,dt.API_URL).href}function _t(e){return dt.API_URL_REGEX.test(e)}function gt(e){return dt.API_SPRITE_REGEX.test(e)}let yt,xt,vt,bt,wt,Tt;function St(){return yt??=self.OffscreenCanvas&&new OffscreenCanvas(1,1).getContext("2d")&&"function"==typeof self.createImageBitmap,yt}const It={requestIdleCallback:e=>{if("undefined"!=typeof requestIdleCallback)return requestIdleCallback(e);setTimeout(()=>e({didTimeout:!1,timeRemaining:()=>50}),0)},now:()=>void 0!==bt?bt:performance.now(),setNow(e){bt=e},restoreNow(){bt=void 0},frame(e){const t=requestAnimationFrame(e);return{cancel:()=>cancelAnimationFrame(t)}},getImageData(e,t=0){const{width:i,height:r}=e;wt||(wt=document.createElement("canvas"));const n=wt.getContext("2d",{willReadFrequently:!0});if(!n)throw new Error("failed to create canvas 2d context");return(i>wt.width||r>wt.height)&&(wt.width=i,wt.height=r),n.clearRect(-t,-t,i+2*t,r+2*t),n.drawImage(e,0,0,i,r),n.getImageData(-t,-t,i+2*t,r+2*t)},resolveURL:e=>(xt||(xt=document.createElement("a")),xt.href=e,xt.href),get devicePixelRatio(){return window.devicePixelRatio},get prefersReducedMotion(){return!!window.matchMedia&&(vt??=window.matchMedia("(prefers-reduced-motion: reduce)"),vt.matches)},hasCanvasFingerprintNoise(){if(void 0!==Tt)return Tt;if(!St())return Tt=!1,!1;const e=new OffscreenCanvas(85,1),t=e.getContext("2d",{willReadFrequently:!0});let i=0;for(let n=0;n<e.width;++n)t.fillStyle=`rgba(${i++},${i++},${i++}, 255)`,t.fillRect(n,0,1,1);const r=t.getImageData(0,0,e.width,e.height);i=0;for(let n=0;n<r.data.length;++n)if(n%4!=3&&i++!==r.data[n])return Tt=!0,!0;return Tt=!1,!1}};function Et(e,t){const i=e.indexOf("?");if(i<0)return`${e}?${new URLSearchParams(t).toString()}`;const r=new URLSearchParams(e.slice(i));for(const n in t)r.set(n,t[n]);return`${e.slice(0,i)}?${r.toString()}`}function At(e,t={persistentParams:[]}){const i=e.indexOf("?");if(i<0)return e;const r=new URLSearchParams,n=new URLSearchParams(e.slice(i));for(const s of t.persistentParams){const e=n.get(s);e&&r.set(s,e)}const o=r.toString();return`${e.slice(0,i)}${o.length>0?`?${o}`:""}`}const Mt="mapbox-tiles";let Ct=500,Pt=50;const Dt=["language","worldview","jobid"];let Rt;function zt(){try{return caches}catch(e){}}function Lt(){const e=zt();e&&null==Rt&&(Rt=e.open(Mt))}let Ft=1/0;const Ot={supported:!1,testSupport:function(e){!Nt&&kt&&(Ut?jt(e):Bt=e)}};let Bt,kt,Nt=!1,Ut=!1;const Vt="undefined"!=typeof self?self:{};function jt(e){const t=e.createTexture();e.bindTexture(e.TEXTURE_2D,t);try{if(e.texImage2D(e.TEXTURE_2D,0,e.RGBA,e.RGBA,e.UNSIGNED_BYTE,kt),e.isContextLost())return;Ot.supported=!0}catch(e){}e.deleteTexture(t),Nt=!0}Vt.document&&(kt=Vt.document.createElement("img"),kt.onload=function(){Bt&&jt(Bt),Bt=null,Ut=!0},kt.onerror=function(){Nt=!0,Bt=null},kt.src="data:image/webp;base64,UklGRh4AAABXRUJQVlA4TBEAAAAvAQAAAAfQ//73v/+BiOh/AAA=");const Gt={Unknown:"Unknown",Style:"Style",Source:"Source",Tile:"Tile",Glyphs:"Glyphs",SpriteImage:"SpriteImage",SpriteJSON:"SpriteJSON",Iconset:"Iconset",Image:"Image",Model:"Model"};Object.freeze(Gt);class Ht extends Error{constructor(e,t,i){401===t&&_t(i)&&(e+=": you may have provided an invalid Mapbox access token. See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes"),super(e),this.status=t,this.url=i}toString(){return`${this.name}: ${this.message} (${this.status}): ${this.url}`}}function $t(e){return"object"==typeof e&&null!==e&&"status"in e&&404===e.status}const qt=it()?()=>self.worker.referrer:()=>("blob:"===location.protocol?parent:self).location.href,Zt=/^\w+:/,Wt=/[\r\n]+/,Xt=function(e,t){return(i=e.url).startsWith("file:")||qt().startsWith("file:")&&!Zt.test(i)?function(e,t){const i=new XMLHttpRequest;i.open(e.method||"GET",e.url,!0),"arrayBuffer"===e.type&&(i.responseType="arraybuffer");for(const r in e.headers)i.setRequestHeader(r,e.headers[r]);return"json"===e.type&&(i.responseType="text",i.setRequestHeader("Accept","application/json")),i.withCredentials="include"===e.credentials,i.onerror=()=>{t(new Error(i.statusText))},i.onload=()=>{if((i.status>=200&&i.status<300||0===i.status)&&null!==i.response){let r=i.response;if("json"===e.type)try{r=JSON.parse(i.response)}catch(e){return t(e)}const n=new Headers;i.getAllResponseHeaders().trim().split(Wt).forEach(e=>{const t=e.split(": "),i=t.shift(),r=t.join(": ");n.append(i,r)}),t(null,r,n)}else t(new Ht(i.statusText,i.status,e.url))},i.send(e.body),{cancel:()=>i.abort()}}(e,t):function(e,t){const i=new AbortController,r=new Request(e.url,{method:e.method||"GET",body:e.body,credentials:e.credentials,headers:e.headers,referrer:qt(),referrerPolicy:e.referrerPolicy,signal:i.signal});let n=!1,o=!1;const s=(a=r.url).indexOf("sku=")>0&&_t(a);var a;"json"===e.type&&r.headers.set("Accept","application/json");const l=(i,n,a)=>{if(o)return;if(i&&"SecurityError"!==i.message&&Ke(i.toString()),n&&a)return c(n);const l=Date.now();fetch(r).then(i=>i.ok?c(i,s?i.clone():null,l):t(new Ht(i.statusText,i.status,e.url))).catch(i=>{"AbortError"!==i.name&&t(/* @__PURE__ */new Error(`${i.message} ${e.url}`))})},c=(i,s,a)=>{("arrayBuffer"===e.type?i.arrayBuffer():"json"===e.type?i.json():i.text()).then(e=>{o||(s&&a&&function(e,t,i){if(Lt(),null==Rt)return;const r=rt(t.headers.get("cache-control")||"");if(r["no-store"])return;const n={status:t.status,statusText:t.statusText,headers:new Headers};t.headers.forEach((e,t)=>n.headers.set(t,e)),r["max-age"]&&n.headers.set("Expires",new Date(i+1e3*r["max-age"]).toUTCString());const o=n.headers.get("expires");if(!o)return;if(new Date(o).getTime()-i<42e4)return;let s=At(e.url,{persistentParams:Dt});if(206===t.status){const t=e.headers.get("Range");if(!t)return;n.status=200,s=Et(s,{range:t})}const a=new Response(200!==(l=t.status)&&404!==l&&[101,103,204,205,304].includes(l)?null:t.body,n);var l;Lt(),Rt?.then(e=>e.put(s,a)).catch(e=>Ke(e.message))}(r,s,a),n=!0,t(null,e,i.headers))}).catch(e=>{o||t(new Error(e.message))})};return s?function(e,t){if(Lt(),null==Rt)return t(null);Rt.then(i=>{let r=At(e.url,{persistentParams:Dt});const n=e.headers.get("Range");n&&(r=Et(r,{range:n})),i.match(r).then(e=>{const n=function(e){if(!e)return!1;const t=new Date(e.headers.get("expires")||0),i=rt(e.headers.get("cache-control")||"");return Number(t)>Date.now()&&!i["no-cache"]}(e);i.delete(r).catch(t),n&&i.put(r,e.clone()).catch(t),t(null,e,n)}).catch(t)}).catch(t)}(r,l):l(null,null),{cancel:()=>{o=!0,n||i.abort()}}}(e,t);var i},Yt=function(e,t){return Xt(Object.assign(e,{type:"json"}),t)},Jt=function(e,t){return Xt(Object.assign(e,{type:"arrayBuffer"}),t)};function Kt(e){const t=document.createElement("a");return t.href=e,t.protocol===location.protocol&&t.host===location.host}let Qt,ei;Qt=[],ei=0;const ti=function(e,t){if(Ot.supported&&(e.headers||(e.headers={}),e.headers.accept="image/webp,*/*"),ei>=dt.MAX_PARALLEL_IMAGE_REQUESTS){const i={requestParameters:e,callback:t,cancelled:!1,cancel(){this.cancelled=!0}};return Qt.push(i),i}ei++;let i=!1;const r=()=>{if(!i)for(i=!0,ei--;Qt.length&&ei<dt.MAX_PARALLEL_IMAGE_REQUESTS;){const e=Qt.shift(),{requestParameters:t,callback:i,cancelled:r}=e;r||(e.cancel=ti(t,i).cancel)}},n=Jt(e,(e,i,n)=>{r(),e?t(e):i&&function(e,t){const i=new Blob([new Uint8Array(e)],{type:"image/png"});createImageBitmap(i).then(e=>{t(null,e)}).catch(e=>{t(/* @__PURE__ */new Error(`Could not load image because of ${e.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`))})}(i,(e,i)=>t(e,i,n))});return{cancel:()=>{n.cancel(),r()}}};var ii,ri,ni,oi={exports:{}},si={exports:{}},ai={exports:{}},li=Te(function(){if(ni)return oi.exports;ni=1;var e=(ii||(ii=1,si.exports=function(e,t){var i,r,n,o,s,a,l,c;for(r=e.length-(i=3&e.length),n=t,s=3432918353,a=461845907,c=0;c<r;)l=255&e.charCodeAt(c)|(255&e.charCodeAt(++c))<<8|(255&e.charCodeAt(++c))<<16|(255&e.charCodeAt(++c))<<24,++c,n=27492+(65535&(o=5*(65535&(n=(n^=l=(65535&(l=(l=(65535&l)*s+(((l>>>16)*s&65535)<<16)&4294967295)<<15|l>>>17))*a+(((l>>>16)*a&65535)<<16)&4294967295)<<13|n>>>19))+((5*(n>>>16)&65535)<<16)&4294967295))+(((o>>>16)+58964&65535)<<16);switch(l=0,i){case 3:l^=(255&e.charCodeAt(c+2))<<16;case 2:l^=(255&e.charCodeAt(c+1))<<8;case 1:n^=l=(65535&(l=(l=(65535&(l^=255&e.charCodeAt(c)))*s+(((l>>>16)*s&65535)<<16)&4294967295)<<15|l>>>17))*a+(((l>>>16)*a&65535)<<16)&4294967295}return n^=e.length,n=2246822507*(65535&(n^=n>>>16))+((2246822507*(n>>>16)&65535)<<16)&4294967295,n=3266489909*(65535&(n^=n>>>13))+((3266489909*(n>>>16)&65535)<<16)&4294967295,(n^=n>>>16)>>>0}),si.exports),t=(ri||(ri=1,ai.exports=function(e,t){for(var i,r=e.length,n=t^r,o=0;r>=4;)i=1540483477*(65535&(i=255&e.charCodeAt(o)|(255&e.charCodeAt(++o))<<8|(255&e.charCodeAt(++o))<<16|(255&e.charCodeAt(++o))<<24))+((1540483477*(i>>>16)&65535)<<16),n=1540483477*(65535&n)+((1540483477*(n>>>16)&65535)<<16)^(i=1540483477*(65535&(i^=i>>>24))+((1540483477*(i>>>16)&65535)<<16)),r-=4,++o;switch(r){case 3:n^=(255&e.charCodeAt(o+2))<<16;case 2:n^=(255&e.charCodeAt(o+1))<<8;case 1:n=1540483477*(65535&(n^=255&e.charCodeAt(o)))+((1540483477*(n>>>16)&65535)<<16)}return n=1540483477*(65535&(n^=n>>>13))+((1540483477*(n>>>16)&65535)<<16),(n^=n>>>15)>>>0}),ai.exports);return oi.exports=e,oi.exports.murmur3=e,oi.exports.murmur2=t,oi.exports}());class ci{constructor(e,...t){Object.assign(this,t[0]||{}),this.type=e}}class hi extends ci{constructor(e,t={}){super("error",Object.assign({error:e},t))}}function ui(e,t,i){i[e]&&i[e].includes(t)||(i[e]=i[e]||[],i[e].push(t))}function di(e,t,i){if(i&&i[e]){const r=i[e].indexOf(t);-1!==r&&i[e].splice(r,1)}}class pi{on(e,t){return this._listeners=this._listeners||{},ui(e,t,this._listeners),this}off(e,t){return di(e,t,this._listeners),di(e,t,this._oneTimeListeners),this}once(e,t){return t?(this._oneTimeListeners=this._oneTimeListeners||{},ui(e,t,this._oneTimeListeners),this):new Promise(t=>{this.once(e,t)})}fire(e,t){const i="string"==typeof e?new ci(e,t):e,r=i.type;if(this.listens(r)){i.target=this;const e=this._listeners&&this._listeners[r]?this._listeners[r].slice():[];for(const r of e)r.call(this,i);const t=this._oneTimeListeners&&this._oneTimeListeners[r]?this._oneTimeListeners[r].slice():[];for(const o of t)di(r,o,this._oneTimeListeners),o.call(this,i);const n=this._eventedParent;if(n){const e="function"==typeof this._eventedParentData?this._eventedParentData():this._eventedParentData;Object.assign(i,e),n.fire(i)}}else i instanceof hi&&console.error(i.error);return this}listens(e){return!!(this._listeners&&this._listeners[e]&&this._listeners[e].length>0||this._oneTimeListeners&&this._oneTimeListeners[e]&&this._oneTimeListeners[e].length>0||this._eventedParent&&this._eventedParent.listens(e))}setEventedParent(e,t){return this._eventedParent=e,this._eventedParentData=t,this}}class fi{constructor(e){"string"==typeof e?this.name=e:(this.name=e.name,this.iconsetId=e.iconsetId)}static from(e){return new fi(e)}static toString(e){return e.iconsetId?`${e.name}${e.iconsetId}`:e.name}static parse(e){const[t,i]=e.split("");return new fi({name:t,iconsetId:i})}static isEqual(e,t){return e.name===t.name&&e.iconsetId===t.iconsetId}toString(){return fi.toString(this)}serialize(){return{name:this.name,iconsetId:this.iconsetId}}}var mi,_i={},gi=function(){if(mi)return _i;mi=1;var e={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 t(e){return(e=Math.round(e))<0?0:e>255?255:e}function i(e){return t("%"===e[e.length-1]?parseFloat(e)/100*255:parseInt(e))}function r(e){return(t="%"===e[e.length-1]?parseFloat(e)/100:parseFloat(e))<0?0:t>1?1:t;var t}function n(e,t,i){return i<0?i+=1:i>1&&(i-=1),6*i<1?e+(t-e)*i*6:2*i<1?t:3*i<2?e+(t-e)*(2/3-i)*6:e}try{_i.parseCSSColor=function(o){var s,a=o.replace(/ /g,"").toLowerCase();if(a in e)return e[a].slice();if("#"===a[0])return 4===a.length?(s=parseInt(a.substr(1),16))>=0&&s<=4095?[(3840&s)>>4|(3840&s)>>8,240&s|(240&s)>>4,15&s|(15&s)<<4,1]:null:7===a.length&&(s=parseInt(a.substr(1),16))>=0&&s<=16777215?[(16711680&s)>>16,(65280&s)>>8,255&s,1]:null;var l=a.indexOf("("),c=a.indexOf(")");if(-1!==l&&c+1===a.length){var h=a.substr(0,l),u=a.substr(l+1,c-(l+1)).split(","),d=1;switch(h){case"rgba":if(4!==u.length)return null;d=r(u.pop());case"rgb":return 3!==u.length?null:[i(u[0]),i(u[1]),i(u[2]),d];case"hsla":if(4!==u.length)return null;d=r(u.pop());case"hsl":if(3!==u.length)return null;var p=(parseFloat(u[0])%360+360)%360/360,f=r(u[1]),m=r(u[2]),_=m<=.5?m*(f+1):m+f-m*f,g=2*m-_;return[t(255*n(g,_,p+1/3)),t(255*n(g,_,p)),t(255*n(g,_,p-1/3)),d];default:return null}}return null}}catch(e){}return _i}();function yi(e,t,i){return e*(1-i)+t*i}class xi{constructor(e,t,i,r=1){this.r=e,this.g=t,this.b=i,this.a=r}static parse(e){if(!e)return;if(e instanceof xi)return e;if("string"!=typeof e)return;const t=gi.parseCSSColor(e);return t?new xi(t[0]/255,t[1]/255,t[2]/255,t[3]):void 0}toString(){const{r:e,g:t,b:i,a:r}=this;return`rgba(${Math.round(255*e)},${Math.round(255*t)},${Math.round(255*i)},${r})`}toNonPremultipliedRenderColor(e){const{r:t,g:i,b:r,a:n}=this;return new bi(e,t,i,r,n)}toPremultipliedRenderColor(e){const{r:t,g:i,b:r,a:n}=this;return new wi(e,t*n,i*n,r*n,n)}clone(){return new xi(this.r,this.g,this.b,this.a)}}class vi{constructor(e,t,i,r,n,o=!1){if(this.premultiplied=!1,this.premultiplied=o,e){const o=e.image.height,s=o*o;this.premultiplied?(t=0===n?0:t/n*(o-1),i=0===n?0:i/n*(o-1),r=0===n?0:r/n*(o-1)):(t*=o-1,i*=o-1,r*=o-1),t=Math.max(0,Math.min(o-1,t)),i=Math.max(0,Math.min(o-1,i)),r=Math.max(0,Math.min(o-1,r));const a=Math.floor(t),l=Math.floor(i),c=Math.floor(r),h=Math.ceil(t),u=Math.ceil(i),d=Math.ceil(r),p=t-a,f=i-l,m=r-c,_=e.image.data,g=4*(a+l*s+c*o),y=4*(a+l*s+d*o),x=4*(a+u*s+c*o),v=4*(a+u*s+d*o),b=4*(h+l*s+c*o),w=4*(h+l*s+d*o),T=4*(h+u*s+c*o),S=4*(h+u*s+d*o);this.r=yi(yi(yi(_[g],_[y],m),yi(_[x],_[v],m),f),yi(yi(_[b],_[w],m),yi(_[T],_[S],m),f),p)/255*(this.premultiplied?n:1),this.g=yi(yi(yi(_[g+1],_[y+1],m),yi(_[x+1],_[v+1],m),f),yi(yi(_[b+1],_[w+1],m),yi(_[T+1],_[S+1],m),f),p)/255*(this.premultiplied?n:1),this.b=yi(yi(yi(_[g+2],_[y+2],m),yi(_[x+2],_[v+2],m),f),yi(yi(_[b+2],_[w+2],m),yi(_[T+2],_[S+2],m),f),p)/255*(this.premultiplied?n:1),this.a=n}else this.r=t,this.g=i,this.b=r,this.a=n}toArray(){const{r:e,g:t,b:i,a:r}=this;return[255*e,255*t,255*i,r]}toHslaArray(){let{r:e,g:t,b:i,a:r}=this;if(this.premultiplied){if(0===r)return[0,0,0,0];const n=1/r;e*=n,t*=n,i*=n}const n=Math.min(Math.max(e,0),1),o=Math.min(Math.max(t,0),1),s=Math.min(Math.max(i,0),1),a=Math.min(n,o,s),l=Math.max(n,o,s),c=l-a,h=.5*(a+l);if(0===c)return[0,0,100*h,r];const u=h>.5?c/(2-l-a):c/(l+a);let d;switch(l){case n:d=60*((o-s)/c+(o<s?6:0));break;case o:d=60*((s-n)/c+2);break;default:d=60*((n-o)/c+4)}return[d,100*u,100*h,r]}toArray01(){const{r:e,g:t,b:i,a:r}=this;return[e,t,i,r]}toArray01Scaled(e){const{r:t,g:i,b:r}=this;return[t*e,i*e,r*e]}toArray01Linear(){const{r:e,g:t,b:i,a:r}=this;return[Math.pow(e,2.2),Math.pow(t,2.2),Math.pow(i,2.2),r]}}class bi extends vi{constructor(e,t,i,r,n){super(e,t,i,r,n,!1)}}class wi extends vi{constructor(e,t,i,r,n){super(e,t,i,r,n,!0)}}function Ti(e,t,i){return e.map((e,r)=>yi(e,t[r],i))}xi.black=new xi(0,0,0,1),xi.white=new xi(1,1,1,1),xi.transparent=new xi(0,0,0,0),xi.red=new xi(1,0,0,1),xi.blue=new xi(0,0,1,1);var Si=Object.freeze({__proto__:null,array:Ti,color:function(e,t,i){return new xi(yi(e.r,t.r,i),yi(e.g,t.g,i),yi(e.b,t.b,i),yi(e.a,t.a,i))},number:yi});class Ii extends Error{constructor(e,t){super(t),this.message=t,this.key=e}}class Ei{constructor(e,t=[]){this.parent=e,this.bindings={};for(const[i,r]of t)this.bindings[i]=r}concat(e){return new Ei(this,e)}get(e){if(this.bindings[e])return this.bindings[e];if(this.parent)return this.parent.get(e);throw new Error(`${e} not found in scope.`)}has(e){return!!this.bindings[e]||!!this.parent&&this.parent.has(e)}}const Ai={kind:"null"},Mi={kind:"number"},Ci={kind:"string"},Pi={kind:"boolean"},Di={kind:"color"},Ri={kind:"object"},zi={kind:"value"},Li={kind:"collator"},Fi={kind:"formatted"},Oi={kind:"resolvedImage"};function Bi(e,t){return{kind:"array",itemType:e,N:t}}function ki(e){if("array"===e.kind){const t=ki(e.itemType);return"number"==typeof e.N?`array<${t}, ${e.N}>`:"value"===e.itemType.kind?"array":`array<${t}>`}return e.kind}const Ni=[Ai,Mi,Ci,Pi,Di,Fi,Ri,Bi(zi),Oi];function Ui(e,t){if("error"===t.kind)return null;if("array"===e.kind){if("array"===t.kind&&(0===t.N&&"value"===t.itemType.kind||!Ui(e.itemType,t.itemType))&&("number"!=typeof e.N||e.N===t.N))return null}else{if(e.kind===t.kind)return null;if("value"===e.kind)for(const e of Ni)if(!Ui(e,t))return null}return`Expected ${ki(e)} but found ${ki(t)} instead.`}function Vi(e,t){return t.some(t=>t.kind===e.kind)}function ji(e,t){return t.some(t=>"null"===t?null===e:"array"===t?Array.isArray(e):"object"===t?e&&!Array.isArray(e)&&"object"==typeof e:t===typeof e)}function Gi(e,t){return"array"===e.kind&&"array"===t.kind?e.N===t.N&&Gi(e.itemType,t.itemType):e.kind===t.kind}class Hi{constructor(e,t,i){this.sensitivity=e?t?"variant":"case":t?"accent":"base",this.locale=i,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})}compare(e,t){return this.collator.compare(e,t)}resolvedLocale(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale}}class $i{constructor(e,t,i,r,n){this.text=e.normalize?e.normalize():e,this.image=t,this.scale=i,this.fontStack=r,this.textColor=n}}class qi{constructor(e){this.sections=e}static fromString(e){return new qi([new $i(e,null,null,null,null)])}isEmpty(){return 0===this.sections.length||!this.sections.some(e=>0!==e.text.length||!!e.image&&e.image.hasPrimary())}static factory(e){return e instanceof qi?e:qi.fromString(e)}toString(){return 0===this.sections.length?"":this.sections.map(e=>e.text).join("")}serialize(){const e=["format"];for(const t of this.sections){if(t.image){const i=t.image.getPrimary().id.toString();e.push(["image",i]);continue}e.push(t.text);const i={};t.fontStack&&(i["text-font"]=["literal",t.fontStack.split(",")]),t.scale&&(i["font-scale"]=t.scale),t.textColor&&(i["text-color"]=["rgba"].concat(t.textColor.toNonPremultipliedRenderColor(null).toArray())),e.push(i)}return e}}class Zi{constructor(e,t={}){this.id=fi.from(e),this.params=t.params,this.sx=t.sx||1,this.sy=t.sy||1}toString(){return JSON.stringify(this)}static parse(e){let t,i,r,n;try{({id:t,params:i,sx:r,sy:n}=JSON.parse(e)||{})}catch(e){return null}return t?new Zi(t,{params:i,sx:r,sy:n}):null}scaleSelf(e,t=e){return this.sx*=e,this.sy*=t,this}}class Wi{constructor(e,t,i,r,n=!1){this.primaryId=fi.from(e),this.primaryOptions=t,i&&(this.secondaryId=fi.from(i)),this.secondaryOptions=r,this.available=n}toString(){return this.primaryId&&this.secondaryId?`[${this.primaryId.name},${this.secondaryId.name}]`:this.primaryId.name}hasPrimary(){return!!this.primaryId}getPrimary(){return new Zi(this.primaryId,this.primaryOptions)}hasSecondary(){return!!this.secondaryId}getSecondary(){return this.secondaryId?new Zi(this.secondaryId,this.secondaryOptions):null}static from(e){return"string"==typeof e?Wi.build({name:e}):e}static build(e,t,i,r){return!e||"object"==typeof e&&!("name"in e)?null:new Wi(e,i,t,r)}}function Xi(e,t,i,r){return"number"==typeof e&&e>=0&&e<=255&&"number"==typeof t&&t>=0&&t<=255&&"number"==typeof i&&i>=0&&i<=255?void 0===r||"number"==typeof r&&r>=0&&r<=1?null:`Invalid rgba value [${[e,t,i,r].join(", ")}]: 'a' must be between 0 and 1.`:`Invalid rgba value [${("number"==typeof r?[e,t,i,r]:[e,t,i]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.`}function Yi(e){if(null===e)return!0;if("string"==typeof e)return!0;if("boolean"==typeof e)return!0;if("number"==typeof e)return!0;if(e instanceof xi)return!0;if(e instanceof Hi)return!0;if(e instanceof qi)return!0;if(e instanceof Wi)return!0;if(Array.isArray(e)){for(const t of e)if(!Yi(t))return!1;return!0}if("object"==typeof e){for(const t in e)if(!Yi(e[t]))return!1;return!0}return!1}function Ji(e){if(null===e)return Ai;if("string"==typeof e)return Ci;if("boolean"==typeof e)return Pi;if("number"==typeof e)return Mi;if(e instanceof xi)return Di;if(e instanceof Hi)return Li;if(e instanceof qi)return Fi;if(e instanceof Wi)return Oi;if(Array.isArray(e)){const t=e.length;let i;for(const r of e){const e=Ji(r);if(i){if(i===e)continue;i=zi;break}i=e}return Bi(i||zi,t)}return Ri}function Ki(e){const t=typeof e;return null===e?"":"string"===t||"number"===t||"boolean"===t?String(e):e instanceof qi||e instanceof Wi||e instanceof xi?e.toString():JSON.stringify(e)}class Qi{constructor(e,t){this.type=e,this.value=t}static parse(e,t){if(2!==e.length)return t.error(`'literal' expression requires exactly one argument, but found ${e.length-1} instead.`);if(!Yi(e[1]))return t.error("invalid value");const i=e[1];let r=Ji(i);const n=t.expectedType;return"array"!==r.kind||0!==r.N||!n||"array"!==n.kind||"number"==typeof n.N&&0!==n.N||(r=n),new Qi(r,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 xi?["rgba"].concat(this.value.toNonPremultipliedRenderColor(null).toArray()):this.value instanceof qi?this.value.serialize():this.value}}class er{constructor(e){this.name="ExpressionEvaluationError",this.message=e}toJSON(){return this.message}}const tr={string:Ci,number:Mi,boolean:Pi,object:Ri};class ir{constructor(e,t){this.type=e,this.args=t}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");let i,r=1;const n=e[0];if("array"===n){let n,o;if(e.length>2){const i=e[1];if("string"!=typeof i||!(i in tr)||"object"===i)return t.error('The item type argument of "array" must be one of string, number, boolean',1);n=tr[i],r++}else n=zi;if(e.length>3){if(null!==e[2]&&("number"!=typeof e[2]||e[2]<0||e[2]!==Math.floor(e[2])))return t.error('The length argument to "array" must be a positive integer literal',2);o=e[2],r++}i=Bi(n,o)}else i=tr[n];const o=[];for(;r<e.length;r++){const i=t.parse(e[r],r,zi);if(!i)return null;o.push(i)}return new ir(i,o)}evaluate(e){for(let t=0;t<this.args.length;t++){const i=this.args[t].evaluate(e);if(!Ui(this.type,Ji(i)))return i;if(t===this.args.length-1)throw new er(`The expression ${JSON.stringify(this.args[t].serialize())} evaluated to ${ki(Ji(i))} but was expected to be of type ${ki(this.type)}.`)}return null}eachChild(e){this.args.forEach(e)}outputDefined(){return this.args.every(e=>e.outputDefined())}serialize(){const e=this.type,t=[e.kind];if("array"===e.kind){const i=e.itemType;if("string"===i.kind||"number"===i.kind||"boolean"===i.kind){t.push(i.kind);const r=e.N;("number"==typeof r||this.args.length>1)&&t.push(r)}}return t.concat(this.args.map(e=>e.serialize()))}}class rr{constructor(e){this.type=Fi,this.sections=e}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");const i=e[1];if(!Array.isArray(i)&&"object"==typeof i)return t.error("First argument must be an image or text section.");const r=[];let n=!1;for(let o=1;o<=e.length-1;++o){const i=e[o];if(n&&"object"==typeof i&&!Array.isArray(i)){n=!1;let e=null;if(i["font-scale"]&&(e=t.parseObjectValue(i["font-scale"],o,"font-scale",Mi),!e))return null;let s=null;if(i["text-font"]&&(s=t.parseObjectValue(i["text-font"],o,"text-font",Bi(Ci)),!s))return null;let a=null;if(i["text-color"]&&(a=t.parseObjectValue(i["text-color"],o,"text-color",Di),!a))return null;const l=r.at(-1);l.scale=e,l.font=s,l.textColor=a}else{const i=t.parse(e[o],o,zi);if(!i)return null;const s=i.type.kind;if("string"!==s&&"value"!==s&&"null"!==s&&"resolvedImage"!==s)return t.error("Formatted text type must be 'string', 'value', 'image' or 'null'.");n=!0,r.push({content:i,scale:null,font:null,textColor:null})}}return new rr(r)}evaluate(e){return new qi(this.sections.map(t=>{const i=t.content.evaluate(e);return Gi(Ji(i),Oi)?new $i("",i,null,null,null):new $i(Ki(i),null,t.scale?t.scale.evaluate(e):null,t.font?t.font.evaluate(e).join(","):null,t.textColor?t.textColor.evaluate(e):null)}))}eachChild(e){for(const t of this.sections)e(t.content),t.scale&&e(t.scale),t.font&&e(t.font),t.textColor&&e(t.textColor)}outputDefined(){return!1}serialize(){const e=["format"];for(const t of this.sections){e.push(t.content.serialize());const i={};t.scale&&(i["font-scale"]=t.scale.serialize()),t.font&&(i["text-font"]=t.font.serialize()),t.textColor&&(i["text-color"]=t.textColor.serialize()),e.push(i)}return e}}class nr{constructor(e,t,i,r){this._imageWarnHistory={},this.type=Oi,this.namePrimary=e,this.nameSecondary=t,i&&(this.paramsPrimary=i.params,this.iconsetIdPrimary=i.iconset?i.iconset.id:void 0),r&&(this.paramsSecondary=r.params,this.iconsetIdSecondary=r.iconset?r.iconset.id:void 0)}static parse(e,t){if(e.length<2)return t.error("Expected two or more arguments.");let i=1;const r=[];function n(){if(i<e.length){const n=t.parse(e[i],i++,Ci);return n?(r.push({image:n,options:{}}),!0):(t.error(r.length?"Secondary image variant is not a string.":"No image name provided."),!1)}return!0}function o(){if(i<e.length){const o=e[i];if(null===(n=o)||"object"!=typeof n||Array.isArray(n))return!0;const s=o.params,a=o.iconset,l=t.concat(i);if(!s&&!a)return i++,!0;if(s){if("object"!=typeof s||s.constructor!==Object)return l.error('Image options "params" should be an object'),!1;const e={},t=l.concat(void 0,"params");for(const i in s){if(!i)return t.error("Image parameter name should be non-empty"),!1;const r=t.concat(void 0,i).parse(s[i],void 0,Di,void 0,{typeAnnotation:"coerce"});if(!r)return!1;e[i]=r}r.at(-1).options.params=e}if(a){if("object"!=typeof a||a.constructor!==Object)return l.error('Image options "iconset" should be an object'),!1;if(!a.id)return l.error('Image options "iconset" should have an "id" property'),!1;r.at(-1).options.iconset=a}return i++,!0}var n;return!0}for(let s=0;s<2;s++)if(!n()||!o())return;return new nr(r[0].image,r[1]?r[1].image:void 0,r[0].options,r[1]?r[1].options:void 0)}evaluateParams(e,t){const i={};if(t){for(const r in t)if(t[r])try{i[r]=t[r].evaluate(e)}catch(e){continue}if(0!==Object.keys(i).length)return{params:i}}}evaluate(e){const t={name:this.namePrimary.evaluate(e),iconsetId:this.iconsetIdPrimary},i=this.nameSecondary?{name:this.nameSecondary.evaluate(e),iconsetId:this.iconsetIdSecondary}:void 0,r=Wi.build(t,i,this.paramsPrimary?this.evaluateParams(e,this.paramsPrimary):void 0,this.paramsSecondary?this.evaluateParams(e,this.paramsSecondary):void 0);if(r&&e.availableImages){const t=r.getPrimary().id;if(r.available=e.availableImages.some(e=>fi.isEqual(e,t)),r.available){const t=r.getSecondary()?r.getSecondary().id:null;t&&(r.available=e.availableImages.some(e=>fi.isEqual(e,t)))}}return r}eachChild(e){if(e(this.namePrimary),this.paramsPrimary)for(const t in this.paramsPrimary)this.paramsPrimary[t]&&e(this.paramsPrimary[t]);if(this.nameSecondary&&(e(this.nameSecondary),this.paramsSecondary))for(const t in this.paramsSecondary)this.paramsSecondary[t]&&e(this.paramsSecondary[t])}outputDefined(){return!1}serializeOptions(e,t){const i={};if(t&&(i.iconset={id:t}),e){i.params={};for(const t in e)e[t]&&(i.params[t]=e[t].serialize())}return Object.keys(i).length>0?i:void 0}serialize(){const e=["image",this.namePrimary.serialize()];if(this.paramsPrimary||this.iconsetIdPrimary){const t=this.serializeOptions(this.paramsPrimary,this.iconsetIdPrimary);t&&e.push(t)}if(this.nameSecondary&&(e.push(this.nameSecondary.serialize()),this.paramsSecondary||this.iconsetIdSecondary)){const t=this.serializeOptions(this.paramsSecondary,this.iconsetIdSecondary);t&&e.push(t)}return e}}function or(e){return ar(e)?"string":lr(e)?"number":cr(e)?"boolean":Array.isArray(e)?"array":null===e?"null":sr(e)?"object":typeof e}function sr(e){return null!=e&&!Array.isArray(e)&&"function"!=typeof e&&!(e instanceof String||e instanceof Number||e instanceof Boolean)&&"object"==typeof e}function ar(e){return"string"==typeof e||e instanceof String}function lr(e){return"number"==typeof e||e instanceof Number}function cr(e){return"boolean"==typeof e||e instanceof Boolean}const hr={"to-boolean":Pi,"to-color":Di,"to-number":Mi,"to-string":Ci};class ur{constructor(e,t){this.type=e,this.args=t}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");const i=e[0],r=[];let n=Ai;if("to-array"===i){if(!Array.isArray(e[1]))return null;const i=e[1].length;if(t.expectedType){if("array"!==t.expectedType.kind)return t.error(`Expected ${t.expectedType.kind} but found array.`);n=Bi(t.expectedType.itemType,i)}else{if(!(i>0&&Yi(e[1][0])))return null;n=Bi(Ji(e[1][0]),i)}for(let o=0;o<i;o++){const i=e[1][o];let s;if(Array.isArray(i))s=t.parse(i,void 0,n.itemType);else{const e=or(i);if(e!==n.itemType.kind)return t.error(`Expected ${n.itemType.kind} but found ${e}.`);s=t.registry.literal.parse(["literal",void 0===i?null:i],t)}if(!s)return null;r.push(s)}}else{if(("to-boolean"===i||"to-string"===i)&&2!==e.length)return t.error("Expected one argument.");n=hr[i];for(let i=1;i<e.length;i++){const n=t.parse(e[i],i,zi);if(!n)return null;r.push(n)}}return new ur(n,r)}evaluate(e){if("boolean"===this.type.kind)return Boolean(this.args[0].evaluate(e));if("color"===this.type.kind){let t,i;for(const r of this.args){if(t=r.evaluate(e),i=null,t instanceof xi)return t;if("string"==typeof t){const i=e.parseColor(t);if(i)return i}else if(Array.isArray(t)&&(i=t.length<3||t.length>4?`Invalid rbga value ${JSON.stringify(t)}: expected an array containing either three or four numeric values.`:Xi(t[0],t[1],t[2],t[3]),!i))return new xi(t[0]/255,t[1]/255,t[2]/255,t[3])}throw new er(i||`Could not parse color from value '${"string"==typeof t?t:String(JSON.stringify(t))}'`)}if("number"===this.type.kind){let t=null;for(const i of this.args){if(t=i.evaluate(e),null===t)return 0;const r=Number(t);if(!isNaN(r))return r}throw new er(`Could not convert ${JSON.stringify(t)} to number.`)}return"formatted"===this.type.kind?qi.fromString(Ki(this.args[0].evaluate(e))):"resolvedImage"===this.type.kind?Wi.build(Ki(this.args[0].evaluate(e))):"array"===this.type.kind?this.args.map(t=>t.evaluate(e)):Ki(this.args[0].evaluate(e))}eachChild(e){this.args.forEach(e)}outputDefined(){return this.args.every(e=>e.outputDefined())}serialize(){if("formatted"===this.type.kind)return new rr([{content:this.args[0],scale:null,font:null,textColor:null}]).serialize();if("resolvedImage"===this.type.kind)return new nr(this.args[0]).serialize();const e="array"===this.type.kind?[]:[`to-${this.type.kind}`];return this.eachChild(t=>{e.push(t.serialize())}),e}}const dr=["Unknown","Point","LineString","Polygon"];class pr{constructor(e,t,i){this.globals=null,this.feature=null,this.featureState=null,this.formattedSection=null,this._parseColorCache={},this.availableImages=null,this.canonical=null,this.featureTileCoord=null,this.featureDistanceData=null,this.scope=e,this.options=t,this.iconImageUseTheme=i}id(){return this.feature&&void 0!==this.feature.id?this.feature.id:null}geometryType(){return this.feature?"number"==typeof this.feature.type?dr[this.feature.type]:this.feature.type:null}geometry(){return this.feature&&"geometry"in this.feature?this.feature.geometry:null}canonicalID(){return this.canonical}properties(){return this.feature&&this.feature.properties||{}}measureLight(e){return this.globals.brightness||0}distanceFromCenter(){if(this.featureTileCoord&&this.featureDistanceData){const e=this.featureDistanceData.center,t=this.featureDistanceData.scale,{x:i,y:r}=this.featureTileCoord;return this.featureDistanceData.bearing[0]*(i*t-e[0])+this.featureDistanceData.bearing[1]*(r*t-e[1])}return 0}parseColor(e){let t=this._parseColorCache[e];return t||(t=this._parseColorCache[e]=xi.parse(e)),t}getConfig(e){return this.options?this.options.get(e):null}}class fr{constructor(e,t,i,r,n){this.name=e,this.type=t,this._evaluate=i,this.args=r,this._overloadIndex=n}evaluate(e){if(!this._evaluate){const e=fr.definitions[this.name];this._evaluate=Array.isArray(e)?e[2]:e.overloads[this._overloadIndex][1]}return this._evaluate(e,this.args)}eachChild(e){this.args.forEach(e)}outputDefined(){return!1}serialize(){return[this.name].concat(this.args.map(e=>e.serialize()))}static parse(e,t){const i=e[0],r=fr.definitions[i];if(!r)return t.error(`Unknown expression "${i}". If you wanted a literal array, use ["literal", [...]].`,0);const n=Array.isArray(r)?r[0]:r.type,o=Array.isArray(r)?[[r[1],r[2]]]:r.overloads,s=[];let a=null,l=-1;for(const[c,h]of o){if(Array.isArray(c)&&c.length!==e.length-1)continue;s.push(c),l++,null===a?a=new Ln(t.registry,t.path,null,t.scope,[],t._scope,t.options,t.iconImageUseTheme):a.errors.length=0;const r=[];let o=!1;for(let t=1;t<e.length;t++){const i=e[t],n=Array.isArray(c)?c[t-1]:c.type,s=a.parse(i,1+r.length,n);if(!s){o=!0;break}r.push(s)}if(!o)if(Array.isArray(c)&&c.length!==r.length)a.error(`Expected ${c.length} arguments, but found ${r.length} instead.`);else{for(let e=0;e<r.length;e++){const t=Array.isArray(c)?c[e]:c.type;a.checkSubtype(t,r[e].type,e+1)}if(0===a.errors.length)return new fr(i,n,h,r,l)}}if(1===s.length)t.errors.push(...a.errors);else{const i=(s.length?s:o.map(([e])=>e)).map(mr).join(" | "),r=[];for(let n=1;n<e.length;n++){const i=t.parse(e[n],1+r.length);if(!i)return null;r.push(ki(i.type))}t.error(`Expected arguments of type ${i}, but found (${r.join(", ")}) instead.`)}return null}static register(e,t){fr.definitions=t;for(const i in t)e[i]=fr}}function mr(e){return Array.isArray(e)?`(${e.map(ki).join(", ")})`:`(${ki(e.type)}...)`}class _r{constructor(e,t,i){this.type=Li,this.locale=i,this.caseSensitive=e,this.diacriticSensitive=t}static parse(e,t){if(2!==e.length)return t.error("Expected one argument."),null;const i=e[1];if("object"!=typeof i||Array.isArray(i))return t.error("Collator options argument must be an object."),null;const r=void 0===i["case-sensitive"]?t.parse(!1,1,Pi):t.parseObjectValue(i["case-sensitive"],1,"case-sensitive",Pi);if(!r)return null;const n=void 0===i["diacritic-sensitive"]?t.parse(!1,1,Pi):t.parseObjectValue(i["diacritic-sensitive"],1,"diacritic-sensitive",Pi);if(!n)return null;let o=null;return i.locale&&(o=t.parseObjectValue(i.locale,1,"locale",Ci),!o)?null:new _r(r,n,o)}evaluate(e){return new Hi(this.caseSensitive.evaluate(e),this.diacriticSensitive.evaluate(e),this.locale?this.locale.evaluate(e):null)}eachChild(e){e(this.caseSensitive),e(this.diacriticSensitive),this.locale&&e(this.locale)}outputDefined(){return!1}serialize(){const e={};return e["case-sensitive"]=this.caseSensitive.serialize(),e["diacritic-sensitive"]=this.diacriticSensitive.serialize(),this.locale&&(e.locale=this.locale.serialize()),["collator",e]}}function gr(e,t,i=0,r=e.length-1,n=xr){for(;r>i;){if(r-i>600){const o=r-i+1,s=t-i+1,a=Math.log(o),l=.5*Math.exp(2*a/3),c=.5*Math.sqrt(a*l*(o-l)/o)*(s-o/2<0?-1:1);gr(e,t,Math.max(i,Math.floor(t-s*l/o+c)),Math.min(r,Math.floor(t+(o-s)*l/o+c)),n)}const o=e[t];let s=i,a=r;for(yr(e,i,t),n(e[r],o)>0&&yr(e,i,r);s<a;){for(yr(e,s,a),s++,a--;n(e[s],o)<0;)s++;for(;n(e[a],o)>0;)a--}0===n(e[i],o)?yr(e,i,a):(a++,yr(e,a,r)),a<=t&&(i=a+1),t<=a&&(r=a-1)}}function yr(e,t,i){const r=e[t];e[t]=e[i],e[i]=r}function xr(e,t){return e<t?-1:e>t?1:0}function vr(e){let t=0;for(let i,r,n=0,o=e.length,s=o-1;n<o;s=n++)i=e[n],r=e[s],t+=(r.x-i.x)*(i.y+r.y);return t}function br(e,t){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 wr(e,t){return!(e[0]<=t[0]||e[2]>=t[2]||e[1]<=t[1]||e[3]>=t[3])}function Tr(e,t,i){const r=e[0]-t[0],n=e[1]-t[1],o=e[0]-i[0],s=e[1]-i[1];return r*s-o*n===0&&r*o<=0&&n*s<=0}function Sr(e,t,i){return t[1]>e[1]!=i[1]>e[1]&&e[0]<(i[0]-t[0])*(e[1]-t[1])/(i[1]-t[1])+t[0]}function Ir(e,t,i=!1){let r=!1;for(let n=0,o=t.length;n<o;n++){const o=t[n];for(let t=0,n=o.length,s=n-1;t<n;s=t++){const n=o[s],a=o[t];if(Tr(e,n,a))return i;Sr(e,n,a)&&(r=!r)}}return r}function Er(e,t,i,r){const n=r[0]-i[0],o=r[1]-i[1],s=(e[0]-i[0])*o-n*(e[1]-i[1]),a=(t[0]-i[0])*o-n*(t[1]-i[1]);return s>0&&a<0||s<0&&a>0}function Ar(e,t,i,r){return 0!==(n=[r[0]-i[0],r[1]-i[1]])[0]*(o=[t[0]-e[0],t[1]-e[1]])[1]-n[1]*o[0]&&!(!Er(e,t,i,r)||!Er(i,r,e,t));var n,o}function Mr(e){const t=new Ie(Number.POSITIVE_INFINITY,Number.POSITIVE_INFINITY),i=new Ie(Number.NEGATIVE_INFINITY,Number.NEGATIVE_INFINITY);for(const r of e[0])t.x>r.x&&(t.x=r.x),t.y>r.y&&(t.y=r.y),i.x<r.x&&(i.x=r.x),i.y<r.y&&(i.y=r.y);return{min:t,max:i}}const Cr=8192;function Pr(e,t){const i=(180+e[0])/360,r=(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+e[1]*Math.PI/360)))/360,n=Math.pow(2,t.z);return[Math.round(i*n*Cr),Math.round(r*n*Cr)]}function Dr(e,t){for(let i=0;i<t.length;i++)if(Ir(e,t[i]))return!0;return!1}function Rr(e,t,i){for(const r of i)for(let i=0,n=r.length,o=n-1;i<n;o=i++)if(Ar(e,t,r[o],r[i]))return!0;return!1}function zr(e,t){for(let i=0;i<e.length;++i)if(!Ir(e[i],t))return!1;for(let i=0;i<e.length-1;++i)if(Rr(e[i],e[i+1],t))return!1;return!0}function Lr(e,t){for(let i=0;i<t.length;i++)if(zr(e,t[i]))return!0;return!1}function Fr(e,t,i){const r=[];for(let n=0;n<e.length;n++){const o=[];for(let r=0;r<e[n].length;r++){const s=Pr(e[n][r],i);br(t,s),o.push(s)}r.push(o)}return r}function Or(e,t,i){const r=[];for(let n=0;n<e.length;n++){const o=Fr(e[n],t,i);r.push(o)}return r}function Br(e,t,i,r){if(e[0]<i[0]||e[0]>i[2]){const t=.5*r;let n=e[0]-i[0]>t?-r:i[0]-e[0]>t?r:0;0===n&&(n=e[0]-i[2]>t?-r:i[2]-e[0]>t?r:0),e[0]+=n}br(t,e)}function kr(e,t,i,r){const n=Math.pow(2,r.z)*Cr,o=[r.x*Cr,r.y*Cr],s=[];if(!e)return s;for(const a of e)for(const e of a){const r=[e.x+o[0],e.y+o[1]];Br(r,t,i,n),s.push(r)}return s}function Nr(e,t,i,r){const n=Math.pow(2,r.z)*Cr,o=[r.x*Cr,r.y*Cr],s=[];if(!e)return s;for(const l of e){const e=[];for(const i of l){const r=[i.x+o[0],i.y+o[1]];br(t,r),e.push(r)}s.push(e)}if(t[2]-t[0]<=n/2){(a=t)[0]=a[1]=1/0,a[2]=a[3]=-1/0;for(const e of s)for(const r of e)Br(r,t,i,n)}var a;return s}class Ur{constructor(e,t){this.type=Pi,this.geojson=e,this.geometries=t}static parse(e,t){if(2!==e.length)return t.error(`'within' expression requires exactly one argument, but found ${e.length-1} instead.`);if(Yi(e[1])){const t=e[1];if("FeatureCollection"===t.type)for(let e=0;e<t.features.length;++e){const i=t.features[e].geometry.type;if("Polygon"===i||"MultiPolygon"===i)return new Ur(t,t.features[e].geometry)}else if("Feature"===t.type){const e=t.geometry.type;if("Polygon"===e||"MultiPolygon"===e)return new Ur(t,t.geometry)}else if("Polygon"===t.type||"MultiPolygon"===t.type)return new Ur(t,t)}return t.error("'within' expression requires valid geojson object that contains polygon geometry type.")}evaluate(e){if(null!=e.geometry()&&null!=e.canonicalID()){if("Point"===e.geometryType())return function(e,t){const i=[1/0,1/0,-1/0,-1/0],r=[1/0,1/0,-1/0,-1/0],n=e.canonicalID();if(!n)return!1;if("Polygon"===t.type){const o=Fr(t.coordinates,r,n),s=kr(e.geometry(),i,r,n);if(!wr(i,r))return!1;for(const e of s)if(!Ir(e,o))return!1}if("MultiPolygon"===t.type){const o=Or(t.coordinates,r,n),s=kr(e.geometry(),i,r,n);if(!wr(i,r))return!1;for(const e of s)if(!Dr(e,o))return!1}return!0}(e,this.geometries);if("LineString"===e.geometryType())return function(e,t){const i=[1/0,1/0,-1/0,-1/0],r=[1/0,1/0,-1/0,-1/0],n=e.canonicalID();if(!n)return!1;if("Polygon"===t.type){const o=Fr(t.coordinates,r,n),s=Nr(e.geometry(),i,r,n);if(!wr(i,r))return!1;for(const e of s)if(!zr(e,o))return!1}if("MultiPolygon"===t.type){const o=Or(t.coordinates,r,n),s=Nr(e.geometry(),i,r,n);if(!wr(i,r))return!1;for(const e of s)if(!Lr(e,o))return!1}return!0}(e,this.geometries)}return!1}eachChild(){}outputDefined(){return!0}serialize(){return["within",this.geojson]}}const Vr={kilometers:1,miles:1e3/1609.344,nauticalmiles:1e3/1852,meters:1e3,metres:1e3,yards:1e3/.9144,feet:1e3/.3048,inches:1e3/.0254},jr=1/298.257223563,Gr=jr*(2-jr),Hr=Math.PI/180;class $r{static fromTile(e,t,i){const r=Math.PI*(1-2*(e+.5)/Math.pow(2,t));return new $r(Math.atan(.5*(Math.exp(r)-Math.exp(-r)))/Hr,i)}static get units(){return Vr}constructor(e,t){if(void 0===e)throw new Error("No latitude given.");if(t&&!Vr[t])throw new Error(`Unknown unit ${t}. Use one of: ${Object.keys(Vr).join(", ")}`);const i=6378.137*Hr*(t?Vr[t]:1),r=Math.cos(e*Hr),n=1/(1-Gr*(1-r*r)),o=Math.sqrt(n);this.kx=i*o*r,this.ky=i*o*n*(1-Gr)}distance(e,t){const i=Wr(e[0]-t[0])*this.kx,r=(e[1]-t[1])*this.ky;return Math.sqrt(i*i+r*r)}bearing(e,t){const i=Wr(t[0]-e[0])*this.kx;return Math.atan2(i,(t[1]-e[1])*this.ky)/Hr}destination(e,t,i){const r=i*Hr;return this.offset(e,Math.sin(r)*t,Math.cos(r)*t)}offset(e,t,i){return[e[0]+t/this.kx,e[1]+i/this.ky]}lineDistance(e){let t=0;for(let i=0;i<e.length-1;i++)t+=this.distance(e[i],e[i+1]);return t}area(e){let t=0;for(let i=0;i<e.length;i++){const r=e[i];for(let e=0,n=r.length,o=n-1;e<n;o=e++)t+=Wr(r[e][0]-r[o][0])*(r[e][1]+r[o][1])*(i?-1:1)}return Math.abs(t)/2*this.kx*this.ky}along(e,t){let i=0;if(t<=0)return e[0];for(let r=0;r<e.length-1;r++){const n=e[r],o=e[r+1],s=this.distance(n,o);if(i+=s,i>t)return Zr(n,o,(t-(i-s))/s)}return e[e.length-1]}pointToSegmentDistance(e,t,i){let[r,n]=t,o=Wr(i[0]-r)*this.kx,s=(i[1]-n)*this.ky;if(0!==o||0!==s){const t=(Wr(e[0]-r)*this.kx*o+(e[1]-n)*this.ky*s)/(o*o+s*s);t>1?(r=i[0],n=i[1]):t>0&&(r+=o/this.kx*t,n+=s/this.ky*t)}return o=Wr(e[0]-r)*this.kx,s=(e[1]-n)*this.ky,Math.sqrt(o*o+s*s)}pointOnLine(e,t){let i=1/0,r=e[0][0],n=e[0][1],o=0,s=0;for(let a=0;a<e.length-1;a++){let l=e[a][0],c=e[a][1],h=Wr(e[a+1][0]-l)*this.kx,u=(e[a+1][1]-c)*this.ky,d=0;0===h&&0===u||(d=(Wr(t[0]-l)*this.kx*h+(t[1]-c)*this.ky*u)/(h*h+u*u),d>1?(l=e[a+1][0],c=e[a+1][1]):d>0&&(l+=h/this.kx*d,c+=u/this.ky*d)),h=Wr(t[0]-l)*this.kx,u=(t[1]-c)*this.ky;const p=h*h+u*u;p<i&&(i=p,r=l,n=c,o=a,s=d)}return{point:[r,n],index:o,t:Math.max(0,Math.min(1,s))}}lineSlice(e,t,i){let r=this.pointOnLine(i,e),n=this.pointOnLine(i,t);if(r.index>n.index||r.index===n.index&&r.t>n.t){const e=r;r=n,n=e}const o=[r.point],s=r.index+1,a=n.index;!qr(i[s],o[0])&&s<=a&&o.push(i[s]);for(let l=s+1;l<=a;l++)o.push(i[l]);return qr(i[a],n.point)||o.push(n.point),o}lineSliceAlong(e,t,i){let r=0;const n=[];for(let o=0;o<i.length-1;o++){const s=i[o],a=i[o+1],l=this.distance(s,a);if(r+=l,r>e&&0===n.length&&n.push(Zr(s,a,(e-(r-l))/l)),r>=t)return n.push(Zr(s,a,(t-(r-l))/l)),n;r>e&&n.push(a)}return n}bufferPoint(e,t){const i=t/this.ky,r=t/this.kx;return[e[0]-r,e[1]-i,e[0]+r,e[1]+i]}bufferBBox(e,t){const i=t/this.ky,r=t/this.kx;return[e[0]-r,e[1]-i,e[2]+r,e[3]+i]}insideBBox(e,t){return Wr(e[0]-t[0])>=0&&Wr(e[0]-t[2])<=0&&e[1]>=t[1]&&e[1]<=t[3]}}function qr(e,t){return e[0]===t[0]&&e[1]===t[1]}function Zr(e,t,i){const r=Wr(t[0]-e[0]);return[e[0]+r*i,e[1]+(t[1]-e[1])*i]}function Wr(e){for(;e<-180;)e+=360;for(;e>180;)e-=360;return e}class Xr{constructor(e=[],t=(e,t)=>e<t?-1:e>t?1:0){if(this.data=e,this.length=this.data.length,this.compare=t,this.length>0)for(let i=(this.length>>1)-1;i>=0;i--)this._down(i)}push(e){this.data.push(e),this._up(this.length++)}pop(){if(0===this.length)return;const e=this.data[0],t=this.data.pop();return--this.length>0&&(this.data[0]=t,this._down(0)),e}peek(){return this.data[0]}_up(e){const{data:t,compare:i}=this,r=t[e];for(;e>0;){const n=e-1>>1,o=t[n];if(i(r,o)>=0)break;t[e]=o,e=n}t[e]=r}_down(e){const{data:t,compare:i}=this,r=this.length>>1,n=t[e];for(;e<r;){let r=1+(e<<1);const o=r+1;if(o<this.length&&i(t[o],t[r])<0&&(r=o),i(t[r],n)>=0)break;t[e]=t[r],e=r}t[e]=n}}var Yr=8192;function Jr(e,t){return t.dist-e.dist}function Kr(e){const t=[1/0,1/0,-1/0,-1/0];if(t.length!==e.length)return!1;for(let i=0;i<t.length;i++)if(t[i]!==e[i])return!1;return!0}function Qr(e){return e[1]-e[0]+1}function en(e,t){const i=e[1]>=e[0]&&e[1]<t;return i||console.warn("Distance Expression: Index is out of range"),i}function tn(e,t){if(e[0]>e[1])return[null,null];const i=Qr(e);if(t){if(2===i)return[e,null];const t=Math.floor(i/2);return[[e[0],e[0]+t],[e[0]+t,e[1]]]}{if(1===i)return[e,null];const t=Math.floor(i/2)-1;return[[e[0],e[0]+t],[e[0]+t+1,e[1]]]}}function rn(e,t){const i=[1/0,1/0,-1/0,-1/0];if(!en(t,e.length))return i;for(let r=t[0];r<=t[1];++r)br(i,e[r]);return i}function nn(e){const t=[1/0,1/0,-1/0,-1/0];for(let i=0;i<e.length;++i)for(let r=0;r<e[i].length;++r)br(t,e[i][r]);return t}function on(e,t,i){if(Kr(e)||Kr(t))return NaN;let r=0,n=0;return e[2]<t[0]&&(r=t[0]-e[2]),e[0]>t[2]&&(r=e[0]-t[2]),e[1]>t[3]&&(n=e[1]-t[3]),e[3]<t[1]&&(n=t[1]-e[3]),i.distance([0,0],[r,n])}function sn(e){return 360*e-180}function an(e){return 360/Math.PI*Math.atan(Math.exp((180-360*e)*Math.PI/180))-90}function ln(e,t,i=8192){const r=Math.pow(2,t.z),n=(e.y/i+t.y)/r;return[sn((e.x/i+t.x)/r),an(n)]}function cn(e,t){const i=[];for(let r=0;r<e.length;++r)i.push(ln(e[r],t));return i}function hn(e,t,i){const r=i.pointOnLine(t,e).point;return i.distance(e,r)}function un(e,t,i,r,n){const o=i.slice(r[0],r[1]+1);let s=1/0;for(let a=t[0];a<=t[1];++a)if(0===(s=Math.min(s,hn(e[a],o,n))))return 0;return s}function dn(e,t,i,r,n){const o=Math.min(n.pointToSegmentDistance(e,i,r),n.pointToSegmentDistance(t,i,r)),s=Math.min(n.pointToSegmentDistance(i,e,t),n.pointToSegmentDistance(r,e,t));return Math.min(o,s)}function pn(e,t,i,r,n){if(!en(t,e.length)||!en(r,i.length))return NaN;let o=1/0;for(let s=t[0];s<t[1];++s)for(let t=r[0];t<r[1];++t){if(Ar(e[s],e[s+1],i[t],i[t+1]))return 0;o=Math.min(o,dn(e[s],e[s+1],i[t],i[t+1],n))}return o}function fn(e,t,i,r,n){if(!en(t,e.length)||!en(r,i.length))return NaN;let o=1/0;for(let s=t[0];s<=t[1];++s)for(let t=r[0];t<=r[1];++t)if(0===(o=Math.min(o,n.distance(e[s],i[t]))))return o;return o}function mn(e,t,i){if(Ir(e,t,!0))return 0;let r=1/0;for(const n of t){const t=n.length;if(t<2)return console.warn("Distance Expression: Invalid polygon!"),NaN;if(n[0]!==n[t-1]&&0===(r=Math.min(r,i.pointToSegmentDistance(e,n[t-1],n[0]))))return r;if(0===(r=Math.min(r,hn(e,n,i))))return r}return r}function _n(e,t,i,r){if(!en(t,e.length))return NaN;for(let o=t[0];o<=t[1];++o)if(Ir(e[o],i,!0))return 0;let n=1/0;for(let o=t[0];o<t[1];++o)for(const t of i)for(let i=0,s=t.length,a=s-1;i<s;a=i++){if(Ar(e[o],e[o+1],t[a],t[i]))return 0;n=Math.min(n,dn(e[o],e[o+1],t[a],t[i],r))}return n}function gn(e,t){for(const i of e)for(let e=0;e<=i.length-1;++e)if(Ir(i[e],t,!0))return!0;return!1}function yn(e,t,i,r=1/0){const n=nn(e),o=nn(t);if(r!==1/0&&on(n,o,i)>=r)return r;if(wr(n,o)){if(gn(e,t))return 0}else if(gn(t,e))return 0;let s=r;for(const a of e)for(let e=0,r=a.length,n=r-1;e<r;n=e++)for(const o of t)for(let t=0,r=o.length,l=r-1;t<r;l=t++){if(Ar(a[n],a[e],o[l],o[t]))return 0;s=Math.min(s,dn(a[n],a[e],o[l],o[t],i))}return s}function xn(e,t,i,r,n,o,s){if(null===o||null===s)return;const a=on(rn(r,o),rn(n,s),i);a<t&&e.push({dist:a,range1:o,range2:s})}function vn(e,t,i,r,n=1/0){let o=Math.min(r.distance(e[0],i[0][0]),n);if(0===o)return o;const s=new Xr([{dist:0,range1:[0,e.length-1],range2:[0,0]}],Jr),a=t?50:100,l=nn(i);for(;s.length;){const n=s.pop();if(n.dist>=o)continue;const c=n.range1;if(Qr(c)<=a){if(!en(c,e.length))return NaN;if(t){const t=_n(e,c,i,r);if(0===(o=Math.min(o,t)))return o}else for(let t=c[0];t<=c[1];++t){const n=mn(e[t],i,r);if(0===(o=Math.min(o,n)))return o}}else{const i=tn(c,t);if(null!==i[0]){const t=on(rn(e,i[0]),l,r);t<o&&s.push({dist:t,range1:i[0],range2:[0,0]})}if(null!==i[1]){const t=on(rn(e,i[1]),l,r);t<o&&s.push({dist:t,range1:i[1],range2:[0,0]})}}}return o}function bn(e,t,i,r,n,o=1/0){let s=Math.min(o,n.distance(e[0],i[0]));if(0===s)return s;const a=new Xr([{dist:0,range1:[0,e.length-1],range2:[0,i.length-1]}],Jr),l=t?50:100,c=r?50:100;for(;a.length;){const o=a.pop();if(o.dist>=s)continue;const h=o.range1,u=o.range2;if(Qr(h)<=l&&Qr(u)<=c){if(!en(h,e.length)||!en(u,i.length))return NaN;if(t&&r?s=Math.min(s,pn(e,h,i,u,n)):t||r?t&&!r?s=Math.min(s,un(i,u,e,h,n)):!t&&r&&(s=Math.min(s,un(e,h,i,u,n))):s=Math.min(s,fn(e,h,i,u,n)),0===s)return s}else{const o=tn(h,t),l=tn(u,r);xn(a,s,n,e,i,o[0],l[0]),xn(a,s,n,e,i,o[0],l[1]),xn(a,s,n,e,i,o[1],l[0]),xn(a,s,n,e,i,o[1],l[1])}}return s}function wn(e,t,i,r,n=1/0){let o=n;const s=rn(e,[0,e.length-1]);for(const a of i)if(!(o!==1/0&&on(s,rn(a,[0,a.length-1]),r)>=o)&&(o=Math.min(o,bn(e,t,a,!0,r,o)),0===o))return o;return o}function Tn(e,t,i,r,n=1/0){let o=n;const s=rn(e,[0,e.length-1]);for(const a of i){if(o!==1/0&&on(s,nn(a),r)>=o)continue;const i=vn(e,t,a,r,o);if(isNaN(i))return i;if(0===(o=Math.min(o,i)))return o}return o}function Sn(e){return"Point"===e||"MultiPoint"===e||"LineString"===e||"MultiLineString"===e||"Polygon"===e||"MultiPolygon"===e}class In{constructor(e,t){this.type=Mi,this.geojson=e,this.geometries=t}static parse(e,t){if(2!==e.length)return t.error(`'distance' expression requires either one argument, but found ' ${e.length-1} instead.`);if(Yi(e[1])){const t=e[1];if("FeatureCollection"===t.type){for(let e=0;e<t.features.length;++e)if(Sn(t.features[e].geometry.type))return new In(t,t.features[e].geometry)}else if("Feature"===t.type){if(Sn(t.geometry.type))return new In(t,t.geometry)}else if(Sn(t.type))return new In(t,t)}return t.error("'distance' expression needs to be an array with format ['Distance', GeoJSONObj].")}evaluate(e){const t=e.geometry(),i=e.canonicalID();if(null!=t&&null!=i){if("Point"===e.geometryType())return function(e,t,i){const r=[];for(const o of e)for(const e of o)r.push(ln(e,t));const n=new $r(r[0][1],"meters");return"Point"===i.type||"MultiPoint"===i.type||"LineString"===i.type?bn(r,!1,"Point"===i.type?[i.coordinates]:i.coordinates,"LineString"===i.type,n):"MultiLineString"===i.type?wn(r,!1,i.coordinates,n):"Polygon"===i.type||"MultiPolygon"===i.type?Tn(r,!1,"Polygon"===i.type?[i.coordinates]:i.coordinates,n):null}(t,i,this.geometries);if("LineString"===e.geometryType())return function(e,t,i){const r=[];for(const o of e){const e=[];for(const i of o)e.push(ln(i,t));r.push(e)}const n=new $r(r[0][0][1],"meters");if("Point"===i.type||"MultiPoint"===i.type||"LineString"===i.type)return wn("Point"===i.type?[i.coordinates]:i.coordinates,"LineString"===i.type,r,n);if("MultiLineString"===i.type){let e=1/0;for(let t=0;t<i.coordinates.length;t++){const o=wn(i.coordinates[t],!0,r,n,e);if(isNaN(o))return o;if(0===(e=Math.min(e,o)))return e}return e}if("Polygon"===i.type||"MultiPolygon"===i.type){let e=1/0;for(let t=0;t<r.length;t++){const o=Tn(r[t],!0,"Polygon"===i.type?[i.coordinates]:i.coordinates,n,e);if(isNaN(o))return o;if(0===(e=Math.min(e,o)))return e}return e}return null}(t,i,this.geometries);if("Polygon"===e.geometryType())return function(e,t,i){const r=[];for(const o of function(e){const t=e.length;if(t<=1)return[e];const i=[];let r,n;for(let o=0;o<t;o++){const t=vr(e[o]);0!==t&&(e[o].area=Math.abs(t),void 0===n&&(n=t<0),n===t<0?(r&&i.push(r),r=[e[o]]):r.push(e[o]))}return r&&i.push(r),i}(e)){const e=[];for(let i=0;i<o.length;++i)e.push(cn(o[i],t));r.push(e)}const n=new $r(r[0][0][0][1],"meters");if("Point"===i.type||"MultiPoint"===i.type||"LineString"===i.type)return Tn("Point"===i.type?[i.coordinates]:i.coordinates,"LineString"===i.type,r,n);if("MultiLineString"===i.type){let e=1/0;for(let t=0;t<i.coordinates.length;t++){const o=Tn(i.coordinates[t],!0,r,n,e);if(isNaN(o))return o;if(0===(e=Math.min(e,o)))return e}return e}return"Polygon"===i.type||"MultiPolygon"===i.type?function(e,t,i){let r=1/0;for(const n of e)for(const e of t){const t=yn(n,e,i,r);if(isNaN(t))return t;if(0===(r=Math.min(r,t)))return r}return r}("Polygon"===i.type?[i.coordinates]:i.coordinates,r,n):null}(t,i,this.geometries);console.warn("Distance Expression: currently only evaluates valid Point/LineString/Polygon geometries.")}else console.warn("Distance Expression: requires valid feature and canonical information.");return null}eachChild(){}outputDefined(){return!0}serialize(){return["distance",this.geojson]}}function En(e){if(e instanceof fr){if("get"===e.name&&1===e.args.length)return!1;if("feature-state"===e.name)return!1;if("has"===e.name&&1===e.args.length)return!1;if("properties"===e.name||"geometry-type"===e.name||"id"===e.name)return!1;if(e.name.startsWith("filter-"))return!1}if(e instanceof Ur)return!1;if(e instanceof In)return!1;if(e instanceof Rn)return e.featureConstant;let t=!0;return e.eachChild(e=>{t&&!En(e)&&(t=!1)}),t}function An(e){if(e instanceof fr&&"feature-state"===e.name)return!1;let t=!0;return e.eachChild(e=>{t&&!An(e)&&(t=!1)}),t}function Mn(e,t){if(e instanceof fr&&t.includes(e.name))return!1;let i=!0;return e.eachChild(e=>{i&&!Mn(e,t)&&(i=!1)}),i}function Cn(e,t,i){return[e,t,i].filter(Boolean).join("")}function Pn(e,t){switch(e){case"string":return Ki(t);case"number":return+t;case"boolean":return!!t;case"color":return xi.parse(t);case"formatted":return qi.fromString(Ki(t));case"resolvedImage":return Wi.build(Ki(t))}return t}function Dn(e,t,i,r){return void 0!==r&&(e=r*Math.round(e/r)),void 0!==t&&e<t&&(e=t),void 0!==i&&e>i&&(e=i),e}class Rn{constructor(e,t,i,r=!1){this.type=e,this.key=t,this.scope=i,this.featureConstant=r}static parse(e,t){let i=t.expectedType;if(i??=zi,e.length<2||e.length>3)return t.error("Invalid number of arguments for 'config' expression.");const r=t.parse(e[1],1);if(!(r instanceof Qi))return t.error("Key name of 'config' expression must be a string literal.");let n,o=!0;const s=Ki(r.value);if(e.length>=3){const i=t.parse(e[2],2);if(!(i instanceof Qi))return t.error("Scope of 'config' expression must be a string literal.");n=Ki(i.value)}if(t.options){const e=Cn(s,n,t._scope),i=t.options.get(e);i&&(o=En(i.value||i.default))}return new Rn(i,s,n,o)}evaluate(e){const t=Cn(this.key,this.scope,e.scope),i=e.getConfig(t);if(!i)return null;const{type:r,value:n,values:o,minValue:s,maxValue:a,stepValue:l}=i,c=i.default.evaluate(e);let h=c;if(n){const t=e.scope;e.scope=(t||"").split("").slice(1).join(""),h=n.evaluate(e),e.scope=t}return r&&(h=Pn(r,h)),void 0===h||void 0===s&&void 0===a&&void 0===l||("number"==typeof h?h=Dn(h,s,a,l):Array.isArray(h)&&(h=h.map(e=>"number"==typeof e?Dn(e,s,a,l):e))),void 0!==n&&void 0!==h&&o&&!o.includes(h)&&(h=c,r&&(h=Pn(r,h))),(r&&r!==this.type||void 0!==h&&!Gi(Ji(h),this.type))&&(h=Pn(this.type.kind,h)),h}eachChild(){}outputDefined(){return!1}serialize(){const e=["config",this.key];return this.scope&&e.concat(this.scope),e}}class zn{constructor(e,t){this.type=t.type,this.name=e,this.boundExpression=t}static parse(e,t){if(2!==e.length||"string"!=typeof e[1])return t.error("'var' expression requires exactly one string literal argument.");const i=e[1];return t.scope.has(i)?new zn(i,t.scope.get(i)):t.error(`Unknown variable "${i}". Make sure "${i}" has been bound in an enclosing "let" expression before using it.`,1)}evaluate(e){return this.boundExpression.evaluate(e)}eachChild(){}outputDefined(){return!1}serialize(){return["var",this.name]}}class Ln{constructor(e,t=[],i,r=new Ei,n=[],o,s,a){this.registry=e,this.path=t,this.scope=r,this.errors=n,this.expectedType=i,this._scope=o,this.options=s,this.iconImageUseTheme=a}get key(){if(void 0===this._key){const e=this.path;let t="";for(let i=0;i<e.length;i++){const r=e[i];t+="string"==typeof r?`['${r}']`:`[${r}]`}this._key=t}return this._key}parse(e,t,i,r,n={}){return t||i?this.concat(t,null,i,r)._parse(e,n):this._parse(e,n)}parseObjectValue(e,t,i,r,n,o={}){return this.concat(t,i,r,n)._parse(e,o)}_parse(e,t){function i(e,t,i){return"assert"===i?new ir(t,[e]):"coerce"===i?new ur(t,[e]):e}if(null!==e&&"string"!=typeof e&&"boolean"!=typeof e&&"number"!=typeof e||(e=["literal",e]),Array.isArray(e)){if(0===e.length)return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');const r="string"==typeof e[0]?this.registry[e[0]]:void 0;if(r){let n=r.parse(e,this);if(!n)return null;if(this.expectedType){const e=this.expectedType,r=n.type;if("string"!==e.kind&&"number"!==e.kind&&"boolean"!==e.kind&&"object"!==e.kind&&"array"!==e.kind||"value"!==r.kind)if("color"!==e.kind&&"formatted"!==e.kind&&"resolvedImage"!==e.kind||"value"!==r.kind&&"string"!==r.kind){if(this.checkSubtype(e,r))return null}else n=i(n,e,t.typeAnnotation||"coerce");else n=i(n,e,t.typeAnnotation||"assert")}if(!(n instanceof Qi)&&"resolvedImage"!==n.type.kind&&Fn(n)){const t=new pr(this._scope,this.options,this.iconImageUseTheme);try{n=new Qi(n.type,n.evaluate(t))}catch(e){return this.error(e.message),null}}return n}return ur.parse(["to-array",e],this)}return this.error(void 0===e?"'undefined' value invalid. Use null instead.":"object"==typeof e?'Bare objects invalid. Use ["literal", {...}] instead.':`Expected an array, but found ${typeof e} instead.`)}concat(e,t,i,r){let n="number"==typeof e?this.path.concat(e):this.path;n="string"==typeof t?n.concat(t):n;const o=r?this.scope.concat(r):this.scope;return new Ln(this.registry,n,i||null,o,this.errors,this._scope,this.options,this.iconImageUseTheme)}error(e,...t){const i=`${this.key}${t.map(e=>`[${e}]`).join("")}`;this.errors.push(new Ii(i,e))}checkSubtype(e,t,i){const r=Ui(e,t);return r&&this.error(r,..."number"==typeof i?[i]:[]),r}}function Fn(e){if(e instanceof zn)return Fn(e.boundExpression);if(e instanceof fr&&"error"===e.name)return!1;if(e instanceof _r)return!1;if(e instanceof Ur)return!1;if(e instanceof In)return!1;if(e instanceof Rn)return!1;const t=e instanceof ur||e instanceof ir;let i=!0;return e.eachChild(e=>{i=t?i&&Fn(e):i&&e instanceof Qi}),!!i&&En(e)&&Mn(e,["zoom","heatmap-density","worldview","line-progress","raster-value","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center","measure-light","raster-particle-speed","is-active-floor"])}function On(e,t){const i=e.length-1;let r,n,o=0,s=i,a=0;for(;o<=s;)if(a=Math.floor((o+s)/2),r=e[a],n=e[a+1],r<=t){if(a===i||t<n)return a;o=a+1}else{if(!(r>t))throw new er("Input is not a number.");s=a-1}return 0}class Bn{constructor(e,t,i){this.type=e,this.input=t,this.labels=[],this.outputs=[];for(const[r,n]of i)this.labels.push(r),this.outputs.push(n)}static parse(e,t){if(e.length-1<4)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if((e.length-1)%2!=0)return t.error("Expected an even number of arguments.");const i=t.parse(e[1],1,Mi);if(!i)return null;const r=[];let n=null;t.expectedType&&"value"!==t.expectedType.kind&&(n=t.expectedType);for(let o=1;o<e.length;o+=2){const i=1===o?-1/0:e[o],s=e[o+1],a=o,l=o+1;if("number"!=typeof i)return t.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.',a);if(r.length&&r.at(-1)[0]>=i)return t.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.',a);const c=t.parse(s,l,n);if(!c)return null;n=n||c.type,r.push([i,c])}return new Bn(n,i,r)}evaluate(e){const t=this.labels,i=this.outputs;if(1===t.length)return i[0].evaluate(e);const r=this.input.evaluate(e);if(r<=t[0])return i[0].evaluate(e);const n=t.length;return r>=t[n-1]?i[n-1].evaluate(e):i[On(t,r)].evaluate(e)}eachChild(e){e(this.input);for(const t of this.outputs)e(t)}outputDefined(){return this.outputs.every(e=>e.outputDefined())}serialize(){const e=["step",this.input.serialize()];for(let t=0;t<this.labels.length;t++)t>0&&e.push(this.labels[t]),e.push(this.outputs[t].serialize());return e}}const kn=.95047,Nn=1.08883,Un=4/29,Vn=6/29,jn=3*Vn*Vn,Gn=Vn*Vn*Vn,Hn=Math.PI/180,$n=180/Math.PI;function qn(e){return e>Gn?Math.pow(e,1/3):e/jn+Un}function Zn(e){return e>Vn?e*e*e:jn*(e-Un)}function Wn(e){return 255*(e<=.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055)}function Xn(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function Yn(e){const t=Xn(e.r),i=Xn(e.g),r=Xn(e.b),n=qn((.4124564*t+.3575761*i+.1804375*r)/kn),o=qn((.2126729*t+.7151522*i+.072175*r)/1);return{l:116*o-16,a:500*(n-o),b:200*(o-qn((.0193339*t+.119192*i+.9503041*r)/Nn)),alpha:e.a}}function Jn(e){let t=(e.l+16)/116,i=isNaN(e.a)?t:t+e.a/500,r=isNaN(e.b)?t:t-e.b/200;return t=1*Zn(t),i=kn*Zn(i),r=Nn*Zn(r),new xi(Wn(3.2404542*i-1.5371385*t-.4985314*r),Wn(-.969266*i+1.8760108*t+.041556*r),Wn(.0556434*i-.2040259*t+1.0572252*r),e.alpha)}function Kn(e,t,i){const r=t-e;return e+i*(r>180||r<-180?r-360*Math.round(r/360):r)}const Qn={forward:Yn,reverse:Jn,interpolate:function(e,t,i){return{l:yi(e.l,t.l,i),a:yi(e.a,t.a,i),b:yi(e.b,t.b,i),alpha:yi(e.alpha,t.alpha,i)}}},eo={forward:function(e){const{l:t,a:i,b:r}=Yn(e),n=Math.atan2(r,i)*$n;return{h:n<0?n+360:n,c:Math.sqrt(i*i+r*r),l:t,alpha:e.a}},reverse:function(e){const t=e.h*Hn,i=e.c;return Jn({l:e.l,a:Math.cos(t)*i,b:Math.sin(t)*i,alpha:e.alpha})},interpolate:function(e,t,i){return{h:Kn(e.h,t.h,i),c:yi(e.c,t.c,i),l:yi(e.l,t.l,i),alpha:yi(e.alpha,t.alpha,i)}}};var to=Object.freeze({__proto__:null,hcl:eo,lab:Qn});class io{constructor(e,t,i,r,n){this.type=e,this.operator=t,this.interpolation=i,this.input=r,this.labels=[],this.outputs=[];for(const[o,s]of n)this.labels.push(o),this.outputs.push(s)}static interpolationFactor(e,t,i,r){let n=0;if("exponential"===e.name)n=ro(t,e.base,i,r);else if("linear"===e.name)n=ro(t,1,i,r);else if("cubic-bezier"===e.name){const o=e.controlPoints;n=new Se(o[0],o[1],o[2],o[3]).solve(ro(t,1,i,r))}return n}static parse(e,t){let[i,r,n,...o]=e;if(!Array.isArray(r)||0===r.length)return t.error("Expected an interpolation type expression.",1);if("linear"===r[0])r={name:"linear"};else if("exponential"===r[0]){const e=r[1];if("number"!=typeof e)return t.error("Exponential interpolation requires a numeric base.",1,1);r={name:"exponential",base:e}}else{if("cubic-bezier"!==r[0])return t.error(`Unknown interpolation type ${String(r[0])}`,1,0);{const e=r.slice(1);if(4!==e.length||e.some(e=>"number"!=typeof e||e<0||e>1))return t.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);r={name:"cubic-bezier",controlPoints:e}}}if(e.length-1<4)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if(e.length-1>3&&(e.length-1)%2!=0)return t.error("Expected an even number of arguments.");if(n=t.parse(n,2,Mi),!n)return null;const s=[];let a=null;"interpolate-hcl"===i||"interpolate-lab"===i?a=Di:t.expectedType&&"value"!==t.expectedType.kind&&(a=t.expectedType);for(let l=0;l<o.length;l+=2){const e=o[l],i=o[l+1],r=l+3,n=l+4;if("number"!=typeof e)return t.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.at(-1)[0]>=e)return t.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.',r);const c=t.parse(i,n,a);if(!c)return null;a=a||c.type,s.push([e,c])}return"number"===a.kind||"color"===a.kind||"array"===a.kind&&"number"===a.itemType.kind&&"number"==typeof a.N?new io(a,i,r,n,s):t.error(`Type ${ki(a)} is not interpolatable.`)}evaluate(e){const t=this.labels,i=this.outputs;if(1===t.length)return i[0].evaluate(e);const r=this.input.evaluate(e);if(r<=t[0])return i[0].evaluate(e);const n=t.length;if(r>=t[n-1])return i[n-1].evaluate(e);const o=On(t,r),s=io.interpolationFactor(this.interpolation,r,t[o],t[o+1]),a=i[o].evaluate(e),l=i[o+1].evaluate(e);return"interpolate"===this.operator?Si[this.type.kind.toLowerCase()](a,l,s):"interpolate-hcl"===this.operator?eo.reverse(eo.interpolate(eo.forward(a),eo.forward(l),s)):Qn.reverse(Qn.interpolate(Qn.forward(a),Qn.forward(l),s))}eachChild(e){e(this.input);for(const t of this.outputs)e(t)}outputDefined(){return this.outputs.every(e=>e.outputDefined())}serialize(){let e;e="linear"===this.interpolation.name?["linear"]:"exponential"===this.interpolation.name?1===this.interpolation.base?["linear"]:["exponential",this.interpolation.base]:["cubic-bezier",...this.interpolation.controlPoints];const t=[this.operator,e,this.input.serialize()];for(let i=0;i<this.labels.length;i++)t.push(this.labels[i],this.outputs[i].serialize());return t}}function ro(e,t,i,r){const n=r-i,o=e-i;return 0===n?0:1===t?o/n:(Math.pow(t,o)-1)/(Math.pow(t,n)-1)}class no{constructor(e,t){this.type=e,this.args=t}static parse(e,t){if(e.length<2)return t.error("Expectected at least one argument."),null;let i=null;const r=t.expectedType;r&&"value"!==r.kind&&(i=r);const n=[];for(const o of e.slice(1)){const e=t.parse(o,1+n.length,i,void 0,{typeAnnotation:"omit"});if(!e)return null;i=i||e.type,n.push(e)}return new no(r&&n.some(e=>Ui(r,e.type))?zi:i,n)}evaluate(e){let t,i=null,r=0;for(const n of this.args){if(r++,i=n.evaluate(e),i&&i instanceof Wi&&!i.available&&(t||(t=i),i=null,r===this.args.length))return t;if(null!==i)break}return i}eachChild(e){this.args.forEach(e)}outputDefined(){return this.args.every(e=>e.outputDefined())}serialize(){const e=["coalesce"];return this.eachChild(t=>{e.push(t.serialize())}),e}}const oo=/[^a-zA-Z0-9_]/;class so{constructor(e,t){this.type=t.type,this.bindings=[].concat(e),this.result=t}evaluate(e){return this.result.evaluate(e)}eachChild(e){for(const t of this.bindings)e(t[1]);e(this.result)}static parse(e,t){if(e.length<4)return t.error(`Expected at least 3 arguments, but found ${e.length-1} instead.`);const i=[];for(let n=1;n<e.length-1;n+=2){const r=e[n];if("string"!=typeof r)return t.error(`Expected string, but found ${typeof r} instead.`,n);if(oo.test(r))return t.error("Variable names must contain only alphanumeric characters or '_'.",n);const o=t.parse(e[n+1],n+1);if(!o)return null;i.push([r,o])}const r=t.parse(e.at(-1),e.length-1,t.expectedType,i);return r?new so(i,r):null}outputDefined(){return this.result.outputDefined()}serialize(){const e=["let"];for(const[t,i]of this.bindings)e.push(t,i.serialize());return e.push(this.result.serialize()),e}}class ao{constructor(e,t,i){this.type=e,this.index=t,this.input=i}static parse(e,t){if(3!==e.length)return t.error(`Expected 2 arguments, but found ${e.length-1} instead.`);const i=t.parse(e[1],1,Mi),r=t.parse(e[2],2,Bi(t.expectedType||zi));return i&&r?new ao(r.type.itemType,i,r):null}evaluate(e){const t=this.index.evaluate(e),i=this.input.evaluate(e);if(t<0)throw new er("Array index out of bounds: negative index");if(t>=i.length)throw new er("Array index out of bounds: index exceeds array size");if(t!==Math.floor(t))throw new er("Array index must be an integer. Use at-interpolated for fractional indices");return i[t]}eachChild(e){e(this.index),e(this.input)}outputDefined(){return!1}serialize(){return["at",this.index.serialize(),this.input.serialize()]}}class lo{constructor(e,t,i){this.type=e,this.index=t,this.input=i}static parse(e,t){if(3!==e.length)return t.error(`Expected 2 arguments, but found ${e.length-1} instead.`);const i=t.parse(e[1],1,Mi),r=t.parse(e[2],2,Bi(t.expectedType||zi));return i&&r?new lo(r.type.itemType,i,r):null}evaluate(e){const t=this.index.evaluate(e),i=this.input.evaluate(e);if(t<0)throw new er(`Array index out of bounds: ${t} < 0.`);if(t>i.length-1)throw new er(`Array index out of bounds: ${t} > ${i.length-1}.`);if(t===Math.floor(t))return i[t];const r=Math.floor(t),n=Math.ceil(t),o=i[r],s=i[n];if("number"!=typeof o||"number"!=typeof s)throw new er(`Cannot interpolate between non-number values at index ${t}.`);const a=t-r;return o*(1-a)+s*a}eachChild(e){e(this.index),e(this.input)}outputDefined(){return!1}serialize(){return["at-interpolated",this.index.serialize(),this.input.serialize()]}}class co{constructor(e,t){this.type=Pi,this.needle=e,this.haystack=t}static parse(e,t){if(3!==e.length)return t.error(`Expected 2 arguments, but found ${e.length-1} instead.`),null;const i=t.parse(e[1],1,zi),r=t.parse(e[2],2,zi);return i&&r?Vi(i.type,[Pi,Ci,Mi,Ai,zi])?new co(i,r):(t.error(`Expected first argument to be of type boolean, string, number or null, but found ${ki(i.type)} instead`),null):null}evaluate(e){const t=this.needle.evaluate(e),i=this.haystack.evaluate(e);if(null==i)return!1;if(!ji(t,["boolean","string","number","null"]))throw new er(`Expected first argument to be of type boolean, string, number or null, but found ${ki(Ji(t))} instead.`);if(!ji(i,["string","array"]))throw new er(`Expected second argument to be of type array or string, but found ${ki(Ji(i))} instead.`);return i.includes(t)}eachChild(e){e(this.needle),e(this.haystack)}outputDefined(){return!0}serialize(){return["in",this.needle.serialize(),this.haystack.serialize()]}}class ho{constructor(e,t,i){this.type=Mi,this.needle=e,this.haystack=t,this.fromIndex=i}static parse(e,t){if(e.length<=2||e.length>=5)return t.error(`Expected 3 or 4 arguments, but found ${e.length-1} instead.`),null;const i=t.parse(e[1],1,zi),r=t.parse(e[2],2,zi);if(!i||!r)return null;if(!Vi(i.type,[Pi,Ci,Mi,Ai,zi]))return t.error(`Expected first argument to be of type boolean, string, number or null, but found ${ki(i.type)} instead`),null;if(4===e.length){const n=t.parse(e[3],3,Mi);return n?new ho(i,r,n):null}return new ho(i,r)}evaluate(e){const t=this.needle.evaluate(e),i=this.haystack.evaluate(e);if(!ji(t,["boolean","string","number","null"]))throw new er(`Expected first argument to be of type boolean, string, number or null, but found ${ki(Ji(t))} instead.`);if(!ji(i,["string","array"]))throw new er(`Expected second argument to be of type array or string, but found ${ki(Ji(i))} instead.`);if(this.fromIndex){const r=this.fromIndex.evaluate(e);return i.indexOf(t,r)}return i.indexOf(t)}eachChild(e){e(this.needle),e(this.haystack),this.fromIndex&&e(this.fromIndex)}outputDefined(){return!1}serialize(){if(null!=this.fromIndex&&void 0!==this.fromIndex){const e=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),e]}return["index-of",this.needle.serialize(),this.haystack.serialize()]}}class uo{constructor(e,t,i,r,n,o){this.inputType=e,this.type=t,this.input=i,this.cases=r,this.outputs=n,this.otherwise=o}static parse(e,t){if(e.length<5)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if(e.length%2!=1)return t.error("Expected an even number of arguments.");let i,r;t.expectedType&&"value"!==t.expectedType.kind&&(r=t.expectedType);const n={},o=[];for(let l=2;l<e.length-1;l+=2){let s=e[l];const a=e[l+1];Array.isArray(s)||(s=[s]);const c=t.concat(l);if(0===s.length)return c.error("Expected at least one branch label.");for(const e of s){if("number"!=typeof e&&"string"!=typeof e)return c.error("Branch labels must be numbers or strings.");if("number"==typeof e&&Math.abs(e)>Number.MAX_SAFE_INTEGER)return c.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);if("number"==typeof e&&Math.floor(e)!==e)return c.error("Numeric branch labels must be integer values.");if(i){if(c.checkSubtype(i,Ji(e)))return null}else i=Ji(e);if(void 0!==n[String(e)])return c.error("Branch labels must be unique.");n[String(e)]=o.length}const h=t.parse(a,l,r);if(!h)return null;r=r||h.type,o.push(h)}const s=t.parse(e[1],1,zi);if(!s)return null;const a=t.parse(e.at(-1),e.length-1,r);return a?"value"!==s.type.kind&&t.concat(1).checkSubtype(i,s.type)?null:new uo(i,r,s,n,o,a):null}evaluate(e){const t=this.input.evaluate(e);return(Gi(Ji(t),this.inputType)&&this.outputs[this.cases[t]]||this.otherwise).evaluate(e)}eachChild(e){e(this.input),this.outputs.forEach(e),e(this.otherwise)}outputDefined(){return this.outputs.every(e=>e.outputDefined())&&this.otherwise.outputDefined()}serialize(){const e=["match",this.input.serialize()],t=Object.keys(this.cases).sort(),i=[],r={};for(const o of t){const e=r[this.cases[o]];void 0===e?(r[this.cases[o]]=i.length,i.push([this.cases[o],[o]])):i[e][1].push(o)}const n=e=>"number"===this.inputType.kind?Number(e):e;for(const[o,s]of i)e.push(1===s.length?n(s[0]):s.map(n)),e.push(this.outputs[o].serialize());return e.push(this.otherwise.serialize()),e}}class po{constructor(e,t,i){this.type=e,this.branches=t,this.otherwise=i}static parse(e,t){if(e.length<4)return t.error(`Expected at least 3 arguments, but found only ${e.length-1}.`),null;if(e.length%2!=0)return t.error("Expected an odd number of arguments."),null;let i;t.expectedType&&"value"!==t.expectedType.kind&&(i=t.expectedType);const r=[];for(let o=1;o<e.length-1;o+=2){const n=t.parse(e[o],o,Pi);if(!n)return null;const s=t.parse(e[o+1],o+1,i);if(!s)return null;r.push([n,s]),i=i||s.type}const n=t.parse(e.at(-1),e.length-1,i);return n?new po(i,r,n):null}evaluate(e){for(const[t,i]of this.branches)if(t.evaluate(e))return i.evaluate(e);return this.otherwise.evaluate(e)}eachChild(e){for(const[t,i]of this.branches)e(t),e(i);e(this.otherwise)}outputDefined(){return this.branches.every(([e,t])=>t.outputDefined())&&this.otherwise.outputDefined()}serialize(){const e=["case"];return this.eachChild(t=>{e.push(t.serialize())}),e}}class fo{constructor(e,t,i,r){this.type=e,this.input=t,this.beginIndex=i,this.endIndex=r}static parse(e,t){if(e.length<=2||e.length>=5)return t.error(`Expected 3 or 4 arguments, but found ${e.length-1} instead.`),null;const i=t.parse(e[1],1,zi),r=t.parse(e[2],2,Mi);if(!i||!r)return null;if(!Vi(i.type,[Bi(zi),Ci,zi]))return t.error(`Expected first argument to be of type array or string, but found ${ki(i.type)} instead`),null;if(4===e.length){const n=t.parse(e[3],3,Mi);return n?new fo(i.type,i,r,n):null}return new fo(i.type,i,r)}evaluate(e){const t=this.input.evaluate(e),i=this.beginIndex.evaluate(e);if(!ji(t,["string","array"]))throw new er(`Expected first argument to be of type array or string, but found ${ki(Ji(t))} instead.`);if(this.endIndex){const r=this.endIndex.evaluate(e);return t.slice(i,r)}return t.slice(i)}eachChild(e){e(this.input),e(this.beginIndex),this.endIndex&&e(this.endIndex)}outputDefined(){return!1}serialize(){if(null!=this.endIndex&&void 0!==this.endIndex){const e=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),e]}return["slice",this.input.serialize(),this.beginIndex.serialize()]}}class mo{constructor(e,t){this.type=Bi(Ci),this.str=e,this.delimiter=t}static parse(e,t){if(3!==e.length)return t.error(`Expected 2 arguments, but found ${e.length-1} instead.`);const i=t.parse(e[1],1,Ci),r=t.parse(e[2],2,Ci);return i&&r?new mo(i,r):void 0}evaluate(e){const t=this.str.evaluate(e),i=this.delimiter.evaluate(e);return t.split(i)}eachChild(e){e(this.str),e(this.delimiter)}outputDefined(){return!1}serialize(){return["split",this.str.serialize(),this.delimiter.serialize()]}}function _o(e,t){return"=="===e||"!="===e?"boolean"===t.kind||"string"===t.kind||"number"===t.kind||"null"===t.kind||"value"===t.kind:"string"===t.kind||"number"===t.kind||"value"===t.kind}function go(e,t,i,r){return 0===r.compare(t,i)}function yo(e,t,i){const r="=="!==e&&"!="!==e;return class n{constructor(e,t,i){this.type=Pi,this.lhs=e,this.rhs=t,this.collator=i,this.hasUntypedArgument="value"===e.type.kind||"value"===t.type.kind}static parse(e,t){if(3!==e.length&&4!==e.length)return t.error("Expected two or three arguments.");const i=e[0];let o=t.parse(e[1],1,zi);if(!o)return null;if(!_o(i,o.type))return t.concat(1).error(`"${i}" comparisons are not supported for type '${ki(o.type)}'.`);let s=t.parse(e[2],2,zi);if(!s)return null;if(!_o(i,s.type))return t.concat(2).error(`"${i}" comparisons are not supported for type '${ki(s.type)}'.`);if(o.type.kind!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return t.error(`Cannot compare types '${ki(o.type)}' and '${ki(s.type)}'.`);r&&("value"===o.type.kind&&"value"!==s.type.kind?o=new ir(s.type,[o]):"value"!==o.type.kind&&"value"===s.type.kind&&(s=new ir(o.type,[s])));let a=null;if(4===e.length){if("string"!==o.type.kind&&"string"!==s.type.kind&&"value"!==o.type.kind&&"value"!==s.type.kind)return t.error("Cannot use collator to compare non-string types.");if(a=t.parse(e[3],3,Li),!a)return null}return new n(o,s,a)}evaluate(n){const o=this.lhs.evaluate(n),s=this.rhs.evaluate(n);if(r&&this.hasUntypedArgument){const t=Ji(o),i=Ji(s);if(t.kind!==i.kind||"string"!==t.kind&&"number"!==t.kind)throw new er(`Expected arguments for "${e}" to be (string, string) or (number, number), but found (${t.kind}, ${i.kind}) instead.`)}if(this.collator&&!r&&this.hasUntypedArgument){const e=Ji(o),i=Ji(s);if("string"!==e.kind||"string"!==i.kind)return t(n,o,s)}return this.collator?i(n,o,s,this.collator.evaluate(n)):t(n,o,s)}eachChild(e){e(this.lhs),e(this.rhs),this.collator&&e(this.collator)}outputDefined(){return!0}serialize(){const t=[e];return this.eachChild(e=>{t.push(e.serialize())}),t}}}const xo=yo("==",function(e,t,i){return t===i},go),vo=yo("!=",function(e,t,i){return t!==i},function(e,t,i,r){return!go(0,t,i,r)}),bo=yo("<",function(e,t,i){return t<i},function(e,t,i,r){return r.compare(t,i)<0}),wo=yo(">",function(e,t,i){return t>i},function(e,t,i,r){return r.compare(t,i)>0}),To=yo("<=",function(e,t,i){return t<=i},function(e,t,i,r){return r.compare(t,i)<=0}),So=yo(">=",function(e,t,i){return t>=i},function(e,t,i,r){return r.compare(t,i)>=0});class Io{constructor(e,t,i,r,n,o){this.type=Ci,this.number=e,this.locale=t,this.currency=i,this.unit=r,this.minFractionDigits=n,this.maxFractionDigits=o}static parse(e,t){if(3!==e.length)return t.error("Expected two arguments.");const i=t.parse(e[1],1,Mi);if(!i)return null;const r=e[2];if("object"!=typeof r||Array.isArray(r))return t.error("NumberFormat options argument must be an object.");let n=null;if(r.locale&&(n=t.parseObjectValue(r.locale,2,"locale",Ci),!n))return null;let o=null;if(r.currency&&(o=t.parseObjectValue(r.currency,2,"currency",Ci),!o))return null;let s=null;if(r.unit&&(s=t.parseObjectValue(r.unit,2,"unit",Ci),!s))return null;let a=null;if(r["min-fraction-digits"]&&(a=t.parseObjectValue(r["min-fraction-digits"],2,"min-fraction-digits",Mi),!a))return null;let l=null;return r["max-fraction-digits"]&&(l=t.parseObjectValue(r["max-fraction-digits"],2,"max-fraction-digits",Mi),!l)?null:new Io(i,n,o,s,a,l)}evaluate(e){return new Intl.NumberFormat(this.locale?this.locale.evaluate(e):[],{style:(this.currency?"currency":this.unit&&"unit")||"decimal",currency:this.currency?this.currency.evaluate(e):void 0,unit:this.unit?this.unit.evaluate(e):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(e):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(e):void 0}).format(this.number.evaluate(e))}eachChild(e){e(this.number),this.locale&&e(this.locale),this.currency&&e(this.currency),this.unit&&e(this.unit),this.minFractionDigits&&e(this.minFractionDigits),this.maxFractionDigits&&e(this.maxFractionDigits)}outputDefined(){return!1}serialize(){const e={};return this.locale&&(e.locale=this.locale.serialize()),this.currency&&(e.currency=this.currency.serialize()),this.unit&&(e.unit=this.unit.serialize()),this.minFractionDigits&&(e["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(e["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),e]}}class Eo{constructor(e){this.type=Mi,this.input=e}static parse(e,t){if(2!==e.length)return t.error(`Expected 1 argument, but found ${e.length-1} instead.`),null;const i=t.parse(e[1],1);return i?"array"!==i.type.kind&&"string"!==i.type.kind&&"value"!==i.type.kind?(t.error(`Expected argument of type string or array, but found ${ki(i.type)} instead.`),null):new Eo(i):null}evaluate(e){const t=this.input.evaluate(e);if("string"==typeof t)return t.length;if(Array.isArray(t))return t.length;throw new er(`Expected value to be of type string or array, but found ${ki(Ji(t))} instead.`)}eachChild(e){e(this.input)}outputDefined(){return!1}serialize(){const e=["length"];return this.eachChild(t=>{e.push(t.serialize())}),e}}function Ao(e){return function(){e=1831565813+(e|=0)|0;let t=Math.imul(e^e>>>15,1|e);return t=t+Math.imul(t^t>>>7,61|t)^t,((t^t>>>14)>>>0)/4294967296}}const Mo={"==":xo,"!=":vo,">":wo,"<":bo,">=":So,"<=":To,array:ir,at:ao,"at-interpolated":lo,boolean:ir,case:po,coalesce:no,collator:_r,format:rr,image:nr,in:co,"index-of":ho,interpolate:io,"interpolate-hcl":io,"interpolate-lab":io,length:Eo,let:so,literal:Qi,match:uo,number:ir,"number-format":Io,object:ir,slice:fo,step:Bn,string:ir,"to-boolean":ur,"to-color":ur,"to-number":ur,"to-string":ur,var:zn,within:Ur,distance:In,config:Rn,split:mo};function Co(e,[t,i,r,n]){t=t.evaluate(e),i=i.evaluate(e),r=r.evaluate(e);const o=n?n.evaluate(e):1,s=Xi(t,i,r,o);if(s)throw new er(s);return new xi(t/255,i/255,r/255,o)}function Po(e,[t,i,r,n]){t=t.evaluate(e),i=i.evaluate(e),r=r.evaluate(e);const o=n?n.evaluate(e):1,s=function(e,t,i,r){return"number"==typeof e&&e>=0&&e<=360?"number"==typeof t&&t>=0&&t<=100&&"number"==typeof i&&i>=0&&i<=100?void 0===r||"number"==typeof r&&r>=0&&r<=1?null:`Invalid hsla value [${[e,t,i,r].join(", ")}]: 'a' must be between 0 and 1.`:`Invalid hsla value [${("number"==typeof r?[e,t,i,r]:[e,t,i]).join(", ")}]: 's', and 'l' must be between 0 and 100.`:`Invalid hsla value [${("number"==typeof r?[e,t,i,r]:[e,t,i]).join(", ")}]: 'h' must be between 0 and 360.`}(t,i,r,o);if(s)throw new er(s);const a=`hsla(${t}, ${i}%, ${r}%, ${o})`,l=xi.parse(a);if(!l)throw new er(`Failed to parse HSLA color: ${a}`);return l}function Do(e,t){return e in t}function Ro(e,t){const i=t[e];return void 0===i?null:i}function zo(e){return{type:e}}function Lo(e){if(e instanceof Rn)return new Set([e.key]);let t=/* @__PURE__ */new Set;return e.eachChild(e=>{t=new Set([...t,...Lo(e)])}),t}function Fo(e){if(e instanceof fr&&"is-active-floor"===e.name)return!0;let t=!1;return e.eachChild(e=>{!t&&Fo(e)&&(t=!0)}),t}function Oo(e){return{result:"success",value:e}}function Bo(e){return{result:"error",value:e}}function ko(e,t){return!!e&&!!e.parameters&&e.parameters.includes(t)}function No(e){return"data-driven"===e["property-type"]}function Uo(e){return ko(e.expression,"measure-light")}function Vo(e){return ko(e.expression,"zoom")}function jo(e){return!!e.expression&&e.expression.interpolated}function Go(e){return"object"==typeof e&&null!==e&&!Array.isArray(e)}function Ho(e){return e}function $o(e,t){const i="color"===t.type,r=e.stops&&"object"==typeof e.stops[0][0],n=r||!(r||void 0!==e.property),o=e.type||(jo(t)?"exponential":"interval");if(i&&((e=Object.assign({},e)).stops&&(e.stops=e.stops.map(e=>[e[0],xi.parse(e[1])])),e.default=xi.parse(e.default?e.default:t.default)),e.colorSpace&&"rgb"!==e.colorSpace&&!to[e.colorSpace])throw new Error(`Unknown color space: ${e.colorSpace}`);let s,a,l;if("exponential"===o)s=Xo;else if("interval"===o)s=Wo;else if("categorical"===o){s=Zo,a=Object.create(null);for(const t of e.stops)a[t[0]]=t[1];l=typeof e.stops[0][0]}else{if("identity"!==o)throw new Error(`Unknown function type "${o}"`);s=Yo}if(r){const i={},r=[];for(let t=0;t<e.stops.length;t++){const n=e.stops[t],o=n[0].zoom;void 0===i[o]&&(i[o]={zoom:o,type:e.type,property:e.property,default:e.default,stops:[]},r.push(o)),i[o].stops.push([n[0].value,n[1]])}const n=[];for(const e of r)n.push([i[e].zoom,$o(i[e],t)]);const o={name:"linear"};return{kind:"composite",interpolationType:o,interpolationFactor:io.interpolationFactor.bind(void 0,o),zoomStops:n.map(e=>e[0]),evaluate:({zoom:i},r)=>Xo({stops:n,base:e.base},t,i).evaluate(i,r)}}if(n){const i="exponential"===o?{name:"exponential",base:void 0!==e.base?e.base:1}:null;return{kind:"camera",interpolationType:i,interpolationFactor:io.interpolationFactor.bind(void 0,i),zoomStops:e.stops.map(e=>e[0]),evaluate:({zoom:i})=>s(e,t,i,a,l)}}return{kind:"source",evaluate(i,r){const n=r&&r.properties?r.properties[e.property]:void 0;return void 0===n?qo(e.default,t.default):s(e,t,n,a,l)}}}function qo(e,t,i){return void 0!==e?e:void 0!==t?t:void 0!==i?i:void 0}function Zo(e,t,i,r,n){return qo(typeof i===n?r[i]:void 0,e.default,t.default)}function Wo(e,t,i){if(!lr(i))return qo(e.default,t.default);const r=e.stops.length;if(1===r)return e.stops[0][1];if(i<=e.stops[0][0])return e.stops[0][1];if(i>=e.stops[r-1][0])return e.stops[r-1][1];const n=On(e.stops.map(e=>e[0]),i);return e.stops[n][1]}function Xo(e,t,i){const r=void 0!==e.base?e.base:1;if(!lr(i))return qo(e.default,t.default);const n=e.stops.length;if(1===n)return e.stops[0][1];if(i<=e.stops[0][0])return e.stops[0][1];if(i>=e.stops[n-1][0])return e.stops[n-1][1];const o=On(e.stops.map(e=>e[0]),i),s=function(e,t,i,r){const n=r-i,o=e-i;return 0===n?0:1===t?o/n:(Math.pow(t,o)-1)/(Math.pow(t,n)-1)}(i,r,e.stops[o][0],e.stops[o+1][0]),a=e.stops[o][1],l=e.stops[o+1][1];let c=Si[t.type]||Ho;if(e.colorSpace&&"rgb"!==e.colorSpace){const t=to[e.colorSpace];c=(e,i)=>t.reverse(t.interpolate(t.forward(e),t.forward(i),s))}return"function"==typeof a.evaluate?{evaluate(...e){const t=a.evaluate.apply(void 0,e),i=l.evaluate.apply(void 0,e);if(void 0!==t&&void 0!==i)return c(t,i,s)}}:c(a,l,s)}function Yo(e,t,i){return"color"===t.type?i=xi.parse(i):"formatted"===t.type?i=qi.fromString(i.toString()):"resolvedImage"===t.type?i=Wi.build(i.toString()):or(i)===t.type||"enum"===t.type&&t.values[i]||(i=void 0),qo(i,e.default,t.default)}fr.register(Mo,{error:[{kind:"error"},[Ci],(e,[t])=>{throw new er(t.evaluate(e))}],typeof:[Ci,[zi],(e,[t])=>ki(Ji(t.evaluate(e)))],"to-rgba":[Bi(Mi,4),[Di],(e,[t])=>t.evaluate(e).toNonPremultipliedRenderColor(null).toArray()],"to-hsla":[Bi(Mi,4),[Di],(e,[t])=>t.evaluate(e).toNonPremultipliedRenderColor(null).toHslaArray()],rgb:[Di,[Mi,Mi,Mi],Co],rgba:[Di,[Mi,Mi,Mi,Mi],Co],hsl:[Di,[Mi,Mi,Mi],Po],hsla:[Di,[Mi,Mi,Mi,Mi],Po],has:{type:Pi,overloads:[[[Ci],(e,[t])=>Do(t.evaluate(e),e.properties())],[[Ci,Ri],(e,[t,i])=>Do(t.evaluate(e),i.evaluate(e))]]},get:{type:zi,overloads:[[[Ci],(e,[t])=>Ro(t.evaluate(e),e.properties())],[[Ci,Ri],(e,[t,i])=>Ro(t.evaluate(e),i.evaluate(e))]]},"feature-state":[zi,[Ci],(e,[t])=>Ro(t.evaluate(e),e.featureState||{})],properties:[Ri,[],e=>e.properties()],"geometry-type":[Ci,[],e=>e.geometryType()],worldview:[Ci,[],e=>e.globals.worldview||""],"is-active-floor":[Pi,zo(Ci),(e,t)=>{if(!(e.globals&&e.globals.activeFloors&&e.globals.activeFloors.size>0))return!1;if(0===t.length)return!0;const i=e.globals.activeFloors;return t.some(t=>{const r=t.evaluate(e);return i.has(r)})}],id:[zi,[],e=>e.id()],zoom:[Mi,[],e=>e.globals.zoom],pitch:[Mi,[],e=>e.globals.pitch||0],"distance-from-center":[Mi,[],e=>e.distanceFromCenter()],"measure-light":[Mi,[Ci],(e,[t])=>e.measureLight(t.evaluate(e))],"heatmap-density":[Mi,[],e=>e.globals.heatmapDensity||0],"line-progress":[Mi,[],e=>e.globals.lineProgress||0],"raster-value":[Mi,[],e=>e.globals.rasterValue||0],"raster-particle-speed":[Mi,[],e=>e.globals.rasterParticleSpeed||0],"sky-radial-progress":[Mi,[],e=>e.globals.skyRadialProgress||0],accumulated:[zi,[],e=>void 0===e.globals.accumulated?null:e.globals.accumulated],"+":[Mi,zo(Mi),(e,t)=>{let i=0;for(const r of t)i+=r.evaluate(e);return i}],"*":[Mi,zo(Mi),(e,t)=>{let i=1;for(const r of t)i*=r.evaluate(e);return i}],"-":{type:Mi,overloads:[[[Mi,Mi],(e,[t,i])=>t.evaluate(e)-i.evaluate(e)],[[Mi],(e,[t])=>-t.evaluate(e)]]},"/":[Mi,[Mi,Mi],(e,[t,i])=>t.evaluate(e)/i.evaluate(e)],"%":[Mi,[Mi,Mi],(e,[t,i])=>t.evaluate(e)%i.evaluate(e)],ln2:[Mi,[],()=>Math.LN2],pi:[Mi,[],()=>Math.PI],e:[Mi,[],()=>Math.E],"^":[Mi,[Mi,Mi],(e,[t,i])=>Math.pow(t.evaluate(e),i.evaluate(e))],sqrt:[Mi,[Mi],(e,[t])=>Math.sqrt(t.evaluate(e))],log10:[Mi,[Mi],(e,[t])=>Math.log(t.evaluate(e))/Math.LN10],ln:[Mi,[Mi],(e,[t])=>Math.log(t.evaluate(e))],log2:[Mi,[Mi],(e,[t])=>Math.log2(t.evaluate(e))],sin:[Mi,[Mi],(e,[t])=>Math.sin(t.evaluate(e))],cos:[Mi,[Mi],(e,[t])=>Math.cos(t.evaluate(e))],tan:[Mi,[Mi],(e,[t])=>Math.tan(t.evaluate(e))],asin:[Mi,[Mi],(e,[t])=>Math.asin(t.evaluate(e))],acos:[Mi,[Mi],(e,[t])=>Math.acos(t.evaluate(e))],atan:[Mi,[Mi],(e,[t])=>Math.atan(t.evaluate(e))],min:[Mi,zo(Mi),(e,t)=>Math.min(...t.map(t=>t.evaluate(e)))],max:[Mi,zo(Mi),(e,t)=>Math.max(...t.map(t=>t.evaluate(e)))],abs:[Mi,[Mi],(e,[t])=>Math.abs(t.evaluate(e))],round:[Mi,[Mi],(e,[t])=>{const i=t.evaluate(e);return i<0?-Math.round(-i):Math.round(i)}],floor:[Mi,[Mi],(e,[t])=>Math.floor(t.evaluate(e))],ceil:[Mi,[Mi],(e,[t])=>Math.ceil(t.evaluate(e))],"filter-==":[Pi,[Ci,zi],(e,[t,i])=>e.properties()[t.value]===i.value],"filter-id-==":[Pi,[zi],(e,[t])=>e.id()===t.value],"filter-type-==":[Pi,[Ci],(e,[t])=>e.geometryType()===t.value],"filter-<":[Pi,[Ci,zi],(e,[t,i])=>{const r=e.properties()[t.value],n=i.value;return typeof r==typeof n&&r<n}],"filter-id-<":[Pi,[zi],(e,[t])=>{const i=e.id(),r=t.value;return typeof i==typeof r&&i<r}],"filter->":[Pi,[Ci,zi],(e,[t,i])=>{const r=e.properties()[t.value],n=i.value;return typeof r==typeof n&&r>n}],"filter-id->":[Pi,[zi],(e,[t])=>{const i=e.id(),r=t.value;return typeof i==typeof r&&i>r}],"filter-<=":[Pi,[Ci,zi],(e,[t,i])=>{const r=e.properties()[t.value],n=i.value;return typeof r==typeof n&&r<=n}],"filter-id-<=":[Pi,[zi],(e,[t])=>{const i=e.id(),r=t.value;return typeof i==typeof r&&i<=r}],"filter->=":[Pi,[Ci,zi],(e,[t,i])=>{const r=e.properties()[t.value],n=i.value;return typeof r==typeof n&&r>=n}],"filter-id->=":[Pi,[zi],(e,[t])=>{const i=e.id(),r=t.value;return typeof i==typeof r&&i>=r}],"filter-has":[Pi,[zi],(e,[t])=>t.value in e.properties()],"filter-has-id":[Pi,[],e=>null!==e.id()&&void 0!==e.id()],"filter-type-in":[Pi,[Bi(Ci)],(e,[t])=>t.value.includes(e.geometryType())],"filter-id-in":[Pi,[Bi(zi)],(e,[t])=>t.value.includes(e.id())],"filter-in-small":[Pi,[Ci,Bi(zi)],(e,[t,i])=>i.value.includes(e.properties()[t.value])],"filter-in-large":[Pi,[Ci,Bi(zi)],(e,[t,i])=>function(e,t,i,r){for(;i<=r;){const n=i+r>>1;if(t[n]===e)return!0;t[n]>e?r=n-1:i=n+1}return!1}(e.properties()[t.value],i.value,0,i.value.length-1)],all:{type:Pi,overloads:[[[Pi,Pi],(e,[t,i])=>t.evaluate(e)&&i.evaluate(e)],[zo(Pi),(e,t)=>{for(const i of t)if(!i.evaluate(e))return!1;return!0}]]},any:{type:Pi,overloads:[[[Pi,Pi],(e,[t,i])=>t.evaluate(e)||i.evaluate(e)],[zo(Pi),(e,t)=>{for(const i of t)if(i.evaluate(e))return!0;return!1}]]},"!":[Pi,[Pi],(e,[t])=>!t.evaluate(e)],"is-supported-script":[Pi,[Ci],(e,[t])=>{const i=e.globals&&e.globals.isSupportedScript;return!i||i(t.evaluate(e))}],upcase:[Ci,[Ci],(e,[t])=>t.evaluate(e).toUpperCase()],downcase:[Ci,[Ci],(e,[t])=>t.evaluate(e).toLowerCase()],concat:[Ci,zo(zi),(e,t)=>t.map(t=>Ki(t.evaluate(e))).join("")],"resolved-locale":[Ci,[Li],(e,[t])=>t.evaluate(e).resolvedLocale()],random:[Mi,[Mi,Mi,zi],(e,t)=>{const[i,r,n]=t.map(t=>t.evaluate(e));if(i>r)return i;if(i===r)return i;let o;if("string"==typeof n)o=function(e){let t=0;if(0===e.length)return t;for(let i=0;i<e.length;i++)t=(t<<5)-t+e.charCodeAt(i),t&=t;return t}(n);else{if("number"!=typeof n)throw new er(`Invalid seed input: ${n}`);o=n}return i+Ao(o)()*(r-i)}]});class Jo{constructor(e,t,i,r,n){this.expression=e,this._warningHistory={},this._scope=i,this._options=r,this._iconImageUseTheme=n,this._evaluator=new pr(i,r,n),this._defaultValue=t?function(e){return"color"===e.type&&(Go(e.default)||Array.isArray(e.default))?new xi(0,0,0,0):"color"===e.type?xi.parse(e.default)||null:void 0===e.default?null:e.default}(t):null,this._enumValues=t&&"enum"===t.type?t.values:null,this.configDependencies=Lo(e),this.isIndoorDependent=Fo(e)}evaluateWithoutErrorHandling(e,t,i,r,n,o,s,a){return this._evaluator.globals=e,this._evaluator.feature=t,this._evaluator.featureState=i,this._evaluator.canonical=r||null,this._evaluator.availableImages=n||null,this._evaluator.formattedSection=o,this._evaluator.featureTileCoord=s||null,this._evaluator.featureDistanceData=a||null,this.expression.evaluate(this._evaluator)}evaluate(e,t,i,r,n,o,s,a,l){this._evaluator||(this._evaluator=new pr(this._scope,this._options,this._iconImageUseTheme)),this._evaluator.globals=e,this._evaluator.feature=t||null,this._evaluator.featureState=i||null,this._evaluator.canonical=r||null,this._evaluator.availableImages=n||null,this._evaluator.formattedSection=o||null,this._evaluator.featureTileCoord=s||null,this._evaluator.featureDistanceData=a||null,this._evaluator.iconImageUseTheme=l||null;try{const e=this.expression.evaluate(this._evaluator);if(null==e||"number"==typeof e&&e!=e)return this._defaultValue;if(this._enumValues&&!(e in this._enumValues))throw new er(`Expected value to be one of ${Object.keys(this._enumValues).map(e=>JSON.stringify(e)).join(", ")}, but found ${JSON.stringify(e)} instead.`);return e}catch(e){const t=e;return this._warningHistory[t.message]||(this._warningHistory[t.message]=!0,"undefined"!=typeof console&&console.warn(`Failed to evaluate expression "${JSON.stringify(this.expression.serialize())}". ${t.message}`)),this._defaultValue}}}function Ko(e){return Array.isArray(e)&&e.length>0&&"string"==typeof e[0]&&e[0]in Mo}function Qo(e,t,i,r,n){const o=new Ln(Mo,[],t?function(e){const t={color:Di,string:Ci,number:Mi,enum:Ci,boolean:Pi,formatted:Fi,resolvedImage:Oi};return"array"===e.type?Bi(t[e.value]||zi,e.length):t[e.type]}(t):void 0,void 0,void 0,i,r,n),s=o.parse(e,void 0,void 0,void 0,t&&"string"===t.type?{typeAnnotation:"coerce"}:void 0);return s?Oo(new Jo(s,t,i,r,n)):Bo(o.errors)}class es{constructor(e,t,i,r){this.kind=e,this._styleExpression=t,this.isLightConstant=i,this.isLineProgressConstant=r,this.isStateDependent="constant"!==e&&!An(t.expression),this.configDependencies=Lo(t.expression),this.isIndoorDependent=Fo(t.expression)}evaluateWithoutErrorHandling(e,t,i,r,n,o){return this._styleExpression.evaluateWithoutErrorHandling(e,t,i,r,n,o)}evaluate(e,t,i,r,n,o,s){return this._styleExpression.evaluate(e,t,i,r,n,o,void 0,void 0,s)}}class ts{constructor(e,t,i,r,n,o){this.kind=e,this.zoomStops=i,this._styleExpression=t,this.isStateDependent="camera"!==e&&!An(t.expression),this.isIndoorDependent=Fo(t.expression),this.isLightConstant=n,this.isLineProgressConstant=o,this.configDependencies=Lo(t.expression),this.interpolationType=r}evaluateWithoutErrorHandling(e,t,i,r,n,o){return this._styleExpression.evaluateWithoutErrorHandling(e,t,i,r,n,o)}evaluate(e,t,i,r,n,o){return this._styleExpression.evaluate(e,t,i,r,n,o)}interpolationFactor(e,t,i){return this.interpolationType?io.interpolationFactor(this.interpolationType,e,t,i):0}}function is(e,t,i,r,n){if("error"===(e=Qo(e,t,i,r,n)).result)return e;const o=e.value.expression,s=En(o);if(!s&&!No(t))return Bo([new Ii("","data expressions not supported")]);const a=Mn(o,["zoom","pitch","distance-from-center"]);if(!a&&!Vo(t))return Bo([new Ii("","zoom expressions not supported")]);const l=Mn(o,["measure-light"]);if(!l&&!Uo(t))return Bo([new Ii("","measure-light expression not supported")]);const c=Mn(o,["line-progress"]);if(!c&&!function(e){return ko(e.expression,"line-progress")}(t))return Bo([new Ii("","line-progress expression not supported")]);const h=t.expression&&t.expression.relaxZoomRestriction,u=ns(o);return u||a||h?u instanceof Ii?Bo([u]):u instanceof io&&!jo(t)?Bo([new Ii("",'"interpolate" expressions cannot be used with this property')]):Oo(u?new ts(s&&c?"camera":"composite",e.value,u.labels,u instanceof io?u.interpolation:void 0,l,c):new es(s&&c?"constant":"source",e.value,l,c)):Bo([new Ii("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression, or in the properties of atmosphere.')])}class rs{constructor(e,t){this._parameters=e,this._specification=t,Object.assign(this,$o(this._parameters,this._specification))}static deserialize(e){return new rs(e._parameters,e._specification)}static serialize(e){return{_parameters:e._parameters,_specification:e._specification}}}function ns(e){let t=null;if(e instanceof so)t=ns(e.result);else if(e instanceof no){for(const i of e.args)if(t=ns(i),t)break}else(e instanceof Bn||e instanceof io)&&e.input instanceof fr&&"zoom"===e.input.name&&(t=e);return t instanceof Ii||e.eachChild(e=>{const i=ns(e);i instanceof Ii?t=i:t&&i&&t!==i&&(t=new Ii("",'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'))}),t}class os{constructor(e,t,i){if(this.boxSeen=new Uint32Array(0),this.circleSeen=new Uint32Array(0),this.generation=0,e instanceof ArrayBuffer){const t=new Int32Array(e);this.width=t[0],this.height=t[1],this.xCellCount=t[2],this.yCellCount=t[3],this.boxUid=t[4],this.circleUid=t[5];const i=this.xCellCount*this.yCellCount,r=[];for(let e=0;e<i;e++){const i=t[6+e],n=t[6+e+1];r.push(i===n?null:t.subarray(i,n))}const n=t[6+i],o=[];for(let e=0;e<i;e++){const i=t[n+e],r=t[n+e+1];o.push(i===r?null:t.subarray(i,r))}let s=t[n+i];this.boxCells=r,this.circleCells=o,this.boxKeys=t.subarray(s,s+this.boxUid),s+=this.boxUid,this.circleKeys=t.subarray(s,s+this.circleUid),s+=this.circleUid,this.bboxes=t.subarray(s,s+4*this.boxUid),s+=4*this.boxUid,this.circles=t.subarray(s,s+3*this.circleUid)}else{this.width=e,this.height=t,this.xCellCount=Math.ceil(e/i),this.yCellCount=Math.ceil(t/i);const r=this.xCellCount*this.yCellCount,n=[],o=[];for(let e=0;e<r;e++)n.push([]),o.push([]);this.boxCells=n,this.circleCells=o,this.boxKeys=[],this.circleKeys=[],this.bboxes=[],this.circles=[],this.boxUid=0,this.circleUid=0}this.xScale=this.xCellCount/this.width,this.yScale=this.yCellCount/this.height}keysLength(){return this.boxKeys.length+this.circleKeys.length}insert(e,t,i,r,n){const o=this.boxUid++,s=this._xCell(t),a=this._yCell(i),l=this._xCell(r),c=this._yCell(n);for(let h=s;h<=l;h++)for(let e=a;e<=c;e++)this.boxCells[this.xCellCount*e+h].push(o);this.boxKeys.push(e),this.bboxes.push(t,i,r,n)}insertCircle(e,t,i,r){const n=this.circleUid++,o=this._xCell(t-r),s=this._yCell(i-r),a=this._xCell(t+r),l=this._yCell(i+r);for(let c=o;c<=a;c++)for(let e=s;e<=l;e++)this.circleCells[this.xCellCount*e+c].push(n);this.circleKeys.push(e),this.circles.push(t,i,r)}query(e,t,i,r,n){const o=[];if(i<0||e>this.width||r<0||t>this.height)return o;const s=this._nextGen(),{boxCells:a,circleCells:l,boxKeys:c,circleKeys:h,bboxes:u,circles:d,boxSeen:p,circleSeen:f,xCellCount:m}=this,_=this._xCell(e),g=this._yCell(t),y=this._xCell(i),x=this._yCell(r);for(let v=_;v<=y;v++)for(let _=g;_<=x;_++){const g=m*_+v,y=a[g];if(y)for(let a=0;a<y.length;a++){const l=y[a];if(p[l]===s)continue;p[l]=s;const h=4*l,d=u[h],f=u[h+1],m=u[h+2],_=u[h+3];e<=m&&t<=_&&i>=d&&r>=f&&(!n||n(c[l]))&&o.push({key:c[l],x1:d,y1:f,x2:m,y2:_})}const x=l[g];if(x)for(let a=0;a<x.length;a++){const l=x[a];if(f[l]===s)continue;f[l]=s;const c=3*l,u=d[c],p=d[c+1],m=d[c+2];!this._circleAndRectCollide(u,p,m,e,t,i,r)||n&&!n(h[l])||o.push({key:h[l],x1:u-m,y1:p-m,x2:u+m,y2:p+m})}}return o}queryKeys(e,t,i,r,n){const o=[];if(i<0||e>this.width||r<0||t>this.height)return o;const s=this._nextGen(),{boxCells:a,boxKeys:l,bboxes:c,boxSeen:h,xCellCount:u,xScale:d,yScale:p}=this,f=this._xCell(e),m=this._yCell(t),_=this._xCell(i),g=this._yCell(r);for(let y=f;y<=_;y++)for(let f=m;f<=g;f++){if(n&&!n(y/d,f/p,(y+1)/d,(f+1)/p))continue;const m=a[u*f+y];if(m)for(let a=0;a<m.length;a++){const u=m[a];if(h[u]===s)continue;h[u]=s;const d=4*u,p=c[d],f=c[d+1],_=c[d+2],g=c[d+3];(n?n(p,f,_,g):e<=_&&t<=g&&i>=p&&r>=f)&&o.push(l[u])}}return o}hitTest(e,t,i,r,n){if(i<0||e>this.width||r<0||t>this.height)return!1;const o=this._nextGen(),{boxCells:s,circleCells:a,boxKeys:l,circleKeys:c,bboxes:h,circles:u,boxSeen:d,circleSeen:p,xCellCount:f}=this,m=this._xCell(e),_=this._yCell(t),g=this._xCell(i),y=this._yCell(r);for(let x=m;x<=g;x++)for(let m=_;m<=y;m++){const _=f*m+x,g=s[_];if(g)for(let s=0;s<g.length;s++){const a=g[s];if(d[a]===o)continue;d[a]=o;const c=4*a;if(e<=h[c+2]&&t<=h[c+3]&&i>=h[c]&&r>=h[c+1]&&(!n||n(l[a])))return!0}const y=a[_];if(y)for(let s=0;s<y.length;s++){const a=y[s];if(p[a]===o)continue;p[a]=o;const l=3*a;if(this._circleAndRectCollide(u[l],u[l+1],u[l+2],e,t,i,r)&&(!n||n(c[a])))return!0}}return!1}hitTestCircle(e,t,i,r){const n=e-i,o=t-i,s=e+i,a=t+i;if(s<0||n>this.width||a<0||o>this.height)return!1;const l=this._nextGen(),{boxCells:c,circleCells:h,boxKeys:u,circleKeys:d,bboxes:p,circles:f,boxSeen:m,circleSeen:_,xCellCount:g}=this,y=this._xCell(n),x=this._yCell(o),v=this._xCell(s),b=this._yCell(a);for(let w=y;w<=v;w++)for(let n=x;n<=b;n++){const o=g*n+w,s=c[o];if(s)for(let n=0;n<s.length;n++){const o=s[n];if(m[o]===l)continue;m[o]=l;const a=4*o;if(this._circleAndRectCollide(e,t,i,p[a],p[a+1],p[a+2],p[a+3])&&(!r||r(u[o])))return!0}const a=h[o];if(a)for(let n=0;n<a.length;n++){const o=a[n];if(_[o]===l)continue;_[o]=l;const s=3*o;if(this._circlesCollide(f[s],f[s+1],f[s+2],e,t,i)&&(!r||r(d[o])))return!0}}return!1}static serialize(e,t){const i=e.toArrayBuffer();return t&&t.add(i),{buffer:i}}static deserialize(e){return new os(e.buffer)}toArrayBuffer(){const e=this.xCellCount*this.yCellCount;let t=0,i=0;for(let s=0;s<e;s++)t+=this.boxCells[s].length,i+=this.circleCells[s].length;const r=new Int32Array(6+(e+1)+t+(e+1)+i+this.boxUid+this.circleUid+4*this.boxUid+3*this.circleUid);r[0]=this.width,r[1]=this.height,r[2]=this.xCellCount,r[3]=this.yCellCount,r[4]=this.boxUid,r[5]=this.circleUid;let n=6+(e+1);for(let s=0;s<e;s++){r[6+s]=n;const e=this.boxCells[s];r.set(e,n),n+=e.length}r[6+e]=n;const o=n;n+=e+1;for(let s=0;s<e;s++){r[o+s]=n;const e=this.circleCells[s];r.set(e,n),n+=e.length}return r[o+e]=n,r.set(this.boxKeys,n),n+=this.boxUid,r.set(this.circleKeys,n),n+=this.circleUid,r.set(this.bboxes,n),n+=4*this.boxUid,r.set(this.circles,n),r.buffer}_xCell(e){return Math.max(0,Math.min(this.xCellCount-1,Math.floor(e*this.xScale)))}_yCell(e){return Math.max(0,Math.min(this.yCellCount-1,Math.floor(e*this.yScale)))}_nextGen(){return this.boxSeen.length<this.boxUid&&(this.boxSeen=new Uint32Array(this.boxUid)),this.circleSeen.length<this.circleUid&&(this.circleSeen=new Uint32Array(this.circleUid)),this.generation=this.generation+1>>>0,0===this.generation&&(this.boxSeen.fill(0),this.circleSeen.fill(0),this.generation=1),this.generation}_circlesCollide(e,t,i,r,n,o){const s=r-e,a=n-t,l=i+o;return l*l>s*s+a*a}_circleAndRectCollide(e,t,i,r,n,o,s){const a=(o-r)/2,l=Math.abs(e-(r+a));if(l>a+i)return!1;const c=(s-n)/2,h=Math.abs(t-(n+c));if(h>c+i)return!1;if(l<=a||h<=c)return!0;const u=l-a,d=h-c;return u*u+d*d<=i*i}}const ss={};function as(e,t,i={}){Object.defineProperty(e,"_classRegistryKey",{value:t,writable:!1}),ss[t]={klass:e,omit:i.omit||[]}}as(Object,"Object"),as(os,"Grid"),delete Ie.prototype.constructor,as(xi,"Color"),as(Error,"Error"),as(qi,"Formatted"),as($i,"FormattedSection"),as(Ht,"AJAXError"),as(Wi,"ResolvedImage"),as(rs,"StylePropertyFunction"),as(Jo,"StyleExpression",{omit:["_evaluator"]}),as(fi,"ImageId"),as(Zi,"ImageVariant"),as(ts,"ZoomDependentExpression"),as(es,"ZoomConstantExpression"),as(fr,"CompoundExpression",{omit:["_evaluate"]});for(const tT in Mo)ss[Mo[tT]._classRegistryKey]||as(Mo[tT],`Expression${tT}`);function ls(e){return e&&(e instanceof ArrayBuffer||e.constructor&&"ArrayBuffer"===e.constructor.name)}function cs(e,t){if(null===e)return null;const i=typeof e;if("object"!==i)return"bigint"===i?{$name:"BigInt",value:e.toString()}:e;if(Array.isArray(e)){const i=e.length,r=[];r.length=i;for(let n=0;n<i;n++)r[n]=cs(e[n],t);return r}if(ArrayBuffer.isView(e))return t&&t.add(e.buffer),e;if(ls(e)||e instanceof ImageBitmap)return t&&t.add(e),e;if(e instanceof ImageData)return t&&t.add(e.data.buffer),e;if(e instanceof Map){const i={$name:"Map",entries:[]};for(const[r,n]of e.entries())i.entries.push(cs(r),cs(n,t));return i}if(e instanceof Set){const t={$name:"Set"};let i=0;for(const r of e.values())t[++i]=cs(r);return t}if(e instanceof Date||e instanceof RegExp||e instanceof Boolean||e instanceof Number||e instanceof String)return e;const r=e.constructor,n=r._classRegistryKey;if(!n)throw new Error(`Can't serialize object of unregistered class "${r.name}".`);const o=r.serialize?r.serialize(e,t):{};if(!r.serialize){const i=ss[n].omit,r=e;for(const e in r)Object.hasOwn(r,e)&&(i.includes(e)||(o[e]=cs(r[e],t)));e instanceof Error&&(o.message=e.message)}if(o.$name)throw new Error("$name property is reserved for worker serialization logic.");return"Object"!==n&&(o.$name=n),o}function hs(e){if(null===e||"object"!=typeof e)return e;if(Array.isArray(e)){for(let t=0;t<e.length;t++)e[t]=hs(e[t]);return e}if(ArrayBuffer.isView(e)||ls(e)||e instanceof ImageBitmap||e instanceof ImageData||e instanceof Date||e instanceof RegExp||e instanceof Boolean||e instanceof Number||e instanceof String)return e;const t=e.$name||"Object";if("Map"===t){const t=e.entries||[],i=/* @__PURE__ */new Map;for(let e=0;e<t.length;e+=2)i.set(hs(t[e]),hs(t[e+1]));return i}if("Set"===t){const t=/* @__PURE__ */new Set;for(const i in e)"$name"!==i&&t.add(hs(e[i]));return t}if("BigInt"===t)return BigInt(e.value);const{klass:i}=ss[t];if(!i)throw new Error(`Can't deserialize unregistered class "${t}".`);if(i.deserialize)return i.deserialize(e);const r=Object.create(i.prototype);for(const n in e)"$name"!==n&&(r[n]=hs(e[n]));return r}const us=e=>e>=1536&&e<=1791,ds=e=>e>=1872&&e<=1919,ps=e=>e>=2208&&e<=2303,fs=e=>e>=11904&&e<=12031,ms=e=>e>=12032&&e<=12255,_s=e=>e>=12272&&e<=12287,gs=e=>e>=12288&&e<=12351,ys=e=>e>=12352&&e<=12447,xs=e=>e>=12448&&e<=12543,vs=e=>e>=12544&&e<=12591,bs=e=>e>=12704&&e<=12735,ws=e=>e>=12736&&e<=12783,Ts=e=>e>=12784&&e<=12799,Ss=e=>e>=12800&&e<=13055,Is=e=>e>=13056&&e<=13311,Es=e=>e>=13312&&e<=19903,As=e=>e>=19968&&e<=40959,Ms=e=>e>=40960&&e<=42127,Cs=e=>e>=42128&&e<=42191,Ps=e=>e>=44032&&e<=55215,Ds=e=>e>=63744&&e<=64255,Rs=e=>e>=64336&&e<=65023,zs=e=>e>=65040&&e<=65055,Ls=e=>e>=65072&&e<=65103,Fs=e=>e>=65104&&e<=65135,Os=e=>e>=65136&&e<=65279,Bs=e=>e>=65280&&e<=65519;function ks(e){for(const t of e)if(js(t.charCodeAt(0)))return!0;return!1}function Ns(e){for(const t of e)if(!Us(t.charCodeAt(0)))return!1;return!0}function Us(e){return!(us(e)||ds(e)||ps(e)||Rs(e)||Os(e))}function Vs(e){return!(e<11904||!(bs(e)||vs(e)||Ls(e)||Ds(e)||Is(e)||fs(e)||ws(e)||gs(e)||Es(e)||As(e)||Ss(e)||Bs(e)||ys(e)||_s(e)||ms(e)||Ts(e)||xs(e)||zs(e)||Cs(e)||Ms(e)))}function js(e){return!(746!==e&&747!==e&&(e<4352||!(bs(e)||vs(e)||Ls(e)&&!(e>=65097&&e<=65103)||Ds(e)||Is(e)||fs(e)||ws(e)||!(!gs(e)||e>=12296&&e<=12305||e>=12308&&e<=12319||12336===e)||Es(e)||As(e)||Ss(e)||(e=>e>=12592&&e<=12687)(e)||(e=>e>=43360&&e<=43391)(e)||(e=>e>=55216&&e<=55295)(e)||(e=>e>=4352&&e<=4607)(e)||Ps(e)||ys(e)||_s(e)||(e=>e>=12688&&e<=12703)(e)||ms(e)||Ts(e)||xs(e)&&12540!==e||!(!Bs(e)||65288===e||65289===e||65293===e||e>=65306&&e<=65310||65339===e||65341===e||65343===e||e>=65371&&e<=65503||65507===e||e>=65512&&e<=65519)||!(!Fs(e)||e>=65112&&e<=65118||e>=65123&&e<=65126)||(e=>e>=5120&&e<=5759)(e)||(e=>e>=6320&&e<=6399)(e)||zs(e)||(e=>e>=19904&&e<=19967)(e)||Ms(e)||Cs(e))))}function Gs(e){return 12312===e||12313===e||12316===e||12540===e||12448===e}function Hs(e){return!(js(e)||function(e){return!!((e=>e>=128&&e<=255)(e)&&(167===e||169===e||174===e||177===e||188===e||189===e||190===e||215===e||247===e)||(e=>e>=8192&&e<=8303)(e)&&(8214===e||8224===e||8225===e||8240===e||8241===e||8251===e||8252===e||8258===e||8263===e||8264===e||8265===e||8273===e)||(e=>e>=8448&&e<=8527)(e)||(e=>e>=8528&&e<=8591)(e)||(e=>e>=8960&&e<=9215)(e)&&(e>=8960&&e<=8967||e>=8972&&e<=8991||e>=8996&&e<=9e3||9003===e||e>=9085&&e<=9114||e>=9150&&e<=9165||9167===e||e>=9169&&e<=9179||e>=9186&&e<=9215)||(e=>e>=9216&&e<=9279)(e)&&9251!==e||(e=>e>=9280&&e<=9311)(e)||(e=>e>=9312&&e<=9471)(e)||(e=>e>=9632&&e<=9727)(e)||(e=>e>=9728&&e<=9983)(e)&&!(e>=9754&&e<=9759)||(e=>e>=11008&&e<=11263)(e)&&(e>=11026&&e<=11055||e>=11088&&e<=11097||e>=11192&&e<=11243)||gs(e)||xs(e)||(e=>e>=57344&&e<=63743)(e)||Ls(e)||Fs(e)||Bs(e)||8734===e||8756===e||8757===e||e>=9984&&e<=10087||e>=10102&&e<=10131||65532===e||65533===e)}(e))}function $s(e){return us(e)||ds(e)||ps(e)||Rs(e)||Os(e)}function qs(e){return e>=1424&&e<=2303||Rs(e)||Os(e)}function Zs(e,t){return!(!t&&qs(e)||e>=2304&&e<=3583||e>=3840&&e<=4255||(e=>e>=6016&&e<=6143)(e))}function Ws(e){for(const t of e)if(qs(t.charCodeAt(0)))return!0;return!1}const Xs={unavailable:"unavailable",deferred:"deferred",loading:"loading",parsing:"parsing",parsed:"parsed",loaded:"loaded",error:"error"};let Ys=null,Js=Xs.unavailable,Ks=null;const Qs=function(e){e&&(Js=Xs.error),Ys&&Ys(e)};function ea(){ta.fire(new ci("pluginStateChange",{pluginStatus:Js,pluginURL:Ks}))}const ta=new pi,ia=function(){return Js},ra=function(){if(Js!==Xs.deferred||!Ks)throw new Error("rtl-text-plugin cannot be downloaded unless a pluginURL is specified");Js=Xs.loading,ea(),Ks&&Jt({url:Ks},e=>{e?Qs(e):(Js=Xs.loaded,ea())})},na={applyArabicShaping:null,processBidirectionalText:null,processStyledBidirectionalText:null,isLoaded:()=>Js===Xs.loaded||null!=na.applyArabicShaping,isLoading:()=>Js===Xs.loading,setState(e){Js=e.pluginStatus,Ks=e.pluginURL},isParsing:()=>Js===Xs.parsing,isParsed:()=>Js===Xs.parsed,getPluginURL:()=>Ks},oa=function(){na.isLoading()||na.isLoaded()||"deferred"!==ia()||ra()};class sa{constructor(e,t){this.zoom=e,t?(this.now=t.now,this.fadeDuration=t.fadeDuration,this.transition=t.transition,this.pitch=t.pitch,this.brightness=t.brightness,this.worldview=t.worldview,this.activeFloors=t.activeFloors):(this.now=0,this.fadeDuration=0,this.transition={},this.pitch=0,this.brightness=0)}isSupportedScript(e){return function(e,t){for(const i of e)if(!Zs(i.charCodeAt(0),t))return!1;return!0}(e,na.isLoaded())}}class aa{constructor(e,t,i,r,n){this.property=e,this.value=t,this.expression=function(e,t,i,r,n){if(Go(e))return new rs(e,t);if(Ko(e)||Array.isArray(e)&&e.length>0){const o=is(e,t,i,r,n);if("error"===o.result)throw new Error(o.value.map(e=>`${e.key}: ${e.message}`).join(", "));return o.value}{let i=e;return"string"==typeof e&&"color"===t.type&&(i=xi.parse(e)),{kind:"constant",configDependencies:/* @__PURE__ */new Set,isIndoorDependent:!1,evaluate:()=>i}}}(void 0===t?e.specification.default:t,e.specification,i,r,n)}isIndoorDependent(){return this.expression.isIndoorDependent}isDataDriven(){return"source"===this.expression.kind||"composite"===this.expression.kind}possiblyEvaluate(e,t,i,r){return this.property.possiblyEvaluate(this,e,t,i,r)}}class la{constructor(e,t,i,r){this.property=e,this.value=new aa(e,void 0,t,i,r)}transitioned(e,t){return new ha(this.property,this.value,t,Object.assign({},e.transition,this.transition),e.now)}untransitioned(){return new ha(this.property,this.value,null,{},0)}}class ca{constructor(e,t,i,r){this._properties=e,this._values=Object.create(e.defaultTransitionablePropertyValues),this._scope=t,this._options=i,this._iconImageUseTheme=r,this._isIndoorDependent=!1,this.configDependencies=/* @__PURE__ */new Set}getValue(e){return Xe(this._values[e].value.value)}setValue(e,t){Object.hasOwn(this._values,e)||(this._values[e]=new la(this._values[e].property,this._scope,this._options,this._iconImageUseTheme)),this._values[e].value=new aa(this._values[e].property,null===t?void 0:Xe(t),this._scope,this._options,this._iconImageUseTheme),this._values[e].value.expression.configDependencies&&(this.configDependencies=new Set([...this.configDependencies,...this._values[e].value.expression.configDependencies]),this._isIndoorDependent=this._isIndoorDependent||this._values[e].value.isIndoorDependent())}setTransitionOrValue(e,t){t&&(this._options=t);const i=this._properties.properties;if(e)for(const r in e){const t=e[r];if(r.endsWith("-transition")){const e=r.slice(0,-11);i[e]&&this.setTransition(e,t)}else Object.hasOwn(i,r)&&this.setValue(r,t)}}getTransition(e){return Xe(this._values[e].transition)}setTransition(e,t){Object.hasOwn(this._values,e)||(this._values[e]=new la(this._values[e].property)),this._values[e].transition=Xe(t)||void 0}serialize(){const e={};for(const t of Object.keys(this._values)){const i=this.getValue(t);void 0!==i&&(e[t]=i);const r=this.getTransition(t);void 0!==r&&(e[`${t}-transition`]=r)}return e}transitioned(e,t){const i=new ua(this._properties);for(const r of Object.keys(this._values))i._values[r]=this._values[r].transitioned(e,t._values[r]);return i}untransitioned(){const e=new ua(this._properties);for(const t of Object.keys(this._values))e._values[t]=this._values[t].untransitioned();return e}isIndoorDependent(){return this._isIndoorDependent}}class ha{constructor(e,t,i,r,n){const o=r.delay||0,s=r.duration||0;n=n||0,this.property=e,this.value=t,this.begin=n+o,this.end=this.begin+s,e.specification.transition&&(r.delay||r.duration)&&(this.prior=i)}possiblyEvaluate(e,t,i){const r=e.now||0,n=this.value.possiblyEvaluate(e,t,i),o=this.prior;if(o){if(r>this.end)return this.prior=null,n;if(this.value.isDataDriven())return this.prior=null,n;if(r<this.begin)return o.possiblyEvaluate(e,t,i);{const s=(r-this.begin)/(this.end-this.begin);return this.property.interpolate(o.possiblyEvaluate(e,t,i),n,Fe(s))}}return n}}class ua{constructor(e){this._properties=e,this._values=Object.create(e.defaultTransitioningPropertyValues)}possiblyEvaluate(e,t,i){const r=new fa(this._properties);for(const n of Object.keys(this._values))r._values[n]=this._values[n].possiblyEvaluate(e,t,i);return r}hasTransition(){for(const e of Object.keys(this._values))if(this._values[e].prior)return!0;return!1}}class da{constructor(e,t,i,r){this._properties=e,this._values=Object.create(e.defaultPropertyValues),this._scope=t,this._options=i,this._iconImageUseTheme=r,this._isIndoorDependent=!1,this.configDependencies=/* @__PURE__ */new Set}getValue(e){return Xe(this._values[e].value)}setValue(e,t){this._values[e]=new aa(this._values[e].property,null===t?void 0:Xe(t),this._scope,this._options,this._iconImageUseTheme),this._values[e].expression.configDependencies&&(this.configDependencies=new Set([...this.configDependencies,...this._values[e].expression.configDependencies]),this._isIndoorDependent=this._isIndoorDependent||this._values[e].isIndoorDependent())}serialize(){const e={};for(const t of Object.keys(this._values)){const i=this.getValue(t);void 0!==i&&(e[t]=i)}return e}possiblyEvaluate(e,t,i,r){const n=new fa(this._properties);for(const o of Object.keys(this._values))n._values[o]=this._values[o].possiblyEvaluate(e,t,i,r);return n}isIndoorDependent(){return this._isIndoorDependent}}class pa{constructor(e,t,i,r){this.property=e,this.value=t,this.parameters=i,this.iconImageUseTheme=r}isConstant(){return"constant"===this.value.kind}constantOr(e){return"constant"===this.value.kind?this.value.value:e}evaluate(e,t,i,r,n){return this.property.evaluate(this.value,this.parameters,e,t,i,r,this.iconImageUseTheme,n)}}class fa{constructor(e){this._properties=e,this._values=Object.create(e.defaultPossiblyEvaluatedValues)}get(e){return this._values[e]}}class ma{constructor(e){this.specification=e}possiblyEvaluate(e,t){return e.expression.evaluate(t)}interpolate(e,t,i){const r=Si[this.specification.type];return r?r(e,t,i):e}}class _a{constructor(e,t){this.specification=e,this.overrides=t}possiblyEvaluate(e,t,i,r,n){return"constant"===e.expression.kind||"camera"===e.expression.kind?new pa(this,{kind:"constant",value:e.expression.evaluate(t,null,{},i,r,void 0,n)},t):new pa(this,e.expression,t,n)}interpolate(e,t,i){if("constant"!==e.value.kind||"constant"!==t.value.kind)return e;if(void 0===e.value.value||void 0===t.value.value)return new pa(this,{kind:"constant",value:void 0},e.parameters);const r=Si[this.specification.type];return r?new pa(this,{kind:"constant",value:r(e.value.value,t.value.value,i)},e.parameters):e}evaluate(e,t,i,r,n,o,s,a){return"constant"===e.kind?e.value:e.evaluate(t,i,r,n,o,a,s)}}class ga{constructor(e){this.specification=e}possiblyEvaluate(e,t,i,r){return!!e.expression.evaluate(t,null,{},i,r)}interpolate(){return!1}}class ya{constructor(e){this.properties=e,this.defaultPropertyValues={},this.defaultTransitionablePropertyValues={},this.defaultTransitioningPropertyValues={},this.defaultPossiblyEvaluatedValues={},this.overridableProperties=[];const t=new sa(0,{});for(const i in e){const r=e[i],n=r.specification;n&&n.overridable&&this.overridableProperties.push(i);const o=this.defaultPropertyValues[i]=new aa(r,void 0),s=this.defaultTransitionablePropertyValues[i]=new la(r);this.defaultTransitioningPropertyValues[i]=s.untransitioned(),this.defaultPossiblyEvaluatedValues[i]=o.possiblyEvaluate(t)}}}as(_a,"DataDrivenProperty"),as(ma,"DataConstantProperty"),as(ga,"ColorRampProperty");var xa=JSON.parse('{"$version":8,"$root":{"version":{"type":"enum","values":[8]},"fragment":{"type":"boolean"},"name":{"type":"string"},"metadata":{"type":"*"},"center":{"type":"array","value":"number"},"zoom":{"type":"number"},"bearing":{"type":"number","default":0,"period":360},"pitch":{"type":"number","default":0},"light":{"type":"light"},"lights":{"type":"array","value":"light-3d"},"terrain":{"type":"terrain","optional":true},"fog":{"type":"fog"},"snow":{"type":"snow"},"rain":{"type":"rain"},"camera":{"type":"camera"},"color-theme":{"type":"colorTheme"},"indoor":{"type":"indoor"},"imports":{"type":"array","value":"import"},"iconsets":{"type":"iconsets"},"schema":{"type":"schema"},"sources":{"type":"sources"},"sprite":{"type":"string"},"glyphs":{"type":"string","default":"mapbox://fonts/mapbox/{fontstack}/{range}.pbf"},"transition":{"type":"transition"},"projection":{"type":"projection"},"layers":{"type":"array","value":"layer"},"models":{"type":"models"},"featuresets":{"type":"featuresets"}},"featuresets":{"*":{"type":"featureset"}},"featureset":{"metadata":{"type":"*"},"selectors":{"type":"array","value":"selector"}},"selector":{"layer":{"type":"string"},"properties":{"type":"selectorProperty"},"featureNamespace":{"type":"string"},"_uniqueFeatureID":{"type":"boolean"}},"selectorProperty":{"*":{"type":"*"}},"model":{"type":"string"},"import":{"id":{"type":"string"},"url":{"type":"string"},"config":{"type":"config"},"data":{"type":"$root"},"color-theme":{"type":"colorTheme","optional":true}},"config":{"*":{"type":"*"}},"schema":{"*":{"type":"option"}},"option":{"default":{"type":"*","expression":{}},"type":{"type":"enum","values":{"string":1,"number":1,"boolean":1,"color":1}},"array":{"type":"boolean"},"minValue":{"type":"number"},"maxValue":{"type":"number"},"stepValue":{"type":"number"},"values":{"type":"array","value":"*"},"metadata":{"type":"*"}},"models":{"*":{"type":"model"}},"light-3d":{"id":{"type":"string"},"properties":{"type":"properties"},"type":{"type":"enum","values":{"ambient":{},"directional":{},"flat":{}}}},"properties":["properties_light_directional","properties_light_ambient","properties_light_flat"],"properties_light_directional":{"direction":{"type":"array","default":[210,30],"minimum":[0,0],"maximum":[360,90],"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"use-theme":true,"transition":true},"intensity":{"type":"number","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"cast-shadows":{"type":"boolean","default":false},"shadow-quality":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"parameters":["zoom"]}},"shadow-intensity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"shadow-draw-before-layer":{"type":"string"}},"properties_light_ambient":{"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"use-theme":true,"transition":true},"intensity":{"type":"number","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"properties_light_flat":{"anchor":{"type":"enum","default":"viewport","values":{"map":1,"viewport":1},"expression":{"parameters":["zoom"]}},"position":{"type":"array","default":[1.15,210,30],"length":3,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"use-theme":true,"transition":true},"intensity":{"type":"number","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"iconsets":{"*":{"type":"iconset"}},"iconset":["iconset_sprite","iconset_source"],"iconset_sprite":{"type":{"type":"enum","values":{"sprite":1}},"url":{"type":"string"}},"iconset_source":{"type":{"type":"enum","values":{"source":1}},"source":{"type":"string"}},"sources":{"*":{"type":"source"}},"source":["source_vector","source_raster","source_raster_dem","source_raster_array","source_geojson","source_video","source_image","source_model"],"source_vector":{"type":{"type":"enum","values":{"vector":1}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"extra_bounds":{"type":"array","value":{"type":"array","value":"number","length":4}},"scheme":{"type":"enum","values":{"xyz":1,"tms":1},"default":"xyz"},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"attribution":{"type":"string"},"promoteId":{"type":"promoteId"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster":{"type":{"type":"enum","values":{"raster":1}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"extra_bounds":{"type":"array","value":{"type":"array","value":"number","length":4}},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512},"scheme":{"type":"enum","values":{"xyz":1,"tms":1},"default":"xyz"},"attribution":{"type":"string"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_dem":{"type":{"type":"enum","values":{"raster-dem":1}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"extra_bounds":{"type":"array","value":{"type":"array","value":"number","length":4}},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512},"attribution":{"type":"string"},"encoding":{"type":"enum","values":{"terrarium":1,"mapbox":1},"default":"mapbox"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_array":{"type":{"type":"enum","values":{"raster-array":1}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"extra_bounds":{"type":"array","value":{"type":"array","value":"number","length":4}},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512},"attribution":{"type":"string"},"rasterLayers":{"type":"*"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_geojson":{"type":{"type":"enum","values":{"geojson":1}},"data":{"type":"*"},"maxzoom":{"type":"number","default":18},"minzoom":{"type":"number","default":0},"attribution":{"type":"string"},"buffer":{"type":"number","default":128,"maximum":512,"minimum":0},"filter":{"type":"*"},"tolerance":{"type":"number","default":0.375},"cluster":{"type":"boolean","default":false},"clusterRadius":{"type":"number","default":50,"minimum":0},"clusterMaxZoom":{"type":"number"},"clusterMinPoints":{"type":"number"},"clusterProperties":{"type":"*"},"lineMetrics":{"type":"boolean","default":false},"generateId":{"type":"boolean","default":false},"promoteId":{"type":"promoteId"},"dynamic":{"type":"boolean","default":false}},"source_video":{"type":{"type":"enum","values":{"video":1}},"urls":{"type":"array","value":"string"},"coordinates":{"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"source_image":{"type":{"type":"enum","values":{"image":1}},"url":{"type":"string"},"coordinates":{"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"modelNodeOverride":{"orientation":{"type":"array","value":"number","length":3,"default":[0,0,0],"period":360}},"modelNodeOverrides":{"*":{"type":"modelNodeOverride"}},"modelMaterialOverride":{"model-color":{"type":"color"},"model-color-mix-intensity":{"type":"number"},"model-opacity":{"type":"number"},"model-emissive-strength":{"type":"number"}},"modelMaterialOverrides":{"*":{"type":"modelMaterialOverride"}},"modelSourceModel":{"uri":{"type":"string"},"position":{"type":"array","value":"number","length":2,"default":[0,0],"minimum":[-180,-90],"maximum":[180,90]},"orientation":{"type":"array","value":"number","length":3,"default":[0,0,0],"period":360},"nodeOverrides":{"type":"modelNodeOverrides"},"materialOverrides":{"type":"modelMaterialOverrides"},"nodeOverrideNames":{"type":"array","value":"string"},"materialOverrideNames":{"type":"array","value":"string"},"featureProperties":{"type":"*"}},"modelSourceModels":{"*":{"type":"modelSourceModel"}},"source_model":{"type":{"type":"enum","values":{"model":1,"batched-model":1}},"url":{"type":"string"},"maxzoom":{"type":"number","default":18},"minzoom":{"type":"number","default":0},"tiles":{"type":"array","value":"string"},"models":{"type":"modelSourceModels"}},"layer":{"id":{"type":"string"},"type":{"type":"enum","values":{"fill":{},"line":{},"symbol":{},"circle":{},"heatmap":{},"fill-extrusion":{},"building":{},"raster":{},"raster-particle":{},"hillshade":{},"model":{},"background":{},"sky":{},"slot":{},"clip":{}}},"metadata":{"type":"*"},"source":{"type":"string"},"source-layer":{"type":"string"},"slot":{"type":"string"},"minzoom":{"type":"number","minimum":0,"maximum":24},"maxzoom":{"type":"number","minimum":0,"maximum":24},"filter":{"type":"filter"},"layout":{"type":"layout"},"paint":{"type":"paint"},"appearances":{"type":"array","value":"appearance","supported-layer-types":["symbol"]}},"appearance":{"condition":{"type":"boolean","expression":{"interpolated":true,"parameters":["zoom","pitch","feature","feature-state","measure-light","distance-from-center"]},"property-type":"data-driven"},"name":{"type":"string"},"properties":{"type":"*"}},"layout":["layout_clip","layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_building","layout_symbol","layout_raster","layout_raster-particle","layout_hillshade","layout_background","layout_sky","layout_model"],"layout_background":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_sky":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_model":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}},"model-id":{"type":"string","default":"","property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"model-allow-density-reduction":{"type":"boolean","default":true}},"layout_clip":{"clip-layer-types":{"type":"array","value":"enum","values":{"model":1,"symbol":1},"default":[],"expression":{}},"clip-layer-scope":{"type":"array","value":"string","default":[],"expression":{}},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_fill":{"fill-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}},"fill-elevation-reference":{"type":"enum","values":{"none":1,"hd-road-base":1,"hd-road-markup":1},"default":"none","expression":{}},"fill-construct-bridge-guard-rail":{"type":"boolean","default":"true","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"}},"layout_circle":{"circle-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"circle-elevation-reference":{"type":"enum","values":{"none":1,"hd-road-markup":1},"default":"none","expression":{}},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_heatmap":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_fill-extrusion":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}},"fill-extrusion-edge-radius":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{}},"source-max-zoom":{"type":"number","minimum":0,"maximum":24}},"layout_building":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}},"building-facade":{"type":"boolean","default":false,"expression":{"parameters":["feature"]},"property-type":"data-driven"},"building-facade-floors":{"type":"number","minimum":1,"maximum":200,"default":3,"property-type":"data-driven","expression":{"parameters":["feature"]}},"building-facade-unit-width":{"type":"number","minimum":1,"maximum":20,"default":3.1,"property-type":"data-driven","expression":{"parameters":["feature"]}},"building-facade-window":{"type":"array","length":2,"value":"number","minimum":0.1,"maximum":1,"default":[0.9,0.9],"property-type":"data-driven","expression":{"parameters":["feature"]}},"building-roof-shape":{"type":"enum","values":{"flat":1,"hipped":1,"gabled":1,"parapet":1,"mansard":1,"skillion":1,"pyramidal":1},"default":"flat","expression":{"parameters":["feature"]},"property-type":"data-driven"},"building-height":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{},"property-type":"data-driven"},"building-base":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{},"property-type":"data-driven"},"building-flood-light-wall-radius":{"property-type":"data-driven","type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"building-flood-light-ground-radius":{"property-type":"data-driven","type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"building-flip-roof-orientation":{"property-type":"data-driven","type":"boolean","default":false,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}}},"layout_line":{"line-cap":{"type":"enum","values":{"butt":1,"round":1,"square":1},"default":"butt","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-join":{"type":"enum","values":{"bevel":1,"round":1,"miter":1,"none":1},"default":"miter","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{"type":"number","default":2,"expression":{"interpolated":true,"parameters":["zoom"]}},"line-round-limit":{"type":"number","default":1.05,"expression":{"interpolated":true,"parameters":["zoom"]}},"line-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-z-offset":{"type":"number","default":0,"expression":{"parameters":["zoom","feature","line-progress"]},"property-type":"data-driven"},"line-elevation-reference":{"type":"enum","values":{"none":1,"sea":1,"ground":1,"hd-road-markup":1},"default":"none","expression":{}},"line-cross-slope":{"type":"number","expression":{}},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}},"line-width-unit":{"type":"enum","values":{"pixels":1,"meters":1},"default":"pixels","expression":{"parameters":["zoom"]}},"line-elevation-ground-scale":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","feature","line-progress"]},"transition":true,"property-type":"data-driven"}},"layout_symbol":{"symbol-placement":{"type":"enum","values":{"point":1,"line":1,"line-center":1},"default":"point","expression":{"parameters":["zoom"]}},"symbol-spacing":{"type":"number","default":250,"minimum":1,"expression":{"interpolated":true,"parameters":["zoom"]}},"symbol-avoid-edges":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"symbol-sort-key":{"type":"number","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{"type":"enum","values":{"auto":1,"viewport-y":1,"source":1},"default":"auto","expression":{"parameters":["zoom"]}},"symbol-z-elevate":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"symbol-elevation-reference":{"type":"enum","values":{"sea":1,"ground":1,"hd-road-markup":1},"default":"ground","expression":{"parameters":["zoom"]}},"icon-allow-overlap":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"icon-ignore-placement":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"icon-optional":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"icon-rotation-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]}},"icon-size":{"type":"number","default":1,"minimum":0,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-size-scale-range":{"type":"array","value":"number","length":2,"default":[0.8,2],"minimum":[0.1,0.1],"maximum":[10,10],"expression":{}},"icon-text-fit":{"type":"enum","values":{"none":1,"width":1,"height":1,"both":1},"default":"none","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit-padding":{"type":"array","value":"number","length":4,"default":[0,0,0,0],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-image":{"type":"resolvedImage","tokens":true,"appearance":true,"use-theme":true,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{"type":"number","default":0,"period":360,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{"type":"number","default":2,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]}},"icon-keep-upright":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"icon-offset":{"type":"array","value":"number","length":2,"default":[0,0],"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{"type":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]}},"text-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]}},"text-rotation-alignment":{"type":"enum","values":{"map":1,"viewport":1,"auto":1},"default":"auto","expression":{"parameters":["zoom"]}},"text-field":{"type":"formatted","default":"","tokens":true,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-font":{"type":"array","value":"string","default":["Open Sans Regular","Arial Unicode MS Regular"],"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size":{"type":"number","default":16,"minimum":0,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size-scale-range":{"type":"array","value":"number","length":2,"default":[0.8,2],"minimum":[0.1,0.1],"maximum":[10,10],"expression":{}},"text-max-width":{"type":"number","default":10,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{"type":"number","default":1.2,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{"type":"number","default":0,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-justify":{"type":"enum","values":{"auto":1,"left":1,"center":1,"right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{"type":"number","default":0,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["zoom","feature"]}},"text-variable-anchor":{"type":"array","value":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"expression":{"parameters":["zoom"]}},"text-anchor":{"type":"enum","values":{"center":1,"left":1,"right":1,"top":1,"bottom":1,"top-left":1,"top-right":1,"bottom-left":1,"bottom-right":1},"default":"center","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{"type":"number","default":45,"expression":{"interpolated":true,"parameters":["zoom"]}},"text-writing-mode":{"type":"array","value":"enum","values":{"horizontal":1,"vertical":1},"expression":{"parameters":["zoom"]}},"text-rotate":{"type":"number","default":0,"period":360,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-padding":{"type":"number","default":2,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]}},"text-keep-upright":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]}},"text-transform":{"type":"enum","values":{"none":1,"uppercase":1,"lowercase":1},"default":"none","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-offset":{"type":"array","value":"number","length":2,"default":[0,0],"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"text-ignore-placement":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"text-optional":{"type":"boolean","default":false,"expression":{"parameters":["zoom"]}},"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_raster":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_raster-particle":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"layout_hillshade":{"visibility":{"type":"enum","values":{"visible":1,"none":1},"default":"visible","expression":{}}},"filter":{"type":"array","value":"*"},"filter_symbol":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature","pitch","distance-from-center"]}},"filter_fill":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_hillshade":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_raster":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_raster-particle":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_clip":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_model":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_line":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_circle":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_fill-extrusion":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_building":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_heatmap":{"type":"boolean","default":false,"property-type":"data-driven","expression":{"parameters":["zoom","feature"]}},"filter_operator":{"type":"enum","values":{"==":1,"!=":1,">":1,">=":1,"<":1,"<=":1,"in":1,"!in":1,"all":1,"any":1,"none":1,"has":1,"!has":1}},"geometry_type":{"type":"enum","values":{"Point":1,"LineString":1,"Polygon":1}},"function":{"expression":{"type":"expression"},"stops":{"type":"array","value":"function_stop"},"base":{"type":"number","default":1,"minimum":0},"property":{"type":"string","default":"$zoom"},"type":{"type":"enum","values":{"identity":1,"exponential":1,"interval":1,"categorical":1},"default":"exponential"},"colorSpace":{"type":"enum","values":{"rgb":1,"lab":1,"hcl":1},"default":"rgb"},"default":{"type":"*"}},"function_stop":{"type":"array","minimum":0,"maximum":24,"value":["number","color"],"length":2},"expression":{"type":"array","value":"*","minimum":1},"fog":{"range":{"type":"array","default":[0.5,10],"minimum":-20,"maximum":20,"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"high-color":{"type":"color","default":"#245cdf","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"space-color":{"type":"color","default":["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"horizon-blend":{"type":"number","default":["interpolate",["linear"],["zoom"],4,0.2,7,0.1],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"star-intensity":{"type":"number","default":["interpolate",["linear"],["zoom"],5,0.35,6,0],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vertical-range":{"type":"array","default":[0,0],"minimum":0,"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}}},"snow":{"density":{"type":"number","default":["interpolate",["linear"],["zoom"],11,0,13,0.85],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"intensity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette":{"type":"number","default":["interpolate",["linear"],["zoom"],11,0,13,0.3],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette-color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"center-thinning":{"type":"number","default":0.4,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"direction":{"type":"array","default":[0,50],"minimum":0,"maximum":360,"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"flake-size":{"type":"number","default":0.71,"minimum":0,"maximum":5,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true}},"rain":{"density":{"type":"number","default":["interpolate",["linear"],["zoom"],11,0,13,0.5],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"intensity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"color":{"type":"color","default":["interpolate",["linear"],["measure-light","brightness"],0,"#03113d",0.3,"#a8adbc"],"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"opacity":{"type":"number","default":["interpolate",["linear"],["measure-light","brightness"],0,0.88,1,0.7],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette":{"type":"number","default":["interpolate",["linear"],["zoom"],11,0,13,1],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"vignette-color":{"type":"color","default":["interpolate",["linear"],["measure-light","brightness"],0,"#001736",0.3,"#464646"],"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"use-theme":true,"transition":true},"center-thinning":{"type":"number","default":0.57,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true},"direction":{"type":"array","default":[0,80],"minimum":0,"maximum":360,"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"droplet-size":{"type":"array","default":[2.6,18.2],"minimum":0,"maximum":50,"length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true}},"distortion-strength":{"type":"number","default":0.7,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"],"relaxZoomRestriction":true},"transition":true}},"camera":{"camera-projection":{"type":"enum","values":{"perspective":1,"orthographic":1},"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"default":"perspective"}},"colorTheme":{"data":{"type":"string","expression":{}}},"indoor_source":{"sourceId":{"type":"string"},"sourceLayers":{"type":"array","value":"string"}},"indoor":{"*":{"type":"indoor_source"}},"light":{"anchor":{"type":"enum","default":"viewport","values":{"map":1,"viewport":1},"expression":{"parameters":["zoom"]}},"position":{"type":"array","default":[1.15,210,30],"length":3,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"use-theme":true,"transition":true},"intensity":{"type":"number","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"projection":{"name":{"type":"enum","values":{"albers":1,"equalEarth":1,"equirectangular":1,"lambertConformalConic":1,"mercator":1,"naturalEarth":1,"winkelTripel":1,"globe":1},"default":"mercator"},"center":{"type":"array","length":2,"value":"number","minimum":[-180,-90],"maximum":[180,90]},"parallels":{"type":"array","length":2,"value":"number","minimum":[-90,-90],"maximum":[90,90]}},"terrain":{"source":{"type":"string"},"exaggeration":{"type":"number","default":1,"minimum":0,"maximum":1000,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"paint":["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_building","paint_symbol","paint_raster","paint_raster-particle","paint_hillshade","paint_background","paint_sky","paint_model"],"paint_fill":{"fill-antialias":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]}},"fill-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-outline-color":{"type":"color","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"fill-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-pattern-cross-fade":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-z-offset":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-bridge-guard-rail-color":{"type":"color","default":"rgba(241, 236, 225, 255)","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature"]},"property-type":"data-driven"},"fill-tunnel-structure-color":{"type":"color","default":"rgba(241, 236, 225, 255)","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature"]},"property-type":"data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-extrusion-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"fill-extrusion-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-pattern-cross-fade":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-extrusion-height":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-height-alignment":{"type":"enum","values":{"terrain":1,"flat":1},"default":"flat"},"fill-extrusion-base-alignment":{"type":"enum","values":{"terrain":1,"flat":1},"default":"terrain"},"fill-extrusion-vertical-gradient":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]}},"fill-extrusion-ambient-occlusion-intensity":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-radius":{"type":"number","default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-wall-radius":{"type":"number","default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-ground-radius":{"type":"number","default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-ground-attenuation":{"type":"number","default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-flood-light-color":{"type":"color","default":"#ffffff","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-extrusion-flood-light-intensity":{"type":"number","default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"fill-extrusion-flood-light-wall-radius":{"property-type":"data-driven","type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"fill-extrusion-flood-light-ground-radius":{"property-type":"data-driven","type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state"]}},"fill-extrusion-flood-light-ground-attenuation":{"type":"number","default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-vertical-scale":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"fill-extrusion-rounded-roof":{"type":"boolean","default":true,"expression":{"parameters":["zoom"]}},"fill-extrusion-cutoff-fade-range":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{}},"fill-extrusion-front-cutoff":{"type":"array","value":"number","expression":{"interpolated":true,"parameters":["zoom"]},"length":3,"default":[0,0,1],"minimum":[0,0,0],"maximum":[1,1,1]},"fill-extrusion-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"property-type":"data-driven"},"fill-extrusion-line-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"fill-extrusion-cast-shadows":{"type":"boolean","default":true}},"paint_building":{"building-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"building-ambient-occlusion-intensity":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"parameters":[]},"transition":true},"building-ambient-occlusion-ground-intensity":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"building-ambient-occlusion-ground-radius":{"type":"number","default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"building-ambient-occlusion-ground-attenuation":{"type":"number","default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"building-vertical-scale":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"building-cast-shadows":{"type":"boolean","default":true},"building-color":{"type":"color","default":"rgba(193, 154, 127, 1)","use-theme":true,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"property-type":"data-driven"},"building-emissive-strength":{"type":"number","default":0,"minimum":0,"maximum":5,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"property-type":"data-driven"},"building-facade-emissive-chance":{"type":"number","default":0.35,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["measure-light","zoom"]}},"building-cutoff-fade-range":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{}},"building-front-cutoff":{"type":"array","value":"number","expression":{"interpolated":true,"parameters":["zoom"]},"length":3,"default":[0,0,1],"minimum":[0,0,0],"maximum":[1,1,1]},"building-flood-light-color":{"type":"color","default":"#ffffff","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"building-flood-light-intensity":{"type":"number","default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"building-flood-light-ground-attenuation":{"type":"number","default":0.69,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}}},"paint_line":{"line-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"line-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"line-width":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light","line-progress"]},"property-type":"data-driven"},"line-gap-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-offset":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"line-dasharray":{"type":"array","value":"number","minimum":0,"expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern-cross-fade":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"line-gradient":{"type":"color","use-theme":true,"expression":{"interpolated":true,"parameters":["line-progress"]}},"line-trim-offset":{"type":"array","value":"number","length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1]},"line-trim-fade-range":{"type":"array","value":"number","length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1],"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"line-trim-color":{"type":"color","default":"transparent","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"line-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]},"property-type":"data-driven"},"line-border-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-border-color":{"type":"color","default":"rgba(0, 0, 0, 0)","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-occlusion-opacity":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"line-blend-mode":{"type":"enum","values":{"default":1,"multiply":1,"additive":1},"default":"default","expression":{"parameters":["zoom"]}},"line-blend-additive-clamp":{"type":"number","default":0,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]}}},"paint_circle":{"circle-radius":{"type":"number","default":5,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-blur":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"circle-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"circle-pitch-scale":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"circle-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1},"default":"viewport","expression":{"parameters":["zoom"]}},"circle-stroke-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-stroke-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-stroke-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"circle-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}}},"paint_heatmap":{"heatmap-radius":{"type":"number","default":30,"minimum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"heatmap-weight":{"type":"number","default":1,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"property-type":"data-driven"},"heatmap-intensity":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"heatmap-color":{"type":"color","default":["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",0.1,"royalblue",0.3,"cyan",0.5,"lime",0.7,"yellow",1,"red"],"use-theme":true,"expression":{"interpolated":true,"parameters":["heatmap-density"]}},"heatmap-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}}},"paint_symbol":{"icon-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-occlusion-opacity":{"type":"number","minimum":0,"maximum":1,"default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-emissive-strength":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"appearance":true,"property-type":"data-driven"},"text-emissive-strength":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light","feature-state"]},"appearance":true,"property-type":"data-driven"},"icon-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"icon-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"icon-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"icon-image-cross-fade":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"text-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-occlusion-opacity":{"type":"number","minimum":0,"maximum":1,"default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"overridable":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state","measure-light"]},"appearance":true,"property-type":"data-driven"},"text-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"text-translate-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":["zoom"]}},"icon-color-saturation":{"type":"number","default":0,"minimum":-1,"maximum":1,"expression":{}},"icon-color-contrast":{"type":"number","default":0,"minimum":-1,"maximum":1,"expression":{}},"icon-color-brightness-min":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{}},"icon-color-brightness-max":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{}},"symbol-z-offset":{"type":"number","default":0,"minimum":0,"transition":true,"appearance":true,"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"}},"paint_raster":{"raster-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-color":{"type":"color","use-theme":true,"expression":{"interpolated":true,"parameters":["raster-value"]}},"raster-color-mix":{"type":"array","default":[0.2126,0.7152,0.0722,0],"length":4,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-color-range":{"type":"array","length":2,"value":"number","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-hue-rotate":{"type":"number","default":0,"period":360,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-brightness-min":{"type":"number","default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-brightness-max":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-saturation":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-contrast":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-resampling":{"type":"enum","values":{"linear":1,"nearest":1},"default":"linear","expression":{"parameters":["zoom"]}},"raster-fade-duration":{"type":"number","default":300,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"raster-array-band":{"type":"string"},"raster-elevation":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-elevation-reference":{"type":"enum","values":{"sea":1,"ground":1},"default":"sea","expression":{}}},"paint_raster-particle":{"raster-particle-array-band":{"type":"string"},"raster-particle-count":{"type":"number","default":512,"minimum":1},"raster-particle-color":{"type":"color","use-theme":true,"expression":{"interpolated":true,"parameters":["raster-particle-speed"]}},"raster-particle-max-speed":{"type":"number","default":1,"minimum":1},"raster-particle-speed-factor":{"type":"number","default":0.2,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-particle-fade-opacity-factor":{"type":"number","default":0.98,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"raster-particle-reset-rate-factor":{"type":"number","default":0.8,"minimum":0,"maximum":1},"raster-particle-elevation":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}}},"paint_hillshade":{"hillshade-illumination-direction":{"type":"number","default":335,"minimum":0,"maximum":359,"expression":{"interpolated":true,"parameters":["zoom"]}},"hillshade-illumination-anchor":{"type":"enum","values":{"map":1,"viewport":1},"default":"viewport","expression":{"parameters":["zoom"]}},"hillshade-exaggeration":{"type":"number","default":0.5,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"hillshade-shadow-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"hillshade-highlight-color":{"type":"color","default":"#FFFFFF","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"hillshade-accent-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"hillshade-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}}},"paint_background":{"background-pitch-alignment":{"type":"enum","values":{"map":1,"viewport":1},"default":"map","expression":{"parameters":[]}},"background-color":{"type":"color","default":"#000000","use-theme":true,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}},"background-pattern":{"type":"resolvedImage","expression":{"parameters":["zoom"]}},"background-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"background-emissive-strength":{"type":"number","default":0,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","measure-light"]}}},"paint_sky":{"sky-type":{"type":"enum","values":{"gradient":1,"atmosphere":1},"default":"atmosphere","expression":{"parameters":["zoom"]}},"sky-atmosphere-sun":{"type":"array","value":"number","length":2,"minimum":[0,0],"maximum":[360,180],"expression":{"parameters":["zoom"]}},"sky-atmosphere-sun-intensity":{"type":"number","default":10,"minimum":0,"maximum":100},"sky-gradient-center":{"type":"array","value":"number","default":[0,0],"length":2,"minimum":[0,0],"maximum":[360,180],"expression":{"parameters":["zoom"]}},"sky-gradient-radius":{"type":"number","default":90,"minimum":0,"maximum":180,"expression":{"parameters":["zoom"]}},"sky-gradient":{"type":"color","default":["interpolate",["linear"],["sky-radial-progress"],0.8,"#87ceeb",1,"white"],"use-theme":true,"expression":{"interpolated":true,"parameters":["sky-radial-progress"]}},"sky-atmosphere-halo-color":{"type":"color","default":"white","use-theme":true},"sky-atmosphere-color":{"type":"color","default":"white","use-theme":true},"sky-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}}},"paint_model":{"model-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"property-type":"data-driven"},"model-rotation":{"type":"array","value":"number","length":3,"default":[0,0,0],"period":360,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-scale":{"type":"array","value":"number","length":3,"default":[1,1,1],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-translation":{"type":"array","value":"number","length":3,"default":[0,0,0],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","zoom"]},"transition":true},"model-color":{"type":"color","default":"#ffffff","property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light","zoom"]},"use-theme":true,"transition":true},"model-color-mix-intensity":{"type":"number","property-type":"data-driven","default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-type":{"type":"enum","values":{"common-3d":1,"location-indicator":1},"default":"common-3d"},"model-cast-shadows":{"type":"boolean","default":true},"model-receive-shadows":{"type":"boolean","default":true},"model-ambient-occlusion-intensity":{"type":"number","default":1,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"model-emissive-strength":{"type":"number","property-type":"data-driven","default":0,"minimum":0,"maximum":5,"expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-roughness":{"type":"number","default":1,"minimum":0,"maximum":1,"property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state"]},"transition":true},"model-height-based-emissive-strength-multiplier":{"type":"array","default":[1,1,1,1,0],"length":5,"value":"number","property-type":"data-driven","expression":{"interpolated":true,"parameters":["feature","feature-state","measure-light"]},"transition":true},"model-cutoff-fade-range":{"type":"number","default":0,"minimum":0,"maximum":1,"expression":{}},"model-front-cutoff":{"type":"array","value":"number","expression":{"interpolated":true,"parameters":["zoom"]},"length":3,"default":[0,0,1],"minimum":[0,0,0],"maximum":[1,1,1]},"model-elevation-reference":{"type":"enum","values":{"sea":1,"ground":1,"hd-road-markup":1},"default":"ground","expression":{}},"model-ignore-line-cutout":{"type":"boolean","default":false,"expression":{}}},"transition":{"duration":{"type":"number","default":300,"minimum":0},"delay":{"type":"number","default":0,"minimum":0}},"promoteId":{"*":{"type":"*"}}}');function va(e){return e instanceof Number||e instanceof String||e instanceof Boolean?e.valueOf():e}function ba(e){if(Array.isArray(e))return e.map(ba);if(e instanceof Object&&!(e instanceof Number||e instanceof String||e instanceof Boolean)){const t={};for(const i in e)t[i]=ba(e[i]);return t}return va(e)}function wa(e){if(!0===e||!1===e)return!0;if(!Array.isArray(e)||0===e.length)return!1;switch(e[0]){case"has":return e.length>=2&&"$id"!==e[1]&&"$type"!==e[1];case"in":return e.length>=3&&("string"!=typeof e[1]||Array.isArray(e[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==e.length||Array.isArray(e[1])||Array.isArray(e[2]);case"any":case"all":for(const t of e.slice(1))if(!wa(t)&&"boolean"!=typeof t)return!1;return!0;default:return!0}}function Ta(e,t="",i=null,r="fill"){if(null==e)return{filter:()=>!0,needGeometry:!1,needFeature:!1};wa(e)||(e=Pa(e));const n=e;let o=!0;try{o=function(e){if(!Ea(e))return e;let t=ba(e);return Ia(t),t=Sa(t),t}(n)}catch(e){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(n,null,2)}\n `)}let s=null,a=null;if("background"!==r&&"sky"!==r&&"slot"!==r){a=xa[`filter_${r}`];const e=Qo(o,a,t,i);if("error"===e.result)throw new Error(e.value.map(e=>`${e.key}: ${e.message}`).join(", "));s=(t,i,r)=>e.value.evaluate(t,i,{},r)}let l=null,c=null;if(o!==n){const e=Qo(n,a,t,i);if("error"===e.result)throw new Error(e.value.map(e=>`${e.key}: ${e.message}`).join(", "));l=(t,i,r,n,o)=>e.value.evaluate(t,i,{},r,void 0,void 0,n,o),c=!En(e.value.expression)}return{filter:s,dynamicFilter:l||void 0,needGeometry:Ca(o),needFeature:!!c}}function Sa(e){if(!Array.isArray(e))return e;const t=function(e){if(Aa.has(e[0]))for(let t=1;t<e.length;t++)if(Ea(e[t]))return!0;return e}(e);return!0===t?t:t.map(e=>Sa(e))}function Ia(e){let t=!1;const i=[];if("case"===e[0]){for(let r=1;r<e.length-1;r+=2)t=t||Ea(e[r]),i.push(e[r+1]);i.push(e.at(-1))}else if("match"===e[0]){t=t||Ea(e[1]);for(let t=2;t<e.length-1;t+=2)i.push(e[t+1]);i.push(e.at(-1))}else if("step"===e[0]){t=t||Ea(e[1]);for(let t=1;t<e.length-1;t+=2)i.push(e[t+1])}t&&(e.length=0,e.push("any",...i));for(let r=1;r<e.length;r++)Ia(e[r])}function Ea(e){if(!Array.isArray(e))return!1;if("pitch"===(t=e[0])||"distance-from-center"===t)return!0;var t;for(let i=1;i<e.length;i++)if(Ea(e[i]))return!0;return!1}const Aa=new Set(["in","==","!=",">",">=","<","<=","to-boolean"]);function Ma(e,t){return e<t?-1:e>t?1:0}function Ca(e){if(!Array.isArray(e))return!1;if("within"===e[0]||"distance"===e[0])return!0;for(let t=1;t<e.length;t++)if(Ca(e[t]))return!0;return!1}function Pa(e){if(!e)return!0;const t=e[0];return e.length<=1?"any"!==t:"=="===t?Da(e[1],e[2],"=="):"!="===t?La(Da(e[1],e[2],"==")):"<"===t||">"===t||"<="===t||">="===t?Da(e[1],e[2],t):"any"===t?(i=e.slice(1),["any"].concat(i.map(Pa))):"all"===t?["all"].concat(e.slice(1).map(Pa)):"none"===t?["all"].concat(e.slice(1).map(Pa).map(La)):"in"===t?Ra(e[1],e.slice(2)):"!in"===t?La(Ra(e[1],e.slice(2))):"has"===t?za(e[1]):"!has"!==t||La(za(e[1]));var i}function Da(e,t,i){switch(e){case"$type":return[`filter-type-${i}`,t];case"$id":return[`filter-id-${i}`,t];default:return[`filter-${i}`,e,t]}}function Ra(e,t){if(0===t.length)return!1;switch(e){case"$type":return["filter-type-in",["literal",t]];case"$id":return["filter-id-in",["literal",t]];default:return t.length>200&&!t.some(e=>typeof e!=typeof t[0])?["filter-in-large",e,["literal",t.sort(Ma)]]:["filter-in-small",e,["literal",t]]}}function za(e){switch(e){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",e]}}function La(e){return["!",e]}const Fa="";function Oa(e,t){return t?`${e}${Fa}${t}`:e}function Ba(e){const t=e.indexOf(Fa);return t>=0?e.slice(t+1):""}let ka;const Na=()=>ka||(ka=new ya({"icon-size":new _a(xa.layout_symbol["icon-size"]),"icon-image":new _a(xa.layout_symbol["icon-image"]),"icon-rotate":new _a(xa.layout_symbol["icon-rotate"]),"icon-offset":new _a(xa.layout_symbol["icon-offset"]),"text-size":new _a(xa.layout_symbol["text-size"]),"text-rotate":new _a(xa.layout_symbol["text-rotate"]),"text-offset":new _a(xa.layout_symbol["text-offset"])}));let Ua;const Va=()=>Ua||(Ua=new ya({"icon-opacity":new _a(xa.paint_symbol["icon-opacity"]),"icon-occlusion-opacity":new _a(xa.paint_symbol["icon-occlusion-opacity"]),"icon-emissive-strength":new _a(xa.paint_symbol["icon-emissive-strength"]),"text-emissive-strength":new _a(xa.paint_symbol["text-emissive-strength"]),"icon-color":new _a(xa.paint_symbol["icon-color"]),"icon-halo-color":new _a(xa.paint_symbol["icon-halo-color"]),"icon-halo-width":new _a(xa.paint_symbol["icon-halo-width"]),"icon-halo-blur":new _a(xa.paint_symbol["icon-halo-blur"]),"icon-translate":new _a(xa.paint_symbol["icon-translate"]),"text-opacity":new _a(xa.paint_symbol["text-opacity"]),"text-occlusion-opacity":new _a(xa.paint_symbol["text-occlusion-opacity"]),"text-color":new _a(xa.paint_symbol["text-color"],{runtimeType:Di,getOverride:e=>e.textColor,hasOverride:e=>!!e.textColor}),"text-halo-color":new _a(xa.paint_symbol["text-halo-color"]),"text-halo-width":new _a(xa.paint_symbol["text-halo-width"]),"text-halo-blur":new _a(xa.paint_symbol["text-halo-blur"]),"text-translate":new _a(xa.paint_symbol["text-translate"]),"symbol-z-offset":new _a(xa.paint_symbol["symbol-z-offset"]),"icon-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"icon-halo-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"text-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"text-halo-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}));class ja{constructor(e,t,i,r,n,o){this._conditionSpec=e,this._propertiesSpec=i;const s=Qo(e,xa.appearance.condition);if("success"===s.result&&(this.condition=s.value),this.name=t,i){this.layoutProperties=new fa(Na()),this.unevaluatedLayout=new da(Na(),r,n,o),this.paintProperties=new fa(Va()),this.unevaluatedPaint=new da(Va(),r,n,"");for(const e in i)e in this.unevaluatedLayout._values?this.unevaluatedLayout.setValue(e,i[e]):e in this.unevaluatedPaint._values&&this.unevaluatedPaint.setValue(e,i[e])}}isActive(e){return!(this.condition||!e.isHidden||"hidden"!==this.name)||this.condition.evaluate(e.globals,e.feature,e.featureState,e.canonical)}getCondition(){return this.condition}getName(){return this.name}getLayoutProperty(e){return this.layoutProperties.get(e)}getPaintProperty(e){return this.paintProperties.get(e)}getUnevaluatedLayoutProperties(){return this.unevaluatedLayout}getUnevaluatedLayoutProperty(e){return this.unevaluatedLayout._values[e]}getUnevaluatedPaintProperty(e){return this.unevaluatedPaint._values[e]}recalculate(e,t,i){this.unevaluatedLayout&&(this.layoutProperties=this.unevaluatedLayout.possiblyEvaluate(e,void 0,t,i)),this.unevaluatedPaint&&(this.paintProperties=this.unevaluatedPaint.possiblyEvaluate(e,void 0,t,""))}serialize(){const e={};e.condition=this.condition.expression.serialize(),this.name&&(e.name=this.name);const t=this.unevaluatedLayout?this.unevaluatedLayout.serialize():{},i=this.unevaluatedPaint?this.unevaluatedPaint.serialize():{},r=Object.assign({},t,i);return Object.keys(r).length>0&&(e.properties=r),e}hasIconLayoutProperties(){const e=this.hasLayoutProperty("icon-image"),t=this.hasLayoutProperty("icon-size"),i=this.hasLayoutProperty("icon-offset"),r=this.hasLayoutProperty("icon-rotate");return e||t||i||r}hasTextLayoutProperties(){const e=this.hasLayoutProperty("text-size"),t=this.hasLayoutProperty("text-offset"),i=this.hasLayoutProperty("text-rotate");return e||t||i}hasIconPaintProperties(){return!!this.unevaluatedPaint&&Object.keys(this.unevaluatedPaint._values).filter(e=>!e.endsWith("-use-theme")).some(e=>(e.startsWith("icon-")||"symbol-z-offset"===e)&&this.hasPaintProperty(e))}hasTextPaintProperties(){return!!this.unevaluatedPaint&&Object.keys(this.unevaluatedPaint._values).filter(e=>!e.endsWith("-use-theme")).some(e=>(e.startsWith("text-")||"symbol-z-offset"===e)&&this.hasPaintProperty(e))}hasLayoutProperty(e){return this.unevaluatedLayout&&void 0!==this.unevaluatedLayout._values[e].value}hasPaintProperty(e){return this.unevaluatedPaint&&void 0!==this.unevaluatedPaint._values[e].value}}const Ga="-transition",Ha=new Set(["fill","line","background","hillshade","raster"]);class $a extends pi{constructor(e,t,i,r,n,o){if(super(),this.id=e.id,this.fqid=Oa(this.id,i),this.type=e.type,this.scope=i,this.lut=r,this.options=n,this.iconImageUseTheme=o,this.appearances=new Array,this.appearancesVersion=0,this._featureFilter={filter:()=>!0,needGeometry:!1,needFeature:!1},this._filterCompiled=!1,this.expressionDependencies={isIndoorDependent:!1,configDependencies:/* @__PURE__ */new Set},"custom"!==e.type){if(this.metadata=e.metadata,this.minzoom=e.minzoom,this.maxzoom=e.maxzoom,e.type&&"background"!==e.type&&"sky"!==e.type&&"slot"!==e.type){this.source=e.source,this.sourceLayer=e["source-layer"],this.filter=e.filter;const t=Qo(this.filter,xa[`filter_${e.type}`]);"error"!==t.result&&(this.expressionDependencies.configDependencies=new Set([...this.expressionDependencies.configDependencies,...t.value.configDependencies]),this.expressionDependencies.isIndoorDependent=this.expressionDependencies.isIndoorDependent||t.value.isIndoorDependent)}if(e.slot&&(this.slot=e.slot),e.appearances&&this.setAppearances(e.appearances),t.layout&&(this._unevaluatedLayout=new da(t.layout,this.scope,n,this.iconImageUseTheme),this.expressionDependencies.configDependencies=new Set([...this.expressionDependencies.configDependencies,...this._unevaluatedLayout.configDependencies]),this.expressionDependencies.isIndoorDependent=this.expressionDependencies.isIndoorDependent||this._unevaluatedLayout.isIndoorDependent()),t.paint){this._transitionablePaint=new ca(t.paint,this.scope,n);for(const t in e.paint)this.setPaintProperty(t,e.paint[t]);for(const t in e.layout)this.setLayoutProperty(t,e.layout[t]);this.expressionDependencies.configDependencies=new Set([...this.expressionDependencies.configDependencies,...this._transitionablePaint.configDependencies]),this.expressionDependencies.isIndoorDependent=this.expressionDependencies.isIndoorDependent||this._transitionablePaint.isIndoorDependent(),this._transitioningPaint=this._transitionablePaint.untransitioned(),this.paint=new fa(t.paint)}}}onAdd(e){}onRemove(e){}isDraped(e){return!this.is3D(!0)&&Ha.has(this.type)}getLayoutProperty(e){return"visibility"===e?this.visibility:this._unevaluatedLayout.getValue(e)}setLayoutProperty(e,t){if("custom"===this.type&&"visibility"===e)return void(this.visibility=t);const i=this._unevaluatedLayout;i._properties.properties[e]&&(i.setValue(e,t),this.expressionDependencies.configDependencies=new Set([...this.expressionDependencies.configDependencies,...i.configDependencies]),this.expressionDependencies.isIndoorDependent=this.expressionDependencies.isIndoorDependent||i.isIndoorDependent(),"visibility"===e&&this.possiblyEvaluateVisibility())}setAppearances(e){this.appearances=[],e.forEach(e=>{this.appearances.push(new ja(e.condition,e.name,e.properties,this.scope,this.options,this.iconImageUseTheme))}),this.appearancesVersion++}possiblyEvaluateVisibility(){this._unevaluatedLayout._values.visibility&&(this.visibility=this._unevaluatedLayout._values.visibility.possiblyEvaluate({zoom:0}))}getPaintProperty(e){return e.endsWith(Ga)?this._transitionablePaint.getTransition(e.slice(0,-11)):this._transitionablePaint.getValue(e)}isPaintProperty(e){return!!this._transitionablePaint._properties.properties[e]}setPaintProperty(e,t){const i=this._transitionablePaint,r=i._properties.properties;if(e.endsWith(Ga)){const n=e.slice(0,-11);return r[n]&&i.setTransition(n,t||void 0),!1}if(!r[e])return!1;const n=i._values[e],o=n.value.isDataDriven(),s=n.value;i.setValue(e,t),this.expressionDependencies.configDependencies=new Set([...this.expressionDependencies.configDependencies,...i.configDependencies]),this.expressionDependencies.isIndoorDependent=this.expressionDependencies.isIndoorDependent||i.isIndoorDependent(),this._handleSpecialPaintPropertyUpdate(e);const a=i._values[e].value,l=a.isDataDriven(),c=e.endsWith("pattern")||"line-dasharray"===e;return l||o||c||this._handleOverridablePaintPropertyUpdate(e,s,a)}_handleSpecialPaintPropertyUpdate(e){}getProgramIds(){return null}getDefaultProgramParams(e,t,i){return null}_handleOverridablePaintPropertyUpdate(e,t,i){return!1}isHidden(e){return!!(this.minzoom&&e<this.minzoom)||!!(this.maxzoom&&e>=this.maxzoom)||"none"===this.visibility}updateTransitions(e){this._transitioningPaint=this._transitionablePaint.transitioned(e,this._transitioningPaint)}hasTransition(){return this._transitioningPaint.hasTransition()}recalculate(e,t){this._unevaluatedLayout&&(this.layout=this._unevaluatedLayout.possiblyEvaluate(e,void 0,t,this.iconImageUseTheme)),this.paint=this._transitioningPaint.possiblyEvaluate(e,void 0,t)}serialize(){const e={id:this.id,type:this.type,slot:this.slot,source:this.source,"source-layer":this.sourceLayer,metadata:this.metadata,minzoom:this.minzoom,maxzoom:this.maxzoom,filter:this.filter,layout:this._unevaluatedLayout&&this._unevaluatedLayout.serialize(),paint:this._transitionablePaint&&this._transitionablePaint.serialize()};return 0!==this.appearances.length&&(e.appearances=this.appearances.map(e=>e.serialize())),We(e,(e,t)=>!(void 0===e||"layout"===t&&!Object.keys(e).length||"paint"===t&&!Object.keys(e).length))}is3D(e){return!1}hasElevation(){return!1}isSky(){return!1}isTileClipped(){return!1}hasOffscreenPass(){return!1}hasShadowPass(){return!1}canCastShadows(){return!1}hasLightBeamPass(){return!1}cutoffRange(){return 0}tileCoverLift(){return 0}resize(){}_clear(){}isStateDependent(){for(const e in this.paint._values){const t=this.paint.get(e);if(t instanceof pa&&No(t.property.specification)&&("source"===t.value.kind||"composite"===t.value.kind)&&t.value.isStateDependent)return!0}for(const e of this.appearances)if(!An(e.condition.expression))return!0;return!1}compileFilter(e){this._filterCompiled||(this._featureFilter=Ta(this.filter,this.scope,e),this._filterCompiled=!0)}invalidateCompiledFilter(){this._filterCompiled=!1}dynamicFilter(){return this._featureFilter.dynamicFilter}dynamicFilterNeedsFeature(){return this._featureFilter.needFeature}dynamicFilterNeedsGeometry(){return this._featureFilter.needGeometry}getLayerRenderingStats(){return this._stats}resetLayerRenderingStats(e){this._stats&&("shadow"===e.renderPass?this._stats.numRenderedVerticesInShadowPass=0:this._stats.numRenderedVerticesInTransparentPass=0)}getAppearances(){return this.appearances}queryRenderedFeatures(e,t,i){return{}}queryRadius(e){}queryIntersectsFeature(e,t,i,r,n,o,s,a,l,c){}}const qa={Int8:Int8Array,Uint8:Uint8Array,Int16:Int16Array,Uint16:Uint16Array,Int32:Int32Array,Uint32:Uint32Array,Float32:Float32Array};class Za{constructor(e,t){this._structArray=e,this._pos1=t*this.size,this._pos2=this._pos1/2,this._pos4=this._pos1/4,this._pos8=this._pos1/8}}const Wa=/* @__PURE__ */new ArrayBuffer(0);class Xa{constructor(){this._reallocCount=0,this.capacity=0,this.length=0}static serialize(e,t){return e._trim(),t&&e.arrayBuffer&&t.add(e.arrayBuffer),{length:e.length,arrayBuffer:e.arrayBuffer}}static deserialize(e){const t=Object.create(this.prototype);return t.arrayBuffer=e.arrayBuffer,t.length=e.length,e.arrayBuffer?t.capacity=e.arrayBuffer.byteLength/t.bytesPerElement:(t.capacity=0,t.arrayBuffer=Wa),t._refreshViews(),t}_trim(){this.length!==this.capacity&&(this.capacity=this.length,this.arrayBuffer=this.arrayBuffer.slice(0,this.length*this.bytesPerElement),this._refreshViews())}clear(){this.length=0}resize(e){this.reserve(e),this.length=e}reserve(e){if(e>this.capacity){this._reallocCount++,this.capacity=Math.max(e,Math.floor(5*this.capacity),128),this.arrayBuffer=new ArrayBuffer(this.capacity*this.bytesPerElement);const t=this.uint8;this._refreshViews(),t&&this.uint8.set(t)}}reserveForAdditional(e){this.reserve(this.length+e)}_refreshViews(){throw new Error("StructArray#_refreshViews() must be implemented by each concrete StructArray layout")}emplace(...e){throw new Error("StructArray#emplace() must be implemented by each concrete StructArray layout")}emplaceBack(...e){throw new Error("StructArray#emplaceBack() must be implemented by each concrete StructArray layout")}destroy(){this.int8=this.uint8=this.int16=this.uint16=this.int32=this.uint32=this.float32=null,this.arrayBuffer=null}}function Ya(e,t=1){let i=0,r=0;return{members:e.map(e=>{const n=qa[e.type].BYTES_PER_ELEMENT,o=i=Ja(i,Math.max(t,n)),s=e.components||1;return r=Math.max(r,n),i+=n*s,{name:e.name,type:e.type,components:s,offset:o}}),size:Ja(i,Math.max(r,t)),alignment:t}}function Ja(e,t){return Math.ceil(e/t)*t}class Ka extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t){const i=this.length;return this.resize(i+1),this.emplace(i,e,t)}emplace(e,t,i){const r=2*e;return this.int16[r+0]=t,this.int16[r+1]=i,e}}Ka.prototype.bytesPerElement=4,as(Ka,"StructArrayLayout2i4");class Qa extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i){const r=this.length;return this.resize(r+1),this.emplace(r,e,t,i)}emplace(e,t,i,r){const n=3*e;return this.int16[n+0]=t,this.int16[n+1]=i,this.int16[n+2]=r,e}}Qa.prototype.bytesPerElement=6,as(Qa,"StructArrayLayout3i6");class el extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i,r){const n=this.length;return this.resize(n+1),this.emplace(n,e,t,i,r)}emplace(e,t,i,r,n){const o=4*e;return this.int16[o+0]=t,this.int16[o+1]=i,this.uint16[o+2]=r,this.uint16[o+3]=n,e}}el.prototype.bytesPerElement=8,as(el,"StructArrayLayout2i2ui8");class tl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e){const t=this.length;return this.resize(t+1),this.emplace(t,e)}emplace(e,t){return this.float32[1*e+0]=t,e}}tl.prototype.bytesPerElement=4,as(tl,"StructArrayLayout1f4");class il extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i){const r=this.length;return this.resize(r+1),this.emplace(r,e,t,i)}emplace(e,t,i,r){const n=4*e,o=2*e;return this.int16[n+0]=t,this.int16[n+1]=i,this.float32[o+1]=r,e}}il.prototype.bytesPerElement=8,as(il,"StructArrayLayout2i1f8");class rl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i){const r=this.length;return this.resize(r+1),this.emplace(r,e,t,i)}emplace(e,t,i,r){const n=4*e;return this.int16[n+0]=t,this.int16[n+1]=i,this.int16[n+2]=r,e}}rl.prototype.bytesPerElement=8,as(rl,"StructArrayLayout3i8");class nl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i,r){const n=this.length;return this.resize(n+1),this.emplace(n,e,t,i,r)}emplace(e,t,i,r,n){const o=4*e;return this.int16[o+0]=t,this.int16[o+1]=i,this.int16[o+2]=r,this.int16[o+3]=n,e}}nl.prototype.bytesPerElement=8,as(nl,"StructArrayLayout4i8");class ol extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n){const o=this.length;return this.resize(o+1),this.emplace(o,e,t,i,r,n)}emplace(e,t,i,r,n,o){const s=5*e;return this.int16[s+0]=t,this.int16[s+1]=i,this.int16[s+2]=r,this.int16[s+3]=n,this.int16[s+4]=o,e}}ol.prototype.bytesPerElement=10,as(ol,"StructArrayLayout5i10");class sl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s){const a=this.length;return this.resize(a+1),this.emplace(a,e,t,i,r,n,o,s)}emplace(e,t,i,r,n,o,s,a){const l=6*e,c=12*e,h=3*e;return this.int16[l+0]=t,this.int16[l+1]=i,this.uint8[c+4]=r,this.uint8[c+5]=n,this.uint8[c+6]=o,this.uint8[c+7]=s,this.float32[h+2]=a,e}}sl.prototype.bytesPerElement=12,as(sl,"StructArrayLayout2i4ub1f12");class al extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i){const r=this.length;return this.resize(r+1),this.emplace(r,e,t,i)}emplace(e,t,i,r){const n=3*e;return this.float32[n+0]=t,this.float32[n+1]=i,this.float32[n+2]=r,e}}al.prototype.bytesPerElement=12,as(al,"StructArrayLayout3f12");class ll extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n){const o=this.length;return this.resize(o+1),this.emplace(o,e,t,i,r,n)}emplace(e,t,i,r,n,o){const s=6*e,a=3*e;return this.uint16[s+0]=t,this.uint16[s+1]=i,this.uint16[s+2]=r,this.uint16[s+3]=n,this.float32[a+2]=o,e}}ll.prototype.bytesPerElement=12,as(ll,"StructArrayLayout4ui1f12");class cl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i,r){const n=this.length;return this.resize(n+1),this.emplace(n,e,t,i,r)}emplace(e,t,i,r,n){const o=4*e;return this.uint16[o+0]=t,this.uint16[o+1]=i,this.uint16[o+2]=r,this.uint16[o+3]=n,e}}cl.prototype.bytesPerElement=8,as(cl,"StructArrayLayout4ui8");class hl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o){const s=this.length;return this.resize(s+1),this.emplace(s,e,t,i,r,n,o)}emplace(e,t,i,r,n,o,s){const a=6*e;return this.int16[a+0]=t,this.int16[a+1]=i,this.int16[a+2]=r,this.int16[a+3]=n,this.int16[a+4]=o,this.int16[a+5]=s,e}}hl.prototype.bytesPerElement=12,as(hl,"StructArrayLayout6i12");class ul extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h,u){const d=this.length;return this.resize(d+1),this.emplace(d,e,t,i,r,n,o,s,a,l,c,h,u)}emplace(e,t,i,r,n,o,s,a,l,c,h,u,d){const p=12*e;return this.int16[p+0]=t,this.int16[p+1]=i,this.int16[p+2]=r,this.int16[p+3]=n,this.uint16[p+4]=o,this.uint16[p+5]=s,this.uint16[p+6]=a,this.uint16[p+7]=l,this.int16[p+8]=c,this.int16[p+9]=h,this.int16[p+10]=u,this.int16[p+11]=d,e}}ul.prototype.bytesPerElement=24,as(ul,"StructArrayLayout4i4ui4i24");class dl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o){const s=this.length;return this.resize(s+1),this.emplace(s,e,t,i,r,n,o)}emplace(e,t,i,r,n,o,s){const a=10*e,l=5*e;return this.int16[a+0]=t,this.int16[a+1]=i,this.int16[a+2]=r,this.float32[l+2]=n,this.float32[l+3]=o,this.float32[l+4]=s,e}}dl.prototype.bytesPerElement=20,as(dl,"StructArrayLayout3i3f20");class pl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r){const n=this.length;return this.resize(n+1),this.emplace(n,e,t,i,r)}emplace(e,t,i,r,n){const o=4*e;return this.float32[o+0]=t,this.float32[o+1]=i,this.float32[o+2]=r,this.float32[o+3]=n,e}}pl.prototype.bytesPerElement=16,as(pl,"StructArrayLayout4f16");class fl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer)}emplaceBack(e){const t=this.length;return this.resize(t+1),this.emplace(t,e)}emplace(e,t){return this.uint32[1*e+0]=t,e}}fl.prototype.bytesPerElement=4,as(fl,"StructArrayLayout1ul4");class ml extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t){const i=this.length;return this.resize(i+1),this.emplace(i,e,t)}emplace(e,t,i){const r=2*e;return this.uint16[r+0]=t,this.uint16[r+1]=i,e}}ml.prototype.bytesPerElement=4,as(ml,"StructArrayLayout2ui4");class _l extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h,u,d){const p=this.length;return this.resize(p+1),this.emplace(p,e,t,i,r,n,o,s,a,l,c,h,u,d)}emplace(e,t,i,r,n,o,s,a,l,c,h,u,d,p){const f=20*e,m=10*e;return this.int16[f+0]=t,this.int16[f+1]=i,this.int16[f+2]=r,this.int16[f+3]=n,this.int16[f+4]=o,this.float32[m+3]=s,this.float32[m+4]=a,this.float32[m+5]=l,this.float32[m+6]=c,this.int16[f+14]=h,this.uint32[m+8]=u,this.uint16[f+18]=d,this.uint16[f+19]=p,e}}_l.prototype.bytesPerElement=40,as(_l,"StructArrayLayout5i4f1i1ul2ui40");class gl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s){const a=this.length;return this.resize(a+1),this.emplace(a,e,t,i,r,n,o,s)}emplace(e,t,i,r,n,o,s,a){const l=8*e;return this.int16[l+0]=t,this.int16[l+1]=i,this.int16[l+2]=r,this.int16[l+4]=n,this.int16[l+5]=o,this.int16[l+6]=s,this.int16[l+7]=a,e}}gl.prototype.bytesPerElement=16,as(gl,"StructArrayLayout3i2i2i16");class yl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n){const o=this.length;return this.resize(o+1),this.emplace(o,e,t,i,r,n)}emplace(e,t,i,r,n,o){const s=4*e,a=8*e;return this.float32[s+0]=t,this.float32[s+1]=i,this.float32[s+2]=r,this.int16[a+6]=n,this.int16[a+7]=o,e}}yl.prototype.bytesPerElement=16,as(yl,"StructArrayLayout2f1f2i16");class xl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o){const s=this.length;return this.resize(s+1),this.emplace(s,e,t,i,r,n,o)}emplace(e,t,i,r,n,o,s){const a=20*e,l=5*e;return this.uint8[a+0]=t,this.uint8[a+1]=i,this.float32[l+1]=r,this.float32[l+2]=n,this.float32[l+3]=o,this.float32[l+4]=s,e}}xl.prototype.bytesPerElement=20,as(xl,"StructArrayLayout2ub4f20");class vl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i){const r=this.length;return this.resize(r+1),this.emplace(r,e,t,i)}emplace(e,t,i,r){const n=3*e;return this.uint16[n+0]=t,this.uint16[n+1]=i,this.uint16[n+2]=r,e}}vl.prototype.bytesPerElement=6,as(vl,"StructArrayLayout3ui6");class bl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v){const b=this.length;return this.resize(b+1),this.emplace(b,e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v)}emplace(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b){const w=30*e,T=15*e,S=60*e;return this.int16[w+0]=t,this.int16[w+1]=i,this.int16[w+2]=r,this.float32[T+2]=n,this.float32[T+3]=o,this.uint16[w+8]=s,this.uint16[w+9]=a,this.uint32[T+5]=l,this.uint32[T+6]=c,this.uint32[T+7]=h,this.uint16[w+16]=u,this.uint16[w+17]=d,this.uint16[w+18]=p,this.float32[T+10]=f,this.float32[T+11]=m,this.uint8[S+48]=_,this.uint8[S+49]=g,this.uint8[S+50]=y,this.uint32[T+13]=x,this.int16[w+28]=v,this.uint8[S+58]=b,e}}bl.prototype.bytesPerElement=60,as(bl,"StructArrayLayout3i2f2ui3ul3ui2f3ub1ul1i1ub60");class wl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S,I,E,A,M,C,P,D,R){const z=this.length;return this.resize(z+1),this.emplace(z,e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S,I,E,A,M,C,P,D,R)}emplace(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S,I,E,A,M,C,P,D,R,z){const L=20*e,F=40*e,O=80*e;return this.float32[L+0]=t,this.float32[L+1]=i,this.int16[F+4]=r,this.int16[F+5]=n,this.int16[F+6]=o,this.int16[F+7]=s,this.int16[F+8]=a,this.int16[F+9]=l,this.int16[F+10]=c,this.int16[F+11]=h,this.int16[F+12]=u,this.uint16[F+13]=d,this.uint16[F+14]=p,this.uint16[F+15]=f,this.uint16[F+16]=m,this.uint16[F+17]=_,this.uint16[F+18]=g,this.uint16[F+19]=y,this.uint16[F+20]=x,this.uint16[F+21]=v,this.uint16[F+22]=b,this.uint16[F+23]=w,this.uint16[F+24]=T,this.uint16[F+25]=S,this.uint16[F+26]=I,this.uint16[F+27]=E,this.uint32[L+14]=A,this.float32[L+15]=M,this.float32[L+16]=C,this.float32[L+17]=P,this.float32[L+18]=D,this.uint8[O+76]=R,this.uint16[F+39]=z,e}}wl.prototype.bytesPerElement=80,as(wl,"StructArrayLayout2f9i15ui1ul4f1ub1ui80");class Tl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o){const s=this.length;return this.resize(s+1),this.emplace(s,e,t,i,r,n,o)}emplace(e,t,i,r,n,o,s){const a=6*e;return this.float32[a+0]=t,this.float32[a+1]=i,this.float32[a+2]=r,this.float32[a+3]=n,this.float32[a+4]=o,this.float32[a+5]=s,e}}Tl.prototype.bytesPerElement=24,as(Tl,"StructArrayLayout6f24");class Sl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n){const o=this.length;return this.resize(o+1),this.emplace(o,e,t,i,r,n)}emplace(e,t,i,r,n,o){const s=5*e;return this.float32[s+0]=t,this.float32[s+1]=i,this.float32[s+2]=r,this.float32[s+3]=n,this.float32[s+4]=o,e}}Sl.prototype.bytesPerElement=20,as(Sl,"StructArrayLayout5f20");class Il extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s){const a=this.length;return this.resize(a+1),this.emplace(a,e,t,i,r,n,o,s)}emplace(e,t,i,r,n,o,s,a){const l=7*e;return this.float32[l+0]=t,this.float32[l+1]=i,this.float32[l+2]=r,this.float32[l+3]=n,this.float32[l+4]=o,this.float32[l+5]=s,this.float32[l+6]=a,e}}Il.prototype.bytesPerElement=28,as(Il,"StructArrayLayout7f28");class El extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h){const u=this.length;return this.resize(u+1),this.emplace(u,e,t,i,r,n,o,s,a,l,c,h)}emplace(e,t,i,r,n,o,s,a,l,c,h,u){const d=11*e;return this.float32[d+0]=t,this.float32[d+1]=i,this.float32[d+2]=r,this.float32[d+3]=n,this.float32[d+4]=o,this.float32[d+5]=s,this.float32[d+6]=a,this.float32[d+7]=l,this.float32[d+8]=c,this.float32[d+9]=h,this.float32[d+10]=u,e}}El.prototype.bytesPerElement=44,as(El,"StructArrayLayout11f44");class Al extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l){const c=this.length;return this.resize(c+1),this.emplace(c,e,t,i,r,n,o,s,a,l)}emplace(e,t,i,r,n,o,s,a,l,c){const h=9*e;return this.float32[h+0]=t,this.float32[h+1]=i,this.float32[h+2]=r,this.float32[h+3]=n,this.float32[h+4]=o,this.float32[h+5]=s,this.float32[h+6]=a,this.float32[h+7]=l,this.float32[h+8]=c,e}}Al.prototype.bytesPerElement=36,as(Al,"StructArrayLayout9f36");class Ml extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t){const i=this.length;return this.resize(i+1),this.emplace(i,e,t)}emplace(e,t,i){const r=2*e;return this.float32[r+0]=t,this.float32[r+1]=i,e}}Ml.prototype.bytesPerElement=8,as(Ml,"StructArrayLayout2f8");class Cl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint32=new Uint32Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e,t,i,r){const n=this.length;return this.resize(n+1),this.emplace(n,e,t,i,r)}emplace(e,t,i,r,n){const o=6*e;return this.uint32[3*e+0]=t,this.uint16[o+2]=i,this.uint16[o+3]=r,this.uint16[o+4]=n,e}}Cl.prototype.bytesPerElement=12,as(Cl,"StructArrayLayout1ul3ui12");class Pl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer)}emplaceBack(e){const t=this.length;return this.resize(t+1),this.emplace(t,e)}emplace(e,t){return this.uint16[1*e+0]=t,e}}Pl.prototype.bytesPerElement=2,as(Pl,"StructArrayLayout1ui2");class Dl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m){const _=this.length;return this.resize(_+1),this.emplace(_,e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m)}emplace(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_){const g=16*e;return this.float32[g+0]=t,this.float32[g+1]=i,this.float32[g+2]=r,this.float32[g+3]=n,this.float32[g+4]=o,this.float32[g+5]=s,this.float32[g+6]=a,this.float32[g+7]=l,this.float32[g+8]=c,this.float32[g+9]=h,this.float32[g+10]=u,this.float32[g+11]=d,this.float32[g+12]=p,this.float32[g+13]=f,this.float32[g+14]=m,this.float32[g+15]=_,e}}Dl.prototype.bytesPerElement=64,as(Dl,"StructArrayLayout16f64");class Rl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.uint16=new Uint16Array(this.arrayBuffer),this.float32=new Float32Array(this.arrayBuffer)}emplaceBack(e,t,i,r,n,o,s){const a=this.length;return this.resize(a+1),this.emplace(a,e,t,i,r,n,o,s)}emplace(e,t,i,r,n,o,s,a){const l=10*e,c=5*e;return this.uint16[l+0]=t,this.uint16[l+1]=i,this.uint16[l+2]=r,this.uint16[l+3]=n,this.float32[c+2]=o,this.float32[c+3]=s,this.float32[c+4]=a,e}}Rl.prototype.bytesPerElement=20,as(Rl,"StructArrayLayout4ui3f20");class zl extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer),this.int16=new Int16Array(this.arrayBuffer)}emplaceBack(e){const t=this.length;return this.resize(t+1),this.emplace(t,e)}emplace(e,t){return this.int16[1*e+0]=t,e}}zl.prototype.bytesPerElement=2,as(zl,"StructArrayLayout1i2");class Ll extends Xa{_refreshViews(){this.uint8=new Uint8Array(this.arrayBuffer)}emplaceBack(e){const t=this.length;return this.resize(t+1),this.emplace(t,e)}emplace(e,t){return this.uint8[1*e+0]=t,e}}Ll.prototype.bytesPerElement=1,as(Ll,"StructArrayLayout1ub1");class Fl extends Za{get projectedAnchorX(){return this._structArray.int16[this._pos2+0]}get projectedAnchorY(){return this._structArray.int16[this._pos2+1]}get projectedAnchorZ(){return this._structArray.int16[this._pos2+2]}get tileAnchorX(){return this._structArray.int16[this._pos2+3]}get tileAnchorY(){return this._structArray.int16[this._pos2+4]}get x1(){return this._structArray.float32[this._pos4+3]}get y1(){return this._structArray.float32[this._pos4+4]}get x2(){return this._structArray.float32[this._pos4+5]}get y2(){return this._structArray.float32[this._pos4+6]}get padding(){return this._structArray.int16[this._pos2+14]}get featureIndex(){return this._structArray.uint32[this._pos4+8]}get sourceLayerIndex(){return this._structArray.uint16[this._pos2+18]}get bucketIndex(){return this._structArray.uint16[this._pos2+19]}}Fl.prototype.size=40;class Ol extends _l{get(e){return new Fl(this,e)}}as(Ol,"CollisionBoxArray");class Bl extends Za{get projectedAnchorX(){return this._structArray.int16[this._pos2+0]}get projectedAnchorY(){return this._structArray.int16[this._pos2+1]}get projectedAnchorZ(){return this._structArray.int16[this._pos2+2]}get tileAnchorX(){return this._structArray.float32[this._pos4+2]}get tileAnchorY(){return this._structArray.float32[this._pos4+3]}get glyphStartIndex(){return this._structArray.uint16[this._pos2+8]}get numGlyphs(){return this._structArray.uint16[this._pos2+9]}get vertexStartIndex(){return this._structArray.uint32[this._pos4+5]}get lineStartIndex(){return this._structArray.uint32[this._pos4+6]}get lineLength(){return this._structArray.uint32[this._pos4+7]}get segment(){return this._structArray.uint16[this._pos2+16]}get lowerSize(){return this._structArray.uint16[this._pos2+17]}get upperSize(){return this._structArray.uint16[this._pos2+18]}get lineOffsetX(){return this._structArray.float32[this._pos4+10]}get lineOffsetY(){return this._structArray.float32[this._pos4+11]}get writingMode(){return this._structArray.uint8[this._pos1+48]}get placedOrientation(){return this._structArray.uint8[this._pos1+49]}set placedOrientation(e){this._structArray.uint8[this._pos1+49]=e}get hidden(){return this._structArray.uint8[this._pos1+50]}set hidden(e){this._structArray.uint8[this._pos1+50]=e}get crossTileID(){return this._structArray.uint32[this._pos4+13]}set crossTileID(e){this._structArray.uint32[this._pos4+13]=e}get associatedIconIndex(){return this._structArray.int16[this._pos2+28]}get flipState(){return this._structArray.uint8[this._pos1+58]}set flipState(e){this._structArray.uint8[this._pos1+58]=e}}Bl.prototype.size=60;class kl extends bl{get(e){return new Bl(this,e)}}as(kl,"PlacedSymbolArray");class Nl extends Za{get tileAnchorX(){return this._structArray.float32[this._pos4+0]}get tileAnchorY(){return this._structArray.float32[this._pos4+1]}get projectedAnchorX(){return this._structArray.int16[this._pos2+4]}get projectedAnchorY(){return this._structArray.int16[this._pos2+5]}get projectedAnchorZ(){return this._structArray.int16[this._pos2+6]}get rightJustifiedTextSymbolIndex(){return this._structArray.int16[this._pos2+7]}get centerJustifiedTextSymbolIndex(){return this._structArray.int16[this._pos2+8]}get leftJustifiedTextSymbolIndex(){return this._structArray.int16[this._pos2+9]}get verticalPlacedTextSymbolIndex(){return this._structArray.int16[this._pos2+10]}get placedIconSymbolIndex(){return this._structArray.int16[this._pos2+11]}get verticalPlacedIconSymbolIndex(){return this._structArray.int16[this._pos2+12]}get key(){return this._structArray.uint16[this._pos2+13]}get textBoxStartIndex(){return this._structArray.uint16[this._pos2+14]}get textBoxEndIndex(){return this._structArray.uint16[this._pos2+15]}get verticalTextBoxStartIndex(){return this._structArray.uint16[this._pos2+16]}get verticalTextBoxEndIndex(){return this._structArray.uint16[this._pos2+17]}get iconBoxStartIndex(){return this._structArray.uint16[this._pos2+18]}get iconBoxEndIndex(){return this._structArray.uint16[this._pos2+19]}get verticalIconBoxStartIndex(){return this._structArray.uint16[this._pos2+20]}get verticalIconBoxEndIndex(){return this._structArray.uint16[this._pos2+21]}get featureIndex(){return this._structArray.uint16[this._pos2+22]}get numHorizontalGlyphVertices(){return this._structArray.uint16[this._pos2+23]}get numVerticalGlyphVertices(){return this._structArray.uint16[this._pos2+24]}get numIconVertices(){return this._structArray.uint16[this._pos2+25]}get numVerticalIconVertices(){return this._structArray.uint16[this._pos2+26]}get useRuntimeCollisionCircles(){return this._structArray.uint16[this._pos2+27]}get crossTileID(){return this._structArray.uint32[this._pos4+14]}set crossTileID(e){this._structArray.uint32[this._pos4+14]=e}get textOffset0(){return this._structArray.float32[this._pos4+15]}get textOffset1(){return this._structArray.float32[this._pos4+16]}get collisionCircleDiameter(){return this._structArray.float32[this._pos4+17]}get zOffset(){return this._structArray.float32[this._pos4+18]}set zOffset(e){this._structArray.float32[this._pos4+18]=e}get hasIconTextFit(){return this._structArray.uint8[this._pos1+76]}get elevationFeatureIndex(){return this._structArray.uint16[this._pos2+39]}}Nl.prototype.size=80;class Ul extends wl{get(e){return new Nl(this,e)}}as(Ul,"SymbolInstanceArray");class Vl extends tl{getoffsetX(e){return this.float32[1*e+0]}}as(Vl,"GlyphOffsetArray");class jl extends Ka{getx(e){return this.int16[2*e+0]}gety(e){return this.int16[2*e+1]}}as(jl,"SymbolLineVertexArray");class Gl extends Za{get featureIndex(){return this._structArray.uint32[this._pos4+0]}get sourceLayerIndex(){return this._structArray.uint16[this._pos2+2]}get bucketIndex(){return this._structArray.uint16[this._pos2+3]}get layoutVertexArrayOffset(){return this._structArray.uint16[this._pos2+4]}}Gl.prototype.size=12;class Hl extends Cl{get(e){return new Gl(this,e)}}as(Hl,"FeatureIndexArray");class $l extends ml{geta_centroid_pos0(e){return this.uint16[2*e+0]}geta_centroid_pos1(e){return this.uint16[2*e+1]}}as($l,"FillExtrusionCentroidArray");class ql extends Za{get a_join_normal_inside0(){return this._structArray.int16[this._pos2+0]}get a_join_normal_inside1(){return this._structArray.int16[this._pos2+1]}get a_join_normal_inside2(){return this._structArray.int16[this._pos2+2]}}ql.prototype.size=6;class Zl extends Qa{get(e){return new ql(this,e)}}as(Zl,"FillExtrusionWallArray");const Wl=Ya([{name:"a_pos",components:2,type:"Int16"}],4),Xl=Ya([{name:"a_circle_z_offset",components:1,type:"Float32"}],4),Yl=Ya([{name:"a_pos_3",components:3,type:"Int16"},{name:"a_pos_normal_3",components:3,type:"Int16"}]);class Jl{constructor(e=[]){this.segments=e}_prepareSegment(e,t,i,r,n){let o=this.segments.at(-1);return e>Jl.MAX_VERTEX_ARRAY_LENGTH&&Ke(`Max vertices per segment is ${Jl.MAX_VERTEX_ARRAY_LENGTH}: bucket requested ${e}`),(!o||o.vertexLength+e>Jl.MAX_VERTEX_ARRAY_LENGTH||o.sortKey!==r||void 0!==n&&o&&void 0!==o.batchIndex&&o.batchIndex!==n)&&(o={vertexOffset:t,primitiveOffset:i,vertexLength:0,primitiveLength:0},void 0!==r&&(o.sortKey=r),void 0!==n&&(o.batchIndex=n),this.segments.push(o)),o}prepareSegment(e,t,i,r,n){return this._prepareSegment(e,t.length,i.length,r,n)}get(){return this.segments}destroy(){for(const e of this.segments)for(const t in e.vaos)e.vaos[t].destroy()}static simpleSegment(e,t,i,r){return new Jl([{vertexOffset:e,primitiveOffset:t,vertexLength:i,primitiveLength:r,vaos:{},sortKey:0}])}}function Kl(e,t){return 256*(e=ke(Math.floor(e),0,255))+ke(Math.floor(t),0,255)}Jl.MAX_VERTEX_ARRAY_LENGTH=Math.pow(2,16)-1,as(Jl,"SegmentVector");const Ql=Ya([{name:"a_pattern",components:4,type:"Uint16"},{name:"a_pixel_ratio",components:1,type:"Float32"}]),ec=Ya([{name:"a_pattern_b",components:4,type:"Uint16"}]),tc=Ya([{name:"a_dash",components:4,type:"Uint16"}]);class ic{constructor(){this.ids=[],this.uniqueIds=[],this.positions=[],this.indexed=!1}add(e,t,i,r){this.ids.push(rc(e)),this.positions.push(t,i,r)}eachPosition(e,t){const i=rc(e);let r=0,n=this.ids.length-1;for(;r<n;){const e=r+n>>1;this.ids[e]>=i?n=e:r=e+1}for(;this.ids[r]===i;)t(this.positions[3*r],this.positions[3*r+1],this.positions[3*r+2]),r++}static serialize(e,t){const i=new Float64Array(e.ids),r=new Uint32Array(e.positions);return nc(i,r,0,i.length-1),t&&(t.add(i.buffer),t.add(r.buffer)),{ids:i,positions:r}}static deserialize(e){const t=new ic;let i;t.ids=e.ids,t.positions=e.positions;for(const r of t.ids)r!==i&&t.uniqueIds.push(r),i=r;return t.indexed=!0,t}}function rc(e){const t=+e;return Number.isSafeInteger(t)?t:li(String(e))}function nc(e,t,i,r){for(;i<r;){const n=e[i+r>>1];let o=i-1,s=r+1;for(;;){do{o++}while(e[o]<n);do{s--}while(e[s]>n);if(o>=s)break;oc(e,o,s),oc(t,3*o,3*s),oc(t,3*o+1,3*s+1),oc(t,3*o+2,3*s+2)}s-i<r-s?(nc(e,t,i,s),i=s+1):(nc(e,t,s+1,r),r=s)}}function oc(e,t,i){const r=e[t];e[t]=e[i],e[i]=r}as(ic,"FeaturePositionMap");class sc{constructor(e){this.gl=e.gl,this.initialized=!1}fetchUniformLocation(e,t){return this.location||this.initialized||(this.location=this.gl.getUniformLocation(e,t),this.initialized=!0),!!this.location}set(e,t,i){throw new Error("Uniform#set() must be implemented by each concrete Uniform")}}class ac extends sc{constructor(e){super(e),this.current=0}set(e,t,i){this.fetchUniformLocation(e,t)&&this.current!==i&&(this.current=i,this.gl.uniform1i(this.location,i))}}class lc extends sc{constructor(e){super(e),this.current=0}set(e,t,i){this.fetchUniformLocation(e,t)&&this.current!==i&&(this.current=i,this.gl.uniform1f(this.location,i))}}class cc extends sc{constructor(e){super(e),this.current=[0,0]}set(e,t,i){this.fetchUniformLocation(e,t)&&(i[0]===this.current[0]&&i[1]===this.current[1]||(this.current=i,this.gl.uniform2f(this.location,i[0],i[1])))}}class hc extends sc{constructor(e){super(e),this.current=[0,0,0]}set(e,t,i){this.fetchUniformLocation(e,t)&&(i[0]===this.current[0]&&i[1]===this.current[1]&&i[2]===this.current[2]||(this.current=i,this.gl.uniform3f(this.location,i[0],i[1],i[2])))}}class uc extends sc{constructor(e){super(e),this.current=[0,0,0,0]}set(e,t,i){this.fetchUniformLocation(e,t)&&(i[0]===this.current[0]&&i[1]===this.current[1]&&i[2]===this.current[2]&&i[3]===this.current[3]||(this.current=i,this.gl.uniform4ui(this.location,i[0],i[1],i[2],i[3])))}}class dc extends sc{constructor(e){super(e),this.current=[0,0,0,0]}set(e,t,i){this.fetchUniformLocation(e,t)&&(i[0]===this.current[0]&&i[1]===this.current[1]&&i[2]===this.current[2]&&i[3]===this.current[3]||(this.current=i,this.gl.uniform4f(this.location,i[0],i[1],i[2],i[3])))}}class pc extends sc{constructor(e){super(e),this.current=xi.transparent.toPremultipliedRenderColor(null)}set(e,t,i){this.fetchUniformLocation(e,t)&&(i.r===this.current.r&&i.g===this.current.g&&i.b===this.current.b&&i.a===this.current.a||(this.current=i,this.gl.uniform4f(this.location,i.r,i.g,i.b,i.a)))}}class fc extends sc{constructor(e){super(e),this.current=new Float32Array(16)}set(e,t,i){if(!this.fetchUniformLocation(e,t))return;const r=this.current;if(i[12]!==r[12]||i[0]!==r[0])return r.set(i),void this.gl.uniformMatrix4fv(this.location,!1,r);for(let n=1;n<16;n++)if(i[n]!==r[n]){r.set(i),this.gl.uniformMatrix4fv(this.location,!1,r);break}}}class mc extends sc{constructor(e){super(e),this.current=new Float32Array(4)}set(e,t,i){if(!this.fetchUniformLocation(e,t))return;const r=this.current;for(let n=0;n<4;n++)if(i[n]!==r[n]){r.set(i),this.gl.uniformMatrix2fv(this.location,!1,r);break}}}function _c(e){return[Kl(255*e.r,255*e.g),Kl(255*e.b,255*e.a)]}function gc(e,t,i,r,n,o,s,a){return!!e&&("composite"===e.kind||"source"===e.kind?"none"===e.evaluate(new sa(0,{brightness:o,worldview:a}),t,i,n,r,s):"none"===e.value)}class yc{constructor(e,t,i,r){this.value=e,this.uniformNames=t.map(e=>`u_${e}`),this.type=i,this.context=r}setUniform(e,t,i,r,n){const o=r.constantOr(this.value);t.set(e,n,o instanceof xi?o.toPremultipliedRenderColor(this.lutExpression&&"constant"===this.lutExpression.kind&&"none"===this.lutExpression.value?null:this.context.lut):o)}getBinding(e,t){return"color"===this.type?new pc(e):new lc(e)}}class xc{constructor(e,t){this.uniformNames=t.map(e=>`u_${e}`),this.pattern=null,this.patternTransition=null,this.pixelRatio=1}setConstantPatternPositions(e,t){this.pixelRatio=e.pixelRatio||1,this.pattern=e.tl.concat(e.br),this.patternTransition=t?t.tl.concat(t.br):this.pattern}setUniform(e,t,i,r,n){let o=null;"u_pattern"!==n&&"u_dash"!==n||(o=this.pattern),"u_pattern_b"===n&&(o=this.patternTransition),"u_pixel_ratio"===n&&(o=this.pixelRatio),o&&t.set(e,n,o)}getBinding(e,t){return"u_pattern"===t||"u_pattern_b"===t||"u_dash"===t?new uc(e):new lc(e)}}class vc{constructor(e,t,i,r){this.expression=e,this.type=i,this.maxValue=0,this.paintVertexAttributes=t.map(e=>({name:`a_${e}`,type:"Float32",components:"color"===i?2:1,offset:0})),this.paintVertexArray=new r}populatePaintArray(e,t,i,r,n,o,s,a){const l=this.paintVertexArray.length,c="composite"===this.expression.kind||"source"===this.expression.kind?this.expression.evaluate(new sa(0,{brightness:o,worldview:a}),t,{},n,r,s):"constant"===this.expression.kind&&this.expression.value,h=gc(this.lutExpression,t,{},r,n,o,s,a);this.paintVertexArray.resize(e),this._setPaintValue(l,e,c,h?null:this.context.lut)}updatePaintArray(e,t,i,r,n,o,s,a){const l="composite"===this.expression.kind||"source"===this.expression.kind?this.expression.evaluate({zoom:0,brightness:s,worldview:a},i,r,void 0,n):"constant"===this.expression.kind&&this.expression.value,c=gc(this.lutExpression,i,r,n,void 0,s,void 0,a);this._setPaintValue(e,t,l,c?null:this.context.lut)}_setPaintValue(e,t,i,r){if("color"===this.type){const n=_c(i.toPremultipliedRenderColor(r));for(let i=e;i<t;i++)this.paintVertexArray.emplace(i,n[0],n[1])}else{for(let r=e;r<t;r++)this.paintVertexArray.emplace(r,i);this.maxValue=Math.max(this.maxValue,Math.abs(i))}}upload(e){this.paintVertexArray&&this.paintVertexArray.arrayBuffer&&(this.paintVertexBuffer&&this.paintVertexBuffer.buffer?this.paintVertexBuffer.updateData(this.paintVertexArray):this.paintVertexBuffer=e.createVertexBuffer(this.paintVertexArray,this.paintVertexAttributes,this.lutExpression&&"constant"!==this.lutExpression.kind&&(this.lutExpression.isStateDependent||!this.lutExpression.isLightConstant)||"constant"!==this.expression.kind&&(this.expression.isStateDependent||!this.expression.isLightConstant)))}destroy(){this.paintVertexBuffer&&this.paintVertexBuffer.destroy()}}class bc{constructor(e,t,i,r,n,o){this.expression=e,this.uniformNames=t.map(e=>`u_${e}_t`),this.type=i,this.useIntegerZoom=r,this.context=n,this.maxValue=0,this.paintVertexAttributes=t.map(e=>({name:`a_${e}`,type:"Float32",components:"color"===i?4:2,offset:0})),this.paintVertexArray=new o}populatePaintArray(e,t,i,r,n,o,s,a){const l=this.expression.evaluate(new sa(this.context.zoom,{brightness:o,worldview:a}),t,{},n,r,s),c=this.expression.evaluate(new sa(this.context.zoom+1,{brightness:o,worldview:a}),t,{},n,r,s),h=gc(this.lutExpression,t,{},r,n,o,s,a),u=this.paintVertexArray.length;this.paintVertexArray.resize(e),this._setPaintValue(u,e,l,c,h?null:this.context.lut)}updatePaintArray(e,t,i,r,n,o,s,a){const l=this.expression.evaluate({zoom:this.context.zoom,brightness:s,worldview:a},i,r,void 0,n),c=this.expression.evaluate({zoom:this.context.zoom+1,brightness:s,worldview:a},i,r,void 0,n),h=gc(this.lutExpression,i,r,n,void 0,s,void 0,a);this._setPaintValue(e,t,l,c,h?null:this.context.lut)}_setPaintValue(e,t,i,r,n){if("color"===this.type){const o=_c(i.toPremultipliedRenderColor(n)),s=_c(r.toPremultipliedRenderColor(n));for(let i=e;i<t;i++)this.paintVertexArray.emplace(i,o[0],o[1],s[0],s[1])}else{for(let n=e;n<t;n++)this.paintVertexArray.emplace(n,i,r);this.maxValue=Math.max(this.maxValue,Math.abs(i),Math.abs(r))}}upload(e){this.paintVertexArray&&this.paintVertexArray.arrayBuffer&&(this.paintVertexBuffer&&this.paintVertexBuffer.buffer?this.paintVertexBuffer.updateData(this.paintVertexArray):this.paintVertexBuffer=e.createVertexBuffer(this.paintVertexArray,this.paintVertexAttributes,this.expression.isStateDependent||!this.expression.isLightConstant))}destroy(){this.paintVertexBuffer&&this.paintVertexBuffer.destroy()}setUniform(e,t,i,r,n){const o=this.useIntegerZoom?Math.floor(i.zoom):i.zoom,s=ke(this.expression.interpolationFactor(o,this.context.zoom,this.context.zoom+1),0,1);t.set(e,n,s)}getBinding(e,t){return new lc(e)}}class wc{constructor(e,t,i,r,n){this.expression=e,this.layerId=n,this.paintVertexAttributes=("array"===i?tc:Ql).members;for(let o=0;o<t.length;++o);this.paintVertexArray=new r,this.paintTransitionVertexArray=new cl}populatePaintArray(e,t,i,r){const n=this.paintVertexArray.length;this.paintVertexArray.resize(e),this._setPaintValues(n,e,t.patterns&&t.patterns[this.layerId],i)}updatePaintArray(e,t,i,r,n,o,s){this._setPaintValues(e,t,i.patterns&&i.patterns[this.layerId],o)}_setPaintValues(e,t,i,r){if(!r||!i)return;const n=r[i[0]],o=r[i[1]];if(n){if(n){const{tl:i,br:r,pixelRatio:o}=n;for(let n=e;n<t;n++)this.paintVertexArray.emplace(n,i[0],i[1],r[0],r[1],o)}if(o){this.paintTransitionVertexArray.resize(this.paintVertexArray.length);const{tl:i,br:r}=o;for(let n=e;n<t;n++)this.paintTransitionVertexArray.emplace(n,i[0],i[1],r[0],r[1])}}}upload(e){const t=this.expression.isStateDependent||!this.expression.isLightConstant;this.paintVertexArray&&this.paintVertexArray.arrayBuffer&&(this.paintVertexBuffer=e.createVertexBuffer(this.paintVertexArray,this.paintVertexAttributes,t)),this.paintTransitionVertexArray&&this.paintTransitionVertexArray.length&&(this.paintTransitionVertexBuffer=e.createVertexBuffer(this.paintTransitionVertexArray,ec.members,t))}destroy(){this.paintVertexBuffer&&this.paintVertexBuffer.destroy(),this.paintTransitionVertexBuffer&&this.paintTransitionVertexBuffer.destroy()}}class Tc{constructor(e,t,i=()=>!0){this.binders={},this._buffers=[],this.context=t;const r=[],n=e;for(const o in e.paint._values){const s=n.paint.get(o);if(o.endsWith("-use-theme"))continue;if(!i(o))continue;if(!(s instanceof pa&&No(s.property.specification)))continue;const a=Ec(o,e.type),l=s.value,c=s.property.specification.type,h=!!s.property.useIntegerZoom,u="line-dasharray"===o||o.endsWith("pattern"),d=n.paint.get(`${o}-use-theme`),p="line-dasharray"===o&&"constant"!==n.layout.get("line-cap").value.kind||d&&"constant"!==d.value.kind;if("constant"!==l.kind||p)if("source"===l.kind||p||u){const t=Cc(o,c,"source");this.binders[o]=u?new wc(l,a,c,t,e.id):new vc(l,a,c,t),r.push(`/a_${o}`)}else{const e=Cc(o,c,"composite");this.binders[o]=new bc(l,a,c,h,t,e),r.push(`/z_${o}`)}else this.binders[o]=u?new xc(l.value,a):new yc(l.value,a,c,t),r.push(`/u_${o}`);d&&(this.binders[o].lutExpression=d.value)}this.cacheKey=r.sort().join("")}updateExpressions(e){const t=e;for(const i in this.binders){const e=this.binders[i];(e instanceof vc||e instanceof bc||e instanceof wc)&&(e.expression=t.paint.get(i).value)}}getMaxValue(e){const t=this.binders[e];return t instanceof vc||t instanceof bc?t.maxValue:0}populatePaintArrays(e,t,i,r,n,o,s,a){for(const l in this.binders){const c=this.binders[l];c.context=this.context,(c instanceof vc||c instanceof bc||c instanceof wc)&&c.populatePaintArray(e,t,i,r,n,o,s,a)}}setConstantPatternPositions(e,t){for(const i in this.binders){const r=this.binders[i];r instanceof xc&&r.setConstantPatternPositions(e,t)}}getPatternTransitionVertexBuffer(e){const t=this.binders[e];return t instanceof wc?t.paintTransitionVertexBuffer:null}updatePaintArrays(e,t,i,r,n,o,s,a,l,c){let h=!1;const u=Object.keys(e),d=0!==u.length&&!a,p=d?u:t.uniqueIds;this.context.lut=n.lut;for(const f in this.binders){const a=this.binders[f];if(a.context=this.context,(a instanceof vc||a instanceof bc||a instanceof wc)&&a.expression&&a.expression.kind&&"constant"!==a.expression.kind&&(!0===a.expression.isStateDependent||!1===a.expression.isLightConstant)){a.expression=n.paint.get(f).value;for(const i of p){const n=e[i.toString()];t.eachPosition(i,(e,t,i)=>{const h=r.feature(e);a.updatePaintArray(t,i,h,n,o,s,l,c)})}if(!d)for(const t of i.uniqueIds){const n=e[t.toString()];i.eachPosition(t,(e,t,i)=>{const h=r.feature(e);a.updatePaintArray(t,i,h,n,o,s,l,c)})}h=!0}}return h}defines(){const e=[];for(const t in this.binders){const i=this.binders[t];(i instanceof yc||i instanceof xc)&&e.push(...i.uniformNames.map(e=>`#define HAS_UNIFORM_${e}`))}return e}getPaintVertexBuffers(){return this._buffers}getUniforms(e){const t=[];for(const i in this.binders){const r=this.binders[i];if(r instanceof yc||r instanceof xc||r instanceof bc)for(const n of r.uniformNames)t.push({name:n,property:i,binding:r.getBinding(e,n)})}return t}setUniforms(e,t,i,r,n){for(const{name:o,property:s,binding:a}of i)this.binders[s].setUniform(e,a,n,r.get(s),o)}updatePaintBuffers(){this._buffers=[];for(const e in this.binders){const t=this.binders[e];(t instanceof vc||t instanceof bc||t instanceof wc)&&t.paintVertexBuffer&&this._buffers.push(t.paintVertexBuffer),t instanceof wc&&t.paintTransitionVertexBuffer&&this._buffers.push(t.paintTransitionVertexBuffer)}}upload(e){for(const t in this.binders){const i=this.binders[t];(i instanceof vc||i instanceof bc||i instanceof wc)&&i.upload(e)}this.updatePaintBuffers()}destroy(){for(const e in this.binders){const t=this.binders[e];(t instanceof vc||t instanceof bc||t instanceof wc)&&t.destroy()}}}class Sc{constructor(e,t,i=()=>!0){this.programConfigurations={};for(const r of e)this.programConfigurations[r.id]=new Tc(r,t,i);this.needsUpload=!1,this._featureMap=new ic,this._featureMapWithoutIds=new ic,this._bufferOffset=0,this._idlessCounter=0}populatePaintArrays(e,t,i,r,n,o,s,a,l){for(const c in this.programConfigurations)this.programConfigurations[c].populatePaintArrays(e,t,r,n,o,s,a,l);void 0!==t.id?this._featureMap.add(t.id,i,this._bufferOffset,e):(this._featureMapWithoutIds.add(this._idlessCounter,i,this._bufferOffset,e),this._idlessCounter+=1),this._bufferOffset=e,this.needsUpload=!0}updatePaintArrays(e,t,i,r,n,o,s,a){for(const l of i)this.needsUpload=this.programConfigurations[l.id].updatePaintArrays(e,this._featureMap,this._featureMapWithoutIds,t,l,r,n,o,s||0,a)||this.needsUpload}get(e){return this.programConfigurations[e]}upload(e){if(this.needsUpload){for(const t in this.programConfigurations)this.programConfigurations[t].upload(e);this.needsUpload=!1}}destroy(){for(const e in this.programConfigurations)this.programConfigurations[e].destroy()}updateExpressions(e){const t=/* @__PURE__ */new Set;for(const i of e){const e=this.programConfigurations[i.id];e&&(e.updateExpressions(i),t.add(i.id))}for(const i in this.programConfigurations)t.has(i)||delete this.programConfigurations[i]}}const Ic={"text-opacity":["opacity"],"icon-opacity":["opacity"],"text-occlusion-opacity":["occlusion_opacity"],"icon-occlusion-opacity":["occlusion_opacity"],"text-color":["fill_color"],"icon-color":["fill_color"],"text-emissive-strength":["emissive_strength"],"icon-emissive-strength":["emissive_strength"],"text-halo-color":["halo_color"],"icon-halo-color":["halo_color"],"text-halo-blur":["halo_blur"],"icon-halo-blur":["halo_blur"],"text-halo-width":["halo_width"],"icon-halo-width":["halo_width"],"symbol-z-offset":["z_offset"],"line-gap-width":["gapwidth"],"line-pattern":["pattern","pixel_ratio","pattern_b"],"fill-pattern":["pattern","pixel_ratio","pattern_b"],"fill-extrusion-pattern":["pattern","pixel_ratio","pattern_b"],"line-dasharray":["dash"],"fill-bridge-guard-rail-color":["structure_color"],"fill-tunnel-structure-color":["structure_color"]};function Ec(e,t){return Ic[e]||[e.replace(`${t}-`,"").replace(/-/g,"_")]}const Ac={"line-pattern":{source:ll,composite:ll},"fill-pattern":{source:ll,composite:ll},"fill-extrusion-pattern":{source:ll,composite:ll},"line-dasharray":{source:cl,composite:cl}},Mc={color:{source:Ml,composite:pl},number:{source:tl,composite:Ml}};function Cc(e,t,i){const r=Ac[e];return r&&r[i]||Mc[t][i]}as(yc,"ConstantBinder"),as(xc,"PatternConstantBinder"),as(vc,"SourceExpressionBinder",{omit:["expression"]}),as(wc,"PatternCompositeBinder",{omit:["expression"]}),as(bc,"CompositeExpressionBinder",{omit:["expression"]}),as(Tc,"ProgramConfiguration",{omit:["_buffers"]}),as(Sc,"ProgramConfigurationSet");const Pc=Yr/Math.PI/2,Dc=64,Rc=[Dc,32,16],zc=-Pc,Lc=Pc;function Fc(e,t,i,r=Pc){return i=Re(i),[e*Math.sin(i)*r,-t*r,e*Math.cos(i)*r]}function Oc(e,t,i){return Fc(Math.cos(Re(e)),Math.sin(Re(e)),t,i)}const Bc=6371008.8,kc=2*Math.PI*Bc;class Nc{constructor(e,t){if(isNaN(e)||isNaN(t))throw new Error(`Invalid LngLat object: (${e}, ${t})`);if(this.lng=+e,this.lat=+t,this.lat>90||this.lat<-90)throw new Error("Invalid LngLat latitude value: must be between -90 and 90")}wrap(){return new Nc(Ue(this.lng,-180,180),this.lat)}toArray(){return[this.lng,this.lat]}toString(){return`LngLat(${this.lng}, ${this.lat})`}distanceTo(e){const t=Math.PI/180,i=this.lat*t,r=e.lat*t,n=Math.sin(i)*Math.sin(r)+Math.cos(i)*Math.cos(r)*Math.cos((e.lng-this.lng)*t);return Bc*Math.acos(Math.min(n,1))}toBounds(e=0){const t=360*e/40075017,i=t/Math.cos(Math.PI/180*this.lat);return new Uc({lng:this.lng-i,lat:this.lat-t},{lng:this.lng+i,lat:this.lat+t})}toEcef(e){return Oc(this.lat,this.lng,Pc+e*Pc/Bc)}static convert(e){if(e instanceof Nc)return e;if(Array.isArray(e)&&(2===e.length||3===e.length))return new Nc(Number(e[0]),Number(e[1]));if(!Array.isArray(e)&&"object"==typeof e&&null!==e)return new Nc(Number("lng"in e?e.lng:e.lon),Number(e.lat));throw new Error("`LngLatLike` argument must be specified as a LngLat instance, an object {lng: <lng>, lat: <lat>}, an object {lon: <lng>, lat: <lat>}, or an array of [<lng>, <lat>]")}}class Uc{constructor(e,t){e&&(t?this.setSouthWest(e).setNorthEast(t):Array.isArray(e)&&4===e.length?this.setSouthWest([e[0],e[1]]).setNorthEast([e[2],e[3]]):this.setSouthWest(e[0]).setNorthEast(e[1]))}setNorthEast(e){return this._ne=e instanceof Nc?new Nc(e.lng,e.lat):Nc.convert(e),this}setSouthWest(e){return this._sw=e instanceof Nc?new Nc(e.lng,e.lat):Nc.convert(e),this}extend(e){const t=this._sw,i=this._ne;let r,n;if(e instanceof Nc)r=e,n=e;else{if(!(e instanceof Uc))return Array.isArray(e)?4===e.length||e.every(Array.isArray)?this.extend(Uc.convert(e)):this.extend(Nc.convert(e)):"object"==typeof e&&null!==e&&Object.hasOwn(e,"lat")&&(Object.hasOwn(e,"lon")||Object.hasOwn(e,"lng"))?this.extend(Nc.convert(e)):this;if(r=e._sw,n=e._ne,!r||!n)return this}return t||i?(t.lng=Math.min(r.lng,t.lng),t.lat=Math.min(r.lat,t.lat),i.lng=Math.max(n.lng,i.lng),i.lat=Math.max(n.lat,i.lat)):(this._sw=new Nc(r.lng,r.lat),this._ne=new Nc(n.lng,n.lat)),this}getCenter(){return new Nc((this._sw.lng+this._ne.lng)/2,(this._sw.lat+this._ne.lat)/2)}getSouthWest(){return this._sw}getNorthEast(){return this._ne}getNorthWest(){return new Nc(this.getWest(),this.getNorth())}getSouthEast(){return new Nc(this.getEast(),this.getSouth())}getWest(){return this._sw.lng}getSouth(){return this._sw.lat}getEast(){return this._ne.lng}getNorth(){return this._ne.lat}toArray(){return[this._sw.toArray(),this._ne.toArray()]}toString(){return`LngLatBounds(${this._sw.toString()}, ${this._ne.toString()})`}isEmpty(){return!(this._sw&&this._ne)}contains(e){const{lng:t,lat:i}=Nc.convert(e);let r=this._sw.lng<=t&&t<=this._ne.lng;return this._sw.lng>this._ne.lng&&(r=this._sw.lng>=t&&t>=this._ne.lng),this._sw.lat<=i&&i<=this._ne.lat&&r}static convert(e){if(e)return e instanceof Uc?e:new Uc(e)}}function Vc(e){return kc*Math.cos(e*Math.PI/180)}function jc(e){return(180+e)/360}function Gc(e){return(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+e*Math.PI/360)))/360}function Hc(e,t){return e/Vc(t)}function $c(e){return 360*e-180}function qc(e){return 360/Math.PI*Math.atan(Math.exp((180-360*e)*Math.PI/180))-90}function Zc(e,t){return e*Vc(qc(t))}const Wc=85.051129;function Xc(e){return Math.cos(Re(ke(e,-85.051129,Wc)))}function Yc(e,t){const i=ke(t,0,25.5),r=Math.pow(2,i);return Xc(e)*kc/(512*r)}function Jc(e){return 1/Math.cos(e*Math.PI/180)}function Kc(e,t=0){const i=Math.exp(Math.PI*(1-(e.y+t/Yr)/(1<<e.z)*2));return 80150034*i/(i*i+1)/Yr/(1<<e.z)}class Qc{constructor(e,t,i=0){this.x=+e,this.y=+t,this.z=+i}static fromLngLat(e,t=0){const i=Nc.convert(e);return new Qc(jc(i.lng),Gc(i.lat),Hc(t,i.lat))}toLngLat(){return new Nc($c(this.x),qc(this.y))}toAltitude(){return Zc(this.z,this.y)}meterInMercatorCoordinateUnits(){return 1/kc*Jc(qc(this.y))}}function eh(e,t,i,r,n,o,s,a,l){const c=(t+r)/2,h=(i+n)/2,u=new Ie(c,h);a(u),function(e,t,i,r,n,o){const s=i-n,a=r-o;return Math.abs((r-t)*s-(i-e)*a)/Math.hypot(s,a)}(u.x,u.y,o.x,o.y,s.x,s.y)>=l?(eh(e,t,i,c,h,o,u,a,l),eh(e,c,h,r,n,u,s,a,l)):e.push(s)}function th(e,t,i){let r=e[0],n=r.x,o=r.y;t(r);const s=[r];for(let a=1;a<e.length;a++){const l=e[a],{x:c,y:h}=l;t(l),eh(s,n,o,c,h,r,l,t,i),n=c,o=h,r=l}return s}function ih(e,t,i,r){if(r(t,i)){const n=t.add(i)._mult(.5);ih(e,t,n,r),ih(e,n,i,r)}else e.push(i)}function rh(e,t){let i=e[0];const r=[i];for(let n=1;n<e.length;n++){const o=e[n];ih(r,i,o,t),i=o}return r}const nh=Math.pow(2,14)-1,oh=-nh-1;function sh(e,t){const i=Math.round(e.x*t),r=Math.round(e.y*t);return e.x=ke(i,oh,nh),e.y=ke(r,oh,nh),(i<e.x||i>e.x+1||r<e.y||r>e.y+1)&&Ke("Geometry exceeds allowed extent, reduce your vector tile buffer size"),e}function ah(e,t,i){const r=e.loadGeometry(),n=e.extent,o=Yr/n;if(t&&i&&i.projection.isReprojectedInTileSpace){const o=1<<t.z,{scale:s,x:a,y:l,projection:c}=i,h=e=>{const i=$c((t.x+e.x/n)/o),r=qc((t.y+e.y/n)/o),h=c.project(i,r);e.x=(h.x*s-a)*n,e.y=(h.y*s-l)*n};for(let t=0;t<r.length;t++)if(1!==e.type)r[t]=th(r[t],h,1);else{const e=[];for(const i of r[t])i.x<0||i.x>=n||i.y<0||i.y>=n||(h(i),e.push(i));r[t]=e}}for(const s of r)for(const e of s)sh(e,o);return r}function lh(e,t){return{type:e.type,id:e.id,properties:e.properties,geometry:t?ah(e):[]}}class ch{constructor(e,t,i,r,n){this.properties={},this.extent=i,this.type=0,this.id=void 0,this._pbf=e,this._geometry=-1,this._keys=r,this._values=n,e.readFields(hh,this,t)}loadGeometry(){const e=this._pbf;e.pos=this._geometry;const t=e.readVarint()+e.pos,i=[];let r,n=1,o=0,s=0,a=0;for(;e.pos<t;){if(o<=0){const t=e.readVarint();n=7&t,o=t>>3}if(o--,1===n||2===n)s+=e.readSVarint(),a+=e.readSVarint(),1===n&&(r&&i.push(r),r=[]),r&&r.push(new Ie(s,a));else{if(7!==n)throw new Error(`unknown command ${n}`);r&&r.push(r[0].clone())}}return r&&i.push(r),i}bbox(){const e=this._pbf;e.pos=this._geometry;const t=e.readVarint()+e.pos;let i=1,r=0,n=0,o=0,s=1/0,a=-1/0,l=1/0,c=-1/0;for(;e.pos<t;){if(r<=0){const t=e.readVarint();i=7&t,r=t>>3}if(r--,1===i||2===i)n+=e.readSVarint(),o+=e.readSVarint(),n<s&&(s=n),n>a&&(a=n),o<l&&(l=o),o>c&&(c=o);else if(7!==i)throw new Error(`unknown command ${i}`)}return[s,l,a,c]}toGeoJSON(e,t,i){const r=this.extent*Math.pow(2,i),n=this.extent*e,o=this.extent*t,s=this.loadGeometry();function a(e){return[360*(e.x+n)/r-180,360/Math.PI*Math.atan(Math.exp((1-2*(e.y+o)/r)*Math.PI))-90]}function l(e){return e.map(a)}let c;if(1===this.type){const e=[];for(const i of s)e.push(i[0]);const t=l(e);c=1===e.length?{type:"Point",coordinates:t[0]}:{type:"MultiPoint",coordinates:t}}else if(2===this.type){const e=s.map(l);c=1===e.length?{type:"LineString",coordinates:e[0]}:{type:"MultiLineString",coordinates:e}}else{if(3!==this.type)throw new Error("unknown feature type");{const e=function(e){const t=e.length;if(t<=1)return[e];const i=[];let r,n;for(let o=0;o<t;o++){const t=uh(e[o]);0!==t&&(void 0===n&&(n=t<0),n===t<0?(r&&i.push(r),r=[e[o]]):r&&r.push(e[o]))}return r&&i.push(r),i}(s),t=[];for(const i of e)t.push(i.map(l));c=1===t.length?{type:"Polygon",coordinates:t[0]}:{type:"MultiPolygon",coordinates:t}}}const h={type:"Feature",geometry:c,properties:this.properties};return null!=this.id&&(h.id=this.id),h}}function hh(e,t,i){1===e?t.id=i.readVarint():2===e?function(e,t){const i=e.readVarint()+e.pos;for(;e.pos<i;){const i=t._keys[e.readVarint()],r=t._values[e.readVarint()];t.properties[i]=r}}(i,t):3===e?t.type=i.readVarint():4===e&&(t._geometry=i.pos)}function uh(e){let t=0;for(let i,r,n=0,o=e.length,s=o-1;n<o;s=n++)i=e[n],r=e[s],t+=(r.x-i.x)*(i.y+r.y);return t}ch.types=["Unknown","Point","LineString","Polygon"];class dh{constructor(e,t){this.version=1,this.name="",this.extent=4096,this.length=0,this._pbf=e,this._keys=[],this._values=[],this._features=[],e.readFields(ph,this,t),this.length=this._features.length}feature(e){if(e<0||e>=this._features.length)throw new Error("feature index out of bounds");this._pbf.pos=this._features[e];const t=this._pbf.readVarint()+this._pbf.pos;return new ch(this._pbf,t,this.extent,this._keys,this._values)}}function ph(e,t,i){15===e?t.version=i.readVarint():1===e?t.name=i.readString():5===e?t.extent=i.readVarint():2===e?t._features.push(i.pos):3===e?t._keys.push(i.readString()):4===e&&t._values.push(function(e){let t=null;const i=e.readVarint()+e.pos;for(;e.pos<i;){const i=e.readVarint()>>3;t=1===i?e.readString():2===i?e.readFloat():3===i?e.readDouble():4===i?e.readVarint64():5===i?e.readVarint():6===i?e.readSVarint():7===i?e.readBoolean():null}if(null==t)throw new Error("unknown feature value");return t}(i))}class fh{constructor(e,t){this.layers=e.readFields(mh,{},t)}}function mh(e,t,i){if(3===e){const e=new dh(i,i.readVarint()+i.pos);e.length&&(t[e.name]=e)}}const _h="3d_elevation_id",gh="level";class yh{constructor(){this._valid=!1}reset(e){return this.feature=e,this._valid=!0,this._geometry=e.loadGeometry(),0!==this._geometry.length&&0!==this._geometry[0].length||(this._valid=!1),this}geometry(e,t){return this._valid&&e(t(this._geometry)),this}require(e,t,i){return this.get(e,!0,t,i)}optional(e,t,i){return this.get(e,!1,t,i)}success(){return this._valid}get(e,t,i,r){const n=Object.hasOwn(this.feature.properties,e)?+this.feature.properties[e]:void 0;return this._valid&&void 0!==n&&!Number.isNaN(n)?i(r?r(n):n):t&&(this._valid=!1),this}}class xh{constructor(e,t){this.featureFunc=e,this.vertexFunc=t}parseFeature(e,t,i){return this.featureFunc(e,t,i)}parseVertex(e,t,i){return this.vertexFunc(e,t,i)}}const vh=new xh((e,t,i)=>e.reset(t).require(_h,e=>{i.id=e}).optional("fixed_height_relative",e=>{i.constantHeight=e},wh.decodeRelativeHeight).geometry(e=>{i.bounds=e},Mr).success(),(e,t,i)=>e.reset(t).require(_h,e=>{i.id=e}).require("elevation_idx",e=>{i.idx=e}).require("extent",e=>{i.extent=e}).require("height_relative",e=>{i.height=e},wh.decodeRelativeHeight).geometry(e=>{i.position=e},wh.getPoint).success()),bh=new xh((e,t,i)=>e.reset(t).require(_h,e=>{i.id=e}).optional("fixed_height",e=>{i.constantHeight=e},wh.decodeMetricHeight).geometry(e=>{i.bounds=e},Mr).success(),(e,t,i)=>e.reset(t).require(_h,e=>{i.id=e}).require("elevation_idx",e=>{i.idx=e}).require("extent",e=>{i.extent=e}).require("height",e=>{i.height=e},wh.decodeMetricHeight).geometry(e=>{i.position=e},wh.getPoint).success());class wh{static getPoint(e){return de(e[0][0].x,e[0][0].y)}static decodeRelativeHeight(e){return 1e-4*e*5}static decodeMetricHeight(e){return 1e-4*e}static getVersionSchema(e){return e?"1.0.1"===e?bh:void 0:vh}static parse(e){const t=[],i=[],r=e.length,n=new yh;for(let o=0;o<r;o++){const r=e.feature(o),s=r.properties.version,a=wh.getVersionSchema(s);if(void 0===a){Ke(`Unknown elevation feature version number ${s||"(unknown)"}`);continue}const l=r.properties.type;if(!l)continue;const c=ch.types[r.type];if("Point"===c&&"curve_point"===l){const e={};a.parseVertex(n,r,e)&&t.push(e)}else if("Polygon"===c&&"curve_meta"===l){const e={};a.parseFeature(n,r,e)&&i.push(e)}}return{vertices:t,features:i}}}class Th{constructor(e,t){this.pos=e,this.dir=t}intersectsPlane(e,t,i){const r=xe(t,this.dir);if(Math.abs(r)<1e-6)return!1;const n=((e[0]-this.pos[0])*t[0]+(e[1]-this.pos[1])*t[1])/r;return i[0]=this.pos[0]+this.dir[0]*n,i[1]=this.pos[1]+this.dir[1]*n,!0}}class Sh{constructor(e,t){this.pos=e,this.dir=t}intersectsPlane(e,t,i){const r=V(t,this.dir);if(Math.abs(r)<1e-6)return!1;const n=((e[0]-this.pos[0])*t[0]+(e[1]-this.pos[1])*t[1]+(e[2]-this.pos[2])*t[2])/r;return i[0]=this.pos[0]+this.dir[0]*n,i[1]=this.pos[1]+this.dir[1]*n,i[2]=this.pos[2]+this.dir[2]*n,!0}closestPointOnSphere(e,t,r){if(function(e,t){var r=e[0],n=e[1],o=e[2],s=t[0],a=t[1],l=t[2];return Math.abs(r-s)<=i*Math.max(1,Math.abs(r),Math.abs(s))&&Math.abs(n-a)<=i*Math.max(1,Math.abs(n),Math.abs(a))&&Math.abs(o-l)<=i*Math.max(1,Math.abs(o),Math.abs(l))}(this.pos,e)||0===t)return r[0]=r[1]=r[2]=0,!1;const[n,o,s]=this.dir,a=this.pos[0]-e[0],l=this.pos[1]-e[1],c=this.pos[2]-e[2],h=n*n+o*o+s*s,u=2*(a*n+l*o+c*s),d=u*u-4*h*(a*a+l*l+c*c-t*t);if(d<0){const e=Math.max(-u/2,0),i=a+n*e,h=l+o*e,d=c+s*e,p=Math.hypot(i,h,d);return r[0]=i*t/p,r[1]=h*t/p,r[2]=d*t/p,!1}{const e=(-u-Math.sqrt(d))/(2*h);if(e<0){const e=Math.hypot(a,l,c);return r[0]=a*t/e,r[1]=l*t/e,r[2]=c*t/e,!1}return r[0]=a+n*e,r[1]=l+o*e,r[2]=c+s*e,!0}}}class Ih{constructor(e,t,i,r,n){this.TL=e,this.TR=t,this.BR=i,this.BL=r,this.horizon=n}static fromInvProjectionMatrix(e,t,i){const r=[-1,1,1],n=[1,1,1],o=[1,-1,1],s=[-1,-1,1];return new Ih(H(r,r,e),H(n,n,e),H(o,o,e),H(s,s,e),t/i)}}function Eh(e,t,i,r){const n=t[0],o=t[1],s=t[2],a=i[0],l=i[1],c=i[2];let h=1/0,u=-1/0;for(let d=0;d<e.length;d++){const t=e[d],i=(t[0]-n)*a+(t[1]-o)*l+(t[2]-s)*c;i<h&&(h=i),i>u&&(u=i)}return r[0]=h,r[1]=u,r}function Ah(e,t){let i=!0;for(let r=0;r<e.planes.length;r++){const n=e.planes[r];let o=0;for(let e=0;e<t.length;e++)o+=+(V(n,t[e])+n[3]>=0);if(0===o)return 0;o!==t.length&&(i=!1)}return i?2:1}const Mh=[0,0];function Ch(e,t){for(const i of e.projections){const r=Eh(t,e.points[0],i.axis,Mh);if(i.projection[1]<r[0]||i.projection[0]>r[1])return 0}return 1}function Ph(e,t){const i=t[0],r=t[1],n=t[2],o=t[3];for(let s=0;s<e.length;s++){const t=e[s];if(i*t[0]+r*t[1]+n*t[2]+o>=0)return!0}return!1}class Dh{constructor(e,t){this.points=e||new Array(8).fill([0,0,0]),this.planes=t||new Array(6).fill([0,0,0,0]),this.bounds=Rh.fromPoints(this.points),this.projections=[],this.frustumEdges=[X([],this.points[2],this.points[3]),X([],this.points[0],this.points[3]),X([],this.points[4],this.points[0]),X([],this.points[5],this.points[1]),X([],this.points[6],this.points[2]),X([],this.points[7],this.points[3])];for(const i of this.frustumEdges){const e=[0,-i[2],i[1]],t=[i[2],0,-i[0]];this.projections.push({axis:e,projection:Eh(this.points,this.points[0],e,[0,0])}),this.projections.push({axis:t,projection:Eh(this.points,this.points[0],t,[0,0])})}}static fromInvProjectionMatrix(e,t,i,r){const n=Math.pow(2,i),o=[[-1,1,-1,1],[1,1,-1,1],[1,-1,-1,1],[-1,-1,-1,1],[-1,1,1,1],[1,1,1,1],[1,-1,1,1],[-1,-1,1,1]].map(i=>{const o=te([],i,e),s=1/o[3]/t*n;return(a=o)[0]=(l=o)[0]*(c=[s,s,r?1/o[3]:s,s])[0],a[1]=l[1]*c[1],a[2]=l[2]*c[2],a[3]=l[3]*c[3],a;var a,l,c}),s=[[0,1,2],[6,5,4],[0,3,7],[2,1,5],[3,2,6],[0,4,5]].map(e=>{const t=U([],j([],X([],o[e[0]],o[e[1]]),X([],o[e[2]],o[e[1]]))),i=-V(t,o[e[1]]);return t.concat(i)}),a=[];for(let l=0;l<o.length;l++)a.push([o[l][0],o[l][1],o[l][2]]);return new Dh(a,s)}intersectsPrecise(e,t,i){for(let a=0;a<t.length;a++)if(!Ph(e,t[a]))return 0;for(let a=0;a<this.planes.length;a++)if(!Ph(e,this.planes[a]))return 0;const r=this.points,n=r[0][0],o=r[0][1],s=r[0][2];for(const a of i)for(const t of this.frustumEdges){const i=a[1]*t[2]-a[2]*t[1],l=a[2]*t[0]-a[0]*t[2],c=a[0]*t[1]-a[1]*t[0];if(0===i&&0===l&&0===c)continue;let h=1/0,u=-1/0;for(let e=0;e<r.length;e++){const t=r[e],a=(t[0]-n)*i+(t[1]-o)*l+(t[2]-s)*c;a<h&&(h=a),a>u&&(u=a)}let d=1/0,p=-1/0;for(let t=0;t<e.length;t++){const r=e[t],a=(r[0]-n)*i+(r[1]-o)*l+(r[2]-s)*c;a<d&&(d=a),a>p&&(p=a)}if(h>p||d>u)return 0}return 1}containsPoint(e){for(const t of this.planes){const i=t[3];if(V([t[0],t[1],t[2]],e)+i<0)return!1}return!0}}class Rh{static fromPoints(e){const t=[1/0,1/0,1/0],i=[-1/0,-1/0,-1/0];for(const r of e)R(t,t,r),z(i,i,r);return new Rh(t,i)}static fromTileIdAndHeight(e,t,i){const r=1<<e.canonical.z,n=e.canonical.x,o=e.canonical.y;return new Rh([n/r,o/r,t],[(n+1)/r,(o+1)/r,i])}static applyTransform(e,t){const i=e.getCorners();for(let r=0;r<i.length;++r)H(i[r],i[r],t);return Rh.fromPoints(i)}static applyTransformFast(e,t){const i=[t[12],t[13],t[14]],r=[...i];for(let n=0;n<3;n++)for(let o=0;o<3;o++){const s=t[4*o+n],a=s*e.min[o],l=s*e.max[o];i[n]+=Math.min(a,l),r[n]+=Math.max(a,l)}return new Rh(i,r)}static projectAabbCorners(e,t){const i=e.getCorners();for(let r=0;r<i.length;++r)H(i[r],i[r],t);return i}constructor(e,t){this.min=e,this.max=t,this.center=L([],C([],this.min,this.max),.5)}quadrant(e){const t=[e%2==0,e<2],i=I(this.min),r=I(this.max);for(let n=0;n<t.length;n++)i[n]=t[n]?this.min[n]:this.center[n],r[n]=t[n]?this.center[n]:this.max[n];return r[2]=this.max[2],new Rh(i,r)}distanceX(e){return Math.max(Math.min(this.max[0],e[0]),this.min[0])-e[0]}distanceY(e){return Math.max(Math.min(this.max[1],e[1]),this.min[1])-e[1]}distanceZ(e){return Math.max(Math.min(this.max[2],e[2]),this.min[2])-e[2]}getCorners(){const e=this.min,t=this.max;return[[e[0],e[1],e[2]],[t[0],e[1],e[2]],[t[0],t[1],e[2]],[e[0],t[1],e[2]],[e[0],e[1],t[2]],[t[0],e[1],t[2]],[t[0],t[1],t[2]],[e[0],t[1],t[2]]]}intersects(e){return this.intersectsAabb(e.bounds)?Ah(e,this.getCorners()):0}intersectsFlat(e){return this.intersectsAabb(e.bounds)?Ah(e,[[this.min[0],this.min[1],0],[this.max[0],this.min[1],0],[this.max[0],this.max[1],0],[this.min[0],this.max[1],0]]):0}intersectsPrecise(e,t){return t||this.intersects(e)?Ch(e,this.getCorners()):0}intersectsPreciseFlat(e,t){return t||this.intersectsFlat(e)?Ch(e,[[this.min[0],this.min[1],0],[this.max[0],this.min[1],0],[this.max[0],this.max[1],0],[this.min[0],this.max[1],0]]):0}intersectsAabb(e){for(let t=0;t<3;++t)if(this.min[t]>e.max[t]||e.min[t]>this.max[t])return!1;return!0}intersectsAabbXY(e){return!(this.min[0]>e.max[0]||e.min[0]>this.max[0]||this.min[1]>e.max[1]||e.min[1]>this.max[1])}encapsulate(e){for(let t=0;t<3;t++)this.min[t]=Math.min(this.min[t],e.min[t]),this.max[t]=Math.max(this.max[t],e.max[t])}encapsulatePoint(e){for(let t=0;t<3;t++)this.min[t]=Math.min(this.min[t],e[t]),this.max[t]=Math.max(this.max[t],e[t])}closestPoint(e){return[Math.max(Math.min(this.max[0],e[0]),this.min[0]),Math.max(Math.min(this.max[1],e[1]),this.min[1]),Math.max(Math.min(this.max[2],e[2]),this.min[2])]}}as(Rh,"Aabb");class zh{constructor(e,t){this.feature=e,this.metersToTile=t,this.index=0}get(){const e=this.feature.vertices[this.index],t=this.feature.vertexProps[this.index].dir,i=t[1],r=-t[0],n=(e.extent+1)*this.metersToTile;return[new Ie(Math.trunc(e.position[0]+i*n),Math.trunc(e.position[1]+r*n)),new Ie(Math.trunc(e.position[0]-i*n),Math.trunc(e.position[1]-r*n))]}next(){this.index++}valid(){return this.index<this.feature.vertices.length}}class Lh{constructor(e,t,i,r,n,o){if(this.vertices=new Array,this.vertexProps=new Array,this.edges=new Array,this.edgeProps=new Array,this._tmpVec2=[ue(),ue(),ue(),ue(),ue(),ue(),ue()],this.id=e,this.heightRange={min:i,max:i},this.safeArea=t,this.constantHeight=i,null==this.constantHeight&&(null!=this.constantHeight||0!==r.length)){this.vertices=r,this.edges=n,this.edges=this.edges.filter(e=>{return e.a<this.vertices.length&&e.b<this.vertices.length&&!((t=this.vertices[e.a].position)[0]===(i=this.vertices[e.b].position)[0]&&t[1]===i[1]);var t,i}),this.heightRange={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};for(const e of this.vertices)this.vertexProps.push({dir:de(0,0)}),this.heightRange.min=Math.min(this.heightRange.min,e.height),this.heightRange.max=Math.max(this.heightRange.max,e.height);for(const e of this.edges){const t=this.vertices[e.a].position,i=this.vertices[e.b].position,r=me(ue(),i,t),n=ge(r),o=_e(ue(),r,1/n);this.edgeProps.push({vec:r,dir:o,len:n});const s=this.vertexProps[e.a].dir,a=this.vertexProps[e.b].dir;fe(s,s,o),fe(a,a,o)}for(const e of this.vertexProps)0===e.dir[0]&&0===e.dir[1]||ye(e.dir,e.dir);this.tessellate(o)}}pointElevation(e){if(null!=this.constantHeight)return this.constantHeight;const t=this.getClosestEdge(e);if(null==t)return 0;const[i,r]=t;return yi(this.vertices[this.edges[i].a].height,this.vertices[this.edges[i].b].height,r)}computeSlopeNormal(e,t){const i=this.getClosestEdge(e);if(!i)return A(0,0,1);const r=i[0],n=this.edges[r],o=this.edgeProps[r].vec,s=A(o[0],o[1],(this.vertices[n.b].height-this.vertices[n.a].height)*t),a=A(s[1],-s[0],0);j(a,a,s);const l=E(a);return l>0?L(a,a,1/l):M(a,0,0,1)}getSafeArea(){return this.safeArea}isTunnel(){return this.heightRange.max<=-5}getClosestEdge(e){if(0===this.edges.length)return;let t=0,i=Number.POSITIVE_INFINITY,r=0;const[n,o,s,a,l,c,h]=this._tmpVec2;pe(h,e.x,e.y);const u=new Th(h,null);for(let d=0;d<this.edges.length;d++){const e=this.edges[d],p=this.edgeProps[d].dir;u.dir=p;const f=this.vertices[e.a].position,m=this.vertices[e.b].position,_=u.intersectsPlane(f,this.vertexProps[e.a].dir,n),g=u.intersectsPlane(m,this.vertexProps[e.b].dir,o);if(!_||!g)continue;me(s,o,n),me(a,h,n);const y=xe(s,s),x=y>0?xe(a,s)/y:0,v=ke(x,0,1),b=Math.abs((x-v)*this.edgeProps[d].len);me(l,h,f),pe(c,p[1],-p[0]);const w=b+Math.abs(xe(l,c));w<i&&(t=d,i=w,r=v)}return[t,r]}tessellate(e){const t=S(),i=S(),r=S(),n=S();for(let o=this.edges.length-1;o>=0;--o){const s=this.edges[o].a,a=this.edges[o].b,{position:l,height:c,extent:h}=this.vertices[s],{position:u,height:d,extent:p}=this.vertices[a],f=this.vertexProps[s].dir,m=this.vertexProps[a].dir;if(M(t,l[0]/e,l[1]/e,c),M(i,u[0]/e,u[1]/e,d),M(r,f[1],-f[0],0),L(r,r,h),M(n,m[1],-m[0],0),L(n,n,p),this.distSqLines(A(t[0]+.5*r[0],t[1]+.5*r[1],t[2]+.5*r[2]),A(i[0]-.5*n[0],i[1]-.5*n[1],i[2]-.5*n[2]),A(t[0]-.5*r[0],t[1]-.5*r[1],t[2]-.5*r[2]),A(i[0]+.5*n[0],i[1]+.5*n[1],i[2]+.5*n[2]))<=.0025000000000000005)continue;const _=this.vertices.length,g=fe(ue(),l,u);this.vertices.push({position:_e(g,g,.5),height:.5*(c+d),extent:.5*(h+p)});const y=fe(ue(),f,m);this.vertexProps.push({dir:ye(y,y)}),this.edges.splice(o,1),this.edgeProps.splice(o,1),this.edges.push({a:s,b:_}),this.edges.push({a:_,b:a});const x=me(ue(),this.vertices[_].position,l),v=ge(x),b={vec:x,dir:_e(ue(),x,1/v),len:v};this.edgeProps.push(b),this.edgeProps.push(b)}}distSqLines(e,t,i,r){const n=P(S(),t,e),o=P(S(),r,i),s=P(S(),e,i),a=V(n,n),l=V(n,o),c=V(n,s),h=V(o,o),u=V(o,s),d=a*h-l*l;if(0===d)return B(G(n,i,r,V(s,o)/V(o,o)),e);const p=(a*u-l*c)/d;return B(G(n,e,t,(l*u-c*h)/d),G(o,i,r,p))}}class Fh{static parseFrom(e,t){const i=wh.parse(e);if(!i)return[];let{vertices:r,features:n}=i;const o=1/Kc(t);n.sort((e,t)=>e.id-t.id),r.sort((e,t)=>e.id-t.id||e.idx-t.idx),r=r.filter((e,t,i)=>t===i.findIndex(t=>t.id===e.id&&t.idx===e.idx));const s=new Array;let a=0;const l=r.length;for(const c of n){if(c.constantHeight){s.push(new Lh(c.id,c.bounds,c.constantHeight));continue}for(;a!==l&&r[a].id<c.id;)a++;if(a===l||r[a].id!==c.id)continue;const e=new Array,t=new Array,i=a;for(;a!==l&&r[a].id===c.id;){const n=r[a];if(e.push({position:n.position,height:n.height,extent:n.extent}),a!==i&&r[a-1].idx===n.idx-1){const e=a-i;t.push({a:e-1,b:e})}a++}s.push(new Lh(c.id,c.bounds,void 0,e,t,o))}return s}static getElevationFeature(e,t){if(!t)return;const i=+e.properties[_h];return Number.isNaN(i)?void 0:t.find(e=>e.id===i)}}class Oh{constructor(e,t){this.zScale=1,this.xOffset=0,this.yOffset=0,e.equals(t)||(this.zScale=Math.pow(2,t.z-e.z),this.xOffset=(e.x*this.zScale-t.x)*Yr,this.yOffset=(e.y*this.zScale-t.y)*Yr)}constantElevation(e,t){if(null!=e.constantHeight)return this.computeBiasedHeight(e.constantHeight,t)}pointElevation(e,t,i){const r=this.constantElevation(t,i);return null!=r?r:(e.x=e.x*this.zScale+this.xOffset,e.y=e.y*this.zScale+this.yOffset,this.computeBiasedHeight(t.pointElevation(e),i))}computeBiasedHeight(e,t){return t<=0?e:e+t*Ne(0,t,e>=0?e:Math.abs(.5*e))}}function Bh(e){if(0===e)return[0,0,0];const t=Ao(e);return[t(),t(),t()]}as(Lh,"ElevationFeature");class kh{constructor(e){this.zoom=e.zoom,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.hasPattern=!1,this.projection=e.projection,this.layoutVertexArray=new Ka,this.indexArray=new vl,this.segments=new Jl,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut}),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.elevationMode=this.layers[0].layout.get("circle-elevation-reference"),this.hasElevation=!1,"none"!==this.elevationMode&&(this.elevatedLayoutVertexArray=new tl),this.worldview=e.worldview,this.hasAppearances=null}updateFootprints(e,t){}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){const n=this.layers[0],o=[];let s=null;"circle"===n.type&&(s=n.layout.get("circle-sort-key"));for(const{feature:l,id:c,index:h,sourceLayerIndex:u}of e){const e=this.layers[0]._featureFilter.needGeometry,n=lh(l,e);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),n,i))continue;const a=s?s.evaluate(n,{},i):void 0,d={id:c,properties:l.properties,type:l.type,sourceLayerIndex:u,index:h,geometry:e?n.geometry:ah(l,i,r),patterns:{},sortKey:a};o.push(d)}s&&o.sort((e,t)=>e.sortKey-t.sortKey);let a=null;"globe"===r.projection.name&&(this.globeExtVertexArray=new hl,a=r.projection);for(const l of o){const{geometry:r,index:n,sourceLayerIndex:o}=l,s=e[n].feature;this.addFeature(l,r,n,t.availableImages,i,a,t.brightness,t.elevationFeatures),t.featureIndex.insert(s,r,n,o,this.index)}this.hasElevation||(this.elevatedLayoutVertexArray=void 0)}update(e,t,i,r,n,o,s){this.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,this.worldview)}updateExpressions(e){this.programConfigurations.updateExpressions(e)}isEmpty(){return 0===this.layoutVertexArray.length}uploadPending(){return!this.uploaded||this.programConfigurations.needsUpload}upload(e){this.uploaded||(this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,Wl.members),this.indexBuffer=e.createIndexBuffer(this.indexArray),this.globeExtVertexArray&&(this.globeExtVertexBuffer=e.createVertexBuffer(this.globeExtVertexArray,Yl.members)),this.elevatedLayoutVertexArray&&(this.elevatedLayoutVertexBuffer=e.createVertexBuffer(this.elevatedLayoutVertexArray,Xl.members))),this.programConfigurations.upload(e),this.uploaded=!0}destroy(){this.layoutVertexBuffer&&(this.layoutVertexBuffer.destroy(),this.indexBuffer.destroy(),this.programConfigurations.destroy(),this.segments.destroy(),this.globeExtVertexBuffer&&this.globeExtVertexBuffer.destroy(),this.elevatedLayoutVertexBuffer&&this.elevatedLayoutVertexBuffer.destroy())}addFeature(e,t,i,r,n,o,s,a){let l;"none"!==this.elevationMode&&(l=Fh.getElevationFeature(e,a));for(const c of t)for(const t of c){const i=t.x,r=t.y;if(i<0||i>=Yr||r<0||r>=Yr)continue;if(o){const e=o.projectTilePoint(i,r,n),t=o.upVector(n,i,r);this.addGlobeExtVertex(e,t),this.addGlobeExtVertex(e,t),this.addGlobeExtVertex(e,t),this.addGlobeExtVertex(e,t)}const s=this.segments.prepareSegment(4,this.layoutVertexArray,this.indexArray,e.sortKey),a=s.vertexLength;if(this.addCircleVertex(i,r,-1,-1),this.addCircleVertex(i,r,1,-1),this.addCircleVertex(i,r,1,1),this.addCircleVertex(i,r,-1,1),"none"!==this.elevationMode){const e=l?l.pointElevation(new Ie(i,r)):0;this.hasElevation=this.hasElevation||0!==e;for(let t=0;t<4;t++)this.elevatedLayoutVertexArray.emplaceBack(e)}this.indexArray.emplaceBack(a,a+1,a+2),this.indexArray.emplaceBack(a,a+2,a+3),s.vertexLength+=4,s.primitiveLength+=2}this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length,e,i,{},r,n,s,void 0,this.worldview)}addCircleVertex(e,t,i,r){this.layoutVertexArray.emplaceBack(2*e+(i+1)/2,2*t+(r+1)/2)}addGlobeExtVertex(e,t){const i=16384;this.globeExtVertexArray.emplaceBack(e.x,e.y,e.z,t[0]*i,t[1]*i,t[2]*i)}}function Nh(e,t){for(let i=0;i<e.length;i++)if(Yh(t,e[i]))return!0;for(let i=0;i<t.length;i++)if(Yh(e,t[i]))return!0;return!!Gh(e,t)}function Uh(e,t,i){return!!Yh(e,t)||!!Zh(t,e,i)}function Vh(e,t){if(1===e.length)return Xh(t,e[0]);for(let i=0;i<t.length;i++){const r=t[i];for(let t=0;t<r.length;t++)if(Yh(e,r[t]))return!0}for(let i=0;i<e.length;i++)if(Xh(t,e[i]))return!0;for(let i=0;i<t.length;i++)if(Gh(e,t[i]))return!0;return!1}function jh(e,t,i){if(e.length>1){if(Gh(e,t))return!0;for(let r=0;r<t.length;r++)if(Zh(t[r],e,i))return!0}for(let r=0;r<e.length;r++)if(Zh(e[r],t,i))return!0;return!1}function Gh(e,t){if(0===e.length||0===t.length)return!1;for(let i=0;i<e.length-1;i++){const r=e[i],n=e[i+1];for(let e=0;e<t.length-1;e++)if(Hh(r,n,t[e],t[e+1]))return!0}return!1}function Hh(e,t,i,r){return Qe(e,i,r)!==Qe(t,i,r)&&Qe(e,t,i)!==Qe(e,t,r)}function $h(e,t,i){return(e.x-i.x)*(t.y-i.y)-(e.y-i.y)*(t.x-i.x)}function qh(e,t,i,r){const n=$h(e,t,r),o=$h(e,t,i);if(Math.sign(n)===Math.sign(o))return;const s=$h(i,r,e),a=s+o-n;return Math.sign(s)!==Math.sign(a)?[s/(s-a),o/(o-n)]:void 0}function Zh(e,t,i){const r=i*i;if(1===t.length)return e.distSqr(t[0])<r;for(let n=1;n<t.length;n++)if(Wh(e,t[n-1],t[n])<r)return!0;return!1}function Wh(e,t,i){const r=t.distSqr(i);if(0===r)return e.distSqr(t);const n=((e.x-t.x)*(i.x-t.x)+(e.y-t.y)*(i.y-t.y))/r;return e.distSqr(n<0?t:n>1?i:i.sub(t)._mult(n)._add(t))}function Xh(e,t){let i,r,n,o=!1;for(let s=0;s<e.length;s++){i=e[s];for(let e=0,s=i.length-1;e<i.length;s=e++)r=i[e],n=i[s],r.y>t.y!=n.y>t.y&&t.x<(n.x-r.x)*(t.y-r.y)/(n.y-r.y)+r.x&&(o=!o)}return o}function Yh(e,t){let i=!1;for(let r=0,n=e.length-1;r<e.length;n=r++){const o=e[r],s=e[n];o.y>t.y!=s.y>t.y&&t.x<(s.x-o.x)*(t.y-o.y)/(s.y-o.y)+o.x&&(i=!i)}return i}function Jh(e,t,i,r,n){for(const s of e)if(t<=s.x&&i<=s.y&&r>=s.x&&n>=s.y)return!0;const o=[new Ie(t,i),new Ie(t,n),new Ie(r,n),new Ie(r,i)];if(e.length>2)for(const s of o)if(Yh(e,s))return!0;for(let s=0;s<e.length-1;s++)if(Kh(e[s],e[s+1],o))return!0;return!1}function Kh(e,t,i){const r=i[0],n=i[2];if(e.x<r.x&&t.x<r.x||e.x>n.x&&t.x>n.x||e.y<r.y&&t.y<r.y||e.y>n.y&&t.y>n.y)return!1;const o=Qe(e,t,i[0]);return o!==Qe(e,t,i[1])||o!==Qe(e,t,i[2])||o!==Qe(e,t,i[3])}function Qh(e,t,i,r,n,o){let s=t.y-e.y,a=e.x-t.x;if(o=o||0){const e=s*s+a*a;if(0===e)return!0;const t=Math.sqrt(e);s/=t,a/=t}return!((i.x-e.x)*s+(i.y-e.y)*a-o<0||(r.x-e.x)*s+(r.y-e.y)*a-o<0||(n.x-e.x)*s+(n.y-e.y)*a-o<0)}function eu(e,t,i,r,n,o,s){return!(Qh(e,t,r,n,o,s)||Qh(t,i,r,n,o,s)||Qh(i,e,r,n,o,s)||Qh(r,n,e,t,i,s)||Qh(n,o,e,t,i,s)||Qh(o,r,e,t,i,s))}function tu(e,t,i){const r=t.paint.get(e).value;return"constant"===r.kind?r.value:i.programConfigurations.get(t.id).getMaxValue(e)}function iu(e){return Math.sqrt(e[0]*e[0]+e[1]*e[1])}function ru(e,t,i,r,n){if(!t[0]&&!t[1])return e;const o=Ie.convert(t)._mult(n);"viewport"===i&&o._rotate(-r);const s=[];for(let a=0;a<e.length;a++)s.push(e[a].sub(o));return s}function nu(e,t,i,r){const n=Ie.convert(e)._mult(r);return"viewport"===t&&n._rotate(-i),n}let ou,su;as(kh,"CircleBucket",{omit:["layers"]});class au{constructor(e,t,i){this.z=e,this.x=t,this.y=i,this.key=hu(0,e,e,t,i)}equals(e){return this.z===e.z&&this.x===e.x&&this.y===e.y}isChildOf(e){const t=this.z-e.z;return 0===e.z||e.z<this.z&&e.x===this.x>>t&&e.y===this.y>>t}url(e,t){const i=function(e,t,i){const r=2**i,n=2*Math.PI*6378137,o=n*(e/r-.5),s=n*(.5-(t+1)/r);return`${o},${s},${o+n/r},${s+n/r}`}(this.x,this.y,this.z),r=function(e,t,i){let r,n="";for(let o=e;o>0;o--)r=1<<o-1,n+=(t&r?1:0)+(i&r?2:0);return n}(this.z,this.x,this.y);return e[(this.x+this.y)%e.length].replace("{prefix}",(this.x%16).toString(16)+(this.y%16).toString(16)).replace(/{z}/g,String(this.z)).replace(/{x}/g,String(this.x)).replace(/{y}/g,String("tms"===t?Math.pow(2,this.z)-this.y-1:this.y)).replace("{quadkey}",r).replace("{bbox-epsg-3857}",i)}toString(){return`${this.z}/${this.x}/${this.y}`}}class lu{constructor(e,t){this.wrap=e,this.canonical=t,this.key=hu(e,t.z,t.z,t.x,t.y)}}class cu{constructor(e,t,i,r,n){this.overscaledZ=e,this.wrap=t,this.canonical=new au(i,+r,+n),this.key=0===t&&e===i?this.canonical.key:hu(t,e,i,r,n)}equals(e){return this.overscaledZ===e.overscaledZ&&this.wrap===e.wrap&&this.canonical.equals(e.canonical)}scaledTo(e){const t=this.canonical.z-e;return e>this.canonical.z?new cu(e,this.wrap,this.canonical.z,this.canonical.x,this.canonical.y):new cu(e,this.wrap,e,this.canonical.x>>t,this.canonical.y>>t)}calculateScaledKey(e,t=!0){if(this.overscaledZ===e&&t)return this.key;if(e>this.canonical.z)return hu(this.wrap*+t,e,this.canonical.z,this.canonical.x,this.canonical.y);{const i=this.canonical.z-e;return hu(this.wrap*+t,e,e,this.canonical.x>>i,this.canonical.y>>i)}}isChildOf(e){if(e.wrap!==this.wrap)return!1;const t=this.canonical.z-e.canonical.z;return 0===e.overscaledZ||e.overscaledZ<this.overscaledZ&&e.canonical.z<this.canonical.z&&e.canonical.x===this.canonical.x>>t&&e.canonical.y===this.canonical.y>>t}children(e){if(this.overscaledZ>=e)return[new cu(this.overscaledZ+1,this.wrap,this.canonical.z,this.canonical.x,this.canonical.y)];const t=this.canonical.z+1,i=2*this.canonical.x,r=2*this.canonical.y;return[new cu(t,this.wrap,t,i,r),new cu(t,this.wrap,t,i+1,r),new cu(t,this.wrap,t,i,r+1),new cu(t,this.wrap,t,i+1,r+1)]}isLessThan(e){return this.wrap<e.wrap||!(this.wrap>e.wrap)&&(this.overscaledZ<e.overscaledZ||!(this.overscaledZ>e.overscaledZ)&&(this.canonical.x<e.canonical.x||!(this.canonical.x>e.canonical.x)&&this.canonical.y<e.canonical.y))}wrapped(){return new cu(this.overscaledZ,0,this.canonical.z,this.canonical.x,this.canonical.y)}unwrapTo(e){return new cu(this.overscaledZ,e,this.canonical.z,this.canonical.x,this.canonical.y)}overscaleFactor(){return Math.pow(2,this.overscaledZ-this.canonical.z)}toUnwrapped(){return new lu(this.wrap,this.canonical)}toString(){return`${this.overscaledZ}/${this.canonical.x}/${this.canonical.y}`}}function hu(e,t,i,r,n){const o=1<<Math.min(i,22);let s=o*(n%o)+r%o;return e&&i<22&&(s+=o*o*((e<0?-2*e-1:2*e)%(1<<2*(22-i)))),16*(32*s+i)+(t-i)}const uu=[e=>{let t=e.canonical.x-1,i=e.wrap;return t<0&&(t=(1<<e.canonical.z)-1,i--),new cu(e.overscaledZ,i,e.canonical.z,t,e.canonical.y)},e=>{let t=e.canonical.x+1,i=e.wrap;return t===1<<e.canonical.z&&(t=0,i++),new cu(e.overscaledZ,i,e.canonical.z,t,e.canonical.y)},e=>new cu(e.overscaledZ,e.wrap,e.canonical.z,e.canonical.x,(0===e.canonical.y?1<<e.canonical.z:e.canonical.y)-1),e=>new cu(e.overscaledZ,e.wrap,e.canonical.z,e.canonical.x,e.canonical.y===(1<<e.canonical.z)-1?0:e.canonical.y+1)];as(au,"CanonicalTileID"),as(cu,"OverscaledTileID",{omit:["projMatrix","expandedProjMatrix"]});const{members:du}=Ya([{type:"Float32",name:"a_globe_pos",components:3},{type:"Float32",name:"a_uv",components:2}]),pu=Ya([{name:"a_pos_3",components:3,type:"Int16"}]);var fu=Ya([{name:"a_pos",type:"Int16",components:2}]);function mu(e){return e*Pc/Bc}const _u=[new Rh([zc,zc,zc],[Lc,Lc,Lc]),new Rh([zc,zc,zc],[0,0,Lc]),new Rh([0,zc,zc],[Lc,0,Lc]),new Rh([zc,0,zc],[0,Lc,Lc]),new Rh([0,0,zc],[Lc,Lc,Lc])];function gu(e,t,i,r=!0){const n=L([],e._camera.position,e.worldSize),o=[t,i,1,1];te(o,o,e.pixelMatrixInverse),Q(o,o,1/o[3]);const s=U([],X([],o,n)),a=e.globeMatrix,l=[a[12],a[13],a[14]],c=X([],l,n),h=E(c),u=U([],c),d=e.worldSize/(2*Math.PI),p=V(u,s),f=Math.asin(d/h);if(f<Math.acos(p)){if(!r)return null;const e=[],t=[];L(e,s,h/p),U(t,X(t,e,c)),U(s,C(s,c,L(s,t,Math.tan(f)*h)))}const m=[];new Sh(n,s).closestPointOnSphere(l,d,m);const _=U([],st(a,0)),g=U([],st(a,1)),y=U([],st(a,2)),x=V(_,m),v=V(g,m),b=V(y,m),w=ze(Math.asin(-v/d));let T=ze(Math.atan2(x,b));return T=e.center.lng+function(e,t){const i=(t-e+180)%360-180;return i<-180?i+360:i}(e.center.lng,T),new Qc(jc(T),ke(Gc(w),0,1))}class yu{constructor(e,t,i){this.a=X([],e,i),this.b=X([],t,i),this.center=i;const r=U([],this.a),n=U([],this.b);this.angle=Math.acos(V(r,n))}}function xu(e,t){if(0===e.angle)return null;let i;return i=0===e.a[t]?1/e.angle*.5*Math.PI:1/e.angle*Math.atan(e.b[t]/e.a[t]/Math.sin(e.angle)-1/Math.tan(e.angle)),i<0||i>1?null:function(e,t,i,r){const n=Math.sin(i);return e*(Math.sin((1-r)*i)/n)+t*(Math.sin(r*i)/n)}(e.a[t],e.b[t],e.angle,ke(i,0,1))+e.center[t]}function vu(e){if(e.z<=1)return _u[e.z+2*e.y+e.x];const t=Eu(Iu(e));return Rh.fromPoints(t)}function bu(e,t,i){return L(e,e,1-i),F(e,e,t,i)}function wu(e,t){const i=Fu(t.zoom);if(0===i)return vu(e);const r=Iu(e),n=Eu(r),o=jc(r.getWest())*t.worldSize,s=jc(r.getEast())*t.worldSize,a=Gc(r.getNorth())*t.worldSize,l=Gc(r.getSouth())*t.worldSize,c=[o,a,0],h=[s,a,0],d=[o,l,0],p=[s,l,0],f=u([],t.globeMatrix);return H(c,c,f),H(h,h,f),H(d,d,f),H(p,p,f),n[0]=bu(n[0],d,i),n[1]=bu(n[1],p,i),n[2]=bu(n[2],h,i),n[3]=bu(n[3],c,i),Rh.fromPoints(n)}function Tu(e,t,i){for(const r of e)H(r,r,t),L(r,r,i)}function Su(e,t,i,r){const n=t/e.worldSize,o=e.globeMatrix;if(i.z<=1){const e=vu(i).getCorners();return Tu(e,o,n),Rh.fromPoints(e)}const s=Iu(i,r),a=Eu(s,Pc+mu(e._tileCoverLift));Tu(a,o,n);const l=Number.MAX_VALUE,c=[-l,-l,-l],h=[l,l,l];if(s.contains(e.center)){for(const e of a)R(h,h,e),z(c,c,e);c[2]=0;const t=e.point,i=[t.x*n,t.y*n,0];return R(h,h,i),z(c,c,i),new Rh(h,c)}if(e._tileCoverLift>0){for(const e of a)R(h,h,e),z(c,c,e);return new Rh(h,c)}const u=[o[12]*n,o[13]*n,o[14]*n],d=s.getCenter(),p=ke(e.center.lat,-85.051129,Wc),f=ke(d.lat,-85.051129,Wc),m=jc(e.center.lng),_=Gc(p);let g=m-jc(d.lng);const y=_-Gc(f);g>.5?g-=1:g<-.5&&(g+=1);let x=0;Math.abs(g)>Math.abs(y)?x=g>=0?1:3:(x=y>=0?0:2,F(u,u,[o[4]*n,o[5]*n,o[6]*n],-Math.sin(Re(y>=0?s.getSouth():s.getNorth()))*Pc));const v=a[x],b=a[(x+1)%4],w=new yu(v,b,u),T=[xu(w,0)||v[0],xu(w,1)||v[1],xu(w,2)||v[2]],S=Fu(e.zoom);if(S>0){const r=function({x:e,y:t,z:i},r,n,o,s){const a=1/(1<<i);let l=e*a,c=l+a,h=t*a,u=h+a,d=0;const p=(l+c)/2-o;return p>.5?d=-1:p<-.5&&(d=1),l=((l+d)*r-(o*=r))*n+o,c=((c+d)*r-o)*n+o,h=(h*r-(s*=r))*n+s,u=(u*r-s)*n+s,[[l,u,0],[c,u,0],[c,h,0],[l,h,0]]}(i,t,e._pixelsPerMercatorPixel,m,_);for(let e=0;e<a.length;e++)bu(a[e],r[e],S);const n=C([],r[x],r[(x+1)%4]);L(n,n,.5),bu(T,n,S)}for(const I of a)R(h,h,I),z(c,c,I);return h[2]=Math.min(v[2],b[2]),R(h,h,T),z(c,c,T),new Rh(h,c)}function Iu({x:e,y:t,z:i},r=!1){const n=1/(1<<i);return new Uc(new Nc($c(e*n),t===(1<<i)-1&&r?-90:qc((t+1)*n)),new Nc($c((e+1)*n),0===t&&r?90:qc(t*n)))}function Eu(e,t=Pc){const i=Re(e.getNorth()),r=Re(e.getSouth()),n=Math.cos(i),o=Math.cos(r),s=Math.sin(i),a=Math.sin(r),l=e.getWest(),c=e.getEast();return[Fc(o,a,l,t),Fc(o,a,c,t),Fc(n,s,c,t),Fc(n,s,l,t)]}function Au(e,t,i,r){const n=1<<i.z,o=(e/Yr+i.x)/n;return Oc(qc((t/Yr+i.y)/n),$c(o),r)}function Mu({min:e,max:t}){return 16383/Math.max(t[0]-e[0],t[1]-e[1],t[2]-e[2])}const Cu=new Float64Array(16);function Pu(e){const t=Mu(e),i=x(Cu,[t,t,t]);return p(i,i,N([],e.min))}function Du(e){const t=1/Mu(e);return y(Cu,e.min),f(Cu,Cu,[t,t,t])}function Ru(e){const t=Yr/(2*Math.PI);return e/(2*Math.PI)/t}function zu(e,t){return Yr/(512*Math.pow(2,e))*Mu(vu(t))}function Lu(e,t,i,r,n){const o=Ru(i),s=[e,t,-i/(2*Math.PI)],a=h(new Float64Array(16));return p(a,a,s),f(a,a,[o,o,o]),m(a,a,Re(-n)),_(a,a,Re(-r)),a}function Fu(e){return Ne(5,6,e)}function Ou(e,t){const i=Oc(t.lat,t.lng);return o=(r=P([],function(e){const t=Oc(e._center.lat,e._center.lng);let i=j([],A(0,1,0),t);const r=v([],-e.angle,t);i=H(i,i,r),v(r,-e._pitch,i);const n=U([],t);return L(n,n,mu(e.cameraToCenterDistance/e.pixelsPerMeter)),H(n,n,r),C([],t,n)}(e),i))[0],s=r[1],a=r[2],l=(n=i)[0],c=n[1],h=n[2],d=(u=Math.sqrt((o*o+s*s+a*a)*(l*l+c*c+h*h)))&&V(r,n)/u,Math.acos(Math.min(Math.max(d,-1),1));var r,n,o,s,a,l,c,h,u,d}function Bu(e,t){return Ou(e,t)>Math.PI/2*1.01}const ku=Re(85),Nu=Math.cos(ku),Uu=Math.sin(ku),Vu=l(),ju=e=>{const t=[];return"map"===e.paint.get("circle-pitch-alignment")&&t.push("PITCH_WITH_MAP"),"map"===e.paint.get("circle-pitch-scale")&&t.push("SCALE_WITH_MAP"),t};function Gu(e,t,i,r,n,o,s,a,l){if(o&&e.queryGeometry.isAboveHorizon)return!1;o&&(l*=e.pixelToTileUnitsFactor);const c=e.tileID.canonical,h=i.projection.upVectorScale(c,i.center.lat,i.worldSize).metersToTile;for(const u of t)for(const t of u){const u=t.add(a),d=n&&i.elevation?i.elevation.exaggeration()*n.getElevationAt(u.x,u.y,!0):0,p=i.projection.projectTilePoint(u.x,u.y,c);if(d>0){const e=i.projection.upVector(c,u.x,u.y);p.x+=e[0]*h*d,p.y+=e[1]*h*d,p.z+=e[2]*h*d}const f=o?u:Hu(p.x,p.y,p.z,r),m=o?e.tilespaceRays.map(e=>Zu(e,d)):e.queryGeometry.screenGeometry,_=te([],[p.x,p.y,p.z,1],r);if(!s&&o?l*=_[3]/i.cameraToCenterDistance:s&&!o&&(l*=i.cameraToCenterDistance/_[3]),o){const e=qc((t.y/Yr+c.y)/(1<<c.z));l/=i.projection.pixelsPerMeter(e,1)/Hc(1,e)}if(Uh(m,f,l))return!0}return!1}function Hu(e,t,i,r){const n=te([],[e,t,i,1],r);return new Ie(n[0]/n[3],n[1]/n[3])}const $u=A(0,0,0),qu=A(0,0,1);function Zu(e,t){const i=S();return $u[2]=t,e.intersectsPlane($u,qu,i),new Ie(i[0],i[1])}class Wu extends kh{}let Xu,Yu,Ju,Ku;function Qu(e,{width:t,height:i},r,n){if(n){if(n instanceof Uint8ClampedArray)n=new Uint8Array(n.buffer);else if(n.length!==t*i*r)throw new RangeError("mismatched image size")}else n=new Uint8Array(t*i*r);return e.width=t,e.height=i,e.data=n,e}function ed(e,t,i){const{width:r,height:n}=t;r===e.width&&n===e.height||(td(e,t,{x:0,y:0},{x:0,y:0},{width:Math.min(e.width,r),height:Math.min(e.height,n)},i,null),e.width=r,e.height=n,e.data=t.data)}function td(e,t,i,r,n,o,s,a){if(0===n.width||0===n.height)return t;if(n.width>e.width||n.height>e.height||i.x>e.width-n.width||i.y>e.height-n.height)throw new RangeError("out of range source coordinates for image copy");if(n.width>t.width||n.height>t.height||r.x>t.width-n.width||r.y>t.height-n.height)throw new RangeError("out of range destination coordinates for image copy");const l=e.data,c=t.data,h=4===o&&a;for(let u=0;u<n.height;u++){const a=((i.y+u)*e.width+i.x)*o,d=((r.y+u)*t.width+r.x)*o;if(h)for(let e=0;e<n.width;e++){const t=a+e*o+3,i=d+e*o;c[i+0]=255,c[i+1]=255,c[i+2]=255,c[i+3]=l[t]}else if(s)for(let e=0;e<n.width;e++){const t=a+e*o,i=d+e*o,r=new xi(l[t+0]/255,l[t+1]/255,l[t+2]/255,l[t+3]).toNonPremultipliedRenderColor(s).toArray();c[i+0]=r[0],c[i+1]=r[1],c[i+2]=r[2],c[i+3]=r[3]}else for(let e=0;e<n.width*o;e++)c[d+e]=l[a+e]}return t}as(Wu,"HeatmapBucket",{omit:["layers"]});class id{constructor(e,t){Qu(this,e,1,t)}resize(e){ed(this,new id(e),1)}clone(){return new id({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(e,t,i,r,n){td(e,t,i,r,n,1,null)}}class rd{constructor(e,t){Qu(this,e,4,t)}resize(e){ed(this,new rd(e),4)}replace(e,t){t?this.data.set(e):this.data=e instanceof Uint8ClampedArray?new Uint8Array(e.buffer):e}clone(){return new rd({width:this.width,height:this.height},new Uint8Array(this.data))}static copy(e,t,i,r,n,o,s){td(e,t,i,r,n,4,o,s)}}class nd{constructor(e,t){this.width=e.width,this.height=e.height,this.data=t instanceof Uint8Array?new Float32Array(t.buffer):t}}function od(e){const t={},i=e.resolution||256,r=e.clips?e.clips.length:1,n=e.image||new rd({width:i,height:r}),o=(i,r,o)=>{t[e.evaluationKey]=o;const s=e.expression.evaluate(t),a=s?s.toNonPremultipliedRenderColor(null):null;a&&(n.data[i+r+0]=Math.floor(255*a.r),n.data[i+r+1]=Math.floor(255*a.g),n.data[i+r+2]=Math.floor(255*a.b),n.data[i+r+3]=Math.floor(255*a.a))};if(e.clips)for(let s=0,a=0;s<r;++s,a+=4*i)for(let t=0,r=0;t<i;t++,r+=4){const n=t/(i-1),{start:l,end:c}=e.clips[s];o(a,r,l*(1-n)+c*n)}else for(let s=0,a=0;s<i;s++,a+=4)o(0,a,s/(i-1));return n}as(id,"AlphaImage"),as(rd,"RGBAImage");const sd=Ya([{name:"a_pos",components:2,type:"Int16"}],4),ad=Ya([{name:"a_road_z_offset",components:1,type:"Float32"}],4),ld=Ya([{name:"a_pos",components:2,type:"Int16"},{name:"a_height",components:1,type:"Float32"}],4),cd=Ya([{name:"a_pos_normal_3",components:3,type:"Int16"}],4);function hd(e,t,i=2){const r=t&&t.length,n=r?t[0]*i:e.length;let o=ud(e,0,n,i,!0);const s=[];if(!o||o.next===o.prev)return s;let a,l,c;if(r&&(o=function(e,t,i,r){const n=[];for(let o=0,s=t.length;o<s;o++){const i=ud(e,t[o]*r,o<s-1?t[o+1]*r:e.length,r,!1);i===i.next&&(i.steiner=!0),n.push(wd(i))}n.sort(yd);for(let o=0;o<n.length;o++)i=xd(n[o],i);return i}(e,t,o,i)),e.length>80*i){a=e[0],l=e[1];let t=a,r=l;for(let o=i;o<n;o+=i){const i=e[o],n=e[o+1];i<a&&(a=i),n<l&&(l=n),i>t&&(t=i),n>r&&(r=n)}c=Math.max(t-a,r-l),c=0!==c?32767/c:0}return pd(o,s,i,a,l,c,0),s}function ud(e,t,i,r,n){let o;if(n===function(e,t,i,r){let n=0;for(let o=t,s=i-r;o<i;o+=r)n+=(e[s]-e[o])*(e[o+1]+e[s+1]),s=o;return n}(e,t,i,r)>0)for(let s=t;s<i;s+=r)o=zd(s/r|0,e[s],e[s+1],o);else for(let s=i-r;s>=t;s-=r)o=zd(s/r|0,e[s],e[s+1],o);return o&&Ad(o,o.next)&&(Ld(o),o=o.next),o}function dd(e,t){if(!e)return e;t||(t=e);let i,r=e;do{if(i=!1,r.steiner||!Ad(r,r.next)&&0!==Ed(r.prev,r,r.next))r=r.next;else{if(Ld(r),r=t=r.prev,r===r.next)break;i=!0}}while(i||r!==t);return t}function pd(e,t,i,r,n,o,s){if(!e)return;!s&&o&&function(e,t,i,r){let n=e;do{0===n.z&&(n.z=bd(n.x,n.y,t,i,r)),n.prevZ=n.prev,n.nextZ=n.next,n=n.next}while(n!==e);n.prevZ.nextZ=null,n.prevZ=null,function(e){let t,i=1;do{let r,n=e;e=null;let o=null;for(t=0;n;){t++;let s=n,a=0;for(let e=0;e<i&&(a++,s=s.nextZ,s);e++);let l=i;for(;a>0||l>0&&s;)0!==a&&(0===l||!s||n.z<=s.z)?(r=n,n=n.nextZ,a--):(r=s,s=s.nextZ,l--),o?o.nextZ=r:e=r,r.prevZ=o,o=r;n=s}o.nextZ=null,i*=2}while(t>1)}(n)}(e,r,n,o);let a=e;for(;e.prev!==e.next;){const l=e.prev,c=e.next;if(o?md(e,r,n,o):fd(e))t.push(l.i,e.i,c.i),Ld(e),e=c.next,a=c.next;else if((e=c)===a){s?1===s?pd(e=_d(dd(e),t),t,i,r,n,o,2):2===s&&gd(e,t,i,r,n,o):pd(dd(e),t,i,r,n,o,1);break}}}function fd(e){const t=e.prev,i=e,r=e.next;if(Ed(t,i,r)>=0)return!1;const n=t.x,o=i.x,s=r.x,a=t.y,l=i.y,c=r.y,h=Math.min(n,o,s),u=Math.min(a,l,c),d=Math.max(n,o,s),p=Math.max(a,l,c);let f=r.next;for(;f!==t;){if(f.x>=h&&f.x<=d&&f.y>=u&&f.y<=p&&Sd(n,a,o,l,s,c,f.x,f.y)&&Ed(f.prev,f,f.next)>=0)return!1;f=f.next}return!0}function md(e,t,i,r){const n=e.prev,o=e,s=e.next;if(Ed(n,o,s)>=0)return!1;const a=n.x,l=o.x,c=s.x,h=n.y,u=o.y,d=s.y,p=Math.min(a,l,c),f=Math.min(h,u,d),m=Math.max(a,l,c),_=Math.max(h,u,d),g=bd(p,f,t,i,r),y=bd(m,_,t,i,r);let x=e.prevZ,v=e.nextZ;for(;x&&x.z>=g&&v&&v.z<=y;){if(x.x>=p&&x.x<=m&&x.y>=f&&x.y<=_&&x!==n&&x!==s&&Sd(a,h,l,u,c,d,x.x,x.y)&&Ed(x.prev,x,x.next)>=0)return!1;if(x=x.prevZ,v.x>=p&&v.x<=m&&v.y>=f&&v.y<=_&&v!==n&&v!==s&&Sd(a,h,l,u,c,d,v.x,v.y)&&Ed(v.prev,v,v.next)>=0)return!1;v=v.nextZ}for(;x&&x.z>=g;){if(x.x>=p&&x.x<=m&&x.y>=f&&x.y<=_&&x!==n&&x!==s&&Sd(a,h,l,u,c,d,x.x,x.y)&&Ed(x.prev,x,x.next)>=0)return!1;x=x.prevZ}for(;v&&v.z<=y;){if(v.x>=p&&v.x<=m&&v.y>=f&&v.y<=_&&v!==n&&v!==s&&Sd(a,h,l,u,c,d,v.x,v.y)&&Ed(v.prev,v,v.next)>=0)return!1;v=v.nextZ}return!0}function _d(e,t){let i=e;do{const r=i.prev,n=i.next.next;!Ad(r,n)&&Md(r,i,i.next,n)&&Dd(r,n)&&Dd(n,r)&&(t.push(r.i,i.i,n.i),Ld(i),Ld(i.next),i=e=n),i=i.next}while(i!==e);return dd(i)}function gd(e,t,i,r,n,o){let s=e;do{let e=s.next.next;for(;e!==s.prev;){if(s.i!==e.i&&Id(s,e)){let a=Rd(s,e);return s=dd(s,s.next),a=dd(a,a.next),pd(s,t,i,r,n,o,0),void pd(a,t,i,r,n,o,0)}e=e.next}s=s.next}while(s!==e)}function yd(e,t){let i=e.x-t.x;return 0===i&&(i=e.y-t.y,0===i)&&(i=(e.next.y-e.y)/(e.next.x-e.x)-(t.next.y-t.y)/(t.next.x-t.x)),i}function xd(e,t){const i=function(e,t){let i=t;const r=e.x,n=e.y;let o,s=-1/0;if(Ad(e,i))return i;do{if(Ad(e,i.next))return i.next;if(n<=i.y&&n>=i.next.y&&i.next.y!==i.y){const e=i.x+(n-i.y)*(i.next.x-i.x)/(i.next.y-i.y);if(e<=r&&e>s&&(s=e,o=i.x<i.next.x?i:i.next,e===r))return o}i=i.next}while(i!==t);if(!o)return null;const a=o,l=o.x,c=o.y;let h=1/0;i=o;do{if(r>=i.x&&i.x>=l&&r!==i.x&&Td(n<c?r:s,n,l,c,n<c?s:r,n,i.x,i.y)){const t=Math.abs(n-i.y)/(r-i.x);Dd(i,e)&&(t<h||t===h&&(i.x>o.x||i.x===o.x&&vd(o,i)))&&(o=i,h=t)}i=i.next}while(i!==a);return o}(e,t);if(!i)return t;const r=Rd(i,e);return dd(r,r.next),dd(i,i.next)}function vd(e,t){return Ed(e.prev,e,t.prev)<0&&Ed(t.next,e,e.next)<0}function bd(e,t,i,r,n){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=(e-i)*n|0)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=(t-r)*n|0)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function wd(e){let t=e,i=e;do{(t.x<i.x||t.x===i.x&&t.y<i.y)&&(i=t),t=t.next}while(t!==e);return i}function Td(e,t,i,r,n,o,s,a){return(n-s)*(t-a)>=(e-s)*(o-a)&&(e-s)*(r-a)>=(i-s)*(t-a)&&(i-s)*(o-a)>=(n-s)*(r-a)}function Sd(e,t,i,r,n,o,s,a){return!(e===s&&t===a)&&Td(e,t,i,r,n,o,s,a)}function Id(e,t){return e.next.i!==t.i&&e.prev.i!==t.i&&!function(e,t){let i=e;do{if(i.i!==e.i&&i.next.i!==e.i&&i.i!==t.i&&i.next.i!==t.i&&Md(i,i.next,e,t))return!0;i=i.next}while(i!==e);return!1}(e,t)&&(Dd(e,t)&&Dd(t,e)&&function(e,t){let i=e,r=!1;const n=(e.x+t.x)/2,o=(e.y+t.y)/2;do{i.y>o!=i.next.y>o&&i.next.y!==i.y&&n<(i.next.x-i.x)*(o-i.y)/(i.next.y-i.y)+i.x&&(r=!r),i=i.next}while(i!==e);return r}(e,t)&&(Ed(e.prev,e,t.prev)||Ed(e,t.prev,t))||Ad(e,t)&&Ed(e.prev,e,e.next)>0&&Ed(t.prev,t,t.next)>0)}function Ed(e,t,i){return(t.y-e.y)*(i.x-t.x)-(t.x-e.x)*(i.y-t.y)}function Ad(e,t){return e.x===t.x&&e.y===t.y}function Md(e,t,i,r){const n=Pd(Ed(e,t,i)),o=Pd(Ed(e,t,r)),s=Pd(Ed(i,r,e)),a=Pd(Ed(i,r,t));return n!==o&&s!==a||!(0!==n||!Cd(e,i,t))||!(0!==o||!Cd(e,r,t))||!(0!==s||!Cd(i,e,r))||!(0!==a||!Cd(i,t,r))}function Cd(e,t,i){return t.x<=Math.max(e.x,i.x)&&t.x>=Math.min(e.x,i.x)&&t.y<=Math.max(e.y,i.y)&&t.y>=Math.min(e.y,i.y)}function Pd(e){return e>0?1:e<0?-1:0}function Dd(e,t){return Ed(e.prev,e,e.next)<0?Ed(e,t,e.next)>=0&&Ed(e,e.prev,t)>=0:Ed(e,t,e.prev)<0||Ed(e,e.next,t)<0}function Rd(e,t){const i=Fd(e.i,e.x,e.y),r=Fd(t.i,t.x,t.y),n=e.next,o=t.prev;return e.next=t,t.prev=e,i.next=n,n.prev=i,r.next=i,i.prev=r,o.next=r,r.prev=o,r}function zd(e,t,i,r){const n=Fd(e,t,i);return r?(n.next=r.next,n.prev=r,r.next.prev=n,r.next=n):(n.prev=n,n.next=n),n}function Ld(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function Fd(e,t,i){return{i:e,x:t,y:i,prev:null,next:null,z:0,prevZ:null,nextZ:null,steiner:!1}}function Od(e,t){const i=e.length;if(i<=1)return[e];const r=[];let n,o;for(let s=0;s<i;s++){const t=et(e[s]);0!==t&&(e[s].area=Math.abs(t),void 0===o&&(o=t<0),o===t<0?(n&&r.push(n),n=[e[s]]):n.push(e[s]))}if(n&&r.push(n),t>1)for(let s=0;s<r.length;s++)r[s].length<=t||(gr(r[s],t,1,r[s].length-1,Bd),r[s]=r[s].slice(0,t));return r}function Bd(e,t){return t.area-e.area}function kd(e,t,i=1){if(!e)return null;const r="string"==typeof e?Wi.from(e).getPrimary():e.getPrimary(),n="string"==typeof e?null:e.getSecondary();for(const o of[r,n]){if(!o)continue;const e=o.id.toString();t.has(e)||t.set(e,[]),o.scaleSelf(i),t.get(e).push(o)}return{primary:r.toString(),secondary:n?n.toString():null}}function Nd(e,t,i,r){const n=r.patternDependencies;let o=!1;for(const s of t){const t=s.paint.get(`${e}-pattern`);t.isConstant()||(o=!0),kd(t.constantOr(null),n,i)&&(o=!0)}return o}function Ud(e,t,i,r,n,o){const s=o.patternDependencies;for(const a of t){const t=a.paint.get(`${e}-pattern`).value;if("constant"!==t.kind){const e=kd(t.evaluate({zoom:r},i,{},void 0,o.availableImages),s,n);if(!e)continue;const{primary:l,secondary:c}=e;l&&(i.patterns[a.id]=[l,c].filter(Boolean))}}return i}class Vd{constructor(){this.portals=[]}static isOnBorder(e,t){return e<=0&&t<=0||e>=Yr&&t>=Yr}static evaluate(e){if(0===e.length)return new Vd;let t=[];for(const a of e)t.push(...a.portals);if(0===t.length)return new Vd;for(const a of t){const e=a.va,t=a.vb;(Vd.isOnBorder(e.x,t.x)||Vd.isOnBorder(e.y,t.y))&&(a.type="border")}const i=t.filter(e=>"unevaluated"!==e.type),r=t.filter(e=>"unevaluated"===e.type);if(0===r.length)return new Vd;r.sort((e,t)=>e.hash===t.hash?e.isTunnel===t.isTunnel?0:e.isTunnel?-1:1:e.hash<t.hash?1:-1),t=i.concat(r);let n=i.length,o=n,s=n;do{if(o++,o===t.length||t[n].hash!==t[o].hash){if(o-n===2){s<n&&(t[s]=t[n],t[n]=null);const e=t[s],i=t[o-1];e.type=e.isTunnel!==i.isTunnel?"tunnel":"polygon",e.connection={a:e.connection.a,b:i.connection.a},s++}n=o}}while(n!==t.length);return t.splice(s),t.sort((e,t)=>e.hash<t.hash?1:-1),{portals:t}}}as(Vd,"ElevationPortalGraph");class jd{constructor(e,t,i){this.outPositions=e,this.outNormals=t,this.outIndices=i,this.vertexLookup=/* @__PURE__ */new Map}addVertex(e,t,i){let r=e[2];null!=i&&(r*=i);const n=`${e[0]},${e[1]},${e[2]},${t[0]},${t[1]},${t[2]}`,o=this.vertexLookup.get(n);if(null!=o)return o;const s=this.outPositions.length;this.vertexLookup.set(n,s);const a=Math.trunc(16384*t[0]),l=Math.trunc(16384*t[1]),c=Math.trunc(16384*t[2]);return this.outPositions.emplaceBack(e[0],e[1],r),this.outNormals.emplaceBack(a,l,c),s}addTriangle(e,t,i){this.outIndices.emplaceBack(e,t,i)}addTriangles(e,t,i){if(0===e.length)return;const r=1===i.length,n=S(),o=S();for(let s=0;s<e.length;s+=3){const a=t[e[s+0]],l=t[e[s+1]],c=t[e[s+2]],h=r?i[0]:i[e[s+1]],u=r?i[0]:i[e[s+2]];M(n,a.x,a.y,r?i[0]:i[e[s+0]]);const d=this.addVertex(n,o);M(n,l.x,l.y,h);const p=this.addVertex(n,o);M(n,c.x,c.y,u);const f=this.addVertex(n,o);this.outIndices.emplaceBack(d,p,f)}}addQuad(e,t,i,r,n,o){const s=this.addVertex(e,n,o),a=this.addVertex(t,n,o),l=this.addVertex(i,n,o),c=this.addVertex(r,n,o);this.addTriangle(s,a,l),this.addTriangle(l,c,s)}getVertexCount(){return this.outPositions.length}clearVertexLookup(){this.vertexLookup.clear()}}class Gd{constructor(e,t,i,r){this.unevaluatedPortals=new Vd,this.bridgeFeatureSections=[],this.tunnelFeatureSections=[],this.vertexHashLookup=/* @__PURE__ */new Map,this.unevalVertices=[],this.unevalHeights=[],this.unevalTriangles=[],this.unevalTunnelTriangles=[],this.unevalEdges=[],this.vertexPositions=new il,this.vertexNormals=new rl,this.indexArray=new vl,this.tileToMeters=Kc(e),this.bridgeProgramConfigurations=new Sc(t,{zoom:i,lut:r},e=>"fill-tunnel-structure-color"!==e),this.tunnelProgramConfigurations=new Sc(t,{zoom:i,lut:r},e=>"fill-bridge-guard-rail-color"!==e)}addVertices(e,t){const i=this.unevalVertices.length;for(let r=0;r<e.length;r++)this.unevalVertices.push(e[r]),this.unevalHeights.push(t[r]);return i}addTriangles(e,t,i){const r=i?this.unevalTunnelTriangles:this.unevalTriangles;for(const n of e)r.push(n+t)}addRenderableRing(e,t,i,r,n,o){const s=[new Ie(n.min.x,n.min.y),new Ie(n.max.x,n.min.y),new Ie(n.max.x,n.max.y),new Ie(n.min.x,n.max.y)];for(let a=0;a<i-1;a++){const i=t+a,l=i+1,c=this.unevalVertices[i],h=this.unevalVertices[l];if(!(c.x>=n.min.x&&c.x<=n.max.x&&c.y>=n.min.y&&c.y<=n.max.y||h.x>=n.min.x&&h.x<=n.max.x&&h.y>=n.min.y&&h.y<=n.max.y||Kh(c,h,s)))continue;if(this.isOnBorder(c.x,h.x)||this.isOnBorder(c.y,h.y))continue;const u=Gd.computeEdgeHash(this.unevalVertices[i],this.unevalVertices[l]);let d,p=this.vertexHashLookup.get(Gd.computePosHash(c));null!=p?d=p.next:(p=this.vertexHashLookup.get(Gd.computePosHash(h)),d=null!=p?p.prev:u),this.unevalEdges.push({polygonIdx:e,a:i,b:l,hash:u,portalHash:d,isTunnel:r,type:"unevaluated",featureInfo:o})}}addPortalCandidates(e,t,i,r,n){if(0!==t.length){this.vertexHashLookup.clear();for(const n of t){if(0===n.length)continue;const t=n[0];let o=Gd.computeEdgeHash(t[t.length-2],t.at(-1));for(let n=0;n<t.length-1;n++){const s=t[n+0],a=t[n+1],l=de(a.x-s.x,a.y-s.y),c=ge(l);if(0===c)continue;let h="unevaluated";const u=r.pointElevation(s),d=r.pointElevation(a);Math.abs(u)<.01&&Math.abs(d)<.01?h="entrance":(this.isOnBorder(s.x,a.x)||this.isOnBorder(s.y,a.y))&&(h="border");const p=Gd.computeEdgeHash(s,a);this.unevaluatedPortals.portals.push({connection:{a:e,b:void 0},va:s,vb:a,vab:l,length:c,hash:p,isTunnel:i,type:h});const f=Gd.computePosHash(s);this.vertexHashLookup.set(f,{prev:o,next:p}),o=p}}}}construct(e){if(0===this.unevalVertices.length)return;const t=()=>({vertexOffset:0,primitiveOffset:this.indexArray.length}),i=e=>{e.primitiveLength=this.indexArray.length-e.primitiveOffset},r=new jd(this.vertexPositions,this.vertexNormals,this.indexArray);this.prepareEdges(e.portals,this.unevalEdges);const n=t(),o=t(),s=t(),a=(e,t)=>{e.sort((e,i)=>e.type===t&&i.type!==t?-1:e.type!==t&&i.type===t?1:0);const i=e.findIndex(e=>e.type!==t);return i>=0?i:e.length};let l=0;this.unevalEdges.length>0&&(l=a(this.unevalEdges,"none"),this.constructBridgeStructures(r,this.unevalVertices,this.unevalHeights,this.unevalEdges,{min:0,max:l},this.tileToMeters)),i(s);const c=t(),h=t();if(this.unevalEdges.length>0){const e=this.unevalEdges.splice(l),t=a(e,"tunnel")+l;this.unevalEdges.push(...e),this.constructTunnelStructures(r,this.unevalVertices,this.unevalHeights,this.unevalEdges,{min:0,max:l},{min:l,max:t})}i(c),r.addTriangles(this.unevalTriangles,this.unevalVertices,this.unevalHeights),i(h),r.addTriangles(this.unevalTunnelTriangles,this.unevalVertices,this.unevalHeights),i(o),r.addTriangles(this.unevalTunnelTriangles,this.unevalVertices,[-.1]),i(n),this.maskSegments=Jl.simpleSegment(0,h.primitiveOffset,0,h.primitiveLength),this.depthSegments=Jl.simpleSegment(0,o.primitiveOffset,0,o.primitiveLength),this.renderableBridgeSegments=Jl.simpleSegment(0,s.primitiveOffset,0,s.primitiveLength),this.renderableTunnelSegments=Jl.simpleSegment(0,c.primitiveOffset,0,c.primitiveLength),this.shadowCasterSegments=Jl.simpleSegment(0,n.primitiveOffset,0,n.primitiveLength)}update(e,t,i,r,n,o,s,a){this.bridgeProgramConfigurations.updatePaintArrays(e,t,n,i,r,o,s,a),this.tunnelProgramConfigurations.updatePaintArrays(e,t,n,i,r,o,s,a)}upload(e){this.vertexBuffer||0===this.vertexPositions.length||0===this.vertexNormals.length||0===this.indexArray.length||(this.vertexBuffer=e.createVertexBuffer(this.vertexPositions,ld.members),this.vertexBufferNormal=e.createVertexBuffer(this.vertexNormals,cd.members),this.indexBuffer=e.createIndexBuffer(this.indexArray),this.bridgeProgramConfigurations.upload(e),this.tunnelProgramConfigurations.upload(e))}destroy(){this.vertexBuffer&&(this.vertexBuffer.destroy(),this.vertexBufferNormal.destroy(),this.indexBuffer.destroy()),this.maskSegments&&(this.maskSegments.destroy(),this.depthSegments.destroy(),this.renderableBridgeSegments.destroy(),this.renderableTunnelSegments.destroy(),this.shadowCasterSegments.destroy()),this.bridgeProgramConfigurations.destroy(),this.tunnelProgramConfigurations.destroy()}populatePaintArrays(e,t,i,r,n){const o=(o,s)=>{for(let a=0;a<s.length-1;a++){const l=s[a].featureIndex,c=s[a+1].vertexStart,h=e.feature(l);o.populatePaintArrays(c,h,l,{},i,t,r,void 0,n)}};o(this.bridgeProgramConfigurations,this.bridgeFeatureSections),o(this.tunnelProgramConfigurations,this.tunnelFeatureSections)}computeVertexConnections(e,t,i,r,n){const o=/* @__PURE__ */new Map;for(let s=r;s<n;s++){const r=i[s],n=r.a,a=r.b,l=Gd.computePosHash(e[n]),c=Gd.computePosHash(e[a]);let h=o.get(l);h||(h={},o.set(l,h));let u=o.get(c);u||(u={},o.set(c,u)),t[n]<=0&&t[a]<=0||(h.to=a,u.from=n)}return o}isTerminalVertex(e,t){const i=Gd.computePosHash(this.unevalVertices[e]),r=t.get(i);return!r||!r.from||!r.to}constructBridgeStructures(e,t,i,r,n,o){e.clearVertexLookup();const s=this.computeVertexConnections(t,i,r,n.min,n.max),a=1/o,l=.5*a,c=(e,r)=>M(e,t[r].x,t[r].y,i[r]*a),h=S(),u=S(),d=S(),p=S(),f=S(),m=(e,i)=>{const r=s.get(Gd.computePosHash(t[i])),n=r.from,o=r.to;if(!n||!o)return;c(h,n),c(u,i),c(d,o),Z(p),W(h,u)||(X(f,u,h),U(p,f)),W(d,u)||(X(f,d,u),C(p,p,U(f,f)));const a=J(p);return a>0?L(e,p,1/a):void 0};let _=Number.POSITIVE_INFINITY;this.sortSubarray(r,n.min,n.max,(e,t)=>e.featureInfo.featureIndex-t.featureInfo.featureIndex);const g=S(),y=S(),x=S(),v=S(),b=S(),w=S(),T=S(),I=S(),E=S(),A=[S(),S(),S(),S()],P=[S(),S(),S(),S()],D=[{coord:new Ie(0,0),height:0},{coord:new Ie(0,0),height:0}],R=(e,t)=>e>t;for(let S=n.min;S<n.max;S++){const n=r[S];if(!n.featureInfo.guardRailEnabled)continue;if(!this.prepareEdgePoints(D,t,i,n,R))continue;const[c,h]=D;if(M(g,c.coord.x,c.coord.y,a*c.height),M(y,h.coord.x,h.coord.y,a*h.height),W(g,y))continue;X(x,y,g),U(x,x);const u=m(I,n.a)||x,d=m(E,n.b)||x;M(v,u[1],-u[0],0),U(v,v),M(b,d[1],-d[0],0),U(b,b),j(I,v,u),U(w,I),j(I,b,d),U(T,I),C(A[0],g,L(I,X(I,v,w),l)),C(A[1],g,L(I,C(I,v,w),l)),C(A[2],g,L(I,w,l)),A[3]=g,C(P[0],y,L(I,X(I,b,T),l)),C(P[1],y,L(I,C(I,b,T),l)),C(P[2],y,L(I,T,l)),P[3]=y,_=this.addFeatureSection(n.featureInfo.featureIndex,_,this.bridgeFeatureSections,e);const p=e.addVertex(A[0],v,o),f=e.addVertex(A[1],v,o),z=e.addVertex(P[0],b,o),F=e.addVertex(P[1],b,o);e.addTriangle(p,f,z),e.addTriangle(f,F,z);const O=e.addVertex(A[1],w,o),B=e.addVertex(A[2],w,o),k=e.addVertex(P[1],T,o),V=e.addVertex(P[2],T,o);e.addTriangle(O,B,k),e.addTriangle(B,V,k),N(v,v),N(b,b);const G=e.addVertex(A[2],v,o),H=e.addVertex(A[3],v,o),$=e.addVertex(P[2],b,o),q=e.addVertex(P[3],b,o);e.addTriangle(G,H,$),e.addTriangle(H,q,$);const Z=this.isTerminalVertex(n.a,s),Y=this.isTerminalVertex(n.b,s);c.height<.01&&Z&&e.addQuad(A[3],A[2],A[1],A[0],N(u,u),o),h.height<.01&&Y&&e.addQuad(P[0],P[1],P[2],P[3],d,o)}this.bridgeFeatureSections.push({featureIndex:Number.POSITIVE_INFINITY,vertexStart:e.getVertexCount()})}constructTunnelStructures(e,t,i,r,n,o){e.clearVertexLookup();let s=Number.POSITIVE_INFINITY;const a=(e,t)=>e.featureInfo.featureIndex-t.featureInfo.featureIndex;this.sortSubarray(r,n.min,n.max,a),this.sortSubarray(r,o.min,o.max,a);const l=e=>U(e,e),c=[{coord:new Ie(0,0),height:0},{coord:new Ie(0,0),height:0}],h=(e,t)=>e<t,u=S(),d=S(),p=S(),f=S(),m=S();for(let _=n.min;_<n.max;_++){if(!this.prepareEdgePoints(c,t,i,r[_],h))continue;const[n,o]=c,a=l(M(m,-(o.coord.y-n.coord.y),o.coord.x-n.coord.x,0));s=this.addFeatureSection(r[_].featureInfo.featureIndex,s,this.tunnelFeatureSections,e),e.addQuad(M(u,n.coord.x,n.coord.y,n.height),M(d,o.coord.x,o.coord.y,o.height),M(p,o.coord.x,o.coord.y,r[_].isTunnel?-.1:0),M(f,n.coord.x,n.coord.y,r[_].isTunnel?-.1:0),a)}for(let _=o.min;_<o.max;_++){const n=r[_];n.isTunnel&&([n.a,n.b]=[n.b,n.a]);const o=t[n.a],a=t[n.b],c=l(M(m,-(a.y-o.y),a.x-o.x,0));s=this.addFeatureSection(n.featureInfo.featureIndex,s,this.tunnelFeatureSections,e),e.addQuad(M(u,a.x,a.y,0),M(d,o.x,o.y,0),M(p,o.x,o.y,i[n.a]+4),M(f,a.x,a.y,i[n.b]+4),c),e.addQuad(M(u,o.x,o.y,0),M(d,a.x,a.y,0),M(p,a.x,a.y,i[n.b]+4),M(f,o.x,o.y,i[n.a]+4),c)}this.tunnelFeatureSections.push({featureIndex:Number.POSITIVE_INFINITY,vertexStart:e.getVertexCount()})}setElevatedPoint(e,t,i,r){e.coord.x=t,e.coord.y=i,e.height=r}prepareEdgePoints(e,t,i,r,n){let o=t[r.a].x,s=t[r.a].y,a=t[r.b].x,l=t[r.b].y,c=i[r.a],h=i[r.b];const u=n(c,0),d=n(h,0);if(u&&d)return this.setElevatedPoint(e[0],o,s,c),this.setElevatedPoint(e[1],a,l,h),!0;if(!u&&!d)return!1;if(u){if(!d){const e=h/(h-c);a=yi(a,o,e),l=yi(l,s,e),h=yi(h,c,e)}}else{const e=c/(c-h);o=yi(o,a,e),s=yi(s,l,e),c=yi(c,h,e)}return this.setElevatedPoint(e[0],o,s,c),this.setElevatedPoint(e[1],a,l,h),!0}prepareEdges(e,t){if(0===t.length)return;t.sort((e,t)=>e.hash===t.hash?t.polygonIdx-e.polygonIdx:t.hash>e.hash?1:-1);let i=0,r=0,n=0,o=t[i].polygonIdx;do{r++,(r===t.length||t[i].hash!==t[r].hash)&&((1===r-i||t[r-1].polygonIdx!==o)&&(n<i&&(t[n]=t[i],t[i]=null),t[n].type="none",n++),i=r,i!==t.length&&(o=t[i].polygonIdx))}while(i!==t.length);if(t.splice(n),0!==t.length&&0!==e.length){t.sort((e,t)=>e.portalHash<t.portalHash?1:-1);let i=0,r=0;for(;i!==t.length&&r!==e.length;){const n=t[i],o=e[r];n.portalHash>o.hash?i++:o.hash>n.portalHash?r++:(n.type=o.type,i++)}}}isOnBorder(e,t){return e<=0&&t<=0||e>=Yr&&t>=Yr}addFeatureSection(e,t,i,r){return e!==t&&(t=e,i.push({featureIndex:e,vertexStart:r.getVertexCount()}),r.clearVertexLookup()),t}sortSubarray(e,t,i,r){const n=e.slice(t,i);n.sort(r),e.splice(t,n.length,...n)}static computeEdgeHash(e,t){return(e.y===t.y&&e.x>t.x||e.y>t.y)&&([e,t]=[t,e]),BigInt(Gd.computePosHash(e))<<32n|BigInt(Gd.computePosHash(t))}static computePosHash(e){return((65535&e.x)<<16|65535&e.y)>>>0}}function Hd(e,t){return e>t?1:e<t?-1:0}class $d{constructor(e=Hd,t=!1){this._compare=e,this._root=null,this._size=0,this._noDuplicates=!!t}rotateLeft(e){var t=e.right;t&&(e.right=t.left,t.left&&(t.left.parent=e),t.parent=e.parent),e.parent?e===e.parent.left?e.parent.left=t:e.parent.right=t:this._root=t,t&&(t.left=e),e.parent=t}rotateRight(e){var t=e.left;t&&(e.left=t.right,t.right&&(t.right.parent=e),t.parent=e.parent),e.parent?e===e.parent.left?e.parent.left=t:e.parent.right=t:this._root=t,t&&(t.right=e),e.parent=t}_splay(e){for(;e.parent;){var t=e.parent;t.parent?t.left===e&&t.parent.left===t?(this.rotateRight(t.parent),this.rotateRight(t)):t.right===e&&t.parent.right===t?(this.rotateLeft(t.parent),this.rotateLeft(t)):t.left===e&&t.parent.right===t?(this.rotateRight(t),this.rotateLeft(t)):(this.rotateLeft(t),this.rotateRight(t)):t.left===e?this.rotateRight(t):this.rotateLeft(t)}}splay(e){for(var t,i,r,n,o;e.parent;)(i=(t=e.parent).parent)&&i.parent?((r=i.parent).left===i?r.left=e:r.right=e,e.parent=r):(e.parent=null,this._root=e),n=e.left,o=e.right,e===t.left?(i&&(i.left===t?(t.right?(i.left=t.right,i.left.parent=i):i.left=null,t.right=i,i.parent=t):(n?(i.right=n,n.parent=i):i.right=null,e.left=i,i.parent=e)),o?(t.left=o,o.parent=t):t.left=null,e.right=t,t.parent=e):(i&&(i.right===t?(t.left?(i.right=t.left,i.right.parent=i):i.right=null,t.left=i,i.parent=t):(o?(i.left=o,o.parent=i):i.left=null,e.right=i,i.parent=e)),n?(t.right=n,n.parent=t):t.right=null,e.left=t,t.parent=e)}replace(e,t){e.parent?e===e.parent.left?e.parent.left=t:e.parent.right=t:this._root=t,t&&(t.parent=e.parent)}minNode(e=this._root){if(e)for(;e.left;)e=e.left;return e}maxNode(e=this._root){if(e)for(;e.right;)e=e.right;return e}insert(e,t){var i=this._root,r=null,n=this._compare;if(this._noDuplicates)for(;i;){if(r=i,0===n(i.key,e))return;i=n(i.key,e)<0?i.right:i.left}else for(;i;)r=i,i=n(i.key,e)<0?i.right:i.left;return i={key:e,data:t,left:null,right:null,parent:r},r?n(r.key,i.key)<0?r.right=i:r.left=i:this._root=i,this.splay(i),this._size++,i}find(e){for(var t=this._root,i=this._compare;t;){var r=i(t.key,e);if(r<0)t=t.right;else{if(!(r>0))return t;t=t.left}}return null}contains(e){for(var t=this._root,i=this._compare;t;){var r=i(e,t.key);if(0===r)return!0;t=r<0?t.left:t.right}return!1}remove(e){var t=this.find(e);if(!t)return!1;if(this.splay(t),t.left)if(t.right){var i=this.minNode(t.right);i.parent!==t&&(this.replace(i,i.right),i.right=t.right,i.right.parent=i),this.replace(t,i),i.left=t.left,i.left.parent=i}else this.replace(t,t.left);else this.replace(t,t.right);return this._size--,!0}removeNode(e){if(!e)return!1;if(this.splay(e),e.left)if(e.right){var t=this.minNode(e.right);t.parent!==e&&(this.replace(t,t.right),t.right=e.right,t.right.parent=t),this.replace(e,t),t.left=e.left,t.left.parent=t}else this.replace(e,e.left);else this.replace(e,e.right);return this._size--,!0}erase(e){var t=this.find(e);if(t){this.splay(t);var i=t.left,r=t.right,n=null;i&&(i.parent=null,n=this.maxNode(i),this.splay(n),this._root=n),r&&(i?n.right=r:this._root=r,r.parent=n),this._size--}}pop(){var e=this._root,t=null;if(e){for(;e.left;)e=e.left;t={key:e.key,data:e.data},this.remove(e.key)}return t}next(e){var t=e;if(t)if(t.right)for(t=t.right;t&&t.left;)t=t.left;else for(t=e.parent;t&&t.right===e;)e=t,t=t.parent;return t}prev(e){var t=e;if(t)if(t.left)for(t=t.left;t&&t.right;)t=t.right;else for(t=e.parent;t&&t.left===e;)e=t,t=t.parent;return t}forEach(e){for(var t=this._root,i=[],r=!1,n=0;!r;)t?(i.push(t),t=t.left):i.length>0?(e(t=i.pop(),n++),t=t.right):r=!0;return this}range(e,t,i,r){const n=[],o=this._compare;let s,a=this._root;for(;0!==n.length||a;)if(a)n.push(a),a=a.left;else{if(a=n.pop(),s=o(a.key,t),s>0)break;if(o(a.key,e)>=0&&i.call(r,a))return this;a=a.right}return this}keys(){for(var e=this._root,t=[],i=[],r=!1;!r;)e?(t.push(e),e=e.left):t.length>0?(e=t.pop(),i.push(e.key),e=e.right):r=!0;return i}values(){for(var e=this._root,t=[],i=[],r=!1;!r;)e?(t.push(e),e=e.left):t.length>0?(e=t.pop(),i.push(e.data),e=e.right):r=!0;return i}at(e){for(var t=this._root,i=[],r=!1,n=0;!r;)if(t)i.push(t),t=t.left;else if(i.length>0){if(t=i.pop(),n===e)return t;n++,t=t.right}else r=!0;return null}load(e=[],t=[],i=!1){if(0!==this._size)throw new Error("bulk-load: tree is not empty");const r=e.length;return i&&Zd(e,t,0,r-1,this._compare),this._root=qd(null,e,t,0,r),this._size=r,this}min(){var e=this.minNode(this._root);return e?e.key:null}max(){var e=this.maxNode(this._root);return e?e.key:null}isEmpty(){return null===this._root}get size(){return this._size}static createTree(e,t,i,r,n){return new $d(i,n).load(e,t,r)}}function qd(e,t,i,r,n){const o=n-r;if(o>0){const s=r+Math.floor(o/2),a={key:t[s],data:i[s],parent:e};return a.left=qd(a,t,i,r,s),a.right=qd(a,t,i,s+1,n),a}return null}function Zd(e,t,i,r,n){if(i>=r)return;const o=e[i+r>>1];let s=i-1,a=r+1;for(;;){do{s++}while(n(e[s],o)<0);do{a--}while(n(e[a],o)>0);if(s>=a)break;let i=e[s];e[s]=e[a],e[a]=i,i=t[s],t[s]=t[a],t[a]=i}Zd(e,t,i,a,n),Zd(e,t,a+1,r,n)}const Wd=134217729;function Xd(e,t,i,r,n){let o,s,a,l,c=t[0],h=r[0],u=0,d=0;h>c==h>-c?(o=c,c=t[++u]):(o=h,h=r[++d]);let p=0;if(u<e&&d<i)for(h>c==h>-c?(s=c+o,a=o-(s-c),c=t[++u]):(s=h+o,a=o-(s-h),h=r[++d]),o=s,0!==a&&(n[p++]=a);u<e&&d<i;)h>c==h>-c?(s=o+c,l=s-o,a=o-(s-l)+(c-l),c=t[++u]):(s=o+h,l=s-o,a=o-(s-l)+(h-l),h=r[++d]),o=s,0!==a&&(n[p++]=a);for(;u<e;)s=o+c,l=s-o,a=o-(s-l)+(c-l),c=t[++u],o=s,0!==a&&(n[p++]=a);for(;d<i;)s=o+h,l=s-o,a=o-(s-l)+(h-l),h=r[++d],o=s,0!==a&&(n[p++]=a);return 0===o&&0!==p||(n[p++]=o),p}function Yd(e){return new Float64Array(e)}const Jd=Yd(4),Kd=Yd(8),Qd=Yd(12),ep=Yd(16),tp=Yd(4);function ip(e,t,i){null===t?(e.inOut=!1,e.otherInOut=!0):(e.isSubject===t.isSubject?(e.inOut=!t.inOut,e.otherInOut=t.otherInOut):(e.inOut=!t.otherInOut,e.otherInOut=t.isVertical()?!t.inOut:t.inOut),t&&(e.prevInResult=!rp(t,i)||t.isVertical()?t.prevInResult:t)),e.resultTransition=rp(e,i)?function(e,t){let i,r=!e.inOut,n=!e.otherInOut;switch(t){case 0:i=r&&n;break;case 1:i=r||n;break;case 3:i=r!==n;break;case 2:i=e.isSubject?r&&!n:n&&!r}return i?1:-1}(e,i):0}function rp(e,t){switch(e.type){case 0:switch(t){case 0:return!e.otherInOut;case 1:return e.otherInOut;case 2:return e.isSubject&&e.otherInOut||!e.isSubject&&!e.otherInOut;case 3:return!0}break;case 2:return 0===t||1===t;case 3:return 2===t;case 1:return!1}return!1}class np{constructor(e,t,i,r,n){this.left=t,this.point=e,this.otherEvent=i,this.isSubject=r??!1,this.type=n||0,this.inOut=!1,this.otherInOut=!1,this.prevInResult=null,this.resultTransition=0,this.otherPos=-1,this.outputContourId=-1,this.isExteriorRing=!0}isBelow(e){const t=this.point,i=this.otherEvent.point;return this.left?(t[0]-e[0])*(i[1]-e[1])-(i[0]-e[0])*(t[1]-e[1])>0:(i[0]-e[0])*(t[1]-e[1])-(t[0]-e[0])*(i[1]-e[1])>0}isAbove(e){return!this.isBelow(e)}isVertical(){return this.point[0]===this.otherEvent.point[0]}get inResult(){return 0!==this.resultTransition}clone(){const e=new np(this.point,this.left,this.otherEvent,this.isSubject,this.type);return e.contourId=this.contourId,e.resultTransition=this.resultTransition,e.prevInResult=this.prevInResult,e.isExteriorRing=this.isExteriorRing,e.inOut=this.inOut,e.otherInOut=this.otherInOut,e}}function op(e,t){return e[0]===t[0]&&e[1]===t[1]}function sp(e,t,i){const r=function(e,t,i,r,n,o){const s=(t-o)*(i-n),a=(e-n)*(r-o),l=s-a;if(0===s||0===a||s>0!=a>0)return l;const c=Math.abs(s+a);return Math.abs(l)>=33306690738754716e-32*c?l:-function(e,t,i,r,n,o,s){let a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S;const I=e-n,E=i-n,A=t-o,M=r-o;v=I*M,d=Wd*I,p=d-(d-I),f=I-p,d=Wd*M,m=d-(d-M),_=M-m,b=f*_-(v-p*m-f*m-p*_),w=A*E,d=Wd*A,p=d-(d-A),f=A-p,d=Wd*E,m=d-(d-E),_=E-m,T=f*_-(w-p*m-f*m-p*_),g=b-T,u=b-g,Jd[0]=b-(g+u)+(u-T),y=v+g,u=y-v,x=v-(y-u)+(g-u),g=x-w,u=x-g,Jd[1]=x-(g+u)+(u-w),S=y+g,u=S-y,Jd[2]=y-(S-u)+(g-u),Jd[3]=S;let C=function(e,t){let i=t[0];for(let r=1;r<4;r++)i+=t[r];return i}(0,Jd),P=22204460492503146e-32*s;if(C>=P||-C>=P)return C;if(u=e-I,a=e-(I+u)+(u-n),u=i-E,c=i-(E+u)+(u-n),u=t-A,l=t-(A+u)+(u-o),u=r-M,h=r-(M+u)+(u-o),0===a&&0===l&&0===c&&0===h)return C;if(P=11093356479670487e-47*s+33306690738754706e-32*Math.abs(C),C+=I*h+M*a-(A*c+E*l),C>=P||-C>=P)return C;v=a*M,d=Wd*a,p=d-(d-a),f=a-p,d=Wd*M,m=d-(d-M),_=M-m,b=f*_-(v-p*m-f*m-p*_),w=l*E,d=Wd*l,p=d-(d-l),f=l-p,d=Wd*E,m=d-(d-E),_=E-m,T=f*_-(w-p*m-f*m-p*_),g=b-T,u=b-g,tp[0]=b-(g+u)+(u-T),y=v+g,u=y-v,x=v-(y-u)+(g-u),g=x-w,u=x-g,tp[1]=x-(g+u)+(u-w),S=y+g,u=S-y,tp[2]=y-(S-u)+(g-u),tp[3]=S;const D=Xd(4,Jd,4,tp,Kd);v=I*h,d=Wd*I,p=d-(d-I),f=I-p,d=Wd*h,m=d-(d-h),_=h-m,b=f*_-(v-p*m-f*m-p*_),w=A*c,d=Wd*A,p=d-(d-A),f=A-p,d=Wd*c,m=d-(d-c),_=c-m,T=f*_-(w-p*m-f*m-p*_),g=b-T,u=b-g,tp[0]=b-(g+u)+(u-T),y=v+g,u=y-v,x=v-(y-u)+(g-u),g=x-w,u=x-g,tp[1]=x-(g+u)+(u-w),S=y+g,u=S-y,tp[2]=y-(S-u)+(g-u),tp[3]=S;const R=Xd(D,Kd,4,tp,Qd);return v=a*h,d=Wd*a,p=d-(d-a),f=a-p,d=Wd*h,m=d-(d-h),_=h-m,b=f*_-(v-p*m-f*m-p*_),w=l*c,d=Wd*l,p=d-(d-l),f=l-p,d=Wd*c,m=d-(d-c),_=c-m,T=f*_-(w-p*m-f*m-p*_),g=b-T,u=b-g,tp[0]=b-(g+u)+(u-T),y=v+g,u=y-v,x=v-(y-u)+(g-u),g=x-w,u=x-g,tp[1]=x-(g+u)+(u-w),S=y+g,u=S-y,tp[2]=y-(S-u)+(g-u),tp[3]=S,ep[Xd(R,Qd,4,tp,ep)-1]}(e,t,i,r,n,o,c)}(e[0],e[1],t[0],t[1],i[0],i[1]);return r>0?-1:r<0?1:0}function ap(e,t){const i=e.point,r=t.point;return i[0]>r[0]?1:i[0]<r[0]?-1:i[1]!==r[1]?i[1]>r[1]?1:-1:function(e,t,i){return e.left!==t.left?e.left?1:-1:0!==sp(i,e.otherEvent.point,t.otherEvent.point)?e.isBelow(t.otherEvent.point)?-1:1:!e.isSubject&&t.isSubject?1:-1}(e,t,i)}function lp(e,t,i){const r=new np(t,!1,e,e.isSubject),n=new np(t,!0,e.otherEvent,e.isSubject);return op(e.point,e.otherEvent.point)&&console.warn("what is that, a collapsed segment?",e),r.contourId=n.contourId=e.contourId,ap(n,e.otherEvent)>0&&(e.otherEvent.left=!0,n.left=!1),e.otherEvent.otherEvent=n,e.otherEvent=r,i.push(n),i.push(r),i}function cp(e,t){return e[0]*t[1]-e[1]*t[0]}function hp(e,t){return e[0]*t[0]+e[1]*t[1]}function up(e,t,i){const r=function(e,t,i,r){const n=[t[0]-e[0],t[1]-e[1]],o=[r[0]-i[0],r[1]-i[1]];function s(e,t,i){return[e[0]+t*i[0],e[1]+t*i[1]]}const a=[i[0]-e[0],i[1]-e[1]];let l=cp(n,o),c=l*l;const h=hp(n,n);if(c>0){const t=cp(a,o)/l;if(t<0||t>1)return null;const r=cp(a,n)/l;return r<0||r>1?null:0===t||1===t?[s(e,t,n)]:0===r||1===r?[s(i,r,o)]:[s(e,t,n)]}if(l=cp(a,n),c=l*l,c>0)return null;const u=hp(n,a)/h,d=u+hp(n,o)/h,p=Math.min(u,d),f=Math.max(u,d);return p<=1&&f>=0?1===p?[s(e,p>0?p:0,n)]:0===f?[s(e,f<1?f:1,n)]:[s(e,p>0?p:0,n),s(e,f<1?f:1,n)]:null}(e.point,e.otherEvent.point,t.point,t.otherEvent.point),n=r?r.length:0;if(0===n||1===n&&(op(e.point,t.point)||op(e.otherEvent.point,t.otherEvent.point))||2===n&&e.isSubject===t.isSubject)return 0;if(1===n)return!op(e.point,r[0])&&!op(e.otherEvent.point,r[0])&&lp(e,r[0],i),!op(t.point,r[0])&&!op(t.otherEvent.point,r[0])&&lp(t,r[0],i),1;const o=[];let s=!1,a=!1;return op(e.point,t.point)?s=!0:1===ap(e,t)?o.push(t,e):o.push(e,t),op(e.otherEvent.point,t.otherEvent.point)?a=!0:1===ap(e.otherEvent,t.otherEvent)?o.push(t.otherEvent,e.otherEvent):o.push(e.otherEvent,t.otherEvent),s&&a||s?(t.type=1,e.type=t.inOut===e.inOut?2:3,s&&!a&&lp(o[1].otherEvent,o[0].point,i),2):a?(lp(o[0],o[1].point,i),3):o[0]!==o[3].otherEvent?(lp(o[0],o[1].point,i),lp(o[1],o[2].point,i),3):(lp(o[0],o[1].point,i),lp(o[3].otherEvent,o[2].point,i),3)}function dp(e,t){if(e===t)return 0;if(0!==sp(e.point,e.otherEvent.point,t.point)||0!==sp(e.point,e.otherEvent.point,t.otherEvent.point))return op(e.point,t.point)?e.isBelow(t.otherEvent.point)?-1:1:e.point[0]===t.point[0]?e.point[1]<t.point[1]?-1:1:1===ap(e,t)?t.isAbove(e.point)?-1:1:e.isBelow(t.point)?-1:1;if(e.isSubject!==t.isSubject)return e.isSubject?-1:1;{let i=e.point,r=t.point;if(i[0]===r[0]&&i[1]===r[1])return i=e.otherEvent.point,r=t.otherEvent.point,i[0]===r[0]&&i[1]===r[1]?0:(e.contourId??0)>(t.contourId??0)?1:-1}return 1===ap(e,t)?1:-1}class pp{constructor(){this.points=[],this.holeIds=[],this.holeOf=null,this.depth=null}isExterior(){return null==this.holeOf}}function fp(e,t,i,r){let n,o=e+1,s=t[e].point;const a=t.length;for(o<a&&(n=t[o].point);o<a&&n[0]===s[0]&&n[1]===s[1];){if(!i[o])return o;o++,o<a&&(n=t[o].point)}for(o=e-1;i[o]&&o>r;)o--;return o}function mp(e,t,i){const r=new pp;if(null!=e.prevInResult){const n=e.prevInResult,o=n.outputContourId;if(n.resultTransition>0){const e=t[o];if(null!=e.holeOf){const n=e.holeOf;t[n].holeIds.push(i),r.holeOf=n,r.depth=t[o].depth}else t[o].holeIds.push(i),r.holeOf=o,r.depth=t[o].depth+1}else r.holeOf=null,r.depth=t[o].depth}else r.holeOf=null,r.depth=0;return r}const _p=Math.max,gp=Math.min;let yp=0;function xp(e,t,i,r,n,o){let s,a,l,c,h,u;for(s=0,a=e.length-1;s<a;s++){if(l=e[s],c=e[s+1],h=new np(l,!1,void 0,t),u=new np(c,!1,h,t),h.otherEvent=u,l[0]===c[0]&&l[1]===c[1])continue;h.contourId=u.contourId=i,o||(h.isExteriorRing=!1,u.isExteriorRing=!1),ap(h,u)>0?u.left=!0:h.left=!0;const a=l[0],d=l[1];n[0]=gp(n[0],a),n[1]=gp(n[1],d),n[2]=_p(n[2],a),n[3]=_p(n[3],d),r.push(h),r.push(u)}}const vp=[];function bp(e,t,i){let r=e,n=t;"number"==typeof e[0][0][0]&&(r=[e]),"number"==typeof t[0][0][0]&&(n=[t]);let o=function(e,t,i){let r=null;return e.length*t.length===0&&(0===i?r=vp:2===i?r=e:(1===i||3===i)&&(r=0===e.length?t:e)),r}(r,n,i);if(o)return o===vp?null:o;const s=[1/0,1/0,-1/0,-1/0],a=[1/0,1/0,-1/0,-1/0],l=function(e,t,i,r,n){const o=new Xr(void 0,ap);let s,a,l,c,h,u;for(l=0,c=e.length;l<c;l++)for(s=e[l],h=0,u=s.length;h<u;h++)a=0===h,a&&yp++,xp(s[h],!0,yp,o,i,a);for(l=0,c=t.length;l<c;l++)for(s=t[l],h=0,u=s.length;h<u;h++)a=0===h,2===n&&(a=!1),a&&yp++,xp(s[h],!1,yp,o,r,a);return o}(r,n,s,a,i);if(o=function(e,t,i,r,n){let o=null;return(i[0]>r[2]||r[0]>i[2]||i[1]>r[3]||r[1]>i[3])&&(0===n?o=vp:2===n?o=e:(1===n||3===n)&&(o=e.concat(t))),o}(r,n,s,a,i),o)return o===vp?null:o;const c=function(e){let t,i;const r=function(e){let t,i,r,n,o;const s=[];for(i=0,r=e.length;i<r;i++)t=e[i],(t.left&&t.inResult||!t.left&&t.otherEvent.inResult)&&s.push(t);let a=!1;for(;!a;)for(a=!0,i=0,r=s.length;i<r;i++)i+1<r&&1===ap(s[i],s[i+1])&&(n=s[i],s[i]=s[i+1],s[i+1]=n,a=!1);for(i=0,r=s.length;i<r;i++)t=s[i],t.otherPos=i;for(i=0,r=s.length;i<r;i++)t=s[i],t.left||(o=t.otherPos,t.otherPos=t.otherEvent.otherPos,t.otherEvent.otherPos=o);return s}(e),n={},o=[];for(t=0,i=r.length;t<i;t++){if(n[t])continue;const e=o.length,i=mp(r[t],o,e),s=t=>{n[t]=!0,t<r.length&&r[t]&&(r[t].outputContourId=e)};let a=t,l=t;for(i.points.push(r[t].point);s(a),a=r[a].otherPos,s(a),i.points.push(r[a].point),a=fp(a,r,n,l),!(a==l||a>=r.length)&&r[a];);o.push(i)}return o}(function(e,t,i,r,n,o){const s=new $d(dp),a=[],l=Math.min(r[2],n[2]);let c,h,u;for(;0!==e.length;){let t=e.pop();if(a.push(t),0===o&&t.point[0]>l||2===o&&t.point[0]>r[2])break;if(t.left){h=c=s.insert(t),u=s.minNode(),c=c!==u?s.prev(c):null,h=s.next(h);const i=c?c.key:null;let r;if(ip(t,i,o),h&&2===up(t,h.key,e)&&(ip(t,i,o),ip(h.key,t,o)),c&&2===up(c.key,t,e)){let e=c;e=e!==u?s.prev(e):null,r=e?e.key:null,ip(i,r,o),ip(t,i,o)}}else t=t.otherEvent,h=c=s.find(t),c&&h&&(c=c!==u?s.prev(c):null,h=s.next(h),s.remove(t),h&&c&&up(c.key,h.key,e))}return a}(l,0,0,s,a,i)),h=[];for(let u=0;u<c.length;u++){let e=c[u];if(e.isExterior()){let t=[e.points];for(let i=0;i<e.holeIds.length;i++)t.push(c[e.holeIds[i]].points);h.push(t)}}return h}function wp(e,t,i,r){const n=[],o=0===r?(e,t,i,r,n,o)=>{e.push(new Ie(o,i+(o-t)/(r-t)*(n-i)))}:(e,t,i,r,n,o)=>{e.push(new Ie(t+(o-i)/(n-i)*(r-t),o))};for(const s of e){const e=[];for(const n of s){if(n.length<=2)continue;const s=[];for(let e=0;e<n.length-1;e++){const a=n[e].x,l=n[e].y,c=n[e+1].x,h=n[e+1].y,u=0===r?a:l,d=0===r?c:h;u<t?d>t&&o(s,a,l,c,h,t):u>i?d<i&&o(s,a,l,c,h,i):s.push(n[e]),d<t&&u>=t&&o(s,a,l,c,h,t),d>i&&u<=i&&o(s,a,l,c,h,i)}let a=n.at(-1);const l=0===r?a.x:a.y;l>=t&&l<=i&&s.push(a),s.length&&(a=s.at(-1),s[0].x===a.x&&s[0].y===a.y||s.push(s[0]),e.push(s))}e.length&&n.push(e)}return n}function Tp(e,t){const i=bp(Ip(e),Ip([t]),0);return null==i?[]:Ep(i)}function Sp(e,t,i=0){const r=65536;let n=Ip(e,r);const o=[];for(;t.valid();t.next()){const[e,n]=t.get();let s=e.x*r,a=e.y*r,l=n.x*r,c=n.y*r;const h=l-s,u=c-a,d=Math.hypot(h,u);if(0===d)continue;s-=h*i,a-=u*i,l+=h*i,c+=u*i;const p=Math.trunc(u/d*3),f=-Math.trunc(h/d*3);o.push([[[s,a],[l,c],[l+p,c+f],[s+p,a+f],[s,a]]])}return o.length>0&&(n=bp(n,o,2)),Ep(n,1/r,128)}function Ip(e,t=1){return[e.map(e=>e.map(e=>[e.x*t,e.y*t]))]}function Ep(e,t=1,i){return e.map(e=>e.map((e,r)=>{const n=e.map(e=>{let r=e[0],n=e[1];return i&&(r=Math.round(r/i)*i,n=Math.round(n/i)*i),new Ie(r*t,n*t)._round()});return r>0&&n.reverse(),n}))}class Ap{constructor(e,t){this.layoutVertexArray=new Ka,this.indexArray=new vl,this.lineIndexArray=new ml,this.triangleSegments=new Jl,this.lineSegments=new Jl,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut}),this.uploaded=!1,t&&(this.elevatedLayoutVertexArray=new tl)}update(e,t,i,r,n,o,s,a){this.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,a)}isEmpty(){return 0===this.layoutVertexArray.length}needsUpload(){return this.programConfigurations.needsUpload}upload(e){this.uploaded||(this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,sd.members),this.indexBuffer=e.createIndexBuffer(this.indexArray),this.lineIndexBuffer=e.createIndexBuffer(this.lineIndexArray),this.elevatedLayoutVertexArray&&this.elevatedLayoutVertexArray.length>0&&(this.elevatedLayoutVertexBuffer=e.createVertexBuffer(this.elevatedLayoutVertexArray,ad.members))),this.programConfigurations.upload(e),this.uploaded=!0}destroy(){this.layoutVertexBuffer&&(this.elevatedLayoutVertexBuffer&&this.elevatedLayoutVertexBuffer.destroy(),this.layoutVertexBuffer.destroy(),this.indexBuffer.destroy(),this.lineIndexBuffer.destroy(),this.programConfigurations.destroy(),this.triangleSegments.destroy(),this.lineSegments.destroy())}populatePaintArrays(e,t,i,r,n,o,s){this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length,e,t,i,r,n,o,void 0,s)}}class Mp{constructor(e){this.zoom=e.zoom,this.pixelRatio=e.pixelRatio,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.hasPattern=!1,this.patternFeatures=[],this.lut=e.lut,this.bufferData=new Ap(e,!1),this.elevationBufferData=new Ap(e,!0),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.projection=e.projection,this.elevationMode=this.layers[0].layout.get("fill-elevation-reference"),this.sourceLayerIndex=e.sourceLayerIndex,this.worldview=e.worldview,this.hasAppearances=null}updateFootprints(e,t){}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){this.hasPattern=Nd("fill",this.layers,this.pixelRatio,t);const n=this.layers[0].layout.get("fill-sort-key"),o=[];for(const{feature:s,id:a,index:l,sourceLayerIndex:c}of e){const e=this.layers[0]._featureFilter.needGeometry,h=lh(s,e);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),h,i))continue;const u=n?n.evaluate(h,{},i,t.availableImages):void 0,d={id:a,properties:s.properties,type:s.type,sourceLayerIndex:c,index:l,geometry:e?h.geometry:ah(s,i,r),patterns:{},sortKey:u};o.push(d)}n&&o.sort((e,t)=>e.sortKey-t.sortKey);for(const s of o){const{geometry:r,index:n,sourceLayerIndex:o}=s;if(this.hasPattern){const e=Ud("fill",this.layers,s,this.zoom,this.pixelRatio,t);this.patternFeatures.push(e)}else this.addFeature(s,r,n,i,{},t.availableImages,t.brightness,t.elevationFeatures);t.featureIndex.insert(e[n].feature,r,n,o,this.index)}}update(e,t,i,r,n,o,s){this.bufferData.update(e,t,i,r,n,o,s,this.worldview),this.elevationBufferData.update(e,t,i,r,n,o,s,this.worldview),this.elevatedStructures&&this.elevatedStructures.update(e,t,i,r,n,o,s,this.worldview)}updateExpressions(e){this.bufferData.programConfigurations.updateExpressions(e),this.elevationBufferData.programConfigurations.updateExpressions(e),this.elevatedStructures&&(this.elevatedStructures.bridgeProgramConfigurations.updateExpressions(e),this.elevatedStructures.tunnelProgramConfigurations.updateExpressions(e))}addFeatures(e,t,i,r,n,o){for(const s of this.patternFeatures)this.addFeature(s,s.geometry,s.index,t,i,r,o,e.elevationFeatures)}isEmpty(){return this.bufferData.isEmpty()&&this.elevationBufferData.isEmpty()}uploadPending(){return!this.uploaded||this.bufferData.needsUpload()||this.elevationBufferData.needsUpload()}upload(e){this.bufferData.upload(e),this.elevationBufferData.upload(e),this.elevatedStructures&&this.elevatedStructures.upload(e)}destroy(){this.bufferData.destroy(),this.elevationBufferData.destroy(),this.elevatedStructures&&this.elevatedStructures.destroy()}addFeature(e,t,i,r,n,o=[],s,a){const l=Od(t,500);"none"!==this.elevationMode?this.addElevatedRoadFeature(e,l,r,i,a):this.addGeometry(l,this.bufferData),this.bufferData.populatePaintArrays(e,i,n,o,r,s,this.worldview),this.elevationBufferData.populatePaintArrays(e,i,n,o,r,s,this.worldview)}getUnevaluatedPortalGraph(){return this.elevatedStructures?this.elevatedStructures.unevaluatedPortals:void 0}setEvaluatedPortalGraph(e,t,i,r,n){this.elevatedStructures&&(this.elevatedStructures.construct(e),this.elevatedStructures.populatePaintArrays(t,i,r,n,this.worldview))}addElevatedRoadFeature(e,t,i,r,n){const o=new Array,s=Fh.getElevationFeature(e,n);if(!s)return void this.addGeometry(t,this.bufferData);{const e=this.clipPolygonsToTile(t,1);e.length>0&&o.push({polygons:e,elevationFeature:s,elevationTileID:i})}const a={guardRailEnabled:this.layers[0].layout.get("fill-construct-bridge-guard-rail").evaluate(e,{},i),featureIndex:r};for(const l of o)if(l.elevationFeature){if("hd-road-base"===this.elevationMode){this.elevatedStructures||(this.elevatedStructures=new Gd(l.elevationTileID,this.layers,this.zoom,this.lut));const t=l.elevationFeature.isTunnel();let i=0;Object.hasOwn(e.properties,gh)&&(i=+e.properties[gh]),this.elevatedStructures.addPortalCandidates(l.elevationFeature.id,l.polygons,t,l.elevationFeature,i)}l.elevationFeature.constantHeight??(l.polygons=this.prepareElevatedPolygons(l.polygons,l.elevationFeature,l.elevationTileID));const t=new Oh(i,l.elevationTileID);this.addElevatedGeometry(l.polygons,t,l.elevationFeature,"hd-road-base"===this.elevationMode?0:.05,r,a)}}addElevatedGeometry(e,t,i,r,n,o){const s={elevation:i,elevationSampler:t,bias:r,index:n,featureInfo:o},[a,l]=this.addGeometry(e,this.elevationBufferData,s);null==this.elevationBufferData.heightRange?this.elevationBufferData.heightRange={min:a,max:l}:(this.elevationBufferData.heightRange.min=Math.min(this.elevationBufferData.heightRange.min,a),this.elevationBufferData.heightRange.max=Math.max(this.elevationBufferData.heightRange.max,l))}addGeometry(e,t,i){let r=Number.POSITIVE_INFINITY,n=Number.NEGATIVE_INFINITY,o=null;i&&(o=i.elevationSampler.constantElevation(i.elevation,i.bias),null!=o&&(r=o,n=o));const s=(e,s,a)=>{if(null!=i)if(s.push(e),null!=o)t.elevatedLayoutVertexArray.emplaceBack(o),a.push(o);else{const o=i.elevationSampler.pointElevation(e,i.elevation,i.bias);t.elevatedLayoutVertexArray.emplaceBack(o),a.push(o),r=Math.min(r,o),n=Math.max(n,o)}};for(const a of e){let e=0;for(const t of a)e+=t.length;const r=t.triangleSegments.prepareSegment(e,t.layoutVertexArray,t.indexArray),n=r.vertexLength,o=[],l=[],c=[],h=[],u=[],d=t.layoutVertexArray.length;for(const f of a){if(0===f.length)continue;f!==a[0]&&l.push(o.length/2);const e=t.lineSegments.prepareSegment(f.length,t.layoutVertexArray,t.lineIndexArray),r=e.vertexLength;i&&u.push(t.layoutVertexArray.length-d),s(f[0],c,h),t.layoutVertexArray.emplaceBack(f[0].x,f[0].y),t.lineIndexArray.emplaceBack(r+f.length-1,r),o.push(f[0].x),o.push(f[0].y);for(let i=1;i<f.length;i++)s(f[i],c,h),t.layoutVertexArray.emplaceBack(f[i].x,f[i].y),t.lineIndexArray.emplaceBack(r+i-1,r+i),o.push(f[i].x),o.push(f[i].y);e.vertexLength+=f.length,e.primitiveLength+=f.length}const p=hd(o,l);for(let i=0;i<p.length;i+=3)t.indexArray.emplaceBack(n+p[i],n+p[i+1],n+p[i+2]);if(p.length>0&&i&&"hd-road-base"===this.elevationMode){const e=i.elevation.isTunnel(),t=i.elevation.safeArea,r=this.elevatedStructures.addVertices(c,h);this.elevatedStructures.addTriangles(p,r,e);const n=u.length;if(n>0){for(let o=0;o<n-1;o++)this.elevatedStructures.addRenderableRing(i.index,u[o]+r,u[o+1]-u[o],e,t,i.featureInfo);this.elevatedStructures.addRenderableRing(i.index,u[n-1]+r,c.length-u[n-1],e,t,i.featureInfo)}}r.vertexLength+=e,r.primitiveLength+=p.length/3}return[r,n]}prepareElevatedPolygons(e,t,i){const r=1/Kc(i),n=[];for(const o of e){const e=Sp(o,new zh(t,r),.1);n.push(...e)}return n}clipPolygonsToTile(e,t){const i=-t,r=-t,n=Yr+t,o=Yr+t;let s=0;const a=[],l=[];for(;s<e.length;s++){const t=e[s],c=Mr(t);(c.min.x>=i&&c.max.x<=n&&c.min.y>=r&&c.max.y<=o?a:l).push(t)}if(a.length===e.length)return e;const c=[new Ie(i,r),new Ie(n,r),new Ie(n,o),new Ie(i,o),new Ie(i,r)],h=a;for(const u of l)h.push(...Tp(u,c));return h}}let Cp,Pp,Dp,Rp;as(Mp,"FillBucket",{omit:["layers","patternFeatures"]}),as(Ap,"FillBufferData"),as(Gd,"ElevatedStructures");class zp{constructor(e,t,i,r){if(this.triangleCount=t.length/3,this.min=new Ie(0,0),this.max=new Ie(0,0),this.xScale=0,this.yScale=0,this.cellsX=0,this.cellsY=0,this.cells=[],this.payload=[],0===this.triangleCount||0===e.length)return;const[n,o]=[e[0].clone(),e[0].clone()];for(let h=1;h<e.length;++h){const t=e[h];n.x=Math.min(n.x,t.x),n.y=Math.min(n.y,t.y),o.x=Math.max(o.x,t.x),o.y=Math.max(o.y,t.y)}if(r){const e=Math.ceil(Math.max(o.x-n.x,o.y-n.y)/r);i=Math.max(i,e)}if(0===i)return;this.min=n,this.max=o;const s=this.max.sub(this.min);s.x=Math.max(s.x,1),s.y=Math.max(s.y,1);const a=Math.max(s.x,s.y)/i;this.cellsX=Math.max(1,Math.ceil(s.x/a)),this.cellsY=Math.max(1,Math.ceil(s.y/a)),this.xScale=1/a,this.yScale=1/a;const l=[];for(let h=0;h<this.triangleCount;h++){const i=e[t[3*h+0]].sub(this.min),r=e[t[3*h+1]].sub(this.min),n=e[t[3*h+2]].sub(this.min),o=Lp(Math.floor(Math.min(i.x,r.x,n.x)),this.xScale,this.cellsX),s=Lp(Math.floor(Math.max(i.x,r.x,n.x)),this.xScale,this.cellsX),c=Lp(Math.floor(Math.min(i.y,r.y,n.y)),this.yScale,this.cellsY),u=Lp(Math.floor(Math.max(i.y,r.y,n.y)),this.yScale,this.cellsY),d=new Ie(0,0),p=new Ie(0,0),f=new Ie(0,0),m=new Ie(0,0);for(let e=c;e<=u;++e){d.y=p.y=e*a,f.y=m.y=(e+1)*a;for(let t=o;t<=s;++t)d.x=f.x=t*a,p.x=m.x=(t+1)*a,(eu(i,r,n,d,p,m)||eu(i,r,n,d,m,f))&&l.push({cellIdx:e*this.cellsX+t,triIdx:h})}}if(0===l.length)return;l.sort((e,t)=>e.cellIdx-t.cellIdx||e.triIdx-t.triIdx);let c=0;for(;c<l.length;){const e=l[c].cellIdx,t={start:this.payload.length,len:0};for(;c<l.length&&l[c].cellIdx===e;)++t.len,this.payload.push(l[c++].triIdx);this.cells[e]=t}}_lazyInitLookup(){this.lookup||(this.lookup=new Uint8Array(Math.ceil(this.triangleCount/8))),this.lookup.fill(0)}queryPoint(e,t){if(0===this.triangleCount||0===this.cells.length)return;if(e.x>this.max.x||this.min.x>e.x||e.y>this.max.y||this.min.y>e.y)return;const i=Lp(e.x-this.min.x,this.xScale,this.cellsX),r=Lp(e.y-this.min.y,this.yScale,this.cellsY),n=this.cells[r*this.cellsX+i];if(n){this._lazyInitLookup();for(let e=0;e<n.len;e++){const i=this.payload[n.start+e],r=Math.floor(i/8),o=1<<i%8;if(!(this.lookup[r]&o)&&(this.lookup[r]|=o,t.push(i),t.length===this.triangleCount))return}}}query(e,t,i){if(0===this.triangleCount||0===this.cells.length)return;if(e.x>this.max.x||this.min.x>t.x)return;if(e.y>this.max.y||this.min.y>t.y)return;this._lazyInitLookup();const r=Lp(e.x-this.min.x,this.xScale,this.cellsX),n=Lp(t.x-this.min.x,this.xScale,this.cellsX),o=Lp(e.y-this.min.y,this.yScale,this.cellsY),s=Lp(t.y-this.min.y,this.yScale,this.cellsY);for(let a=o;a<=s;a++)for(let e=r;e<=n;e++){const t=this.cells[a*this.cellsX+e];if(t)for(let e=0;e<t.len;e++){const r=this.payload[t.start+e],n=Math.floor(r/8),o=1<<r%8;if(!(this.lookup[n]&o)&&(this.lookup[n]|=o,i.push(r),i.length===this.triangleCount))return}}}}function Lp(e,t,i){return Math.max(0,Math.min(i-1,Math.floor(e*t)))}as(zp,"TriangleGridIndex");class Fp{constructor(e){this.zoom=e.zoom,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.hasPattern=!1,this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.footprints=[],this.worldview=e.worldview,this.hasAppearances=null}updateFootprints(e,t){for(const i of this.footprints)t.push({footprint:i,id:e})}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){const n=[];for(const{feature:o,id:s,index:a,sourceLayerIndex:l}of e){const e=this.layers[0]._featureFilter.needGeometry,c=lh(o,e);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),c,i))continue;const h={id:s,properties:o.properties,type:o.type,sourceLayerIndex:l,index:a,geometry:e?c.geometry:ah(o,i,r),patterns:{}};n.push(h)}for(const o of n){const{geometry:r,index:n,sourceLayerIndex:s}=o;this.addFeature(o,r,n,i,{},t.availableImages,t.brightness),t.featureIndex.insert(e[n].feature,r,n,s,this.index)}}isEmpty(){return 0===this.footprints.length}uploadPending(){return!1}upload(e){}update(e,t,i,r,n,o,s){}destroy(){}addFeature(e,t,i,r,n,o=[],s){for(const a of Od(t,2)){const e=[],t=[],i=[],r=new Ie(1/0,1/0),n=new Ie(-1/0,-1/0);for(const l of a)if(0!==l.length){l!==a[0]&&i.push(t.length/2);for(let i=0;i<l.length;i++)t.push(l[i].x),t.push(l[i].y),e.push(l[i]),r.x=Math.min(r.x,l[i].x),r.y=Math.min(r.y,l[i].y),n.x=Math.max(n.x,l[i].x),n.y=Math.max(n.y,l[i].y)}const o=hd(t,i),s=new zp(e,o,8,256);this.footprints.push({vertices:e,indices:o,grid:s,min:r,max:n})}}}as(Fp,"ClipBucket",{omit:["layers"]});const Op=Ya([{name:"a_pos_normal_ed",components:4,type:"Int16"}]),Bp=Ya([{name:"a_pos_end",components:4,type:"Int16"},{name:"a_angular_offset_factor",components:1,type:"Int16"}]),kp=Ya([{name:"a_flood_light_ground_radius",components:1,type:"Float32"}]),Np=Ya([{name:"a_centroid_pos",components:2,type:"Uint16"}]),Up=Ya([{name:"a_join_normal_inside",components:3,type:"Int16"}]),Vp=Ya([{name:"a_hidden_by_landmark",components:1,type:"Uint8"}]),jp=Ya([{name:"a_pos_3",components:3,type:"Int16"},{name:"a_pos_normal_3",components:3,type:"Int16"}]),{members:Gp}=Op,Hp=Number.MAX_SAFE_INTEGER,$p=Hp-1;function qp(e,t,i,r){return e.order<t||e.order===Hp||!(e.clipMask&i)||function(e,t){if(0===t.length)return!1;let i=e;for(;""!==i;){if(t.includes(i))return!1;i=Ba(i)}return!0}(r,e.clipScope)}function Zp(e,t){return e.x-t.x||e.y-t.y}function Wp(e,t){return 0===Zp(e.min,t.min)&&0===Zp(e.max,t.max)}function Xp(e,t){return!(e.min.x>t.max.x||e.max.x<t.min.x||e.min.y>t.max.y||e.max.y<t.min.y)}function Yp(e,t){if(e.length!==t.length)return!1;for(let i=0;i<e.length;i++)if(e[i].sourceId!==t[i].sourceId||!Wp(e[i],t[i])||e[i].order!==t[i].order||e[i].clipMask!==t[i].clipMask||!Ee(e[i].clipScope,t[i].clipScope))return!1;return!0}function Jp(e,t,i){const r=1/Yr,n=1/(1<<i.canonical.z),o=(t.x*r+i.canonical.x)*n+i.wrap,s=(t.y*r+i.canonical.y)*n;return{min:new Ie((e.x*r+i.canonical.x)*n+i.wrap,(e.y*r+i.canonical.y)*n),max:new Ie(o,s)}}function Kp(e,t,i){const r=1<<i.canonical.z,n=((t.x-i.wrap)*r-i.canonical.x)*Yr,o=(t.y*r-i.canonical.y)*Yr;return{min:new Ie(((e.x-i.wrap)*r-i.canonical.x)*Yr,(e.y*r-i.canonical.y)*Yr),max:new Ie(n,o)}}function Qp(e,t,i,r,n,o,s){const a=e.indices,l=e.vertices,c=[];for(let h=r;h<r+n;h+=3){const r=t[i[h+0]+o],n=t[i[h+1]+o],u=t[i[h+2]+o],d=Math.min(r.x,n.x,u.x),p=Math.max(r.x,n.x,u.x),f=Math.min(r.y,n.y,u.y),m=Math.max(r.y,n.y,u.y);c.length=0,e.grid.query(new Ie(d,f),new Ie(p,m),c);for(let e=0;e<c.length;e++){const t=c[e];if(eu(l[a[3*t+0]],l[a[3*t+1]],l[a[3*t+2]],r,n,u,s))return!0}}return!1}function ef(e,t,i,r){if(!e||!i)return!1;let n=e.vertices;if(!t.canonical.equals(r.canonical)||t.wrap!==r.wrap){if(i.vertices.length<e.vertices.length)return ef(i,r,e,t);const o=t.canonical,s=r.canonical,a=Math.pow(2,s.z-o.z);n=e.vertices.map(e=>new Ie((e.x+o.x*Yr)*a-s.x*Yr,(e.y+o.y*Yr)*a-s.y*Yr))}return Qp(i,n,e.indices,0,e.indices.length,0,0)}function tf(e,t,i,r){const n=Math.pow(2,r.z-i.z);return new Ie((e+i.x*Yr)*n-r.x*Yr,(t+i.y*Yr)*n-r.y*Yr)}function rf(e,t){const i=[];t.grid.queryPoint(e,i);const r=t.indices,n=t.vertices;for(let o=0;o<i.length;o++){const t=i[o];if(Yh([n[r[3*t+0]],n[r[3*t+1]],n[r[3*t+2]]],e))return!0}return!1}const nf={None:0,Model:1,Symbol:2,FillExtrusion:4},of=[new Ie(0,0),new Ie(Yr,0),new Ie(Yr,Yr),new Ie(0,Yr)];function sf(e,t){const i=[];let r=[];if(!t||e.length<2)return[e];if(2===e.length)return Kh(e[0],e[1],of)?[e]:[];for(let n=0;n<e.length+2;n++){const t=0===n?e.at(-1):e[(n-1)%e.length],o=e[n%e.length],s=e[(n+1)%e.length],a=Kh(t,o,of),l=Kh(o,s,of),c=a||l;c&&r.push(o),c&&l||r.length>0&&(r.length>1&&i.push(r),r=[])}return r.length>1&&i.push(r),i}const af=ch.types,lf=["fill-extrusion-base","fill-extrusion-height","fill-extrusion-color","fill-extrusion-pattern","fill-extrusion-flood-light-wall-radius","fill-extrusion-line-width","fill-extrusion-emissive-strength"],cf=["fill-extrusion-flood-light-ground-radius"],hf=Math.pow(2,13),uf=Math.pow(2,15)-1,df=new Ie(0,1),pf=2147483648,ff=1073741824;function mf(e,t,i,r,n,o,s,a){e.emplaceBack((t<<1)+s,(i<<1)+o,(Math.floor(r*hf)<<1)+n,Math.round(a))}function _f(e,t,i){e.emplaceBack(t.x*Yr,t.y*Yr,i?1:0)}function gf(e,t,i,r,n,o){e.emplaceBack(t.x,t.y,(i.x<<1)+r,(i.y<<1)+n,o)}function yf(e,t,i){const r=16384;e.emplaceBack(t.x,t.y,t.z,i[0]*r,i[1]*r,i[2]*r)}class xf{constructor(){this.vertexOffset=0,this.vertexCount=0,this.indexOffset=0,this.indexCount=0}}class vf{constructor(){this.data=[]}get length(){return this.data.length}push(e){this.data.push(e)}get(e){return this.data[e]}static serialize(e,t){const i=e.data.length,r=new Uint32Array(4*i),n=[];n.length=i;for(let o=0;o<i;o++){const t=e.data[o],i=4*o;r[i]=t.vertexOffset,r[i+1]=t.vertexCount,r[i+2]=t.indexOffset,r[i+3]=t.indexCount,n[o]=t.ringIndices}return t&&t.add(r.buffer),{scalars:r,rings:n}}static deserialize(e){const{scalars:t,rings:i}=e,r=t.length/4,n=new vf,o=[];o.length=r,n.data=o;for(let s=0;s<r;s++){const e=4*s,r=new xf;r.vertexOffset=t[e],r.vertexCount=t[e+1],r.indexOffset=t[e+2],r.indexCount=t[e+3],r.ringIndices=i[s],n.data[s]=r}return n}}class bf{constructor(){this.centroidXY=new Ie(0,0),this.vertexArrayOffset=0,this.vertexCount=0,this.groundVertexArrayOffset=0,this.groundVertexCount=0,this.flags=0,this.footprintSegIdx=-1,this.footprintSegLen=0,this.polygonSegIdx=-1,this.polygonSegLen=0,this.min=new Ie(Number.MAX_VALUE,Number.MAX_VALUE),this.max=new Ie(-Number.MAX_VALUE,-Number.MAX_VALUE),this.height=0,this.buildingId=0,this.groupCentroidPos=new Ie(0,0)}span(){return new Ie(this.max.x-this.min.x,this.max.y-this.min.y)}}class wf{constructor(){this.data=[],this.buffer=null}get length(){return this.data.length}push(e){this.data.push(e)}get(e){return this.data[e]}find(e){return this.data.find(e)}[Symbol.iterator](){return this.data[Symbol.iterator]()}static serialize(e,t){const i=e.data.length,r=new Float64Array(15*i);for(let n=0;n<i;n++){const t=e.data[n],i=15*n;r[i]=t.centroidXY.x,r[i+1]=t.centroidXY.y,r[i+2]=t.min.x,r[i+3]=t.min.y,r[i+4]=t.max.x,r[i+5]=t.max.y,r[i+6]=t.groupCentroidPos.x,r[i+7]=t.groupCentroidPos.y,r[i+8]=t.vertexArrayOffset,r[i+9]=t.vertexCount,r[i+10]=t.groundVertexArrayOffset,r[i+11]=t.groundVertexCount,r[i+12]=t.footprintSegLen,r[i+13]=t.height,r[i+14]=t.buildingId}return t&&t.add(r.buffer),{buffer:r}}static deserialize(e){const t=e.buffer,i=t.length/15,r=new wf;r.buffer=t;const n=[];n.length=i,r.data=n;let o=0;for(let s=0;s<i;s++){const e=15*s,i=new bf;i.centroidXY=new Ie(t[e],t[e+1]),i.min=new Ie(t[e+2],t[e+3]),i.max=new Ie(t[e+4],t[e+5]),i.groupCentroidPos=new Ie(t[e+6],t[e+7]),i.vertexArrayOffset=t[e+8],i.vertexCount=t[e+9],i.groundVertexArrayOffset=t[e+10],i.groundVertexCount=t[e+11],i.footprintSegLen=t[e+12],i.height=t[e+13],i.buildingId=t[e+14],i.footprintSegIdx=o,o+=i.footprintSegLen,r.data[s]=i}return r}}class Tf{constructor(){this.acc=new Ie(0,0),this.accCount=0,this.centroidDataIndex=0}startRing(e,t){e.min.x===Number.MAX_VALUE&&(e.min.x=e.max.x=t.x,e.min.y=e.max.y=t.y)}appendEdge(e,t,i){this.accCount++,this.acc._add(t);let r=!!this.borders;t.x<e.min.x?(e.min.x=t.x,r=!0):t.x>e.max.x&&(e.max.x=t.x,r=!0),t.y<e.min.y?(e.min.y=t.y,r=!0):t.y>e.max.y&&(e.max.y=t.y,r=!0),((0===t.x||t.x===Yr)&&t.x===i.x)!=((0===t.y||t.y===Yr)&&t.y===i.y)&&this.processBorderOverlap(t,i),r&&this.checkBorderIntersection(t,i)}checkBorderIntersection(e,t){t.x<0!=e.x<0&&this.addBorderIntersection(0,yi(t.y,e.y,(0-t.x)/(e.x-t.x))),t.x>Yr!=e.x>Yr&&this.addBorderIntersection(1,yi(t.y,e.y,(Yr-t.x)/(e.x-t.x))),t.y<0!=e.y<0&&this.addBorderIntersection(2,yi(t.x,e.x,(0-t.y)/(e.y-t.y))),t.y>Yr!=e.y>Yr&&this.addBorderIntersection(3,yi(t.x,e.x,(Yr-t.y)/(e.y-t.y)))}addBorderIntersection(e,t){this.borders||(this.borders=[[Number.MAX_VALUE,-Number.MAX_VALUE],[Number.MAX_VALUE,-Number.MAX_VALUE],[Number.MAX_VALUE,-Number.MAX_VALUE],[Number.MAX_VALUE,-Number.MAX_VALUE]]);const i=this.borders[e];t<i[0]&&(i[0]=t),t>i[1]&&(i[1]=t)}processBorderOverlap(e,t){if(e.x===t.x){if(e.y===t.y)return;const i=0===e.x?0:1;this.addBorderIntersection(i,t.y),this.addBorderIntersection(i,e.y)}else{const i=0===e.y?2:3;this.addBorderIntersection(i,t.x),this.addBorderIntersection(i,e.x)}}centroid(){return 0===this.accCount?new Ie(0,0):new Ie(Math.floor(Math.max(0,this.acc.x)/this.accCount),Math.floor(Math.max(0,this.acc.y)/this.accCount))}intersectsCount(){return this.borders?this.borders.reduce((e,t)=>e+ +(t[0]!==Number.MAX_VALUE),0):0}}function Sf(e,t){const i=e.add(t)._unit(),r=ke(e.x*i.x+e.y*i.y,-1,1);var n,o,s;return s=Math.acos(r),Math.min(4,Math.max(-4,Math.tan(s)))/4*uf*((n=e).x*(o=t).y-n.y*o.x<0?-1:1)}const If=[e=>e.x<0,e=>e.x>Yr,e=>e.y<0,e=>e.y>Yr];function Ef(e,t,i,r){const n=[4];if(0===r)return n;i._mult(r);const o=[e,t,e.sub(i),t.sub(i)];for(let s=0;s<4;s++)for(const e of o)if(If[s](e)){n.push(s);break}return n}class Af{constructor(e){this.groundRadiusArray=null,this.groundRadiusBuffer=null,this.vertexArray=new ol,this.indexArray=new vl,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut},e=>cf.includes(e)),this._segments=new Jl,this.hiddenByLandmarkVertexArray=new Ll,this._segmentToGroundQuads={},this._segmentToGroundQuads[0]=[],this._segmentToRegionTriCounts={},this._segmentToRegionTriCounts[0]=[0,0,0,0,0],this.regionSegments={},this.regionSegments[4]=new Jl}getDefaultSegment(){return this.regionSegments[4]}hasData(){return 0!==this.vertexArray.length}addData(e,t,i,r=!1){const n=e.length;if(n>2){let o=Math.max(0,this._segments.get().length-1);const s=this._segments._prepareSegment(4*n,this.vertexArray.length,2*this._segmentToGroundQuads[o].length);let a;o!==this._segments.get().length-1&&(o++,this._segmentToGroundQuads[o]=[],this._segmentToRegionTriCounts[o]=[0,0,0,0,0]);{const t=e[0],i=e[1];a=Sf(t.sub(e[n-1])._perp()._unit(),i.sub(t)._perp()._unit())}for(let l=0;l<n;l++){const c=l===n-1?0:l+1,h=e[l],u=e[c],d=e[c===n-1?0:c+1],p=u.sub(h)._perp()._unit(),f=Sf(p,d.sub(u)._perp()._unit()),m=a,_=f;if(Rf(h,u,t)||r&&zf(h,t)&&zf(u,t)){a=f;continue}const g=s.vertexLength;gf(this.vertexArray,h,u,1,1,m),gf(this.vertexArray,h,u,1,0,m),gf(this.vertexArray,h,u,0,1,_),gf(this.vertexArray,h,u,0,0,_),s.vertexLength+=4;const y=Ef(h,u,p,i);for(const e of y)this._segmentToGroundQuads[o].push({id:g,region:e}),this._segmentToRegionTriCounts[o][e]+=2,s.primitiveLength+=2;a=f}}}prepareBorderSegments(){if(!this.hasData())return;const e=this._segments.get(),t=e.length;for(let i=0;i<t;i++)this._segmentToGroundQuads[i].sort((e,t)=>e.region-t.region);for(let i=0;i<t;i++){const t=this._segmentToGroundQuads[i],r=e[i],n=this._segmentToRegionTriCounts[i];n.reduce((e,t)=>e+t,0);let o=0;for(let e=0;e<=4;e++){const t=n[e];if(0!==t){let i=this.regionSegments[e];i||(i=this.regionSegments[e]=new Jl);const n={vertexOffset:r.vertexOffset,primitiveOffset:r.primitiveOffset+o,vertexLength:r.vertexLength,primitiveLength:t};i.get().push(n)}o+=t}for(let e=0;e<t.length;e++){const i=t[e].id;this.indexArray.emplaceBack(i,i+1,i+3),this.indexArray.emplaceBack(i,i+3,i+2)}}this._segmentToGroundQuads=null,this._segmentToRegionTriCounts=null,this._segments.destroy(),this._segments=null}addPaintPropertiesData(e,t,i,r,n,o,s){this.hasData()&&this.programConfigurations.populatePaintArrays(this.vertexArray.length,e,t,i,r,n,o,void 0,s)}upload(e){this.hasData()&&(this.vertexBuffer=e.createVertexBuffer(this.vertexArray,Bp.members),this.indexBuffer=e.createIndexBuffer(this.indexArray),null!=this.groundRadiusArray&&(this.groundRadiusBuffer=e.createVertexBuffer(this.groundRadiusArray,kp.members)))}uploadPaintProperties(e){this.hasData()&&this.programConfigurations.upload(e)}update(e,t,i,r,n,o,s,a){this.hasData()&&this.programConfigurations.updatePaintArrays(e,t,i,r,n,o,s,a)}updateHiddenByLandmark(e){this.updateHiddenByLandmarkRange(e.groundVertexArrayOffset,e.groundVertexCount,!!(e.flags&pf||e.flags&ff))}updateHiddenByLandmarkRange(e,t,i){if(!this.hasData())return;const r=t+e;if(0!==t){for(let t=e;t<r;++t)this.hiddenByLandmarkVertexArray.emplace(t,i?1:0);this._needsHiddenByLandmarkUpdate=!0}}uploadHiddenByLandmark(e){this.hasData()&&this._needsHiddenByLandmarkUpdate&&(!this.hiddenByLandmarkVertexBuffer&&this.hiddenByLandmarkVertexArray.length>0?this.hiddenByLandmarkVertexBuffer=e.createVertexBuffer(this.hiddenByLandmarkVertexArray,Vp.members,!0):this.hiddenByLandmarkVertexBuffer&&this.hiddenByLandmarkVertexBuffer.updateData(this.hiddenByLandmarkVertexArray),this._needsHiddenByLandmarkUpdate=!1)}destroy(){if(this.vertexBuffer){this.vertexBuffer.destroy(),this.indexBuffer.destroy(),this.hiddenByLandmarkVertexBuffer&&this.hiddenByLandmarkVertexBuffer.destroy(),this.groundRadiusBuffer&&this.groundRadiusBuffer.destroy(),this._segments&&this._segments.destroy(),this.programConfigurations.destroy();for(let e=0;e<=4;e++){const t=this.regionSegments[e];t&&t.destroy()}}}}class Mf{constructor(e){this.zoom=e.zoom,this.canonical=e.canonical,this.overscaling=e.overscaling,this.layers=e.layers,this.pixelRatio=e.pixelRatio,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.hasPattern=!1,this.edgeRadius=0,this.projection=e.projection,this.activeReplacements=[],this.replacementUpdateTime=0,this.centroidData=new wf,this.footprintIndices=new vl,this.footprintVertices=new Ka,this.footprintSegments=new vf,this.layoutVertexArray=new nl,this.centroidVertexArray=new $l,this.wallVertexArray=new Zl,this.indexArray=new vl,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut},e=>lf.includes(e)),this.segments=new Jl,this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.groundEffect=new Af(e),this.maxHeight=0,this.partLookup={},this.triangleSubSegments=[],this.polygonSegments=[],this.buildingGroups=/* @__PURE__ */new Map,this.worldview=e.worldview,this.hasAppearances=null}updateFootprints(e,t){}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){this.features=[],this.hasPattern=Nd("fill-extrusion",this.layers,this.pixelRatio,t),this.featuresOnBorder=[],this.borderFeatureIndices=[[],[],[],[]],this.borderDoneWithNeighborZ=[-1,-1,-1,-1],this.selfDEMTileTimestamp=Number.MAX_VALUE,this.borderDEMTileTimestamp=[Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE,Number.MAX_VALUE],this.tileToMeter=Kc(i),this.edgeRadius=this.layers[0].layout.get("fill-extrusion-edge-radius")/this.tileToMeter,this.wallMode=0!==this.layers[0].paint.get("fill-extrusion-line-width").constantOr(1);for(const{feature:n,id:o,index:s,sourceLayerIndex:a}of e){const e=this.layers[0]._featureFilter.needGeometry,l=lh(n,e);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),l,i))continue;const c={id:o,sourceLayerIndex:a,index:s,geometry:e?l.geometry:ah(n,i,r),properties:n.properties,type:n.type,patterns:{}},h=this.layoutVertexArray.length,u="Polygon"===af[c.type];if(this.hasPattern)this.features.push({featureId:n.id,feature:Ud("fill-extrusion",this.layers,c,this.zoom,this.pixelRatio,t)});else if(this.wallMode)for(const o of c.geometry)for(const e of sf(o,u))this.addFeature(n.id,c,[e],s,i,{},t.availableImages,r,t.brightness);else this.addFeature(n.id,c,c.geometry,s,i,{},t.availableImages,r,t.brightness);t.featureIndex.insert(n,c.geometry,s,a,this.index,h)}this._finalizeBuildingGroups(),this.sortBorders(),"mercator"===this.projection.name&&this.splitToSubtiles(),this.groundEffect.prepareBorderSegments(),this.polygonSegments.length=0}addFeatures(e,t,i,r,n,o){for(const{featureId:s,feature:a}of this.features){const e="Polygon"===af[a.type],{geometry:l}=a;if(this.wallMode)for(const c of l)for(const l of sf(c,e))this.addFeature(s,a,[l],a.index,t,i,r,n,o);else this.addFeature(s,a,l,a.index,t,i,r,n,o)}this._finalizeBuildingGroups(),this.sortBorders(),"mercator"===this.projection.name&&this.splitToSubtiles()}update(e,t,i,r,n,o,s){this.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,this.worldview),this.groundEffect.update(e,t,n,i,r,o,s,this.worldview)}updateExpressions(e){this.programConfigurations.updateExpressions(e),this.groundEffect.programConfigurations.updateExpressions(e)}isEmpty(){return 0===this.layoutVertexArray.length}uploadPending(){return!this.uploaded||this.programConfigurations.needsUpload||this.groundEffect.programConfigurations.needsUpload}upload(e){this.uploaded||(this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,Gp),this.indexBuffer=e.createIndexBuffer(this.indexArray),this.wallVertexBuffer=e.createVertexBuffer(this.wallVertexArray,Up.members),this.layoutVertexExtArray&&(this.layoutVertexExtBuffer=e.createVertexBuffer(this.layoutVertexExtArray,jp.members,!0)),this.groundEffect.upload(e)),this.groundEffect.uploadPaintProperties(e),this.programConfigurations.upload(e),this.uploaded=!0}uploadCentroid(e){this.groundEffect.uploadHiddenByLandmark(e),this.needsCentroidUpdate&&(!this.centroidVertexBuffer&&this.centroidVertexArray.length>0?this.centroidVertexBuffer=e.createVertexBuffer(this.centroidVertexArray,Np.members,!0):this.centroidVertexBuffer&&this.centroidVertexBuffer.updateData(this.centroidVertexArray),this.needsCentroidUpdate=!1)}destroy(){this.layoutVertexBuffer&&(this.layoutVertexBuffer.destroy(),this.centroidVertexBuffer&&this.centroidVertexBuffer.destroy(),this.layoutVertexExtBuffer&&this.layoutVertexExtBuffer.destroy(),this.groundEffect.destroy(),this.indexBuffer.destroy(),this.programConfigurations.destroy(),this.segments.destroy())}addFeature(e,t,i,r,n,o,s,a,l){const c=this.layers[0].paint.get("fill-extrusion-flood-light-ground-radius").evaluate(t,{})/this.tileToMeter,h=[new Ie(0,0),new Ie(Yr,Yr)],u=a.projection,d="globe"===u.name,p=this.wallMode||"Polygon"===af[t.type],f=new Tf;f.centroidDataIndex=this.centroidData.length;const m=new bf;m.buildingId=e,t.properties&&Object.hasOwn(t.properties,"building_id")&&(m.buildingId=Number(t.properties.building_id)),f.buildingId=m.buildingId;const _=this.layers[0].paint.get("fill-extrusion-base").evaluate(t,{},n)<=0,g=this.layers[0].paint.get("fill-extrusion-height").evaluate(t,{},n);let y;if(m.height=g,m.vertexArrayOffset=this.layoutVertexArray.length,m.groundVertexArrayOffset=this.groundEffect.vertexArray.length,d&&!this.layoutVertexExtArray&&(this.layoutVertexExtArray=new hl),this.wallMode){if(d)return void Ke("Non zero fill-extrusion-line-width is not yet supported on globe.");if(1!==i.length)return;y=function(e){const t=e[0].x===e.at(-1).x&&e[0].y===e.at(-1).y;(function(e){let t=0;const i=e.length;for(let r=0;r<i;r++)t+=(e[(r+1)%i].x-e[r].x)*(e[(r+1)%i].y+e[r].y);return t>=0})(e)||(e=e.reverse());const i={geometry:[],joinNormals:[],indices:[]},r=[],n=[],o=[];let s=e.length;for(;s>=2&&e[s-1].equals(e[s-2]);)s--;if(s<(t?3:2))return i;let a,l,c,h,u,d=0;for(;d<s-1&&e[d].equals(e[d+1]);)d++;t&&(a=e[s-2],u=e[d].sub(a)._unit()._perp());for(let f=d;f<s;f++){if(c=f===s-1?t?e[d+1]:void 0:e[f+1],c&&e[f].equals(c))continue;u&&(h=u),a&&(l=a),a=e[f],u=c?c.sub(a)._unit()._perp():h,h=h||u;let i=h.add(u);0===i.x&&0===i.y||i._unit();const p=i.x*u.x+i.y*u.y,m=0!==p?1/p:1/0,_=h.x*u.y-h.y*u.x>0;let g="miter";const y=2;"miter"===g&&m>y&&(g="bevel"),"bevel"===g&&(m>100&&(g="flipbevel"),m<y&&(g="miter"));const x=(e,t,i,s)=>{const a=new Ie(e.x,e.y),l=new Ie(e.x,e.y);a.x+=t.x*s,a.y+=t.y*s,l.x-=t.x*Math.max(i,1),l.y-=t.y*Math.max(i,1),o.push(t),r.push(a),n.push(l)};if("miter"===g)i._mult(m),x(a,i,0,0);else if("flipbevel"===g)i=u.mult(-1),x(a,i,0,0),x(a,i.mult(-1),0,0);else{const e=-Math.sqrt(m*m-1),t=_?e:0,i=_?0:e;l&&x(a,h,t,i),c&&x(a,u,t,i)}}i.geometry=[...r,...n.reverse(),r[0]],i.joinNormals=[...o,...o.reverse(),o.at(-1)];const p=i.geometry.length-1;for(let f=0;f<p/2;f++)if(f+1<p/2){let e=f,t=f+1,r=p-1-f,n=p-2-f;e=0===e?p-1:e-1,t=0===t?p-1:t-1,r=0===r?p-1:r-1,n=0===n?p-1:n-1,i.indices.push(r),i.indices.push(t),i.indices.push(e),i.indices.push(r),i.indices.push(n),i.indices.push(t)}return i}(i[0]),i=[y.geometry]}const x=(e,t)=>e<(t.length-1)/2||e===t.length-1,v=this.wallMode?[i]:Od(i,500);for(let I=v.length-1;I>=0;I--){const e=v[I];(0===e.length||Lf(e[0]))&&v.splice(I,1)}let b;if(d)b=kf(v,h,n);else{b=[];for(const e of v)b.push({polygon:e,bounds:h})}const w=p?this.edgeRadius:0,T=w>0&&this.zoom<17,S=(e,t)=>{if(0===e.length)return!1;const i=e.at(-1);return t.x===i.x&&t.y===i.y};for(const{polygon:I,bounds:E}of b){let e=0,t=0;for(const n of I)p&&!n[0].equals(n.at(-1))&&n.push(n[0]),t+=p?n.length-1:n.length;const i=this.segments.prepareSegment((p?5:4)*t,this.layoutVertexArray,this.indexArray);m.footprintSegIdx<0&&(m.footprintSegIdx=this.footprintSegments.length),m.polygonSegIdx<0&&(m.polygonSegIdx=this.polygonSegments.length);const r={triangleArrayOffset:this.indexArray.length,triangleCount:0,triangleSegIdx:this.segments.segments.length-1},o=new xf;if(o.vertexOffset=this.footprintVertices.length,o.indexOffset=3*this.footprintIndices.length,o.ringIndices=[],p){const t=[],r=[];e=i.vertexLength;for(let e=0;e<I.length;e++){const s=I[e];s.length&&0!==e&&r.push(t.length/2);const a=[];let l,h;l=s[1].sub(s[0])._perp()._unit(),o.ringIndices.push(s.length-1);for(let e=1;e<s.length;e++){const r=s[e],o=s[e===s.length-1?1:e+1],c=r.clone();if(w){h=o.sub(r)._perp()._unit();const e=l.add(h)._unit(),t=w*Math.min(4,1/(l.x*e.x+l.y*e.y));c.x+=t*e.x,c.y+=t*e.y,c.x=Math.round(c.x),c.y=Math.round(c.y),l=h}if(!_||0!==w&&!T||S(a,c)||a.push(c),mf(this.layoutVertexArray,c.x,c.y,0,0,1,1,0),this.wallMode){const t=x(e,s);_f(this.wallVertexArray,y.joinNormals[e],!t)}i.vertexLength++,this.footprintVertices.emplaceBack(r.x,r.y),t.push(r.x,r.y),d&&yf(this.layoutVertexExtArray,u.projectTilePoint(c.x,c.y,n),u.upVector(n,c.x,c.y))}_&&(0===w||T)&&(0!==a.length&&S(a,a[0])&&a.pop(),this.groundEffect.addData(a,E,c))}const s=this.wallMode?y.indices:hd(t,r);for(let n=0;n<s.length;n+=3)this.footprintIndices.emplaceBack(o.vertexOffset+s[n+0],o.vertexOffset+s[n+1],o.vertexOffset+s[n+2]),this.indexArray.emplaceBack(e+s[n],e+s[n+2],e+s[n+1]),i.primitiveLength++;o.indexCount+=s.length,o.vertexCount+=this.footprintVertices.length-o.vertexOffset}for(let s=0;s<I.length;s++){const t=I[s];f.startRing(m,t[0]);let r=t.length>4&&Ff(t[t.length-2],t[0],t[1]),o=w?Pf(t[t.length-2],t[0],t[1],w):0;const a=[];let l,h,g;h=t[1].sub(t[0])._perp()._unit();let v=!0;for(let s=1,c=0;s<t.length;s++){let p=t[s-1],b=t[s];const T=t[s===t.length-1?1:s+1];if(f.appendEdge(m,b,p),Rf(b,p,E)){w&&(h=T.sub(b)._perp()._unit(),v=!v);continue}const I=b.sub(p)._perp(),A=I.x/(Math.abs(I.x)+Math.abs(I.y)),M=I.y>0?1:0,C=p.dist(b);if(c+C>32768&&(c=0),w){g=T.sub(b)._perp()._unit();let e=Df(p,b,T,Cf(h,g),w);isNaN(e)&&(e=0);const t=b.sub(p)._unit();p=p.add(t.mult(o))._round(),b=b.add(t.mult(-e))._round(),o=e,h=g,_&&this.zoom>=17&&(S(a,p)||a.push(p),S(a,b)||a.push(b))}const P=i.vertexLength,D=t.length>4&&Ff(p,b,T);let R=Of(c,r,v);if(mf(this.layoutVertexArray,p.x,p.y,A,M,0,0,R),mf(this.layoutVertexArray,p.x,p.y,A,M,0,1,R),this.wallMode){const e=x(s-1,t),i=y.joinNormals[s-1];_f(this.wallVertexArray,i,e),_f(this.wallVertexArray,i,e)}if(c+=C,R=Of(c,D,!v),r=D,mf(this.layoutVertexArray,b.x,b.y,A,M,0,0,R),mf(this.layoutVertexArray,b.x,b.y,A,M,0,1,R),this.wallMode){const e=x(s,t),i=y.joinNormals[s];_f(this.wallVertexArray,i,e),_f(this.wallVertexArray,i,e)}if(i.vertexLength+=4,this.indexArray.emplaceBack(P+0,P+1,P+2),this.indexArray.emplaceBack(P+1,P+3,P+2),i.primitiveLength+=2,w){const r=e+(1===s?t.length-2:s-2),n=1===s?e:r+1;if(this.indexArray.emplaceBack(P+1,r,P+3),this.indexArray.emplaceBack(r,n,P+3),i.primitiveLength+=2,void 0===l&&(l=P),!Rf(T,t[s],E)){const e=s===t.length-1?l:i.vertexLength;this.indexArray.emplaceBack(P+2,P+3,e),this.indexArray.emplaceBack(P+3,e+1,e),this.indexArray.emplaceBack(P+3,n,e+1),i.primitiveLength+=3}v=!v}if(d){const e=this.layoutVertexExtArray,t=u.projectTilePoint(p.x,p.y,n),i=u.projectTilePoint(b.x,b.y,n),r=u.upVector(n,p.x,p.y),o=u.upVector(n,b.x,b.y);yf(e,t,r),yf(e,t,r),yf(e,i,o),yf(e,i,o)}}p&&(e+=t.length-1),_&&w&&this.zoom>=17&&(0!==a.length&&S(a,a[0])&&a.pop(),this.groundEffect.addData(a,E,c,w>0))}this.footprintSegments.push(o),r.triangleCount=this.indexArray.length-r.triangleArrayOffset,this.polygonSegments.push(r),++m.footprintSegLen,++m.polygonSegLen}if(m.vertexCount=this.layoutVertexArray.length-m.vertexArrayOffset,m.groundVertexCount=this.groundEffect.vertexArray.length-m.groundVertexArrayOffset,0!==m.vertexCount){if(m.centroidXY=f.borders?df:this.encodeCentroid(f,m),t.properties&&Object.hasOwn(t.properties,"building_id")){const e=m.buildingId;let t=this.buildingGroups.get(e);t||(t={accX:0,accY:0,accCount:0,mergedMin:new Ie(Number.MAX_VALUE,Number.MAX_VALUE),mergedMax:new Ie(-Number.MAX_VALUE,-Number.MAX_VALUE),partIndices:[]},this.buildingGroups.set(e,t)),t.accX+=f.acc.x,t.accY+=f.acc.y,t.accCount+=f.accCount,t.mergedMin.x=Math.min(t.mergedMin.x,m.min.x),t.mergedMin.y=Math.min(t.mergedMin.y,m.min.y),t.mergedMax.x=Math.max(t.mergedMax.x,m.max.x),t.mergedMax.y=Math.max(t.mergedMax.y,m.max.y),t.partIndices.push(this.centroidData.length)}if(this.centroidData.push(m),f.borders){this.featuresOnBorder.push(f);const e=this.featuresOnBorder.length-1;for(let t=0;t<f.borders.length;t++)f.borders[t][0]!==Number.MAX_VALUE&&this.borderFeatureIndices[t].push(e)}this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length,t,r,o,s,n,l,void 0,this.worldview),this.groundEffect.addPaintPropertiesData(t,r,o,s,n,l,this.worldview),this.maxHeight=Math.max(this.maxHeight,g)}}_finalizeBuildingGroups(){for(const[,e]of this.buildingGroups){if(0===e.partIndices.length)continue;const t=new Tf;t.acc=new Ie(e.accX,e.accY),t.accCount=e.accCount;const i=new bf;i.min=e.mergedMin,i.max=e.mergedMax;const r=this.encodeCentroid(t,i),n=t.centroid();for(const o of e.partIndices){const t=this.centroidData.get(o);t.centroidXY.x===df.x&&t.centroidXY.y===df.y||(t.centroidXY=r),t.min=e.mergedMin,t.max=e.mergedMax,t.groupCentroidPos=n}}this.buildingGroups.clear()}sortBorders(){for(let e=0;e<this.borderFeatureIndices.length;e++)this.borderFeatureIndices[e].sort((t,i)=>this.featuresOnBorder[t].borders[e][0]-this.featuresOnBorder[i].borders[e][0])}splitToSubtiles(){const e=[];for(let s=0;s<this.centroidData.length;s++){const t=this.centroidData.get(s),i=+(t.min.y+t.max.y>Yr),r=2*i+(+(t.min.x+t.max.x>Yr)^i);for(let n=0;n<t.polygonSegLen;n++){const i=t.polygonSegIdx+n;e.push({centroidIdx:s,subtile:r,polygonSegmentIdx:i,triangleSegmentIdx:this.polygonSegments[i].triangleSegIdx})}}const t=new vl;e.sort((e,t)=>e.triangleSegmentIdx===t.triangleSegmentIdx?e.subtile-t.subtile:e.triangleSegmentIdx-t.triangleSegmentIdx);let i=0,r=0,n=0;for(const s of e){if(s.triangleSegmentIdx!==i)break;n++}const o=e.length;for(;r!==e.length;){i=e[r].triangleSegmentIdx;let s=0,a=r,l=r;for(let t=a;t<n&&e[t].subtile===s;t++)l++;for(;a!==n;){const r=e[a];s=r.subtile;const o=this.centroidData.get(r.centroidIdx).min.clone(),c=this.centroidData.get(r.centroidIdx).max.clone(),h={vertexOffset:this.segments.segments[i].vertexOffset,primitiveOffset:t.length,vertexLength:this.segments.segments[i].vertexLength,primitiveLength:0,sortKey:void 0,vaos:{}};for(let i=a;i<l;i++){const r=e[i],n=this.polygonSegments[r.polygonSegmentIdx],s=this.centroidData.get(r.centroidIdx).min,a=this.centroidData.get(r.centroidIdx).max,l=this.indexArray.uint16;for(let e=n.triangleArrayOffset;e<n.triangleArrayOffset+n.triangleCount;e++)t.emplaceBack(l[3*e],l[3*e+1],l[3*e+2]);h.primitiveLength+=n.triangleCount,o.x=Math.min(o.x,s.x),o.y=Math.min(o.y,s.y),c.x=Math.max(c.x,a.x),c.y=Math.max(c.y,a.y)}h.primitiveLength>0&&this.triangleSubSegments.push({segment:h,min:o,max:c}),a=l;for(let t=a;t<n&&e[t].subtile===e[a].subtile;t++)l++}r=n;for(let t=r;t<o&&e[t].triangleSegmentIdx===e[r].triangleSegmentIdx;t++)n++}t._trim(),this.indexArray=t}getVisibleSegments(e,t,i){const r=new Jl;if(this.wallMode){for(const e of this.triangleSubSegments)r.segments.push(e.segment);return r}let n=0,o=0;const s=1<<e.canonical.z;if(t){const i=t.getMinMaxForTile(e);i&&(n=i.min,o=i.max)}o+=this.maxHeight;const a=e.toUnwrapped();let l;const c=[a.canonical.x/s+a.wrap,a.canonical.y/s],h=[(a.canonical.x+1)/s+a.wrap,(a.canonical.y+1)/s],u=(e,t,i)=>[e[0]*(1-i[0])+t[0]*i[0],e[1]*(1-i[1])+t[1]*i[1]],d=[],p=[];for(const f of this.triangleSubSegments){d[0]=f.min.x/Yr,d[1]=f.min.y/Yr,p[0]=f.max.x/Yr,p[1]=f.max.y/Yr;const e=u(c,h,d),t=u(c,h,p);if(0===new Rh([e[0],e[1],n],[t[0],t[1],o]).intersectsPrecise(i)){l&&(r.segments.push(l),l=void 0);continue}const s=f.segment;l&&l.vertexOffset!==s.vertexOffset&&(r.segments.push(l),l=void 0),l?(l.vertexLength+=s.vertexLength,l.primitiveLength+=s.primitiveLength):l={vertexOffset:s.vertexOffset,primitiveLength:s.primitiveLength,vertexLength:s.vertexLength,primitiveOffset:s.primitiveOffset,sortKey:void 0,vaos:{}}}return l&&r.segments.push(l),r}encodeCentroid(e,t){const i=e.centroid(),r=t.span(),n=Math.min(7,Math.round(r.x*this.tileToMeter/10)),o=Math.min(6,Math.round(r.y*this.tileToMeter/10));return new Ie(ke(i.x,1,8191)<<3|n,ke(i.y,1,8191)<<3|o)}encodeBorderCentroid(e){if(!e.borders)return new Ie(0,0);const t=e.borders,i=Number.MAX_VALUE;if(t[0][0]!==i||t[1][0]!==i){const e=t[0][0]!==i?0:1;return new Ie(6|(t[0][0]!==i?0:65528),(t[e][0]+t[e][1])/2<<3|6)}{const e=t[2][0]!==i?2:3;return new Ie((t[e][0]+t[e][1])/2<<3|6,6|(t[2][0]!==i?0:65528))}}showCentroid(e){const t=this.centroidData.get(e.centroidDataIndex);if(t.flags&=pf,0!==t.groupCentroidPos.x||0!==t.groupCentroidPos.y){const e=t.span(),i=Math.min(7,Math.round(e.x*this.tileToMeter/10)),r=Math.min(6,Math.round(e.y*this.tileToMeter/10));t.centroidXY=new Ie(ke(t.groupCentroidPos.x,1,8191)<<3|i,ke(t.groupCentroidPos.y,1,8191)<<3|r)}else t.centroidXY=new Ie(0,0);this.writeCentroidToBuffer(t)}writeCentroidToBuffer(e){this.groundEffect.updateHiddenByLandmark(e);const t=e.vertexArrayOffset,i=e.vertexCount+e.vertexArrayOffset,r=-1073741824&e.flags?df:e.centroidXY,n=this.centroidVertexArray.geta_centroid_pos0(t);if(this.centroidVertexArray.geta_centroid_pos1(t)!==r.y||n!==r.x){for(let e=t;e<i;++e)this.centroidVertexArray.emplace(e,r.x,r.y);this.needsCentroidUpdate=!0}}createCentroidsBuffer(){this.centroidVertexArray.resize(this.layoutVertexArray.length),this.groundEffect.hiddenByLandmarkVertexArray.resize(this.groundEffect.vertexArray.length);for(const e of this.centroidData)this.writeCentroidToBuffer(e)}updateReplacement(e,t,i){if(t.updateTime===this.replacementUpdateTime)return;this.replacementUpdateTime=t.updateTime;const r=t.getReplacementRegionsForTile(e.toUnwrapped());if(Yp(this.activeReplacements,r))return;if(this.activeReplacements=r,0===this.centroidVertexArray.length)this.createCentroidsBuffer();else for(const o of this.centroidData)o.flags&=1073741823;const n=[];for(const o of this.activeReplacements){if(o.order<i)continue;const t=Math.max(1,Math.pow(2,o.footprintTileId.canonical.z-e.canonical.z));if(o.footprint.buildingIds)for(const e of this.centroidData)e.flags&pf||e.flags&ff||o.min.x>e.max.x||e.min.x>o.max.x||o.min.y>e.max.y||e.min.y>o.max.y||o.footprint.buildingIds.has(e.buildingId)&&(e.flags|=o.clipMask!==nf.None?-1073741824:pf);else for(const i of this.centroidData)if(!(i.flags&pf||i.flags&ff||o.min.x>i.max.x||i.min.x>o.max.x||o.min.y>i.max.y||i.min.y>o.max.y))for(let r=0;r<i.footprintSegLen;r++){const s=this.footprintSegments.get(i.footprintSegIdx+r);if(n.length=0,Nf(this.footprintVertices,s.vertexOffset,s.vertexCount,o.footprintTileId.canonical,e.canonical,n),Qp(o.footprint,n,this.footprintIndices.uint16,s.indexOffset,s.indexCount,-s.vertexOffset,-t)){i.flags|=o.clipMask!==nf.None?-1073741824:pf;break}}}for(const o of this.centroidData)this.writeCentroidToBuffer(o);this.borderDoneWithNeighborZ=[-1,-1,-1,-1]}footprintContainsPoint(e,t,i){let r=!1;for(let n=0;n<i.footprintSegLen;n++){const o=this.footprintSegments.get(i.footprintSegIdx+n);let s=0;for(const i of o.ringIndices){for(let n=s,a=i+s-1;n<i+s;a=n++){const i=this.footprintVertices.int16[2*(n+o.vertexOffset)+0],s=this.footprintVertices.int16[2*(n+o.vertexOffset)+1],l=this.footprintVertices.int16[2*(a+o.vertexOffset)+1];s>t!=l>t&&e<(this.footprintVertices.int16[2*(a+o.vertexOffset)+0]-i)*(t-s)/(l-s)+i&&(r=!r)}s=i}}return r}getHeightAtTileCoord(e,t){let i=Number.NEGATIVE_INFINITY,r=!0;const n=4*(e+Yr)*Yr+(t+Yr);if(Object.hasOwn(this.partLookup,n)){const e=this.partLookup[n];return e?{height:e.height,hidden:!!(e.flags&pf)}:void 0}const o=this.centroidData.buffer,s=this.centroidData.length;for(let a=0;a<s;a++){const s=15*a;if(e>o[s+4]||o[s+2]>e||t>o[s+5]||o[s+3]>t)continue;const l=o[s+13];if(l<=i)continue;const c=this.centroidData.get(a);this.footprintContainsPoint(e,t,c)&&(i=l,this.partLookup[n]=c,r=!!(c.flags&pf))}if(i!==Number.NEGATIVE_INFINITY)return{height:i,hidden:r};this.partLookup[n]=void 0}}function Cf(e,t){const i=e.add(t)._unit();return e.x*i.x+e.y*i.y}function Pf(e,t,i,r){return Df(e,t,i,Cf(t.sub(e)._perp()._unit(),i.sub(t)._perp()._unit()),r)}function Df(e,t,i,r,n){const o=Math.sqrt(1-r*r);return Math.min(e.dist(t)/3,t.dist(i)/3,n*o/r)}function Rf(e,t,i){return e.x<i[0].x&&t.x<i[0].x||e.x>i[1].x&&t.x>i[1].x||e.y<i[0].y&&t.y<i[0].y||e.y>i[1].y&&t.y>i[1].y}function zf(e,t){return e.x<t[0].x||e.x>t[1].x||e.y<t[0].y||e.y>t[1].y}function Lf(e){return e.every(e=>e.x<=0)||e.every(e=>e.x>=Yr)||e.every(e=>e.y<=0)||e.every(e=>e.y>=Yr)}function Ff(e,t,i){if(e.x<0||e.x>=Yr||t.x<0||t.x>=Yr||i.x<0||i.x>=Yr)return!1;const r=i.sub(t),n=r.perp(),o=e.sub(t);return(r.x*o.x+r.y*o.y)/Math.sqrt((r.x*r.x+r.y*r.y)*(o.x*o.x+o.y*o.y))>-.866&&n.x*o.x+n.y*o.y<0}function Of(e,t,i){const r=t?2|e:-3&e;return i?1|r:-2&r}function Bf(){const e=Math.PI/32,t=Math.tan(e),i=Bc;return i*Math.sqrt(1+2*t*t)-i}function kf(e,t,i){const r=1<<i.z,n=$c(i.x/r),o=$c((i.x+1)/r),s=qc(i.y/r),a=qc((i.y+1)/r);return function(e,t,i,r,n=0,o){const s=[];if(!e.length||!i||!r)return s;const a=(e,t)=>{for(const i of e)s.push({polygon:i,bounds:t})},l=Math.ceil(Math.log2(i)),c=Math.ceil(Math.log2(r)),h=l-c,u=[];for(let f=0;f<Math.abs(h);f++)u.push(h>0?0:1);for(let f=0;f<Math.min(l,c);f++)u.push(0),u.push(1);let d=e;if(d=wp(d,t[0].y-n,t[1].y+n,1),d=wp(d,t[0].x-n,t[1].x+n,0),!d.length)return s;const p=[];for(u.length?p.push({polygons:d,bounds:t,depth:0}):a(d,t);p.length;){const e=p.pop(),t=e.depth,i=u[t],r=e.bounds[0],s=e.bounds[1],l=0===i?r.x:r.y,c=0===i?s.x:s.y,h=o?o(i,l,c):.5*(l+c),d=wp(e.polygons,l-n,h+n,i),f=wp(e.polygons,h-n,c+n,i);if(d.length){const e=[r,new Ie(0===i?h:s.x,1===i?h:s.y)];u.length>t+1?p.push({polygons:d,bounds:e,depth:t+1}):a(d,e)}if(f.length){const e=[new Ie(0===i?h:r.x,1===i?h:r.y),s];u.length>t+1?p.push({polygons:f,bounds:e,depth:t+1}):a(f,e)}}return s}(e,t,Math.ceil((o-n)/11.25),Math.ceil((s-a)/11.25),1,(e,t,n)=>{if(0===e)return.5*(t+n);{const e=qc((i.y+t/Yr)/r);return(Gc(.5*(qc((i.y+n/Yr)/r)+e))*r-i.y)*Yr}})}function Nf(e,t,i,r,n,o){const s=Math.pow(2,r.z-n.z);for(let a=0;a<i;a++){let i=e.int16[2*(a+t)+0],l=e.int16[2*(a+t)+1];i=(i+n.x*Yr)*s-r.x*Yr,l=(l+n.y*Yr)*s-r.y*Yr,o.push(new Ie(i,l))}}let Uf,Vf,jf,Gf;as(Mf,"FillExtrusionBucket",{omit:["layers","features"]}),as(bf,"PartData"),as(wf,"PartDataArray"),as(vf,"FootprintSegmentArray"),as(Tf,"BorderCentroidData"),as(Af,"GroundEffect");class Hf extends Ie{constructor(e,t,i){super(e,t),this.z=i}}class $f extends Hf{constructor(e,t,i,r){super(e,t,i),this.w=r}}function qf(e,t,i,r){const n="x"===i?"y":"x",o=(r-e[i])/(t[i]-e[i]);e[n]=Math.round(e[n]+(t[n]-e[n])*o),e[i]=r,Object.hasOwn(e,"z")&&(e.z=yi(e.z,t.z,o)),Object.hasOwn(e,"w")&&(e.w=yi(e.w,t.w,o))}function Zf(e,t,i,r){const n=i,o=r;for(const s of["x","y"]){let i=e,r=t;i[s]>=r[s]&&(i=t,r=e),i[s]<n&&r[s]>n&&qf(i,r,s,n),i[s]<o&&r[s]>o&&qf(r,i,s,o)}}function Wf(e,t,i,r,n,o){const s=[];for(let a=0;a<e.length;a++){const l=e[a];let c;const h=s.length;let u=0;for(let e=0;e<l.length-1;e++){let h=l[e],d=l[e+1],p=0;const f=u;let m,_;o&&(p=Math.hypot(d.x-h.x,d.y-h.y),u+=p,m=h,_=d),h.x<t&&d.x<t||(h.x<t?h=new Ie(t,h.y+(t-h.x)/(d.x-h.x)*(d.y-h.y))._round():d.x<t&&(d=new Ie(t,h.y+(t-h.x)/(d.x-h.x)*(d.y-h.y))._round()),h.y<i&&d.y<i||(h.y<i?h=new Ie(h.x+(i-h.y)/(d.y-h.y)*(d.x-h.x),i)._round():d.y<i&&(d=new Ie(h.x+(i-h.y)/(d.y-h.y)*(d.x-h.x),i)._round()),h.x>=r&&d.x>=r||(h.x>=r?h=new Ie(r,h.y+(r-h.x)/(d.x-h.x)*(d.y-h.y))._round():d.x>=r&&(d=new Ie(r,h.y+(r-h.x)/(d.x-h.x)*(d.y-h.y))._round()),h.y>=n&&d.y>=n||(h.y>=n?h=new Ie(h.x+(n-h.y)/(d.y-h.y)*(d.x-h.x),n)._round():d.y>=n&&(d=new Ie(h.x+(n-h.y)/(d.y-h.y)*(d.x-h.x),n)._round()),c&&h.equals(c.at(-1))||(c=[h],s.push(c),o&&o.push({progress:{min:f+Yf(m,_,h)*p,max:1},parentIndex:a,prevPoint:m,nextPoint:_})),c.push(d),o&&(o.at(-1).progress.max=f+Yf(m,_,d)*p,o.at(-1).nextPoint=_)))))}if(o&&u>0)for(let e=h;e<s.length;e++)o[e].progress.min/=u,o[e].progress.max/=u}return s}function Xf(e,t,i,r,n){if(e.length<2)return void r.push(e);const o=[];for(;t.valid();){const[i,r]=t.get();for(let t=0;t<e.length-1;t++){const n=e[t],s=e[t+1],a=qh(n,s,i,r);if(a){const[e]=a,i=new Ie(yi(n.x,s.x,e),yi(n.y,s.y,e));o.push({t:t+e,distance:0,point:i})}}t.next()}if(0===o.length)return void r.push(e);o.sort((e,t)=>e.t-t.t);let s=0,a=0,l=[];for(r.push(l);s!==e.length;){if(a===o.length){for(;s!==e.length;)0!==l.length&&l.at(-1).equals(e[s])||l.push(e[s]),s++;break}o[a].t<=s?(0!==l.length&&l.at(-1).equals(o[a].point)||l.push(o[a].point),Math.trunc(o[a].t),a++):(0!==l.length&&l.at(-1).equals(e[s])||l.push(e[s]),s++)}}function Yf(e,t,i){return e.x!==t.x?(i.x-e.x)/(t.x-e.x):e.y!==t.y?(i.y-e.y)/(t.y-e.y):0}function Jf(e,t){return e.x*t.x+e.y*t.y}function Kf(e,t){if(1===e.length){let i=0;const r=t[i++];let n;for(;!n||r.equals(n);)if(n=t[i++],!n)return 1/0;for(;i<t.length;i++){const o=t[i],s=e[0],a=n.sub(r),l=o.sub(r),c=s.sub(r),h=Jf(a,a),u=Jf(a,l),d=Jf(l,l),p=Jf(c,a),f=Jf(c,l),m=h*d-u*u,_=(d*p-u*f)/m,g=(h*f-u*p)/m,y=r.z*(1-_-g)+n.z*_+o.z*g;if(isFinite(y))return y}return 1/0}{let e=1/0;for(const i of t)e=Math.min(e,i.z);return e}}function Qf(e,t,i){let r=1/0;Vh(i,t)&&(r=Kf(i,t[0]));for(let n=0;n<t.length;n++){const o=t[n],s=e[n];for(let e=0;e<o.length-1;e++){const t=o[e],n=[t,o[e+1],s[e+1],s[e],t];Nh(i,n)&&(r=Math.min(r,Kf(i,n)))}}return r!==1/0&&r}function em(e,t,i,r,n,o,s,a,l,c,h){return"globe"===e.projection.name?function(e,t,i,r,n,o,s,a,l,c,h){const u=[],d=[],p=e.projection.upVectorScale(h,e.center.lat,e.worldSize).metersToTile,f=[0,0,0,1],m=[0,0,0,1],_=(e,t,i,r)=>{e[0]=t,e[1]=i,e[2]=r,e[3]=1},g=Bf();i>0&&(i+=g),r+=g;for(const y of t){const t=[],g=[];for(const u of y){const d=u.x+n.x,y=u.y+n.y,x=e.projection.projectTilePoint(d,y,h),v=e.projection.upVector(h,u.x,u.y);let b=i,w=r;if(s){const e=tm(d,y,i,r,s,a,l,c);b+=e.base,w+=e.top}0!==i?_(f,x.x+v[0]*p*b,x.y+v[1]*p*b,x.z+v[2]*p*b):_(f,x.x,x.y,x.z),_(m,x.x+v[0]*p*w,x.y+v[1]*p*w,x.z+v[2]*p*w),H(f,f,o),H(m,m,o),t.push(new Hf(f[0],f[1],f[2])),g.push(new Hf(m[0],m[1],m[2]))}u.push(t),d.push(g)}return[u,d]}(e,t,i,r,n,o,s,a,l,c,h):s?function(e,t,i,r,n,o,s,a,l){const c=[],h=[],u=[0,0,0,1];for(const d of e){const e=[],p=[];for(const c of d){const h=c.x+r.x,d=c.y+r.y,f=tm(h,d,t,i,o,s,a,l);u[0]=h,u[1]=d,u[2]=f.base,u[3]=1,te(u,u,n),u[3]=Math.max(u[3],1e-5);const m=new Hf(u[0]/u[3],u[1]/u[3],u[2]/u[3]);u[0]=h,u[1]=d,u[2]=f.top,u[3]=1,te(u,u,n),u[3]=Math.max(u[3],1e-5);const _=new Hf(u[0]/u[3],u[1]/u[3],u[2]/u[3]);e.push(m),p.push(_)}c.push(e),h.push(p)}return[c,h]}(t,i,r,n,o,s,a,l,c):function(e,t,i,r,n){const o=[],s=[],a=n[8]*t,l=n[9]*t,c=n[10]*t,h=n[11]*t,u=n[8]*i,d=n[9]*i,p=n[10]*i,f=n[11]*i;for(const m of e){const e=[],t=[];for(const i of m){const o=i.x+r.x,s=i.y+r.y,m=n[0]*o+n[4]*s+n[12],_=n[1]*o+n[5]*s+n[13],g=n[2]*o+n[6]*s+n[14],y=n[3]*o+n[7]*s+n[15],x=m+a,v=_+l,b=g+c,w=Math.max(y+h,1e-5),T=m+u,S=_+d,I=g+p,E=Math.max(y+f,1e-5);e.push(new Hf(x/w,v/w,b/w)),t.push(new Hf(T/E,S/E,I/E))}o.push(e),s.push(t)}return[o,s]}(t,i,r,n,o)}function tm(e,t,i,r,n,o,s,a){const l=s*n.getElevationAt(e,t,!0,!0),c=0!==o[0],h=c?0===o[1]?s*(o[0]/7-450):s*function(e,t,i){const r=Math.floor(t[0]/8),n=Math.floor(t[1]/8),o=10*(t[0]-8*r),s=10*(t[1]-8*n),a=e.getElevationAt(r,n,!0,!0),l=e.getMeterToDEM(i),c=Math.floor(.5*(o*l-1)),h=Math.floor(.5*(s*l-1)),u=e.tileCoordToPixel(r,n),d=2*c+1,p=2*h+1,f=function(e,t,i,r,n){return[e.getElevationAtPixel(t,i,!0),e.getElevationAtPixel(t+n,i,!0),e.getElevationAtPixel(t,i+n,!0),e.getElevationAtPixel(t+r,i+n,!0)]}(e,u.x-c,u.y-h,d,p),m=Math.abs(f[0]-f[1]),_=Math.abs(f[2]-f[3]),g=Math.abs(f[0]-f[2])+Math.abs(f[1]-f[3]),y=Math.min(.25,.5*l*(m+_)/d),x=Math.min(.25,.5*l*g/p);return a+Math.max(y*o,x*s)}(n,o,a):l;return{base:l+(0===i?-1:i),top:c?Math.max(h+r,l+i+2):l+r}}let im=null,rm=null,nm=null,om=null;const sm=5120,am=5121,lm=5122,cm=5123,hm=5125,um=5126,dm={[sm]:Int8Array,[am]:Uint8Array,[lm]:Int16Array,[cm]:Uint16Array,[hm]:Uint32Array,[um]:Float32Array},pm={[sm]:"DT_INT8",[am]:"DT_UINT8",[lm]:"DT_INT16",[cm]:"DT_UINT16",[hm]:"DT_UINT32",[um]:"DT_FLOAT32"},fm={SCALAR:1,VEC2:2,VEC3:3,VEC4:4,MAT2:4,MAT3:9,MAT4:16};function mm(e,t,i){const r=i.json.bufferViews.length,n=i.buffers.length;t.bufferView=r,i.json.bufferViews[r]={buffer:n,byteLength:e.byteLength},i.buffers[n]=e}const _m="KHR_draco_mesh_compression";function gm(e,t){const i=e.extensions&&e.extensions[_m];if(!i)return;const r=new im.Decoder,n=Sm(t,i.bufferView),o=new im.Mesh;if(!r.DecodeArrayToMesh(n,n.byteLength,o))throw new Error("Failed to decode Draco mesh");const s=t.json.accessors[e.indices],a=dm[s.componentType],l=s.count*a.BYTES_PER_ELEMENT,c=im._malloc(l);a===Uint16Array?r.GetTrianglesUInt16Array(o,l,c):r.GetTrianglesUInt32Array(o,l,c),mm(im.memory.buffer.slice(c,c+l),s,t),im._free(c);for(const h of Object.keys(i.attributes)){const n=r.GetAttributeByUniqueId(o,i.attributes[h]),s=t.json.accessors[e.attributes[h]],a=pm[s.componentType],l=s.count*fm[s.type]*dm[s.componentType].BYTES_PER_ELEMENT,c=im._malloc(l);r.GetAttributeDataArrayForAllPoints(o,n,im[a],l,c),mm(im.memory.buffer.slice(c,c+l),s,t),im._free(c)}r.destroy(),o.destroy(),delete e.extensions[_m]}const ym="EXT_meshopt_compression";function xm(e,t){if(!e.extensions||!e.extensions[ym])return;const i=e.extensions[ym],r=new Uint8Array(t.buffers[i.buffer],i.byteOffset||0,i.byteLength||0),n=new Uint8Array(i.count*i.byteStride);nm.decodeGltfBuffer(n,i.count,i.byteStride,r,i.mode,i.filter),e.buffer=t.buffers.length,e.byteOffset=0,t.buffers[e.buffer]=n.buffer,delete e.extensions[ym]}const vm=1179937895,bm=new TextDecoder("utf8");function wm(e,t){return new URL(e,t).href}async function Tm(e,t,i,r,n){const o=await(await fetch(wm(e.uri,r),{signal:n})).arrayBuffer();t.buffers[i]=o}function Sm(e,t){const i=e.json.bufferViews[t];return new Uint8Array(e.buffers[i.buffer],i.byteOffset||0,i.byteLength)}async function Im(e,t,i,r,n){if(e.uri){const o=wm(e.uri,r),s=await(await fetch(o,{signal:n})).blob(),a=await createImageBitmap(s);t.images[i]=a}else if(void 0!==e.bufferView){const r=Sm(t,e.bufferView),n=new Blob([r],{type:e.mimeType}),o=await createImageBitmap(n);t.images[i]=o}}async function Em(e,t=0,i,r){const n={json:null,images:[],buffers:[]};if(new Uint32Array(e,t,1)[0]===vm){const i=new Uint32Array(e,t);let r=2;const o=(i[r++]>>2)-3,s=i[r++]>>2;if(r++,n.json=JSON.parse(bm.decode(i.subarray(r,r+s))),r+=s,r<o){const o=i[r++];r++;const s=t+(r<<2);n.buffers[0]=e.slice(s,s+o)}}else n.json=JSON.parse(bm.decode(new Uint8Array(e,t)));const{buffers:o,images:s,meshes:a,extensionsUsed:l,bufferViews:c}=n.json;if(o){const e=[];for(let t=0;t<o.length;t++){const s=o[t];s.uri?e.push(Tm(s,n,t,i,r)):n.buffers[t]||(n.buffers[t]=null)}await Promise.all(e)}if(r&&r.aborted)throw new DOMException("Aborted","AbortError");const h=[],u=l&&l.includes(_m),d=l&&l.includes(ym);if(u&&h.push(function(){if(!im)return rm??=function(e){let t,i=null;function r(){t=new Uint8Array(i.buffer)}function n(){throw new Error("Unexpected Draco error.")}return WebAssembly.instantiateStreaming(e,{a:{a:n,d:function(e,i,r){return t.copyWithin(e,i,i+r)},c:function(e){const n=t.length,o=Math.max(e>>>0,Math.ceil(1.2*n)),s=Math.ceil((o-n)/65536);try{return i.grow(s),r(),!0}catch(e){return!1}},b:n}}).then(e=>{const{Rb:n,Qb:o,P:s,T:a,X:l,Ja:c,La:h,Qa:u,Va:d,Wa:p,eb:f,jb:m,f:_,e:g,yb:y,zb:x,Ab:v,Bb:b,Db:w,Gb:T}=e.instance.exports;i=g;const S=(()=>{let e=0,i=0,r=0,s=0;return a=>{r&&(n(s),n(e),i+=r,r=e=0),e||(i+=128,e=o(i));const l=a.length+7&-8;let c=e;l>=i&&(r=l,c=s=o(l));for(let e=0;e<a.length;e++)t[c+e]=a[e];return c}})();return r(),_(),{memory:g,_free:n,_malloc:o,Mesh:class{constructor(){this.ptr=s()}destroy(){a(this.ptr)}},Decoder:class{constructor(){this.ptr=c()}destroy(){m(this.ptr)}DecodeArrayToMesh(e,t,i){const r=S(e);return!!l(h(this.ptr,r,t,i.ptr))}GetAttributeByUniqueId(e,t){return{ptr:u(this.ptr,e.ptr,t)}}GetTrianglesUInt16Array(e,t,i){d(this.ptr,e.ptr,t,i)}GetTrianglesUInt32Array(e,t,i){p(this.ptr,e.ptr,t,i)}GetAttributeDataArrayForAllPoints(e,t,i,r,n){f(this.ptr,e.ptr,t.ptr,i,r,n)}},DT_INT8:y(),DT_UINT8:x(),DT_INT16:v(),DT_UINT16:b(),DT_UINT32:w(),DT_FLOAT32:T()}})}(fetch(pt())).then(e=>{im=e,rm=null}),rm}()),d&&h.push(function(){var e;if(!nm)return om??=(e=fetch(ft()),WebAssembly.instantiateStreaming(e,{}).then(e=>{const{sbrk:t,memory:i,meshopt_decodeVertexBuffer:r,meshopt_decodeIndexBuffer:n,meshopt_decodeIndexSequence:o,meshopt_decodeFilterOct:s,meshopt_decodeFilterQuat:a,meshopt_decodeFilterExp:l}=e.instance.exports,c={ATTRIBUTES:r,TRIANGLES:n,INDICES:o},h={OCTAHEDRAL:s,QUATERNION:a,EXPONENTIAL:l};return e.instance.exports.__wasm_call_ctors(),{decodeGltfBuffer(e,r,n,o,s,a){const l=r+3&-4,u=t(l*n),d=t(o.length),p=new Uint8Array(i.buffer);p.set(o,d);const f=c[s](u,r,n,d,o.length);if(0===f&&h[a]&&h[a](u,l,n),e.set(p.subarray(u,u+r*n)),t(u-t(0)),0!==f)throw new Error(`Malformed buffer data: ${f}`)}}})).then(e=>{nm=e,om=null}),om}()),s)for(let p=0;p<s.length;p++)h.push(Im(s[p],n,p,i,r));if(h.length&&await Promise.all(h),r&&r.aborted)throw new DOMException("Aborted","AbortError");if(u&&a)for(const{primitives:p}of a)for(const e of p)gm(e,n);if(d&&a&&c)for(const p of c)xm(p,n);return n}async function Am(e,t){return Em(await async function(e,t){if(t&&t.aborted)throw new DOMException("Aborted","AbortError");return new Promise((i,r)=>{const n=Xt(e,(e,t)=>{e?r(e):i(t)});t&&t.addEventListener("abort",()=>{n.cancel(),r(new DOMException("Aborted","AbortError"))},{once:!0})})}({url:e,type:"arrayBuffer"},t),0,e,t)}function Mm(e){switch(e){case WebGL2RenderingContext.RGBA8:case WebGL2RenderingContext.RGBA16F:return WebGL2RenderingContext.RGBA;case WebGL2RenderingContext.DEPTH_COMPONENT16:return WebGL2RenderingContext.DEPTH_COMPONENT;case WebGL2RenderingContext.DEPTH24_STENCIL8:return WebGL2RenderingContext.DEPTH_STENCIL;case WebGL2RenderingContext.R8:case WebGL2RenderingContext.R32F:return WebGL2RenderingContext.RED}}function Cm(e){switch(e){case WebGL2RenderingContext.RGBA8:return WebGL2RenderingContext.UNSIGNED_BYTE;case WebGL2RenderingContext.RGBA16F:return WebGL2RenderingContext.HALF_FLOAT;case WebGL2RenderingContext.DEPTH_COMPONENT16:return WebGL2RenderingContext.UNSIGNED_SHORT;case WebGL2RenderingContext.DEPTH24_STENCIL8:return WebGL2RenderingContext.UNSIGNED_INT_24_8;case WebGL2RenderingContext.R8:return WebGL2RenderingContext.UNSIGNED_BYTE;case WebGL2RenderingContext.R32F:return WebGL2RenderingContext.FLOAT}}class Pm{constructor(e,t,i,r){this.context=e,this.format=i,this.useMipmap=r&&r.useMipmap,this.texture=e.gl.createTexture(),this.update(t,{premultiply:r&&r.premultiply})}update(e,t){const i=e&&e instanceof HTMLVideoElement&&0===e.width?e.videoWidth:e.width,r=e&&e instanceof HTMLVideoElement&&0===e.height?e.videoHeight:e.height,{context:n}=this,{gl:o}=n,{x:s,y:a}=t&&t.position?t.position:{x:0,y:0},l=s+i,c=a+r;this.size&&(this.size[0]!==l||this.size[1]!==c)&&(!t||void 0===t.recreateWhenResize||t.recreateWhenResize)&&(o.bindTexture(o.TEXTURE_2D,null),o.deleteTexture(this.texture),this.texture=o.createTexture(),this.size=null),o.bindTexture(o.TEXTURE_2D,this.texture),n.pixelStoreUnpackFlipY.set(!1),n.pixelStoreUnpack.set(1),n.pixelStoreUnpackPremultiplyAlpha.set(this.format===o.RGBA8&&(!t||!1!==t.premultiply));const h=e instanceof HTMLImageElement||e instanceof HTMLCanvasElement||e instanceof HTMLVideoElement||e instanceof ImageData||ImageBitmap&&e instanceof ImageBitmap;if(!this.size&&l>0&&c>0){const e=this.useMipmap?Math.floor(Math.log2(Math.max(l,c)))+1:1;o.texStorage2D(o.TEXTURE_2D,e,this.format,l,c),this.size=[l,c]}this.size&&(h?o.texSubImage2D(o.TEXTURE_2D,0,s,a,Mm(this.format),Cm(this.format),e):"data"in e&&e.data&&o.texSubImage2D(o.TEXTURE_2D,0,s,a,i,r,Mm(this.format),Cm(this.format),e.data)),this.useMipmap&&o.generateMipmap(o.TEXTURE_2D)}bind(e,t,i=!1){const{context:r}=this,{gl:n}=r;n.bindTexture(n.TEXTURE_2D,this.texture),e!==this.minFilter&&(n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MAG_FILTER,e),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_MIN_FILTER,this.useMipmap&&!i?e===n.NEAREST?n.NEAREST_MIPMAP_NEAREST:n.LINEAR_MIPMAP_LINEAR:e),this.minFilter=e),t!==this.wrapS&&(n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_S,t),n.texParameteri(n.TEXTURE_2D,n.TEXTURE_WRAP_T,t),this.wrapS=t)}bindExtraParam(e,t,i,r,n){const{context:o}=this,{gl:s}=o;s.bindTexture(s.TEXTURE_2D,this.texture),t!==this.magFilter&&(s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MAG_FILTER,t),this.magFilter=t),e!==this.minFilter&&(s.texParameteri(s.TEXTURE_2D,s.TEXTURE_MIN_FILTER,this.useMipmap?e===s.NEAREST?s.NEAREST_MIPMAP_NEAREST:s.LINEAR_MIPMAP_LINEAR:e),this.minFilter=e),i!==this.wrapS&&(s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_S,i),this.wrapS=i),r!==this.wrapT&&(s.texParameteri(s.TEXTURE_2D,s.TEXTURE_WRAP_T,r),this.wrapT=r),n!==this.compareMode&&(n?(s.texParameteri(s.TEXTURE_2D,s.TEXTURE_COMPARE_MODE,s.COMPARE_REF_TO_TEXTURE),s.texParameteri(s.TEXTURE_2D,s.TEXTURE_COMPARE_FUNC,n)):s.texParameteri(s.TEXTURE_2D,s.TEXTURE_COMPARE_MODE,s.NONE),this.compareMode=n)}destroy(){const{gl:e}=this.context;e.deleteTexture(this.texture),this.texture=null}}class Dm{constructor(e,t){this.context=e,this.texture=t}bind(e,t){const{context:i}=this,{gl:r}=i;r.bindTexture(r.TEXTURE_2D,this.texture),e!==this.minFilter&&(r.texParameteri(r.TEXTURE_2D,r.TEXTURE_MAG_FILTER,e),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_MIN_FILTER,e),this.minFilter=e),t!==this.wrapS&&(r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_S,t),r.texParameteri(r.TEXTURE_2D,r.TEXTURE_WRAP_T,t),this.wrapS=t)}}const Rm=Ya([{name:"a_pos_3f",components:3,type:"Float32"}]),zm=Ya([{name:"a_color_3f",components:3,type:"Float32"}]),Lm=Ya([{name:"a_color_4f",components:4,type:"Float32"}]),Fm=Ya([{name:"a_uv_2f",components:2,type:"Float32"}]),Om=Ya([{name:"a_normal_3f",components:3,type:"Float32"}]),Bm=Ya([{name:"a_normal_matrix0",components:4,type:"Float32"},{name:"a_normal_matrix1",components:4,type:"Float32"},{name:"a_normal_matrix2",components:4,type:"Float32"},{name:"a_normal_matrix3",components:4,type:"Float32"}]),km=Ya([{name:"a_pbr",components:4,type:"Uint16"},{name:"a_heightBasedEmissiveStrength",components:3,type:"Float32"}]);function Nm(e,t){const i=Vm(e.projection,e.zoom,e.width,e.height),r=function(e,t,i,r,n){const o=new Nc(i.lng-180*jm,i.lat),s=new Nc(i.lng+180*jm,i.lat),a=e.project(o.lng,o.lat),l=e.project(s.lng,s.lat),c=-Math.atan2(l.y-a.y,l.x-a.x),u=Qc.fromLngLat(i);u.y=ke(u.y,-1+jm,1-jm);const p=u.toLngLat(),m=e.project(p.lng,p.lat),_=Qc.fromLngLat(p);_.x+=jm;const y=_.toLngLat(),x=e.project(y.lng,y.lat),v=Hm(x.x-m.x,x.y-m.y,c),b=Qc.fromLngLat(p);b.y+=jm;const w=b.toLngLat(),T=e.project(w.lng,w.lat),S=Hm(T.x-m.x,T.y-m.y,c),I=Math.abs(v.x)/Math.abs(S.y),E=h([]);g(E,E,-c*(1-(n?0:r)));const A=h([]);return f(A,A,[1,1-(1-I)*r,1]),A[4]=-S.x/S.y*r,g(A,A,c),d(A,E,A),A}(e.projection,0,e.center,i,t),n=Um(e);return f(r,r,[n,n,1]),r}function Um(e){const t=e.projection,i=Vm(e.projection,e.zoom,e.width,e.height),r=Gm(t,e.center),n=Gm(t,Nc.convert(t.center));return Math.pow(2,r*i+(1-i)*n)}function Vm(e,t,i,r,n=1/0){const o=e.range;if(!o)return 0;const s=Math.log2(Math.min(n,Math.max(i,r))/1024);return Ne(o[0]+s,o[1]+s,t)}const jm=1/4e4;function Gm(e,t){const i=ke(t.lat,-85.051129,Wc),r=new Nc(t.lng-180*jm,i),n=new Nc(t.lng+180*jm,i),o=e.project(r.lng,i),s=e.project(n.lng,i),a=Qc.fromLngLat(r),l=Qc.fromLngLat(n),c=s.x-o.x,h=s.y-o.y,u=l.x-a.x,d=l.y-a.y,p=Math.sqrt((u*u+d*d)/(c*c+h*h));return Math.log2(p)}function Hm(e,t,i){const r=Math.cos(i),n=Math.sin(i);return{x:e*r-t*n,y:e*n+t*r}}const $m=new Float64Array([1,0,0,0,0,0,1,0,0,1,0,0,0,0,0,1]);function qm(e,t,i){h(e),g(e,e,Re(t[2])),m(e,e,Re(t[0])),_(e,e,Re(t[1])),f(e,e,i),d(e,e,$m)}function Zm(e,t,i,r,n,o,s,a){const l=[i[0]-t[0],i[1]-t[1],0],c=[r[0]-t[0],r[1]-t[1],0];if(E(l)<1e-12||E(c)<1e-12)return re(e);const h=j([],l,c);U(h,h),P(c,r,t),l[2]=(o-n)*a,c[2]=(s-n)*a;const u=l;return j(u,l,c),U(u,u),he(e,h,u)}function Wm(e,t,i=!1){const r=Fu(t.zoom),n=function(e,t,i){const r=t.worldSize,n=[e[12],e[13],e[14]],o=qc(n[1]/r),s=$c(n[0]/r),a=h([]),l=Hc(1,o)*r,c=Hc(1,0)*r*Yc(o,t.zoom),u=1/Ru(r);let m=c*u;if(i){const e=Vm(t.projection,t.zoom,t.width,t.height,1024);m=u*t.projection.pixelSpaceConversion(t.center.lat,r,e)}const _=Oc(o,s);C(_,_,L([],U([],_),l*m*n[2]));const g=function(e){const t=[e[0],e[1],e[2]];let i=[0,1,0];const r=j([],i,t);return j(i,t,r),0===k(i)&&(i=[0,1,0],j(r,t,i)),U(r,r),U(i,i),U(t,t),[r[0],r[1],r[2],0,i[0],i[1],i[2],0,t[0],t[1],t[2],0,e[0],e[1],e[2],1]}(_);f(a,a,[m,m,m*l]),p(a,a,[-n[0],-n[1],-n[2]]);const y=d([],t.globeMatrix,g);return d(y,y,a),d(y,y,e),y}(e,t,i);return r>0?function(e,t,i){const r=(e,t,i)=>{const r=E(e),n=E(t),o=bu(e,t,i);return L(o,o,1/E(o)*yi(r,n,i))},n=r([e[0],e[1],e[2]],[t[0],t[1],t[2]],i),o=r([e[4],e[5],e[6]],[t[4],t[5],t[6]],i),s=r([e[8],e[9],e[10]],[t[8],t[9],t[10]],i),a=bu([e[12],e[13],e[14]],[t[12],t[13],t[14]],i);return[n[0],n[1],n[2],0,o[0],o[1],o[2],0,s[0],s[1],s[2],0,a[0],a[1],a[2],1]}(n,function(e,t){const i=t.worldSize,r=Hc(1,0)*i*Yc(t.center.lat,t.zoom)/Ru(i),n=Hc(1,t.center.lat)*i,o=h([]);_(o,o,Re(t.center.lng)),m(o,o,Re(t.center.lat)),p(o,o,[0,0,Pc]),f(o,o,[r,r,r*n]);const s=t.point;return p(o,o,[-s.x,-s.y,0]),d(o,o,e),d(o,t.globeMatrix,o)}(e,t),r):n}function Xm(e,t,i,r){const n=Rh.projectAabbCorners(r,i);let o=Number.MAX_VALUE;for(let s=0;s<n.length;++s){const e=n[s];e[0]=(.5*e[0]+.5)*t.width,e[1]=(.5-.5*e[1])*t.height,e[2]<o&&(o=e[2])}if(Nh(e,function(e){const t=[];let i=0;for(let s=1;s<e.length;s++)(e[s][0]<e[i][0]||e[s][0]===e[i][0]&&e[s][1]<e[i][1])&&(i=s);let r,n=i;const o=new Uint8Array(e.length);do{if(o[n])break;t.push(new Ie(e[n][0],e[n][1])),o[n]=1,r=(n+1)%e.length;for(let t=0;t<e.length;t++){if(e[t][0]===e[r][0]&&e[t][1]===e[r][1]||e[t][0]===e[n][0]&&e[t][1]===e[n][1])continue;const i=[e[t][0]-e[n][0],e[t][1]-e[n][1]],o=[e[r][0]-e[n][0],e[r][1]-e[n][1]],s=i[0]*o[1]-i[1]*o[0];(s>0||0===s&&i[0]*o[0]+i[1]*o[1]>=0&&i[0]*i[0]+i[1]*i[1]>o[0]*o[0]+o[1]*o[1])&&(r=t)}n=r}while(n!==i);return t.length>0&&t.push(t[0]),t}(n)))return o}const Ym=64,Jm={CoordinateSpaceTile:1,HasMapboxMeshFeatures:4,HasMeshoptCompression:8};function Km(e,t,i,r,n,o,s,a,l,c=!1){const u=i.zoom,m=i.project(r),_=Yc(r.lat,u),g=1/_;h(e),p(e,e,[m.x+s[0]*g,m.y+s[1]*g,s[2]]);let y=1,x=1;const v=i.worldSize;if(c){if("mercator"===i.projection.name){let e=0;i.elevation&&(e=i.elevation.getAtPointOrZero(new Qc(m.x/v,m.y/v),0));const t=te([],[m.x,m.y,e,1],i.projMatrix)[3]/i.cameraToCenterDistance;y=t,x=t*Yc(i.center.lat,u)}else if("globe"===i.projection.name){const t=Wm(e,i),n=[0,0,0,1];te(n,n,d([],i.projMatrix,t));const o=n[3]/i.cameraToCenterDistance,s=Fu(u),a=i.projection.pixelsPerMeter(r.lat,v)*Yc(r.lat,u),l=i.projection.pixelsPerMeter(i.center.lat,v)*Yc(i.center.lat,u);y=o/yi(a,Xc(i.center.lat),s),x=o*_/a,y*=l,x*=l}}else y=g;f(e,e,[y,y,x]);const b=[...e],T=t.orientation,S=[];if(qm(S,[T[0]+(n?n[0]:0),T[1]+(n?n[1]:0),T[2]+(n?n[2]:0)],o),d(e,b,S),a&&i.elevation){let n=0;const o=[];l&&i.elevation?(n=function(e,t,i,r,n){const o=t.elevation;if(!o)return 0;const s=Rh.projectAabbCorners(i,r),a=Hc(1,n.lat)*t.worldSize,l=function(e,t){const i=[0,0,1],r=[{corners:[0,1,3,2],dotProductWithUp:0},{corners:[1,5,2,6],dotProductWithUp:0},{corners:[0,4,1,5],dotProductWithUp:0},{corners:[2,6,3,7],dotProductWithUp:0},{corners:[4,7,5,6],dotProductWithUp:0},{corners:[0,3,4,7],dotProductWithUp:0}];for(const n of r){const r=e[n.corners[0]],o=e[n.corners[1]],s=e[n.corners[2]],a=[o[0]-r[0],o[1]-r[1],t*(o[2]-r[2])],l=j(a,a,[s[0]-r[0],s[1]-r[1],t*(s[2]-r[2])]);U(l,l),n.dotProductWithUp=V(l,i)}return r.sort((e,t)=>e.dotProductWithUp-t.dotProductWithUp),r[0].corners}(s,a),c=s[l[0]],h=s[l[1]],u=s[l[2]],d=s[l[3]],p=o.getAtPointOrZero(new Qc(c[0]/t.worldSize,c[1]/t.worldSize),0),f=o.getAtPointOrZero(new Qc(h[0]/t.worldSize,h[1]/t.worldSize),0),m=o.getAtPointOrZero(new Qc(u[0]/t.worldSize,u[1]/t.worldSize),0),_=o.getAtPointOrZero(new Qc(d[0]/t.worldSize,d[1]/t.worldSize),0),g=(p+_)/2,y=(f+m)/2;return g>y?f<m?Zm(e,h,d,c,f,_,p,a):Zm(e,u,c,d,m,p,_,a):p<_?Zm(e,c,h,u,p,f,m,a):Zm(e,d,u,h,_,m,f,a),Math.max(g,y)}(o,i,t.aabb,e,r),d(e,b,d([],w([],o),S))):n=i.elevation.getAtPointOrZero(new Qc(m.x/v,m.y/v),0),0!==n&&(e[14]+=n)}}class Qm{constructor(e,t,i,r,n){this.materialOverrides=/* @__PURE__ */new Map,this.nodeOverrides=/* @__PURE__ */new Map,this.materialOverrideNames=[],this.nodeOverrideNames=[],this.featureProperties={},this.id=e,this.uri=t,this.position=null!=i?new Nc(i[0],i[1]):new Nc(0,0),this.orientation=null!=r?r:[0,0,0],this.nodes=n,this.uploaded=!1,this.aabb=new Rh([1/0,1/0,1/0],[-1/0,-1/0,-1/0]),this.matrix=[]}_applyTransformations(e,t){d(e.globalMatrix,t,e.localMatrix);const i=this.nodeOverrides.get(e.name);if(void 0!==i){const t=[];n=i.orientation,h(r=t),_(r,r,Re(n[1])),g(r,r,Re(n[2])),m(r,r,Re(n[0])),d(e.globalMatrix,e.globalMatrix,t)}var r,n;if(e.meshes)for(const o of e.meshes){const t=Rh.applyTransformFast(o.aabb,e.globalMatrix);this.aabb.encapsulate(t)}if(e.children)for(const o of e.children)this._applyTransformations(o,e.globalMatrix)}computeBoundsAndApplyParent(){const e=h([]);this.aabb=new Rh([1/0,1/0,1/0],[-1/0,-1/0,-1/0]);for(const t of this.nodes)this._applyTransformations(t,e)}computeModelMatrix(e,t,i,r,n,o,s=!1){Km(this.matrix,this,e.transform,this.position,t,i,r,n,o,s)}upload(e){if(!this.uploaded){for(const t of this.nodes)i_(t,e);for(const e of this.nodes)n_(e);this.uploaded=!0}}destroy(){for(const e of this.nodes)s_(e)}}function e_(e,t,i=!1){e.uploaded||(e.gfxTexture=new Pm(t,e.image,i?t.gl.R8:t.gl.RGBA8,{useMipmap:e.sampler.minFilter>=t.gl.NEAREST_MIPMAP_NEAREST}),e.uploaded=!0,e.image=null)}function t_(e,t,i){e.indexBuffer=t.createIndexBuffer(e.indexArray,!1,!0),e.vertexBuffer=t.createVertexBuffer(e.vertexArray,Rm.members,!1,!0),e.normalArray&&(e.normalBuffer=t.createVertexBuffer(e.normalArray,Om.members,!1,!0)),e.texcoordArray&&(e.texcoordBuffer=t.createVertexBuffer(e.texcoordArray,Fm.members,!1,!0)),e.colorArray&&(e.colorBuffer=t.createVertexBuffer(e.colorArray,(12===e.colorArray.bytesPerElement?zm:Lm).members,!1,!0)),e.featureArray&&(e.pbrBuffer=t.createVertexBuffer(e.featureArray,km.members,!0)),e.segments=Jl.simpleSegment(0,0,e.vertexArray.length,e.indexArray.length);const r=e.material;r.pbrMetallicRoughness.baseColorTexture&&e_(r.pbrMetallicRoughness.baseColorTexture,t),r.pbrMetallicRoughness.metallicRoughnessTexture&&e_(r.pbrMetallicRoughness.metallicRoughnessTexture,t),r.normalTexture&&e_(r.normalTexture,t),r.occlusionTexture&&e_(r.occlusionTexture,t,i),r.emissionTexture&&e_(r.emissionTexture,t)}function i_(e,t,i){if(e.meshes)for(const r of e.meshes)t_(r,t,i);if(e.lodMeshes)for(const r of e.lodMeshes)t_(r,t,i);if(e.children)for(const r of e.children)i_(r,t,i)}function r_(e){e.indexArray.destroy(),e.vertexArray.destroy(),e.colorArray&&e.colorArray.destroy(),e.normalArray&&e.normalArray.destroy(),e.texcoordArray&&e.texcoordArray.destroy(),e.featureArray&&e.featureArray.destroy()}function n_(e){if(e.meshes)for(const t of e.meshes)r_(t);if(e.lodMeshes)for(const t of e.lodMeshes)r_(t);if(e.children)for(const t of e.children)n_(t)}function o_(e){var t;e.vertexBuffer&&(e.vertexBuffer.destroy(),e.indexBuffer.destroy(),e.normalBuffer&&e.normalBuffer.destroy(),e.texcoordBuffer&&e.texcoordBuffer.destroy(),e.colorBuffer&&e.colorBuffer.destroy(),e.pbrBuffer&&e.pbrBuffer.destroy(),e.segments.destroy(),e.material&&((t=e.material).pbrMetallicRoughness.baseColorTexture&&t.pbrMetallicRoughness.baseColorTexture.gfxTexture&&t.pbrMetallicRoughness.baseColorTexture.gfxTexture.destroy(),t.pbrMetallicRoughness.metallicRoughnessTexture&&t.pbrMetallicRoughness.metallicRoughnessTexture.gfxTexture&&t.pbrMetallicRoughness.metallicRoughnessTexture.gfxTexture.destroy(),t.normalTexture&&t.normalTexture.gfxTexture&&t.normalTexture.gfxTexture.destroy(),t.emissionTexture&&t.emissionTexture.gfxTexture&&t.emissionTexture.gfxTexture.destroy(),t.occlusionTexture&&t.occlusionTexture.gfxTexture&&t.occlusionTexture.gfxTexture.destroy()))}function s_(e){if(e.meshes)for(const t of e.meshes)o_(t);if(e.lodMeshes)for(const t of e.lodMeshes)o_(t);if(e.footprintDebugMesh&&(e.footprintDebugMesh.vertexBuffer.destroy(),e.footprintDebugMesh.indexBuffer.destroy(),e.footprintDebugMesh.segments.destroy()),e.children)for(const t of e.children)s_(t)}function a_(e,t,i,r){return e[0]<=r[0]&&t[0]>=i[0]&&e[1]<=r[1]&&t[1]>=i[1]&&e[2]<=r[2]&&t[2]>=i[2]}function l_(e,t,i,r,n,o,s,a,l,c,h){const u=.5*(c[0]+h[0]),d=.5*(c[1]+h[1]),p=.5*(c[2]+h[2]),f=.5*(h[0]-c[0]),m=.5*(h[1]-c[1]),_=.5*(h[2]-c[2]),g=e-u,y=t-d,x=i-p,v=r-u,b=n-d,w=o-p,T=s-u,S=a-d,I=l-p,E=v-g,A=b-y,M=w-x,C=T-v,P=S-b,D=I-w,R=g-T,z=y-S,L=x-I;let F,O,B,k,N,U;if(F=x*A-y*M,O=w*A-b*M,B=I*A-S*M,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(M)*m+Math.abs(A)*_,k>U||N<-U)return!1;if(F=x*P-y*D,O=w*P-b*D,B=I*P-S*D,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(D)*m+Math.abs(P)*_,k>U||N<-U)return!1;if(F=x*z-y*L,O=w*z-b*L,B=I*z-S*L,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(L)*m+Math.abs(z)*_,k>U||N<-U)return!1;if(F=g*M-x*E,O=v*M-w*E,B=T*M-I*E,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(M)*f+Math.abs(E)*_,k>U||N<-U)return!1;if(F=g*D-x*C,O=v*D-w*C,B=T*D-I*C,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(D)*f+Math.abs(C)*_,k>U||N<-U)return!1;if(F=g*L-x*R,O=v*L-w*R,B=T*L-I*R,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(L)*f+Math.abs(R)*_,k>U||N<-U)return!1;if(F=y*E-g*A,O=b*E-v*A,B=S*E-T*A,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(A)*f+Math.abs(E)*m,k>U||N<-U)return!1;if(F=y*C-g*P,O=b*C-v*P,B=S*C-T*P,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(P)*f+Math.abs(C)*m,k>U||N<-U)return!1;if(F=y*R-g*z,O=b*R-v*z,B=S*R-T*z,k=Math.min(F,O,B),N=Math.max(F,O,B),U=Math.abs(z)*f+Math.abs(R)*m,k>U||N<-U)return!1;if(k=Math.min(g,v,T),N=Math.max(g,v,T),k>f||N<-f)return!1;if(k=Math.min(y,b,S),N=Math.max(y,b,S),k>m||N<-m)return!1;if(k=Math.min(x,w,I),N=Math.max(x,w,I),k>_||N<-_)return!1;const V=A*D-M*P,j=M*C-E*D,G=E*P-A*C,H=-(V*g+j*y+G*x);return U=f*Math.abs(V)+m*Math.abs(j)+_*Math.abs(G),!(Math.abs(H)>U)}const c_=[];class h_{serializeFromGltf(e,t,i,r){if(e.length<7)return;let n=0;if(109!==e[n++]||98!==e[n++]||120!==e[n++]||98!==e[n++]||118!==e[n++]||104!==e[n++])return;if(43!==e[n++])return;const o=new DataView(e.buffer,e.byteOffset),s=o.getUint16(n,!0);if(n+=2,0===s)return;this._nodes=[];let a=0;for(let c=0;c<s;c++){const e=[t[3*a],t[3*a+1],t[3*a+2]],r=[i[3*a],i[3*a+1],i[3*a+2]];a++;const s=o.getUint16(n,!0);n+=2;let l=0,c=0;65535===s&&(l=o.getUint16(n,!0),n+=2,c=o.getUint32(n,!0),n+=4),this._nodes.push({aabbMin:e,aabbMax:r,backChild:s,indexCount:l,indexOffset:c})}const l=o.getUint32(n,!0);this._indices=r.slice(0,l)}setVertices(e){this._vertices=e}findHighestPoint(e,t){if(!this._nodes||0===this._nodes.length)return null;if(!a_(this._nodes[0].aabbMin,this._nodes[0].aabbMax,e,t))return null;const i=c_;i.length=0,i.push(0);let r=-1/0;for(;i.length>0;){const n=i.pop(),o=this._nodes[n];if(o.aabbMax[2]<=r)continue;if(65535===o.backChild){for(let i=0;i<o.indexCount;i+=3){const n=3*this._indices[o.indexOffset+i],s=3*this._indices[o.indexOffset+i+1],a=3*this._indices[o.indexOffset+i+2];l_(this._vertices[n],this._vertices[n+1],this._vertices[n+2],this._vertices[s],this._vertices[s+1],this._vertices[s+2],this._vertices[a],this._vertices[a+1],this._vertices[a+2],e,t)&&(r=Math.max(r,this._vertices[n+2],this._vertices[s+2],this._vertices[a+2]))}continue}const s=n+1,a=o.backChild,l=this._nodes[s],c=this._nodes[a],h=a_(l.aabbMin,l.aabbMax,e,t),u=a_(c.aabbMin,c.aabbMax,e,t);h&&u?l.aabbMax[2]<c.aabbMax[2]?(i.push(s),i.push(a)):(i.push(a),i.push(s)):h?i.push(s):u&&i.push(a)}return r>=0?r:null}}function u_(e,t){const i=e.json.bufferViews[t.bufferView],r=dm[t.componentType];return new r(e.buffers[i.buffer],(t.byteOffset||0)+(i.byteOffset||0),t.count*(i.byteStride&&i.byteStride!==fm[t.type]*r.BYTES_PER_ELEMENT?i.byteStride/r.BYTES_PER_ELEMENT:fm[t.type]))}function d_(e,t,i,r){const n=dm[t.componentType],o=function(e){switch(e){case Int8Array:return 1/127;case Uint8Array:return 1/255;case Int16Array:return 1/32767;case Uint16Array:return 1/65535;default:return 1}}(n),s=e.json.bufferViews[t.bufferView],a=s.byteStride?s.byteStride/n.BYTES_PER_ELEMENT:fm[t.type],l=i.float32,c=l.length/i.capacity;for(let h=0,u=0;h<t.count*a;h+=a,u+=c)for(let e=0;e<c;e++)l[u+e]=r[h+e]*o;i._trim()}function p_(e,t,i){const r=e.indices,n=e.attributes,o={};o.indexArray=new vl;const s=t.json.accessors[r],a=s.count/3;o.indexArray.reserve(a);const l=u_(t,s);for(let d=0;d<a;d++)o.indexArray.emplaceBack(l[3*d],l[3*d+1],l[3*d+2]);o.indexArray._trim(),o.vertexArray=new al;const c=t.json.accessors[n.POSITION];o.vertexArray.reserve(c.count);const h=u_(t,c);for(let d=0;d<c.count;d++)o.vertexArray.emplaceBack(h[3*d],h[3*d+1],h[3*d+2]);if(o.vertexArray._trim(),o.aabb=new Rh(c.min,c.max),o.centroid=function(e,t){const i=[0,0,0],r=e.length;if(r>0){for(let n=0;n<r;n++){const r=3*e[n];i[0]+=t[r],i[1]+=t[r+1],i[2]+=t[r+2]}i[0]/=r,i[1]/=r,i[2]/=r}return i}(l,h),void 0!==n.COLOR_0){const e=t.json.accessors[n.COLOR_0],i=fm[e.type],r=u_(t,e);o.colorArray=3===i?new al:new pl,o.colorArray.resize(e.count),d_(t,e,o.colorArray,r)}if(void 0!==n.NORMAL){o.normalArray=new al;const e=t.json.accessors[n.NORMAL];o.normalArray.resize(e.count);const i=u_(t,e);d_(t,e,o.normalArray,i)}if(void 0!==n.TEXCOORD_0&&i.length>0){o.texcoordArray=new Ml;const e=t.json.accessors[n.TEXCOORD_0];o.texcoordArray.resize(e.count);const i=u_(t,e);d_(t,e,o.texcoordArray,i)}if(void 0!==n._FEATURE_ID_RGBA4444){const e=t.json.accessors[n._FEATURE_ID_RGBA4444];t.json.extensionsUsed&&t.json.extensionsUsed.includes("EXT_meshopt_compression")&&(o.featureData=u_(t,e))}void 0!==n._FEATURE_RGBA4444&&(o.featureData=new Uint32Array(u_(t,t.json.accessors[n._FEATURE_RGBA4444]).buffer));const u=e.material;return o.material=function(e,t){const{emissiveFactor:i=[0,0,0],alphaMode:r="OPAQUE",alphaCutoff:n=.5,normalTexture:o,occlusionTexture:s,emissiveTexture:a,doubleSided:l,name:c}=e,{baseColorFactor:h=[1,1,1,1],metallicFactor:u=1,roughnessFactor:d=1,baseColorTexture:p,metallicRoughnessTexture:f}=e.pbrMetallicRoughness||{},m=s?t[s.index]:void 0;if(s&&s.extensions&&s.extensions.KHR_texture_transform&&m){const e=s.extensions.KHR_texture_transform;m.offsetScale=[e.offset[0],e.offset[1],e.scale[0],e.scale[1]]}return{name:c,pbrMetallicRoughness:{baseColorFactor:new xi(...h),metallicFactor:u,roughnessFactor:d,baseColorTexture:p?t[p.index]:void 0,metallicRoughnessTexture:f?t[f.index]:void 0},doubleSided:l,emissiveFactor:new xi(...i),alphaMode:r,alphaCutoff:n,normalTexture:o?t[o.index]:void 0,occlusionTexture:m,emissionTexture:a?t[a.index]:void 0,defined:void 0===e.defined}}(void 0!==u?t.json.materials[u]:{defined:!1},i),o}function f_(e,t,i){const{matrix:r,rotation:n,translation:o,scale:s,mesh:a,extras:l,children:h,name:u}=e,d={};if(d.name=u,d.localMatrix=r||function(e,t,i,r){var n=t[0],o=t[1],s=t[2],a=t[3],l=n+n,c=o+o,h=s+s,u=n*l,d=n*c,p=n*h,f=o*c,m=o*h,_=s*h,g=a*l,y=a*c,x=a*h,v=r[0],b=r[1],w=r[2];return e[0]=(1-(f+_))*v,e[1]=(d+x)*v,e[2]=(p-y)*v,e[3]=0,e[4]=(d-x)*b,e[5]=(1-(u+_))*b,e[6]=(m+g)*b,e[7]=0,e[8]=(p+y)*w,e[9]=(m-g)*w,e[10]=(1-(u+f))*w,e[11]=0,e[12]=i[0],e[13]=i[1],e[14]=i[2],e[15]=1,e}([],n||[0,0,0,1],o||[0,0,0],s||[1,1,1]),d.globalMatrix=c(d.localMatrix),void 0!==a){d.meshes=i[a];const e=d.anchor=[0,0];for(const t of d.meshes){const{min:i,max:r}=t.aabb;e[0]+=i[0]+r[0],e[1]+=i[1]+r[1]}e[0]=Math.floor(e[0]/d.meshes.length/2),e[1]=Math.floor(e[1]/d.meshes.length/2)}if(l&&(l.id&&(d.id=l.id),l.lights&&(d.lights=function(e){if(!e.length)return[];const t=function(e){const t=atob(e),i=new Uint8Array(t.length);for(let r=0;r<t.length;r++)i[r]=t.codePointAt(r);return i}(e),i=[],r=t.length/24,n=new Uint16Array(t.buffer),o=new Float32Array(t.buffer);for(let s=0;s<r;s++){const e=n[2*s*6]/30,t=n[2*s*6+1]/30,r=n[2*s*6+10]/100,a=o[6*s+1],l=o[6*s+2],c=o[6*s+3],h=o[6*s+4],u=c-a,d=h-l,p=Math.hypot(u,d);i.push({pos:[a+.5*u,l+.5*d,t],normal:[d/p,-u/p,0],width:p,height:e,depth:r,points:[a,l,c,h]})}return i}(l.lights)),l.MAPBOX_geometry_bloom&&(d.isGeometryBloom=l.MAPBOX_geometry_bloom)),h){const e=[];for(const r of h)e.push(f_(t.json.nodes[r],t,i));d.children=e}if(e.extensions&&e.extensions.mbx_bvh&&(d.meshBVH=function(e,t,i){const r=t.binaryAccessor,n=t.positionMinAccessor,o=t.positionMaxAccessor,s=t.indexAccessor;if(!(Number.isInteger(r)&&Number.isInteger(n)&&Number.isInteger(o)&&Number.isInteger(s)))return null;const a=e.json.accessors;if(r>=a.length||n>=a.length||o>=a.length||s>=a.length)return null;const l=a[r],c=a[n],h=a[o],u=a[s];if(void 0===l.bufferView||void 0===c.bufferView||void 0===h.bufferView||void 0===u.bufferView)return null;const d=e.json.bufferViews;if(l.bufferView>=d.length||c.bufferView>=d.length||h.bufferView>=d.length||u.bufferView>=d.length)return null;const p=d[l.bufferView],f=d[c.bufferView],m=d[h.bufferView],_=d[u.bufferView];if(p.buffer>=e.buffers.length||f.buffer>=e.buffers.length||m.buffer>=e.buffers.length||_.buffer>=e.buffers.length)return null;const g=(e,t,i)=>e>=0&&e<=i&&t<=i-e,y=l.byteOffset||0,x=c.byteOffset||0,v=h.byteOffset||0,b=u.byteOffset||0;if(!(g(y,0,p.byteLength)&&g(x,3*c.count*4,f.byteLength)&&g(v,3*h.count*4,m.byteLength)&&g(b,4*u.count,_.byteLength)))return null;const w=new Uint8Array(e.buffers[p.buffer],(p.byteOffset||0)+y,p.byteLength-y),T=new Float32Array(e.buffers[f.buffer],(f.byteOffset||0)+x,3*c.count),S=new Float32Array(e.buffers[m.buffer],(m.byteOffset||0)+v,3*h.count),I=new Uint32Array(e.buffers[_.buffer],(_.byteOffset||0)+b,u.count),E=new h_;if(E.serializeFromGltf(w,T,S,I),void 0!==i&&e.json.meshes&&e.json.meshes[i]){const t=e.json.meshes[i].primitives[0];if(t&&void 0!==t.attributes.POSITION&&t.attributes.POSITION<a.length){const i=a[t.attributes.POSITION];if(void 0!==i.bufferView&&i.bufferView<d.length){const t=d[i.bufferView];if(t.buffer<e.buffers.length){const r=i.byteOffset||0,n=t.byteStride?t.byteStride/4:3;if(g(r,i.count*n*4,t.byteLength)){const o=(t.byteOffset||0)+r;if(3===n)E.setVertices(new Float32Array(e.buffers[t.buffer],o,3*i.count));else{const r=new Float32Array(e.buffers[t.buffer],o,i.count*n),s=new Float32Array(3*i.count);for(let e=0;e<i.count;e++)s[3*e]=r[e*n],s[3*e+1]=r[e*n+1],s[3*e+2]=r[e*n+2];E.setVertices(s)}}}}}}return E}(t,e.extensions.mbx_bvh,a)),!d.meshBVH&&d.children)for(const c of d.children)if(c.meshBVH){d.meshBVH=c.meshBVH;break}return d}function m_(e){if(0===e.vertices.length||0===e.indices.length)return null;const t=new zp(e.vertices,e.indices,8,256),[i,r]=[t.min.clone(),t.max.clone()];return{vertices:e.vertices,indices:e.indices,grid:t,min:i,max:r}}function __(e){if(!e.extras||!e.extras.ground)return null;const t=e.extras.ground;if(!t||!Array.isArray(t)||0===t.length)return null;const i=t[0];if(!i||!Array.isArray(i)||0===i.length)return null;const r=[];for(const s of i){if(!Array.isArray(s)||2!==s.length)continue;const e=s[0],t=s[1];"number"==typeof e&&"number"==typeof t&&r.push(new Ie(e,t))}if(r.length<3)return null;r.length>1&&r.at(-1).equals(r[0])&&r.pop();let n=0;for(let s=0;s<r.length;s++){const e=r[s],t=r[(s+1)%r.length],i=r[(s+2)%r.length];n+=(e.x-t.x)*(i.y-t.y)-(i.x-t.x)*(e.y-t.y)}n>0&&r.reverse();const o=hd(r.flatMap(e=>[e.x,e.y]),[]);return 0===o.length?null:{vertices:r,indices:o}}function g_(e,t){const i=[],r=[];let n=0;const o=[];for(const s of e){n=i.length;const e=s.vertexArray.float32,a=s.indexArray.uint16;for(let r=0;r<s.vertexArray.length;r++)o[0]=e[3*r+0],o[1]=e[3*r+1],o[2]=e[3*r+2],H(o,o,t),i.push(new Ie(o[0],o[1]));for(let t=0;t<3*s.indexArray.length;t++)r.push(a[t]+n)}if(r.length%3!=0)return null;for(let s=0;s<r.length;s+=3){const e=i[r[s+0]],t=i[r[s+1]],n=i[r[s+2]];(e.x-t.x)*(n.y-t.y)-(n.x-t.x)*(e.y-t.y)>0&&([r[s+1],r[s+2]]=[r[s+2],r[s+1]])}return{vertices:i,indices:r}}function y_(e,t){for(let i=0;i<e.length;i++)if(e[i].name===t)return i;return-1}function x_(e){const t=function(e,t){const i=[];for(const r of e.json.meshes){const n=[];for(const i of r.primitives)n.push(p_(i,e,t));i.push(n)}return i}(e,function(e,t){const i=[],r=WebGL2RenderingContext;if(e.json.textures)for(const n of e.json.textures){const o={magFilter:r.LINEAR,minFilter:r.NEAREST,wrapS:r.REPEAT,wrapT:r.REPEAT};void 0!==n.sampler&&Object.assign(o,e.json.samplers[n.sampler]),i.push({image:t[n.source],sampler:o,uploaded:!1})}return i}(e,e.images)),{scenes:i,scene:r,nodes:n}=e.json;let o=i?y_(i,"Default Scene"):-1;o<0&&(o=r||0);const s=i?i[o].nodes:[...n.keys()],a=[];for(const c of s)a.push(f_(n[c],e,t));!function(e,t,i){const r={},n=/* @__PURE__ */new Set;for(let o=0;o<e.length;o++){const e=i[t[o]];if(!e.extras)continue;const s=e.extras["mapbox:footprint:version"],a=e.extras["mapbox:footprint:id"];(s||a)&&n.add(o),"1.0.0"===s&&a&&(r[a]=o)}for(let o=0;o<e.length;o++){if(n.has(o))continue;const s=e[o],a=i[t[o]];if(!a.extras)continue;let l=null;s.id in r&&(l=g_(e[r[s.id]].meshes,s.localMatrix)),l||(l=__(a)),l&&(s.footprint=m_(l))}if(n.size>0){const t=Array.from(n.values()).sort((e,t)=>e-t);for(let i=t.length-1;i>=0;i--)e.splice(t[i],1)}}(a,s,e.json.nodes);const l=i?y_(i,"LOD"):-1;if(l>=0){const r=i[l].nodes,o=/* @__PURE__ */new Map;for(const i of r){const r=f_(n[i],e,t);r.id&&o.set(r.id,r)}for(const e of a)if(e.id){const t=o.get(e.id);t&&t.meshes&&(e.lodMeshes=t.meshes,t.meshBVH&&(e.meshBVH=t.meshBVH))}}return a}function v_(e){e.heightmap=new Float32Array(4096),e.heightmap.fill(-1);const t=e.vertexArray.float32,i=e.aabb.min[0]-1,r=e.aabb.min[1]-1,n=Ym/(e.aabb.max[0]-i+2),o=Ym/(e.aabb.max[1]-r+2);for(let s=0;s<t.length;s+=3){const a=t[s+2],l=(t[s+0]-i)*n|0,c=(t[s+1]-r)*o|0;a>e.heightmap[c*Ym+l]&&(e.heightmap[c*Ym+l]=a)}}function b_(e,t,i,r,n){i.reserve(i.length+4*e.length),r.reserve(r.length+10*e.length),n.reserve(n.length+10*e.length);let o=r.length;for(const s of e){const e=Math.min(10,Math.max(4,1.3*s.height))*t,a=[-s.normal[1],s.normal[0],0],l=Math.min(.29,.1*s.width/s.depth),c=s.width-2*s.depth*t*(l+.01),h=F([],s.pos,a,c/2),u=F([],s.pos,a,-c/2),d=[h[0],h[1],h[2]+s.height],p=[u[0],u[1],u[2]+s.height],f=F([],s.normal,a,l);L(f,f,e);const m=F([],s.normal,a,-l);L(m,m,e),C(f,h,f),C(m,u,m),h[2]+=.1,u[2]+=.1,r.emplaceBack(f[0],f[1],f[2]),r.emplaceBack(m[0],m[1],m[2]),r.emplaceBack(h[0],h[1],h[2]),r.emplaceBack(u[0],u[1],u[2]),r.emplaceBack(d[0],d[1],d[2]),r.emplaceBack(p[0],p[1],p[2]),r.emplaceBack(h[0],h[1],h[2]),r.emplaceBack(u[0],u[1],u[2]),r.emplaceBack(f[0],f[1],f[2]),r.emplaceBack(m[0],m[1],m[2]);const _=c/e/2;n.emplaceBack(-_-l,-1,_,.8),n.emplaceBack(_+l,-1,_,.8),n.emplaceBack(-_,0,_,1.3),n.emplaceBack(_,0,_,1.3),n.emplaceBack(_+l,-.8,_,.7),n.emplaceBack(_+l,-.8,_,.7),n.emplaceBack(0,0,_,1.3),n.emplaceBack(0,0,_,1.3),n.emplaceBack(_+l,-1.2,_,.8),n.emplaceBack(_+l,-1.2,_,.8),i.emplaceBack(6+o,4+o,8+o),i.emplaceBack(7+o,9+o,5+o),i.emplaceBack(0+o,1+o,2+o),i.emplaceBack(1+o,3+o,2+o),o+=10}}function w_(e,t){const i={};i.indexArray=new vl,i.vertexArray=new al,i.colorArray=new pl,b_(e,t,i.indexArray,i.vertexArray,i.colorArray);const r={defined:!0};r.emissiveFactor=xi.black;const n={};return n.baseColorFactor=xi.white,r.pbrMetallicRoughness=n,i.material=r,i.aabb=new Rh([1/0,1/0,1/0],[-1/0,-1/0,-1/0]),i}as(h_,"ModelBVH");const T_=Ya([{name:"a_pos_3f",components:3,type:"Float32"}]),S_=Ya([{name:"a_normal_3",components:3,type:"Int16"}]),I_=Ya([{name:"a_centroid_3",components:3,type:"Int16"}]),E_=Ya([{name:"a_part_color_emissive",components:2,type:"Uint16"}]),A_=Ya([{name:"a_faux_facade_color_emissive",components:2,type:"Uint16"}]),M_=Ya([{name:"a_faux_facade_data",components:4,type:"Uint16"}]),C_=Ya([{name:"a_faux_facade_vertical_range",components:2,type:"Uint16"}]),P_=Ya([{name:"a_bloom_attenuation",components:4,type:"Float32"}]),D_=Ya([{name:"a_flood_light_wall_radius_1i16",components:1,type:"Int16"}]),R_=4096;class z_{constructor(e){this.module=e,this.memoryStack=this.module.malloc(R_),this.memoryStackNextFree=this.memoryStack}createIntArray(e){const t=this.memoryStackNextFree;return this.memoryStackNextFree+=e.length*Int32Array.BYTES_PER_ELEMENT,this.memoryStackNextFree-this.memoryStack>R_?-1:(new Int32Array(this.module.heap32.buffer,t,e.length).set(e),t)}createFloatArray(e){const t=this.memoryStackNextFree;return this.memoryStackNextFree+=e.length*Float32Array.BYTES_PER_ELEMENT,this.memoryStackNextFree-this.memoryStack>R_?-1:(new Float32Array(this.module.heapF32.buffer,t,e.length).set(e),t)}readStringBuffer(e){let t="";for(;0!==this.module.heapU8[e];)t+=String.fromCharCode(this.module.heapU8[e]),++e;return t}setStyle(e){const t=e.normalScale;this.module.setStyle(t[0],t[1],t[2],e.tileToMeters)}setAOOptions(e,t){this.module.setAOOptions(e?1:0,t)}setMetricOptions(e,t){this.module.setMetricOptions(e?1:0,t)}setStructuralOptions(e){this.module.setStructuralOptions(e?1:0)}setFacadeOptions(e,t){this.module.setFacadeOptions(e,t?1:0)}setFauxFacadeOptions(e,t,i){this.module.setFauxFacadeOptions(e?1:0,t?1:0,i)}setFacadeClassifierOptions(e){this.module.setFacadeClassifierOptions(e)}generateMesh(e,t){this.memoryStackNextFree=this.memoryStack;for(const s of e){const e=this.createIntArray(s.ringIndices),t=this.createFloatArray(s.coordinates);if(-1===e||-1===t)return`building_gen: Out of stack memory: ${this.memoryStackNextFree-this.memoryStack}/4096`;this.module.addFeature(s.id,s.sourceId,s.minHeight,s.height,s.roofType,t,e,s.ringIndices.length-1)}for(const s of t){let e;e=s.entrances?JSON.parse(s.entrances):[];const t=this.createFloatArray(e),i=this.createFloatArray(s.coordinates);if(-1===t||-1===i)return`building_gen: Out of stack memory: ${this.memoryStackNextFree-this.memoryStack}/4096`;this.module.addFacade(s.sourceId,s.crossPerc,s.distanceToRoad,t,e.length,i,s.coordinates.length)}if(!this.module.generateMesh()){const e=this.module.getLastError();return this.readStringBuffer(e)}const i=this.module.getMeshCount(),r=new Array(i);for(let s=0;s<i;s++){const e=this.module.getPositionsPtr(s),t=this.module.getPositionsLength(s),i=new Float32Array(this.module.heapF32.buffer,e,t),n=this.module.getNormalsPtr(s),o=this.module.getNormalsLength(s),a=new Float32Array(this.module.heapF32.buffer,n,o),l=this.module.getAOPtr(s),c=this.module.getAOLength(s),h=new Float32Array(this.module.heapF32.buffer,l,c),u=this.module.getUVPtr(s),d=this.module.getUVLength(s),p=new Float32Array(this.module.heapF32.buffer,u,d),f=this.module.getFauxFacadePtr(s),m=this.module.getFauxFacadeLength(s),_=new Uint8Array(this.module.heapU8.buffer,f,m),g=this.module.getIndicesPtr(s),y=this.module.getIndicesLength(s);r[s]={positions:i,normals:a,ao:h,uv:p,isFauxFacade:_,indices:new Int16Array(this.module.heap16.buffer,g,y),buildingPart:this.module.getBuildingPart(s)}}const n=this.module.getRingCount(),o=[];for(let s=0;s<n;s++){const e=this.module.getRingPtr(s),t=this.module.getRingLength(s),i=new Float32Array(this.module.heapF32.buffer,e,t);o.push(i)}return{meshes:r,outerRingLength:this.module.getOuterRingLength(),modifiedPolygonRings:o}}}const L_=ch.types,F_=32767;function O_(e,t){const i=Yr+t;for(const r of e)for(const e of r)if(e.x<-t||e.x>i||e.y<-t||e.y>i)return!1;return!0}function B_(e){switch(e){case"flat":return 3;case"hipped":return 1;case"gabled":return 2;case"parapet":return 0;case"mansard":return 4;case"skillion":return 5;case"pyramidal":return 6;default:throw new Error(`Unknown roof shape: ${e}`)}}let k_=null,N_=null,U_=null;class V_{constructor(){this.layoutVertexArray=new al,this.layoutAttenuationArray=new pl,this.layoutColorArray=new ml,this.indexArray=new vl,this.indexArrayForConflation=new vl,this.segmentsBucket=new Jl}}class j_{constructor(e){this.layoutFacadePaintArray=null,this.layoutFacadeDataArray=null,this.layoutFacadeVerticalRangeArray=null,this.segmentsBucket=new Jl,this.entranceBloom=new V_;const t=66560;this.layoutVertexArray=new al,this.layoutVertexArray.reserve(t),this.layoutNormalArray=new Qa,this.layoutNormalArray.reserve(t),this.layoutCentroidArray=new Qa,this.layoutCentroidArray.reserve(t),this.layoutColorArray=new ml,this.layoutColorArray.reserve(t),this.layoutFloodLightDataArray=new zl,this.layoutFloodLightDataArray.reserve(t),this.layoutAOArray=new Ll,this.layoutAOArray.reserve(t),this.indexArray=new vl,this.indexArray.reserve(66560),this.indexArrayForConflation=new vl,this.segmentsBucket=new Jl,this.entranceBloom=new V_,e&&(this.layoutFacadePaintArray=new ml,this.layoutFacadeDataArray=new cl,this.layoutFacadeVerticalRangeArray=new ml)}reserve(e,t,i){this.layoutVertexArray.reserveForAdditional(e),this.layoutCentroidArray.reserveForAdditional(e),this.layoutFloodLightDataArray.reserveForAdditional(e),this.layoutNormalArray.reserveForAdditional(e),this.layoutAOArray.reserveForAdditional(e),this.layoutColorArray.reserveForAdditional(e),this.indexArray.reserveForAdditional(t),i&&(this.layoutFacadePaintArray.reserveForAdditional(e),this.layoutFacadeDataArray.reserveForAdditional(e),this.layoutFacadeVerticalRangeArray.reserveForAdditional(e))}}class G_{constructor(e){this.colorBufferUploaded=!1,this.maxHeight=0,this.replacementUpdateTime=0,this.activeReplacements=[],this.footprints=[],this.footprintsVertices=new Ml,this.footprintsIndices=new Pl,this.footprintsMin=new Ie(1/0,1/0),this.footprintsMax=new Ie(-1/0,-1/0),this.featuresOnBorder=[],this.buildingWithoutFacade=new j_(!1),this.buildingWithFacade=new j_(!0),this.indexArrayForConflationUploaded=!1,this.featureFootprintLookup=/* @__PURE__ */new Map,this.buildingIds=/* @__PURE__ */new Set,this.footprintLookup={},this.zoom=e.zoom,this.canonical=e.canonical,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.hasPattern=!1,this.worldview=e.worldview,this.lut=e.lut,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut}),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.projection=e.projection,this.groundEffect=new Af(e),this.groundEffect.groundRadiusArray=new tl,this.hasAppearances=null}updateFootprints(e,t){const i=new zp([],[],1),r={vertices:[],indices:new Uint32Array(0),grid:i,min:this.footprintsMin,max:this.footprintsMax,buildingIds:this.buildingIds};t.push({footprint:r,id:e})}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){if(!U_)return;const n=Kc(i);this.tileToMeter=n,this.brightness=t.brightness,U_.setStyle({normalScale:[1,-1,n],tileToMeters:n}),U_.setAOOptions(!1,.3),U_.setMetricOptions(!1,16),U_.setStructuralOptions(!0),U_.setFacadeClassifierOptions(3);const o=/* @__PURE__ */new Map,s=/* @__PURE__ */new Map;let a=0;for(const{feature:m}of e){if("LineString"!==L_[m.type]){o.set(m.id,m.properties.source_id);continue}const e=this.layers[0]._featureFilter.needGeometry;if(e&&!this.layers[0]._featureFilter.filter(new sa(this.zoom),m,i))continue;const t=lh(m,e);if(!e&&!this.layers[0]._featureFilter.filter(new sa(this.zoom),t,i))continue;const n=e?t.geometry:ah(m,i,r),l=[];for(const i of n)for(const e of i)l.push(e.x),l.push(e.y);const c={coordinates:l,crossPerc:m.properties.cross_perc,distanceToRoad:m.properties.distance_to_road,entrances:m.properties.entrances,sourceId:0},h=m.properties.source_id;let u=s.get(h);u||(u=[],s.set(h,u)),u.push(c),++a}this.maxHeight=0;const l=new Array,c=/* @__PURE__ */new Set,h=e=>{null!=e&&c.add(e)},u=(e,t)=>{null!=e&&l.push({buildingId:e,footprintIndex:t})},d=64*(e.length-a),p=d/2;this.buildingWithFacade.reserve(d,p,!0),this.buildingWithoutFacade.reserve(2*d,2*p,!1),this.footprintsIndices.reserve(16*(e.length-a)),this.footprintsVertices.reserve(8*(e.length-a));for(const{feature:m,id:_,index:g,sourceLayerIndex:y}of e){if("LineString"===L_[m.type])continue;const e=this.layers[0]._featureFilter.needGeometry;if(e&&!this.layers[0]._featureFilter.filter(new sa(this.zoom),m,i))continue;let a=null;if(m.properties&&Object.hasOwn(m.properties,"building_id")&&(a=Number(m.properties.building_id),c.has(a)))continue;const l=lh(m,e);if(!e&&!this.layers[0]._featureFilter.filter(new sa(this.zoom),l,i))continue;const d=e?l.geometry:ah(m,i,r),p=Od(d,500);let f=!1;for(const t of p)if(1!==t.length){f=!0;break}if(f){h(a);continue}if(!O_(d,163)){h(a);continue}const x=this.layers[0],v=B_(x.layout.get("building-roof-shape").evaluate(m,{},i)),b=x.layout.get("building-base").evaluate(m,{},i),w=x.layout.get("building-height").evaluate(m,{},i),T=x.layout.get("building-flood-light-ground-radius").evaluate(m,{},i),S=x.paint.get("building-ambient-occlusion-intensity"),I=T/this.tileToMeter;m.properties["building-part"]="roof";const E=x.paint.get("building-color").evaluate(m,{},this.canonical).toPremultipliedRenderColor(this.lut),A=x.paint.get("building-emissive-strength").evaluate(m,{},this.canonical);m.properties["building-part"]="wall";const M=x.paint.get("building-color").evaluate(m,{},this.canonical).toPremultipliedRenderColor(this.lut),C=x.paint.get("building-emissive-strength").evaluate(m,{},this.canonical);m.properties["building-part"]="window";const P=x.paint.get("building-color").evaluate(m,{},this.canonical).toPremultipliedRenderColor(this.lut),D=x.paint.get("building-emissive-strength").evaluate(m,{},this.canonical);m.properties["building-part"]="door";const R=x.paint.get("building-color").evaluate(m,{},this.canonical).toPremultipliedRenderColor(this.lut),z=x.paint.get("building-emissive-strength").evaluate(m,{},this.canonical);let L=x.layout.get("building-flood-light-wall-radius").evaluate(m,{},i);L=ke(L,0,2048);const F=L/2048*F_,O=o.get(_),B=s.get(O)||[],k=0!==B.length&&x.layout.get("building-facade").evaluate(m,{},i);U_.setFacadeOptions(4,!0),U_.setFauxFacadeOptions(k,!1,1);let N=0,U=0,V=0,j=0,G=0,H=0,$=0,q=0,Z=0,W=0,X=0;if(k){let e=Math.round(x.layout.get("building-facade-floors").evaluate(m,{},i));if(0===b){e=Math.max(1,e-(B.length>0?1:0));let t=4;if(w>100){const e=[10,13,15];t=e[m.id?m.id%e.length:0]}else w<=10&&(t=3);U_.setFacadeOptions(t,!0),G=(w<15?1.3:1.61803)*t/n}else G=b/n;H=w/n,G=Math.min(G,H),V=x.layout.get("building-facade-unit-width").evaluate(m,{},i)/n,j=(H-G)/e,U_.setFauxFacadeOptions(!0,!0,V);const t=x.layout.get("building-facade-window").evaluate(m,{},i);N=t[0],U=t[1],$=Math.floor(65535*Math.min(1,G/Yr)),q=Math.floor(65535*Math.min(1,H/Yr)),Z=Math.floor(255*N)<<8|Math.floor(255*U),W=Math.floor(65535*Math.min(1,V/Yr)),X=Math.floor(65535*Math.min(1,j/Yr))}const Y=Array(p.length),J={x:1/0,y:1/0},K={x:-1/0,y:-1/0},Q={x:0,y:0};let ee=0;for(let t=0;t<p.length;t++){const e=p[t];if(e.length>0){const i=[],r=Array(e.length+1);r[0]=0;for(let t=0;t<e.length;t++){const n=e[t];for(let e=0;e<n.length;e++){const t=n[n.length-e-1];J.x=Math.min(J.x,t.x),J.y=Math.min(J.y,t.y),K.x=Math.max(K.x,t.x),K.y=Math.max(K.y,t.y),Q.x+=t.x,Q.y+=t.y,ee++,i.push(t.x),i.push(t.y)}r[t+1]=i.length}Y[t]={id:m.id?m.id:0,height:w,minHeight:b,sourceId:0,roofType:v,coordinates:i,ringIndices:r}}}Q.x/=ee||1,Q.y/=ee||1;const te=U_.generateMesh(Y,B);if("string"==typeof te){Ke(`Unable to generate building ${m.id}: ${te}`),h(a);continue}if(0===te.meshes.length||0===te.modifiedPolygonRings.length){h(a);continue}const ie=k?this.buildingWithFacade:this.buildingWithoutFacade;let re=0;for(const t of te.meshes)re+=t.positions.length/3;const ne=ie.segmentsBucket.prepareSegment(re,ie.layoutVertexArray,ie.indexArray),oe=[];let se=null,ae=0,le=-1;const ce=ie.layoutVertexArray.length,he=ce+re;ie.layoutVertexArray.resize(he),ie.layoutCentroidArray.resize(he),ie.layoutNormalArray.resize(he),ie.layoutAOArray.resize(he),ie.layoutColorArray.resize(he),ie.layoutFloodLightDataArray.resize(he),k&&(ie.layoutFacadePaintArray.resize(he),ie.layoutFacadeDataArray.resize(he),ie.layoutFacadeVerticalRangeArray.resize(he));const ue=ie.indexArray.length;let de=0,pe=ce;for(const t of te.meshes){let e,i;if(1===t.buildingPart)e=E,i=A;else if(0===t.buildingPart)e=M,i=C;else if(2===t.buildingPart)e=P,i=D;else{if(3!==t.buildingPart)continue;e=R,i=z}if(i=ke(i,0,1),3===t.buildingPart){const e=new Array;for(let o=0;o<t.positions.length;o+=12){const i=t.positions[o+0],r=t.positions[o+1],n=t.positions[o+3],s=t.positions[o+4],a=t.positions[o+2],l=t.positions[o+8]-a,c=1,h=n-i,u=s-r,d=Math.hypot(h,u);e.push({pos:[i+.5*h,r+.5*u,a],normal:[u/d,-h/d,0],width:d,height:l,depth:c,points:[i,r,n,s]})}const i=ie.entranceBloom.segmentsBucket.prepareSegment(10*e.length,ie.entranceBloom.layoutVertexArray,ie.entranceBloom.indexArray),r=ie.entranceBloom.layoutVertexArray.length;ae=ie.entranceBloom.indexArray.length,b_(e,.5/this.tileToMeter,ie.entranceBloom.indexArray,ie.entranceBloom.layoutVertexArray,ie.entranceBloom.layoutAttenuationArray);const n=ie.entranceBloom.layoutVertexArray.length-r;le=ie.entranceBloom.indexArray.length-ae;for(let t=0;t<n;t++)ie.entranceBloom.layoutColorArray.emplaceBack(255*R.r<<8|255*R.g,255*R.b<<8|51*z);i.vertexLength+=n,i.primitiveLength+=le,se={part:t.buildingPart,vertexOffset:r,vertexLength:n}}ie.layoutVertexArray.float32.set(t.positions,3*pe);const r=t.positions.length/3;for(let p=0;p<r;++p){const r=3*p;de=Math.max(de,t.positions[r+2]);const n=t.normals[r+1]*F_,o=t.normals[r+2]*F_,s=3*(pe+p);ie.layoutNormalArray.int16[s]=t.normals[r]*F_,ie.layoutNormalArray.int16[s+1]=n,ie.layoutNormalArray.int16[s+2]=o;const a=t.ao[p];ie.layoutAOArray.uint8[pe+p]=255*a;const l=1+(a-1)*S,c=255*e.b*l<<8|255*i;ie.layoutColorArray.uint16[2*(pe+p)]=255*e.r*l<<8|255*e.g*l,ie.layoutColorArray.uint16[2*(pe+p)+1]=c}const n=Math.min(8191,Math.max(0,Math.floor(Q.x))),o=Math.min(8191,Math.max(0,Math.floor(Q.y))),s=Math.floor(w),a=20,l=4*n+Math.min(3,Math.round((K.x-J.x)*this.tileToMeter/a)),c=4*o+Math.min(3,Math.round((K.y-J.y)*this.tileToMeter/a));for(let t=0;t<r;++t){const e=3*(pe+t);ie.layoutCentroidArray.int16[e]=l,ie.layoutCentroidArray.int16[e+1]=c,ie.layoutCentroidArray.int16[e+2]=s}if(ie.layoutFloodLightDataArray.int16.fill(0===t.buildingPart?F:0,pe,pe+r),k){const e=255*P.r<<8|255*P.g,i=255*P.b<<8|255*D;for(let t=0;t<r;++t){const r=2*(pe+t);ie.layoutFacadePaintArray.uint16[r]=e,ie.layoutFacadePaintArray.uint16[r+1]=i}for(let n=0;n<r;++n)if(t.isFauxFacade[n]){const e=Math.min(65535,Math.floor(t.uv[2*n]*te.outerRingLength));ie.layoutFacadeDataArray.emplace(pe+n,1|e,Z,W,X),ie.layoutFacadeVerticalRangeArray.emplace(pe+n,$,q)}else ie.layoutFacadeDataArray.emplace(pe+n,0,0,0,0),ie.layoutFacadeVerticalRangeArray.emplace(pe+n,0,0)}const h=ne.vertexLength,u=t.indices.length/3,d=ie.indexArray.length;ie.indexArray.resize(d+u);for(let p=0;p<u;++p){const e=3*p,i=3*d+e;ie.indexArray.uint16[i]=h+t.indices[e],ie.indexArray.uint16[i+1]=h+t.indices[e+1],ie.indexArray.uint16[i+2]=h+t.indices[e+2]}1!==t.buildingPart&&0!==t.buildingPart&&2!==t.buildingPart&&3!==t.buildingPart||oe.push({part:t.buildingPart,vertexOffset:pe,vertexLength:t.positions.length/3}),pe+=r,ne.vertexLength+=r,ne.primitiveLength+=t.indices.length/3}this.maxHeight=Math.max(this.maxHeight,de);const fe=ie.indexArray.length-ue,me=this.footprintsIndices.length,_e=this.footprintsVertices.length,ge=[],ye=new Ie(1/0,1/0),xe=new Ie(-1/0,-1/0),ve=this.groundEffect.vertexArray.length;for(const t of te.modifiedPolygonRings){const e=[],i=new Ie(1/0,1/0),r=new Ie(-1/0,-1/0);for(let n=0;n<t.length;n+=2){const o=t.length-n-2;i.x=Math.min(i.x,t[o]),i.y=Math.min(i.y,t[o+1]),r.x=Math.max(r.x,t[o]),r.y=Math.max(r.y,t[o+1]);const s=new Ie(t[o],t[o+1]);e.push(s),ge.push(s.x,s.y),this.footprintsVertices.emplaceBack(s.x,s.y)}ye.x=Math.min(ye.x,i.x),ye.y=Math.min(ye.y,i.y),xe.x=Math.max(xe.x,r.x),xe.y=Math.max(xe.y,r.y),this.groundEffect.addData(e,[i,r],I)}const be=this.groundEffect.vertexArray.length-ve;this.groundEffect.groundRadiusArray.reserveForAdditional(be);for(let t=0;t<be;t++)this.groundEffect.groundRadiusArray.emplaceBack(T);(J.x<0||K.x>Yr||J.y<0||K.y>Yr)&&this.featuresOnBorder.push({featureId:m.id,footprintIndex:this.footprints.length});{const e=hd(ge,null,2);this.footprintsIndices.resize(this.footprintsIndices.length+e.length),this.footprintsIndices.uint16.set(e,me),this.buildingIds.add(null!=a?a:m.id),this.footprintsMin.x=Math.min(this.footprintsMin.x,ye.x),this.footprintsMin.y=Math.min(this.footprintsMin.y,ye.y),this.footprintsMax.x=Math.max(this.footprintsMax.x,xe.x),this.footprintsMax.y=Math.max(this.footprintsMax.y,xe.y);const t={footprintVertexOffset:_e,footprintVertexLength:this.footprintsVertices.length-_e,footprintIndexOffset:me,footprintIndexLength:this.footprintsIndices.length-me,min:ye,max:xe,hiddenFlags:0,indicesOffset:ue,indicesLength:fe,bloomIndicesOffset:ae,bloomIndicesLength:le,groundEffectVertexOffset:ve,groundEffectVertexLength:be,hasFauxFacade:k,height:de,promoteId:_,feature:l,parts:oe,buildingBloom:se},i=this.footprints.length;void 0!==m.id&&this.featureFootprintLookup.set(m.id,i),u(a,i),this.footprints.push(t)}this.programConfigurations.populatePaintArrays(ie.layoutVertexArray.length,m,g,{},t.availableImages,i,t.brightness),this.groundEffect.addPaintPropertiesData(m,g,{},t.availableImages,i,t.brightness),t.featureIndex.insert(m,d,g,y,this.index,ce)}l.forEach(({buildingId:e,footprintIndex:t})=>{c.has(e)&&(this.footprints[t].hiddenFlags|=4)});const f=/* @__PURE__ */new Set;this.buildingIds.forEach((e,t,i)=>{c.has(e)||f.add(e)}),this.buildingIds=f,this.groundEffect.prepareBorderSegments()}update(e,t,i,r,n,o,s){this.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s),this.groundEffect.update(e,t,n,i,r,o,s),this.evaluate(this.layers[0],e),this.colorBufferUploaded=!1}updateExpressions(e){this.programConfigurations.updateExpressions(e),this.groundEffect.programConfigurations.updateExpressions(e)}isEmpty(){return 0===this.buildingWithoutFacade.layoutVertexArray.length&&0===this.buildingWithFacade.layoutVertexArray.length}uploadPending(){return!this.uploaded||this.programConfigurations.needsUpload||this.groundEffect.programConfigurations.needsUpload}upload(e){const t=t=>{t.layoutVertexBuffer=e.createVertexBuffer(t.layoutVertexArray,T_.members),t.layoutNormalBuffer=e.createVertexBuffer(t.layoutNormalArray,S_.members),t.layoutCentroidBuffer=e.createVertexBuffer(t.layoutCentroidArray,I_.members),t.layoutFloodLightDataBuffer=e.createVertexBuffer(t.layoutFloodLightDataArray,D_.members),t.layoutFacadeDataArray&&t.layoutFacadeDataArray.length&&(t.layoutFacadeDataBuffer=e.createVertexBuffer(t.layoutFacadeDataArray,M_.members)),t.layoutFacadeVerticalRangeArray&&t.layoutFacadeVerticalRangeArray.length&&(t.layoutFacadeVerticalRangeBuffer=e.createVertexBuffer(t.layoutFacadeVerticalRangeArray,C_.members)),t.entranceBloom.layoutVertexArray.length&&(t.entranceBloom.layoutVertexBuffer=e.createVertexBuffer(t.entranceBloom.layoutVertexArray,T_.members),t.entranceBloom.layoutAttenuationBuffer=e.createVertexBuffer(t.entranceBloom.layoutAttenuationArray,P_.members)),this.uploadUpdatedColorBuffer(e),this.uploadUpdatedIndexBuffer(e)};this.uploaded||(t(this.buildingWithoutFacade),t(this.buildingWithFacade),this.groundEffect.upload(e)),this.groundEffect.uploadPaintProperties(e),this.programConfigurations.upload(e),this.uploaded=!0}destroy(){const e=e=>{e.layoutVertexBuffer&&(e.layoutVertexBuffer.destroy(),e.layoutNormalBuffer.destroy(),e.layoutColorBuffer.destroy(),e.segmentsBucket.destroy(),e.indexBuffer&&e.indexBuffer.destroy(),e.entranceBloom.layoutVertexBuffer&&(e.entranceBloom.layoutVertexBuffer.destroy(),e.entranceBloom.layoutColorBuffer.destroy(),e.entranceBloom.layoutAttenuationBuffer.destroy(),e.entranceBloom.indexBuffer.destroy(),e.entranceBloom.segmentsBucket.destroy()))};e(this.buildingWithoutFacade),e(this.buildingWithFacade),this.groundEffect.destroy(),this.programConfigurations.destroy()}updateFootprintHiddenFlags(e,t,i=!0){let r=!1;const n=i?t:0,o=0|(i?-1:~t);0===this.groundEffect.hiddenByLandmarkVertexArray.length&&this.groundEffect.hiddenByLandmarkVertexArray.resize(this.groundEffect.vertexArray.length);for(const s of e){const e=this.footprints[s],t=e.hiddenFlags&o|n;e.hiddenFlags!==t&&(e.hiddenFlags=t,r=!0,this.groundEffect.updateHiddenByLandmarkRange(e.groundEffectVertexOffset,e.groundEffectVertexLength,0!==e.hiddenFlags))}return r&&(this.indexArrayForConflationUploaded=!1),r}uploadUpdatedIndexBuffer(e){if(this.groundEffect.uploadHiddenByLandmark(e),this.indexArrayForConflationUploaded)return;const t=e=>{0!==e.indexArray.length&&(e.indexArrayForConflation.resize(e.indexArray.length),e.indexArrayForConflation.uint16.set(e.indexArray.uint16),e.entranceBloom.indexArrayForConflation.resize(e.entranceBloom.indexArray.length),e.entranceBloom.indexArrayForConflation.uint16.set(e.entranceBloom.indexArray.uint16))};t(this.buildingWithoutFacade),t(this.buildingWithFacade);for(const r of this.footprints){const e=r.hasFauxFacade?this.buildingWithFacade:this.buildingWithoutFacade,t=r.indicesOffset+r.indicesLength;if(0!==r.hiddenFlags){for(let n=r.indicesOffset;n<t;n++)e.indexArrayForConflation.uint16[3*n+0]=0,e.indexArrayForConflation.uint16[3*n+1]=0,e.indexArrayForConflation.uint16[3*n+2]=0;const i=r.bloomIndicesOffset+r.bloomIndicesLength;for(let t=r.bloomIndicesOffset;t<i;t++)e.entranceBloom.indexArrayForConflation.uint16[3*t+0]=0,e.entranceBloom.indexArrayForConflation.uint16[3*t+1]=0,e.entranceBloom.indexArrayForConflation.uint16[3*t+2]=0}}const i=t=>{0!==t.indexArray.length&&(t.indexBuffer?t.indexBuffer.updateData(t.indexArrayForConflation):t.indexBuffer=e.createIndexBuffer(t.indexArrayForConflation,!0),t.entranceBloom.indexBuffer?t.entranceBloom.indexBuffer.updateData(t.entranceBloom.indexArrayForConflation):t.entranceBloom.indexBuffer=e.createIndexBuffer(t.entranceBloom.indexArrayForConflation,!0))};i(this.buildingWithoutFacade),i(this.buildingWithFacade),this.indexArrayForConflationUploaded=!0}uploadUpdatedColorBuffer(e){const t=t=>{t.layoutColorBuffer?t.layoutColorBuffer.updateData(t.layoutColorArray):t.layoutColorBuffer=e.createVertexBuffer(t.layoutColorArray,E_.members,!0),t.layoutFacadePaintArray&&(t.layoutFacadePaintBuffer?t.layoutFacadePaintBuffer.updateData(t.layoutFacadePaintArray):t.layoutFacadePaintBuffer=e.createVertexBuffer(t.layoutFacadePaintArray,A_.members,!0)),t.entranceBloom.layoutColorBuffer?t.entranceBloom.layoutColorBuffer.updateData(t.entranceBloom.layoutColorArray):t.entranceBloom.layoutColorBuffer=e.createVertexBuffer(t.entranceBloom.layoutColorArray,E_.members,!0)};t(this.buildingWithoutFacade),t(this.buildingWithFacade),this.colorBufferUploaded=!0}evaluate(e,t){const i=e.paint.get("building-ambient-occlusion-intensity");for(const r of this.footprints){if(4&r.hiddenFlags)continue;const n=t[r.promoteId],o=r.feature;o.properties["building-part"]="roof";const s=e.paint.get("building-color").evaluate(o,n,this.canonical).toPremultipliedRenderColor(this.lut),a=e.paint.get("building-emissive-strength").evaluate(o,n,this.canonical);o.properties["building-part"]="wall";const l=e.paint.get("building-color").evaluate(o,n,this.canonical).toPremultipliedRenderColor(this.lut),c=e.paint.get("building-emissive-strength").evaluate(o,n,this.canonical);o.properties["building-part"]="window";const h=e.paint.get("building-color").evaluate(o,n,this.canonical).toPremultipliedRenderColor(this.lut),u=e.paint.get("building-emissive-strength").evaluate(o,n,this.canonical);o.properties["building-part"]="door";const d=e.paint.get("building-color").evaluate(o,n,this.canonical).toPremultipliedRenderColor(this.lut),p=e.paint.get("building-emissive-strength").evaluate(o,n,this.canonical),f=r.hasFauxFacade?this.buildingWithFacade:this.buildingWithoutFacade;for(const e of r.parts){let t,n=s;1===e.part?(n=s,t=a):0===e.part?(n=l,t=c):2===e.part?(n=h,t=u):3===e.part&&(n=d,t=p),t=ke(t,0,1);for(let o=0;o<e.vertexLength;o++){const s=e.vertexOffset+o,a=1+(f.layoutAOArray.uint8[s]/255-1)*i;f.layoutColorArray.emplace(s,n.r*a*255<<8|n.g*a*255,n.b*a*255<<8|255*t),r.hasFauxFacade&&f.layoutFacadePaintArray.emplace(s,255*h.r<<8|255*h.g,255*h.b<<8|255*u)}}const m=r.buildingBloom;if(m)for(let e=0;e<m.vertexLength;e++)f.entranceBloom.layoutColorArray.emplace(m.vertexOffset+e,255*d.r<<8|255*d.g,255*d.b<<8|51*p)}}needsEvaluation(){return!this.colorBufferUploaded}updateReplacement(e,t,i){if(t.updateTime===this.replacementUpdateTime)return;this.replacementUpdateTime=t.updateTime;const r=t.getReplacementRegionsForTile(e.toUnwrapped());if(Yp(this.activeReplacements,r))return;this.activeReplacements=r;for(const o of this.footprints)o.hiddenFlags&=-2;const n=[];for(const o of this.activeReplacements){if(o.order<i)continue;const t=Math.max(1,Math.pow(2,o.footprintTileId.canonical.z-e.canonical.z));for(const i of this.footprints)i.min.x>o.max.x||i.max.x<o.min.x||i.min.y>o.max.y||i.max.y<o.min.y||(n.length=0,$_(this.footprintsVertices,i.footprintVertexOffset,i.footprintVertexLength,o.footprintTileId.canonical,e.canonical,n),Qp(o.footprint,n,this.footprintsIndices.uint16,i.footprintIndexOffset,i.footprintIndexLength,0,-t)&&(i.hiddenFlags|=1))}0===this.groundEffect.hiddenByLandmarkVertexArray.length&&this.groundEffect.hiddenByLandmarkVertexArray.resize(this.groundEffect.vertexArray.length);for(const o of this.footprints)this.groundEffect.updateHiddenByLandmarkRange(o.groundEffectVertexOffset,o.groundEffectVertexLength,0!==o.hiddenFlags);this.indexArrayForConflationUploaded=!1}getFootprint(e){if(void 0!==e.id){const t=this.featureFootprintLookup.get(e.id);return this.footprints[t]}return null}getHeightAtTileCoord(e,t){let i=Number.NEGATIVE_INFINITY,r=!0;const n=4*(e+Yr)*Yr+(t+Yr);if(Object.hasOwn(this.footprintLookup,n)){const e=this.footprintLookup[n];return e?{height:e.height,hidden:0!==e.hiddenFlags}:void 0}const o=new Ie(e,t);for(const s of this.footprints)e>s.max.x||s.min.x>e||t>s.max.y||s.min.y>t||s.height<=i||H_(o,this.footprintsVertices.float32.subarray(2*s.footprintVertexOffset,2*(s.footprintVertexOffset+s.footprintVertexLength)),this.footprintsIndices.uint16.subarray(s.footprintIndexOffset,s.footprintIndexOffset+s.footprintIndexLength))&&(i=s.height,this.footprintLookup[n]=s,r=0!==s.hiddenFlags);if(i!==Number.NEGATIVE_INFINITY)return{height:i,hidden:r};this.footprintLookup[n]=void 0}}function H_(e,t,i){for(let r=0;r<i.length;r+=3){const n=i[r],o=i[r+1],s=i[r+2],a=t[2*n+0],l=t[2*n+1],c=t[2*o+0],h=t[2*o+1],u=t[2*s+0],d=t[2*s+1],p=(a-u)*(e.y-d)-(l-d)*(e.x-u),f=(c-a)*(e.y-l)-(h-l)*(e.x-a);if(p<0!=f<0&&0!==p&&0!==f)continue;const m=(u-c)*(e.y-h)-(d-h)*(e.x-c);if(0===m||m<0==p+f<=0)return!0}return!1}function $_(e,t,i,r,n,o){const s=Math.pow(2,r.z-n.z);for(let a=0;a<i;a++){let i=e.float32[2*(a+t)+0],l=e.float32[2*(a+t)+1];i=(i+n.x*Yr)*s-r.x*Yr,l=(l+n.y*Yr)*s-r.y*Yr,o.push(new Ie(i,l))}}async function q_(){return it(self)?null!=U_||null!=N_?null:(null!=k_||(k_=function(e){let t,i,r,n,o;function s(){t=new Uint8Array(o.buffer),i=new Int16Array(o.buffer),r=new Int32Array(o.buffer),n=new Float32Array(o.buffer)}function a(){throw new Error("Unexpected BuildingGen error.")}const l=()=>{},c={a:{a:a,f:function(e){const i=t.length,r=Math.max(e>>>0,Math.ceil(1.2*i)),n=Math.ceil((r-i)/65536);try{return o.grow(n),s(),!0}catch(e){return!1}},g:a,b:l,c:l,d:l,e:l}};return(WebAssembly.instantiateStreaming?WebAssembly.instantiateStreaming(e,c):e.then(e=>e.arrayBuffer()).then(e=>WebAssembly.instantiate(e,c))).then(e=>{const a=e.instance.exports;return(0,a.g)(),o=a.f,s(),new z_({setStyle:a.h,setAOOptions:a.i,setMetricOptions:a.j,setStructuralOptions:a.k,setFacadeOptions:a.l,setFauxFacadeOptions:a.m,setFacadeClassifierOptions:a.n,addFeature:a.o,addFacade:a.p,generateMesh:a.q,getLastError:a.r,getOuterRingLength:a.s,getMeshCount:a.t,getPositionsPtr:a.u,getPositionsLength:a.v,getNormalsPtr:a.w,getNormalsLength:a.x,getAOPtr:a.y,getAOLength:a.z,getUVPtr:a.A,getUVLength:a.B,getFauxFacadePtr:a.C,getFauxFacadeLength:a.D,getIndicesPtr:a.E,getIndicesLength:a.F,getBuildingPart:a.G,getRingCount:a.H,getRingPtr:a.I,getRingLength:a.J,malloc:a.K,free:a.L,heapU8:t,heap16:i,heap32:r,heapF32:n})})}(fetch(mt())).then(e=>{k_=null,U_=e}).catch(e=>{Ke("Could not load building-gen"),k_=null,N_=e})),k_):null}as(G_,"BuildingBucket",{omit:["layers"]}),as(j_,"BuildingGeometry"),as(V_,"BuildingBloomGeometry");const Z_=Ya([{name:"a_pos_normal",components:2,type:"Int16"},{name:"a_data",components:4,type:"Uint8"},{name:"a_linesofar",components:1,type:"Float32"}],4),W_=Ya([{name:"a_z_offset_width",components:3,type:"Float32"}],4),X_=Ya([{name:"a_elevation_id_col",components:3,type:"Float32"}],4),Y_=Ya([{name:"a_elevation_ground_scale",components:1,type:"Float32"}],4),{members:J_}=Z_,{members:K_}=Ya([{name:"a_packed",components:3,type:"Float32"}]),{members:Q_}=Ya([{name:"a_pattern_data",components:3,type:"Float32"}]);class eg{constructor(e,t){this.width=e,this.height=t,this.nextRow=0,this.image=new id({width:e,height:t}),this.positions={},this.uploaded=!1}getDash(e,t){const i=this.getKey(e,t);return this.positions[i]}trim(){const e=this.width,t=this.height=$e(this.nextRow);this.image.resize({width:e,height:t})}getKey(e,t){return e.join(",")+t}getDashRanges(e,t,i){const r=[];let n=e.length%2==1?-e.at(-1)*i:0,o=e[0]*i,s=!0;r.push({left:n,right:o,isDash:s,zeroLength:0===e[0]});let a=e[0];for(let l=1;l<e.length;l++){s=!s;const t=e[l];n=a*i,a+=t,o=a*i,r.push({left:n,right:o,isDash:s,zeroLength:0===t})}return r}addRoundDash(e,t,i){const r=t/2;for(let n=-i;n<=i;n++){const t=this.width*(this.nextRow+i+n);let o=0,s=e[o];for(let a=0;a<this.width;a++){a/s.right>1&&(s=e[++o]);const l=Math.abs(a-s.left),c=Math.abs(a-s.right),h=Math.min(l,c);let u;const d=n/i*(r+1);if(s.isDash){const e=r-Math.abs(d);u=Math.sqrt(h*h+e*e)}else u=r-Math.sqrt(h*h+d*d);this.image.data[t+a]=Math.max(0,Math.min(255,u+128))}}}addRegularDash(e,t){for(let a=e.length-1;a>=0;--a){const t=e[a],i=e[a+1];t.zeroLength?e.splice(a,1):i&&i.isDash===t.isDash&&(i.left=t.left,e.splice(a,1))}const i=e[0],r=e.at(-1);i.isDash===r.isDash&&(i.left=r.left-this.width,r.right=i.right+this.width);const n=this.width*this.nextRow;let o=0,s=e[o];for(let a=0;a<this.width;a++){a/s.right>1&&(s=e[++o]);const i=Math.abs(a-s.left),r=Math.abs(a-s.right),l=Math.min(i,r);this.image.data[n+a]=Math.max(0,Math.min(255,(s.isDash?l:-l)+t+128))}}addDash(e,t){const i=this.getKey(e,t);if(this.positions[i])return this.positions[i];const r="round"===t,n=r?7:0,o=2*n+1;if(this.nextRow+o>this.height)return Ke("LineAtlas out of space"),null;0===e.length&&e.push(1);let s=0;for(let h=0;h<e.length;h++)e[h]<0&&(Ke("Negative value is found in line dasharray, replacing values with 0"),e[h]=0),s+=e[h];if(0!==s){const i=this.width/s,o=this.getDashRanges(e,this.width,i);r?this.addRoundDash(o,i,n):this.addRegularDash(o,"square"===t?.5*i:0)}const a=this.nextRow+n;this.nextRow+=o;const l=Math.floor(s),c={tl:[a,n],br:[l,Math.round(65535*(s-l))]};return this.positions[i]=c,c}}as(eg,"LineAtlas");const tg=ch.types,ig=Math.cos(Math.PI/180*37.5),rg=Math.cos(Math.PI/180*5);class ng{constructor(e){this.evaluationGlobals={zoom:0,lineProgress:void 0},this.elevationType="none",this.isSeaLevelReference=!1,this.showElevationIdDebug=!1,this.zoom=e.zoom,this.evaluationGlobals.zoom=this.zoom,this.overscaling=e.overscaling,this.pixelRatio=e.pixelRatio,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.projection=e.projection,this.hasPattern=!1,this.hasCrossSlope=!1,this.patternFeatures=[],this.lineClipsArray=[],this.gradients={},this.layers.forEach(e=>{this.gradients[e.id]={}}),this.layoutVertexArray=new sl,this.layoutVertexArray2=new al,this.patternVertexArray=new al,this.indexArray=new vl,this.programConfigurations=new Sc(e.layers,{zoom:e.zoom,lut:e.lut}),this.segments=new Jl,this.maxLineLength=0,this.zOffsetVertexArray=new al,this.elevationIdColVertexArray=new al,this.elevationGroundScaleVertexArray=new tl,this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.tessellationStep=e.tessellationStep?e.tessellationStep:128,this.worldview=e.worldview,this.hasAppearances=null}updateFootprints(e,t){}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){this.showElevationIdDebug=t.showElevationIdDebug,this.hasPattern=Nd("line",this.layers,this.pixelRatio,t);const n=this.layers[0].layout.get("line-sort-key");this.tileToMeter=Kc(i);const o=this.layers[0].layout.get("line-elevation-reference");if("hd-road-markup"===o)this.elevationType="road";else{const e=this.layers[0].layout.get("line-z-offset"),t=e.isConstant()&&!e.constantOr(0);this.elevationType="sea"!==o&&"ground"!==o&&t?"none":"offset","offset"===this.elevationType&&"none"===o&&Ke(`line-elevation-reference: ground is used for the layer ${this.layerIds[0]} because non-zero line-z-offset value was found.`),this.isSeaLevelReference="sea"===o}const s=this.layers[0].layout.get("line-cross-slope");this.hasCrossSlope="offset"===this.elevationType&&void 0!==s;const a=[];for(const{feature:u,id:d,index:p,sourceLayerIndex:f}of e){const e=this.layers[0]._featureFilter.needGeometry,o=lh(u,e);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),o,i))continue;const s=n?n.evaluate(o,{},i):void 0,l={id:d,properties:u.properties,type:u.type,sourceLayerIndex:f,index:p,geometry:e?o.geometry:ah(u,i,r),patterns:{},sortKey:s};a.push(l)}n&&a.sort((e,t)=>e.sortKey-t.sortKey);const{lineAtlas:l,featureIndex:c}=t,h=this.addConstantDashes(l);for(const u of a){const{geometry:r,index:n,sourceLayerIndex:o}=u;if(h&&this.addFeatureDashes(u,l),this.hasPattern){const e=Ud("line",this.layers,u,this.zoom,this.pixelRatio,t);this.patternFeatures.push(e)}else this.addFeature(u,r,n,i,l.positions,t.availableImages,t.brightness,t.elevationFeatures);c.insert(e[n].feature,r,n,o,this.index)}}addConstantDashes(e){let t=!1;for(const i of this.layers){const r=i.paint.get("line-dasharray").value,n=i.layout.get("line-cap").value;if("constant"!==r.kind||"constant"!==n.kind)t=!0;else{const t=n.value,i=r.value;if(!i)continue;e.addDash(i,t)}}return t}addFeatureDashes(e,t){const i=this.zoom;for(const r of this.layers){const n=r.paint.get("line-dasharray").value,o=r.layout.get("line-cap").value;if("constant"===n.kind&&"constant"===o.kind)continue;let s,a;if("constant"===n.kind){if(s=n.value,!s)continue}else s=n.evaluate({zoom:i},e);a="constant"===o.kind?o.value:o.evaluate({zoom:i},e),t.addDash(s,a),e.patterns[r.id]=[t.getKey(s,a)]}}update(e,t,i,r,n,o,s,a,l){this.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,l)}updateExpressions(e){this.programConfigurations.updateExpressions(e)}addFeatures(e,t,i,r,n,o){for(const s of this.patternFeatures)this.addFeature(s,s.geometry,s.index,t,i,r,o,e.elevationFeatures)}isEmpty(){return 0===this.layoutVertexArray.length}uploadPending(){return!this.uploaded||this.programConfigurations.needsUpload}upload(e){this.uploaded||(0!==this.layoutVertexArray2.length&&(this.layoutVertexBuffer2=e.createVertexBuffer(this.layoutVertexArray2,K_)),0!==this.patternVertexArray.length&&(this.patternVertexBuffer=e.createVertexBuffer(this.patternVertexArray,Q_)),!this.zOffsetVertexBuffer&&this.zOffsetVertexArray.length>0&&(this.zOffsetVertexBuffer=e.createVertexBuffer(this.zOffsetVertexArray,W_.members,!0)),!this.elevationIdColVertexBuffer&&this.elevationIdColVertexArray.length>0&&(this.elevationIdColVertexBuffer=e.createVertexBuffer(this.elevationIdColVertexArray,X_.members,!0)),!this.elevationGroundScaleVertexBuffer&&this.elevationGroundScaleVertexArray.length>0&&(this.elevationGroundScaleVertexBuffer=e.createVertexBuffer(this.elevationGroundScaleVertexArray,Y_.members,!0)),this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,J_),this.indexBuffer=e.createIndexBuffer(this.indexArray)),this.programConfigurations.upload(e),this.uploaded=!0}destroy(){this.layoutVertexBuffer&&(this.zOffsetVertexBuffer&&this.zOffsetVertexBuffer.destroy(),this.elevationIdColVertexBuffer&&this.elevationIdColVertexBuffer.destroy(),this.elevationGroundScaleVertexBuffer&&this.elevationGroundScaleVertexBuffer.destroy(),this.layoutVertexBuffer.destroy(),this.indexBuffer.destroy(),this.programConfigurations.destroy(),this.segments.destroy())}lineFeatureClips(e,t){let i,r;if(t&&t>0?(i=`mapbox_clip_start_${t}`,r=`mapbox_clip_end_${t}`):(i="mapbox_clip_start",r="mapbox_clip_end"),e.properties&&Object.hasOwn(e.properties,i)&&Object.hasOwn(e.properties,r))return{start:+e.properties[i],end:+e.properties[r]}}addFeature(e,t,i,r,n,o,s,a){const l=this.layers[0].layout,c=l.get("line-join").evaluate(e,{}),h=l.get("line-cap").evaluate(e,{}),u=l.get("line-miter-limit"),d=l.get("line-round-limit");this.lineClips=this.lineFeatureClips(e),this.lineFeature=e;const p=!(!e.properties||!Object.hasOwn(e.properties,"mapbox_line_metrics"))&&e.properties.mapbox_line_metrics;this.zOffsetValue=l.get("line-z-offset").value;const f=this.layers[0].paint.get("line-width").value;if("constant"!==f.kind&&!1===f.isLineProgressConstant&&(this.variableWidthValue=f),this.isSeaLevelReference){const e=l.get("line-elevation-ground-scale").value;"constant"===e.kind&&0===e.value||(this.elevationGroundScaleValue=e)}if("road"===this.elevationType){const i=this.layoutVertexArray.length;if(!this.addElevatedRoadFeature(e,t,r,a,c,h,u,d)){const[n,o]=this.clipRuntimeLinesToTile(t,1);for(let t=0;t<n.length;t++){const i=n[t],s=o[t],a={progress:{min:s.progress.min,max:s.progress.max},nextDir:this.computeSegNextDir(s,i),prevDir:this.computeSegPrevDir(s,i)};this.addLine(i,e,r,c,h,u,d,a,p&&s.parentIndex>0?s.parentIndex:null)}this.fillNonElevatedRoadSegment(i)}}else for(let m=0;m<t.length;m++)this.addLine(t[m],e,r,c,h,u,d,void 0,p&&m>0?m:null);this.programConfigurations.populatePaintArrays(this.layoutVertexArray.length,e,i,n,o,r,s,void 0,this.worldview)}computeSegNextDir(e,t){return e.nextPoint.sub(t.at(-2)).unit()}computeSegPrevDir(e,t){return t[1].sub(e.prevPoint).unit()}clipLinesToTile(e,t){return Wf(e,-t,-t,Yr+t,Yr+t)}clipRuntimeLinesToTile(e,t){const i=[];return[Wf(e,-t,-t,Yr+t,Yr+t,i),i]}addElevatedRoadFeature(e,t,i,r,n,o,s,a){const l=[],c=Fh.getElevationFeature(e,r);if(c){const e=this.clipLinesToTile(t,1),r=this.prepareElevatedLines(e,c,i);for(const t of r)l.push({geometry:t,elevation:c,elevationTileID:i,segment:{progress:{min:0,max:1},nextDir:void 0,prevDir:void 0}})}if(0===l.length)return!1;for(const h of l){const t=this.layoutVertexArray.length;this.addLine(h.geometry,e,i,n,o,s,a);const r=new Oh(i,h.elevationTileID);if(h.elevation){const e=this.showElevationIdDebug?Bh(h.elevation.id):null;for(let i=t;i<this.layoutVertexArray.length;i++){const t=new Ie(this.layoutVertexArray.int16[6*i]>>1,this.layoutVertexArray.int16[6*i+1]>>1),n=r.pointElevation(t,h.elevation,.05);this.updateHeightRange(n),this.zOffsetVertexArray.emplaceBack(n,0,0),e?this.elevationIdColVertexArray.emplaceBack(e[0],e[1],e[2]):this.showElevationIdDebug&&this.elevationIdColVertexArray.emplaceBack(0,0,0)}}else this.fillNonElevatedRoadSegment(t)}return!0}prepareElevatedLines(e,t,i){if(null!=t.constantHeight)return e;const r=[],n=1/Kc(i);for(const o of e)Xf(o,new zh(t,n),0,r);return r}fillNonElevatedRoadSegment(e){for(let t=e;t<this.layoutVertexArray.length;t++)this.zOffsetVertexArray.emplaceBack(0,0,0),this.showElevationIdDebug&&this.elevationIdColVertexArray.emplaceBack(0,0,0)}updateHeightRange(e){this.heightRange?(this.heightRange.min=Math.min(this.heightRange.min,e),this.heightRange.max=Math.max(this.heightRange.max,e)):this.heightRange={min:e,max:e}}addLine(e,t,i,r,n,o,s,a,l){this.distance=0,this.prevDistance=0,this.scaledDistance=0,this.totalDistance=0,this.totalFeatureLength=0,this.lineSoFar=0,this.currentVertex=void 0,this.lineClips=l?this.lineFeatureClips(t,l):this.lineClips;const c="none"===r;this.patternJoinNone=this.hasPattern&&c,this.currentLineJoinType=r,this.segmentStart=0,this.segmentStartf32=0,this.segmentPoints=[];const h=a&&a.progress.min>0,u=a&&a.progress.max<1;if(this.lineClips){let i={min:this.lineClips.start,max:this.lineClips.end},r=1;if(a){const e=this.lineClips.end-this.lineClips.start;i=function(e,t,i){return{min:ut(e.min,t,i),max:ut(e.max,t,i)}}(a.progress,{min:0,max:1},i),e>0&&(r=(i.max-i.min)/e)}const n=+t.properties.mapbox_clip_feature_len,o=+t.properties.mapbox_clip_seg_len;if(Number.isNaN(n)||Number.isNaN(o)){for(let i=0;i<e.length-1;i++)this.totalDistance+=e[i].dist(e[i+1]);const t=this.totalDistance/(i.max-i.min);this.totalFeatureLength=Number.isFinite(t)?t:0,this.lineClips.start=i.min,this.lineClips.end=i.max,this.maxLineLength=Math.max(this.maxLineLength,this.totalDistance)}else this.totalFeatureLength=n,this.distance=o*r,this.lineClips.start=i.min,this.lineClips.end=i.max,this.maxLineLength=Math.max(this.maxLineLength,this.distance);this.lineClipsArray.push(this.lineClips),this.updateScaledDistance()}const d="Polygon"===tg[t.type];let p=e.length;for(;p>=2&&e[p-1].equals(e[p-2]);)p--;let f=0;for(;f<p-1&&e[f].equals(e[f+1]);)f++;if(p<(d?3:2))return;"bevel"===r&&(o=1.05);const m=this.segments.prepareSegment(10*p,this.layoutVertexArray,this.indexArray);let _,g,y,x,v,b,w,T;a&&a.prevDir&&(b=a.prevDir.perp()),a&&a.nextDir&&(w=a.nextDir.perp()),this.e1=this.e2=-1,d&&(_=e[p-2],v=e[f].sub(_)._unit()._perp());for(let S=f;S<p;S++){if(y=S===p-1?d?e[f+1]:void 0:e[S+1],y&&e[S].equals(y))continue;v&&(x=v),_&&(g=_),_=e[S],T=this.evaluateLineProgressFeatures(g?g.dist(_):0),v=y?y.sub(_)._unit()._perp():x,x=x||v;const t=g&&y;let i=t?r:d||c?"butt":n;const a=x.x*v.x+x.y*v.y;if(c){const e=function(e){if(e.patternJoinNone){const t=e.segmentPoints.length/2,i=e.lineSoFar-e.segmentStart;for(let r=0;r<t;++r){const t=e.segmentPoints[2*r+1],n=Math.round(e.segmentPoints[2*r])+.5+.25*t;e.patternVertexArray.emplaceBack(n,i,e.segmentStart),e.patternVertexArray.emplaceBack(n,i,e.segmentStart)}e.segmentPoints.length=0}e.e1=e.e2=-1};if(t&&a<rg){this.updateDistance(g,_),this.addCurrentVertex(_,x,1,1,m,T),e(this),this.addCurrentVertex(_,v,-1,-1,m,T);continue}if(g){if(!y){this.updateDistance(g,_),this.addCurrentVertex(_,x,1,1,m,T),e(this);continue}i="miter"}}let l=x.add(v);0===l.x&&0===l.y||l._unit();const I=l.x*v.x+l.y*v.y,E=0!==I?1/I:1/0,A=2*Math.sqrt(2-2*I),M=I<ig&&g&&y,C=x.x*v.y-x.y*v.x>0,P=this.overscaling<=16?122880/(512*this.overscaling):0;if(t&&"round"===i)if(E<s)i="miter";else if(E<=2){const e=og(_,-10,8202);i="offset"===this.elevationType&&(e||this.hasCrossSlope)?"miter":"fakeround"}if("miter"===i&&E>o&&(i="bevel"),"bevel"===i&&(E>2&&(i="flipbevel"),E<o&&(i="miter")),g&&!("miter"===i&&M)&&this.updateDistance(g,_),"miter"===i)if(M){const e=_.dist(g);if(e>2*P){const t=_.sub(_.sub(g)._mult(P/e)._round());this.updateDistance(g,t),this.addCurrentVertex(t,x,0,0,m,T),g=t}this.updateDistance(g,_),l._mult(E),this.addCurrentVertex(_,l,0,0,m,T);const t=_.dist(y);if(t>2*P){const e=_.add(y.sub(_)._mult(P/t)._round());this.updateDistance(_,e),this.addCurrentVertex(e,v,0,0,m,T),_=e}}else l._mult(E),this.addCurrentVertex(_,l,0,0,m,T);else if("flipbevel"===i){if(E>100)l=v.mult(-1);else{const e=E*x.add(v).mag()/x.sub(v).mag();l._perp()._mult(e*(C?-1:1))}this.addCurrentVertex(_,l,0,0,m,T),this.addCurrentVertex(_,l.mult(-1),0,0,m,T)}else if("bevel"===i||"fakeround"===i){const e=_.dist(g);let t=1;if("offset"===this.elevationType&&"bevel"===i&&"round"!==this.currentLineJoinType&&!this.patternJoinNone&&null!=T&&g&&y){const i=4*P;e<i&&(t=Math.max(0,e/i))}null!=T&&g&&this.addCurrentVertex(_,w||x,-t,-t,m,T);const r=e<=2*P&&"bevel"!==i,n=l.mult(C?1:-1);n._mult(E);const o=v.mult(C?-1:1),s=x.mult(C?-1:1),c=this.evaluateLineProgressFeatures(this.distance);if(T??(this.addHalfVertex(_,n.x,n.y,!1,!C,0,m,c),r||this.addHalfVertex(_,n.x+2*s.x,n.y+2*s.y,!1,C,0,m,c)),"fakeround"===i){const e=Math.round(180*A/Math.PI/20);this.addHalfVertex(_,s.x,s.y,!1,C,0,m,c);for(let t=0;t<e;t++){let i=t/e;if(.5!==i){const e=i-.5;i+=i*e*(i-1)*((1.0904+a*(a*(3.55645-1.43519*a)-3.2452))*e*e+(.848013+a*(.215638*a-1.06021)))}const r=o.sub(s)._mult(i)._add(s)._unit();this.addHalfVertex(_,r.x,r.y,!1,C,0,m,c)}this.addHalfVertex(_,o.x,o.y,!1,C,0,m,c)}r||null!=T||this.addHalfVertex(_,n.x+2*o.x,n.y+2*o.y,!1,C,0,m,c),null!=T&&y&&this.addCurrentVertex(_,b||v,t,t,m,T)}else if("butt"===i)this.addCurrentVertex(_,l,0,0,m,T);else if("square"===i){if(!g){const e=h?0:-1;this.addCurrentVertex(_,l,e,e,m,T)}if(this.addCurrentVertex(_,l,0,0,m,T),g){const e=u?0:1;this.addCurrentVertex(_,l,e,e,m,T)}}else if("round"===i){if(g){const e=!t&&w?w:x;this.addCurrentVertex(_,e,0,0,m,T),!t&&u||this.addCurrentVertex(_,e,1,1,m,T,!0)}if(y){const e=!t&&b?b:v;!t&&h||this.addCurrentVertex(_,e,-1,-1,m,T,!0),this.addCurrentVertex(_,e,0,0,m,T)}}}}addVerticesTo(e,t,i,r,n,o,s,a,l,c){const h=(t.w-e.w)/this.tessellationStep|0;let u=0;const d=this.scaledDistance;if(h>1){this.lineSoFar=e.w;const i=(t.x-e.x)/h,r=(t.y-e.y)/h,n=(t.z-e.z)/h,o=(t.w-e.w)/h,s=t.x-e.x,a=t.y-e.y,d=Math.sqrt(s*s+a*a);if(0===d)return;const p=-a/d,f=s/d,m=p,_=f,g=-p,y=-f;for(let t=1;t<h;++t){e.x+=i,e.y+=r,e.z+=n,this.lineSoFar+=o,u+=o;const t=this.evaluateLineProgressFeatures(this.prevDistance+u);this.scaledDistance=(this.prevDistance+u)/this.totalDistance,this.addHalfVertex(e,m,_,c,!1,0,l,t),this.addHalfVertex(e,g,y,c,!0,0,l,t)}}this.lineSoFar=t.w,this.scaledDistance=d;const p=this.evaluateLineProgressFeatures(this.distance);this.addHalfVertex(t,i,r,c,!1,s,l,p),this.addHalfVertex(t,n,o,c,!0,-a,l,p)}evaluateLineProgressFeatures(e){if(!this.variableWidthValue&&"offset"!==this.elevationType)return null;this.evaluationGlobals.lineProgress=0,this.lineClips?this.evaluationGlobals.lineProgress=Math.min(1,(this.totalFeatureLength*this.lineClips.start+e)/this.totalFeatureLength):Ke(`line-progress evaluation for ${this.layerIds[0]} requires enabling 'lineMetrics' for the source.`);let t=0;this.variableWidthValue&&"constant"!==this.variableWidthValue.kind&&(t=this.variableWidthValue.evaluate(this.evaluationGlobals,this.lineFeature)||0);const i=this.evaluateElevationGroundScale();return"offset"!==this.elevationType?{zOffset:0,variableWidth:t,elevationGroundScale:i}:"constant"===this.zOffsetValue.kind?{zOffset:this.zOffsetValue.value,variableWidth:t,elevationGroundScale:i}:{zOffset:this.zOffsetValue.evaluate(this.evaluationGlobals,this.lineFeature)||0,variableWidth:t,elevationGroundScale:i}}evaluateElevationGroundScale(){return this.elevationGroundScaleValue?"constant"===this.elevationGroundScaleValue.kind?this.elevationGroundScaleValue.value:this.elevationGroundScaleValue.evaluate(this.evaluationGlobals,this.lineFeature)||0:0}addCurrentVertex(e,t,i,r,n,o,s=!1){const a=t.x+t.y*i,l=t.y-t.x*i,c=t.y*r-t.x,h=-t.y-t.x*r;if(null!=o){const t="offset"===this.elevationType,u="offset"===this.elevationType?2:10,d=-u,p=Yr+u,f=o.zOffset,m=new $f(e.x,e.y,f,this.lineSoFar),_=!!t&&og(e,d,p),g=this.lineSoFar,y=this.distance;if(this.currentVertex)if(_){const t=this.currentVertexIsOutside,o=this.currentVertex,u=new $f(e.x,e.y,f,this.lineSoFar);if(Zf(o,u,d,p),!og(u,d,p)){if(t){this.e1=this.e2=-1,this.distance-=o.dist(m),this.lineSoFar=o.w;const e=this.evaluateLineProgressFeatures(o.w-this.totalFeatureLength*(this.lineClips?this.lineClips.start:0));this.addHalfVertex(o,a,l,s,!1,i,n,e),this.addHalfVertex(o,c,h,s,!0,-r,n,e),this.prevDistance=this.distance}this.distance=this.prevDistance+o.dist(u),this.scaledDistance=this.distance/this.totalDistance,this.addVerticesTo(o,u,a,l,c,h,i,r,n,s),this.distance=y,this.scaledDistance=this.distance/this.totalDistance}}else{const e=this.currentVertex;if(this.currentVertexIsOutside){Zf(e,m,d,p),this.e1=this.e2=-1,this.distance-=e.dist(m),this.scaledDistance=this.distance/this.totalDistance,this.lineSoFar=e.w;const t=this.evaluateLineProgressFeatures(e.w-this.totalFeatureLength*(this.lineClips?this.lineClips.start:0));this.addHalfVertex(e,a,l,s,!1,i,n,t),this.addHalfVertex(e,c,h,s,!0,-r,n,t),this.prevDistance=this.distance,this.distance=y,this.scaledDistance=this.distance/this.totalDistance}this.addVerticesTo(e,m,a,l,c,h,i,r,n,s)}else _||(this.addHalfVertex(e,a,l,s,!1,i,n,o),this.addHalfVertex(e,c,h,s,!0,-r,n,o));this.currentVertex=m,this.currentVertexIsOutside=_,this.lineSoFar=g}else this.addHalfVertex(e,a,l,s,!1,i,n,o),this.addHalfVertex(e,c,h,s,!0,-r,n,o)}addHalfVertex({x:e,y:t},i,r,n,o,s,a,l){if(this.patternJoinNone&&(0===this.segmentPoints.length&&(this.segmentStart=this.lineSoFar,this.segmentStartf32=Math.fround(this.lineSoFar)),o||this.segmentPoints.push(this.lineSoFar-this.segmentStart,s)),this.layoutVertexArray.emplaceBack((e<<1)+(n?1:0),(t<<1)+(o?1:0),Math.round(63*i)+128,Math.round(63*r)+128,1+(0===s?0:s<0?-1:1),0,this.lineSoFar-this.segmentStartf32),this.lineClips){const e=yi(this.lineClips.start,this.lineClips.end,this.scaledDistance);this.layoutVertexArray2.emplaceBack(this.scaledDistance,this.lineClipsArray.length,e)}const c=a.vertexLength++;if(this.e1>=0&&this.e2>=0&&(this.indexArray.emplaceBack(this.e1,this.e2,c),a.primitiveLength++),o?this.e2=c:this.e1=c,null!=l&&(this.zOffsetVertexArray.emplaceBack(l.zOffset,l.variableWidth,l.variableWidth),this.showElevationIdDebug&&this.elevationIdColVertexArray.emplaceBack(0,0,0)),this.elevationGroundScaleValue){const e=l?l.elevationGroundScale:this.evaluateElevationGroundScale();this.elevationGroundScaleVertexArray.emplaceBack(e)}}updateScaledDistance(){this.lineClips?(this.scaledDistance=this.distance/this.totalDistance,this.lineSoFar=this.totalFeatureLength*this.lineClips.start+this.distance):this.lineSoFar=this.distance}updateDistance(e,t){this.prevDistance=this.distance,this.distance+=e.dist(t),this.updateScaledDistance()}}function og(e,t,i){return e.x<t||e.x>i||e.y<t||e.y>i}let sg,ag;function lg(e,t,i){return t*(Yr/(e.tileSize*Math.pow(2,i-e.tileID.overscaledZ)))}as(ng,"LineBucket",{omit:["layers","patternFeatures","currentVertex","currentVertexIsOutside"]});const cg=(e,t,i)=>(1-i)*e+i*t;function hg(e,t){return 1/lg(e,1,t.tileZoom)}function ug(e,t,i,r){return e.translatePosMatrix(r||t.tileID.projMatrix,t,i.paint.get("line-translate"),i.paint.get("line-translate-anchor"))}const dg=e=>{const t=[];pg(e)&&t.push("RENDER_LINE_DASH"),e.paint.get("line-gradient")&&t.push("RENDER_LINE_GRADIENT"),"multiply"===e.paint.get("line-blend-mode")&&t.push("LINE_BLEND_MULTIPLY"),"additive"===e.paint.get("line-blend-mode")&&t.push("LINE_BLEND_ADDITIVE");const i=e.paint.get("line-trim-offset");0===i[0]&&0===i[1]||t.push("RENDER_LINE_TRIM_OFFSET"),0!==e.paint.get("line-border-width").constantOr(1)&&t.push("RENDER_LINE_BORDER");const r="none"===e.layout.get("line-join").constantOr("miter"),n=!!e.paint.get("line-pattern").constantOr(1);return r&&n&&t.push("LINE_JOIN_NONE"),t};function pg(e){const t=e.paint.get("line-dasharray").value;return"constant"!==t.kind||t.value}let fg;const mg=()=>fg||(fg={layout:sg||(sg=new ya({"line-cap":new _a(xa.layout_line["line-cap"]),"line-join":new _a(xa.layout_line["line-join"]),"line-miter-limit":new ma(xa.layout_line["line-miter-limit"]),"line-round-limit":new ma(xa.layout_line["line-round-limit"]),"line-sort-key":new _a(xa.layout_line["line-sort-key"]),"line-z-offset":new _a(xa.layout_line["line-z-offset"]),"line-elevation-reference":new ma(xa.layout_line["line-elevation-reference"]),"line-cross-slope":new ma(xa.layout_line["line-cross-slope"]),visibility:new ma(xa.layout_line.visibility),"line-width-unit":new ma(xa.layout_line["line-width-unit"]),"line-elevation-ground-scale":new _a(xa.layout_line["line-elevation-ground-scale"])})),paint:ag||(ag=new ya({"line-opacity":new _a(xa.paint_line["line-opacity"]),"line-color":new _a(xa.paint_line["line-color"]),"line-translate":new ma(xa.paint_line["line-translate"]),"line-translate-anchor":new ma(xa.paint_line["line-translate-anchor"]),"line-width":new _a(xa.paint_line["line-width"]),"line-gap-width":new _a(xa.paint_line["line-gap-width"]),"line-offset":new _a(xa.paint_line["line-offset"]),"line-blur":new _a(xa.paint_line["line-blur"]),"line-dasharray":new _a(xa.paint_line["line-dasharray"]),"line-pattern":new _a(xa.paint_line["line-pattern"]),"line-pattern-cross-fade":new ma(xa.paint_line["line-pattern-cross-fade"]),"line-gradient":new ga(xa.paint_line["line-gradient"]),"line-trim-offset":new ma(xa.paint_line["line-trim-offset"]),"line-trim-fade-range":new ma(xa.paint_line["line-trim-fade-range"]),"line-trim-color":new ma(xa.paint_line["line-trim-color"]),"line-emissive-strength":new _a(xa.paint_line["line-emissive-strength"]),"line-border-width":new _a(xa.paint_line["line-border-width"]),"line-border-color":new _a(xa.paint_line["line-border-color"]),"line-occlusion-opacity":new ma(xa.paint_line["line-occlusion-opacity"]),"line-blend-mode":new ma(xa.paint_line["line-blend-mode"]),"line-blend-additive-clamp":new ma(xa.paint_line["line-blend-additive-clamp"]),"line-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"line-gradient-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"line-trim-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"line-border-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},fg);class _g extends _a{possiblyEvaluate(e,t){return t=new sa(Math.floor(t.zoom),{now:t.now,fadeDuration:t.fadeDuration,transition:t.transition,worldview:t.worldview}),super.possiblyEvaluate(e,t)}evaluate(e,t,i,r){return t=Object.assign({},t,{zoom:Math.floor(t.zoom)}),super.evaluate(e,t,i,r)}}let gg;function yg(e,t){return t>0?t+2*e:e}const xg=Ya([{name:"a_pos_offset",components:4,type:"Int16"},{name:"a_tex_size",components:4,type:"Uint16"},{name:"a_pixeloffset",components:4,type:"Int16"}],4),vg=Ya([{name:"a_globe_anchor",components:3,type:"Int16"},{name:"a_globe_normal",components:3,type:"Float32"}],4),bg=Ya([{name:"a_projected_pos",components:4,type:"Float32"}],4);Ya([{name:"a_fade_opacity",components:1,type:"Uint32"}],4);const wg=Ya([{name:"a_auto_z_offset",components:1,type:"Float32"}],4),Tg=Ya([{name:"a_feature_index",components:1,type:"Float32"}],4),Sg=Ya([{name:"a_x_axis",components:3,type:"Float32"},{name:"a_y_axis",components:3,type:"Float32"}]),Ig=Ya([{name:"a_texb",components:2,type:"Uint16"}]),Eg=Ya([{name:"a_placed",components:2,type:"Uint8"},{name:"a_shift",components:2,type:"Float32"},{name:"a_elevation_from_sea",components:2,type:"Float32"}]),Ag=Ya([{name:"a_size_scale",components:1,type:"Float32"},{name:"a_padding",components:2,type:"Float32"},{name:"a_auto_z_offset",components:1,type:"Float32"}]);Ya([{type:"Int16",name:"projectedAnchorX"},{type:"Int16",name:"projectedAnchorY"},{type:"Int16",name:"projectedAnchorZ"},{type:"Int16",name:"tileAnchorX"},{type:"Int16",name:"tileAnchorY"},{type:"Float32",name:"x1"},{type:"Float32",name:"y1"},{type:"Float32",name:"x2"},{type:"Float32",name:"y2"},{type:"Int16",name:"padding"},{type:"Uint32",name:"featureIndex"},{type:"Uint16",name:"sourceLayerIndex"},{type:"Uint16",name:"bucketIndex"}]);const Mg=Ya([{name:"a_pos",components:3,type:"Int16"},{name:"a_anchor_pos",components:2,type:"Int16"},{name:"a_extrude",components:2,type:"Int16"}],4),Cg=Ya([{name:"a_pos_2f",components:2,type:"Float32"},{name:"a_radius",components:1,type:"Float32"},{name:"a_flags",components:2,type:"Int16"}],4);Ya([{name:"triangle",components:3,type:"Uint16"}]),Ya([{type:"Int16",name:"projectedAnchorX"},{type:"Int16",name:"projectedAnchorY"},{type:"Int16",name:"projectedAnchorZ"},{type:"Float32",name:"tileAnchorX"},{type:"Float32",name:"tileAnchorY"},{type:"Uint16",name:"glyphStartIndex"},{type:"Uint16",name:"numGlyphs"},{type:"Uint32",name:"vertexStartIndex"},{type:"Uint32",name:"lineStartIndex"},{type:"Uint32",name:"lineLength"},{type:"Uint16",name:"segment"},{type:"Uint16",name:"lowerSize"},{type:"Uint16",name:"upperSize"},{type:"Float32",name:"lineOffsetX"},{type:"Float32",name:"lineOffsetY"},{type:"Uint8",name:"writingMode"},{type:"Uint8",name:"placedOrientation"},{type:"Uint8",name:"hidden"},{type:"Uint32",name:"crossTileID"},{type:"Int16",name:"associatedIconIndex"},{type:"Uint8",name:"flipState"}]),Ya([{type:"Float32",name:"tileAnchorX"},{type:"Float32",name:"tileAnchorY"},{type:"Int16",name:"projectedAnchorX"},{type:"Int16",name:"projectedAnchorY"},{type:"Int16",name:"projectedAnchorZ"},{type:"Int16",name:"rightJustifiedTextSymbolIndex"},{type:"Int16",name:"centerJustifiedTextSymbolIndex"},{type:"Int16",name:"leftJustifiedTextSymbolIndex"},{type:"Int16",name:"verticalPlacedTextSymbolIndex"},{type:"Int16",name:"placedIconSymbolIndex"},{type:"Int16",name:"verticalPlacedIconSymbolIndex"},{type:"Uint16",name:"key"},{type:"Uint16",name:"textBoxStartIndex"},{type:"Uint16",name:"textBoxEndIndex"},{type:"Uint16",name:"verticalTextBoxStartIndex"},{type:"Uint16",name:"verticalTextBoxEndIndex"},{type:"Uint16",name:"iconBoxStartIndex"},{type:"Uint16",name:"iconBoxEndIndex"},{type:"Uint16",name:"verticalIconBoxStartIndex"},{type:"Uint16",name:"verticalIconBoxEndIndex"},{type:"Uint16",name:"featureIndex"},{type:"Uint16",name:"numHorizontalGlyphVertices"},{type:"Uint16",name:"numVerticalGlyphVertices"},{type:"Uint16",name:"numIconVertices"},{type:"Uint16",name:"numVerticalIconVertices"},{type:"Uint16",name:"useRuntimeCollisionCircles"},{type:"Uint32",name:"crossTileID"},{type:"Float32",components:2,name:"textOffset"},{type:"Float32",name:"collisionCircleDiameter"},{type:"Float32",name:"zOffset"},{type:"Uint8",name:"hasIconTextFit"},{type:"Uint16",name:"elevationFeatureIndex"}]),Ya([{type:"Float32",name:"offsetX"}]),Ya([{type:"Int16",name:"x"},{type:"Int16",name:"y"}]);const Pg=class e{constructor(t=null,i=0,r=4096){if(this.batchIndex=i,this.headerBuffer=null,this.propertiesBuffer=null,this.blockIndicesBuffer=null,this.context=t||null,this.propsDwords=r,this.totalBytes=4*this.propsDwords,this.headerData=new Uint32Array(e.HEADER_DWORDS),this.propertiesData=new Float32Array(this.propsDwords),!e._blockIndicesTemplate){e._blockIndicesTemplate=new Uint32Array(this.propsDwords);for(let t=0;t<this.propsDwords;t++)e._blockIndicesTemplate[t]=t}this.blockIndicesData=new Uint32Array(e._blockIndicesTemplate),t&&this._initBuffers(t)}_initBuffers(t){const i=t.gl;if(this.totalBytes>t.maxUniformBlockSize)throw new Error(`UBO size ${this.totalBytes} exceeds device limit ${t.maxUniformBlockSize}`);if(this.headerBuffer=i.createBuffer(),!this.headerBuffer)throw new Error("Failed to create header UBO buffer");if(i.bindBuffer(i.UNIFORM_BUFFER,this.headerBuffer),i.bufferData(i.UNIFORM_BUFFER,e.HEADER_BYTES,i.DYNAMIC_DRAW),this.propertiesBuffer=i.createBuffer(),!this.propertiesBuffer)throw new Error("Failed to create properties UBO buffer");if(i.bindBuffer(i.UNIFORM_BUFFER,this.propertiesBuffer),i.bufferData(i.UNIFORM_BUFFER,this.totalBytes,i.DYNAMIC_DRAW),this.blockIndicesBuffer=i.createBuffer(),!this.blockIndicesBuffer)throw new Error("Failed to create block-indices UBO buffer");i.bindBuffer(i.UNIFORM_BUFFER,this.blockIndicesBuffer),i.bufferData(i.UNIFORM_BUFFER,this.totalBytes,i.DYNAMIC_DRAW),i.bindBuffer(i.UNIFORM_BUFFER,null)}writeHeader(e){const t=this.headerData;t[0]=e.dataDrivenMask,t[1]=e.zoomDependentMask,t[2]=e.dataDrivenBlockSizeVec4,t[3]=e.offsets[0],t[4]=e.offsets[1],t[5]=e.offsets[2],t[6]=e.offsets[3],t[7]=e.offsets[4],t[8]=e.offsets[5],t[9]=e.offsets[6],t[10]=e.offsets[7],t[11]=e.offsets[8]}writeDataDrivenBlock(t,i,r){const n=4*r.dataDrivenBlockSizeVec4;if(0===n)return;const o=i*n;if(o+n>this.propertiesData.length)throw new Error(`UBO write out of bounds: feature index ${i} exceeds propertiesData capacity`);for(let s=0;s<9;s++)r.dataDrivenMask&1<<s&&this._copyFromFlat(o+r.offsets[s],s,t,e.EVAL_FLAT_OFFSETS[s],r.zoomDependentMask)}static getMaxFeatureCount(e,t=4096){const i=4*e.dataDrivenBlockSizeVec4;return 0===i?1/0:Math.floor(t/i)}_copyFromFlat(e,t,i,r,n){const o=this.propertiesData,s=8===t,a=!!(n&1<<t);t<2||s&&a?(o[e]=i[r],o[e+1]=i[r+1],o[e+2]=i[r+2],o[e+3]=i[r+3]):s||a?(o[e]=i[r],o[e+1]=i[r+1]):o[e]=i[r]}upload(e){this.context||(this.context=e);const t=e.gl;this.headerBuffer&&this.propertiesBuffer&&this.blockIndicesBuffer||this._initBuffers(e),t.bindBuffer(t.UNIFORM_BUFFER,this.headerBuffer),t.bufferSubData(t.UNIFORM_BUFFER,0,this.headerData),t.bindBuffer(t.UNIFORM_BUFFER,this.propertiesBuffer),t.bufferSubData(t.UNIFORM_BUFFER,0,this.propertiesData),t.bindBuffer(t.UNIFORM_BUFFER,this.blockIndicesBuffer),t.bufferSubData(t.UNIFORM_BUFFER,0,this.blockIndicesData),t.bindBuffer(t.UNIFORM_BUFFER,null)}bind(e,t){const i=e.gl,r=(e,r,n)=>{if(!r)return;const o=i.getUniformBlockIndex(t,e);o!==i.INVALID_INDEX&&(i.uniformBlockBinding(t,o,n),i.bindBufferBase(i.UNIFORM_BUFFER,n,r))},n=3*this.batchIndex;r("SymbolPaintPropertiesHeaderUniform",this.headerBuffer,n),r("SymbolPaintPropertiesUniform",this.propertiesBuffer,n+1),r("SymbolPaintPropertiesIndexUniform",this.blockIndicesBuffer,n+2)}destroy(){if(this.context){const e=this.context.gl;this.headerBuffer&&(e.deleteBuffer(this.headerBuffer),this.headerBuffer=null),this.propertiesBuffer&&(e.deleteBuffer(this.propertiesBuffer),this.propertiesBuffer=null),this.blockIndicesBuffer&&(e.deleteBuffer(this.blockIndicesBuffer),this.blockIndicesBuffer=null)}}};Pg.HEADER_DWORDS=12,Pg.HEADER_BYTES=48,Pg.EVAL_FLAT_OFFSETS=[0,4,8,10,12,14,16,18,20],Pg.EVAL_FLAT_SIZES=[4,4,2,2,2,2,2,2,4],Pg.EVAL_FLAT_TOTAL=24,Pg._blockIndicesTemplate=null;let Dg=Pg;function Rg(e,t,i,r,n,o,s,a){return!!e&&("constant"===e.kind?"none"===e.value:"composite"===e.kind||"source"===e.kind?"none"===e.evaluate({zoom:0,brightness:o,worldview:a},t,i,n,r,s):"string"==typeof e&&"none"===e)}as(Dg,"SymbolPropertiesUBO",{omit:["headerBuffer","propertiesBuffer","blockIndicesBuffer"]});class zg{constructor(e,t,i,r,n="",o,s){this.layer=e,this.zoom=t,this.lut=i,this.isText=r,this.propDefs=this._getPropDefs(),this.worldview=n,this.maxUniformBufferBindings=o||24,this.uboSizeDwords=s||4096,this.featureVertexRangesFromId=/* @__PURE__ */new Map,this.allFeatures=[],this.ubos=[],this.featureCount=0,this.cachedHeader=null,this.maxFeaturesPerBatch=0,this.propertyHashToUBOIndex=/* @__PURE__ */new Map,this.canDeduplicate=this._checkIfAllPropertiesAreConstant(e,r),this.cachedParams=null,this.cachedParamsNext=null,this.cachedBrightness=void 0,this.cachedConstantUniforms=null,this.cachedConstantRenderZoom=null,this.cachedConstantBrightness=void 0,this.activeAppearanceByVtIndex=/* @__PURE__ */new Map,this.isLightConstant=!0,this._evalFlat=new Float32Array(Dg.EVAL_FLAT_TOTAL)}_getPropDefs(){const e=this.isText?"text":"icon";return[{name:`${e}-color`,useThemeName:`${e}-color-use-theme`,isColor:!0},{name:`${e}-halo-color`,useThemeName:`${e}-halo-color-use-theme`,isColor:!0},{name:`${e}-opacity`,useThemeName:null,isColor:!1},{name:`${e}-halo-width`,useThemeName:null,isColor:!1},{name:`${e}-halo-blur`,useThemeName:null,isColor:!1},{name:`${e}-emissive-strength`,useThemeName:null,isColor:!1},{name:`${e}-occlusion-opacity`,useThemeName:null,isColor:!1},{name:"symbol-z-offset",useThemeName:null,isColor:!1},{name:`${e}-translate`,useThemeName:null,isColor:!1,isVec2:!0}]}buildHeader(){const e=this.layer.paint,t=this.propDefs;let i=0,r=0,n=0,o=0,s=!0;const a=[0,0,0,0,0,0,0,0,0];for(let c=0;c<9;c++){const{name:l,isColor:h,isVec2:u}=t[c],d=e.get(l),p=!(!d||"function"!=typeof d.isConstant||d.isConstant()),f=this._appearancesHavePaintProperties(l),m=p||f,_=!(!d||!d.value||"composite"!==d.value.kind),g=this.layer._transitionablePaint._values[l],y=!m&&"camera"===(g&&g.value&&g.value.expression&&g.value.expression.kind);if(m){i|=1<<c,_&&(r|=1<<c);const e=d&&d.value;e&&!1===e.isLightConstant&&(s=!1),h?(o%4!=0&&(o=o+3&-4),a[c]=o,o+=4):u?_?(o%4!=0&&(o=o+3&-4),a[c]=o,o+=4):(o%4==3&&o++,a[c]=o,o+=2):(a[c]=o,o+=_?2:1)}else y&&(n|=1<<c)}const l=(0===o?0:o+3&-4)/4;return this.isLightConstant=s,{dataDrivenMask:i,zoomDependentMask:r,cameraMask:n,dataDrivenBlockSizeVec4:l,offsets:a}}get hasCameraExpression(){return!(!this.cachedHeader||!this.cachedHeader.cameraMask)}evaluateAllProperties(e,t,i,r,n,o,s){const{params:a,paramsNext:l}=this._getCachedParams(n),c={feature:e,featureState:t,canonical:i,availableImages:r,params:a,paramsNext:l,formattedSection:o},h=this.cachedHeader,u=this.propDefs;this._evalFlat||(this._evalFlat=new Float32Array(Dg.EVAL_FLAT_TOTAL));const d=this._evalFlat;for(let p=0;p<9;p++){const{name:e,useThemeName:t,isColor:i,isVec2:r}=u[p],o=!!(h&&h.zoomDependentMask&1<<p),a=Dg.EVAL_FLAT_OFFSETS[p];i?this._evaluateColorValue(e,t,c,n,o,s,d,a):r?this._evaluateTranslateValue(e,o,c,s,d,a):this._evaluateFloatValue(e,o,c,s,d,a)}return d}_evaluateColorValue(e,t,i,r,n,o,s,a){const l=this.layer.paint,c=e,h=o&&o.hasPaintProperty(c)?o.paintProperties.get(c):l.get(e),u=t,d=t&&o&&o.hasPaintProperty(u)?o.paintProperties.get(u):t?l.get(t):void 0;if(!h)return s[a]=0,s[a+1]=0,s[a+2]=0,void(s[a+3]=1);const p=Rg(d&&"string"!=typeof d?d.value:void 0,i.feature,i.featureState,i.availableImages,i.canonical,r,i.formattedSection,this.worldview)?null:this.lut;let f,m;h.isConstant()?f=m=h.constantOr(xi.transparent):(f=h.property.evaluate(h.value,i.params,i.feature,i.featureState,i.canonical,i.availableImages,h.iconImageUseTheme,i.formattedSection),m=n?h.property.evaluate(h.value,i.paramsNext,i.feature,i.featureState,i.canonical,i.availableImages,h.iconImageUseTheme,i.formattedSection):f);const _=(f||xi.transparent).toNonPremultipliedRenderColor(p);if(s[a]=Kl(255*_.r,255*_.g),s[a+1]=Kl(255*_.b,255*_.a),n){const e=(m||xi.transparent).toNonPremultipliedRenderColor(p);s[a+2]=Kl(255*e.r,255*e.g),s[a+3]=Kl(255*e.b,255*e.a)}else s[a+2]=0,s[a+3]=0}_evaluateFloatValue(e,t,i,r,n,o){const s=this.layer.paint,a=e.endsWith("opacity")?1:0,l=e,c=r&&r.hasPaintProperty(l)?r.paintProperties.get(l):s.get(e);if(!c)return n[o]=a,void(n[o+1]=0);if(c.isConstant())return n[o]=c.constantOr(a),void(n[o+1]=0);const h=c.property.evaluate(c.value,i.params,i.feature,i.featureState,i.canonical,i.availableImages,c.iconImageUseTheme,i.formattedSection);if(n[o]=null!=h?h:a,t){const e=c.property.evaluate(c.value,i.paramsNext,i.feature,i.featureState,i.canonical,i.availableImages,c.iconImageUseTheme,i.formattedSection);n[o+1]=null!=e?e:a}else n[o+1]=0}_evaluateTranslateValue(e,t,i,r,n,o){const s=this.layer.paint,a=e,l=r&&r.hasPaintProperty(a)?r.paintProperties.get(a):s.get(e);if(!l)return n[o]=0,n[o+1]=0,n[o+2]=0,void(n[o+3]=0);if("function"!=typeof l.isConstant){const e=l||[0,0];return n[o]=e[0],n[o+1]=e[1],n[o+2]=0,void(n[o+3]=0)}if(l.isConstant()){const e=l.constantOr([0,0]);return n[o]=e[0],n[o+1]=e[1],n[o+2]=0,void(n[o+3]=0)}const c=l.property.evaluate(l.value,i.params,i.feature,i.featureState,i.canonical,i.availableImages,l.iconImageUseTheme,i.formattedSection)||[0,0];if(n[o]=c[0],n[o+1]=c[1],t){const e=l.property.evaluate(l.value,i.paramsNext,i.feature,i.featureState,i.canonical,i.availableImages,l.iconImageUseTheme,i.formattedSection)||[0,0];n[o+2]=e[0],n[o+3]=e[1]}else n[o+2]=0,n[o+3]=0}_getCachedParams(e){return this.cachedParams&&this.cachedParamsNext&&this.cachedBrightness===e||(this.cachedParams=new sa(this.zoom,{brightness:e,worldview:this.worldview}),this.cachedParamsNext=new sa(this.zoom+1,{brightness:e,worldview:this.worldview}),this.cachedBrightness=e),{params:this.cachedParams,paramsNext:this.cachedParamsNext}}_appearancesHavePaintProperties(e){return this.layer.getAppearances().some(void 0!==e?t=>t.hasPaintProperty(e):this.isText?e=>e.hasTextPaintProperties():e=>e.hasIconPaintProperties())}_checkIfAllPropertiesAreConstant(e,t){const i=e.paint,r=t?"text":"icon",n=[`${r}-color`,`${r}-halo-color`,`${r}-opacity`,`${r}-halo-width`,`${r}-halo-blur`,`${r}-emissive-strength`,`${r}-occlusion-opacity`,"symbol-z-offset",`${r}-translate`];for(const o of n){const e=i.get(o);if(e&&"object"==typeof e&&"isConstant"in e&&!e.isConstant())return!1}return!this._appearancesHavePaintProperties()}_hashDataDrivenValues(e,t){if(0===t.dataDrivenMask)return"";const i=[];for(let r=0;r<this.propDefs.length;r++){if(!(t.dataDrivenMask&1<<r))continue;const n=Dg.EVAL_FLAT_OFFSETS[r],o=Dg.EVAL_FLAT_SIZES[r];let s=String(e[n]);for(let t=1;t<o;t++)s+=`,${String(e[n+t])}`;i.push(s)}return i.join("|")}getCurrentBatchIndex(){return this.cachedHeader&&0!==this.maxFeaturesPerBatch?Math.floor(this.featureCount/this.maxFeaturesPerBatch):0}populateUBO(e,t,i,r,n,o,s){const a=e.id;if(!this.cachedHeader){this.cachedHeader=this.buildHeader();const e=Dg.getMaxFeatureCount(this.cachedHeader,this.uboSizeDwords);this.maxFeaturesPerBatch=isFinite(e)?e:Number.MAX_SAFE_INTEGER}const l=this.cachedHeader,c=this.evaluateAllProperties(e,{},i,r,n,o);if(this.canDeduplicate){const e=this._hashDataDrivenValues(c,l),i=this.propertyHashToUBOIndex.get(e);if(void 0!==i){const e=isFinite(this.maxFeaturesPerBatch)?Math.floor(i/this.maxFeaturesPerBatch):0,r=isFinite(this.maxFeaturesPerBatch)?i%this.maxFeaturesPerBatch:i,n={batchIndex:e,localFeatureIndex:r,vtFeatureIndex:t,featureId:a};return this.allFeatures.push(n),null!=a&&(this.featureVertexRangesFromId.has(a)||this.featureVertexRangesFromId.set(a,[]),this.featureVertexRangesFromId.get(a).push(n)),r}this.propertyHashToUBOIndex.set(e,this.featureCount)}const h=this.featureCount++,u=isFinite(this.maxFeaturesPerBatch)?Math.floor(h/this.maxFeaturesPerBatch):0,d=isFinite(this.maxFeaturesPerBatch)?h%this.maxFeaturesPerBatch:h,p=s?s.maxUniformBufferBindings:this.maxUniformBufferBindings;if(3*u+2>=p){Ke(`Too many symbol features: batch ${u} requires binding points up to ${3*u+2}, device limit ${p}. Some features will render incorrectly.`);const e={batchIndex:0,localFeatureIndex:0,vtFeatureIndex:t,featureId:a};return this.allFeatures.push(e),null!=a&&(this.featureVertexRangesFromId.has(a)||this.featureVertexRangesFromId.set(a,[]),this.featureVertexRangesFromId.get(a).push(e)),0}this.ubos[u]||(this.ubos[u]=new Dg(s,u,this.uboSizeDwords),this.ubos[u].writeHeader(l)),this.ubos[u].writeDataDrivenBlock(c,d,l);const f={batchIndex:u,localFeatureIndex:d,vtFeatureIndex:t,featureId:a};return this.allFeatures.push(f),null!=a&&(this.featureVertexRangesFromId.has(a)||this.featureVertexRangesFromId.set(a,[]),this.featureVertexRangesFromId.get(a).push(f)),d}updateFeatures(e,t,i,r,n,o,s){if(this.layer=t,this.cachedConstantUniforms=null,!this.cachedHeader)return;const a=this.cachedHeader;for(const l of e){const e=this.featureVertexRangesFromId.get(l);if(!e)continue;const t=o[l]||{};for(const o of e){if(!i)continue;const e=i.feature(o.vtFeatureIndex);if(!e)continue;const c={type:e.type,id:l,properties:e.properties||{},geometry:[]},h=this.activeAppearanceByVtIndex?this.activeAppearanceByVtIndex.get(o.vtFeatureIndex):void 0,u=this.evaluateAllProperties(c,t,r,n,s,void 0,h);this.ubos[o.batchIndex]&&this.ubos[o.batchIndex].writeDataDrivenBlock(u,o.localFeatureIndex,a)}}}updateDynamicExpressions(e,t,i,r,n,o){if(this.layer=e,this.cachedConstantUniforms=null,!this.cachedHeader)return;if(0===this.cachedHeader.dataDrivenMask)return;const s=this.cachedHeader;for(const a of this.allFeatures){if(!t)continue;const e=t.feature(a.vtFeatureIndex);if(!e)continue;const l=null!=a.featureId&&n[a.featureId]||{},c={type:e.type,id:a.featureId,properties:e.properties||{},geometry:[]},h=this.activeAppearanceByVtIndex?this.activeAppearanceByVtIndex.get(a.vtFeatureIndex):void 0,u=this.evaluateAllProperties(c,l,i,r,o,void 0,h);this.ubos[a.batchIndex]&&this.ubos[a.batchIndex].writeDataDrivenBlock(u,a.localFeatureIndex,s)}}updateFeaturePaintForAppearance(e,t,i,r,n,o,s){if(!this.layer)return!1;if(this.activeAppearanceByVtIndex||(this.activeAppearanceByVtIndex=/* @__PURE__ */new Map),this.activeAppearanceByVtIndex.set(e,s||null),!this.cachedHeader)return!1;const a=this.cachedHeader;if(0===a.dataDrivenMask)return!1;let l=!1;for(const c of this.allFeatures){if(c.vtFeatureIndex!==e)continue;const h=this.evaluateAllProperties(t,i,r,n,o,void 0,s);this.ubos[c.batchIndex]&&(this.ubos[c.batchIndex].writeDataDrivenBlock(h,c.localFeatureIndex,a),l=!0)}return l}getConstantUniformValues(e,t){const i=this.cachedHeader,r=!(!i||!i.cameraMask);if(this.cachedConstantUniforms&&this.cachedConstantBrightness===t&&(!r||this.cachedConstantRenderZoom===e))return this.cachedConstantUniforms;const n=this.layer.paint,o=this.propDefs,s=r?new sa(e,{brightness:t,worldview:this.worldview}):null,a={type:1,id:void 0,properties:{},geometry:[]},l=e=>{const r=o[e],l=n.get(r.name);if(!l)return[0,0,0,1];const c=r.useThemeName?n.get(r.useThemeName):void 0,h=Rg(c&&"string"!=typeof c?c.value:void 0,a,{},[],void 0,t,void 0,this.worldview)?null:this.lut;let u;u=i&&i.cameraMask&1<<e&&s?l.property.evaluate(l.value,s,a,{},void 0,[]):l.constantOr(xi.transparent);const d=(u||xi.transparent).toNonPremultipliedRenderColor(h);return[d.r,d.g,d.b,d.a]},c=(e,t)=>{const r=n.get(o[e].name);if(!r)return t;if(i&&i.cameraMask&1<<e&&s){const e=r.property.evaluate(r.value,s,a,{},void 0,[]);return null!=e?e:t}return r.constantOr(t)},h={fill_np_color:l(0),halo_np_color:l(1),opacity:c(2,1),halo_width:c(3,0),halo_blur:c(4,0),emissive_strength:c(5,0),occlusion_opacity:c(6,1),z_offset:c(7,0)};return this.cachedConstantUniforms=h,this.cachedConstantRenderZoom=e,this.cachedConstantBrightness=t,h}upload(e){for(const t of this.ubos)t.upload(e)}bind(e,t,i=0){this.ubos[i]&&this.ubos[i].bind(e,t)}destroy(){for(const e of this.ubos)e.destroy();this.ubos=[],this.featureVertexRangesFromId.clear(),this.allFeatures=[],this.featureCount=0,this.cachedHeader=null,this.maxFeaturesPerBatch=0,this.propertyHashToUBOIndex&&this.propertyHashToUBOIndex.clear()}}as(zg,"SymbolPropertyBinderUBO",{omit:["layer","cachedParams","cachedParamsNext","cachedBrightness","propertyHashToUBOIndex","cachedConstantUniforms","cachedConstantRenderZoom","cachedConstantBrightness","activeAppearanceByVtIndex","_evalFlat"]});var Lg=24;function Fg(e,t,i){return e.sections.forEach(e=>{e.text=function(e,t,i){const r=t.layout.get("text-transform").evaluate(i,{});return"uppercase"===r?e=e.toLocaleUpperCase():"lowercase"===r&&(e=e.toLocaleLowerCase()),na.applyArabicShaping&&(e=na.applyArabicShaping(e)),e}(e.text,t,i)}),e}const Og={"!":"︕","#":"#",$:"$","%":"%","&":"&","(":"︵",")":"︶","*":"*","+":"+",",":"︐","-":"︲",".":"・","/":"/",":":"︓",";":"︔","<":"︿","=":"=",">":"﹀","?":"︖","@":"@","[":"﹇","\\":"\","]":"﹈","^":"^",_:"︳","`":"`","{":"︷","|":"―","}":"︸","~":"~","¢":"¢","£":"£","¥":"¥","¦":"¦","¬":"¬","¯":" ̄","–":"︲","—":"︱","‘":"﹃","’":"﹄","“":"﹁","”":"﹂","…":"︙","‧":"・","₩":"₩","、":"︑","。":"︒","〈":"︿","〉":"﹀","《":"︽","》":"︾","「":"﹁","」":"﹂","『":"﹃","』":"﹄","【":"︻","】":"︼","〔":"︹","〕":"︺","〖":"︗","〗":"︘","!":"︕","(":"︵",")":"︶",",":"︐","-":"︲",".":"・",":":"︓",";":"︔","<":"︿",">":"﹀","?":"︖","[":"﹇","]":"﹈","_":"︳","{":"︷","|":"―","}":"︸","⦅":"︵","⦆":"︶","。":"︒","「":"﹁","」":"﹂","←":"↑","→":"↓"};function Bg(e){return"︶"===e||"﹈"===e||"︸"===e||"﹄"===e||"﹂"===e||"︾"===e||"︼"===e||"︺"===e||"︘"===e||"﹀"===e||"︐"===e||"︓"===e||"︔"===e||"`"===e||" ̄"===e||"︑"===e||"︒"===e}function kg(e){return"︵"===e||"﹇"===e||"︷"===e||"﹃"===e||"﹁"===e||"︽"===e||"︻"===e||"︹"===e||"︗"===e||"︿"===e}const Ng=4294967296,Ug=1/Ng,Vg="undefined"==typeof TextDecoder?null:new TextDecoder("utf-8");let jg=class{constructor(e=new Uint8Array(16)){this.buf=ArrayBuffer.isView(e)?e:new Uint8Array(e),this.dataView=new DataView(this.buf.buffer),this.pos=0,this.type=0,this.length=this.buf.length}readFields(e,t,i=this.length){for(;this.pos<i;){const i=this.readVarint(),r=i>>3,n=this.pos;this.type=7&i,e(r,t,this),this.pos===n&&this.skip(i)}return t}readMessage(e,t){return this.readFields(e,t,this.readVarint()+this.pos)}readFixed32(){const e=this.dataView.getUint32(this.pos,!0);return this.pos+=4,e}readSFixed32(){const e=this.dataView.getInt32(this.pos,!0);return this.pos+=4,e}readFixed64(){const e=this.dataView.getUint32(this.pos,!0)+this.dataView.getUint32(this.pos+4,!0)*Ng;return this.pos+=8,e}readSFixed64(){const e=this.dataView.getUint32(this.pos,!0)+this.dataView.getInt32(this.pos+4,!0)*Ng;return this.pos+=8,e}readFloat(){const e=this.dataView.getFloat32(this.pos,!0);return this.pos+=4,e}readDouble(){const e=this.dataView.getFloat64(this.pos,!0);return this.pos+=8,e}readVarint(e){const t=this.buf;let i,r;return r=t[this.pos++],i=127&r,r<128?i:(r=t[this.pos++],i|=(127&r)<<7,r<128?i:(r=t[this.pos++],i|=(127&r)<<14,r<128?i:(r=t[this.pos++],i|=(127&r)<<21,r<128?i:(r=t[this.pos],i|=(15&r)<<28,function(e,t,i){const r=i.buf;let n,o;if(o=r[i.pos++],n=(112&o)>>4,o<128)return Gg(e,n,t);if(o=r[i.pos++],n|=(127&o)<<3,o<128)return Gg(e,n,t);if(o=r[i.pos++],n|=(127&o)<<10,o<128)return Gg(e,n,t);if(o=r[i.pos++],n|=(127&o)<<17,o<128)return Gg(e,n,t);if(o=r[i.pos++],n|=(127&o)<<24,o<128)return Gg(e,n,t);if(o=r[i.pos++],n|=(1&o)<<31,o<128)return Gg(e,n,t);throw new Error("Expected varint not more than 10 bytes")}(i,e,this)))))}readVarint64(){return this.readVarint(!0)}readSVarint(){const e=this.readVarint();return e%2==1?(e+1)/-2:e/2}readBoolean(){return Boolean(this.readVarint())}readString(){const e=this.readVarint()+this.pos,t=this.pos;return this.pos=e,e-t>=12&&Vg?Vg.decode(this.buf.subarray(t,e)):function(e,t,i){let r="",n=t;for(;n<i;){const t=e[n];let o,s,a,l=null,c=t>239?4:t>223?3:t>191?2:1;if(n+c>i)break;1===c?t<128&&(l=t):2===c?(o=e[n+1],128==(192&o)&&(l=(31&t)<<6|63&o,l<=127&&(l=null))):3===c?(o=e[n+1],s=e[n+2],128==(192&o)&&128==(192&s)&&(l=(15&t)<<12|(63&o)<<6|63&s,(l<=2047||l>=55296&&l<=57343)&&(l=null))):4===c&&(o=e[n+1],s=e[n+2],a=e[n+3],128==(192&o)&&128==(192&s)&&128==(192&a)&&(l=(15&t)<<18|(63&o)<<12|(63&s)<<6|63&a,(l<=65535||l>=1114112)&&(l=null))),null===l?(l=65533,c=1):l>65535&&(l-=65536,r+=String.fromCharCode(l>>>10&1023|55296),l=56320|1023&l),r+=String.fromCharCode(l),n+=c}return r}(this.buf,t,e)}readBytes(){const e=this.readVarint()+this.pos,t=this.buf.subarray(this.pos,e);return this.pos=e,t}readPackedVarint(e=[],t){const i=this.readPackedEnd();for(;this.pos<i;)e.push(this.readVarint(t));return e}readPackedSVarint(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readSVarint());return e}readPackedBoolean(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readBoolean());return e}readPackedFloat(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readFloat());return e}readPackedDouble(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readDouble());return e}readPackedFixed32(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readFixed32());return e}readPackedSFixed32(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readSFixed32());return e}readPackedFixed64(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readFixed64());return e}readPackedSFixed64(e=[]){const t=this.readPackedEnd();for(;this.pos<t;)e.push(this.readSFixed64());return e}readPackedEnd(){return 2===this.type?this.readVarint()+this.pos:this.pos+1}skip(e){const t=7&e;if(0===t)for(;this.buf[this.pos++]>127;);else if(2===t)this.pos=this.readVarint()+this.pos;else if(5===t)this.pos+=4;else{if(1!==t)throw new Error(`Unimplemented type: ${t}`);this.pos+=8}}writeTag(e,t){this.writeVarint(e<<3|t)}realloc(e){let t=this.length||16;for(;t<this.pos+e;)t*=2;if(t!==this.length){const e=new Uint8Array(t);e.set(this.buf),this.buf=e,this.dataView=new DataView(e.buffer),this.length=t}}finish(){return this.length=this.pos,this.pos=0,this.buf.subarray(0,this.length)}writeFixed32(e){this.realloc(4),this.dataView.setInt32(this.pos,e,!0),this.pos+=4}writeSFixed32(e){this.realloc(4),this.dataView.setInt32(this.pos,e,!0),this.pos+=4}writeFixed64(e){this.realloc(8),this.dataView.setInt32(this.pos,-1&e,!0),this.dataView.setInt32(this.pos+4,Math.floor(e*Ug),!0),this.pos+=8}writeSFixed64(e){this.realloc(8),this.dataView.setInt32(this.pos,-1&e,!0),this.dataView.setInt32(this.pos+4,Math.floor(e*Ug),!0),this.pos+=8}writeVarint(e){(e=+e||0)>268435455||e<0?function(e,t){let i,r;if(e>=0?(i=e%4294967296|0,r=e/4294967296|0):(i=~(-e%4294967296),r=~(-e/4294967296),4294967295^i?i=i+1|0:(i=0,r=r+1|0)),e>=0x10000000000000000||e<-0x10000000000000000)throw new Error("Given varint doesn't fit into 10 bytes");t.realloc(10),function(e,t,i){i.buf[i.pos++]=127&e|128,e>>>=7,i.buf[i.pos++]=127&e|128,e>>>=7,i.buf[i.pos++]=127&e|128,e>>>=7,i.buf[i.pos++]=127&e|128,i.buf[i.pos]=127&(e>>>=7)}(i,0,t),function(e,t){const i=(7&e)<<4;t.buf[t.pos++]|=i|((e>>>=3)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e|((e>>>=7)?128:0),e&&(t.buf[t.pos++]=127&e)))))}(r,t)}(e,this):(this.realloc(4),this.buf[this.pos++]=127&e|(e>127?128:0),e<=127||(this.buf[this.pos++]=127&(e>>>=7)|(e>127?128:0),e<=127||(this.buf[this.pos++]=127&(e>>>=7)|(e>127?128:0),e<=127||(this.buf[this.pos++]=e>>>7&127))))}writeSVarint(e){this.writeVarint(e<0?2*-e-1:2*e)}writeBoolean(e){this.writeVarint(+e)}writeString(e){e=String(e),this.realloc(4*e.length),this.pos++;const t=this.pos;this.pos=function(e,t,i){for(let r,n,o=0;o<t.length;o++){if(r=t.charCodeAt(o),r>55295&&r<57344){if(!n){r>56319||o+1===t.length?(e[i++]=239,e[i++]=191,e[i++]=189):n=r;continue}if(r<56320){e[i++]=239,e[i++]=191,e[i++]=189,n=r;continue}r=n-55296<<10|r-56320|65536,n=null}else n&&(e[i++]=239,e[i++]=191,e[i++]=189,n=null);r<128?e[i++]=r:(r<2048?e[i++]=r>>6|192:(r<65536?e[i++]=r>>12|224:(e[i++]=r>>18|240,e[i++]=r>>12&63|128),e[i++]=r>>6&63|128),e[i++]=63&r|128)}return i}(this.buf,e,this.pos);const i=this.pos-t;i>=128&&Hg(t,i,this),this.pos=t-1,this.writeVarint(i),this.pos+=i}writeFloat(e){this.realloc(4),this.dataView.setFloat32(this.pos,e,!0),this.pos+=4}writeDouble(e){this.realloc(8),this.dataView.setFloat64(this.pos,e,!0),this.pos+=8}writeBytes(e){const t=e.length;this.writeVarint(t),this.realloc(t);for(let i=0;i<t;i++)this.buf[this.pos++]=e[i]}writeRawMessage(e,t){this.pos++;const i=this.pos;e(t,this);const r=this.pos-i;r>=128&&Hg(i,r,this),this.pos=i-1,this.writeVarint(r),this.pos+=r}writeMessage(e,t,i){this.writeTag(e,2),this.writeRawMessage(t,i)}writePackedVarint(e,t){t.length&&this.writeMessage(e,$g,t)}writePackedSVarint(e,t){t.length&&this.writeMessage(e,qg,t)}writePackedBoolean(e,t){t.length&&this.writeMessage(e,Xg,t)}writePackedFloat(e,t){t.length&&this.writeMessage(e,Zg,t)}writePackedDouble(e,t){t.length&&this.writeMessage(e,Wg,t)}writePackedFixed32(e,t){t.length&&this.writeMessage(e,Yg,t)}writePackedSFixed32(e,t){t.length&&this.writeMessage(e,Jg,t)}writePackedFixed64(e,t){t.length&&this.writeMessage(e,Kg,t)}writePackedSFixed64(e,t){t.length&&this.writeMessage(e,Qg,t)}writeBytesField(e,t){this.writeTag(e,2),this.writeBytes(t)}writeFixed32Field(e,t){this.writeTag(e,5),this.writeFixed32(t)}writeSFixed32Field(e,t){this.writeTag(e,5),this.writeSFixed32(t)}writeFixed64Field(e,t){this.writeTag(e,1),this.writeFixed64(t)}writeSFixed64Field(e,t){this.writeTag(e,1),this.writeSFixed64(t)}writeVarintField(e,t){this.writeTag(e,0),this.writeVarint(t)}writeSVarintField(e,t){this.writeTag(e,0),this.writeSVarint(t)}writeStringField(e,t){this.writeTag(e,2),this.writeString(t)}writeFloatField(e,t){this.writeTag(e,5),this.writeFloat(t)}writeDoubleField(e,t){this.writeTag(e,1),this.writeDouble(t)}writeBooleanField(e,t){this.writeVarintField(e,+t)}};function Gg(e,t,i){return i?4294967296*t+(e>>>0):4294967296*(t>>>0)+(e>>>0)}function Hg(e,t,i){const r=t<=16383?1:t<=2097151?2:t<=268435455?3:Math.floor(Math.log(t)/(7*Math.LN2));i.realloc(r);for(let n=i.pos-1;n>=e;n--)i.buf[n+r]=i.buf[n]}function $g(e,t){for(let i=0;i<e.length;i++)t.writeVarint(e[i])}function qg(e,t){for(let i=0;i<e.length;i++)t.writeSVarint(e[i])}function Zg(e,t){for(let i=0;i<e.length;i++)t.writeFloat(e[i])}function Wg(e,t){for(let i=0;i<e.length;i++)t.writeDouble(e[i])}function Xg(e,t){for(let i=0;i<e.length;i++)t.writeBoolean(e[i])}function Yg(e,t){for(let i=0;i<e.length;i++)t.writeFixed32(e[i])}function Jg(e,t){for(let i=0;i<e.length;i++)t.writeSFixed32(e[i])}function Kg(e,t){for(let i=0;i<e.length;i++)t.writeFixed64(e[i])}function Qg(e,t){for(let i=0;i<e.length;i++)t.writeSFixed64(e[i])}function ey(e,t,i){t.glyphs=[],1===e&&i.readMessage(ty,t)}function ty(e,t,i){if(3===e){const{id:e,bitmap:r,width:n,height:o,left:s,top:a,advance:l}=i.readMessage(iy,{});t.glyphs.push({id:e,bitmap:new id({width:n+6,height:o+6},r),metrics:{width:n,height:o,left:s,top:a,advance:l}})}else 4===e?t.ascender=i.readSVarint():5===e&&(t.descender=i.readSVarint())}function iy(e,t,i){1===e?t.id=i.readVarint():2===e?t.bitmap=i.readBytes():3===e?t.width=i.readVarint():4===e?t.height=i.readVarint():5===e?t.left=i.readSVarint():6===e?t.top=i.readSVarint():7===e&&(t.advance=i.readVarint())}const ry={horizontal:1,vertical:2,horizontalOnly:3};class ny{constructor(){this.scale=1,this.fontStack="",this.image=null}static forText(e,t){const i=new ny;return i.scale=e||1,i.fontStack=t,i}static forImage(e){const t=new ny;return t.image=e,t}}class oy{constructor(){this.text="",this.sectionIndex=[],this.sections=[],this.imageSectionID=null}static fromFeature(e,t,i,r=1){const n=new oy;for(let o=0;o<e.sections.length;o++){const s=e.sections[o];s.image?n.addImageSection(s,i,r):n.addTextSection(s,t)}return n}length(){return this.text.length}getSection(e){return this.sections[this.sectionIndex[e]]}getSections(){return this.sections}getSectionIndex(e){return this.sectionIndex[e]}getCodePoint(e){return this.text.codePointAt(e)}verticalizePunctuation(e){this.text=function(e,t){let i="";for(let r=0;r<e.length;r++){const n=e.charCodeAt(r+1)||null,o=e.charCodeAt(r-1)||null;i+=!t&&(n&&Hs(n)&&!Og[e[r+1]]||o&&Hs(o)&&!Og[e[r-1]])||!Og[e[r]]?e[r]:Og[e[r]]}return i}(this.text,e)}trim(){let e=0;for(let i=0;i<this.text.length&&ay[this.text.charCodeAt(i)];i++)e++;let t=this.text.length;for(let i=this.text.length-1;i>=0&&i>=e&&ay[this.text.charCodeAt(i)];i--)t--;this.text=this.text.substring(e,t),this.sectionIndex=this.sectionIndex.slice(e,t)}substring(e,t){const i=new oy;return i.text=this.text.substring(e,t),i.sectionIndex=this.sectionIndex.slice(e,t),i.sections=this.sections,i}toString(){return this.text}getMaxScale(){return this.sectionIndex.reduce((e,t)=>Math.max(e,this.sections[t].scale),0)}addTextSection(e,t){this.text+=e.text,this.sections.push(ny.forText(e.scale,e.fontStack||t));const i=this.sections.length-1;for(let r=0;r<e.text.length;++r)this.sectionIndex.push(i)}addImageSection(e,t,i=1){const r=e.image?e.image.getPrimary():null;if(!r)return void Ke("Can't add FormattedSection with an empty image.");r.scaleSelf(t*i);const n=this.getNextImageSectionCharCode();n?(this.text+=String.fromCodePoint(n),this.sections.push(ny.forImage(r)),this.sectionIndex.push(this.sections.length-1)):Ke("Reached maximum number of images 6401")}getNextImageSectionCharCode(){return this.imageSectionID?this.imageSectionID>=63743?null:++this.imageSectionID:(this.imageSectionID=57344,this.imageSectionID)}}function sy(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m=1,_=1){const g=oy.fromFeature(e,n,m,_);u===ry.vertical&&g.verticalizePunctuation(d);let y=[];const x=function(e,t,i,r,n,o,s=1){if(!e)return[];const a=[],l=function(e,t,i,r,n,o,s=1){let a=0;for(let l=0;l<e.length();l++){const i=e.getSection(l);a+=cy(e.getCodePoint(l),i,r,n,t,o,s)}return a/Math.max(1,Math.ceil(a/i))}(e,t,i,r,n,o,s),c=e.text.includes("");let h=0;for(let u=0;u<e.length();u++){const i=e.getSection(u),d=e.getCodePoint(u);if(ay[d]||(h+=cy(d,i,r,n,t,o,s)),u<e.length()-1){const t=Vs(d);(ly[d]||t||i.image)&&a.push(dy(u+1,h,l,a,uy(d,e.getCodePoint(u+1),t&&c),!1))}}return py(dy(e.length(),h,l,a,0,!0))}(g,c,o,t,r,p,_),{processBidirectionalText:v,processStyledBidirectionalText:b}=na;if(v&&1===g.sections.length){const e=v(g.toString(),x);for(const t of e){const e=new oy;e.text=t,e.sections=g.sections;for(let i=0;i<t.length;i++)e.sectionIndex.push(0);y.push(e)}}else if(b){const e=b(g.text,g.sectionIndex,x);for(const t of e){const e=new oy;e.text=t[0],e.sectionIndex=t[1],e.sections=g.sections,y.push(e)}}else y=function(e,t){const i=[],r=e.text;let n=0;for(const o of t)i.push(e.substring(n,o)),n=o;return n<r.length&&i.push(e.substring(n,r.length)),i}(g,x);const w=[],T={positionedLines:w,text:g.toString(),top:h[1],bottom:h[1],left:h[0],right:h[0],writingMode:u,iconsInText:!1,verticalizable:!1,hasBaseline:!1};if(function(e,t,i,r,n,o,s,a,l,c,h,u,d=1){let p=0,f=0,m=0;const _="right"===a?1:"left"===a?0:.5;let g=!1;for(const w of n){const e=w.getSections();for(const i of e){if(i.image)continue;const e=t[i.fontStack];if(e&&(g=void 0!==e.ascender&&void 0!==e.descender,!g))break}if(!g)break}let y=0;for(const w of n){w.trim();const n=w.getMaxScale(),s=(n-1)*Lg,a={positionedGlyphs:[],lineOffset:0};e.positionedLines[y]=a;const x=a.positionedGlyphs;let v=0;if(!w.length()){f+=o,++y;continue}let b=0,T=0;for(let o=0;o<w.length();o++){const s=w.getSection(o),a=w.getSectionIndex(o),m=w.getCodePoint(o);let _=s.scale,y=null,S=null,I=null,E=Lg,A=0,M=l;M===ry.vertical&&Gs(m)&&(M=ry.horizontal);const C=!(M===ry.horizontal||!h&&!js(m)||h&&(ay[m]||$s(m)));if(s.image){const t=r.get(s.image.toString());if(!t)continue;I=s.image,e.iconsInText=e.iconsInText||!0,S=t.paddedRect;const i=t.displaySize,o=i[0]*d,a=i[1]*d;_=_*Lg/u,y={width:o,height:a,left:0,top:-3,advance:C?a:o,localGlyph:!1},A=g?-y.height*_:n*Lg-17-a*_,E=y.advance;const l=(C?o:a)*_-Lg*n;l>0&&l>v&&(v=l)}else{const e=i[s.fontStack];if(!e)continue;e[m]&&(S=e[m]);const r=t[s.fontStack];if(!r)continue;const o=r.glyphs[m];if(!o)continue;if(y=o.metrics,E=8203!==m?Lg:0,g){const e=void 0!==r.ascender?Math.abs(r.ascender):0,t=void 0!==r.descender?Math.abs(r.descender):0,i=(e+t)*_;b<i&&(b=i,T=(e-t)/2*_),A=-e*_}else A=(n-_)*Lg-17}C?(e.verticalizable=!0,x.push({glyph:m,image:I,x:p,y:f+A,vertical:C,scale:_,localGlyph:y.localGlyph,fontStack:s.fontStack,sectionIndex:a,metrics:y,rect:S}),p+=E*_+c):(x.push({glyph:m,image:I,x:p,y:f+A,vertical:C,scale:_,localGlyph:y.localGlyph,fontStack:s.fontStack,sectionIndex:a,metrics:y,rect:S}),p+=y.advance*_+c)}0!==x.length&&(m=Math.max(p-c,m),g?my(x,_,v,T,o*n/2):my(x,_,v,0,o/2)),p=0;const S=o*n+v;a.lineOffset=Math.max(v,s),f+=S,++y}const x=f,{horizontalAlign:v,verticalAlign:b}=fy(s);(function(e,t,i,r,n,o){const s=(t-i)*n,a=-o*r;for(const l of e)for(const e of l.positionedGlyphs)e.x+=s,e.y+=a})(e.positionedLines,_,v,b,m,x),e.top+=-b*x,e.bottom=e.top+x,e.left+=-v*m,e.right=e.left+m,e.hasBaseline=g}(T,t,i,r,y,s,a,l,u,c,d,f,_),!function(e){for(const t of e)if(0!==t.positionedGlyphs.length)return!1;return!0}(w))return T}const ay={9:!0,10:!0,11:!0,12:!0,13:!0,32:!0},ly={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 cy(e,t,i,r,n,o,s=1){if(t.image){const e=r.get(t.image.toString());return e?e.displaySize[0]*s*t.scale*Lg/o+n:0}{const r=i[t.fontStack],o=r&&r.glyphs[e];return o?o.metrics.advance*t.scale+n:0}}function hy(e,t,i,r){const n=Math.pow(e-t,2);return r?e<t?n/2:2*n:n+Math.abs(i)*i}function uy(e,t,i){let r=0;return 10===e&&(r-=1e4),i&&(r+=150),40!==e&&65288!==e||(r+=50),41!==t&&65289!==t||(r+=50),r}function dy(e,t,i,r,n,o){let s=null,a=hy(t,i,n,o);for(const l of r){const e=hy(t-l.x,i,n,o)+l.badness;e<=a&&(s=l,a=e)}return{index:e,x:t,priorBreak:s,badness:a}}function py(e){return e?py(e.priorBreak).concat(e.index):[]}function fy(e){let t=.5,i=.5;switch(e){case"right":case"top-right":case"bottom-right":t=1;break;case"left":case"top-left":case"bottom-left":t=0}switch(e){case"bottom":case"bottom-right":case"bottom-left":i=1;break;case"top":case"top-right":case"top-left":i=0}return{horizontalAlign:t,verticalAlign:i}}function my(e,t,i,r,n){if(!(t||i||r||n))return;const o=e.length-1,s=e[o],a=(s.x+s.metrics.advance*s.scale)*t;for(let l=0;l<=o;l++)e[l].x-=a,e[l].y+=i+r+n}function _y(e){return void 0!==e.imagePrimary&&void 0!==e.top&&void 0!==e.bottom&&void 0!==e.left&&void 0!==e.right}function gy(e,t,i,r){const{horizontalAlign:n,verticalAlign:o}=fy(r),s=i[0]-e.displaySize[0]*n,a=i[1]-e.displaySize[1]*o;return{imagePrimary:e,imageSecondary:t,top:a,bottom:a+e.displaySize[1],left:s,right:s+e.displaySize[0]}}function yy(e,t,i,r,n,o){const s=e.imagePrimary;let a;if(s.content){const e=s.content,t=s.pixelRatio||1;a=[e[0]/t,e[1]/t,s.displaySize[0]-e[2]/t,s.displaySize[1]-e[3]/t]}const l=t.left*o,c=t.right*o;let h,u,d,p;"width"===i||"both"===i?(p=n[0]+l-r[3],u=n[0]+c+r[1]):(p=n[0]+(l+c-s.displaySize[0])/2,u=p+s.displaySize[0]);const f=t.top*o,m=t.bottom*o;return"height"===i||"both"===i?(h=n[1]+f-r[0],d=n[1]+m+r[2]):(h=n[1]+(f+m-s.displaySize[1])/2,d=h+s.displaySize[1]),{imagePrimary:s,imageSecondary:void 0,top:h,right:u,bottom:d,left:p,collisionPadding:a}}function xy(e){return!e.imagePrimary.stretchX}function vy(e){return!e.imagePrimary.stretchY}function by(e){return{width:e.right-e.left,height:e.bottom-e.top}}const wy=128;function Ty(e,t,i,r){const{expression:n}=t;if("constant"===n.kind)return{kind:"constant",layoutSize:n.evaluate(new sa(e+1,{worldview:i}),void 0,void 0,void 0,r)};if("source"===n.kind)return{kind:"source"};{const{zoomStops:t,interpolationType:o}=n;let s=0;for(;s<t.length&&t[s]<=e;)s++;s=Math.max(0,s-1);let a=s;for(;a<t.length&&t[a]<e+1;)a++;a=Math.min(t.length-1,a);const l=t[s],c=t[a];return"composite"===n.kind?{kind:"composite",minZoom:l,maxZoom:c,interpolationType:o}:{kind:"camera",minZoom:l,maxZoom:c,minSize:n.evaluate(new sa(l,{worldview:i}),void 0,void 0,void 0,r),maxSize:n.evaluate(new sa(c,{worldview:i}),void 0,void 0,void 0,r),interpolationType:o}}}function Sy(e,{uSize:t,uSizeT:i},{lowerSize:r,upperSize:n}){return"source"===e.kind?r/wy:"composite"===e.kind?yi(r/wy,n/wy,i):t}function Iy(e,t,i=1){let r=0,n=0;if("constant"===e.kind)n=e.layoutSize*i;else if("source"!==e.kind){const{interpolationType:o,minZoom:s,maxZoom:a}=e,l=o?ke(io.interpolationFactor(o,t,s,a),0,1):0;"camera"===e.kind?n=yi(e.minSize,e.maxSize,l)*i:r=l*i}return{uSizeT:r,uSize:n}}class Ey extends Ie{constructor(e,t,i,r,n){super(e,t),this.angle=r,this.z=i,void 0!==n&&(this.segment=n)}clone(){return new Ey(this.x,this.y,this.z,this.angle,this.segment)}}function Ay(e,t,i,r,n){if(void 0===t.segment)return!0;let o=t,s=t.segment+1,a=0;for(;a>-i/2;){if(s--,s<0)return!1;a-=e[s].dist(o),o=e[s]}a+=e[s].dist(e[s+1]),s++;const l=[];let c=0;for(;a<i/2;){const t=e[s],i=e[s+1];if(!i)return!1;let o=e[s-1].angleTo(t)-t.angleTo(i);for(o=Math.abs((o+3*Math.PI)%(2*Math.PI)-Math.PI),l.push({distance:a,angleDelta:o}),c+=o;a-l[0].distance>r;)c-=l.shift().angleDelta;if(c>n)return!1;s++,a+=t.dist(i)}return!0}function My(e){let t=0;for(let i=0;i<e.length-1;i++)t+=e[i].dist(e[i+1]);return t}function Cy(e,t,i){return e?.6*t*i:0}function Py(e,t){return Math.max(e?e.right-e.left:0,t?t.right-t.left:0)}function Dy(e,t,i,r,n,o){const s=Cy(i,n,o),a=Py(i,r)*o;let l=0;const c=My(e)/2;for(let h=0;h<e.length-1;h++){const i=e[h],r=e[h+1],n=i.dist(r);if(l+n>c){const o=(c-l)/n,u=new Ey(yi(i.x,r.x,o),yi(i.y,r.y,o),0,r.angleTo(i),h);return!s||Ay(e,u,a,s,t)?u:void 0}l+=n}}function Ry(e,t,i,r,n,o,s,a,l){const c=Cy(r,o,s),h=Py(r,n),u=h*s,d=0===e[0].x||e[0].x===l||0===e[0].y||e[0].y===l;return t-u<t/4&&(t=u+t/4),zy(e,d?t/2*a%t:(h/2+2*o)*s*a%t,t,c,i,u,d,!1,l)}function zy(e,t,i,r,n,o,s,a,l){const c=o/2,h=My(e);let u=0,d=t-i,p=[];for(let f=0;f<e.length-1;f++){const t=e[f],s=e[f+1],a=t.dist(s),m=s.angleTo(t);for(;d+i<u+a;){d+=i;const _=(d-u)/a,g=yi(t.x,s.x,_),y=yi(t.y,s.y,_);if(g>=0&&g<l&&y>=0&&y<l&&d-c>=0&&d+c<=h){const t=new Ey(g,y,0,m,f);r&&!Ay(e,t,o,r,n)||p.push(t)}}u+=a}return a||p.length||s||(p=zy(e,u/2,i,r,n,o,s,!0,l)),p}function Ly(e){let t=0,i=0;for(const s of e)t+=s.w*s.h,i=Math.max(i,s.w);e.sort((e,t)=>t.h-e.h);const r=[{x:0,y:0,w:Math.max(Math.ceil(Math.sqrt(t/.95)),i),h:1/0}];let n=0,o=0;for(const s of e)for(let e=r.length-1;e>=0;e--){const t=r[e];if(!(s.w>t.w||s.h>t.h)){if(s.x=t.x,s.y=t.y,o=Math.max(o,s.y+s.h),n=Math.max(n,s.x+s.w),s.w===t.w&&s.h===t.h){const t=r.pop();t&&e<r.length&&(r[e]=t)}else s.h===t.h?(t.x+=s.w,t.w-=s.w):s.w===t.w?(t.y+=s.h,t.h-=s.h):(r.push({x:t.x+s.w,y:t.y,w:t.w-s.w,h:s.h}),t.y+=s.h,t.h-=s.h);break}}return{w:n,h:o,fill:t/(n*o)||0}}function Fy(e,t){return e.id<t.id?-1:e.id>t.id?1:e.version<t.version?-1:e.version>t.version?1:e.sx<t.sx?-1:e.sx>t.sx?1:e.sy<t.sy?-1:e.sy>t.sy?1:0}function Oy(e){let t=0;for(let i=0;i<e.length;i++)t=(t<<5)-t+e.charCodeAt(i),t&=t;return t}function By(e,t){return(e<<5)-e+t}function ky(e,t,i,r){for(const[n]of e.entries()){const e=r&&r.get(n)||Zi.parse(n),o=e.id.toString(),s=t.get(o)||0;i.push({id:n,version:s,sx:e.sx,sy:e.sy})}}as(Ey,"Anchor");class Ny{constructor(e,t,i,r,n){this.iconDescriptors=[],this.patternDescriptors=[],this.requiresMipMaps=t.size>0,ky(e,i,this.iconDescriptors,n),ky(t,i,this.patternDescriptors,n),this.iconDescriptors.sort(Fy),this.patternDescriptors.sort(Fy);let o=0;const s=r?r.data:"";s&&(o=By(o,Oy(s))),o=By(o,1);for(const a of this.iconDescriptors)o=By(o,Oy(a.id)),o=By(o,a.version),o=By(o,a.sx),o=By(o,a.sy);o=By(o,1);for(const a of this.patternDescriptors)o=By(o,Oy(a.id)),o=By(o,a.version),o=By(o,a.sx),o=By(o,a.sy);this.hash=o}subsetOf(e){return this.isSubsetArray(this.iconDescriptors,e.iconDescriptors,Fy)&&this.isSubsetArray(this.patternDescriptors,e.patternDescriptors,Fy)}isSubsetArray(e,t,i){let r=0,n=0;if(e.length>t.length)return!1;for(;r<e.length&&n<t.length;){const o=i(e[r],t[n]);if(0===o)r++,n++;else{if(o<0)return!1;n++}}return r===e.length}}as(Ny,"AtlasContentDescriptor");class Uy{static getImagePositionScale(e,t,i){if(t&&e){const{sx:t,sy:i}=e;return{x:t,y:i}}return{x:i,y:i}}constructor(e,t,i,r){this.paddedRect=e;const{pixelRatio:n,version:o,stretchX:s,stretchY:a,content:l,sdf:c,usvg:h}=t;this.pixelRatio=n,this.stretchX=s,this.stretchY=a,this.content=l,this.version=o,this.padding=i,this.sdf=c,this.usvg=h,this.scale=Uy.getImagePositionScale(r,h,n)}get tl(){return[this.paddedRect.x+this.padding,this.paddedRect.y+this.padding]}get br(){return[this.paddedRect.x+this.paddedRect.w-this.padding,this.paddedRect.y+this.paddedRect.h-this.padding]}get displaySize(){return[(this.paddedRect.w-2*this.padding)/this.scale.x,(this.paddedRect.h-2*this.padding)/this.scale.y]}}function Vy(e,t,i){const r=Zi.parse(e),n=function(e,t,i=[1,1]){return{x:0,y:0,w:(e.data?e.data.width:e.width*i[0])+2*t,h:(e.data?e.data.height:e.height*i[1])+2*t}}(t,i,[r.sx,r.sy]);return{bin:n,imagePosition:new Uy(n,t,i,r),imageVariant:r}}function jy(e,t){const i=[];for(const[n,o]of e.entries()){const e=Zi.parse(n);e&&(i.push({key:n,value:o,variant:e}),t&&t.set(n,e))}i.sort((e,t)=>{const i=e.variant.id.toString().localeCompare(t.variant.id.toString());return 0!==i?i:e.variant.sx!==t.variant.sx?e.variant.sx-t.variant.sx:e.variant.sy!==t.variant.sy?e.variant.sy-t.variant.sy:0});const r=/* @__PURE__ */new Map;for(const n of i)r.set(n.key,n.value);return r}class Gy{constructor(e){this.sourceAtlasHash=e}}class Hy{constructor(e,t,i,r){const n=/* @__PURE__ */new Map,o=/* @__PURE__ */new Map;this.haveRenderCallbacks=[];const s=[],a=void 0!==r,l=a?/* @__PURE__ */new Map:void 0,c=a?jy(e,l):e,h=a?jy(t,l):t;this.addImages(c,n,1,s),this.addImages(h,o,2,s);const{w:u,h:d}=Ly(s),p=new rd({width:u||1,height:d||1});for(const[f,m]of c.entries()){const e=n.get(f).paddedRect;rd.copy(m.data,p,{x:0,y:0},{x:e.x+1,y:e.y+1},m.data,null,m.sdf)}for(const[f,m]of h.entries()){const e=o.get(f),t=e.paddedRect;let r=e.padding;const n=t.x+r,s=t.y+r,a=m.data.width,l=m.data.height;r=r>1?r-1:r,rd.copy(m.data,p,{x:0,y:0},{x:n,y:s},m.data,i),rd.copy(m.data,p,{x:0,y:l-r},{x:n,y:s-r},{width:a,height:r},i),rd.copy(m.data,p,{x:0,y:0},{x:n,y:s+l},{width:a,height:r},i),rd.copy(m.data,p,{x:a-r,y:0},{x:n-r,y:s},{width:r,height:l},i),rd.copy(m.data,p,{x:0,y:0},{x:n+a,y:s},{width:r,height:l},i),rd.copy(m.data,p,{x:a-r,y:l-r},{x:n-r,y:s-r},{width:r,height:r},i),rd.copy(m.data,p,{x:0,y:l-r},{x:n+a,y:s-r},{width:r,height:r},i),rd.copy(m.data,p,{x:0,y:0},{x:n+a,y:s+l},{width:r,height:r},i),rd.copy(m.data,p,{x:a-r,y:0},{x:n-r,y:s+l},{width:r,height:r},i)}this.lut=i,this.image=p,this.iconPositions=n,this.patternPositions=o,a&&(this.contentDescriptor=new Ny(c,h,r,i,l))}addImages(e,t,i,r){for(const[n,o]of e.entries()){const{bin:e,imagePosition:s,imageVariant:a}=Vy(n,o,i);t.set(n,s),r.push(e),o.hasRenderCallback&&this.haveRenderCallbacks.push(a.id)}}patchUpdatedImages(e,t,i,r){this.haveRenderCallbacks=this.haveRenderCallbacks.filter(t=>e.hasImage(t,i)),e.dispatchRenderCallbacks(this.haveRenderCallbacks,i);for(const n of e.getUpdatedImages(i)){for(const r of this.iconPositions.keys()){const o=Zi.parse(r);if(fi.isEqual(o.id,n)){const o=e.getImage(n,i);this.patchUpdatedImage(this.iconPositions.get(r),o,t,null)}}for(const o of this.patternPositions.keys()){const s=Zi.parse(o);if(fi.isEqual(s.id,n)){const s=e.getImage(n,i);this.patchUpdatedImage(this.patternPositions.get(o),s,t,r||this.lut)}}}}patchUpdatedImage(e,t,i,r=null){if(!e||!t)return;if(e.version===t.version)return;e.version=t.version;const[n,o]=e.tl,s=e.sdf;if(this.lut||s){const e={width:t.data.width,height:t.data.height},a=new rd(e);rd.copy(t.data,a,{x:0,y:0},{x:0,y:0},e,r,s),i.update(a,{position:{x:n,y:o},recreateWhenResize:!1})}else i.update(t.data,{position:{x:n,y:o},recreateWhenResize:!1})}}as(Uy,"ImagePosition"),as(Hy,"ImageAtlas",{omit:["lut"]}),as(Gy,"ImageAtlasReference");class $y{constructor(e){this.pendingRequests=/* @__PURE__ */new Map,this.cachedRanges=/* @__PURE__ */new Map,this.fontstackCompositing=e&&e.fontstackCompositing||"client"}loadGlyphRange(e,t,i,r,n){if("server"===this.fontstackCompositing)return void $y.loadGlyphRange(e,t,i,r,n);const o=e.split(",").map(e=>e.trim()).filter(e=>e.length>0);0!==o.length?1!==o.length?this._loadMultipleFonts(o,t,i,r,n):this._loadFont(o[0],t,i,r,n):n(/* @__PURE__ */new Error("Empty fontstack"))}_loadMultipleFonts(e,t,i,r,n){const o=e.map(()=>null),s={completed:0,firstError:null,callbackCalled:!1},a=(t,i,r)=>{if(!s.callbackCalled&&(i&&!s.firstError&&(s.firstError=i),r&&(o[t]=r),s.completed++,s.completed===e.length)){s.callbackCalled=!0;const e=o.filter(e=>null!==e);if(0===e.length)return void n(s.firstError||/* @__PURE__ */new Error("All fonts failed to load"));n(null,this._composeGlyphs(e))}};for(let l=0;l<e.length;l++)this._loadFont(e[l],t,i,r,(e,t)=>{a(l,e,t)})}_loadFont(e,t,i,r,n){const o=`${e}:${t}`;if(this.cachedRanges.has(o)){const e=this.cachedRanges.get(o);return void It.frame(()=>n(null,e))}const s=this.pendingRequests.get(o);s?s.push(n):(this.pendingRequests.set(o,[n]),$y.loadGlyphRange(e,t,i,r,(e,t)=>{e||this.cachedRanges.set(o,t||null);const i=this.pendingRequests.get(o);if(this.pendingRequests.delete(o),i)for(const r of i)r(e,t)}))}_composeGlyphs(e){const t={};let i,r;for(const n of e)if(void 0===i&&void 0!==n.ascender&&(i=n.ascender),void 0===r&&void 0!==n.descender&&(r=n.descender),n.glyphs)for(const e in n.glyphs)void 0===t[e]&&(t[e]=n.glyphs[e]);return{glyphs:t,ascender:i,descender:r}}}$y.loadGlyphRange=function(e,t,i,r,n){const o=256*t,s=o+255;Jt(r.transformRequest(r.normalizeGlyphsURL(i).replace("{fontstack}",e).replace("{range}",`${o}-${s}`),Gt.Glyphs),(e,t)=>{if(e)n(e);else if(t){const e={},i=function(e){return new jg(e).readFields(ey,{})}(t);for(const t of i.glyphs)e[t.id]=t;n(null,{glyphs:e,ascender:i.ascender,descender:i.descender})}})};const qy=1e20,Zy=new Float64Array(256);for(let tT=0;tT<256;tT++){const e=.5-Math.pow(tT/255,1/2.2);Zy[tT]=e*Math.abs(e)}function Wy(e,t,i,r,n,o,s,a,l){for(let c=t;c<t+r;c++)Xy(e,i*o+c,o,n,s,a,l);for(let c=i;c<i+n;c++)Xy(e,c*o+t,1,r,s,a,l)}function Xy(e,t,i,r,n,o,s){o[0]=0,s[0]=-1e20,s[1]=qy,n[0]=e[t];for(let a=1,l=0,c=0;a<r;a++){n[a]=e[t+a*i];const r=a*a;do{const e=o[l];c=(n[a]-n[e]+r-e*e)/(a-e)/2}while(c<=s[l]&&--l>-1);l++,o[l]=a,s[l]=c,s[l+1]=qy}for(let a=0,l=0;a<r;a++){for(;s[l+1]<a;)l++;const r=o[l],c=a-r;e[t+a*i]=n[r]+c*c}}Zy[255]=-1e20;const Yy=/bold/i,Jy=/medium/i,Ky=/light/i,Qy={none:0,ideographs:1,all:2};class ex{constructor(e,t,i,r){this.requestManager=e,this.localGlyphMode=t,this.localFontFamily=i,this.url="",this.entries={},this.localGlyphs={200:{},400:{},500:{},900:{}},this.glyphLoader=new $y({fontstackCompositing:r})}setURL(e){this.url=e}prefetchRange(e,t){const i=this.url||dt.GLYPHS_URL;if(!i)return;let r=this.entries[e];r||(r=this.entries[e]={glyphs:{},requests:{},ranges:{}}),r.ranges[t]||r.requests[t]||(r.requests[t]=[],this.glyphLoader.loadGlyphRange(e,t,i,this.requestManager,(e,i)=>{if(i){r.ascender=i.ascender,r.descender=i.descender;for(const e in i.glyphs)this._doesCharSupportLocalGlyph(+e)||(r.glyphs[+e]=i.glyphs[+e]);r.ranges[t]=!0}for(const n of r.requests[t]||[])n(e,i);delete r.requests[t]}))}getGlyphs(e,t){const i=[],r=this.url||dt.GLYPHS_URL;for(const n in e)for(const t of e[n])i.push({stack:n,id:t});Ve(i,({stack:e,id:t},i)=>{let n=this.entries[e];n||(n=this.entries[e]={glyphs:{},requests:{},ranges:{},ascender:void 0,descender:void 0});let o=n.glyphs[t];if(void 0!==o)return void i(null,{stack:e,id:t,glyph:o});if(o=this._tinySDF(n,e,t),o)return n.glyphs[t]=o,void i(null,{stack:e,id:t,glyph:o});const s=Math.floor(t/256);if(256*s>65535)return Ke("glyphs > 65535 not supported"),void i(null,{stack:e,id:t,glyph:o});if(n.ranges[s])return void i(null,{stack:e,id:t,glyph:o});let a=n.requests[s];a||(a=n.requests[s]=[],this.glyphLoader.loadGlyphRange(e,s,r,this.requestManager,(e,t)=>{if(t){n.ascender=t.ascender,n.descender=t.descender;for(const e in t.glyphs)this._doesCharSupportLocalGlyph(+e)||(n.glyphs[+e]=t.glyphs[+e]);n.ranges[s]=!0}for(const i of a)i(e,t);delete n.requests[s]})),a.push((r,n)=>{r?i(r):n&&i(null,{stack:e,id:t,glyph:n.glyphs[t]||null})})},(e,i)=>{if(e)t(e);else if(i){const e={};for(const{stack:t,id:r,glyph:n}of i)void 0===e[t]&&(e[t]={}),void 0===e[t].glyphs&&(e[t].glyphs={}),e[t].glyphs[r]=n&&{id:n.id,bitmap:n.bitmap.clone(),metrics:n.metrics},e[t].ascender=this.entries[t].ascender,e[t].descender=this.entries[t].descender;t(null,e)}})}_doesCharSupportLocalGlyph(e){return this.localGlyphMode!==Qy.none&&(this.localGlyphMode===Qy.all?!!this.localFontFamily:!!this.localFontFamily&&(As(e)||Ps(e)||ys(e)||xs(e)||gs(e)||Es(e)||(t=e)>=131072&&t<=173791||(e=>e>=66736&&e<=66815)(e)));var t}_tinySDF(e,t,i){const r=this.localFontFamily;if(!r||!this._doesCharSupportLocalGlyph(i))return;let n=e.tinySDF;if(!n){let i="400";Yy.test(t)?i="900":Jy.test(t)?i="500":Ky.test(t)&&(i="200"),n=e.tinySDF=new ex.TinySDF({fontFamily:r,fontWeight:i,fontSize:48,buffer:6,radius:16}),n.fontWeight=i}const o=n.fontWeight;if(this.localGlyphs[o][i])return this.localGlyphs[o][i];const s=String.fromCodePoint(i),{data:a,width:l,height:c,glyphWidth:h,glyphHeight:u,glyphLeft:d,glyphTop:p,glyphAdvance:f}=n.draw(s);return this.localGlyphs[o][i]={id:i,bitmap:new id({width:l,height:c},a),metrics:{width:h/2,height:u/2,left:d/2,top:p/2-27,advance:f/2,localGlyph:!0}}}}function tx(e,t){return e+t[1]-t[0]}function ix(e,t,i,r,n=1){const o=[],s=e.imagePrimary,a=s.pixelRatio,l=s.paddedRect.w-2,c=s.paddedRect.h-2,h=(e.right-e.left)*n,u=(e.bottom-e.top)*n,d=s.stretchX||[[0,l]],p=s.stretchY||[[0,c]],f=d.reduce(tx,0),m=p.reduce(tx,0),_=l-f,g=c-m;let y=0,x=f,v=0,b=m,w=0,T=_,S=0,I=g;if(s.content&&r){const e=s.content;y=nx(d,0,e[0]),v=nx(p,0,e[1]),x=nx(d,e[0],e[2]),b=nx(p,e[1],e[3]),w=e[0]-y,S=e[1]-v,T=e[2]-e[0]-x,I=e[3]-e[1]-b}const E=(r,o,l,c)=>{const d=ax(r.stretch-y,x,h,e.left*n),p=lx(r.fixed-w,T,r.stretch,f),_=ax(o.stretch-v,b,u,e.top*n),g=lx(o.fixed-S,I,o.stretch,m),E=ax(l.stretch-y,x,h,e.left*n),A=lx(l.fixed-w,T,l.stretch,f),M=ax(c.stretch-v,b,u,e.top*n),C=lx(c.fixed-S,I,c.stretch,m),P=new Ie(d,_),D=new Ie(E,_),R=new Ie(E,M),z=new Ie(d,M),L=new Ie(p/a,g/a),F=new Ie(A/a,C/a),O=t*Math.PI/180;if(O){const e=Math.sin(O),t=Math.cos(O),i=[t,-e,e,t];P._matMult(i),D._matMult(i),z._matMult(i),R._matMult(i)}const B=r.stretch+r.fixed,k=l.stretch+l.fixed,N=o.stretch+o.fixed,U=c.stretch+c.fixed,V=e.imageSecondary;return{tl:P,tr:D,bl:z,br:R,texPrimary:{x:s.paddedRect.x+1+B,y:s.paddedRect.y+1+N,w:k-B,h:U-N},texSecondary:V?{x:V.paddedRect.x+1+B,y:V.paddedRect.y+1+N,w:k-B,h:U-N}:void 0,writingMode:void 0,glyphOffset:[0,0],sectionIndex:0,pixelOffsetTL:L,pixelOffsetBR:F,minFontScaleX:T/a/h,minFontScaleY:I/a/u,isSDF:i}};if(s.stretchX||s.stretchY){const e=ox(d,_,f),t=ox(p,g,m);for(let i=0;i<e.length-1;i++){const r=e[i],n=e[i+1];for(let e=0;e<t.length-1;e++)o.push(E(r,t[e],n,t[e+1]))}}else o.push(E({fixed:0,stretch:-1},{fixed:0,stretch:-1},{fixed:0,stretch:l+1},{fixed:0,stretch:c+1}));return o}function rx(e,t){const i=e.stretchY||[[0,e.paddedRect.h-2]];return e.stretchX||e.stretchY?sx(e.stretchX||[[0,e.paddedRect.w-2]])*sx(i):1}function nx(e,t,i){let r=0;for(const n of e)r+=Math.max(t,Math.min(i,n[1]))-Math.max(t,Math.min(i,n[0]));return r}function ox(e,t,i){const r=[{fixed:-1,stretch:0}];for(const[n,o]of e){const e=r.at(-1);r.push({fixed:n-e.stretch,stretch:e.stretch}),r.push({fixed:n-e.stretch,stretch:e.stretch+(o-n)})}return r.push({fixed:t+1,stretch:i}),r}function sx(e){return 2*e.length+1}function ax(e,t,i,r){return e/t*i+r}function lx(e,t,i,r){return e-t*i/r}function cx(e,t,i,r){const n=t+e.positionedLines[r].lineOffset;return 0===r?i+n/2:i+(n+(t+e.positionedLines[r-1].lineOffset))/2}function hx(e,t,i,r,n,o,s,a,l,c=1){const h=[];if(0===t.positionedLines.length)return h;const u=(void 0!==l?l:r.layout.get("text-rotate").evaluate(o,{}))*Math.PI/180,d=function(e){const t=e[0],i=e[1],r=t*i;return r>0?[t,-i]:r<0?[-t,i]:0===t?[i,t]:[i,-t]}(i);let p=Math.abs(t.top-t.bottom);for(const g of t.positionedLines)p-=g.lineOffset;const f=t.positionedLines.length,m=p/f;let _=t.top-i[1];for(let g=0;g<f;++g){const e=t.positionedLines[g];_=cx(t,m,_,g);for(const r of e.positionedGlyphs){if(!r.rect)continue;const e=r.rect||{};let o=4,l=!0,p=1,f=0;if(r.image){const e=s.get(r.image.toString());if(!e)continue;if(e.sdf){Ke("SDF images are not supported in formatted text and will be ignored.");continue}l=!1,p=e.pixelRatio,o=1/p,e.usvg||(p/=c)}const m=(n||a)&&r.vertical,g=r.metrics.advance*r.scale/2,y=r.metrics,x=r.rect;if(null===x)continue;a&&t.verticalizable&&(f=r.image?g-r.metrics.width*r.scale/2:0);const v=n?[r.x+g,r.y]:[0,0];let b=[0,0],w=[0,0],T=!1;n||(m?(w=[r.x+g+d[0],r.y+d[1]-f],T=!0):b=[r.x+g+i[0],r.y+i[1]-f]);const S=x.w*r.scale/(p*(r.localGlyph?2:1)),I=x.h*r.scale/(p*(r.localGlyph?2:1));let E,A,M,C;if(m){const e=r.y-_,t=new Ie(-g,g-e),i=-Math.PI/2,n=new Ie(...w);E=new Ie(-g+b[0],b[1]),E._rotateAround(i,t)._add(n),E.x+=-e+g,E.y-=(y.left-o)*r.scale;const s=r.image?y.advance*r.scale:Lg*r.scale,a=String.fromCodePoint(r.glyph);Bg(a)?E.x+=(1-o)*r.scale:kg(a)?E.x+=s-y.height*r.scale+(-o-1)*r.scale:E.x+=r.image||y.width+2*o===x.w&&y.height+2*o===x.h?(s-I)/2:(s-(y.height+2*o)*r.scale)/2,A=new Ie(E.x,E.y-S),M=new Ie(E.x+I,E.y),C=new Ie(E.x+I,E.y-S)}else{const e=(y.left-o)*r.scale-g+b[0],t=(-y.top-o)*r.scale+b[1],i=e+S,n=t+I;E=new Ie(e,t),A=new Ie(i,t),M=new Ie(e,n),C=new Ie(i,n)}if(u){let e;e=n?new Ie(0,0):T?new Ie(d[0],d[1]):new Ie(i[0],i[1]),E._rotateAround(u,e),A._rotateAround(u,e),M._rotateAround(u,e),C._rotateAround(u,e)}const P=new Ie(0,0),D=new Ie(0,0);h.push({tl:E,tr:A,bl:M,br:C,texPrimary:e,texSecondary:void 0,writingMode:t.writingMode,glyphOffset:v,sectionIndex:r.sectionIndex,isSDF:l,pixelOffsetTL:P,pixelOffsetBR:D,minFontScaleX:0,minFontScaleY:0})}}return h}function ux(e,t=1,i=!1){let r=1/0,n=1/0,o=-1/0,s=-1/0;const a=e[0];for(let p=0;p<a.length;p++){const e=a[p];(!p||e.x<r)&&(r=e.x),(!p||e.y<n)&&(n=e.y),(!p||e.x>o)&&(o=e.x),(!p||e.y>s)&&(s=e.y)}const l=Math.min(o-r,s-n);let c=l/2;const h=new Xr([],dx);if(0===l)return new Ie(r,n);for(let p=r;p<o;p+=l)for(let t=n;t<s;t+=l)h.push(new px(p+c,t+c,c,e));let u=function(e){let t=0,i=0,r=0;const n=e[0];for(let o=0,s=n.length,a=s-1;o<s;a=o++){const e=n[o],s=n[a],l=e.x*s.y-s.x*e.y;i+=(e.x+s.x)*l,r+=(e.y+s.y)*l,t+=3*l}return new px(i/t,r/t,0,e)}(e),d=h.length;for(;h.length;){const r=h.pop();(r.d>u.d||!u.d)&&(u=r,i&&console.log("found best %d after %d probes",Math.round(1e4*r.d)/1e4,d)),r.max-u.d<=t||(c=r.h/2,h.push(new px(r.p.x-c,r.p.y-c,c,e)),h.push(new px(r.p.x+c,r.p.y-c,c,e)),h.push(new px(r.p.x-c,r.p.y+c,c,e)),h.push(new px(r.p.x+c,r.p.y+c,c,e)),d+=4)}return i&&(console.log(`num probes: ${d}`),console.log(`best distance: ${u.d}`)),u.p}function dx(e,t){return t.max-e.max}ex.TinySDF=class{constructor({fontSize:e=24,buffer:t=3,radius:i=8,cutoff:r=.25,fontFamily:n="sans-serif",fontWeight:o="normal",fontStyle:s="normal",lang:a=null}={}){this.buffer=t,this.radius=i,this.cutoff=r,this.lang=a;const l=this.size=e+4*t,c=this._createCanvas(l),h=this.ctx=c.getContext("2d",{willReadFrequently:!0});h.font=`${s} ${o} ${e}px ${n}`,h.textBaseline="alphabetic",h.textAlign="left",h.fillStyle="black",this.gridOuter=new Float64Array(l*l),this.gridInner=new Float64Array(l*l),this.f=new Float64Array(l),this.z=new Float64Array(l+1),this.v=new Uint16Array(l)}_createCanvas(e){if("undefined"!=typeof OffscreenCanvas)return new OffscreenCanvas(e,e);const t=document.createElement("canvas");return t.width=t.height=e,t}draw(e){const{width:t,actualBoundingBoxAscent:i,actualBoundingBoxDescent:r,actualBoundingBoxLeft:n,actualBoundingBoxRight:o}=this.ctx.measureText(e),s=Math.ceil(i),a=Math.floor(n),l=Math.max(0,Math.min(this.size-this.buffer,Math.ceil(o)-a)),c=Math.max(0,Math.min(this.size-this.buffer,s+Math.ceil(r))),h=l+2*this.buffer,u=c+2*this.buffer,d=Math.max(h*u,0),p=new Uint8ClampedArray(d),f={data:p,width:h,height:u,glyphWidth:l,glyphHeight:c,glyphTop:s,glyphLeft:a,glyphAdvance:t};if(0===l||0===c)return f;const{ctx:m,buffer:_,gridInner:g,gridOuter:y}=this;this.lang&&(m.lang=this.lang),m.clearRect(_,_,l,c),m.fillText(e,_-a,_+s);const x=m.getImageData(_,_,l,c);y.fill(qy,0,d),g.fill(0,0,d);let v=3;for(let T=0;T<c;T++){let e=(T+_)*h+_;for(let t=0;t<l;t++,v+=4,e++){const t=x.data[v];if(0===t)continue;const i=Zy[t];y[e]=Math.max(0,i),g[e]=Math.max(0,-i)}}Wy(y,0,0,h,u,h,this.f,this.v,this.z),Wy(g,_,_,l,c,h,this.f,this.v,this.z);const b=255/this.radius,w=255*(1-this.cutoff);for(let T=0;T<d;T++){const e=Math.sqrt(y[T])-Math.sqrt(g[T]);p[T]=Math.round(w-b*e)}return f}};class px{constructor(e,t,i,r){this.p=new Ie(e,t),this.h=i,this.d=function(e,t){let i=!1,r=1/0;for(let n=0;n<t.length;n++){const o=t[n];for(let t=0,n=o.length,s=n-1;t<n;s=t++){const n=o[t],a=o[s];n.y>e.y!=a.y>e.y&&e.x<(a.x-n.x)*(e.y-n.y)/(a.y-n.y)+n.x&&(i=!i),r=Math.min(r,Wh(e,n,a))}}return(i?1:-1)*Math.sqrt(r)}(this.p,r),this.max=this.d+this.h*Math.SQRT2}}const fx=Object.keys,mx=Number.POSITIVE_INFINITY,_x=Math.sqrt(2);function gx(e,t,i,r,n,o){const s=_y(e)&&e.collisionPadding?e.collisionPadding:[0,0,0,0],a={top:e.top-s[1],bottom:e.bottom+s[3],left:e.left-s[0],right:e.right+s[2],scaled:!1};return void 0!==r&&function(e,t){e.top*=t,e.bottom*=t,e.left*=t,e.right*=t,e.scaled=!0}(a,r),o&&(a.left+=o[0],a.right+=o[0],a.top+=o[1],a.bottom+=o[1]),i&&function(e,t,i){if(!t)return;const r=Re(t),n=new Ie(i?i[0]:0,i?i[1]:0),o=new Ie(e.left,e.top),s=new Ie(e.right,e.top),a=new Ie(e.left,e.bottom),l=new Ie(e.right,e.bottom);o._rotateAround(r,n),s._rotateAround(r,n),a._rotateAround(r,n),l._rotateAround(r,n),e.left=Math.min(o.x,s.x,a.x,l.x),e.right=Math.max(o.x,s.x,a.x,l.x),e.top=Math.min(o.y,s.y,a.y,l.y),e.bottom=Math.max(o.y,s.y,a.y,l.y)}(a,i,n),t?{top:Math.min(t.top,a.top),bottom:Math.max(t.bottom,a.bottom),left:Math.min(t.left,a.left),right:Math.max(t.right,a.right),scaled:t.scaled||a.scaled}:a}function yx(e,[t,i]){let r=0,n=0;if(i===mx){t<0&&(t=0);const i=t/_x;switch(e){case"top-right":case"top-left":n=i-7;break;case"bottom-right":case"bottom-left":n=7-i;break;case"bottom":n=7-t;break;case"top":n=t-7}switch(e){case"top-right":case"bottom-right":r=-i;break;case"top-left":case"bottom-left":r=i;break;case"left":r=t;break;case"right":r=-t}}else{switch(t=Math.abs(t),i=Math.abs(i),e){case"top-right":case"top-left":case"top":n=i-7;break;case"bottom-right":case"bottom-left":case"bottom":n=7-i}switch(e){case"top-right":case"bottom-right":case"right":r=-t;break;case"top-left":case"bottom-left":case"left":r=t}}return[r,n]}function xx(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f){const m=e.layers[0],_=m.appearances;if(0===_.length)return{iconBBox:null,iconVerticalBBox:null,textBBox:null,textVerticalBBox:null};const g={iconBBox:null,iconVerticalBBox:null},y={textBBox:null,textVerticalBBox:null},{baseIconRotate:x,baseTextRotate:v,iconScaleFactor:b}=function(e,t,i){const r=e.get("icon-rotate").evaluate(t,{},i),n=e.get("text-rotate").evaluate(t,{},i),[o,s]=e.get("icon-size-scale-range");return{baseIconRotate:r,baseTextRotate:n,iconScaleFactor:ke(1,o,s)}}(r,n,o);t&&(g.iconBBox=gx(t,g.iconBBox,x),i)&&(g.iconVerticalBBox=gx(i,g.iconVerticalBBox,x+90));const w=Nx(u.horizontal);w&&(y.textBBox=gx(w,y.textBBox,v,1,p)),u.vertical&&(y.textVerticalBBox=gx(u.vertical,y.textVerticalBBox,v+90,1,p));for(const T of _)T.hasIconLayoutProperties()&&vx(g,e,m,T,n,o,a,x,s,l,t,c,b,h,f),T.hasTextLayoutProperties()&&wx(y,m,T,n,o,p,v,d,w,u.vertical);return{iconBBox:g.iconBBox,iconVerticalBBox:g.iconVerticalBBox,textBBox:y.textBBox,textVerticalBBox:y.textVerticalBBox}}function vx(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f){const{appearanceIconOffset:m,appearanceIconRotate:_,appearanceIconSize:g}=bx(r,i,n,o,s,a,l,c.iconScaleFactor);let y=null,x=null,v=null;r.hasLayoutProperty("icon-image")?v=function(e,t,i,r,n,o,s,a){let l=null;const c=t.getAppearanceValueAndResolveTokens(i,"icon-image",r,n,a);if(c){const h=e.getResolvedImageFromTokens(c),u=i.hasLayoutProperty("icon-size")?i.getUnevaluatedLayoutProperty("icon-size"):t._unevaluatedLayout._values["icon-size"],d=Ex(h,Ty(e.zoom,u,e.worldview,a),u,n,e.zoom,r,e.pixelRatio,s,e.worldview,a);l=o.get(d.iconPrimary.toString())}return l}(t,i,r,n,o,u,d,f):h&&(v=h.imagePrimary),v&&(y=gy(v,null,m,p),t.allowVerticalPlacement&&(x=gy(v,null,m,p)));const b=l>0?g/l:1;y&&(e.iconBBox=gx(y,e.iconBBox,_,1!==b?b:void 0)),x&&(e.iconVerticalBBox=gx(x,e.iconVerticalBBox,_+90,1!==b?b:void 0))}function bx(e,t,i,r,n,o,s,a){const l=e.hasLayoutProperty("icon-offset")?t.getAppearanceValueAndResolveTokens(e,"icon-offset",i,r,[]):null,c=l&&Array.isArray(l)?l:n,h=e.hasLayoutProperty("icon-rotate")?t.getAppearanceValueAndResolveTokens(e,"icon-rotate",i,r,[]):null,u="number"==typeof h?h:o,d=e.hasLayoutProperty("icon-size")?t.getAppearanceValueAndResolveTokens(e,"icon-size",i,r,[]):null;return{appearanceIconOffset:c,appearanceIconRotate:u,appearanceIconSize:"number"==typeof d?d*a:s}}function wx(e,t,i,r,n,o,s,a,l,c){const{appearanceTextOffset:h,appearanceTextRotate:u,appearanceTextSize:d}=Tx(i,t,r,n,o,s,a),p=d/a,f=[(h[0]-o[0])*p,(h[1]-o[1])*p],m=0!==f[0]||0!==f[1];l&&(e.textBBox=gx(l,e.textBBox,u,p,h,m?f:void 0)),c&&(e.textVerticalBBox=gx(c,e.textVerticalBBox,u+90,p,h,m?f:void 0))}function Tx(e,t,i,r,n,o,s){const a=e.hasLayoutProperty("text-offset")?t.getAppearanceValueAndResolveTokens(e,"text-offset",i,r,[]):null,l=a&&Array.isArray(a)?[a[0]*Lg,a[1]*Lg]:n,c=e.hasLayoutProperty("text-rotate")?t.getAppearanceValueAndResolveTokens(e,"text-rotate",i,r,[]):null,h="number"==typeof c?c:o,u=e.hasLayoutProperty("text-size")?t.getAppearanceValueAndResolveTokens(e,"text-size",i,r,[]):null;return{appearanceTextOffset:l,appearanceTextRotate:h,appearanceTextSize:"number"==typeof u?u:s}}function Sx(e,t,i,r,n,o,s,a,l){if(!t||!t.usvg)return;const c=by(r),h=by(n),u="both"!==o&&"width"!==o||!xy(r)?1:h.width/c.width,d="both"!==o&&"height"!==o||!vy(r)?1:h.height/c.height;i.scaleSelf(u,d);const p=i.toString();s.set(p,i),a.set(p,t);const{imagePosition:f}=Vy(p,t,1);l.set(p,f)}function Ix(e,t,i,r,n,o,s,a,l,c){if(!e)return;const h=function(e,t,i,r,n,o,s){if("camera"===e.kind)return e.maxSize;if("composite"===e.kind){const r=t.possiblyEvaluate(new sa(e.maxZoom,{worldview:o}),i,s).evaluate(n,{},i,s),a=t.possiblyEvaluate(new sa(e.minZoom,{worldview:o}),i,s).evaluate(n,{},i,s);return Math.max(r,a)}return t.possiblyEvaluate(new sa(r,{worldview:o}),i,s).evaluate(n,{},i,s)}(t,i,r,n,o,l,c);return e.scaleSelf(h*a*s)}function Ex(e,t,i,r,n,o,s,a,l,c){return{iconPrimary:Ix(e.getPrimary(),t,i,r,n,o,s,a,l,c),iconSecondary:Ix(e.getSecondary(),t,i,r,n,o,s,a,l,c)}}function Ax(e,t,i){if(!t)return;const r=i.get(e.toString()),n=i.get(t.toString());r&&n&&(r.paddedRect.w===n.paddedRect.w&&r.paddedRect.h===n.paddedRect.h||Ke(`Mismatch in icon variant sizes: ${e.toString()} and ${t.toString()}`),r.usvg!==n.usvg&&Ke(`Mismatch in icon variant image types: ${e.id} and ${t.id}`))}function Mx(e,t,i,r){if(!e)return;const n=t.get(i.toString());n&&(e.imagePrimary=n),r&&(e.imageSecondary=t.get(r.toString()))}function Cx(e,t){for(const i in e.horizontal)Px(e.horizontal[i],t);Px(e.vertical,t)}function Px(e,t){if(e)for(const i of e.positionedLines)for(const e of i.positionedGlyphs)if(null!==e.image){const i=e.image.toString();e.rect=t.get(i).paddedRect}}function Dx(e){switch(e){case"right":case"top-right":case"bottom-right":return"right";case"left":case"top-left":case"bottom-left":return"left"}return"center"}function Rx(e,t,i,r,n,o,s,a,l){const c=Nx(o.horizontal)||o.vertical,h=i.get("icon-text-fit-padding").evaluate(r,{},n);let u,d=t;return t&&"none"!==l&&(e.allowVerticalPlacement&&o.vertical&&(u=yy(t,o.vertical,l,h,a,s)),c&&(d=yy(t,c,l,h,a,s))),{defaultShapedIcon:d,verticallyShapedIcon:u}}function zx(e,t){return e*t/24}function Lx(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T){let S=s.textMaxSize.evaluate(t,{},d);void 0===S?S=a*s.textScaleFactor:S*=s.textScaleFactor;const I=e.layers[0].layout,E=zx(a,s.textScaleFactor),A=Nx(i.horizontal)||i.vertical,M=e.hasAnyAppearanceLayoutProperty(["text-size","text-offset","text-rotate"]),C=e.getAppearanceFeatureData(t.index);("none"!==_||M)&&C&&(C.textShaping=A,C.iconTextFitPadding=I.get("icon-text-fit-padding").evaluate(t,{},d),C.fontScale=E,C.textScaleFactor=s.textScaleFactor);const P="globe"===p.name,D=e.tilePixelRatio*S/24,R=(k=e.overscaling,e.zoom>18&&k>2&&(k>>=1),Math.max(Yr/(512*k),1)*I.get("symbol-spacing")),z=I.get("text-padding")*e.tilePixelRatio,L=I.get("icon-padding")*e.tilePixelRatio,F=Re(I.get("text-max-angle")),O="map"===I.get("icon-rotation-alignment")&&"point"!==x,B=R/2;var k;!1===e.hasAnyIconTextFit&&"none"!==_&&(e.hasAnyIconTextFit=!0);const N=t.properties?+t.properties[_h]:null,U=N&&e.elevationFeatureIdToIndex?e.elevationFeatureIdToIndex.get(N):65535,V=(a,l,x)=>{if(l.x<0||l.x>=Yr||l.y<0||l.y>=Yr)return;let T=null;if(P){const{x:e,y:t,z:i}=p.projectTilePoint(l.x,l.y,x);T={anchor:new Ey(e,t,i,0,void 0),up:p.upVector(x,l.x,l.y)}}!function(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S,I,E,A,M,C,P,D){const R=e.addToLineVertexArray(t,r);let z,L,F,O,B,k,N,U=0,V=0,j=0,G=0,H=-1,$=-1;const q={};let Z=li("");const W=i?i.anchor:t,X="none"!==A;let Y=0,J=0;if(void 0===l._unevaluatedLayout.getValue("text-radial-offset")){const e=l.layout.get("text-offset").evaluate(v,{},S);Y=e[0]*Lg,J=e[1]*Lg}else Y=l.layout.get("text-radial-offset").evaluate(v,{},S)*Lg,J=mx;if(e.allowVerticalPlacement&&n.vertical){const e=n.vertical;if(f)k=Vx(e),a&&(N=Vx(a));else{const i=l.layout.get("text-rotate").evaluate(v,{},S)+90;F=Ux(c,W,t,h,u,d,e,p,i,m,D),a&&(O=Ux(c,W,t,h,u,d,a,g,i,null,P))}}if(o){const r=l.layout.get("icon-rotate").evaluate(v,{},S),n=ix(o,r,w,X,b.iconScaleFactor),s=a?ix(a,r,w,X,b.iconScaleFactor):void 0;L=Ux(c,W,t,h,u,d,o,g,r,null,C);const p=function(e,t,i,r,n,o,s,a,l,c){const h=e.layers[0],u=h.appearances;let d=t.length;if(i&&(d=Math.max(d,i.length)),0===u.length)return d;const[p,f]=r.get("icon-size-scale-range"),m=ke(1,p,f);for(const _ of u)if(_.hasLayoutProperty("icon-image")){const t=h.getAppearanceValueAndResolveTokens(_,"icon-image",o,s,c);if(t){const i=e.getResolvedImageFromTokens(t);if(i){const t=_.hasLayoutProperty("icon-size")?_.getUnevaluatedLayoutProperty("icon-size"):n._values["icon-size"],r=Ex(i,Ty(e.zoom,t,e.worldview,c),t,s,e.zoom,o,e.pixelRatio,m,e.worldview,c),l=a.get(r.iconPrimary.toString());l&&(d=Math.max(d,rx(l)))}}}return d}(e,n,s,l.layout,l._unevaluatedLayout,v,S,e.iconAtlasPositions,0,T);U=4*p;const f=l.layout.get("icon-size").evaluate(v,{},S,T),m=b.compositeIconSizes?b.compositeIconSizes[0].evaluate(v,{},S,T):0,_=b.compositeIconSizes?b.compositeIconSizes[1].evaluate(v,{},S,T):0,A=kx(e.layerIds[0],e.iconSizeData,f,o.imagePrimary.usvg?1:b.iconScaleFactor,m,_);e.addSymbols(e.icon,n,A,x,y,v,void 0,i,t,R.lineStartIndex,R.lineLength,-1,T,S,I,E,e.symbolInstances.length,p),H=e.icon.placedSymbolArray.length-1,s&&(V=4*p,e.addSymbols(e.icon,s,A,x,y,v,ry.vertical,i,t,R.lineStartIndex,R.lineLength,-1,T,S,I,E,e.symbolInstances.length,p),$=e.icon.placedSymbolArray.length-1)}for(const te in n.horizontal){const r=te,o=n.horizontal[r];z||(Z=li(o.text),f?B=Vx(o):z=Ux(c,W,t,h,u,d,o,p,l.layout.get("text-rotate").evaluate(v,{},S),m,D));const a=1===o.positionedLines.length;if(j+=Bx(e,i,t,o,s,l,f,v,m,R,n.vertical?ry.horizontal:ry.horizontalOnly,a?fx(n.horizontal):[r],q,H,b,T,S,e.symbolInstances.length,I),a)break}n.vertical&&(G+=Bx(e,i,t,n.vertical,s,l,f,v,m,R,ry.vertical,["vertical"],q,$,b,T,S,e.symbolInstances.length,I));let K=-1;const Q=(e,t)=>e?Math.max(e,t):t;K=Q(B,K),K=Q(k,K),K=Q(N,K);const ee=K>-1?1:0;e.glyphOffsetArray.length>=65535&&Ke("Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"),void 0!==v.sortKey&&e.addToSortKeyRanges(e.symbolInstances.length,v.sortKey),e.symbolInstances.emplaceBack(t.x,t.y,W.x,W.y,W.z,q.right>=0?q.right:-1,q.center>=0?q.center:-1,q.left>=0?q.left:-1,q.vertical>=0?q.vertical:-1,H,$,Z,void 0!==z?z:e.collisionBoxArray.length,void 0!==z?z+1:e.collisionBoxArray.length,void 0!==F?F:e.collisionBoxArray.length,void 0!==F?F+1:e.collisionBoxArray.length,void 0!==L?L:e.collisionBoxArray.length,void 0!==L?L+1:e.collisionBoxArray.length,O||e.collisionBoxArray.length,O?O+1:e.collisionBoxArray.length,h,j,G,U,V,ee,0,Y,J,K,0,X?1:0,M)}(e,l,T,a,i,r,o,n,e.layers[0],e.collisionBoxArray,t.index,t.sourceLayerIndex,e.index,z,y,c,0,L,O,g,t,s,h,u,d,f,m,_,U,v,b,w)};if("line"===x)for(const j of Wf(t.geometry,0,0,Yr,Yr)){const t=Ry(j,R,F,i.vertical||A,r,24,D,e.overscaling,Yr);for(const i of t)A&&jx(e,A.text,B,i)||V(j,i,d)}else if("line-center"===x){for(const j of t.geometry)if(j.length>1){const e=Dy(j,F,i.vertical||A,r,24,D);e&&V(j,e,d)}}else if("Polygon"===t.type)for(const j of Od(t.geometry,0)){const e=ux(j,16);V(j[0],new Ey(e.x,e.y,0,0,void 0),d)}else if("LineString"===t.type)for(const j of t.geometry)V(j,new Ey(j[0].x,j[0].y,0,0,void 0),d);else if("Point"===t.type)for(const j of t.geometry)for(const e of j)V([e],new Ey(e.x,e.y,0,0,void 0),d)}const Fx=255,Ox=Fx*wy;function Bx(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y){const x=hx(0,r,l,o,s,a,n,e.allowVerticalPlacement,void 0,f.textScaleFactor),v=o.layout.get("text-size").evaluate(a,{},_),b=f.compositeTextSizes?f.compositeTextSizes[0].evaluate(a,{},_):0,w=f.compositeTextSizes?f.compositeTextSizes[1].evaluate(a,{},_):0,T=kx(e.layerIds[0],e.textSizeData,v,f.textScaleFactor,b,w);e.addSymbols(e.text,x,T,l,s,a,h,t,i,c.lineStartIndex,c.lineLength,p,m,_,y,!1,g,x.length);for(const S of u)d[S]=e.text.placedSymbolArray.length-1;return 4*x.length}function kx(e,t,i,r,n,o){const s=t;let a=null;return"source"===s.kind?(a=[wy*i*r],a[0]>Ox&&Ke(`${e}: Value for "text-size" or "icon-size" is >= ${Fx}. Reduce your "text-size" or "icon-size".`)):"composite"===s.kind&&(a=[wy*n*r,wy*o*r],(a[0]>Ox||a[1]>Ox)&&Ke(`${e}: Value for "text-size" or "icon-size" is >= ${Fx}. Reduce your "text-size" or "icon-size".`)),a}function Nx(e){for(const t in e)return e[t];return null}function Ux(e,t,i,r,n,o,s,a,l,c,h){let u,d,p,f;if(u=h?h.top:s.top,d=h?h.bottom:s.bottom,p=h?h.left:s.left,f=h?h.right:s.right,_y(s)&&s.collisionPadding){const e=s.collisionPadding;p-=e[0],u-=e[1],f+=e[2],d+=e[3]}if(l){const e=new Ie(p,u),t=new Ie(f,u),i=new Ie(p,d),r=new Ie(f,d),n=Re(l);let o=new Ie(0,0);c&&(o=new Ie(c[0],c[1])),e._rotateAround(n,o),t._rotateAround(n,o),i._rotateAround(n,o),r._rotateAround(n,o),p=Math.min(e.x,t.x,i.x,r.x),f=Math.max(e.x,t.x,i.x,r.x),u=Math.min(e.y,t.y,i.y,r.y),d=Math.max(e.y,t.y,i.y,r.y)}return e.emplaceBack(t.x,t.y,t.z,i.x,i.y,p,u,f,d,a,r,n,o),e.length-1}function Vx(e){_y(e)&&e.collisionPadding&&(e.top-=e.collisionPadding[1],e.bottom+=e.collisionPadding[3]);const t=e.bottom-e.top;return t>0?Math.max(10,t):null}function jx(e,t,i,r){const n=e.compareText;if(t in n){const e=n[t];for(let t=e.length-1;t>=0;t--)if(r.dist(e[t])<i)return!0}else n[t]=[];return n[t].push(r),!1}function Gx(e,t){const i=e.fovAboveCenter,r=e.elevation?e.elevation.getMinElevationBelowMSL()*t:0,n=Math.min(r,e.isOrthographic?-10*t:0),o=(e._camera.position[2]*e.worldSize-n)/Math.cos(e._pitch),s=Math.sin(i)*o/Math.sin(Math.max(Math.PI/2-e._pitch-i,.01));let a=Math.sin(e._pitch)*s+o;const l=o*(1/e._horizonShift);if(!e.elevation||0===e.elevation.exaggeration()){let t=Math.max(e.zoom-17,0);e.isOrthographic&&(t/=10),a*=1+t}return Math.min(1.01*a,l)}function Hx(e,t){if(!t.isReprojectedInTileSpace)return{scale:1<<e.z,x:e.x,y:e.y,x2:e.x+1,y2:e.y+1,projection:t};const i=Math.pow(2,-e.z),r=e.x*i,n=(e.x+1)*i,o=e.y*i,s=(e.y+1)*i,a=$c(r),l=$c(n),c=qc(o),h=qc(s),u=t.project(a,c),d=t.project(l,c),p=t.project(l,h),f=t.project(a,h);let m=Math.min(u.x,d.x,p.x,f.x),_=Math.min(u.y,d.y,p.y,f.y),g=Math.max(u.x,d.x,p.x,f.x),y=Math.max(u.y,d.y,p.y,f.y);const x=i/16;function v(e,i,r,n,o,s){const a=(r+o)/2,l=(n+s)/2,c=t.project($c(a),qc(l)),h=Math.max(0,m-c.x,_-c.y,c.x-g,c.y-y);m=Math.min(m,c.x),g=Math.max(g,c.x),_=Math.min(_,c.y),y=Math.max(y,c.y),h>x&&(v(e,c,r,n,a,l),v(c,i,a,l,o,s))}v(u,d,r,o,n,o),v(d,p,n,o,n,s),v(p,f,n,s,r,s),v(f,u,r,s,r,o),m-=x,_-=x,g+=x,y+=x;const b=1/Math.max(g-m,y-_);return{scale:b,x:m*b,y:_*b,x2:g*b,y2:y*b,projection:t}}function $x(e,{x:t,y:i},r=0){return new Ie(((t-r)*e.scale-e.x)*Yr,(i*e.scale-e.y)*Yr)}const qx=h(new Float32Array(16));class Zx{constructor(e){this.spec=e,this.name=e.name,this.wrap=!1,this.requiresDraping=!1,this.supportsWorldCopies=!1,this.supportsTerrain=!1,this.supportsFog=!1,this.supportsFreeCamera=!1,this.zAxisUnit="meters",this.isReprojectedInTileSpace=!0,this.unsupportedLayers=["custom"],this.center=[0,0],this.range=[3.5,7]}project(e,t){return{x:0,y:0,z:0}}unproject(e,t){return new Nc(0,0)}projectTilePoint(e,t,i){return{x:e,y:t,z:0}}locationPoint(e,t,i,r=!0){return e._coordinatePoint(e.locationCoordinate(t,i),r)}pixelsPerMeter(e,t){return Hc(1,e)*t}pixelSpaceConversion(e,t,i){return 1}farthestPixelDistance(e){return Gx(e,e.pixelsPerMeter)}pointCoordinate(e,t,i,r){const n=e.horizonLineFromTop(!1),o=new Ie(t,Math.max(n,i));return e.rayIntersectionCoordinate(e.pointRayIntersection(o,r))}pointCoordinate3D(e,t,i){const r=new Ie(t,i);if(e.elevation)return e.elevation.pointCoordinate(r);{const t=this.pointCoordinate(e,r.x,r.y,0);return[t.x,t.y,t.z]}}isPointAboveHorizon(e,t){if(e.elevation&&e.elevation.visibleDemTiles.length)return!this.pointCoordinate3D(e,t.x,t.y);const i=e.horizonLineFromTop();return t.y<i}createInversionMatrix(e,t){return qx}createTileMatrix(e,t,i){let r,n,o;const s=i.canonical,a=h(new Float64Array(16));if(this.isReprojectedInTileSpace){const l=Hx(s,this);r=1,n=l.x+i.wrap*l.scale,o=l.y,f(a,a,[r/l.scale,r/l.scale,e.pixelsPerMeter/t])}else r=t/e.zoomScale(s.z),n=(s.x+Math.pow(2,s.z)*i.wrap)*r,o=s.y*r;return p(a,a,[n,o,0]),f(a,a,[r/Yr,r/Yr,1]),a}upVector(e,t,i){return[0,0,1]}upVectorScale(e,t,i){return{metersToTile:1}}}class Wx extends Zx{constructor(e){super(e),this.range=[4,7],this.center=e.center||[-96,37.5];const[t,i]=this.parallels=e.parallels||[29.5,45.5],r=Math.sin(Re(t));this.n=(r+Math.sin(Re(i)))/2,this.c=1+r*(2*this.n-r),this.r0=Math.sqrt(this.c)/this.n}project(e,t){const{n:i,c:r,r0:n}=this,o=Re(e-this.center[0]),s=Re(t),a=Math.sqrt(r-2*i*Math.sin(s))/i;return{x:a*Math.sin(o*i),y:a*Math.cos(o*i)-n,z:0}}unproject(e,t){const{n:i,c:r,r0:n}=this,o=n+t;let s=Math.atan2(e,Math.abs(o))*Math.sign(o);o*i<0&&(s-=Math.PI*Math.sign(e)*Math.sign(o));const a=Re(this.center[0])*i;return s=Ue(s,-Math.PI-a,Math.PI-a),new Nc(ke(ze(s/i)+this.center[0],-180,180),ke(ze(Math.asin(ke((r-(e*e+o*o)*i*i)/(2*i),-1,1))),-85.051129,Wc))}}const Xx=1.340264,Yx=-.081106,Jx=893e-6,Kx=.003796,Qx=Math.sqrt(3)/2;class ev extends Zx{project(e,t){t=t/180*Math.PI,e=e/180*Math.PI;const i=Math.asin(Qx*Math.sin(t)),r=i*i,n=r*r*r;return{x:.5*(e*Math.cos(i)/(Qx*(Xx+3*Yx*r+n*(7*Jx+9*Kx*r)))/Math.PI+.5),y:1-.5*(i*(Xx+Yx*r+n*(Jx+Kx*r))/Math.PI+1),z:0}}unproject(e,t){e=(2*e-.5)*Math.PI;let i=t=(2*(1-t)-1)*Math.PI,r=i*i,n=r*r*r;for(let a,l,c,h=0;h<12&&(l=i*(Xx+Yx*r+n*(Jx+Kx*r))-t,c=Xx+3*Yx*r+n*(7*Jx+9*Kx*r),a=l/c,i=ke(i-a,-Math.PI/3,Math.PI/3),r=i*i,n=r*r*r,!(Math.abs(a)<1e-12));++h);const o=Qx*e*(Xx+3*Yx*r+n*(7*Jx+9*Kx*r))/Math.cos(i),s=Math.asin(Math.sin(i)/Qx);return new Nc(ke(180*o/Math.PI,-180,180),ke(180*s/Math.PI,-85.051129,Wc))}}class tv extends Zx{constructor(e){super(e),this.wrap=!0,this.supportsWorldCopies=!0}project(e,t){return{x:.5+e/360,y:.5-t/360,z:0}}unproject(e,t){return new Nc(360*(e-.5),ke(360*(.5-t),-85.051129,Wc))}}const iv=Math.PI/2;function rv(e){return Math.tan((iv+e)/2)}class nv extends Zx{constructor(e){super(e),this.center=e.center||[0,30];const[t,i]=this.parallels=e.parallels||[30,30];let r=Re(t),n=Re(i);this.southernCenter=r+n<0,this.southernCenter&&(r=-r,n=-n);const o=Math.cos(r),s=rv(r);this.n=r===n?Math.sin(r):Math.log(o/Math.cos(n))/Math.log(rv(n)/s),this.f=o*Math.pow(rv(r),this.n)/this.n}project(e,t){t=Re(t),this.southernCenter&&(t=-t),e=Re(e-this.center[0]);const i=1e-6,{n:r,f:n}=this;n>0?t<-iv+i&&(t=-iv+i):t>iv-i&&(t=iv-i);const o=n/Math.pow(rv(t),r);let s=o*Math.sin(r*e),a=n-o*Math.cos(r*e);return s=.5*(s/Math.PI+.5),a=.5*(a/Math.PI+.5),{x:s,y:this.southernCenter?a:1-a,z:0}}unproject(e,t){e=(2*e-.5)*Math.PI,this.southernCenter&&(t=1-t),t=(2*(1-t)-.5)*Math.PI;const{n:i,f:r}=this,n=r-t,o=Math.sign(n),s=Math.sign(i)*Math.sqrt(e*e+n*n);let a=Math.atan2(e,Math.abs(n))*o;n*i<0&&(a-=Math.PI*Math.sign(e)*o);const l=ke(ze(a/i)+this.center[0],-180,180),c=ke(ze(2*Math.atan(Math.pow(r/s,1/i))-iv),-85.051129,Wc);return new Nc(l,this.southernCenter?-c:c)}}class ov extends Zx{constructor(e){super(e),this.wrap=!0,this.supportsWorldCopies=!0,this.supportsTerrain=!0,this.supportsFog=!0,this.supportsFreeCamera=!0,this.isReprojectedInTileSpace=!1,this.unsupportedLayers=[],this.range=null}project(e,t){return{x:jc(e),y:Gc(t),z:0}}unproject(e,t){return new Nc($c(e),qc(t))}}const sv=Re(Wc);class av extends Zx{project(e,t){const i=(t=Re(t))*t,r=i*i;return{x:.5*((e=Re(e))*(.8707-.131979*i+r*(r*(.003971*i-.001529*r)-.013791))/Math.PI+.5),y:1-.5*(t*(1.007226+i*(.015085+r*(.028874*i-.044475-.005916*r)))/Math.PI+1),z:0}}unproject(e,t){e=(2*e-.5)*Math.PI;let i=t=(2*(1-t)-1)*Math.PI,r=25,n=0,o=i*i;do{o=i*i;const e=o*o;n=(i*(1.007226+o*(.015085+e*(.028874*o-.044475-.005916*e)))-t)/(1.007226+o*(.045255+e*(.259866*o-.311325-.005916*11*e))),i=ke(i-n,-sv,sv)}while(Math.abs(n)>1e-6&&--r>0);return o=i*i,new Nc(ke(ze(e/(.8707+o*(o*(o*o*o*(.003971-.001529*o)-.013791)-.131979))),-180,180),ze(i))}}const lv=Re(Wc);class cv extends Zx{project(e,t){t=Re(t),e=Re(e);const i=Math.cos(t),r=2/Math.PI,n=Math.acos(i*Math.cos(e/2)),o=Math.sin(n)/n,s=.5*(e*r+2*i*Math.sin(e/2)/o)||0,a=.5*(t+Math.sin(t)/o)||0;return{x:.5*(s/Math.PI+.5),y:1-.5*(a/Math.PI+1),z:0}}unproject(e,t){let i=e=(2*e-.5)*Math.PI,r=t=(2*(1-t)-1)*Math.PI,n=25;const o=1e-6;let s=0,a=0;do{const n=Math.cos(r),o=Math.sin(r),l=2*o*n,c=o*o,h=n*n,u=Math.cos(i/2),d=Math.sin(i/2),p=2*u*d,f=d*d,m=1-h*u*u,_=m?1/m:0,g=m?Math.acos(n*u)*Math.sqrt(1/m):0,y=.5*(2*g*n*d+2*i/Math.PI)-e,x=.5*(g*o+r)-t,v=.5*_*(h*f+g*n*u*c)+1/Math.PI,b=_*(p*l/4-g*o*d),w=.125*_*(l*d-g*o*h*p),T=.5*_*(c*u+g*f*n)+.5,S=b*w-T*v;s=(x*b-y*T)/S,a=(y*w-x*v)/S,i=ke(i-s,-Math.PI,Math.PI),r=ke(r-a,-lv,lv)}while((Math.abs(s)>o||Math.abs(a)>o)&&--n>0);return new Nc(ze(i),ze(r))}}class hv extends Zx{constructor(e){super(e),this.center=e.center||[0,0],this.parallels=e.parallels||[0,0],this.cosPhi=Math.max(.01,Math.cos(Re(this.parallels[0]))),this.scale=1/(2*Math.max(Math.PI*this.cosPhi,1/this.cosPhi)),this.wrap=!0,this.supportsWorldCopies=!0}project(e,t){const{scale:i,cosPhi:r}=this;return{x:Re(e)*r*i+.5,y:-Math.sin(Re(t))/r*i+.5,z:0}}unproject(e,t){const{scale:i,cosPhi:r}=this,n=-(t-.5)/i;return new Nc(ke(ze((e-.5)/i)/r,-180,180),ke(ze(Math.asin(ke(n*r,-1,1))),-85.051129,Wc))}}class uv extends ov{constructor(e){super(e),this.requiresDraping=!0,this.supportsWorldCopies=!1,this.supportsFog=!0,this.zAxisUnit="pixels",this.unsupportedLayers=["debug"],this.range=[3,5]}projectTilePoint(e,t,i){const r=Au(e,t,i);return H(r,r,Pu(vu(i))),{x:r[0],y:r[1],z:r[2]}}locationPoint(e,t,i){const r=Oc(t.lat,t.lng),n=U([],r),o=i?e._centerAltitude+i:e.elevation?e.elevation.getAtPointOrZero(e.locationCoordinate(t),e._centerAltitude):e._centerAltitude;F(r,r,n,Hc(1,0)*Yr*o);const s=h(new Float64Array(16));return d(s,e.pixelMatrix,e.globeMatrix),H(r,r,s),new Ie(r[0],r[1])}pixelsPerMeter(e,t){return Hc(1,0)*t}pixelSpaceConversion(e,t,i){const r=Hc(1,e)*t,n=yi(Hc(1,45)*t,r,i);return this.pixelsPerMeter(e,t)/n}createTileMatrix(e,t,i){const r=Du(vu(i.canonical));return d(new Float64Array(16),e.globeMatrix,r)}createInversionMatrix(e,t){const{center:i}=e,r=Pu(vu(t));return _(r,r,Re(i.lng)),m(r,r,Re(i.lat)),f(r,r,[e._pixelsPerMercatorPixel,e._pixelsPerMercatorPixel,1]),Float32Array.from(r)}pointCoordinate(e,t,i,r){return gu(e,t,i,!0)||new Qc(0,0)}pointCoordinate3D(e,t,i){const r=this.pointCoordinate(e,t,i,0);return[r.x,r.y,r.z]}isPointAboveHorizon(e,t){return!gu(e,t.x,t.y,!1)}farthestPixelDistance(e){const t=function(e,t){const i=e.cameraToCenterDistance,r=e._centerAltitude*t,n=e._camera,o=e._camera.forward(),s=C([],L([],o,-i),[0,0,r]),a=e.worldSize/(2*Math.PI),l=[0,0,-a],c=e.width/e.height,h=Math.tan(e.fovAboveCenter),u=L([],n.up(),h),d=L([],n.right(),h*c),p=U([],C([],C([],o,u),d)),f=[];let m;if(new Sh(s,p).closestPointOnSphere(l,a,f)){const t=X([],C([],f,l),s);m=Math.cos(e.fovAboveCenter)*E(t)}else{const e=X([],s,l),t=X([],l,s);U(t,t);const i=E(e)-a;m=Math.sqrt(i*(i+2*a));const r=Math.acos(m/(a+i))-Math.acos(V(o,t));m*=Math.cos(r)}return 1.01*m}(e,this.pixelsPerMeter(e.center.lat,e.worldSize)),i=Fu(e.zoom);if(i>0){const r=Gx(e,Hc(1,e.center.lat)*e.worldSize),n=e.worldSize/(2*Math.PI),o=Math.max(e.width,e.height)/e.worldSize*Math.PI;return yi(t,r+n*(1-Math.cos(o)),Math.pow(i,10))}return t}upVector(e,t,i){return Au(t,i,e,1)}upVectorScale(e){return{metersToTile:mu(Mu(vu(e)))}}}function dv(e){const t=e.parallels,i=!!t&&Math.abs(t[0]+t[1])<.01;switch(e.name){case"mercator":return new ov(e);case"equirectangular":return new tv(e);case"naturalEarth":return new av(e);case"equalEarth":return new ev(e);case"winkelTripel":return new cv(e);case"albers":return i?new hv(e):new Wx(e);case"lambertConformalConic":return i?new hv(e):new nv(e);case"globe":return new uv(e)}throw new Error(`Invalid projection name: ${e.name}`)}class pv{constructor(e,t){this.lastParams=null,this.lastAllFeaturesIndex=-2,this.appearancesVersion=t,this.appearances=e;const i=e.map(e=>function(e){if(!e.condition)return{featureDependent:!1,stateDependent:!1,zoomDependent:!1,pitchDependent:!1,brightnessDependent:!1,worldviewDependent:!1};const t=e.condition.expression;return{featureDependent:!En(t),stateDependent:!An(t),zoomDependent:!Mn(t,["zoom"]),pitchDependent:!Mn(t,["pitch"]),brightnessDependent:!Mn(t,["brightness","measure-light"]),worldviewDependent:!Mn(t,["worldview"])}}(e));this.anyFeatureDependent=i.some(e=>e.featureDependent),this.anyStateDependent=i.some(e=>e.stateDependent)}update(e,t){const i=this.lastParams,r=!i||i.zoom!==e.zoom||i.pitch!==(e.pitch||0)||i.brightness!==(e.brightness||0)||i.worldview!==e.worldview;this.lastParams={zoom:e.zoom,pitch:e.pitch||0,brightness:e.brightness||0,worldview:e.worldview};const n=t&&this.anyStateDependent;if(!r&&!n&&-2!==this.lastAllFeaturesIndex)return{kind:"no-changes"};if(!this.anyFeatureDependent&&!n){const t=this.evaluateAllFeatures(e);return t===this.lastAllFeaturesIndex?{kind:"no-changes"}:(this.lastAllFeaturesIndex=t,{kind:"all-features",appearanceIndex:t})}return{kind:"per-feature"}}evaluateAllFeatures(e){for(let t=0;t<this.appearances.length;t++){const i=this.appearances[t];if(i.condition&&i.condition.evaluate(e,void 0,void 0,void 0))return t}return-1}}const fv=ch.types,mv=[{name:"a_fade_opacity",components:1,type:"Uint8",offset:0}];function _v(e,t,i,r,n,o,s,a,l,c,h,u,d){const p=a?Math.min(Ox,Math.round(a[0])):0,f=a?Math.min(Ox,Math.round(a[1])):0;e.emplaceBack(t,i,Math.round(32*r),Math.round(32*n),o,s,(p<<1)+(l?1:0),0+(f<<1),16*c,16*h,256*u,256*d)}function gv(e,t,i){e.emplaceBack(t,i)}function yv(e,t,i,r,n,o,s){e.emplaceBack(t,i,r,n,o,s)}const xv=(e,t,i,r)=>{for(let n=0;n<t;n++)e.emplaceBack(i[0],i[1],i[2],r[0],r[1],r[2])};function vv(e,t,i,r,n){e.emplaceBack(t,i,r,n),e.emplaceBack(t,i,r,n),e.emplaceBack(t,i,r,n),e.emplaceBack(t,i,r,n)}function bv(e){for(const t of e.sections)if(Ws(t.text))return!0;return!1}const wv=12;class Tv{constructor(e){this.layoutVertexArray=new ul,this.indexArray=new vl,this.programConfigurations=e,this.segments=new Jl,this.dynamicLayoutVertexArray=new pl,this.opacityVertexArray=new fl,this.placedSymbolArray=new kl,this.iconTransitioningVertexArray=new ml,this.globeExtVertexArray=new dl,this.zOffsetVertexArray=new tl,this.orientationVertexArray=new Tl,this.symbolInstanceIndices=[],this.uboBinder=null,this.featureIdArray=new tl,this.featureIdBuffer=null,this.cachedBatchIndices=null,this.cachedBatchSegments=null}isEmpty(){return 0===this.layoutVertexArray.length&&0===this.indexArray.length&&0===this.dynamicLayoutVertexArray.length&&0===this.opacityVertexArray.length&&0===this.iconTransitioningVertexArray.length}getBatchGrouping(e){const t=e.get().length===this.segments.get().length;if(t&&this.cachedBatchIndices&&this.cachedBatchSegments)return{batchIndices:this.cachedBatchIndices,batchSegments:this.cachedBatchSegments};const i=/* @__PURE__ */new Map;for(const o of e.get()){const e=void 0!==o.batchIndex?o.batchIndex:0;i.has(e)||i.set(e,[]),i.get(e).push(o)}const r=Array.from(i.keys()).sort((e,t)=>e-t),n=/* @__PURE__ */new Map;for(const o of r){const e=i.get(o);n.set(o,new Jl(e))}return t&&(this.cachedBatchIndices=r,this.cachedBatchSegments=n),{batchIndices:r,batchSegments:n}}snapshotSymbolVertexData(e,t){const i=e*wv;return this.layoutVertexArray.uint16.slice(i,i+t*wv)}restoreSymbolVertexData(e,t){this.layoutVertexArray.uint16.set(t,e*wv)}updateSymbolVertexData(e,t,i,r,n,o,s,a,l,c,h,u,d){const p=this.layoutVertexArray.uint16,f=e*wv;p[f]=t,p[f+1]=i,p[f+2]=r,p[f+3]=n,p[f+4]=o,p[f+5]=s,p[f+6]=a,p[f+7]=l,p[f+8]=c,p[f+9]=h,p[f+10]=u,p[f+11]=d}upload(e,t,i,r,n,o){this.isEmpty()||(i&&(this.cachedBatchIndices=null,this.cachedBatchSegments=null,this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,xg.members,!!o),this.indexBuffer=e.createIndexBuffer(this.indexArray,t),this.dynamicLayoutVertexBuffer=e.createVertexBuffer(this.dynamicLayoutVertexArray,bg.members,!0),this.opacityVertexBuffer=e.createVertexBuffer(this.opacityVertexArray,mv,!0),this.iconTransitioningVertexArray.length>0&&(this.iconTransitioningVertexBuffer=e.createVertexBuffer(this.iconTransitioningVertexArray,Ig.members,!0)),this.globeExtVertexArray.length>0&&(this.globeExtVertexBuffer=e.createVertexBuffer(this.globeExtVertexArray,vg.members,!0)),!this.zOffsetVertexBuffer&&(this.zOffsetVertexArray.length>0||n)&&(this.zOffsetVertexBuffer=e.createVertexBuffer(this.zOffsetVertexArray,wg.members,!0)),!this.orientationVertexBuffer&&this.orientationVertexArray&&this.orientationVertexArray.length>0&&(this.orientationVertexBuffer=e.createVertexBuffer(this.orientationVertexArray,Sg.members,!0)),this.opacityVertexBuffer.itemSize=1,this.featureIdArray&&this.featureIdArray.length>0&&(this.featureIdBuffer=e.createVertexBuffer(this.featureIdArray,Tg.members,!1))),(i||r)&&(this.programConfigurations.upload(e),this.uboBinder&&this.uboBinder.upload(e)))}destroy(){this.layoutVertexBuffer&&(this.layoutVertexBuffer.destroy(),this.indexBuffer.destroy(),this.programConfigurations.destroy(),this.segments.destroy(),this.dynamicLayoutVertexBuffer.destroy(),this.opacityVertexBuffer.destroy(),this.iconTransitioningVertexBuffer&&this.iconTransitioningVertexBuffer.destroy(),this.globeExtVertexBuffer&&this.globeExtVertexBuffer.destroy(),this.zOffsetVertexBuffer&&this.zOffsetVertexBuffer.destroy(),this.orientationVertexBuffer&&this.orientationVertexBuffer.destroy(),this.featureIdBuffer&&this.featureIdBuffer.destroy(),this.uboBinder&&this.uboBinder.destroy())}}as(Tv,"SymbolBuffers",{omit:["cachedBatchIndices","cachedBatchSegments"]});class Sv{constructor(e,t,i){this.layoutVertexArray=new e,this.layoutAttributes=t,this.indexArray=new i,this.segments=new Jl,this.collisionVertexArray=new xl,this.collisionVertexArrayExt=new pl}upload(e){this.layoutVertexBuffer=e.createVertexBuffer(this.layoutVertexArray,this.layoutAttributes),this.indexBuffer=e.createIndexBuffer(this.indexArray),this.collisionVertexBuffer=e.createVertexBuffer(this.collisionVertexArray,Eg.members,!0),this.collisionVertexBufferExt=e.createVertexBuffer(this.collisionVertexArrayExt,Ag.members,!0)}destroy(){this.layoutVertexBuffer&&(this.layoutVertexBuffer.destroy(),this.indexBuffer.destroy(),this.segments.destroy(),this.collisionVertexBuffer.destroy(),this.collisionVertexBufferExt.destroy())}}as(Sv,"CollisionBuffers");class Iv{constructor(e){this.collisionBoxArray=e.collisionBoxArray,this.zoom=e.zoom,this.overscaling=e.overscaling,this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.index=e.index,this.pixelRatio=e.pixelRatio,this.sourceLayerIndex=e.sourceLayerIndex,this.hasPattern=!1,this.hasRTLText=!1,this.fullyClipped=!1,this.hasAnyIconTextFit=!1,this.sortKeyRanges=[],this.collisionCircleArray=[],this.placementInvProjMatrix=h([]),this.placementViewportMatrix=h([]);const t=this.layers[0]._unevaluatedLayout._values;this.worldview=e.worldview,this.localizable=e.localizable,this.maxUniformBufferBindings=e.maxUniformBufferBindings,this.maxUniformBlockSizeDwords=e.maxUniformBlockSizeDwords,this.disableSymbolUBO=e.disableSymbolUBO,this.textSizeData=Ty(this.zoom,t["text-size"],this.worldview,e.availableImages),this.iconSizeData=Ty(this.zoom,t["icon-size"],this.worldview,e.availableImages);const i=this.layers[0].layout,r=i.get("symbol-sort-key"),n=i.get("symbol-z-order");this.lut=e.lut,this.canOverlap=i.get("text-allow-overlap")||i.get("icon-allow-overlap")||i.get("text-ignore-placement")||i.get("icon-ignore-placement"),this.sortFeaturesByKey="viewport-y"!==n&&void 0!==r.constantOr(1),this.sortFeaturesByY=("viewport-y"===n||"auto"===n&&!this.sortFeaturesByKey)&&this.canOverlap,this.writingModes=i.get("text-writing-mode").map(e=>ry[e]),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.sourceID=e.sourceID,this.projection=e.projection,this.hasAnyZOffset=!1,this.zOffsetSortDirty=!1,this.zOffsetBuffersNeedUpload=!1,this.elevationType="none",this.elevationStateComplete=!1,this.activeReplacements=[],this.replacementUpdateTime=0,this.hasAnySecondaryIcon=!1,this.hasAppearances=null,this.featureAppearances=null,this.featureAppearanceData=/* @__PURE__ */new Map}hasAnyAppearanceLayoutProperty(e){const t=this.layers[0].getAppearances();if(!t||0===t.length)return!1;const i=Array.isArray(e)?e:[e];return t.some(e=>i.some(t=>e.hasLayoutProperty(t)))}getAppearanceFeatureData(e){return this.featureAppearanceData.get(e)}createArrays(){this.text=new Tv(new Sc(this.layers,{zoom:this.zoom,lut:this.lut},e=>e.startsWith("text")||e.startsWith("symbol"))),this.icon=new Tv(new Sc(this.layers,{zoom:this.zoom,lut:this.lut},e=>e.startsWith("icon")||e.startsWith("symbol"))),this.disableSymbolUBO||(this.text.uboBinder=new zg(this.layers[0],this.zoom,this.lut,!0,"",this.maxUniformBufferBindings,this.maxUniformBlockSizeDwords),this.icon.uboBinder=new zg(this.layers[0],this.zoom,this.lut,!1,"",this.maxUniformBufferBindings,this.maxUniformBlockSizeDwords)),this.glyphOffsetArray=new Vl,this.lineVertexArray=new jl,this.symbolInstances=new Ul}calculateGlyphDependencies(e,t,i,r,n){for(const o of e){const e=o.codePointAt(0);if(void 0===e)break;if(t[e]=!0,r&&n&&e<=65535){const e=Og[o];e&&(t[e.charCodeAt(0)]=!0)}}}calculateEffectiveAppearanceIconSize(e,t,i,r,n,o,s){if(!e.hasLayoutProperty("icon-size"))return s*o;let a=1;const l=e.getUnevaluatedLayoutProperty("icon-size"),c=Ty(this.zoom,l,this.worldview,n),h=Iy(c,t);if("constant"!==c.kind&&"camera"!==c.kind||(a=h.uSize),"composite"===c.kind){const{minZoom:e,maxZoom:t}=c,o=l.possiblyEvaluate(new sa(e,{worldview:this.worldview}),r),s=l.possiblyEvaluate(new sa(t,{worldview:this.worldview}),r),u=o.evaluate(i,{},r,n);a=u+(s.evaluate(i,{},r,n)-u)*h.uSizeT}return"source"===c.kind&&(a=l.possiblyEvaluate(new sa(this.zoom,{worldview:this.worldview}),r).evaluate(i,{},r,n)),a*o}updateFootprints(e,t){}updateReplacement(e,t){if(t.updateTime===this.replacementUpdateTime)return!1;this.replacementUpdateTime=t.updateTime;const i=t.getReplacementRegionsForTile(e.toUnwrapped(),!0);return!Yp(this.activeReplacements,i)&&(this.activeReplacements=i,!0)}getResolvedImageFromTokens(e){return"string"==typeof e?Wi.build(e):e}populate(e,t,i,r){const n=this.layers[0],o=n.layout,s="globe"===this.projection.name,a=o.get("text-font"),l=o.get("text-field"),c=o.get("icon-image"),[h,u]=o.get("icon-size-scale-range"),d=ke(t.scaleFactor||1,h,u),[p,f]=o.get("text-size-scale-range"),m=ke(t.scaleFactor||1,p,f),_=("constant"!==l.value.kind||l.value.value instanceof qi&&!l.value.value.isEmpty()||l.value.value.toString().length>0)&&("constant"!==a.value.kind||a.value.value.length>0),g="constant"!==c.value.kind||!!c.value.value||Object.keys(c.parameters).length>0,y=this.hasAnyAppearanceLayoutProperty("icon-image"),x=o.get("symbol-sort-key");if(this.features=[],this.featureAppearanceData=/* @__PURE__ */new Map,!_&&!g&&!y)return;const v=t.iconDependencies,b=t.glyphDependencies,w=t.availableImages,T=new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),S=e=>{const t=e.id.toString();v.has(t)?v.get(t).push(e):v.set(t,[e])};for(const I of e){const{feature:e,id:t,index:l,sourceLayerIndex:c}=I,h=n._featureFilter.needGeometry,u=lh(e,h);if(!n._featureFilter.filter(T,u,i))continue;if(h||(u.geometry=ah(e,i,r)),s&&1!==e.type&&i.z<=5){const e=u.geometry,t=.98078528056,r=(e,r)=>V(Au(e.x,e.y,i,1),Au(r.x,r.y,i,1))<t;for(let i=0;i<e.length;i++)e[i]=rh(e[i],r)}let p,f;if(_){const e=n.getValueAndResolveTokens("text-field",u,i,w),t=qi.factory(e);bv(t)&&(this.hasRTLText=!0),(!this.hasRTLText||"unavailable"===ia()||this.hasRTLText&&na.isParsed())&&(p=Fg(t,n,u))}if(g){const e=n.getValueAndResolveTokens("icon-image",u,i,w);f=this.getResolvedImageFromTokens(e)}const E=this.layers[0];let A=!1;if(!f&&y){const e=E.getAppearances();for(const t of e)if(t.getLayoutProperty("icon-image")){const e=E.getAppearanceValueAndResolveTokens(t,"icon-image",u,i,w);if(e){f=this.getResolvedImageFromTokens(e),A=!0;break}}}if(!p&&!f)continue;const M=this.sortFeaturesByKey?x.evaluate(u,{},i):void 0,C={id:t,text:p,icon:f,index:l,sourceLayerIndex:c,geometry:u.geometry,properties:e.properties,type:fv[e.type],sortKey:M};if(this.features.push(C),this.featureAppearanceData.set(l,{id:t,properties:e.properties,usesAppearanceIconAsPlaceholder:A}),f){const e=E._unevaluatedLayout._values,{iconPrimary:t,iconSecondary:r}=Ex(f,this.iconSizeData,e["icon-size"],i,this.zoom,C,this.pixelRatio,d,this.worldview,w);S(t),r&&(this.hasAnySecondaryIcon=!0,S(r))}const P=E.getAppearances();if(0!==P.length&&P.forEach(e=>{if(!e.getLayoutProperty("icon-image"))return;const t=this.getCombinedIconPrimary(e,E,u,i,w,C,d);t&&S(t)}),p){const e=a.evaluate(u,{},i).join(","),t="map"===o.get("text-rotation-alignment")&&"point"!==o.get("symbol-placement");this.allowVerticalPlacement=this.writingModes&&this.writingModes.includes(ry.vertical);for(const i of p.sections)if(i.image){const e=i.image.getPrimary().scaleSelf(this.pixelRatio*m),t=e.id.toString(),r=v.get(t)||[];r.push(e),v.set(t,r)}else{const r=ks(p.toString()),n=i.fontStack||e,o=b[n]=b[n]||{};this.calculateGlyphDependencies(i.text,o,t,this.allowVerticalPlacement,r)}}}if("line"===o.get("symbol-placement")&&(this.features=function(e){const t={},i={},r=[];let n=0;function o(t){r.push(e[t]),n++}function s(e,t,n){const o=i[e];return delete i[e],i[t]=o,r[o].geometry[0].pop(),r[o].geometry[0]=r[o].geometry[0].concat(n[0]),o}function a(e,i,n){const o=t[i];return delete t[i],t[e]=o,r[o].geometry[0].shift(),r[o].geometry[0]=n[0].concat(r[o].geometry[0]),o}function l(e,t,i){const r=i?t[0].at(-1):t[0][0];return`${e}:${r.x}:${r.y}`}for(let c=0;c<e.length;c++){const h=e[c],u=h.geometry,d=h.text?h.text.toString():null;if(!d){o(c);continue}const p=l(d,u),f=l(d,u,!0);if(p in i&&f in t&&i[p]!==t[f]){const e=a(p,f,u),n=s(p,f,r[e].geometry);delete t[p],delete i[f],i[l(d,r[n].geometry,!0)]=n,r[e].geometry=null}else p in i?s(p,f,u):f in t?a(p,f,u):(o(c),t[p]=n-1,i[f]=n-1)}return r.filter(e=>e.geometry)}(this.features)),"hd-road-markup"===o.get("symbol-elevation-reference")){if(this.elevationType="road",t.elevationFeatures){!this.elevationFeatures&&t.elevationFeatures.length>0&&(this.elevationFeatures=[],this.elevationFeatureIdToIndex=/* @__PURE__ */new Map);for(const e of t.elevationFeatures)this.elevationFeatureIdToIndex.set(e.id,this.elevationFeatures.length),this.elevationFeatures.push(e)}}else o.get("symbol-z-elevate")&&(this.elevationType="offset");"none"!==this.elevationType&&(this.zOffsetBuffersNeedUpload=!0),this.sortFeaturesByKey&&this.features.sort((e,t)=>e.sortKey-t.sortKey)}getCombinedIconPrimary(e,t,i,r,n,o,s){let a,l;if(e.hasLayoutProperty("icon-image")){const o=t.getAppearanceValueAndResolveTokens(e,"icon-image",i,r,n);a=this.getResolvedImageFromTokens(o)}else{const e=t.getValueAndResolveTokens("icon-image",i,r,n);a=this.getResolvedImageFromTokens(e)}if(a){const i=e.hasLayoutProperty("icon-size")?e.getUnevaluatedLayoutProperty("icon-size"):t._unevaluatedLayout._values["icon-size"];l=Ex(a,Ty(this.zoom,i,this.worldview,n),i,r,this.zoom,o,this.pixelRatio,s,this.worldview,n).iconPrimary}return l}updateSymbolInstanceIconVertices(e,t,i,r,n,o){const{canonical:s,availableImages:a,globalProperties:l,layer:c,iconScaleFactor:h,featureState:u,layoutIconOffset:d,layoutIconSize:p,layoutIconRotate:f}=o;if(e.placedIconSymbolIndex<0)return{vertexOffsetDelta:0,hasChanges:!1};if(t.activeAppearanceIndex===i)return{vertexOffsetDelta:e.numIconVertices,hasChanges:!1};const m=i>=0?c.appearances[i]:null;if(m){const i=this.getCombinedIconPrimary(m,c,r,s,a,{sortKey:void 0,text:void 0,icon:null,index:e.featureIndex,sourceLayerIndex:e.featureIndex,geometry:[],properties:t.properties,type:"Point",id:t.id},h);if(!i)return{vertexOffsetDelta:0,hasChanges:!1};const o=i.toString(),_=this.iconAtlasPositions&&this.iconAtlasPositions.get(o);if(_){const{appearanceIconOffset:i,appearanceIconRotate:o}=bx(m,c,r,s,d,f,p,h);let g=gy(_,void 0,i,c.layout.get("icon-anchor").evaluate(r,u,s));const y=_.sdf,x=c.layout.get("icon-text-fit").constantOr("none");"none"!==x&&t.textShaping&&t.iconTextFitPadding&&t.fontScale&&(g=yy(g,t.textShaping,x,t.iconTextFitPadding,i,t.fontScale));const v=this.calculateEffectiveAppearanceIconSize(m,l.zoom,r,s,a,h,p),b=0,w=1+(Math.min(Ox,Math.round(v*wy))<<1),T=ix(g,o,y,"none"!==x,h);t.isUsingAppearanceIconVertexData||(t.isUsingAppearanceIconVertexData=!0,t.layoutBasedIconVertexData=this.icon.snapshotSymbolVertexData(n,e.numIconVertices));const S=Math.floor(e.numIconVertices/4),I=Math.min(T.length,S);let E=n;for(let r=0;r<I;++r){const i=T[r],n=t.layoutBasedIconVertexData[0]||e.tileAnchorX,o=t.layoutBasedIconVertexData[1]||e.tileAnchorY,s=16*i.pixelOffsetTL.x,a=16*i.pixelOffsetTL.y,l=16*i.pixelOffsetBR.x,c=16*i.pixelOffsetBR.y,h=16*i.minFontScaleX,u=16*i.minFontScaleY;this.icon.updateSymbolVertexData(E,n,o,Math.round(32*i.tl.x),Math.round(32*i.tl.y),i.texPrimary.x,i.texPrimary.y,b,w,s,a,h,u),this.icon.updateSymbolVertexData(E+1,n,o,Math.round(32*i.tr.x),Math.round(32*i.tr.y),i.texPrimary.x+i.texPrimary.w,i.texPrimary.y,b,w,l,a,h,u),this.icon.updateSymbolVertexData(E+2,n,o,Math.round(32*i.bl.x),Math.round(32*i.bl.y),i.texPrimary.x,i.texPrimary.y+i.texPrimary.h,b,w,s,c,h,u),this.icon.updateSymbolVertexData(E+3,n,o,Math.round(32*i.br.x),Math.round(32*i.br.y),i.texPrimary.x+i.texPrimary.w,i.texPrimary.y+i.texPrimary.h,b,w,l,c,h,u),E+=4}const A=e.numIconVertices-4*I;for(let e=0;e<A;++e)this.icon.updateSymbolVertexData(E+e,0,0,0,0,0,0,0,0,0,0,0,0);return{vertexOffsetDelta:e.numIconVertices,hasChanges:!0}}}else{if(t.usesAppearanceIconAsPlaceholder)return this.icon.updateSymbolVertexData(n,0,0,0,0,0,0,0,0,0,0,0,0),this.icon.updateSymbolVertexData(n+1,0,0,0,0,0,0,0,0,0,0,0,0),this.icon.updateSymbolVertexData(n+2,0,0,0,0,0,0,0,0,0,0,0,0),this.icon.updateSymbolVertexData(n+3,0,0,0,0,0,0,0,0,0,0,0,0),{vertexOffsetDelta:e.numIconVertices,hasChanges:!0};if(t.isUsingAppearanceIconVertexData)return this.icon.restoreSymbolVertexData(n,t.layoutBasedIconVertexData),t.isUsingAppearanceIconVertexData=!1,{vertexOffsetDelta:t.layoutBasedIconVertexData.length/wv,hasChanges:!0}}return{vertexOffsetDelta:e.numIconVertices,hasChanges:!1}}updateSymbolInstanceTextVertices(e,t,i,r,n,o){const{canonical:s,layer:a,textScaleFactor:l,imageMap:c,featureState:h,layoutTextOffset:u,layoutTextSize:d,layoutTextRotate:p,layoutMinZoomSize:f,layoutMaxZoomSize:m,layoutTextSizeMinZoom:_,layoutTextSizeMaxZoom:g,availableImages:y}=o,x=e.numHorizontalGlyphVertices>0||e.numVerticalGlyphVertices>0;if(!x)return{vertexOffsetDelta:x?e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices:0,hasChanges:!1};if(t.activeAppearanceIndex===i)return{vertexOffsetDelta:e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices,hasChanges:!1};const v=i>=0?a.appearances[i]:null;if(v&&t.textShaping){const{appearanceTextOffset:i,appearanceTextRotate:o,appearanceTextSize:x}=Tx(v,a,r,s,u,p,d);t.fontScale=zx(x,t.textScaleFactor);const b=v.getUnevaluatedLayoutProperty("text-size");let w=this.textSizeData,T=_,S=g;v.hasLayoutProperty("text-size")&&(w=Ty(this.zoom,b,this.worldview,y),T="composite"===this.textSizeData.kind?this.textSizeData.minZoom:0,S="composite"===this.textSizeData.kind?this.textSizeData.maxZoom:0);const I=t.textShaping.bottom-u[1],E=t.textShaping.left-u[0],A=t.textShaping.right-u[0];t.textShaping.top=i[1]+(t.textShaping.top-u[1]),t.textShaping.bottom=i[1]+I,t.textShaping.left=i[0]+E,t.textShaping.right=i[0]+A;const M=hx(0,t.textShaping,i,a,!1,r,c,this.allowVerticalPlacement,o),C=x&&"composite"===w.kind?b.possiblyEvaluate(new sa(T,{}),s).evaluate(r,h,s):f,P=x&&"composite"===w.kind?b.possiblyEvaluate(new sa(S,{}),s).evaluate(r,h,s):m,D=kx(v.name,w,x,l,C,P),R=Array.isArray(D)?D[1]:x,z=0,L=1+(Math.min(Ox,Math.round(R*wy))<<1);t.isUsingAppearanceTextVertexData||(t.isUsingAppearanceTextVertexData=!0,t.layoutBasedTextVertexData=this.text.snapshotSymbolVertexData(n,e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices));for(let t=0;t<M.length&&t<(e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices)/4;++t){const i=M[t],r=i.glyphOffset[1],o=e.tileAnchorX,s=e.tileAnchorY,a=n+4*t;this.text.updateSymbolVertexData(a,o,s,Math.round(32*i.tl.x),Math.round(32*(r+i.tl.y)),i.texPrimary.x,i.texPrimary.y,z,L,i.pixelOffsetTL.x,i.pixelOffsetTL.y,i.minFontScaleX,i.minFontScaleY),this.text.updateSymbolVertexData(a+1,o,s,Math.round(32*i.tr.x),Math.round(32*(r+i.tr.y)),i.texPrimary.x+i.texPrimary.w,i.texPrimary.y,z,L,i.pixelOffsetBR.x,i.pixelOffsetTL.y,i.minFontScaleX,i.minFontScaleY),this.text.updateSymbolVertexData(a+2,o,s,Math.round(32*i.bl.x),Math.round(32*(r+i.bl.y)),i.texPrimary.x,i.texPrimary.y+i.texPrimary.h,z,L,i.pixelOffsetTL.x,i.pixelOffsetBR.y,i.minFontScaleX,i.minFontScaleY),this.text.updateSymbolVertexData(a+3,o,s,Math.round(32*i.br.x),Math.round(32*(r+i.br.y)),i.texPrimary.x+i.texPrimary.w,i.texPrimary.y+i.texPrimary.h,z,L,i.pixelOffsetBR.x,i.pixelOffsetBR.y,i.minFontScaleX,i.minFontScaleY)}return{vertexOffsetDelta:e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices,hasChanges:!0}}return t.isUsingAppearanceTextVertexData?(this.text.restoreSymbolVertexData(n,t.layoutBasedTextVertexData),t.isUsingAppearanceTextVertexData=!1,{vertexOffsetDelta:t.layoutBasedTextVertexData.length/wv,hasChanges:!0}):{vertexOffsetDelta:e.numHorizontalGlyphVertices+e.numVerticalGlyphVertices,hasChanges:!1}}updateExpressions(e){this.text&&this.text.programConfigurations.updateExpressions(e),this.icon&&this.icon.programConfigurations.updateExpressions(e)}update(e,t,i,r,n,o,s,a){if(this.text.uboBinder||this.text.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,this.worldview),this.icon.uboBinder||this.icon.programConfigurations.updatePaintArrays(e,t,n,i,r,o,s,this.worldview),a)if(o)this.text.uboBinder&&!this.text.uboBinder.isLightConstant&&this.text.uboBinder.updateDynamicExpressions(n[0],t,a,i,e,s),this.icon.uboBinder&&!this.icon.uboBinder.isLightConstant&&this.icon.uboBinder.updateDynamicExpressions(n[0],t,a,i,e,s);else if(Object.keys(e).length>0){const r=new Set(Object.keys(e).map(e=>{const t=Number(e);return!isNaN(t)&&Number.isSafeInteger(t)&&String(t)===e?t:e}));this.text.uboBinder&&this.text.uboBinder.updateFeatures(r,n[0],t,a,i,e,s),this.icon.uboBinder&&this.icon.uboBinder.updateFeatures(r,n[0],t,a,i,e,s)}}updateRoadElevation(e){if("road"!==this.elevationType||!this.elevationFeatures)return;if(this.elevationStateComplete)return;this.elevationStateComplete=!0,this.hasAnyZOffset=!1;let t=!1;const i=Kc(e),r=1/i;let n=!1,o=!1;for(let s=0;s<this.symbolInstances.length;s++){const e=this.symbolInstances.get(s),a=A(1,0,0),l=A(0,1,0),{numHorizontalGlyphVertices:c,numVerticalGlyphVertices:h,numIconVertices:u,numVerticalIconVertices:d}=e,p=c>0||h>0,f=u>0,m=this.elevationFeatures[e.elevationFeatureIndex];if(m){const s=new Ie(e.tileAnchorX,e.tileAnchorY),c=.075+m.pointElevation(s);e.zOffset!==c&&(t=!0,e.zOffset=c),0!==c&&(this.hasAnyZOffset=!0);const h=m.computeSlopeNormal(s,r),u=he(ie(),A(0,0,1),h);q(a,a,u),q(l,l,u),a[2]*=i,l[2]*=i,1===a[0]&&0===a[1]&&0===a[2]&&0===l[0]&&1===l[1]&&0===l[2]||(n=n||p,o=o||f)}if(p&&(xv(this.text.orientationVertexArray,c,a,l),xv(this.text.orientationVertexArray,h,a,l)),f){const{placedIconSymbolIndex:t,verticalPlacedIconSymbolIndex:i}=e;t>=0&&xv(this.icon.orientationVertexArray,u,a,l),i>=0&&xv(this.icon.orientationVertexArray,d,a,l)}}n||(this.text.orientationVertexArray=void 0),o||(this.icon.orientationVertexArray=void 0),t&&(this.zOffsetBuffersNeedUpload=!0,this.zOffsetSortDirty=!0)}updateZOffset(){const e=(e,t,r)=>{i+=t,i>e.length&&e.resize(i);for(let n=-t;n<0;n++)e.emplace(n+i,r)},t=(e,t,i)=>{r+=t,r>e.length&&e.resize(r);for(let n=-t;n<0;n++)e.emplace(n+r,i)};if(!this.zOffsetBuffersNeedUpload)return;this.zOffsetBuffersNeedUpload=!1;let i=0,r=0;for(let n=0;n<this.symbolInstances.length;n++){const i=this.symbolInstances.get(n),{numHorizontalGlyphVertices:r,numVerticalGlyphVertices:o,numIconVertices:s}=i,a=i.zOffset,l=s>0;if((r>0||o>0)&&(e(this.text.zOffsetVertexArray,r,a),e(this.text.zOffsetVertexArray,o,a)),l){const{placedIconSymbolIndex:e,verticalPlacedIconSymbolIndex:r}=i;e>=0&&t(this.icon.zOffsetVertexArray,s,a),r>=0&&t(this.icon.zOffsetVertexArray,i.numVerticalIconVertices,a)}}this.text.zOffsetVertexBuffer&&this.text.zOffsetVertexBuffer.updateData(this.text.zOffsetVertexArray),this.icon.zOffsetVertexBuffer&&this.icon.zOffsetVertexBuffer.updateData(this.icon.zOffsetVertexArray)}isEmpty(){return 0===this.symbolInstances.length&&!this.hasRTLText}uploadPending(){return!this.uploaded||this.text.programConfigurations.needsUpload||this.icon.programConfigurations.needsUpload}upload(e,t,i,r,n){!this.uploaded&&this.hasDebugData()&&(this.textCollisionBox.upload(e),this.iconCollisionBox.upload(e)),this.text.upload(e,this.sortFeaturesByY,!this.uploaded,this.text.programConfigurations.needsUpload,this.zOffsetBuffersNeedUpload,this.hasAppearances),null===this.hasAppearances&&(this.hasAppearances=this.layers.some(e=>e.appearances&&e.appearances.length>0)),this.icon.upload(e,this.sortFeaturesByY,!this.uploaded,this.icon.programConfigurations.needsUpload,this.zOffsetBuffersNeedUpload,this.hasAppearances),this.uploaded=!0}updateAppearances(e,t,i,r,n,o=!1){const s={hasLayoutChanges:!1,hasUboChanges:!1};if(!e||!i||!this.featureAppearanceData)return s;const a=t||{},l=this.icon.layoutVertexArray&&this.icon.layoutVertexArray.length>0&&this.icon.layoutVertexArray.arrayBuffer,c=this.text.layoutVertexArray&&this.text.layoutVertexArray.length>0&&this.text.layoutVertexArray.arrayBuffer;if(!l&&!c)return s;const h=this.layers[0],u=h.layout;this.featureAppearances&&this.featureAppearances.appearancesVersion===h.appearancesVersion||(this.featureAppearances=new pv(h.appearances,h.appearancesVersion));const d=this.featureAppearances.update(r,o);if("no-changes"===d.kind)return s;let p=1,f=0,m=!1,_=!1;if(l){const[e,t]=u.get("icon-size-scale-range");p=ke(1,e,t)}let g=1,y=0,x=!1;if(c){const[e,t]=u.get("text-size-scale-range");g=ke(1,e,t)}const v=/* @__PURE__ */new Map;if(n&&i)for(const b of i){const e=n.getImage(b,h.scope);if(e){const t=new Zi(b.toString());v.set(t.toString(),e)}}for(let b=0;b<this.symbolInstances.length;b++){const t=this.symbolInstances.get(b),n=this.getAppearanceFeatureData(t.featureIndex);if(!n)continue;const o=n.id,s=void 0!==o?a[String(o)]:void 0,w={type:"Point",id:n.id,properties:n.properties,geometry:[]};let T;if("all-features"===d.kind)T=d.appearanceIndex;else{const t=h.appearances?h.appearances.findIndex(t=>t.isActive({globals:r,feature:w,canonical:e,featureState:s})):-1;T=t>=0?t:-1}const S=n.activeAppearanceIndex!==T;if(c){const r=u.get("text-size"),o="composite"===this.textSizeData.kind?this.textSizeData.minZoom:0,a="composite"===this.textSizeData.kind?this.textSizeData.maxZoom:0,l={canonical:e,layer:h,featureState:s,availableImages:i,textScaleFactor:g,imageMap:v,layoutTextOffset:u.get("text-offset").evaluate(w,s,e).map(e=>e*Lg),layoutTextSize:r.evaluate(w,s,e),layoutTextRotate:u.get("text-rotate").evaluate(w,s,e),layoutMinZoomSize:r.evaluate(w,{zoom:o},e),layoutMaxZoomSize:r.evaluate(w,{zoom:a},e),layoutTextSizeMinZoom:o,layoutTextSizeMaxZoom:a},c=this.updateSymbolInstanceTextVertices(t,n,T,w,y,l);y+=c.vertexOffsetDelta,x=x||c.hasChanges}if(l){const o={canonical:e,layer:h,featureState:s,availableImages:i,globalProperties:r,iconScaleFactor:p,layoutIconOffset:u.get("icon-offset").evaluate(w,s,e),layoutIconSize:u.get("icon-size").evaluate(w,s,e,i),layoutIconRotate:u.get("icon-rotate").evaluate(w,s,e)},a=this.updateSymbolInstanceIconVertices(t,n,T,w,f,o);f+=a.vertexOffsetDelta,m=m||a.hasChanges}if(S){const n=t.featureIndex,o=r?r.brightness:null,a=s||{},l=T>=0?h.appearances[T]:null;this.text.uboBinder&&(this.text.uboBinder.layer=h,_=this.text.uboBinder.updateFeaturePaintForAppearance(n,w,a,e,i,o,l)||_),this.icon.uboBinder&&(this.icon.uboBinder.layer=h,_=this.icon.uboBinder.updateFeaturePaintForAppearance(n,w,a,e,i,o,l)||_)}n.activeAppearanceIndex=T}return m&&this.icon.layoutVertexBuffer&&null!==this.icon.layoutVertexArray.arrayBuffer&&this.icon.layoutVertexArray.length===this.icon.layoutVertexBuffer.length&&this.icon.layoutVertexBuffer.updateData(this.icon.layoutVertexArray),x&&this.text.layoutVertexBuffer&&null!==this.text.layoutVertexArray.arrayBuffer&&this.text.layoutVertexArray.length===this.text.layoutVertexBuffer.length&&this.text.layoutVertexBuffer.updateData(this.text.layoutVertexArray),{hasLayoutChanges:m||x,hasUboChanges:_}}destroyDebugData(){this.textCollisionBox.destroy(),this.iconCollisionBox.destroy()}getProjection(){return this.projectionInstance||(this.projectionInstance=dv(this.projection)),this.projectionInstance}destroy(){this.text.destroy(),this.icon.destroy(),this.hasDebugData()&&this.destroyDebugData()}addToLineVertexArray(e,t){const i=this.lineVertexArray.length;if(void 0!==e.segment)for(const{x:r,y:n}of t)this.lineVertexArray.emplaceBack(r,n);return{lineStartIndex:i,lineLength:this.lineVertexArray.length-i}}addSymbols(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g){const y=e.indexArray,x=e.layoutVertexArray,v=e.globeExtVertexArray,b=g,w=e.uboBinder?e.uboBinder.getCurrentBatchIndex():void 0,T=e.segments.prepareSegment(4*b,x,y,this.canOverlap?o.sortKey:void 0,w),S=this.glyphOffsetArray.length,I=T.vertexLength,E=this.allowVerticalPlacement&&s===ry.vertical?Math.PI/2:0,A=o.text&&o.text.sections;let M=x.length,C=-1;for(let R=0;R<t.length;R++){const{tl:r,tr:n,bl:s,br:c,texPrimary:h,texSecondary:u,pixelOffsetTL:_,pixelOffsetBR:g,minFontScaleX:b,minFontScaleY:w,glyphOffset:S,isSDF:I,sectionIndex:P}=t[R],D=T.vertexLength,z=S[1];if(_v(x,l.x,l.y,r.x,z+r.y,h.x,h.y,i,I,_.x,_.y,b,w),_v(x,l.x,l.y,n.x,z+n.y,h.x+h.w,h.y,i,I,g.x,_.y,b,w),_v(x,l.x,l.y,s.x,z+s.y,h.x,h.y+h.h,i,I,_.x,g.y,b,w),_v(x,l.x,l.y,c.x,z+c.y,h.x+h.w,h.y+h.h,i,I,g.x,g.y,b,w),a){const{x:t,y:i,z:r}=a.anchor,[n,o,s]=a.up;yv(v,t,i,r,n,o,s),yv(v,t,i,r,n,o,s),yv(v,t,i,r,n,o,s),yv(v,t,i,r,n,o,s),vv(e.dynamicLayoutVertexArray,t,i,r,E)}else vv(e.dynamicLayoutVertexArray,l.x,l.y,l.z,E);if(m){const t=u||h;gv(e.iconTransitioningVertexArray,t.x,t.y),gv(e.iconTransitioningVertexArray,t.x+t.w,t.y),gv(e.iconTransitioningVertexArray,t.x,t.y+t.h),gv(e.iconTransitioningVertexArray,t.x+t.w,t.y+t.h)}if(y.emplaceBack(D,D+1,D+2),y.emplaceBack(D+1,D+2,D+3),T.vertexLength+=4,T.primitiveLength+=2,this.glyphOffsetArray.emplaceBack(S[0]),(R===t.length-1||P!==t[R+1].sectionIndex)&&(e.uboBinder||e.programConfigurations.populatePaintArrays(x.length,o,o.index,{},d,p,f,A&&A[P],this.worldview),e.uboBinder&&e.featureIdArray)){const t=e.uboBinder.populateUBO(o,o.index,p,d,f,A&&A[P],void 0);C=t;const i=x.length-M;for(let r=0;r<i;r++)e.featureIdArray.emplaceBack(t);M=x.length}}const P=g-t.length;if(0!==P&&(this._addNullVertices(P,x,i,a,v,e,m,T,y),e.uboBinder&&e.featureIdArray&&C>=0)){const t=4*P;for(let i=0;i<t;i++)e.featureIdArray.emplaceBack(C)}const D=a?a.anchor:l;e.placedSymbolArray.emplaceBack(D.x,D.y,D.z,l.x,l.y,S,this.glyphOffsetArray.length-S,I,c,h,l.segment,i?i[0]:0,i?i[1]:0,r[0],r[1],s,0,0,0,u,0),e.symbolInstanceIndices.push(_)}_addNullVertices(e,t,i,r,n,o,s,a,l){for(let c=0;c<e;c++){for(let a=0;a<4;a++)_v(t,0,0,0,0,0,0,i,!1,0,0,0,0),r?(yv(n,0,0,0,0,0,0),vv(o.dynamicLayoutVertexArray,0,0,0,0)):vv(o.dynamicLayoutVertexArray,0,0,0,0),s&&gv(o.iconTransitioningVertexArray,0,0);const e=a.vertexLength;l.emplaceBack(e,e+1,e+2),l.emplaceBack(e+1,e+2,e+3),a.vertexLength+=4,a.primitiveLength+=2,this.glyphOffsetArray.emplaceBack(0)}}_commitLayoutVertex(e,t,i,r,n,o,s){e.emplaceBack(t,i,r,n,o,Math.round(s.x),Math.round(s.y))}_addCollisionDebugVertices(e,t,i,r,n,o,s){const a=i.segments.prepareSegment(4,i.layoutVertexArray,i.indexArray),l=a.vertexLength,c=s.tileAnchorX,h=s.tileAnchorY;for(let d=0;d<4;d++)i.collisionVertexArray.emplaceBack(0,0,0,0,0,0);this._commitDebugCollisionVertexUpdate(i.collisionVertexArrayExt,t,e.padding,s.zOffset),this._commitLayoutVertex(i.layoutVertexArray,r,n,o,c,h,new Ie(e.x1,e.y1)),this._commitLayoutVertex(i.layoutVertexArray,r,n,o,c,h,new Ie(e.x2,e.y1)),this._commitLayoutVertex(i.layoutVertexArray,r,n,o,c,h,new Ie(e.x2,e.y2)),this._commitLayoutVertex(i.layoutVertexArray,r,n,o,c,h,new Ie(e.x1,e.y2)),a.vertexLength+=4;const u=i.indexArray;u.emplaceBack(l,l+1),u.emplaceBack(l+1,l+2),u.emplaceBack(l+2,l+3),u.emplaceBack(l+3,l),a.primitiveLength+=4}_addTextDebugCollisionBoxes(e,t,i,r,n,o){for(let s=r;s<n;s++){const r=i.get(s),n=this.getSymbolInstanceTextSize(e,o,t,s);this._addCollisionDebugVertices(r,n,this.textCollisionBox,r.projectedAnchorX,r.projectedAnchorY,r.projectedAnchorZ,o)}}_addIconDebugCollisionBoxes(e,t,i,r,n,o){for(let s=r;s<n;s++){const r=i.get(s),n=this.getSymbolInstanceIconSize(e,t,o.placedIconSymbolIndex);this._addCollisionDebugVertices(r,n,this.iconCollisionBox,r.projectedAnchorX,r.projectedAnchorY,r.projectedAnchorZ,o)}}generateCollisionDebugBuffers(e,t,i){this.hasDebugData()&&this.destroyDebugData(),this.textCollisionBox=new Sv(gl,Mg.members,ml),this.iconCollisionBox=new Sv(gl,Mg.members,ml);const r=Iy(this.iconSizeData,e),n=Iy(this.textSizeData,e,i);for(let o=0;o<this.symbolInstances.length;o++){const i=this.symbolInstances.get(o);this._addTextDebugCollisionBoxes(n,e,t,i.textBoxStartIndex,i.textBoxEndIndex,i),this._addTextDebugCollisionBoxes(n,e,t,i.verticalTextBoxStartIndex,i.verticalTextBoxEndIndex,i),this._addIconDebugCollisionBoxes(r,e,t,i.iconBoxStartIndex,i.iconBoxEndIndex,i),this._addIconDebugCollisionBoxes(r,e,t,i.verticalIconBoxStartIndex,i.verticalIconBoxEndIndex,i)}}getSymbolInstanceTextSize(e,t,i,r){const n=this.text.placedSymbolArray.get(t.rightJustifiedTextSymbolIndex>=0?t.rightJustifiedTextSymbolIndex:t.centerJustifiedTextSymbolIndex>=0?t.centerJustifiedTextSymbolIndex:t.leftJustifiedTextSymbolIndex>=0?t.leftJustifiedTextSymbolIndex:t.verticalPlacedTextSymbolIndex>=0?t.verticalPlacedTextSymbolIndex:r),o=Sy(this.textSizeData,e,n)/Lg;return this.tilePixelRatio*o}getSymbolInstanceIconSize(e,t,i){const r=this.icon.placedSymbolArray.get(i),n=Sy(this.iconSizeData,e,r);return this.tilePixelRatio*n}_commitDebugCollisionVertexUpdate(e,t,i,r){e.emplaceBack(t,-i,-i,r),e.emplaceBack(t,i,-i,r),e.emplaceBack(t,i,i,r),e.emplaceBack(t,-i,i,r)}_updateTextDebugCollisionBoxes(e,t,i,r,n,o,s){for(let a=r;a<n;a++){const r=i.get(a),n=this.getSymbolInstanceTextSize(e,o,t,a);this._commitDebugCollisionVertexUpdate(this.textCollisionBox.collisionVertexArrayExt,n,r.padding,o.zOffset)}}_updateIconDebugCollisionBoxes(e,t,i,r,n,o,s){for(let a=r;a<n;a++){const r=i.get(a),n=this.getSymbolInstanceIconSize(e,t,o.placedIconSymbolIndex);this._commitDebugCollisionVertexUpdate(this.iconCollisionBox.collisionVertexArrayExt,n,r.padding,o.zOffset)}}updateCollisionDebugBuffers(e,t,i,r){if(!this.hasDebugData())return;this.hasTextCollisionBoxData()&&this.textCollisionBox.collisionVertexArrayExt.clear(),this.hasIconCollisionBoxData()&&this.iconCollisionBox.collisionVertexArrayExt.clear();const n=Iy(this.iconSizeData,e,r),o=Iy(this.textSizeData,e,i);for(let s=0;s<this.symbolInstances.length;s++){const a=this.symbolInstances.get(s);this._updateTextDebugCollisionBoxes(o,e,t,a.textBoxStartIndex,a.textBoxEndIndex,a,i),this._updateTextDebugCollisionBoxes(o,e,t,a.verticalTextBoxStartIndex,a.verticalTextBoxEndIndex,a,i),this._updateIconDebugCollisionBoxes(n,e,t,a.iconBoxStartIndex,a.iconBoxEndIndex,a,r),this._updateIconDebugCollisionBoxes(n,e,t,a.verticalIconBoxStartIndex,a.verticalIconBoxEndIndex,a,r)}this.hasTextCollisionBoxData()&&this.textCollisionBox.collisionVertexBufferExt&&this.textCollisionBox.collisionVertexBufferExt.updateData(this.textCollisionBox.collisionVertexArrayExt),this.hasIconCollisionBoxData()&&this.iconCollisionBox.collisionVertexBufferExt&&this.iconCollisionBox.collisionVertexBufferExt.updateData(this.iconCollisionBox.collisionVertexArrayExt)}_deserializeCollisionBoxesForSymbol(e,t,i,r,n,o,s,a,l){const c={};if(t<i){const{x1:i,y1:r,x2:n,y2:o,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d,featureIndex:p}=e.get(t);c.textBox={x1:i,y1:r,x2:n,y2:o,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d},c.textFeatureIndex=p}if(r<n){const{x1:t,y1:i,x2:n,y2:o,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d,featureIndex:p}=e.get(r);c.verticalTextBox={x1:t,y1:i,x2:n,y2:o,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d},c.verticalTextFeatureIndex=p}if(o<s){const{x1:t,y1:i,x2:r,y2:n,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d,featureIndex:p}=e.get(o);c.iconBox={x1:t,y1:i,x2:r,y2:n,padding:s,projectedAnchorX:a,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d},c.iconFeatureIndex=p}if(a<l){const{x1:t,y1:i,x2:r,y2:n,padding:o,projectedAnchorX:s,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d,featureIndex:p}=e.get(a);c.verticalIconBox={x1:t,y1:i,x2:r,y2:n,padding:o,projectedAnchorX:s,projectedAnchorY:l,projectedAnchorZ:h,tileAnchorX:u,tileAnchorY:d},c.verticalIconFeatureIndex=p}return c}deserializeCollisionBoxes(e){this.collisionArrays=[];for(let t=0;t<this.symbolInstances.length;t++){const i=this.symbolInstances.get(t);this.collisionArrays.push(this._deserializeCollisionBoxesForSymbol(e,i.textBoxStartIndex,i.textBoxEndIndex,i.verticalTextBoxStartIndex,i.verticalTextBoxEndIndex,i.iconBoxStartIndex,i.iconBoxEndIndex,i.verticalIconBoxStartIndex,i.verticalIconBoxEndIndex))}}hasTextData(){return this.text.segments.get().length>0}hasIconData(){return this.icon.segments.get().length>0}hasDebugData(){return this.textCollisionBox&&this.iconCollisionBox}hasTextCollisionBoxData(){return this.hasDebugData()&&this.textCollisionBox.segments.get().length>0}hasIconCollisionBoxData(){return this.hasDebugData()&&this.iconCollisionBox.segments.get().length>0}hasIconTextFit(){return this.hasAnyIconTextFit}addIndicesForPlacedSymbol(e,t){const i=e.placedSymbolArray.get(t),r=i.vertexStartIndex+4*i.numGlyphs;for(let n=i.vertexStartIndex;n<r;n+=4)e.indexArray.emplaceBack(n,n+1,n+2),e.indexArray.emplaceBack(n+1,n+2,n+3)}getSortedSymbolIndexes(e){if(this.sortedAngle===e&&void 0!==this.symbolInstanceIndexes)return this.symbolInstanceIndexes;const t=Math.sin(e),i=Math.cos(e),r=[],n=[],o=[];for(let s=0;s<this.symbolInstances.length;++s){o.push(s);const e=this.symbolInstances.get(s);r.push(0|Math.round(t*e.tileAnchorX+i*e.tileAnchorY)),n.push(e.featureIndex)}return o.sort((e,t)=>r[e]-r[t]||n[t]-n[e]),o}getSortedIndexesByZOffset(){if(!this.zOffsetSortDirty)return this.symbolInstanceIndexesSortedZOffset;if(!this.symbolInstanceIndexesSortedZOffset){this.symbolInstanceIndexesSortedZOffset=[];for(let e=0;e<this.symbolInstances.length;++e)this.symbolInstanceIndexesSortedZOffset.push(e)}return this.zOffsetSortDirty=!1,this.symbolInstanceIndexesSortedZOffset.sort((e,t)=>this.symbolInstances.get(t).zOffset-this.symbolInstances.get(e).zOffset)}addToSortKeyRanges(e,t){const i=this.sortKeyRanges.at(-1);i&&i.sortKey===t?i.symbolInstanceEnd=e+1:this.sortKeyRanges.push({sortKey:t,symbolInstanceStart:e,symbolInstanceEnd:e+1})}sortFeatures(e){if(this.sortFeaturesByY&&this.sortedAngle!==e)if(this.text.segments.get().length>1||this.icon.segments.get().length>1)this.sortFeaturesWithinSegments();else{this.symbolInstanceIndexes=this.getSortedSymbolIndexes(e),this.sortedAngle=e,this.text.indexArray.clear(),this.icon.indexArray.clear(),this.featureSortOrder=[];for(const e of this.symbolInstanceIndexes){const t=this.symbolInstances.get(e);this.featureSortOrder.push(t.featureIndex);const{rightJustifiedTextSymbolIndex:i,centerJustifiedTextSymbolIndex:r,leftJustifiedTextSymbolIndex:n,verticalPlacedTextSymbolIndex:o,placedIconSymbolIndex:s,verticalPlacedIconSymbolIndex:a}=t;i>=0&&this.addIndicesForPlacedSymbol(this.text,i),r>=0&&r!==i&&this.addIndicesForPlacedSymbol(this.text,r),n>=0&&n!==r&&n!==i&&this.addIndicesForPlacedSymbol(this.text,n),o>=0&&this.addIndicesForPlacedSymbol(this.text,o),s>=0&&this.addIndicesForPlacedSymbol(this.icon,s),a>=0&&this.addIndicesForPlacedSymbol(this.icon,a)}this.text.indexBuffer&&this.text.indexBuffer.updateData(this.text.indexArray),this.icon.indexBuffer&&this.icon.indexBuffer.updateData(this.icon.indexArray)}}getOrCreateSortedSymbolsByBatch(e,t){const i=(this.text.uboBinder&&this.text.uboBinder.maxFeaturesPerBatch>0?this.text.uboBinder:this.icon.uboBinder&&this.icon.uboBinder.maxFeaturesPerBatch>0?this.icon.uboBinder:null).maxFeaturesPerBatch;if(this.symbolsByBatch)for(const r of this.symbolsByBatch.values())for(const i of r){const r=this.symbolInstances.get(i.index);i.rotatedY=0|Math.round(e*r.tileAnchorX+t*r.tileAnchorY)}else{this.symbolsByBatch=/* @__PURE__ */new Map;for(let r=0;r<this.symbolInstances.length;r++){const n=this.symbolInstances.get(r),o=Math.floor(r/i),s=0|Math.round(e*n.tileAnchorX+t*n.tileAnchorY);this.symbolsByBatch.has(o)||this.symbolsByBatch.set(o,[]),this.symbolsByBatch.get(o).push({index:r,rotatedY:s,featureIndex:n.featureIndex})}}for(const r of this.symbolsByBatch.values())r.sort((e,t)=>e.rotatedY-t.rotatedY||t.featureIndex-e.featureIndex);return this.symbolsByBatch}rebuildTextSegmentIndices(e,t){for(const i of e){const e=i.batchIndex;if(void 0===e)continue;const r=t.get(e);if(!r){i.primitiveOffset=this.text.indexArray.length,i.primitiveLength=0;continue}i.primitiveOffset=this.text.indexArray.length;const n=this.text.indexArray.length;for(const{index:t}of r){const{rightJustifiedTextSymbolIndex:e,centerJustifiedTextSymbolIndex:i,leftJustifiedTextSymbolIndex:r,verticalPlacedTextSymbolIndex:n}=this.symbolInstances.get(t);e>=0&&this.addIndicesForPlacedSymbol(this.text,e),i>=0&&i!==e&&this.addIndicesForPlacedSymbol(this.text,i),r>=0&&r!==i&&r!==e&&this.addIndicesForPlacedSymbol(this.text,r),n>=0&&this.addIndicesForPlacedSymbol(this.text,n)}i.primitiveLength=this.text.indexArray.length-n}}rebuildIconSegmentIndices(e,t){for(const i of e){const e=i.batchIndex;if(void 0===e)continue;const r=t.get(e);if(!r){i.primitiveOffset=this.icon.indexArray.length,i.primitiveLength=0;continue}i.primitiveOffset=this.icon.indexArray.length;const n=this.icon.indexArray.length;for(const{index:t}of r){const{placedIconSymbolIndex:e,verticalPlacedIconSymbolIndex:i}=this.symbolInstances.get(t);e>=0&&this.addIndicesForPlacedSymbol(this.icon,e),i>=0&&this.addIndicesForPlacedSymbol(this.icon,i)}i.primitiveLength=this.icon.indexArray.length-n}}sortFeaturesWithinSegments(){this.featureSortOrder=[];const e=Math.sin(this.sortedAngle),t=Math.cos(this.sortedAngle),i=this.getOrCreateSortedSymbolsByBatch(e,t),r=Array.from(i.keys()).sort((e,t)=>e-t);for(const n of r){const e=i.get(n);for(const{index:t}of e){const e=this.symbolInstances.get(t);this.featureSortOrder.push(e.featureIndex)}}this.text.indexArray.clear(),this.icon.indexArray.clear(),this.rebuildTextSegmentIndices(this.text.segments.get(),i),this.rebuildIconSegmentIndices(this.icon.segments.get(),i),this.text.indexBuffer&&this.text.indexBuffer.updateData(this.text.indexArray),this.icon.indexBuffer&&this.icon.indexBuffer.updateData(this.icon.indexArray)}getElevationFeatureForText(e){const t=this.symbolInstances.get(this.text.symbolInstanceIndices[e]).elevationFeatureIndex;let i;return this.elevationFeatures&&t<this.elevationFeatures.length&&(i=this.elevationFeatures[t]),i}}function Ev(e,t){return t.replace(/{([^{}]+)}/g,(t,i)=>i in e?String(e[i]):"")}let Av,Mv,Cv;as(Iv,"SymbolBucket",{omit:["layers","collisionBoxArray","compareText","features"]}),Iv.addDynamicAttributes=vv;class Pv{constructor(e){this.type=e.property.overrides?e.property.overrides.runtimeType:Ai,this.defaultValue=e}evaluate(e){if(e.formattedSection){const t=this.defaultValue.property.overrides;if(t&&t.hasOverride(e.formattedSection))return t.getOverride(e.formattedSection)}return e.feature&&e.featureState?this.defaultValue.evaluate(e.feature,e.featureState):this.defaultValue.property.specification.default}eachChild(e){this.defaultValue.isConstant()||e(this.defaultValue.value._styleExpression.expression)}outputDefined(){return!1}serialize(){return null}}as(Pv,"FormatSectionOverride",{omit:["defaultValue"]});const Dv=()=>Cv||(Cv={layout:Av||(Av=new ya({"symbol-placement":new ma(xa.layout_symbol["symbol-placement"]),"symbol-spacing":new ma(xa.layout_symbol["symbol-spacing"]),"symbol-avoid-edges":new ma(xa.layout_symbol["symbol-avoid-edges"]),"symbol-sort-key":new _a(xa.layout_symbol["symbol-sort-key"]),"symbol-z-order":new ma(xa.layout_symbol["symbol-z-order"]),"symbol-z-elevate":new ma(xa.layout_symbol["symbol-z-elevate"]),"symbol-elevation-reference":new ma(xa.layout_symbol["symbol-elevation-reference"]),"icon-allow-overlap":new ma(xa.layout_symbol["icon-allow-overlap"]),"icon-ignore-placement":new ma(xa.layout_symbol["icon-ignore-placement"]),"icon-optional":new ma(xa.layout_symbol["icon-optional"]),"icon-rotation-alignment":new ma(xa.layout_symbol["icon-rotation-alignment"]),"icon-size":new _a(xa.layout_symbol["icon-size"]),"icon-size-scale-range":new ma(xa.layout_symbol["icon-size-scale-range"]),"icon-text-fit":new _a(xa.layout_symbol["icon-text-fit"]),"icon-text-fit-padding":new _a(xa.layout_symbol["icon-text-fit-padding"]),"icon-image":new _a(xa.layout_symbol["icon-image"]),"icon-image-use-theme":new ma({type:"string",default:"default","property-type":"data-constant"}),"icon-rotate":new _a(xa.layout_symbol["icon-rotate"]),"icon-padding":new ma(xa.layout_symbol["icon-padding"]),"icon-keep-upright":new ma(xa.layout_symbol["icon-keep-upright"]),"icon-offset":new _a(xa.layout_symbol["icon-offset"]),"icon-anchor":new _a(xa.layout_symbol["icon-anchor"]),"icon-pitch-alignment":new ma(xa.layout_symbol["icon-pitch-alignment"]),"text-pitch-alignment":new ma(xa.layout_symbol["text-pitch-alignment"]),"text-rotation-alignment":new ma(xa.layout_symbol["text-rotation-alignment"]),"text-field":new _a(xa.layout_symbol["text-field"]),"text-font":new _a(xa.layout_symbol["text-font"]),"text-size":new _a(xa.layout_symbol["text-size"]),"text-size-scale-range":new ma(xa.layout_symbol["text-size-scale-range"]),"text-max-width":new _a(xa.layout_symbol["text-max-width"]),"text-line-height":new _a(xa.layout_symbol["text-line-height"]),"text-letter-spacing":new _a(xa.layout_symbol["text-letter-spacing"]),"text-justify":new _a(xa.layout_symbol["text-justify"]),"text-radial-offset":new _a(xa.layout_symbol["text-radial-offset"]),"text-variable-anchor":new ma(xa.layout_symbol["text-variable-anchor"]),"text-anchor":new _a(xa.layout_symbol["text-anchor"]),"text-max-angle":new ma(xa.layout_symbol["text-max-angle"]),"text-writing-mode":new ma(xa.layout_symbol["text-writing-mode"]),"text-rotate":new _a(xa.layout_symbol["text-rotate"]),"text-padding":new ma(xa.layout_symbol["text-padding"]),"text-keep-upright":new ma(xa.layout_symbol["text-keep-upright"]),"text-transform":new _a(xa.layout_symbol["text-transform"]),"text-offset":new _a(xa.layout_symbol["text-offset"]),"text-allow-overlap":new ma(xa.layout_symbol["text-allow-overlap"]),"text-ignore-placement":new ma(xa.layout_symbol["text-ignore-placement"]),"text-optional":new ma(xa.layout_symbol["text-optional"]),visibility:new ma(xa.layout_symbol.visibility)})),paint:Mv||(Mv=new ya({"icon-opacity":new _a(xa.paint_symbol["icon-opacity"]),"icon-occlusion-opacity":new _a(xa.paint_symbol["icon-occlusion-opacity"]),"icon-emissive-strength":new _a(xa.paint_symbol["icon-emissive-strength"]),"text-emissive-strength":new _a(xa.paint_symbol["text-emissive-strength"]),"icon-color":new _a(xa.paint_symbol["icon-color"]),"icon-halo-color":new _a(xa.paint_symbol["icon-halo-color"]),"icon-halo-width":new _a(xa.paint_symbol["icon-halo-width"]),"icon-halo-blur":new _a(xa.paint_symbol["icon-halo-blur"]),"icon-translate":new ma(xa.paint_symbol["icon-translate"]),"icon-translate-anchor":new ma(xa.paint_symbol["icon-translate-anchor"]),"icon-image-cross-fade":new ma(xa.paint_symbol["icon-image-cross-fade"]),"text-opacity":new _a(xa.paint_symbol["text-opacity"]),"text-occlusion-opacity":new _a(xa.paint_symbol["text-occlusion-opacity"]),"text-color":new _a(xa.paint_symbol["text-color"],{runtimeType:Di,getOverride:e=>e.textColor,hasOverride:e=>!!e.textColor}),"text-halo-color":new _a(xa.paint_symbol["text-halo-color"]),"text-halo-width":new _a(xa.paint_symbol["text-halo-width"]),"text-halo-blur":new _a(xa.paint_symbol["text-halo-blur"]),"text-translate":new ma(xa.paint_symbol["text-translate"]),"text-translate-anchor":new ma(xa.paint_symbol["text-translate-anchor"]),"icon-color-saturation":new ma(xa.paint_symbol["icon-color-saturation"]),"icon-color-contrast":new ma(xa.paint_symbol["icon-color-contrast"]),"icon-color-brightness-min":new ma(xa.paint_symbol["icon-color-brightness-min"]),"icon-color-brightness-max":new ma(xa.paint_symbol["icon-color-brightness-max"]),"symbol-z-offset":new _a(xa.paint_symbol["symbol-z-offset"]),"icon-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"icon-halo-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"text-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"text-halo-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},Cv);class Rv extends $a{constructor(e,t,i,r){super(e,Dv(),t,i,r,e.layout?e.layout["icon-image-use-theme"]:null),this._colorAdjustmentMatrix=h([]),this.hasOcclusionOpacityProperties=void 0!==e.paint&&("icon-occlusion-opacity"in e.paint||"text-occlusion-opacity"in e.paint)}_handleSpecialPaintPropertyUpdate(e){"icon-occlusion-opacity"!==e&&"text-occlusion-opacity"!==e||(this.hasOcclusionOpacityProperties=!0)}recalculate(e,t){super.recalculate(e,t),this.appearances&&this.appearances.forEach(i=>{i.recalculate(e,t,this.iconImageUseTheme)}),"auto"===this.layout.get("icon-rotation-alignment")&&(this.layout._values["icon-rotation-alignment"]="point"!==this.layout.get("symbol-placement")?"map":"viewport"),"auto"===this.layout.get("text-rotation-alignment")&&(this.layout._values["text-rotation-alignment"]="point"!==this.layout.get("symbol-placement")?"map":"viewport"),"auto"===this.layout.get("text-pitch-alignment")&&(this.layout._values["text-pitch-alignment"]=this.layout.get("text-rotation-alignment")),"auto"===this.layout.get("icon-pitch-alignment")&&(this.layout._values["icon-pitch-alignment"]=this.layout.get("icon-rotation-alignment"));const i=this.layout.get("text-writing-mode");if(i){const e=[];for(const t of i)e.includes(t)||e.push(t);this.layout._values["text-writing-mode"]=e}else this.layout._values["text-writing-mode"]="point"===this.layout.get("symbol-placement")?["horizontal"]:["horizontal","vertical"];this._setPaintOverrides()}getColorAdjustmentMatrix(e,t,i,r){return this._saturation===e&&this._contrast===t&&this._brightnessMin===i&&this._brightnessMax===r||(this._colorAdjustmentMatrix=function(e,t,i,r){e=ht(e),t=ct(t);const n=l(),o=e/3,s=1-2*o,a=[s,o,o,0,o,s,o,0,o,o,s,0,0,0,0,1],c=.5-.5*t,h=r-i;return d(n,[h,0,0,0,0,h,0,0,0,0,h,0,i,i,i,1],[t,0,0,0,0,t,0,0,0,0,t,0,c,c,c,1]),d(n,n,a),n}(e,t,i,r),this._saturation=e,this._contrast=t,this._brightnessMin=i,this._brightnessMax=r),this._colorAdjustmentMatrix}getValueAndResolveTokens(e,t,i,r){const n=this.layout.get(e).evaluate(t,{},i,r),o=this._unevaluatedLayout._values[e];return o.isDataDriven()||Ko(o.value)||!n?n:Ev(t.properties,n)}getAppearanceValueAndResolveTokens(e,t,i,r,n){const o=e.getLayoutProperty(t);if(!o)return;const s=o.evaluate(i,{},r,n),a=e.getUnevaluatedLayoutProperties()._values[t];return a.isDataDriven()||Ko(a.value)||!s||"string"!=typeof s?s:Ev(i.properties,s)}createBucket(e){return new Iv(e)}queryRadius(){return 0}queryIntersectsFeature(){return!1}_setPaintOverrides(){for(const e of Dv().paint.overridableProperties){if(!Rv.hasPaintOverride(this.layout,e))continue;const t=this.paint.get(e),i=new Jo(new Pv(t),t.property.specification,this.scope,this.options,this.layout.get("icon-image-use-theme"));let r=null;r="constant"===t.value.kind||"source"===t.value.kind?new es("source",i):new ts("composite",i,t.value.zoomStops,t.value.interpolationType),this.paint._values[e]=new pa(t.property,r,t.parameters)}}_handleOverridablePaintPropertyUpdate(e,t,i){return!(!this.layout||t.isDataDriven()||i.isDataDriven())&&Rv.hasPaintOverride(this.layout,e)}static hasPaintOverride(e,t){const i=e.get("text-field"),r=Dv().paint.properties[t];let n=!1;const o=e=>{for(const t of e)if(r.overrides&&r.overrides.hasOverride(t))return void(n=!0)};if("constant"===i.value.kind&&i.value.value instanceof qi)o(i.value.value.sections);else if("source"===i.value.kind){const e=t=>{n||(t instanceof Qi&&Ji(t.value)===Fi?o(t.value.sections):t instanceof rr?o(t.sections):t.eachChild(e))},t=i.value;t._styleExpression&&e(t._styleExpression.expression)}return n}getProgramIds(){return["symbol"]}getDefaultProgramParams(e,t,i){return{config:new Tc(this,{zoom:t,lut:i}),overrideFog:!1}}hasElevation(){return this.layout&&"hd-road-markup"===this.layout.get("symbol-elevation-reference")}}let zv,Lv,Fv,Ov;var Bv=Ya([{name:"a_pos",type:"Int16",components:2},{name:"a_texture_pos",type:"Uint16",components:2}]);function kv(e,t,i,r,n,o,l,c){const h=[e,t,1,i,r,1,n,o,1],u=[l,c,1],[d,p,f]=$(u,u,s([],h));return a(h,h,[d,0,0,0,p,0,0,0,f])}function Nv(e,t,i,r,n,o,l,c){const h=function(e,t,i,r,n,o,l,c){const h=kv(0,0,1,0,1,1,0,1),u=kv(e,t,i,r,n,o,l,c);return a(u,u,s([],h))}(e,t,i,r,n,o,l,c);return[h[2]/h[8]/Yr,h[5]/h[8]/Yr]}function Uv(e){return[e[0],Math.min(Math.max(e[1],-85.051129),Wc)]}class Vv extends pi{constructor(e,t,i,r){super(),this.id=e,this.dispatcher=i,this.coordinates=t.coordinates,this.type="image",this.minzoom=0,this.maxzoom=22,this.tileSize=512,this.tiles={},this._loaded=!1,this.onNorthPole=!1,this.onSouthPole=!1,this.setEventedParent(r),this.options=t,this._dirty=!1}load(e,t){if(this._loaded=t||!1,this.fire(new ci("dataloading",{dataType:"source"})),this.url=this.options.url,!this.url)return e&&(this.coordinates=e),this._loaded=!0,void this._finishLoading();this._imageRequest=ti(this.map._requestManager.transformRequest(this.url,Gt.Image),(t,i)=>{this._imageRequest=null,this._loaded=!0,t?this.fire(new hi(t)):i&&(this.image=i,this._dirty=!0,this.width=this.image.width,this.height=this.image.height,e&&(this.coordinates=e),this._finishLoading())})}loaded(){return this._loaded}updateImage(e){return e.url?(this._imageRequest&&e.url!==this.options.url&&(this._imageRequest.cancel(),this._imageRequest=null),this.options.url=e.url,this.load(e.coordinates,this._loaded),this):this}setTexture(e){if(!(e.handle instanceof WebGLTexture))throw new Error("The provided handle is not a WebGLTexture instance");return this.texture=new Dm(this.map.painter.context,e.handle),this.width=e.dimensions[0],this.height=e.dimensions[1],this._dirty=!1,this._loaded=!0,this._finishLoading(),this}_finishLoading(){this.map&&(this.setCoordinates(this.coordinates),this.fire(new ci("data",{dataType:"source",sourceDataType:"metadata"})))}onAdd(e){this.map=e,this.load()}onRemove(e){this._imageRequest&&(this._imageRequest.cancel(),this._imageRequest=null),!this.texture||this.texture instanceof Dm||this.texture.destroy(),this.boundsBuffer&&(this.boundsBuffer.destroy(),this.elevatedGlobeVertexBuffer&&this.elevatedGlobeVertexBuffer.destroy(),this.elevatedGlobeIndexBuffer&&this.elevatedGlobeIndexBuffer.destroy())}setCoordinates(e){if(this.coordinates=e,this._boundsArray=void 0,this._unsupportedCoords=!1,!e.length)return this;this.onNorthPole=!1,this.onSouthPole=!1;let t=e[0][1],i=e[0][1];for(const n of e)n[1]>i&&(i=n[1]),n[1]<t&&(t=n[1]);const r=(i+t)/2;if(r>Wc?this.onNorthPole=!0:r<-85.051129&&(this.onSouthPole=!0),!this.onNorthPole&&!this.onSouthPole){const t=e.map(Qc.fromLngLat);this.tileID=function(e){let t=1/0,i=1/0,r=-1/0,n=-1/0;for(const c of e)t=Math.min(t,c.x),i=Math.min(i,c.y),r=Math.max(r,c.x),n=Math.max(n,c.y);const o=Math.max(r-t,n-i),s=Math.max(0,Math.floor(-Math.log2(o))),a=Math.pow(2,s);let l=Math.floor((t+r)/2*a);return l>1&&(l-=1),new au(s,l,Math.floor((i+n)/2*a))}(t),this.minzoom=this.maxzoom=this.tileID.z}return this.fire(new ci("data",{dataType:"source",sourceDataType:"content"})),this}_clear(){!this.texture||this.texture instanceof Dm||(this.texture.destroy(),this._dirty=!0),this.texture=null,this._boundsArray=void 0,this._unsupportedCoords=!1}_prepareData(e){for(const s in this.tiles){const e=this.tiles[s];"loaded"!==e.state&&(e.state="loaded",e.texture=this.texture)}if(this._boundsArray||this.onNorthPole||this.onSouthPole||this._unsupportedCoords)return;const t=Hx(new au(0,0,0),this.map.transform.projection),i=[t.projection.project(this.coordinates[0][0],this.coordinates[0][1]),t.projection.project(this.coordinates[1][0],this.coordinates[1][1]),t.projection.project(this.coordinates[2][0],this.coordinates[2][1]),t.projection.project(this.coordinates[3][0],this.coordinates[3][1])];if(!function(e){const t=e[1].x-e[0].x,i=e[1].y-e[0].y,r=e[2].x-e[1].x,n=e[2].y-e[1].y,o=e[3].x-e[2].x,s=e[3].y-e[2].y,a=e[0].x-e[3].x,l=e[0].y-e[3].y,c=t*n-r*i,h=r*s-o*n,u=o*l-a*s,d=a*i-t*l;return c>0&&h>0&&u>0&&d>0||c<0&&h<0&&u<0&&d<0}(i))return console.warn("Image source coordinates are defining non-convex area in the Mercator projection"),void(this._unsupportedCoords=!0);const r=Hx(this.tileID,this.map.transform.projection),[n,o,l,c]=this.coordinates.map(e=>$x(r,r.projection.project(e[0],e[1]))._round());this.perspectiveTransform=Nv(n.x,n.y,o.x,o.y,l.x,l.y,c.x,c.y);const h=this._boundsArray=new el;h.emplaceBack(n.x,n.y,0,0),h.emplaceBack(o.x,o.y,Yr,0),h.emplaceBack(c.x,c.y,0,Yr),h.emplaceBack(l.x,l.y,Yr,Yr),this.boundsBuffer&&(this.boundsBuffer.destroy(),this.elevatedGlobeVertexBuffer&&this.elevatedGlobeVertexBuffer.destroy(),this.elevatedGlobeIndexBuffer&&this.elevatedGlobeIndexBuffer.destroy()),this.boundsBuffer=e.createVertexBuffer(h,Bv.members),this.boundsSegments=Jl.simpleSegment(0,0,4,2);const u=[],[d,p,f,m]=function(e){let t=e[0][0],i=t,r=e[0][1],n=r;for(let o=1;o<e.length;o++)e[o][0]<t?t=e[o][0]:e[o][0]>i&&(i=e[o][0]),e[o][1]<r?r=e[o][1]:e[o][1]>n&&(n=e[o][1]);return[t,r,i-t,n-r]}(function(e){return[Uv(e[0]),Uv(e[1]),Uv(e[2]),Uv(e[3])]}(this.coordinates));{const r=new el,[n,o,l,c]=function(e){let t=e[0].x,i=t,r=e[0].y,n=r;for(let o=1;o<e.length;o++)e[o].x<t?t=e[o].x:e[o].x>i&&(i=e[o].x),e[o].y<r?r=e[o].y:e[o].y>n&&(n=e[o].y);return[t,r,i-t,n-r]}(i),h=e=>[(e.x-n)/l,(e.y-o)/c],[_,g,y,x]=i.map(h),v=function(e,t,i,r,n,o,l,c){const h=kv(0,0,1,0,1,1,0,1);return a(h,h,s([],kv(e,t,i,r,n,o,l,c)))}(_[0],_[1],g[0],g[1],y[0],y[1],x[0],x[1]);this.elevatedGlobePerspectiveTransform=Nv(_[0],_[1],g[0],g[1],y[0],y[1],x[0],x[1]);const b=(e,t)=>{u.push(e.lng);const i=Math.round((e.lng-d)/f*Yr),n=Math.round((e.lat-p)/m*Yr),o=h(t),s=$([],[o[0],o[1],1],v),a=Math.round(s[0]/s[2]*Yr),l=Math.round(s[1]/s[2]*Yr);r.emplaceBack(i,n,a,l)},w=i[3].x-i[0].x,T=i[3].y-i[0].y,S=i[2].x-i[1].x,I=i[2].y-i[1].y;for(let e=0;e<65;e++){const r=e/64,n=[i[0].x+r*w,i[0].y+r*T],o=[i[1].x+r*S,i[1].y+r*I],s=o[0]-n[0],a=o[1]-n[1];for(let e=0;e<65;e++){const i=e/64,r={x:n[0]+s*i,y:n[1]+a*i};b(t.projection.unproject(r.x,r.y),r)}}this.elevatedGlobeVertexBuffer=e.createVertexBuffer(r,Bv.members)}{this.maxLongitudeTriangleSize=0;let t=[],i=new vl;const r=(e,r,n)=>{i.emplaceBack(e,r,n);const o=u[e],s=u[r],a=u[n],l=Math.min(Math.min(o,s),a),c=Math.max(Math.max(o,s),a)-l;c>this.maxLongitudeTriangleSize&&(this.maxLongitudeTriangleSize=c),t.push(l+c/2)};for(let e=0;e<64;e++)for(let t=0;t<64;t++){const i=65*e+t,n=i+1,o=i+65,s=o+1;r(i,o,n),r(n,o,s)}[t,i]=function(e,t){const i=Array.from({length:e.length},(e,t)=>t);i.sort((t,i)=>e[t]-e[i]);const r=[],n=new vl;for(let o=0;o<i.length;o++){const s=i[o];r.push(e[s]);const a=3*s,l=a+1;n.emplaceBack(t.uint16[a],t.uint16[l],t.uint16[l+1])}return[r,n]}(t,i),this.elevatedGlobeTrianglesCenterLongitudes=t,this.elevatedGlobeIndexBuffer=e.createIndexBuffer(i)}this.elevatedGlobeSegments=Jl.simpleSegment(0,0,4225,8192),this.elevatedGlobeGridMatrix=new Float32Array([0,f/Yr,0,m/Yr,0,0,p,d,0])}prepare(){const e=0!==Object.keys(this.tiles).length;if(this.tileID&&!e)return;const t=this.map.painter.context,i=t.gl;!this._dirty||this.texture instanceof Dm||(this.texture?this.texture.update(this.image):(this.texture=new Pm(t,this.image,i.RGBA8),this.texture.bind(i.LINEAR,i.CLAMP_TO_EDGE)),this._dirty=!1),e&&this._prepareData(t)}loadTile(e,t){this.tileID&&this.tileID.equals(e.tileID.canonical)?(this.tiles[String(e.tileID.wrap)]=e,e.buckets={},t(null)):(e.state="errored",t(null))}serialize(){return{type:"image",url:this.options.url,coordinates:this.coordinates}}hasTransition(){return!1}getSegmentsForLongitude(e){const t=this.elevatedGlobeSegments;if(!this.elevatedGlobeTrianglesCenterLongitudes||!t)return null;const i=this.elevatedGlobeTrianglesCenterLongitudes;let r=(n=e+180)+360*Math.round((i[0]-n)/360);var n;const o=new Jl,s=(e,i)=>{o.segments.push({vertexOffset:0,primitiveOffset:e,vertexLength:t.segments[0].vertexLength,primitiveLength:i,sortKey:void 0,vaos:{}})},a=.51*this.maxLongitudeTriangleSize;if(Math.abs(i[0]-r)<=a){const e=lt(i,0,i.length,r+a);return e===i.length||s(e,at(i,e+1,i.length,r+360-a)-e),o}r<i[0]&&(r+=360);const l=at(i,0,i.length,r-a);if(l===i.length)return s(0,i.length),o;s(0,l-0);const c=lt(i,l+1,i.length,r+a);return c!==i.length&&s(c,i.length-c),o}}const jv=1024,Gv=(Math.pow(jv,2)-1)/268170240;class Hv extends $a{constructor(e,t,i,r){super(e,{layout:Fv||(Fv=new ya({visibility:new ma(xa.layout_raster.visibility)})),paint:Ov||(Ov=new ya({"raster-opacity":new ma(xa.paint_raster["raster-opacity"]),"raster-color":new ga(xa.paint_raster["raster-color"]),"raster-color-mix":new ma(xa.paint_raster["raster-color-mix"]),"raster-color-range":new ma(xa.paint_raster["raster-color-range"]),"raster-hue-rotate":new ma(xa.paint_raster["raster-hue-rotate"]),"raster-brightness-min":new ma(xa.paint_raster["raster-brightness-min"]),"raster-brightness-max":new ma(xa.paint_raster["raster-brightness-max"]),"raster-saturation":new ma(xa.paint_raster["raster-saturation"]),"raster-contrast":new ma(xa.paint_raster["raster-contrast"]),"raster-resampling":new ma(xa.paint_raster["raster-resampling"]),"raster-fade-duration":new ma(xa.paint_raster["raster-fade-duration"]),"raster-emissive-strength":new ma(xa.paint_raster["raster-emissive-strength"]),"raster-array-band":new ma(xa.paint_raster["raster-array-band"]),"raster-elevation":new ma(xa.paint_raster["raster-elevation"]),"raster-elevation-reference":new ma(xa.paint_raster["raster-elevation-reference"]),"raster-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this.updateColorRamp(),this._curRampRange=[NaN,NaN]}getProgramIds(){return["raster"]}hasColorMap(){return!!this._transitionablePaint._values["raster-color"].value.value}tileCoverLift(){return this.paint.get("raster-elevation")}isDraped(e){return!(e&&e._source instanceof Vv&&(e._source.onNorthPole||e._source.onSouthPole))&&0===this.paint.get("raster-elevation")}_handleSpecialPaintPropertyUpdate(e){"raster-color"!==e&&"raster-color-range"!==e||(this._curRampRange=[NaN,NaN],this.updateColorRamp())}_clear(){this.colorRampTexture&&(this.colorRampTexture.destroy(),this.colorRampTexture=null)}updateColorRamp(e){if(!this.hasColorMap())return;if(!this._curRampRange)return;const t=this._transitionablePaint._values["raster-color"].value.expression,[i,r]=e||this._transitionablePaint._values["raster-color-range"].value.expression.evaluate({zoom:0})||[NaN,NaN];isNaN(i)&&isNaN(r)||i===this._curRampRange[0]&&r===this._curRampRange[1]||(this.colorRamp=od({expression:t,evaluationKey:"rasterValue",image:this.colorRamp,clips:[{start:i,end:r}],resolution:jv}),this.colorRampTexture=null,this._curRampRange=[i,r])}is3D(e){return this.paint.get("raster-elevation")>0}}let $v,qv,Zv,Wv,Xv,Yv,Jv;class Kv extends $a{constructor(e,t,i,r){super(e,{layout:$v||($v=new ya({visibility:new ma(xa["layout_raster-particle"].visibility)})),paint:qv||(qv=new ya({"raster-particle-array-band":new ma(xa["paint_raster-particle"]["raster-particle-array-band"]),"raster-particle-count":new ma(xa["paint_raster-particle"]["raster-particle-count"]),"raster-particle-color":new ga(xa["paint_raster-particle"]["raster-particle-color"]),"raster-particle-max-speed":new ma(xa["paint_raster-particle"]["raster-particle-max-speed"]),"raster-particle-speed-factor":new ma(xa["paint_raster-particle"]["raster-particle-speed-factor"]),"raster-particle-fade-opacity-factor":new ma(xa["paint_raster-particle"]["raster-particle-fade-opacity-factor"]),"raster-particle-reset-rate-factor":new ma(xa["paint_raster-particle"]["raster-particle-reset-rate-factor"]),"raster-particle-elevation":new ma(xa["paint_raster-particle"]["raster-particle-elevation"]),"raster-particle-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this._updateColorRamp(),this.lastInvalidatedAt=It.now()}_clear(){this.colorRampTexture&&(this.colorRampTexture.destroy(),this.colorRampTexture=null),this.tileFramebuffer&&(this.tileFramebuffer.destroy(),this.tileFramebuffer=null),this.particleFramebuffer&&(this.particleFramebuffer.destroy(),this.particleFramebuffer=null)}onRemove(e){this.colorRampTexture&&this.colorRampTexture.destroy(),this.tileFramebuffer&&this.tileFramebuffer.destroy(),this.particleFramebuffer&&this.particleFramebuffer.destroy()}hasColorMap(){return!!this._transitionablePaint._values["raster-particle-color"].value.value}getProgramIds(){return["rasterParticle"]}hasOffscreenPass(){return"none"!==this.visibility}isDraped(e){return!1}_handleSpecialPaintPropertyUpdate(e){"raster-particle-color"!==e&&"raster-particle-max-speed"!==e||(this._updateColorRamp(),this._invalidateAnimationState()),"raster-particle-count"===e&&this._invalidateAnimationState()}_updateColorRamp(){if(!this.hasColorMap())return;const e=this._transitionablePaint._values["raster-particle-color"].value.expression,t=this._transitionablePaint._values["raster-particle-max-speed"].value.expression.evaluate({zoom:0});this.colorRamp=od({expression:e,evaluationKey:"rasterParticleSpeed",image:this.colorRamp,clips:[{start:0,end:t}],resolution:256}),this.colorRampTexture=null}_invalidateAnimationState(){this.lastInvalidatedAt=It.now()}tileCoverLift(){return this.paint.get("raster-particle-elevation")}}class Qv extends $a{constructor(e,t){super(e,{},t,null),this.implementation=e,e.slot&&(this.slot=e.slot)}is3D(e){return"3d"===this.implementation.renderingMode}hasOffscreenPass(){return void 0!==this.implementation.prerender}isDraped(e){return void 0!==this.implementation.renderToTile}shouldRedrape(){return!!this.implementation.shouldRerenderTiles&&this.implementation.shouldRerenderTiles()}recalculate(){}updateTransitions(){}hasTransition(){return!1}serialize(){}onAdd(e){this.implementation.onAdd&&this.implementation.onAdd(e,e.painter.context.gl)}onRemove(e){this.implementation.onRemove&&this.implementation.onRemove(e,e.painter.context.gl)}}function eb(e,t,i){const r=[0,0,1],n=re([]);return oe(n,n,i?-Re(e)+Math.PI:Re(e)),ne(n,n,-Re(t)),q(r,r,n),U(r,r)}class tb{constructor(e,t){this.feature=e,this.instancedDataOffset=t,this.instancedDataCount=0,this.rotation=[0,0,0],this.scale=[1,1,1],this.translation=[0,0,0]}}class ib{constructor(){this.maxScale=1,this.maxXYTranslationDistance=0,this.instancedDataArray=new Dl,this.instancesEvaluatedElevation=[],this.features=[],this.idToFeaturesIndex={}}colorForInstance(e){const t=16*e,i=this.instancedDataArray.float32;let r=Math.floor(i[t+2]);const n=1.05*(i[t+2]-r);return r/=100,[i[t]%1*1.05,i[t+1]%1*1.05,n,r]}tileCoordinatesForInstance(e){const t=16*e,i=this.instancedDataArray.float32;let r=i[t+0];return r=r>Yr?r-Yr:r,new Ie(Math.trunc(r),Math.trunc(i[t+1]))}translationForInstance(e){const t=16*e,i=this.instancedDataArray.float32;return[i[t+4],i[t+5],i[t+6]]}rotationScaleForInstance(e){const t=16*e,i=this.instancedDataArray.float32;return[i[t+7],i[t+8],i[t+9],i[t+10],i[t+11],i[t+12],i[t+13],i[t+14],i[t+15]]}transformForInstance(e){const t=16*e,i=this.instancedDataArray.float32;return[i[t+7],i[t+8],i[t+9],i[t+4],i[t+10],i[t+11],i[t+12],i[t+5],i[t+13],i[t+14],i[t+15],i[t+6],0,0,0,1]}}class rb{constructor(e){this.zoom=e.zoom,this.canonical=e.canonical,this.overscaledZ=this.canonical.z+Math.log2(e.overscaling),this.layers=e.layers,this.layerIds=this.layers.map(e=>e.fqid),this.projection=e.projection,this.index=e.index,this.worldview=e.worldview,this.hasZoomDependentProperties=this.layers[0].isZoomDependent(),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.hasPattern=!1,this.instancesPerModel={},this.validForExaggeration=0,this.maxVerticalOffset=0,this.maxScale=0,this.maxHeight=0,this.lookupDim=this.zoom>this.canonical.z+1?0:this.zoom>this.canonical.z?256:this.zoom>15?75:100,this.instanceCount=0,this.terrainElevationMin=0,this.terrainElevationMax=0,this.validForDEMTile={id:null,timestamp:0},this.modelUris=[],this.modelsRequested=!1,this.activeReplacements=[],this.replacementUpdateTime=0,this.styleDefinedModelURLs=e.styleDefinedModelURLs,this.hasAppearances=null}updateFootprints(e,t){}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}populate(e,t,i,r){this.tileToMeter=Kc(i);const n=this.layers[0]._featureFilter.needGeometry;this.lookup=new Uint8Array(this.lookupDim*this.lookupDim);const o="hd-road-markup"===this.layers[0].paint.get("model-elevation-reference")?t.elevationFeatures:void 0;for(const{feature:s,id:a,index:l,sourceLayerIndex:c}of e){const e=null!=a?a:s.properties&&Object.hasOwn(s.properties,"id")?s.properties.id:void 0,h=lh(s,n);if(!this.layers[0]._featureFilter.filter(new sa(this.zoom,{worldview:this.worldview,activeFloors:t.activeFloors}),h,i))continue;const u={id:e,sourceLayerIndex:c,index:l,geometry:n?h.geometry:ah(s,i,r),properties:s.properties,type:s.type,patterns:{}},d=this.addFeature(u,u.geometry,h,o,i);d&&t.featureIndex.insert(s,u.geometry,l,c,this.index,this.instancesPerModel[d].instancedDataArray.length,256)}this.lookup=null}evaluateQueryRenderedFeaturePadding(){const e=this.layers[0].modelManager,t=this.layers[0].scope;let i=0;for(const r of this.modelUris){const n=e.getModel(r,t);if(!n)continue;const o=this.instancesPerModel[r];if(o){const e=.5*O(n.aabb.max,n.aabb.min)*o.maxScale+o.maxXYTranslationDistance,t=Math.min(Yr,Math.max(e/this.tileToMeter,256));i=Math.max(t,i)}}return i}update(e,t,i,r){for(const n in this.instancesPerModel){const t=this.instancesPerModel[n];for(const i in e)Object.hasOwn(t.idToFeaturesIndex,i)&&(this.evaluate(t.features[t.idToFeaturesIndex[i]],e[i],t,!0),this.uploaded=!1)}this.maxHeight=0}updateZoomBasedPaintProperties(){if(!this.hasZoomDependentProperties)return!1;let e=!1;for(const t in this.instancesPerModel){const i=this.instancesPerModel[t];for(const t of i.features){const r=this.layers[0],n=t.feature,o=this.canonical,s=r.paint.get("model-rotation").evaluate(n,{},o),a=r.paint.get("model-scale").evaluate(n,{},o),l=r.paint.get("model-translation").evaluate(n,{},o);W(t.rotation,s)&&W(t.scale,a)&&W(t.translation,l)||(this.evaluate(t,t.featureStates,i,!0),e=!0)}}return e}updateReplacement(e,t,i,r){if(t.updateTime===this.replacementUpdateTime)return!1;this.replacementUpdateTime=t.updateTime;const n=t.getReplacementRegionsForTile(e.toUnwrapped(),!0);if(Yp(this.activeReplacements,n))return!1;this.activeReplacements=n;let o=!1;for(const s in this.instancesPerModel){const t=this.instancesPerModel[s],n=t.instancedDataArray;for(const s of t.features){const t=s.instancedDataOffset,a=s.instancedDataCount;for(let s=0;s<a;s++){const a=16*(s+t);let l=n.float32[a+0];const c=l>Yr;l=c?l-Yr:l;const h=Math.floor(l),u=Math.floor(n.float32[a+1]);let d=!1;for(const t of this.activeReplacements)if(!qp(t,i,nf.Model,r)&&!(t.min.x>h||h>t.max.x||t.min.y>u||u>t.max.y)&&(d=rf(tf(h,u,e.canonical,t.footprintTileId.canonical),t.footprint),d))break;n.float32[a]=d?l+Yr:l,o=o||d!==c}}}return o}isEmpty(){for(const e in this.instancesPerModel)if(0!==this.instancesPerModel[e].instancedDataArray.length)return!1;return!0}uploadPending(){return!this.uploaded}upload(e){if(!this.uploaded)for(const t in this.instancesPerModel){const i=this.instancesPerModel[t];i.instancedDataArray.length<0||0===i.instancedDataArray.length||(i.instancedDataBuffer?i.instancedDataBuffer.updateData(i.instancedDataArray):i.instancedDataBuffer=e.createVertexBuffer(i.instancedDataArray,Bm.members,!0,void 0,this.instanceCount))}this.uploaded=!0}destroy(e){for(const i in this.instancesPerModel){const e=this.instancesPerModel[i];0!==e.instancedDataArray.length&&e.instancedDataBuffer&&e.instancedDataBuffer.destroy()}const t=this.layers[0].modelManager;if(e&&t&&this.modelUris&&this.modelsRequested)for(const i of this.modelUris)t.removeModel(i,"",!0)}addFeature(e,t,i,r,n){const o=this.layers[0],s=o.layout.get("model-id"),a=o.layout.get("model-allow-density-reduction"),l=s.evaluate(i,{},this.canonical);if(!l)return Ke(`modelId is not evaluated for layer ${o.id} and it is not going to get rendered.`),l;!l.includes("://")&&!this.styleDefinedModelURLs[l]||this.modelUris.includes(l)||this.modelUris.push(l),this.instancesPerModel[l]||(this.instancesPerModel[l]=new ib);const c=this.instancesPerModel[l],h=c.instancedDataArray,u=new tb(i,h.length);let d;r&&(d=Fh.getElevationFeature(e,r));for(const p of t)for(const e of p){if(e.x<0||e.x>=Yr||e.y<0||e.y>=Yr)continue;if(0!==this.lookupDim&&a){const t=(this.lookupDim-1)/Yr,i=this.lookupDim*(e.y*t|0)+e.x*t|0;if(this.lookup){if(0!==this.lookup[i])continue;this.lookup[i]=1}}this.instanceCount++;const t=h.length;if(h.resize(t+1),r){c.instancesRoadElevation||(c.instancesRoadElevation=[]);const t=d?d.pointElevation(new Ie(e.x,e.y)):0;c.instancesRoadElevation.push(t)}c.instancesEvaluatedElevation.push(0),h.float32[16*t]=e.x,h.float32[16*t+1]=e.y}return u.instancedDataCount=c.instancedDataArray.length-u.instancedDataOffset,u.instancedDataCount>0&&(e.id&&(c.idToFeaturesIndex[e.id]=c.features.length),c.features.push(u),this.evaluate(u,{},c,!1)),l}getModelUris(){return this.modelUris}evaluate(e,t,i,r){const n=this.layers[0],o=e.feature,s=this.canonical,a=e.rotation=n.paint.get("model-rotation").evaluate(o,t,s),l=e.scale=n.paint.get("model-scale").evaluate(o,t,s),c=e.translation=n.paint.get("model-translation").evaluate(o,t,s),h=Object.assign({},n.paint.get("model-color").evaluate(o,t,s));h.a=n.paint.get("model-color-mix-intensity").evaluate(o,t,s);const u=[];this.maxVerticalOffset<c[2]&&(this.maxVerticalOffset=c[2]);const d=c[0]*c[0]+c[1]*c[1],p=d>0?Math.sqrt(d):0;i.maxScale=Math.max(Math.max(i.maxScale,l[0]),Math.max(l[1],l[2])),i.maxXYTranslationDistance=Math.max(i.maxXYTranslationDistance,p),this.maxScale=Math.max(Math.max(this.maxScale,l[0]),Math.max(l[1],l[2])),qm(u,a,l);const f=Math.round(100*h.a)+h.b/1.05;for(let m=0;m<e.instancedDataCount;++m){const t=e.instancedDataOffset+m,n=16*t,o=i.instancedDataArray.float32;let a=0;r&&(a=o[n+6]-i.instancesEvaluatedElevation[t]);const l=0|o[n+1];o[n]=(0|o[n])+h.r/1.05,o[n+1]=l+h.g/1.05,o[n+2]=f,o[n+3]=1/(s.z>10?this.tileToMeter:Kc(s,l)),o[n+4]=c[0],o[n+5]=c[1],o[n+6]=c[2]+(i.instancesRoadElevation?i.instancesRoadElevation[t]:0)+a,o[n+7]=u[0],o[n+8]=u[1],o[n+9]=u[2],o[n+10]=u[4],o[n+11]=u[5],o[n+12]=u[6],o[n+13]=u[8],o[n+14]=u[9],o[n+15]=u[10],i.instancesEvaluatedElevation[t]=c[2]}}}as(rb,"ModelBucket",{omit:["layers"]}),as(ib,"PerModelAttributes"),as(tb,"ModelFeature");class nb{constructor(e,t,i){this._demTile=e,this._dem=this._demTile.dem,this._scale=t,this._offset=i}static create(e,t,i){const r=i||e.findDEMTileFor(t);if(!r||!r.dem)return;const n=r.dem,o=r.tileID,s=1<<t.canonical.z-o.canonical.z;return new nb(r,n.dim/Yr/s,[(t.canonical.x/s-o.canonical.x)*n.dim,(t.canonical.y/s-o.canonical.y)*n.dim])}tileCoordToPixel(e,t){const i=t*this._scale+this._offset[1];return new Ie(Math.floor(e*this._scale+this._offset[0]),Math.floor(i))}getElevationAt(e,t,i,r){const n=e*this._scale+this._offset[0],o=t*this._scale+this._offset[1],s=Math.floor(n),a=Math.floor(o),l=this._dem;return r=!!r,i?yi(yi(l.get(s,a,r),l.get(s,a+1,r),o-a),yi(l.get(s+1,a,r),l.get(s+1,a+1,r),o-a),n-s):l.get(s,a,r)}getElevationAtPixel(e,t,i){return this._dem.get(e,t,!!i)}getMeterToDEM(e){return(1<<this._demTile.tileID.canonical.z)*Hc(1,e)*this._dem.stride}}const ob=new Float32Array(262144),sb=new Uint8Array(262144),ab=[0,0,0],lb=[0,0,0];function cb(e){let t=0;if(e.meshes)for(const i of e.meshes)t=Math.max(t,i.aabb.max[2]);if(e.children)for(const i of e.children)t=Math.max(t,cb(i));return t}function hb(e,t,i){if(e.meshes)for(const r of e.meshes){if(r.aabb.min[0]===1/0)continue;const n=Rh.applyTransform(r.aabb,e.globalMatrix);i.insert(t,n.min[0],n.min[1],n.max[0],n.max[1])}if(e.children)for(const r of e.children)hb(r,t,i)}const ub=["","wall","door","roof","window","lamp","logo"];class db{constructor(e){this.node=e,this.evaluatedRMEA=[[1,0,0,1],[1,0,0,1],[1,0,0,1],[1,0,0,1],[.4,1,0,1],[1,0,0,1],[1,0,0,1]],this.hiddenByReplacement=!1,this.evaluatedTranslation=[0,0,0],this.evaluatedScale=[1,1,1],this.evaluatedColor=[],this.emissionHeightBasedParams=[],this.cameraCollisionOpacity=1,this.targetLod=-1,this.feature={type:"Point",id:e.id,geometry:[],properties:{height:cb(e)}},this.aabb=this._getLocalBounds(),this.state=null}_getLocalBounds(){if(!this.node.meshes)return new Rh([1/0,1/0,1/0],[-1/0,-1/0,-1/0]);if(!this.aabb){let e=0;const t=new Rh([1/0,1/0,1/0],[-1/0,-1/0,-1/0]);for(const i of this.node.meshes)this.node.lightMeshIndex!==e&&(i.transformedAabb=Rh.applyTransformFast(i.aabb,this.node.globalMatrix),t.encapsulate(i.transformedAabb)),e++;this.aabb=t}return this.aabb}}class pb{constructor(e,t,i,r,n,o,s,a){this.id=i,this.layers=e,this.layerIds=this.layers.map(e=>e.fqid),this.stateDependentLayerIds=this.layers.filter(e=>e.isStateDependent()).map(e=>e.id),this.modelTraits|=Jm.CoordinateSpaceTile,this.uploaded=!1,this.hasPattern=!1,r&&(this.modelTraits|=Jm.HasMapboxMeshFeatures),n&&(this.modelTraits|=Jm.HasMeshoptCompression),this.zoom=-1,this.terrainExaggeration=1,this.projection={name:"mercator"},this.replacementUpdateTime=0,this.elevationReadFromZ=255,this.brightness=o,this.worldview=a,this.dirty=!0,this.needsUpload=!1,this.filter=null,this.nodesInfo=[];for(const l of t)this.nodesInfo.push(new db(l)),hb(l,s.featureIndexArray.length,s.grid),s.featureIndexArray.emplaceBack(this.nodesInfo.length-1,0,s.bucketLayerIDs.length-1,0);this.states={},this.hasAppearances=null}updateFootprints(e,t){for(const i of this.getNodesInfo()){const r=i.node;r.footprint&&t.push({footprint:r.footprint,id:e})}}updateAppearances(e,t,i,r){return{hasLayoutChanges:!1,hasUboChanges:!1}}update(e){const t=0!==Object.keys(e).length;if(t&&!this.stateDependentLayers.length)return;const i=t?this.stateDependentLayers:this.layers;if(!Ee(e,this.states))for(const r of i)this.evaluate(r,e);this.states=structuredClone(e)}populate(){console.log("populate 3D model bucket")}uploadPending(){return!this.uploaded||this.needsUpload}upload(e){if(!this.needsUpload)return;const t=this.getNodesInfo();for(const i of t){const t=i.node;this.uploaded?this.updatePbrBuffer(t):i_(t,e,!0)}for(const i of t)n_(i.node);this.uploaded=!0,this.needsUpload=!1}updatePbrBuffer(e){let t=!1;if(!e.meshes)return t;for(const i of e.meshes)i.pbrBuffer&&(i.pbrBuffer.updateData(i.featureArray),t=!0);if(e.lodMeshes)for(const i of e.lodMeshes)i.pbrBuffer&&(i.pbrBuffer.updateData(i.featureArray),t=!0);return t}needsReEvaluation(e,t,i){const r=e.transform.projectionOptions,n=e.style.getBrightness(),o=this.brightness!==n;if(!this.uploaded||this.dirty||r.name!==this.projection.name||fb(i.paint.get("model-color").value,o)||fb(i.paint.get("model-color-mix-intensity").value,o)||fb(i.paint.get("model-roughness").value,o)||fb(i.paint.get("model-emissive-strength").value,o)||fb(i.paint.get("model-height-based-emissive-strength-multiplier").value,o)){this.projection=r,this.brightness=n;const e=this.getNodesInfo();for(const t of e)t.state=null;return!0}return!1}evaluateTransform(e,t){if(e.transform.zoom===this.zoom)return;this.zoom=e.transform.zoom;const i=this.getNodesInfo(),r=this.id.canonical;for(const n of i){const e=n.feature;n.evaluatedTranslation=t.paint.get("model-translation").evaluate(e,{},r),n.evaluatedScale=t.paint.get("model-scale").evaluate(e,{},r)}}evaluate(e,t){const i=this.getNodesInfo();for(const r of i){if(!r.node.meshes)continue;const i=r.feature,n=t&&t[i.id];if(Ee(n,r.state))continue;r.state=structuredClone(n);const o=r.node.meshes&&r.node.meshes[0].featureData,s=r.evaluatedColor[2],a=r.evaluatedRMEA[2],l=this.id.canonical;if(r.hasTranslucentParts=!1,o){for(let t=0;t<ub.length;t++){const o=ub[t];o.length&&(i.properties.part=o);const s=e.paint.get("model-color").evaluate(i,n,l).toPremultipliedRenderColor(null),a=e.paint.get("model-color-mix-intensity").evaluate(i,n,l);r.evaluatedColor[t]=[s.r,s.g,s.b,a],r.evaluatedRMEA[t][0]=e.paint.get("model-roughness").evaluate(i,n,l),r.evaluatedRMEA[t][2]=e.paint.get("model-emissive-strength").evaluate(i,n,l),r.evaluatedRMEA[t][3]=s.a,r.emissionHeightBasedParams[t]=e.paint.get("model-height-based-emissive-strength-multiplier").evaluate(i,n,l),!r.hasTranslucentParts&&s.a<1&&(r.hasTranslucentParts=!0)}delete i.properties.part,_b(r,s!==r.evaluatedColor[2]||a!==r.evaluatedRMEA[2],this.modelTraits)}else r.evaluatedRMEA[0][2]=e.paint.get("model-emissive-strength").evaluate(i,n,l);r.evaluatedTranslation=e.paint.get("model-translation").evaluate(i,n,l),r.evaluatedScale=e.paint.get("model-scale").evaluate(i,n,l),this.updatePbrBuffer(r.node)||(this.needsUpload=!0)}this.dirty=!1}elevationUpdate(e,t,i,r){const n=e.findDEMTileFor(i);if(n&&(n.tileID.canonical!==this.terrainTile||t!==this.terrainExaggeration)){if(n.dem&&n.tileID.overscaledZ!==this.elevationReadFromZ){this.elevationReadFromZ=n.tileID.overscaledZ;const t=nb.create(e,i,n);if(!t)return;this.modelTraits&Jm.HasMapboxMeshFeatures&&this.updateDEM(e,t,i,r);for(const e of this.getNodesInfo()){const i=e.node;if(!i.footprint||!i.footprint.vertices||!i.footprint.vertices.length)continue;const r=i.footprint.vertices;let n=t.getElevationAt(r[0].x,r[0].y,!0,!0);for(let e=1;e<r.length;e++)n=Math.min(n,t.getElevationAt(r[e].x,r[e].y,!0,!0));i.elevation=n}}this.terrainTile=n.tileID.canonical,this.terrainExaggeration=t}}updateDEM(e,t,i,r){let n=t._dem._modifiedForSources[r];if(void 0===n&&(t._dem._modifiedForSources[r]=[],n=t._dem._modifiedForSources[r]),n.includes(i.canonical))return;const o=t._dem.dim;n.push(i.canonical);let s=!1;for(const a of this.getNodesInfo()){const e=a.node;if(!e.footprint||!e.footprint.grid)continue;const i=e.footprint.grid,r=t.tileCoordToPixel(i.min.x,i.min.y),n=t.tileCoordToPixel(i.max.x,i.max.y),l=Math.min(Math.min(o-n.y,r.x),Math.min(r.y,o-n.x));if(l<0)continue;const c=ke(l,2,5);let h=Math.max(0,r.x-c),u=Math.max(0,r.y-c),d=Math.min(n.x+c,o-1),p=Math.min(n.y+c,o-1);for(let t=u;t<=p;++t)for(let e=h;e<=d;++e)sb[t*o+e]=255;let f=0,m=0;for(let s=0;s<i.cellsY;++s)for(let e=0;e<i.cellsX;++e){if(!i.cells[s*i.cellsX+e])continue;const r=t.tileCoordToPixel(i.min.x+e/i.xScale,i.min.y+s/i.yScale),n=t.tileCoordToPixel(i.min.x+(e+1)/i.xScale,i.min.y+(s+1)/i.yScale);for(let e=r.y;e<=Math.min(n.y+1,o-1);++e)for(let i=r.x;i<=Math.min(n.x+1,o-1);++i)255===sb[e*o+i]&&(sb[e*o+i]=0,f+=t.getElevationAtPixel(i,e),m++)}const _=f/m;h=Math.max(1,r.x-c),u=Math.max(1,r.y-c),d=Math.min(n.x+c,o-2),p=Math.min(n.y+c,o-2),s=!0;for(let s=u;s<=p;++s)for(let e=h;e<=d;++e)0===sb[s*o+e]&&(ob[s*o+e]=t._dem.set(e,s,_));for(let s=1;s<c;++s){h=Math.max(1,r.x-s),u=Math.max(1,r.y-s),d=Math.min(n.x+s,o-2),p=Math.min(n.y+s,o-2);for(let e=u;e<=p;++e)for(let i=h;i<=d;++i){const r=e*o+i;if(255===sb[r]){let n=0,a=0,l=-1,h=-1;for(let t=-1;t<=1;++t)for(let r=-1;r<=1;++r){const c=(e+t)*o+i+r;if(sb[c]>=s)continue;const u=ob[c],d=Math.abs(u);d>a&&(n=u,a=d,l=r,h=t)}if(a>.1){const o=1-(s+.5*Math.abs(l*h))/c;let a=t._dem.get(i,e)+n*o;const u=t._dem.get(i+l,e+h),d=t._dem.get(i-l,e-h,!0);(a-u)*(a-d)>0&&(a=(u+d)/2),ob[r]=t._dem.set(i,e,a),sb[r]=s}}}}}s&&(t._demTile.needsDEMTextureUpload=!0,t._dem._timestamp=It.now())}setFilter(e){this.filter=e?Ta(e):null}getNodesInfo(){return this.filter?this.nodesInfo.filter(e=>this.filter.filter(new sa(this.id.overscaledZ,{worldview:this.worldview}),e.feature,this.id.canonical)):this.nodesInfo}destroy(){const e=this.getNodesInfo();for(const t of e)n_(t.node),s_(t.node)}isEmpty(){return!this.nodesInfo.length}updateReplacement(e,t){if(t.updateTime===this.replacementUpdateTime)return;this.replacementUpdateTime=t.updateTime;const i=t.getReplacementRegionsForTile(e.toUnwrapped());for(const r of this.getNodesInfo()){const e=r.node.footprint;r.hiddenByReplacement=!!e&&!i.some(t=>t.footprint===e)}}getHeightAtTileCoord(e,t){const i=[0,0,0],r=h([]);for(const n of this.getNodesInfo()){const o=n.node.meshes[0],s=o.transformedAabb;if(e<s.min[0]||t<s.min[1]||e>s.max[0]||t>s.max[1])continue;if(!0===n.node.hidden)return{height:1/0,maxHeight:n.feature.properties.height,hidden:!1,verticalScale:n.evaluatedScale[2]};if(u(r,n.node.globalMatrix),i[0]=e,i[1]=t,i[2]=0,H(i,i,r),n.node.meshBVH){const e=i[0],t=i[1];ab[0]=e-1,ab[1]=t-1,ab[2]=-1e3,lb[0]=e+1,lb[1]=t+1,lb[2]=1e3;const r=n.node.meshBVH.findHighestPoint(ab,lb);if(null!==r)return{height:r,maxHeight:n.feature.properties.height,hidden:n.hiddenByReplacement,verticalScale:n.evaluatedScale[2]};continue}const a=(i[0]-o.aabb.min[0])/(o.aabb.max[0]-o.aabb.min[0])*Ym|0,l=Math.min(63,(i[1]-o.aabb.min[1])/(o.aabb.max[1]-o.aabb.min[1])*Ym|0)*Ym+Math.min(63,a),c=o.heightmap[l];if(c<0&&n.node.footprint){const i=[];if(n.node.footprint.grid.query(new Ie(e,t),new Ie(e,t),i),i.length>0)return{height:void 0,maxHeight:n.feature.properties.height,hidden:n.hiddenByReplacement,verticalScale:n.evaluatedScale[2]};continue}if(n.hiddenByReplacement)return;return{height:c,maxHeight:n.feature.properties.height,hidden:!1,verticalScale:n.evaluatedScale[2]}}}}function fb(e,t){return e instanceof es&&!e.isLightConstant&&t}function mb(e,t,i,r,n,o,s,a){let l=(61440&t|(61440&t)>>4)>>8,c=(3840&t|(3840&t)>>4)>>4,h=240&t|(240&t)>>4;const u=15&t|(15&t)<<4;i[3]>0&&(l=yi(l,255*i[0],i[3]),c=yi(c,255*i[1],i[3]),h=yi(h,255*i[2],i[3]));const d=u/255;l*=d,c*=d,h*=d;const p=l<<8|c,f=h<<8|Math.floor(255*r[3]),m=function(e){const t=ke(e,0,2);return Math.min(Math.round(.5*t*255),255)}(r[2])<<8|15*r[0]<<4|15*r[1],_=ke(n[0],0,1),g=ke(n[1],0,1),y=ke(n[2],0,1),x=ke(n[3],0,1);let v,b,w,T;if(_!==g&&s!==o&&g!==_){const e=s-o;b=1/(e*(g-_)),w=-(o+e*_)/(e*(g-_));const t=ke(n[4],-1,1);T=Math.pow(10,t),v=255*y<<8|255*x}else v=65535,b=0,w=1,T=1;if(e.emplaceBack(p,f,m,v,b,w,T),a){const e=a.length;a.clear();for(let t=0;t<e;t++)a.emplaceBack(p,f,m,v,b,w,T)}}function _b(e,t,i){const r=e.node;let n=0;const o=i&Jm.HasMeshoptCompression;for(const s of r.meshes){if(r.lights&&r.lightMeshIndex===n)continue;if(!s.featureData)continue;s.featureArray=new Rl,s.featureArray.reserve(s.featureData.length);let i=t;for(const t of s.featureData){const n=o?65535&t:t>>16&65535,a=o?t>>16&65535:65535&t,l=(15&a)<8?15&a:0,c=e.evaluatedRMEA[l],h=e.evaluatedColor[l],u=e.emissionHeightBasedParams[l];let d;if(i&&2===l&&r.lights&&(d=new Rl,d.resize(10*r.lights.length)),mb(s.featureArray,n,h,c,u,s.aabb.min[2],s.aabb.max[2],d),d&&i){i=!1;const e=r.meshes[r.lightMeshIndex];e.featureArray=d,e.featureArray._trim()}}s.featureArray._trim(),n++}if(r.lodMeshes)for(const s of r.lodMeshes)if(s.featureData){s.featureArray=new Rl,s.featureArray.reserve(s.featureData.length);for(const t of s.featureData){const i=o?t>>16&65535:65535&t,r=(15&i)<8?15&i:0;mb(s.featureArray,o?65535&t:t>>16&65535,e.evaluatedColor[r],e.evaluatedRMEA[r],e.emissionHeightBasedParams[r],s.aabb.min[2],s.aabb.max[2],null)}s.featureArray._trim()}}as(pb,"Tiled3dModelBucket",{omit:["layers"]}),as(db,"Tiled3dModelFeature");const gb=["id","tile","layer","source","sourceLayer","state"];class yb{constructor(e,t,i,r,n){this.type="Feature",this._vectorTileFeature=e,this._z=t,this._x=i,this._y=r,this.properties=e?e.properties:{},this.id=n}clone(){const e=new yb(this._vectorTileFeature,this._z,this._x,this._y,this.id);return this.state&&(e.state=Object.assign({},this.state)),this.layer&&(e.layer=Object.assign({},this.layer)),this.source&&(e.source=this.source),this.sourceLayer&&(e.sourceLayer=this.sourceLayer),e}get geometry(){return void 0===this._geometry&&this._vectorTileFeature&&(this._geometry=this._vectorTileFeature.toGeoJSON(this._x,this._y,this._z).geometry),this._geometry}set geometry(e){this._geometry=e}toJSON(){const e={type:"Feature",state:void 0,geometry:this.geometry,properties:this.properties};for(const t of gb)void 0!==this[t]&&(e[t]=this[t]);return e}}class xb extends pi{constructor(e,t,i,r){super(),this.id=e,this.type="model",this.models=[],this._options=t,this._modelsInfo=/* @__PURE__ */new Map,this._abortController=null}cancelModelRequests(){this._abortController&&(this._abortController.abort(),this._abortController=null)}loadGLTFFromURI(e,t){return Am(this.map._requestManager.transformRequest(e,Gt.Model).url,t)}async loadModel(e,t,i){try{const r=await this.loadGLTFFromURI(t.uri,i);if(i.aborted)return;const n=this._modelsInfo.get(e);if(!n)return;const o=x_(r),s=n.modelSpec,a=new Qm(e,s.uri,s.position,s.orientation,o);xb.applyModelSpecification(a,s),a.computeBoundsAndApplyParent(),this.models.push(a),n.model=a}catch(i){if(i instanceof Error&&"AbortError"===i.name)return;const r=i instanceof Error?i.message:"Unknown error";this.fire(new hi(/* @__PURE__ */new Error(`Could not load model ${e} from ${t.uri}: ${r}`)))}}async load(){this._abortController||(this._abortController=new AbortController);const e=this._abortController.signal,t=[];for(const i in this._options.models){const r=this._options.models[i],n=this._modelsInfo.get(i);if(n&&n.model){n.modelSpec=r;const e=n.model;e.position=null!=r.position?new Nc(r.position[0],r.position[1]):new Nc(0,0),e.orientation=null!=r.orientation?r.orientation:[0,0,0],xb.applyModelSpecification(e,r),e.computeBoundsAndApplyParent(),this.models.push(e)}else n?n.modelSpec=r:(this._modelsInfo.set(i,{modelSpec:r,model:null}),t.push(this.loadModel(i,r,e)))}0!==t.length?(await Promise.allSettled(t),e.aborted||this.fire(new ci("data",{dataType:"source",sourceDataType:"metadata"}))):this.loaded()&&this.fire(new ci("data",{dataType:"source",sourceDataType:"metadata"}))}static applyModelSpecification(e,t){t.nodeOverrides&&xb.convertNodeOverrides(e,t.nodeOverrides),t.materialOverrides&&xb.convertMaterialOverrides(e,t.materialOverrides),t.nodeOverrideNames&&(e.nodeOverrideNames=[...t.nodeOverrideNames]),t.materialOverrideNames&&(e.materialOverrideNames=[...t.materialOverrideNames]),t.featureProperties&&(e.featureProperties=t.featureProperties)}static convertNodeOverrides(e,t){if(Array.isArray(t)&&t.every(e=>"string"==typeof e)){e.nodeOverrideNames=[];for(const i of t)e.nodeOverrideNames.push(i)}else Object.entries(t).forEach(([t,i])=>{const r={orientation:[0,0,0]};if(Object.hasOwn(i,"orientation")){const e=i.orientation;e&&(r.orientation=e)}e.nodeOverrides.set(t,r)})}static convertMaterialOverrides(e,t){if(Array.isArray(t)&&t.every(e=>"string"==typeof e)){e.materialOverrideNames=[];for(const i of t)e.materialOverrideNames.push(i)}else Object.entries(t).forEach(([t,i])=>{const r={color:new xi(1,1,1),colorMix:0,emissionStrength:0,opacity:1},n=i["model-color"];void 0!==n&&(r.color.r=n[0],r.color.g=n[1],r.color.b=n[2]);const o=i["model-color-mix-intensity"];void 0!==o&&(r.colorMix=o);const s=i["model-emissive-strength"];void 0!==s&&(r.emissionStrength=s);const a=i["model-opacity"];void 0!==a&&(r.opacity=a),e.materialOverrides.set(t,r)})}onAdd(e){this.map=e,this.load()}hasTransition(){return!1}loaded(){if(0===this._modelsInfo.size)return!0;for(const e of this._modelsInfo.values())if(null==e.model)return!1;return!0}getModels(){return this.models}loadTile(e,t){}serialize(){return this._options}setProperty(e,t){return!1}reload(){this.cancelModelRequests();const e=Oa(this.id,this.scope);this.map.style.clearSource(e),this.models=[],this._modelsInfo.clear(),this.load()}onRemove(e){this.cancelModelRequests()}setModels(e){this.models=[];const t=/* @__PURE__ */new Map;for(const i in e){const r=e[i],n=this._modelsInfo.get(i);n&&n.modelSpec.uri===r.uri&&t.set(i,n)}if(this._modelsInfo.size!==t.size){this.cancelModelRequests();for(const[e,i]of t)i.model||t.delete(e)}this._modelsInfo=t,this._options.models=e,this.load()}}function vb(e,t,i,r){const n=1<<e.z;t.lat=qc((r/Yr+e.y)/n),t.lng=$c((i/Yr+e.x)/n)}function bb(e,t,i,r){const n=e.getNodesInfo()[t];if(!n||n.hiddenByReplacement||!n.node.meshes)return;let o=Number.MAX_VALUE;const s=n.node,a=i.tile,l=r.calculatePosMatrix(a.tileID.toUnwrapped(),r.worldSize),c=n.evaluatedScale;let h=0;r.elevation&&s.elevation&&(h=s.elevation*r.elevation.exaggeration()),p(l,l,[(s.anchor?s.anchor[0]:0)*(c[0]-1),(s.anchor?s.anchor[1]:0)*(c[1]-1),h]),f(l,l,c);const u=i.queryGeometry,m=u.isPointQuery()?u.screenBounds:u.screenGeometry,_=function(e){const t=d([],l,e.globalMatrix);d(t,r.expandedFarZProjMatrix,t);for(let i=0;i<e.meshes.length;++i){const n=e.meshes[i];if(i===e.lightMeshIndex)continue;const s=Xm(m,r,t,n.aabb);null!=s&&(o=Math.min(s,o))}if(e.children)for(const i of e.children)_(i)};if(_(s),o===Number.MAX_VALUE)return;const g=new Nc(0,0);return vb(a.tileID.canonical,g,n.node.anchor[0],n.node.anchor[1]),{intersectionZ:o,position:g,feature:n.feature}}const wb={circle:class extends $a{constructor(e,t,i,r){super(e,{layout:ou||(ou=new ya({"circle-sort-key":new _a(xa.layout_circle["circle-sort-key"]),"circle-elevation-reference":new ma(xa.layout_circle["circle-elevation-reference"]),visibility:new ma(xa.layout_circle.visibility)})),paint:su||(su=new ya({"circle-radius":new _a(xa.paint_circle["circle-radius"]),"circle-color":new _a(xa.paint_circle["circle-color"]),"circle-blur":new _a(xa.paint_circle["circle-blur"]),"circle-opacity":new _a(xa.paint_circle["circle-opacity"]),"circle-translate":new ma(xa.paint_circle["circle-translate"]),"circle-translate-anchor":new ma(xa.paint_circle["circle-translate-anchor"]),"circle-pitch-scale":new ma(xa.paint_circle["circle-pitch-scale"]),"circle-pitch-alignment":new ma(xa.paint_circle["circle-pitch-alignment"]),"circle-stroke-width":new _a(xa.paint_circle["circle-stroke-width"]),"circle-stroke-color":new _a(xa.paint_circle["circle-stroke-color"]),"circle-stroke-opacity":new _a(xa.paint_circle["circle-stroke-opacity"]),"circle-emissive-strength":new ma(xa.paint_circle["circle-emissive-strength"]),"circle-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"circle-stroke-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r)}createBucket(e){return new kh(e)}queryRadius(e){const t=e;return tu("circle-radius",this,t)+tu("circle-stroke-width",this,t)+iu(this.paint.get("circle-translate"))}queryIntersectsFeature(e,t,i,r,n,o,s,a){const l=nu(this.paint.get("circle-translate"),this.paint.get("circle-translate-anchor"),o.angle,e.pixelToTileUnitsFactor),c=this.paint.get("circle-radius").evaluate(t,i)+this.paint.get("circle-stroke-width").evaluate(t,i);return Gu(e,r,o,s,a,"map"===this.paint.get("circle-pitch-alignment"),"map"===this.paint.get("circle-pitch-scale"),l,c)}getProgramIds(){return["circle"]}getDefaultProgramParams(e,t,i){const r=ju(this);return{config:new Tc(this,{zoom:t,lut:i}),defines:r,overrideFog:!1}}is3D(e){return!e&&!!this.layout&&"none"!==this.layout.get("circle-elevation-reference")}hasElevation(){return this.layout&&"none"!==this.layout.get("circle-elevation-reference")}},heatmap:class extends $a{createBucket(e){return new Wu(e)}constructor(e,t,i,r){super(e,{layout:Xu||(Xu=new ya({visibility:new ma(xa.layout_heatmap.visibility)})),paint:Yu||(Yu=new ya({"heatmap-radius":new _a(xa.paint_heatmap["heatmap-radius"]),"heatmap-weight":new _a(xa.paint_heatmap["heatmap-weight"]),"heatmap-intensity":new ma(xa.paint_heatmap["heatmap-intensity"]),"heatmap-color":new ga(xa.paint_heatmap["heatmap-color"]),"heatmap-opacity":new ma(xa.paint_heatmap["heatmap-opacity"]),"heatmap-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this._updateColorRamp()}_handleSpecialPaintPropertyUpdate(e){"heatmap-color"===e&&this._updateColorRamp()}_updateColorRamp(){this.colorRamp=od({expression:this._transitionablePaint._values["heatmap-color"].value.expression,evaluationKey:"heatmapDensity",image:this.colorRamp}),this.colorRampTexture=null}resize(){this.heatmapFbo&&(this.heatmapFbo.destroy(),this.heatmapFbo=null)}_clear(){this.heatmapFbo&&(this.heatmapFbo.destroy(),this.heatmapFbo=null),this.colorRampTexture&&(this.colorRampTexture.destroy(),this.colorRampTexture=null)}queryRadius(e){return tu("heatmap-radius",this,e)}queryIntersectsFeature(e,t,i,r,n,o,s,a){const l=this.paint.get("heatmap-radius").evaluate(t,i);return Gu(e,r,o,s,a,!0,!0,new Ie(0,0),l)}hasOffscreenPass(){return 0!==this.paint.get("heatmap-opacity")&&"none"!==this.visibility}getProgramIds(){return["heatmap","heatmapTexture"]}getDefaultProgramParams(e,t,i){return"heatmap"===e?{config:new Tc(this,{zoom:t,lut:i}),overrideFog:!1}:{}}},hillshade:class extends $a{constructor(e,t,i,r){super(e,{layout:Ju||(Ju=new ya({visibility:new ma(xa.layout_hillshade.visibility)})),paint:Ku||(Ku=new ya({"hillshade-illumination-direction":new ma(xa.paint_hillshade["hillshade-illumination-direction"]),"hillshade-illumination-anchor":new ma(xa.paint_hillshade["hillshade-illumination-anchor"]),"hillshade-exaggeration":new ma(xa.paint_hillshade["hillshade-exaggeration"]),"hillshade-shadow-color":new ma(xa.paint_hillshade["hillshade-shadow-color"]),"hillshade-highlight-color":new ma(xa.paint_hillshade["hillshade-highlight-color"]),"hillshade-accent-color":new ma(xa.paint_hillshade["hillshade-accent-color"]),"hillshade-emissive-strength":new ma(xa.paint_hillshade["hillshade-emissive-strength"]),"hillshade-shadow-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"hillshade-highlight-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"hillshade-accent-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r)}shouldRedrape(){return this.hasOffscreenPass()&&"viewport"===this.paint.get("hillshade-illumination-anchor")}hasOffscreenPass(){return 0!==this.paint.get("hillshade-exaggeration")&&"none"!==this.visibility}getProgramIds(){return["hillshade","hillshadePrepare"]}getDefaultProgramParams(e,t,i){return{overrideFog:!1}}},fill:class extends $a{constructor(e,t,i,r){super(e,{layout:Cp||(Cp=new ya({"fill-sort-key":new _a(xa.layout_fill["fill-sort-key"]),visibility:new ma(xa.layout_fill.visibility),"fill-elevation-reference":new ma(xa.layout_fill["fill-elevation-reference"]),"fill-construct-bridge-guard-rail":new _a(xa.layout_fill["fill-construct-bridge-guard-rail"])})),paint:Pp||(Pp=new ya({"fill-antialias":new ma(xa.paint_fill["fill-antialias"]),"fill-opacity":new _a(xa.paint_fill["fill-opacity"]),"fill-color":new _a(xa.paint_fill["fill-color"]),"fill-outline-color":new _a(xa.paint_fill["fill-outline-color"]),"fill-translate":new ma(xa.paint_fill["fill-translate"]),"fill-translate-anchor":new ma(xa.paint_fill["fill-translate-anchor"]),"fill-pattern":new _a(xa.paint_fill["fill-pattern"]),"fill-pattern-cross-fade":new ma(xa.paint_fill["fill-pattern-cross-fade"]),"fill-emissive-strength":new ma(xa.paint_fill["fill-emissive-strength"]),"fill-z-offset":new _a(xa.paint_fill["fill-z-offset"]),"fill-bridge-guard-rail-color":new _a(xa.paint_fill["fill-bridge-guard-rail-color"]),"fill-tunnel-structure-color":new _a(xa.paint_fill["fill-tunnel-structure-color"]),"fill-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"fill-outline-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"fill-bridge-guard-rail-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"fill-tunnel-structure-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r)}getProgramIds(){const e=this.paint.get("fill-pattern"),t=e&&e.constantOr(1),i=[t?"fillPattern":"fill"];return this.paint.get("fill-antialias")&&i.push(t&&!this.getPaintProperty("fill-outline-color")?"fillOutlinePattern":"fillOutline"),i}getDefaultProgramParams(e,t,i){return{config:new Tc(this,{zoom:t,lut:i}),overrideFog:!1}}recalculate(e,t){super.recalculate(e,t);const i=this.paint._values["fill-outline-color"];"constant"===i.value.kind&&void 0===i.value.value&&(this.paint._values["fill-outline-color"]=this.paint._values["fill-color"])}createBucket(e){return new Mp(e)}queryRadius(){return iu(this.paint.get("fill-translate"))}queryIntersectsFeature(e,t,i,r,n,o){return!e.queryGeometry.isAboveHorizon&&Vh(ru(e.tilespaceGeometry,this.paint.get("fill-translate"),this.paint.get("fill-translate-anchor"),o.angle,e.pixelToTileUnitsFactor),r)}isTileClipped(){return 0===this.paint.get("fill-z-offset").constantOr(1)}is3D(e){if(0!==this.paint.get("fill-z-offset").constantOr(1))return!0;const t=this.layout&&"none"!==this.layout.get("fill-elevation-reference");return null!=e?t&&!e:t}hasElevation(){return this.layout&&"none"!==this.layout.get("fill-elevation-reference")}hasShadowPass(){return this.layout&&"none"!==this.layout.get("fill-elevation-reference")}},"fill-extrusion":class extends $a{constructor(e,t,i,r){super(e,{layout:Uf||(Uf=new ya({visibility:new ma(xa["layout_fill-extrusion"].visibility),"fill-extrusion-edge-radius":new ma(xa["layout_fill-extrusion"]["fill-extrusion-edge-radius"]),"source-max-zoom":new ma(xa["layout_fill-extrusion"]["source-max-zoom"])})),paint:Vf||(Vf=new ya({"fill-extrusion-opacity":new ma(xa["paint_fill-extrusion"]["fill-extrusion-opacity"]),"fill-extrusion-color":new _a(xa["paint_fill-extrusion"]["fill-extrusion-color"]),"fill-extrusion-translate":new ma(xa["paint_fill-extrusion"]["fill-extrusion-translate"]),"fill-extrusion-translate-anchor":new ma(xa["paint_fill-extrusion"]["fill-extrusion-translate-anchor"]),"fill-extrusion-pattern":new _a(xa["paint_fill-extrusion"]["fill-extrusion-pattern"]),"fill-extrusion-pattern-cross-fade":new ma(xa["paint_fill-extrusion"]["fill-extrusion-pattern-cross-fade"]),"fill-extrusion-height":new _a(xa["paint_fill-extrusion"]["fill-extrusion-height"]),"fill-extrusion-base":new _a(xa["paint_fill-extrusion"]["fill-extrusion-base"]),"fill-extrusion-height-alignment":new ma(xa["paint_fill-extrusion"]["fill-extrusion-height-alignment"]),"fill-extrusion-base-alignment":new ma(xa["paint_fill-extrusion"]["fill-extrusion-base-alignment"]),"fill-extrusion-vertical-gradient":new ma(xa["paint_fill-extrusion"]["fill-extrusion-vertical-gradient"]),"fill-extrusion-ambient-occlusion-intensity":new ma(xa["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-intensity"]),"fill-extrusion-ambient-occlusion-radius":new ma(xa["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-radius"]),"fill-extrusion-ambient-occlusion-wall-radius":new ma(xa["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-wall-radius"]),"fill-extrusion-ambient-occlusion-ground-radius":new ma(xa["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-ground-radius"]),"fill-extrusion-ambient-occlusion-ground-attenuation":new ma(xa["paint_fill-extrusion"]["fill-extrusion-ambient-occlusion-ground-attenuation"]),"fill-extrusion-flood-light-color":new ma(xa["paint_fill-extrusion"]["fill-extrusion-flood-light-color"]),"fill-extrusion-flood-light-intensity":new ma(xa["paint_fill-extrusion"]["fill-extrusion-flood-light-intensity"]),"fill-extrusion-flood-light-wall-radius":new _a(xa["paint_fill-extrusion"]["fill-extrusion-flood-light-wall-radius"]),"fill-extrusion-flood-light-ground-radius":new _a(xa["paint_fill-extrusion"]["fill-extrusion-flood-light-ground-radius"]),"fill-extrusion-flood-light-ground-attenuation":new ma(xa["paint_fill-extrusion"]["fill-extrusion-flood-light-ground-attenuation"]),"fill-extrusion-vertical-scale":new ma(xa["paint_fill-extrusion"]["fill-extrusion-vertical-scale"]),"fill-extrusion-rounded-roof":new ma(xa["paint_fill-extrusion"]["fill-extrusion-rounded-roof"]),"fill-extrusion-cutoff-fade-range":new ma(xa["paint_fill-extrusion"]["fill-extrusion-cutoff-fade-range"]),"fill-extrusion-front-cutoff":new ma(xa["paint_fill-extrusion"]["fill-extrusion-front-cutoff"]),"fill-extrusion-emissive-strength":new _a(xa["paint_fill-extrusion"]["fill-extrusion-emissive-strength"]),"fill-extrusion-line-width":new _a(xa["paint_fill-extrusion"]["fill-extrusion-line-width"]),"fill-extrusion-cast-shadows":new ma(xa["paint_fill-extrusion"]["fill-extrusion-cast-shadows"]),"fill-extrusion-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"fill-extrusion-flood-light-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this._stats={numRenderedVerticesInShadowPass:0,numRenderedVerticesInTransparentPass:0}}createBucket(e){return new Mf(e)}queryRadius(){return iu(this.paint.get("fill-extrusion-translate"))}is3D(e){return!0}hasShadowPass(){return this.paint.get("fill-extrusion-cast-shadows")}cutoffRange(){return this.paint.get("fill-extrusion-cutoff-fade-range")}canCastShadows(){return!0}getProgramIds(){return[this.paint.get("fill-extrusion-pattern").constantOr(1)?"fillExtrusionPattern":"fillExtrusion"]}queryIntersectsFeature(e,t,i,r,n,o,s,a,l){const c=nu(this.paint.get("fill-extrusion-translate"),this.paint.get("fill-extrusion-translate-anchor"),o.angle,e.pixelToTileUnitsFactor),h=this.paint.get("fill-extrusion-height").evaluate(t,i),u=this.paint.get("fill-extrusion-base").evaluate(t,i),d=[0,0],p=a&&o.elevation,f=o.elevation?o.elevation.exaggeration():1,m=e.tile.getBucket(this);if(m instanceof Mf){const e=m.centroidData.find(e=>l>=e.vertexArrayOffset&&l<e.vertexArrayOffset+e.vertexCount);if(e&&e.flags&ff)return!1;if(p){const e=m.centroidVertexArray,t=l+1;t<e.length&&(d[0]=e.geta_centroid_pos0(t),d[1]=e.geta_centroid_pos1(t))}}if(0===d[0]&&1===d[1])return!1;"globe"===o.projection.name&&(r=kf([r],[new Ie(0,0),new Ie(Yr,Yr)],e.tileID.canonical).map(e=>e.polygon).flat());const[_,g]=em(o,r,u,h,c,s,p?a:null,d,f,o.center.lat,e.tileID.canonical),y=e.queryGeometry;return Qf(_,g,y.isPointQuery()?y.screenBounds:y.screenGeometry)}},building:class extends $a{constructor(e,t,i,r){super(e,{layout:jf||(jf=new ya({visibility:new ma(xa.layout_building.visibility),"building-facade":new _a(xa.layout_building["building-facade"]),"building-facade-floors":new _a(xa.layout_building["building-facade-floors"]),"building-facade-unit-width":new _a(xa.layout_building["building-facade-unit-width"]),"building-facade-window":new _a(xa.layout_building["building-facade-window"]),"building-roof-shape":new _a(xa.layout_building["building-roof-shape"]),"building-height":new _a(xa.layout_building["building-height"]),"building-base":new _a(xa.layout_building["building-base"]),"building-flood-light-wall-radius":new _a(xa.layout_building["building-flood-light-wall-radius"]),"building-flood-light-ground-radius":new _a(xa.layout_building["building-flood-light-ground-radius"]),"building-flip-roof-orientation":new _a(xa.layout_building["building-flip-roof-orientation"])})),paint:Gf||(Gf=new ya({"building-opacity":new ma(xa.paint_building["building-opacity"]),"building-ambient-occlusion-intensity":new ma(xa.paint_building["building-ambient-occlusion-intensity"]),"building-ambient-occlusion-ground-intensity":new ma(xa.paint_building["building-ambient-occlusion-ground-intensity"]),"building-ambient-occlusion-ground-radius":new ma(xa.paint_building["building-ambient-occlusion-ground-radius"]),"building-ambient-occlusion-ground-attenuation":new ma(xa.paint_building["building-ambient-occlusion-ground-attenuation"]),"building-vertical-scale":new ma(xa.paint_building["building-vertical-scale"]),"building-cast-shadows":new ma(xa.paint_building["building-cast-shadows"]),"building-color":new _a(xa.paint_building["building-color"]),"building-emissive-strength":new _a(xa.paint_building["building-emissive-strength"]),"building-facade-emissive-chance":new ma(xa.paint_building["building-facade-emissive-chance"]),"building-cutoff-fade-range":new ma(xa.paint_building["building-cutoff-fade-range"]),"building-front-cutoff":new ma(xa.paint_building["building-front-cutoff"]),"building-flood-light-color":new ma(xa.paint_building["building-flood-light-color"]),"building-flood-light-intensity":new ma(xa.paint_building["building-flood-light-intensity"]),"building-flood-light-ground-attenuation":new ma(xa.paint_building["building-flood-light-ground-attenuation"]),"building-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"building-flood-light-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this._stats={numRenderedVerticesInShadowPass:0,numRenderedVerticesInTransparentPass:0}}prepare(){return q_()}createBucket(e){return new G_(e)}cutoffRange(){return this.paint.get("building-cutoff-fade-range")}hasShadowPass(){return this.paint.get("building-cast-shadows")}hasLightBeamPass(){return!0}canCastShadows(){return!0}is3D(e){return!0}queryRadius(e){return 0}queryIntersectsFeature(e,t,i,r,n,o,s,a,l,c){let h=this.layout.get("building-height").evaluate(t,i);const u=this.layout.get("building-base").evaluate(t,i),d=e.tile.getBucket(this).getFootprint(t);if(d){if(0!==d.hiddenFlags)return!1;h=d.height}const[p,f]=em(o,r,u,h,new Ie(0,0),s,null,[0,0],1,o.center.lat,e.tileID.canonical),m=e.queryGeometry;return Qf(p,f,m.isPointQuery()?m.screenBounds:m.screenGeometry)}},line:class extends $a{constructor(e,t,i,r){const n=mg();super(e,n,t,i,r),n.layout&&(this.layout=new fa(n.layout)),this.gradientVersion=0,this.hasElevatedBuckets=!1,this.hasNonElevatedBuckets=!1,this.lineBlendFbos=null,this.lineBlendDensityReadback=null}_handleSpecialPaintPropertyUpdate(e){if("line-gradient"===e){const e=this._transitionablePaint._values["line-gradient"].value.expression;this.stepInterpolant=e._styleExpression&&e._styleExpression.expression instanceof Bn,this.gradientVersion=(this.gradientVersion+1)%Number.MAX_SAFE_INTEGER}}gradientExpression(){return this._transitionablePaint._values["line-gradient"].value.expression}widthExpression(){return this._transitionablePaint._values["line-width"].value.expression}emissiveStrengthExpression(){return this._transitionablePaint._values["line-emissive-strength"].value.expression}recalculate(e,t){super.recalculate(e,t),this.paint._values["line-floorwidth"]=(gg||(gg=new _g(mg().paint.properties["line-width"].specification),gg.useIntegerZoom=!0,gg)).possiblyEvaluate(this._transitioningPaint._values["line-width"].value,e)}createBucket(e){return new ng(e)}getProgramIds(){const e=[this.paint.get("line-pattern").constantOr(1)?"linePattern":"line"];return"default"!==this.paint.get("line-blend-mode")&&e.push("lineBlendComposite"),e}getDefaultProgramParams(e,t,i){if("lineBlendComposite"===e)return{};const r=dg(this);return{config:new Tc(this,{zoom:t,lut:i}),defines:r,overrideFog:!1}}queryRadius(e){const t=e,i=yg(tu("line-width",this,t),tu("line-gap-width",this,t)),r=tu("line-offset",this,t);return i/2+Math.abs(r)+iu(this.paint.get("line-translate"))}queryIntersectsFeature(e,t,i,r,n,o){if(e.queryGeometry.isAboveHorizon)return!1;const s=ru(e.tilespaceGeometry,this.paint.get("line-translate"),this.paint.get("line-translate-anchor"),o.angle,e.pixelToTileUnitsFactor),a=e.pixelToTileUnitsFactor/2*yg(this.paint.get("line-width").evaluate(t,i),this.paint.get("line-gap-width").evaluate(t,i)),l=this.paint.get("line-offset").evaluate(t,i);return l&&(r=function(e,t){const i=[],r=new Ie(0,0);for(let n=0;n<e.length;n++){const o=e[n],s=[];for(let e=0;e<o.length;e++){const i=o[e],n=o[e+1],a=0===e?r:i.sub(o[e-1])._unit()._perp(),l=e===o.length-1?r:n.sub(i)._unit()._perp(),c=a._add(l)._unit();c._mult(1/(c.x*l.x+c.y*l.y)),s.push(c._mult(t)._add(i))}i.push(s)}return i}(r,l*e.pixelToTileUnitsFactor)),function(e,t,i){for(let r=0;r<t.length;r++){const n=t[r];if(e.length>=3)for(let t=0;t<n.length;t++)if(Yh(e,n[t]))return!0;if(jh(e,n,i))return!0}return!1}(s,r,a)}isTileClipped(){return this.hasNonElevatedBuckets}isDraped(e){return!this.hasElevatedBuckets||this.layout&&"hd-road-markup"===this.layout.get("line-elevation-reference")}hasElevation(){return this.layout&&"none"!==this.layout.get("line-elevation-reference")}hasOffscreenPass(){return"default"!==this.paint.get("line-blend-mode")&&0!==this.paint.get("line-opacity").constantOr(1)&&0!==this.paint.get("line-width").constantOr(1)&&"none"!==this.visibility}resize(){this._destroyLineBlendFbo()}onRemove(e){this._destroyLineBlendFbo(e.painter&&e.painter.context&&e.painter.context.gl||void 0)}_clear(){this._destroyLineBlendFbo()}_destroyLineBlendFbo(e){this.lineBlendFbos&&(this.lineBlendFbos.destroy(),this.lineBlendFbos=null),e&&this.lineBlendDensityReadback&&this.lineBlendDensityReadback.destroy(e),this.lineBlendDensityReadback=null}},symbol:Rv,background:class extends $a{constructor(e,t,i,r){super(e,{layout:zv||(zv=new ya({visibility:new ma(xa.layout_background.visibility)})),paint:Lv||(Lv=new ya({"background-pitch-alignment":new ma(xa.paint_background["background-pitch-alignment"]),"background-color":new ma(xa.paint_background["background-color"]),"background-pattern":new ma(xa.paint_background["background-pattern"]),"background-opacity":new ma(xa.paint_background["background-opacity"]),"background-emissive-strength":new ma(xa.paint_background["background-emissive-strength"]),"background-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r)}getProgramIds(){return[this.paint.get("background-pattern")?"backgroundPattern":"background"]}getDefaultProgramParams(e,t,i){return{overrideFog:!1}}is3D(e){return"viewport"===this.paint.get("background-pitch-alignment")}},raster:Hv,"raster-particle":Kv,sky:class extends $a{constructor(e,t,i,r){super(e,{layout:Zv||(Zv=new ya({visibility:new ma(xa.layout_sky.visibility)})),paint:Wv||(Wv=new ya({"sky-type":new ma(xa.paint_sky["sky-type"]),"sky-atmosphere-sun":new ma(xa.paint_sky["sky-atmosphere-sun"]),"sky-atmosphere-sun-intensity":new ma(xa.paint_sky["sky-atmosphere-sun-intensity"]),"sky-gradient-center":new ma(xa.paint_sky["sky-gradient-center"]),"sky-gradient-radius":new ma(xa.paint_sky["sky-gradient-radius"]),"sky-gradient":new ga(xa.paint_sky["sky-gradient"]),"sky-atmosphere-halo-color":new ma(xa.paint_sky["sky-atmosphere-halo-color"]),"sky-atmosphere-color":new ma(xa.paint_sky["sky-atmosphere-color"]),"sky-opacity":new ma(xa.paint_sky["sky-opacity"]),"sky-gradient-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"sky-atmosphere-halo-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"}),"sky-atmosphere-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this._updateColorRamp()}_clear(){this.skyboxFbo&&(this.skyboxFbo.destroy(),this.skyboxFbo=null),this.colorRampTexture&&(this.colorRampTexture.destroy(),this.colorRampTexture=null),this._skyboxInvalidated=!0}_handleSpecialPaintPropertyUpdate(e){"sky-gradient"===e?this._updateColorRamp():"sky-atmosphere-sun"!==e&&"sky-atmosphere-halo-color"!==e&&"sky-atmosphere-color"!==e&&"sky-atmosphere-sun-intensity"!==e||(this._skyboxInvalidated=!0)}_updateColorRamp(){this.colorRamp=od({expression:this._transitionablePaint._values["sky-gradient"].value.expression,evaluationKey:"skyRadialProgress"}),this.colorRampTexture&&(this.colorRampTexture.destroy(),this.colorRampTexture=null)}needsSkyboxCapture(e){if(this._skyboxInvalidated||!this.skyboxTexture||!this.skyboxGeometry)return!0;if(!this.paint.get("sky-atmosphere-sun")){const t=e.style.light.properties.get("position");return this._lightPosition.azimuthal!==t.azimuthal||this._lightPosition.polar!==t.polar}return!1}getCenter(e,t){if("atmosphere"===this.paint.get("sky-type")){const i=this.paint.get("sky-atmosphere-sun"),r=!i,n=e.style.light,o=n.properties.get("position");return r&&"viewport"===n.properties.get("anchor")&&Ke("The sun direction is attached to a light with viewport anchor, lighting may behave unexpectedly."),r?eb(o.azimuthal,90-o.polar,t):eb(i[0],90-i[1],t)}const i=this.paint.get("sky-gradient-center");return eb(i[0],90-i[1],t)}isSky(){return!0}markSkyboxValid(e){this._skyboxInvalidated=!1,this._lightPosition=e.style.light.properties.get("position")}hasOffscreenPass(){return!0}getProgramIds(){const e=this.paint.get("sky-type");return"atmosphere"===e?["skyboxCapture","skybox"]:"gradient"===e?["skyboxGradient"]:null}},slot:class extends $a{constructor(e,t,i,r){super(e,{paint:Xv||(Xv=new ya({}))},t,null)}},model:class extends $a{constructor(e,t,i,r){super(e,{layout:Yv||(Yv=new ya({visibility:new ma(xa.layout_model.visibility),"model-id":new _a(xa.layout_model["model-id"]),"model-allow-density-reduction":new ma(xa.layout_model["model-allow-density-reduction"])})),paint:Jv||(Jv=new ya({"model-opacity":new _a(xa.paint_model["model-opacity"]),"model-rotation":new _a(xa.paint_model["model-rotation"]),"model-scale":new _a(xa.paint_model["model-scale"]),"model-translation":new _a(xa.paint_model["model-translation"]),"model-color":new _a(xa.paint_model["model-color"]),"model-color-mix-intensity":new _a(xa.paint_model["model-color-mix-intensity"]),"model-type":new ma(xa.paint_model["model-type"]),"model-cast-shadows":new ma(xa.paint_model["model-cast-shadows"]),"model-receive-shadows":new ma(xa.paint_model["model-receive-shadows"]),"model-ambient-occlusion-intensity":new ma(xa.paint_model["model-ambient-occlusion-intensity"]),"model-emissive-strength":new _a(xa.paint_model["model-emissive-strength"]),"model-roughness":new _a(xa.paint_model["model-roughness"]),"model-height-based-emissive-strength-multiplier":new _a(xa.paint_model["model-height-based-emissive-strength-multiplier"]),"model-cutoff-fade-range":new ma(xa.paint_model["model-cutoff-fade-range"]),"model-front-cutoff":new ma(xa.paint_model["model-front-cutoff"]),"model-elevation-reference":new ma(xa.paint_model["model-elevation-reference"]),"model-ignore-line-cutout":new ma(xa.paint_model["model-ignore-line-cutout"]),"model-color-use-theme":new _a({type:"string",default:"default","property-type":"data-driven"})}))},t,i,r),this.layer=e,this._stats={numRenderedVerticesInShadowPass:0,numRenderedVerticesInTransparentPass:0}}createBucket(e){return new rb(e)}getProgramIds(){return["model"]}is3D(e){return!0}hasShadowPass(){return!0}canCastShadows(){return!0}hasLightBeamPass(){return!0}cutoffRange(){return this.paint.get("model-cutoff-fade-range")}queryRadius(e){return e instanceof pb?8191:0}queryRenderedFeatures(e,t,i){const r=t.getSource();if(!(r&&r instanceof xb))return{};const n=r,o={};o[this.id]=[];const s=o[this.id];let a=0;for(const l of n.models){const r=t.getFeatureState(this.sourceLayer,l.id),n={type:"Unknown",id:l.id,properties:l.featureProperties},o=this.paint.get("model-rotation").evaluate(n,r),c=this.paint.get("model-scale").evaluate(n,r),h=this.paint.get("model-translation").evaluate(n,r),u=this.paint.get("model-elevation-reference");let p=[];Km(p,l,i,l.position,o,c,h,"ground"===u,"ground"===u,!1),"globe"===i.projection.name&&(p=Wm(p,i));const f=d([],i.projMatrix,p),m=Xm(e.isPointQuery()?e.screenBounds:e.screenGeometry,i,f,l.aabb);if(null!=m){const e=new yb(void 0,0,0,0,l.id);e.layer=this.layer,e.properties=structuredClone(l.featureProperties),e.properties.layer=this.id,e.properties.uri=l.uri,e.properties.orientation=l.orientation,e.sourceLayer=this.sourceLayer,e.geometry={type:"Point",coordinates:[l.position.lng,l.position.lat]},e.state=r,e.source=this.source,s.push({featureIndex:a,feature:e,intersectionZ:m})}++a}return o}queryIntersectsFeature(e,t,i,r,n,o,s,a,l,c){if(!this.modelManager)return!1;const h=this.modelManager,u=e.tile.getBucket(this);if(!(u&&u instanceof rb))return!1;for(const p in u.instancesPerModel){const i=u.instancesPerModel[p],r=void 0!==t.id?t.id:t.properties&&Object.hasOwn(t.properties,"id")?t.properties.id:void 0;if(Object.hasOwn(i.idToFeaturesIndex,r)){const t=i.features[i.idToFeaturesIndex[r]],n=h.getModel(p,c||this.scope);if(!n)return!1;let s=[];const a=new Nc(0,0),l=u.canonical;let f=Number.MAX_VALUE;for(let r=0;r<t.instancedDataCount;++r){const c=16*(t.instancedDataOffset+r),h=i.instancedDataArray.float32,u=[h[c+4],h[c+5],h[c+6]];vb(l,a,Math.floor(h[c]),Math.floor(h[c+1])),Km(s,n,o,a,t.rotation,t.scale,u,!1,!1,!1),"globe"===o.projection.name&&(s=Wm(s,o));const p=d([],o.projMatrix,s),m=e.queryGeometry,_=Xm(m.isPointQuery()?m.screenBounds:m.screenGeometry,o,p,n.aabb);null!=_&&(f=Math.min(_,f))}return f!==Number.MAX_VALUE&&f}}return!1}_handleOverridablePaintPropertyUpdate(e,t,i){return!(!this.layout||t.isDataDriven()||i.isDataDriven()||"model-color"!==e&&"model-color-mix-intensity"!==e&&"model-rotation"!==e&&"model-scale"!==e&&"model-translation"!==e&&"model-emissive-strength"!==e)}_isPropertyZoomDependent(e){const t=this._transitionablePaint._values[e];return null!=t&&null!=t.value&&null!=t.value.expression&&t.value.expression instanceof ts}isZoomDependent(){return this._isPropertyZoomDependent("model-scale")||this._isPropertyZoomDependent("model-rotation")||this._isPropertyZoomDependent("model-translation")}},clip:class extends $a{constructor(e,t,i,r){super(e,{layout:Dp||(Dp=new ya({"clip-layer-types":new ma(xa.layout_clip["clip-layer-types"]),"clip-layer-scope":new ma(xa.layout_clip["clip-layer-scope"]),visibility:new ma(xa.layout_clip.visibility)})),paint:Rp||(Rp=new ya({}))},t,i,r)}recalculate(e,t){super.recalculate(e,t)}createBucket(e){return new Fp(e)}is3D(e){return!0}}};class Tb{constructor(e){this.capacity=e,this.cache=/* @__PURE__ */new Map}get(e){if(!this.cache.has(e))return;const t=this.cache.get(e);return this.cache.delete(e),this.cache.set(e,t),t}put(e,t){this.cache.has(e)?this.cache.delete(e):this.cache.size===this.capacity&&this.cache.delete(this.cache.keys().next().value),this.cache.set(e,t)}delete(e){this.cache.delete(e)}}as(Tb,"LRUCache");class Sb{constructor(e){this._callback=e,this._triggered=!1,"undefined"!=typeof MessageChannel&&(this._channel=new MessageChannel,this._channel.port2.onmessage=()=>{this._triggered=!1,this._callback()})}trigger(){this._triggered||(this._triggered=!0,this._channel?this._channel.port1.postMessage(!0):setTimeout(()=>{this._triggered=!1,this._callback()},0))}remove(){this._channel=void 0,this._callback=()=>{}}}class Ib{constructor(e){this._stringToNumber={},this._numberToString=[];for(let t=0;t<e.length;t++){const i=e[t];this._stringToNumber[i]=t,this._numberToString[t]=i}}encode(e){return this._stringToNumber[e]}decode(e){return this._numberToString[e]}}class Eb{constructor(e,t){this.tileID=e,this.x=e.canonical.x,this.y=e.canonical.y,this.z=e.canonical.z,this.grid=new os(Yr,Yr,512),this.featureIndexArray=new Hl,this.promoteId=t,this.is3DTile=!1,this.serializedLayersCache=/* @__PURE__ */new Map}insert(e,t,i,r,n,o=0,s=0){const a=this.featureIndexArray.length;this.featureIndexArray.emplaceBack(i,r,n,o);const l=this.grid;for(let c=0;c<t.length;c++){const e=t[c],i=[1/0,1/0,-1/0,-1/0];for(let t=0;t<e.length;t++){const r=e[t];i[0]=Math.min(i[0],r.x),i[1]=Math.min(i[1],r.y),i[2]=Math.max(i[2],r.x),i[3]=Math.max(i[3],r.y)}0!==s&&(i[0]-=s,i[1]-=s,i[2]+=s,i[3]+=s),i[0]<Yr&&i[1]<Yr&&i[2]>=0&&i[3]>=0&&l.insert(a,i[0],i[1],i[2],i[3])}}loadVTLayers(){if(!this.vtLayers){this.vtLayers=new fh(new jg(this.rawTileData)).layers,this.sourceLayerCoder=new Ib(this.vtLayers?Object.keys(this.vtLayers).sort():["_geojsonTileLayer"]),this.vtFeatures={};for(const e in this.vtLayers)this.vtFeatures[e]=[]}return this.vtLayers}query(e,t){const{tilespaceGeometry:i,transform:r,tileTransform:n,pixelPosMatrix:o,availableImages:s,worldview:a}=t;this.loadVTLayers(),this.serializedLayersCache.clear();const l=t.queryRadius?t.queryRadius:0,c=i.bufferedTilespaceBounds,h=this.grid.queryKeys(c.min.x,c.min.y,c.max.x,c.max.y,(e,t,r,n)=>Jh(i.bufferedTilespaceGeometry,e-l,t-l,r+l,n+l));h.sort(Mb);let u=null;r.elevation&&h.length>0&&(u=nb.create(r.elevation,this.tileID));const d={};let p;for(let f=0;f<h.length;f++){const l=h[f];if(l===p)continue;p=l;const c=this.featureIndexArray.get(l);let m=null;this.is3DTile?this.loadMatchingModelFeature(d,c,e,i,r,a):this.loadMatchingFeature(d,c,e,s,a,(e,s,a,l=0)=>(m||(m=ah(e,this.tileID.canonical,n)),s.queryIntersectsFeature(i,e,a,m,this.z,r,o,u,l,t.scope)))}return d}loadMatchingFeature(e,t,i,r,n,o){const{featureIndex:s,bucketIndex:a,sourceLayerIndex:l,layoutVertexArrayOffset:c}=t,h=this.bucketLayerIDs[a],u=i.layers,d=Object.keys(u);if(d.length&&!Ye(d,h))return;const p=i.sourceCache,f=this.sourceLayerCoder.decode(l),m=this.vtLayers[f].feature(s),_=this.getId(m,f);for(let g=0;g<h.length;g++){const t=h[g];if(!u[t])continue;const{styleLayer:i,targets:a}=u[t];let l={};void 0!==_&&(l=p.getFeatureState(i.sourceLayer,_));const d=!o||o(m,i,l,c);if(!d)continue;const f=new yb(m,this.z,this.x,this.y,_);f.tile=this.tileID.canonical,f.state=l;let y=this.serializedLayersCache.get(t);y||(y=i.serialize(),y.id=t,this.serializedLayersCache.set(t,y)),f.source=y.source,f.sourceLayer=y["source-layer"],f.layer=Object.assign({},y),f.layer.paint=Ab(y.paint,i.paint,m,l,r),f.layer.layout=Ab(y.layout,i.layout,m,l,r);let x=!1;for(const e of a){this.updateFeatureProperties(f,e);const{filter:t}=e;if(t)if(m.properties=f.properties,t.needGeometry){const e=lh(m,!0);if(!t.filter(new sa(this.tileID.overscaledZ,{worldview:n}),e,this.tileID.canonical))continue}else if(!t.filter(new sa(this.tileID.overscaledZ,{worldview:n}),m))continue;x=!0,e.targetId&&this.addFeatureVariant(f,e)}x&&this.appendToResult(e,t,s,f,d)}}loadMatchingModelFeature(e,t,i,r,n,o){const{featureIndex:s,bucketIndex:a}=t,l=this.bucketLayerIDs[a],c=i.layers,h=Object.keys(c);if(!h.length||Ye(h,l))for(let u=0;u<l.length;u++){const t=l[u],{styleLayer:a,targets:h}=c[t];if("model"!==a.type)continue;const d=r.tile,p=d.getBucket(a);if(!(p&&p instanceof pb))continue;const f=bb(p,s,r,n);if(!f)continue;const{z:m,x:_,y:g}=d.tileID.canonical,{feature:y,intersectionZ:x,position:v}=f;let b={};void 0!==y.id&&(b=i.sourceCache.getFeatureState(a.sourceLayer,y.id));const w=new yb({},m,_,g,y.id);w.tile=this.tileID.canonical,w.state=b,w.properties=y.properties,w.geometry={type:"Point",coordinates:[v.lng,v.lat]};let T=this.serializedLayersCache.get(t);T||(T=a.serialize(),T.id=t,this.serializedLayersCache.set(t,T)),w.source=T.source,w.sourceLayer=T["source-layer"],w.layer=Object.assign({},T);let S=!1;for(const e of h){this.updateFeatureProperties(w,e);const{filter:t}=e;if(t)if(y.properties=w.properties,t.needGeometry){if(!t.filter(new sa(this.tileID.overscaledZ,{worldview:o}),y,this.tileID.canonical))continue}else if(!t.filter(new sa(this.tileID.overscaledZ,{worldview:o}),y))continue;S=!0,e.targetId&&this.addFeatureVariant(w,e)}S&&this.appendToResult(e,t,s,w,x)}}updateFeatureProperties(e,t,i){if(t.properties){const r={};for(const n in t.properties){const o=t.properties[n].evaluate({zoom:this.z},e._vectorTileFeature,e.state,e.tile,i);null!=o&&(r[n]=o)}e.properties=r}}addFeatureVariant(e,t,i){const r={target:t.target,namespace:t.namespace,uniqueFeatureID:t.uniqueFeatureID};t.properties&&(r.properties=e.properties),e.variants=e.variants||{},e.variants[t.targetId]=e.variants[t.targetId]||[],e.variants[t.targetId].push(r)}appendToResult(e,t,i,r,n){let o=e[t];void 0===o&&(o=e[t]=[]),o.push({featureIndex:i,feature:r,intersectionZ:n})}lookupSymbolFeatures(e,t,i,r,n,o){const s={};this.loadVTLayers();for(const a of e)this.loadMatchingFeature(s,{bucketIndex:t,sourceLayerIndex:i,featureIndex:a,layoutVertexArrayOffset:0},r,n,o);return s}loadFeature(e){const{featureIndex:t,sourceLayerIndex:i}=e;this.loadVTLayers();const r=this.sourceLayerCoder.decode(i),n=this.vtFeatures[r];if(n[t])return n[t];const o=this.vtLayers[r].feature(t);return n[t]=o,o}hasLayer(e){for(const t of this.bucketLayerIDs)for(const i of t)if(e===i)return!0;return!1}getId(e,t){let i=e.id;if(this.promoteId){const r=Array.isArray(this.promoteId)||"object"!=typeof this.promoteId?this.promoteId:this.promoteId[t];if(null!=r)if(Array.isArray(r)){if(!this.promoteIdExpression){const e=Qo(r);if("success"!==e.result)return void Ke(`Failed to create expression for promoteId: ${e.value.map(e=>`${e.key}: ${e.message}`).join(", ")}`);this.promoteIdExpression=e.value}i=this.promoteIdExpression.evaluate({zoom:0},e)}else i=e.properties[r];"boolean"==typeof i&&(i=Number(i))}return i}}function Ab(e,t,i,r,n){return Ze(e,(e,o)=>{const s=t instanceof fa?t.get(o):null;return s&&s.evaluate?s.evaluate(i,r,void 0,n):s})}function Mb(e,t){return t-e}function Cb(e,t){const i={};if(!t)return i;for(const r of e){const e=r.layerIds.map(e=>t.getLayer(e)).filter(Boolean);if(0!==e.length){r.layers=e,r.stateDependentLayerIds&&(r.stateDependentLayers=r.stateDependentLayerIds.map(t=>e.filter(e=>e.id===t)[0])),r.updateExpressions&&r.updateExpressions(e);for(const t of e)i[t.fqid]=r}}return i}as(Eb,"FeatureIndex",{omit:["rawTileData","sourceLayerCoder"]});const Pb=32,Db=33,Rb=new Uint16Array(8184);for(let tT=0;tT<2046;tT++){let e=tT+2,t=0,i=0,r=0,n=0,o=0,s=0;for(1&e?r=n=o=Pb:t=i=s=Pb;(e>>=1)>1;){const a=t+r>>1,l=i+n>>1;1&e?(r=t,n=i,t=o,i=s):(t=r,i=n,r=o,n=s),o=a,s=l}const a=4*tT;Rb[a+0]=t,Rb[a+1]=i,Rb[a+2]=r,Rb[a+3]=n}const zb=new Uint16Array(2178),Lb=new Uint8Array(1089),Fb=new Uint16Array(1089);function Ob(e){return 0===e?-.03125:32===e?.03125:0}const Bb={Other:0,Symbol:1,FillExtrusion:2},kb={type:2,extent:Yr,loadGeometry:()=>[[new Ie(0,0),new Ie(8193,0),new Ie(8193,8193),new Ie(0,8193),new Ie(0,0)]]};class Nb{constructor(){this.tasks={},this.taskQueue=[],qe(["process"],this),this.invoker=new Sb(this.process),this.nextId=0}add(e,t){const i=this.nextId++,r=function({type:e,renderSourceType:t,zoom:i}){i=i||0;const r=t===Bb.Symbol;return"message"===e?0:"maybePrepare"!==e||r?"parseTile"!==e||r?"parseTile"===e&&r?300-i:"maybePrepare"===e&&r?400-i:500:200-i:100-i}(t);if(0===r){try{e()}finally{}return null}return this.tasks[i]={fn:e,metadata:t,priority:r,id:i},this.taskQueue.push(i),this.invoker.trigger(),{cancel:()=>{delete this.tasks[i]}}}process(){try{if(this.taskQueue=this.taskQueue.filter(e=>!!this.tasks[e]),!this.taskQueue.length)return;const e=this.pick();if(null===e)return;const t=this.tasks[e];if(delete this.tasks[e],this.taskQueue.length&&this.invoker.trigger(),!t)return;t.fn()}finally{}}pick(){let e=null,t=1/0;for(let r=0;r<this.taskQueue.length;r++){const i=this.tasks[this.taskQueue[r]];i.priority<t&&(t=i.priority,e=r)}if(null===e)return null;const i=this.taskQueue[e];return this.taskQueue.splice(e,1),i}remove(){this.invoker.remove()}}function Ub(e,t,i){try{t=function(e){if(!e.variants)return e;if(!Array.isArray(e.variants))throw new Error("variants must be an array");for(const t of e.variants){if(null==t||"object"!=typeof t||t.constructor!==Object)throw new Error("variant must be an object");if(!Array.isArray(t.capabilities))throw new Error("capabilities must be an array");if(1===t.capabilities.length&&"meshopt"===t.capabilities[0])return Object.assign(e,t)}return e}(t)}catch(e){return new Error("Failed to process TileJSON variants",{cause:e})}const r=je(Object.assign({},t,e),["tilejson","tiles","minzoom","maxzoom","attribution","mapbox_logo","bounds","extra_bounds","scheme","tileSize","encoding","vector_layers","raster_layers","worldview_options","worldview_default","worldview"]);return e.url&&t.tiles&&e.tiles&&(r.tiles=t.tiles),r.tiles=i.canonicalizeTileset(r,e.url),r}const Vb=/* @__PURE__ */new Map,jb=/* @__PURE__ */new Map;class Gb{constructor(e){this.size=e,this.minimums=[],this.maximums=[],this.leaves=[]}getElevation(e,t){const i=this.toIdx(e,t);return{min:this.minimums[i],max:this.maximums[i]}}isLeaf(e,t){return this.leaves[this.toIdx(e,t)]}toIdx(e,t){return t*this.size+e}}function Hb(e,t,i,r){let n=0,o=Number.MAX_VALUE;for(let s=0;s<3;s++)if(Math.abs(r[s])<1e-15){if(i[s]<e[s]||i[s]>t[s])return null}else{const a=1/r[s];let l=(e[s]-i[s])*a,c=(t[s]-i[s])*a;if(l>c){const e=l;l=c,c=e}if(l>n&&(n=l),c<o&&(o=c),n>o)return null}return n}function $b(e,t,i,r,n,o,s,a,l,c,h){const u=r-e,d=n-t,p=o-i,f=s-e,m=a-t,_=l-i,g=h[1]*_-h[2]*m,y=h[2]*f-h[0]*_,x=h[0]*m-h[1]*f,v=u*g+d*y+p*x;if(Math.abs(v)<1e-15)return null;const b=1/v,w=c[0]-e,T=c[1]-t,S=c[2]-i,I=(w*g+T*y+S*x)*b;if(I<0||I>1)return null;const E=T*p-S*d,A=S*u-w*p,M=w*d-T*u,C=(h[0]*E+h[1]*A+h[2]*M)*b;return C<0||I+C>1?null:(f*E+m*A+_*M)*b}function qb(e,t,i){return(e-t)/(i-t)}function Zb(e,t,i,r,n,o,s,a,l){const c=1<<i,h=o-r,u=s-n,d=(e+1)/c*h+r,p=(t+0)/c*u+n,f=(t+1)/c*u+n;a[0]=(e+0)/c*h+r,a[1]=p,l[0]=d,l[1]=f}class Wb{constructor(e){if(this.maximums=[],this.minimums=[],this.leaves=[],this.childOffsets=[],this.nodeCount=0,this.dem=e,this._siblingOffset=[[0,0],[1,0],[0,1],[1,1]],!this.dem)return;const t=function(e){const t=Math.ceil(Math.log2(e.dim/8)),i=[];let r=Math.ceil(Math.pow(2,t));const n=1/r,o=(e,t,i,r,n)=>{const o=r?1:0,s=(e+1)*i-o,a=t*i,l=(t+1)*i-o;n[0]=e*i,n[1]=a,n[2]=s,n[3]=l};let s=new Gb(r);const a=[];for(let l=0;l<r*r;l++){o(l%r,Math.floor(l/r),n,!1,a);const t=Yb(a[0],a[1],e),i=Yb(a[2],a[1],e),c=Yb(a[2],a[3],e),h=Yb(a[0],a[3],e);s.minimums.push(Math.min(t,i,c,h)),s.maximums.push(Math.max(t,i,c,h)),s.leaves.push(1)}for(i.push(s),r/=2;r>=1;r/=2){const e=i.at(-1);s=new Gb(r);for(let t=0;t<r*r;t++){o(t%r,Math.floor(t/r),2,!0,a);const i=e.getElevation(a[0],a[1]),n=e.getElevation(a[2],a[1]),l=e.getElevation(a[2],a[3]),c=e.getElevation(a[0],a[3]),h=e.isLeaf(a[0],a[1]),u=e.isLeaf(a[2],a[1]),d=e.isLeaf(a[2],a[3]),p=e.isLeaf(a[0],a[3]),f=Math.min(i.min,n.min,l.min,c.min),m=Math.max(i.max,n.max,l.max,c.max),_=h&&u&&d&&p;s.maximums.push(m),s.minimums.push(f),s.leaves.push(m-f<=5&&_?1:0)}i.push(s)}return i}(this.dem),i=t.length-1,r=t[i];this._addNode(r.minimums[0],r.maximums[0],r.leaves[0]),this._construct(t,0,0,i,0)}raycastRoot(e,t,i,r,n,o,s=1){return Hb([e,t,-100],[i,r,this.maximums[0]*s],n,o)}raycast(e,t,i,r,n,o,s=1){if(!this.nodeCount)return null;const a=this.raycastRoot(e,t,i,r,n,o,s);if(null==a)return null;const l=[],c=[],h=[],u=[],d=[{idx:0,t:a,nodex:0,nodey:0,depth:0}];for(;d.length>0;){const{idx:a,t:p,nodex:f,nodey:m,depth:_}=d.pop();if(this.leaves[a]){Zb(f,m,_,e,t,i,r,h,u);const a=1<<_,l=(f+0)/a,c=(f+1)/a,d=(m+0)/a,g=(m+1)/a,y=Yb(l,d,this.dem)*s,x=Yb(c,d,this.dem)*s,v=Yb(c,g,this.dem)*s,b=Yb(l,g,this.dem)*s,w=$b(h[0],h[1],y,u[0],h[1],x,u[0],u[1],v,n,o),T=$b(u[0],u[1],v,h[0],u[1],b,h[0],h[1],y,n,o),S=Math.min(null!==w?w:Number.MAX_VALUE,null!==T?T:Number.MAX_VALUE);if(S!==Number.MAX_VALUE)return S;{const e=F([],n,o,p);if(Xb(y,x,b,v,qb(e[0],h[0],u[0]),qb(e[1],h[1],u[1]))>=e[2])return p}continue}let g=0;for(let d=0;d<this._siblingOffset.length;d++){Zb((f<<1)+this._siblingOffset[d][0],(m<<1)+this._siblingOffset[d][1],_+1,e,t,i,r,h,u),h[2]=-100,u[2]=this.maximums[this.childOffsets[a]+d]*s;const p=Hb(h,u,n,o);if(null!=p){const e=p;l[d]=e;let t=!1;for(let i=0;i<g&&!t;i++)e>=l[c[i]]&&(c.splice(i,0,d),t=!0);t||(c[g]=d),g++}}for(let e=0;e<g;e++){const t=c[e];d.push({idx:this.childOffsets[a]+t,t:l[t],nodex:(f<<1)+this._siblingOffset[t][0],nodey:(m<<1)+this._siblingOffset[t][1],depth:_+1})}}return null}_addNode(e,t,i){return this.minimums.push(e),this.maximums.push(t),this.leaves.push(i),this.childOffsets.push(0),this.nodeCount++}_construct(e,t,i,r,n){if(1===e[r].isLeaf(t,i))return;this.childOffsets[n]||(this.childOffsets[n]=this.nodeCount);const o=r-1,s=e[o];let a=0,l=0;for(let c=0;c<this._siblingOffset.length;c++){const e=2*t+this._siblingOffset[c][0],r=2*i+this._siblingOffset[c][1],n=s.getElevation(e,r),o=s.isLeaf(e,r),h=this._addNode(n.min,n.max,o);o&&(a|=1<<c),l||(l=h)}for(let c=0;c<this._siblingOffset.length;c++)a&1<<c||this._construct(e,2*t+this._siblingOffset[c][0],2*i+this._siblingOffset[c][1],o,l+c)}}function Xb(e,t,i,r,n,o){return yi(yi(e,i,o),yi(t,r,o),n)}function Yb(e,t,i){const r=i.dim,n=ke(e*r-.5,0,r-1),o=ke(t*r-.5,0,r-1),s=Math.floor(n),a=Math.floor(o),l=Math.min(s+1,r-1),c=Math.min(a+1,r-1);return Xb(i.get(s,a),i.get(l,a),i.get(s,c),i.get(l,c),n-s,o-a)}const Jb={mapbox:[6553.6,25.6,.1,1e4],terrarium:[256,1,1/256,32768]};function Kb(e,t,i){return(256*e*256+256*t+i)/10-1e4}function Qb(e,t,i){return 256*e+t+i/256-32768}class ew{get tree(){return this._tree||this._buildQuadTree(),this._tree}constructor(e,t,i,r=!1){if(this.uid=e,t.height!==t.width)throw new RangeError("DEM tiles must be square");if(i&&"mapbox"!==i&&"terrarium"!==i)return void Ke(`"${i}" is not a valid encoding type. Valid types include "mapbox" and "terrarium".`);this.stride=t.height;const n=this.dim=t.height-2,o=new Uint32Array(t.data.buffer);if(this.pixels=new Uint8Array(t.data.buffer),this.floatView=new Float32Array(t.data.buffer),this.borderReady=r,this._modifiedForSources={},!r){for(let e=0;e<n;e++)o[this._idx(-1,e)]=o[this._idx(0,e)],o[this._idx(n,e)]=o[this._idx(n-1,e)],o[this._idx(e,-1)]=o[this._idx(e,0)],o[this._idx(e,n)]=o[this._idx(e,n-1)];o[this._idx(-1,-1)]=o[this._idx(0,0)],o[this._idx(n,-1)]=o[this._idx(n-1,0)],o[this._idx(-1,n)]=o[this._idx(0,n-1)],o[this._idx(n,n)]=o[this._idx(n-1,n-1)]}const s="terrarium"===i?Qb:Kb;for(let a=0;a<o.length;++a){const e=4*a;this.floatView[a]=s(this.pixels[e],this.pixels[e+1],this.pixels[e+2])}this._timestamp=It.now()}_buildQuadTree(){this._tree=new Wb(this)}get(e,t,i=!1){i&&(e=ke(e,-1,this.dim),t=ke(t,-1,this.dim));const r=this._idx(e,t);return this.floatView[r]}set(e,t,i){const r=this._idx(e,t),n=this.floatView[r];return this.floatView[r]=i,i-n}static getUnpackVector(e){return Jb[e]}_idx(e,t){if(e<-1||e>=this.dim+1||t<-1||t>=this.dim+1)throw new RangeError("out of range source coordinates for DEM data");return(t+1)*this.stride+(e+1)}static pack(e,t){const i=[0,0,0,0],r=ew.getUnpackVector(t);let n=Math.floor((e+r[3])/r[2]);return i[2]=n%256,n=Math.floor(n/256),i[1]=n%256,n=Math.floor(n/256),i[0]=n,i}getPixels(){return new nd({width:this.stride,height:this.stride},this.pixels)}backfillBorder(e,t,i){if(this.dim!==e.dim)throw new Error("dem dimension mismatch");let r=t*this.dim,n=t*this.dim+this.dim,o=i*this.dim,s=i*this.dim+this.dim;switch(t){case-1:r=n-1;break;case 1:n=r+1}switch(i){case-1:o=s-1;break;case 1:s=o+1}const a=-t*this.dim,l=-i*this.dim;for(let c=o;c<s;c++)for(let t=r;t<n;t++){const i=4*this._idx(t,c),r=4*this._idx(t+a,c+l);this.pixels[i+0]=e.pixels[r+0],this.pixels[i+1]=e.pixels[r+1],this.pixels[i+2]=e.pixels[r+2],this.pixels[i+3]=e.pixels[r+3]}}onDeserialize(){this._tree&&(this._tree.dem=this)}}function tw(e,t,i){1===e?t.headerLength=i.readFixed32():2===e?t.x=i.readVarint():3===e?t.y=i.readVarint():4===e?t.z=i.readVarint():5===e&&t.layers.push(function(e,t){return e.readFields(sw,{version:0,name:"",units:"",tileSize:0,buffer:0,pixelFormat:0,dataIndex:[]},t)}(i,i.readVarint()+i.pos))}function iw(e,t,i){1===e?(t.delta_filter=function(e,t){return e.readFields(rw,{blockSize:0},t)}(i,i.readVarint()+i.pos),t.filter="delta_filter"):2===e?(i.readVarint(),t.filter="zigzag_filter"):3===e?(i.readVarint(),t.filter="bitshuffle_filter"):4===e&&(i.readVarint(),t.filter="byteshuffle_filter")}function rw(e,t,i){1===e&&(t.blockSize=i.readVarint())}function nw(e,t,i){1===e?(i.readVarint(),t.codec="gzip_data"):2===e?(i.readVarint(),t.codec="jpeg_image"):3===e?(i.readVarint(),t.codec="webp_image"):4===e&&(i.readVarint(),t.codec="png_image")}function ow(e,t,i){let r=0,n=0;1===e?t.firstByte=i.readFixed64():2===e?t.lastByte=i.readFixed64():3===e?t.filters.push(function(e,t){return e.readFields(iw,{},t)}(i,i.readVarint()+i.pos)):4===e?t.codec=function(e,t){return e.readFields(nw,{},t)}(i,i.readVarint()+i.pos):5===e?n=i.readFloat():6===e?r=i.readFloat():7===e?t.bands.push(i.readString()):8===e?t.offset=i.readDouble():9===e&&(t.scale=i.readDouble()),0===t.offset&&(t.offset=n),0===t.scale&&(t.scale=r)}function sw(e,t,i){1===e?t.version=i.readVarint():2===e?t.name=i.readString():3===e?t.units=i.readString():4===e?t.tileSize=i.readVarint():5===e?t.buffer=i.readVarint():6===e?t.pixelFormat=i.readVarint():7===e&&t.dataIndex.push(function(e,t){return e.readFields(ow,{firstByte:0,lastByte:0,filters:[],codec:null,offset:0,scale:0,bands:[]},t)}(i,i.readVarint()+i.pos))}function aw(e,t,i){if(2===e)!function(e,t,i){e.readFields(lw,i,t)}(i,i.readVarint()+i.pos,t);else if(3===e)throw new Error("Not implemented")}function lw(e,t,i){if(1===e){let e=0;const r=i.readVarint()+i.pos;for(;i.pos<r;)t[e++]=i.readVarint()}}function cw(e,t){if(4!==t.length)throw new Error(`Expected data of dimension 4 but got ${t.length}.`);let i=t[3];for(let r=2;r>=1;r--){const n=1===r?1:0,o=2===r?1:0;for(let r=0;r<t[0];r++){const s=t[1]*r;for(let r=n;r<t[1];r++){const n=t[2]*(r+s);for(let r=o;r<t[2];r++){const o=t[3]*(r+n);for(let r=0;r<t[3];r++){const t=o+r;e[t]+=e[t-i]}}}}i*=t[r]}return e}function hw(e){for(let t=0,i=e.length;t<i;t++)e[t]=e[t]>>>1^-(1&e[t]);return e}function uw(e,t){switch(t){case"uint32":return e;case"uint16":for(let t=0;t<e.length;t+=2){const i=e[t],r=e[t+1];e[t]=(240&i)>>4|(61440&i)>>8|(240&r)<<4|61440&r,e[t+1]=15&i|(3840&i)>>4|(15&r)<<8|(3840&r)<<4}return e;case"uint8":for(let t=0;t<e.length;t+=4){const i=e[t],r=e[t+1],n=e[t+2],o=e[t+3];e[t+0]=(192&i)>>6|(192&r)>>4|(192&n)>>2|192&o,e[t+1]=(48&i)>>4|(48&r)>>2|48&n|(48&o)<<2,e[t+2]=(12&i)>>2|12&r|(12&n)<<2|(12&o)<<4,e[t+3]=3&i|(3&r)<<2|(3&n)<<4|(3&o)<<6}return e;default:throw new Error(`Invalid pixel format, "${t}"`)}}as(ew,"DEMData"),as(Wb,"DemMinMaxQuadTree",{omit:["dem"]});var dw=Uint8Array,pw=Uint16Array,fw=Int32Array,mw=new dw([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),_w=new dw([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),gw=new dw([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),yw=function(e,t){for(var i=new pw(31),r=0;r<31;++r)i[r]=t+=1<<e[r-1];var n=new fw(i[30]);for(r=1;r<30;++r)for(var o=i[r];o<i[r+1];++o)n[o]=o-i[r]<<5|r;return{b:i,r:n}},xw=yw(mw,2),vw=xw.b,bw=xw.r;vw[28]=258,bw[258]=28;for(var ww=yw(_w,0).b,Tw=new pw(32768),Sw=0;Sw<32768;++Sw){var Iw=(43690&Sw)>>1|(21845&Sw)<<1;Tw[Sw]=((65280&(Iw=(61680&(Iw=(52428&Iw)>>2|(13107&Iw)<<2))>>4|(3855&Iw)<<4))>>8|(255&Iw)<<8)>>1}var Ew=function(e,t,i){for(var r=e.length,n=0,o=new pw(t);n<r;++n)e[n]&&++o[e[n]-1];var s,a=new pw(t);for(n=1;n<t;++n)a[n]=a[n-1]+o[n-1]<<1;s=new pw(1<<t);var l=15-t;for(n=0;n<r;++n)if(e[n])for(var c=n<<4|e[n],h=t-e[n],u=a[e[n]-1]++<<h,d=u|(1<<h)-1;u<=d;++u)s[Tw[u]>>l]=c;return s},Aw=new dw(288);for(Sw=0;Sw<144;++Sw)Aw[Sw]=8;for(Sw=144;Sw<256;++Sw)Aw[Sw]=9;for(Sw=256;Sw<280;++Sw)Aw[Sw]=7;for(Sw=280;Sw<288;++Sw)Aw[Sw]=8;var Mw=new dw(32);for(Sw=0;Sw<32;++Sw)Mw[Sw]=5;var Cw=Ew(Aw,9),Pw=Ew(Mw,5),Dw=function(e){for(var t=e[0],i=1;i<e.length;++i)e[i]>t&&(t=e[i]);return t},Rw=function(e,t,i){var r=t/8|0;return(e[r]|e[r+1]<<8)>>(7&t)&i},zw=function(e,t){var i=t/8|0;return(e[i]|e[i+1]<<8|e[i+2]<<16)>>(7&t)},Lw=function(e){return(e+7)/8|0},Fw=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],Ow=function(e,t,i){var r=new Error(t||Fw[e]);if(r.code=e,Error.captureStackTrace&&Error.captureStackTrace(r,Ow),!i)throw r;return r},Bw=new dw(0),kw="undefined"!=typeof TextDecoder&&new TextDecoder;try{kw.decode(Bw,{stream:!0})}catch(e){}const Nw={gzip_data:"gzip"};class Uw extends Error{constructor(e){super(e),this.name="MRTError"}}const Vw={0:"uint32",1:"uint32",2:"uint16",3:"uint8"},jw={uint32:1,uint16:2,uint8:4},Gw={uint32:Uint32Array,uint16:Uint16Array,uint8:Uint8Array};let Hw;class $w{constructor(e=5){this.x=NaN,this.y=NaN,this.z=NaN,this.layers={},this._cacheSize=e}getLayer(e){const t=this.layers[e];if(!t)throw new Uw(`Layer '${e}' not found`);return t}getHeaderLength(e){const t=new Uint8Array(e),i=new DataView(e);if(13!==t[0])throw new Uw("File is not a valid MRT.");return i.getUint32(1,!0)}parseHeader(e){const t=new Uint8Array(e),i=this.getHeaderLength(e);if(t.length<i)throw new Uw(`Expected header with length >= ${i} but got buffer of length ${t.length}`);const r=new Hw(t.subarray(0,i)).readFields(tw,{headerLength:0,x:0,y:0,z:0,layers:[]},void 0);if(!isNaN(this.x)&&(this.x!==r.x||this.y!==r.y||this.z!==r.z))throw new Uw(`Invalid attempt to parse header ${r.z}/${r.x}/${r.y} for tile ${this.z}/${this.x}/${this.y}`);this.x=r.x,this.y=r.y,this.z=r.z;for(const n of r.layers)this.layers[n.name]=new qw(n,{cacheSize:this._cacheSize});return this}createDecodingTask(e){const t=[],i=this.getLayer(e.layerName);for(let r of e.blockIndices){const n=i.dataIndex[r],o=n.firstByte-e.firstByte,s=n.lastByte-e.firstByte;if(i._blocksInProgress.has(r))continue;const a={layerName:i.name,firstByte:o,lastByte:s,pixelFormat:i.pixelFormat,blockIndex:r,blockShape:[n.bands.length].concat(i.bandShape),buffer:i.buffer,codec:n.codec.codec,filters:n.filters.map(e=>e.filter)};i._blocksInProgress.add(r),t.push(a)}return new Zw(t,()=>{t.forEach(e=>i._blocksInProgress.delete(e.blockIndex))},(e,r)=>{if(t.forEach(e=>i._blocksInProgress.delete(e.blockIndex)),e)throw e;r.forEach(e=>{this.getLayer(e.layerName).processDecodedData(e)})})}}class qw{constructor({version:e,name:t,units:i,tileSize:r,pixelFormat:n,buffer:o,dataIndex:s},a){if(this.version=e,1!==this.version)throw new Uw(`Cannot parse raster layer encoded with MRT version ${e}`);this.name=t,this.units=i,this.tileSize=r,this.buffer=o,this.pixelFormat=Vw[n],this.dataIndex=s,this.bandShape=[r+2*o,r+2*o,jw[this.pixelFormat]],this._decodedBlocks=new Tb(a?a.cacheSize:5),this._blocksInProgress=/* @__PURE__ */new Set}get dimension(){return jw[this.pixelFormat]}get cacheSize(){return this._decodedBlocks.capacity}getBandList(){return this.dataIndex.map(({bands:e})=>e).flat()}processDecodedData(e){const t=e.blockIndex.toString();this._decodedBlocks.get(t)||this._decodedBlocks.put(t,e.data)}getBlockForBand(e){let t=0;switch(typeof e){case"string":for(const[i,r]of this.dataIndex.entries()){for(const[n,o]of r.bands.entries())if(o===e)return{bandIndex:t+n,blockIndex:i,blockBandIndex:n};t+=r.bands.length}break;case"number":for(const[i,r]of this.dataIndex.entries()){if(e>=t&&e<t+r.bands.length)return{bandIndex:e,blockIndex:i,blockBandIndex:e-t};t+=r.bands.length}break;default:throw new Uw(`Invalid band \`${JSON.stringify(e)}\`. Expected string or integer.`)}return{blockIndex:-1,blockBandIndex:-1}}getDataRange(e){let t=1/0,i=-1/0;const r=[],n=/* @__PURE__ */new Set;for(const o of e){const{blockIndex:e}=this.getBlockForBand(o);if(e<0)throw new Uw(`Invalid band: ${JSON.stringify(o)}`);const s=this.dataIndex[e];r.includes(e)||r.push(e),n.add(e),t=Math.min(t,s.firstByte),i=Math.max(i,s.lastByte)}if(n.size>this.cacheSize)throw new Uw(`Number of blocks to decode (${n.size}) exceeds cache size (${this.cacheSize}).`);return{layerName:this.name,firstByte:t,lastByte:i,blockIndices:r}}hasBand(e){const{blockIndex:t}=this.getBlockForBand(e);return t>=0}hasDataForBand(e){const{blockIndex:t}=this.getBlockForBand(e);return t>=0&&!!this._decodedBlocks.get(t.toString())}getBandView(e){const{blockIndex:t,blockBandIndex:i}=this.getBlockForBand(e);if(t<0)throw new Uw(`Band not found: ${JSON.stringify(e)}`);const r=this._decodedBlocks.get(t.toString());if(!r)throw new Uw(`Data for band ${JSON.stringify(e)} of layer "${this.name}" not decoded.`);const n=this.dataIndex[t],o=this.bandShape.reduce((e,t)=>e*t,1),s=i*o,a=r.subarray(s,s+o);return{data:a,bytes:new Uint8Array(a.buffer).subarray(a.byteOffset,a.byteOffset+a.byteLength),tileSize:this.tileSize,buffer:this.buffer,pixelFormat:this.pixelFormat,dimension:this.dimension,offset:n.offset,scale:n.scale}}}$w.setPbf=function(e){Hw=e};class Zw{constructor(e,t,i){this.tasks=e,this._onCancel=t,this._onComplete=i,this._finalized=!1}cancel(){this._finalized||(this._onCancel(),this._finalized=!0)}complete(e,t){this._finalized||(this._onComplete(e,t),this._finalized=!0)}}$w.performDecoding=function(e,t){const i=new Uint8Array(e);return Promise.all(t.tasks.map(e=>{const{layerName:t,firstByte:r,lastByte:n,pixelFormat:o,blockShape:s,blockIndex:a,filters:l,codec:c}=e,h=i.subarray(r,n+1),u=new Uint32Array(s[0]*s[1]*s[2]);let d;if("gzip_data"!==c)throw new Uw(`Unhandled codec: ${c}`);return d=function(e,t){if(!globalThis.DecompressionStream&&"gzip_data"===t)return Promise.resolve((o=function(e){31==e[0]&&139==e[1]&&8==e[2]||Ow(6,"invalid gzip data");var t=e[3],i=10;4&t&&(i+=2+(e[10]|e[11]<<8));for(var r=(t>>3&1)+(t>>4&1);r>0;r-=!e[i++]);return i+(2&t)}(i=e),o+8>i.length&&Ow(6,"invalid gzip data"),function(e,t,i){var r=e.length;if(!r||t.f&&!t.l)return i||new dw(0);var n=!i,o=n||2!=t.i,s=t.i;n&&(i=new dw(3*r));var a=function(e){var t=i.length;if(e>t){var r=new dw(Math.max(2*t,e));r.set(i),i=r}},l=t.f||0,c=t.p||0,h=t.b||0,u=t.l,d=t.d,p=t.m,f=t.n,m=8*r;do{if(!u){l=Rw(e,c,1);var _=Rw(e,c+1,3);if(c+=3,!_){var g=e[(M=Lw(c)+4)-4]|e[M-3]<<8,y=M+g;if(y>r){s&&Ow(0);break}o&&a(h+g),i.set(e.subarray(M,y),h),t.b=h+=g,t.p=c=8*y,t.f=l;continue}if(1==_)u=Cw,d=Pw,p=9,f=5;else if(2==_){var x=Rw(e,c,31)+257,v=Rw(e,c+10,15)+4,b=x+Rw(e,c+5,31)+1;c+=14;for(var w=new dw(b),T=new dw(19),S=0;S<v;++S)T[gw[S]]=Rw(e,c+3*S,7);c+=3*v;var I=Dw(T),E=(1<<I)-1,A=Ew(T,I);for(S=0;S<b;){var M,C=A[Rw(e,c,E)];if(c+=15&C,(M=C>>4)<16)w[S++]=M;else{var P=0,D=0;for(16==M?(D=3+Rw(e,c,3),c+=2,P=w[S-1]):17==M?(D=3+Rw(e,c,7),c+=3):18==M&&(D=11+Rw(e,c,127),c+=7);D--;)w[S++]=P}}var R=w.subarray(0,x),z=w.subarray(x);p=Dw(R),f=Dw(z),u=Ew(R,p),d=Ew(z,f)}else Ow(1);if(c>m){s&&Ow(0);break}}o&&a(h+131072);for(var L=(1<<p)-1,F=(1<<f)-1,O=c;;O=c){var B=(P=u[zw(e,c)&L])>>4;if((c+=15&P)>m){s&&Ow(0);break}if(P||Ow(2),B<256)i[h++]=B;else{if(256==B){O=c,u=null;break}var k=B-254;B>264&&(k=Rw(e,c,(1<<(V=mw[S=B-257]))-1)+vw[S],c+=V);var N=d[zw(e,c)&F],U=N>>4;if(N||Ow(3),c+=15&N,z=ww[U],U>3){var V=_w[U];z+=zw(e,c)&(1<<V)-1,c+=V}if(c>m){s&&Ow(0);break}o&&a(h+131072);var j=h+k;if(h<z){var G=0-z,H=Math.min(z,j);for(G+h<0&&Ow(3);h<H;++h)i[h]=(void 0)[G+h]}for(;h<j;++h)i[h]=i[h-z]}}t.l=u,t.p=O,t.b=h,t.f=l,u&&(l=1,t.m=p,t.d=d,t.n=f)}while(!l);return h!=i.length&&n?function(e,t,i){return(null==i||i>e.length)&&(i=e.length),new dw(e.subarray(0,i))}(i,0,h):i.subarray(0,h)}(i.subarray(o,-8),{i:2},new dw(((r=i)[(n=r.length)-4]|r[n-3]<<8|r[n-2]<<16|r[n-1]<<24)>>>0))));var i,r,n,o;const s=Nw[t];if(!s)throw new Error(`Unhandled codec: ${t}`);const a=new globalThis.DecompressionStream(s);return new Response(new Blob([e]).stream().pipeThrough(a)).arrayBuffer().then(e=>new Uint8Array(e))}(h,c).then(e=>(function(e,t){e.readFields(aw,t)}(new Hw(e),u),new Gw[o](u.buffer))),d.then(e=>{for(let t=l.length-1;t>=0;t--)switch(l[t]){case"delta_filter":cw(e,s);break;case"zigzag_filter":hw(e);break;case"bitshuffle_filter":uw(e,o);break;default:throw new Uw(`Unhandled filter "${l[t]}"`)}return{layerName:t,blockIndex:a,data:e}}).catch(e=>{throw e})}))},as(Zw,"MRTDecodingBatch",{omit:["_onCancel","_onComplete"]}),as($w,"MapboxRasterTile"),as(qw,"MapboxRasterLayer",{omit:["_blocksInProgress"]});const Ww=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array];class Xw{static from(e){if(!(e instanceof ArrayBuffer))throw new Error("Data must be an instance of ArrayBuffer.");const[t,i]=new Uint8Array(e,0,2);if(219!==t)throw new Error("Data does not appear to be in a KDBush format.");const r=i>>4;if(1!==r)throw new Error(`Got v${r} data when expected v1.`);const n=Ww[15&i];if(!n)throw new Error("Unrecognized array type.");const[o]=new Uint16Array(e,2,1),[s]=new Uint32Array(e,4,1);return new Xw(s,o,n,e)}constructor(e,t=64,i=Float64Array,r){if(isNaN(e)||e<0)throw new Error(`Unpexpected numItems value: ${e}.`);this.numItems=+e,this.nodeSize=Math.min(Math.max(+t,2),65535),this.ArrayType=i,this.IndexArrayType=e<65536?Uint16Array:Uint32Array;const n=Ww.indexOf(this.ArrayType),o=2*e*this.ArrayType.BYTES_PER_ELEMENT,s=e*this.IndexArrayType.BYTES_PER_ELEMENT,a=(8-s%8)%8;if(n<0)throw new Error(`Unexpected typed array class: ${i}.`);r&&r instanceof ArrayBuffer?(this.data=r,this.ids=new this.IndexArrayType(this.data,8,e),this.coords=new this.ArrayType(this.data,8+s+a,2*e),this._pos=2*e,this._finished=!0):(this.data=new ArrayBuffer(8+o+s+a),this.ids=new this.IndexArrayType(this.data,8,e),this.coords=new this.ArrayType(this.data,8+s+a,2*e),this._pos=0,this._finished=!1,new Uint8Array(this.data,0,2).set([219,16+n]),new Uint16Array(this.data,2,1)[0]=t,new Uint32Array(this.data,4,1)[0]=e)}add(e,t){const i=this._pos>>1;return this.ids[i]=i,this.coords[this._pos++]=e,this.coords[this._pos++]=t,i}finish(){const e=this._pos>>1;if(e!==this.numItems)throw new Error(`Added ${e} items when expected ${this.numItems}.`);return Yw(this.ids,this.coords,this.nodeSize,0,this.numItems-1,0),this._finished=!0,this}range(e,t,i,r){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:n,coords:o,nodeSize:s}=this,a=[0,n.length-1,0],l=[];for(;a.length;){const c=a.pop()||0,h=a.pop()||0,u=a.pop()||0;if(h-u<=s){for(let s=u;s<=h;s++){const a=o[2*s],c=o[2*s+1];a>=e&&a<=i&&c>=t&&c<=r&&l.push(n[s])}continue}const d=u+h>>1,p=o[2*d],f=o[2*d+1];p>=e&&p<=i&&f>=t&&f<=r&&l.push(n[d]),(0===c?e<=p:t<=f)&&(a.push(u),a.push(d-1),a.push(1-c)),(0===c?i>=p:r>=f)&&(a.push(d+1),a.push(h),a.push(1-c))}return l}within(e,t,i){if(!this._finished)throw new Error("Data not yet indexed - call index.finish().");const{ids:r,coords:n,nodeSize:o}=this,s=[0,r.length-1,0],a=[],l=i*i;for(;s.length;){const c=s.pop()||0,h=s.pop()||0,u=s.pop()||0;if(h-u<=o){for(let i=u;i<=h;i++)eT(n[2*i],n[2*i+1],e,t)<=l&&a.push(r[i]);continue}const d=u+h>>1,p=n[2*d],f=n[2*d+1];eT(p,f,e,t)<=l&&a.push(r[d]),(0===c?e-i<=p:t-i<=f)&&(s.push(u),s.push(d-1),s.push(1-c)),(0===c?e+i>=p:t+i>=f)&&(s.push(d+1),s.push(h),s.push(1-c))}return a}}function Yw(e,t,i,r,n,o){if(n-r<=i)return;const s=r+n>>1;Jw(e,t,s,r,n,o),Yw(e,t,i,r,s-1,1-o),Yw(e,t,i,s+1,n,1-o)}function Jw(e,t,i,r,n,o){for(;n>r;){if(n-r>600){const s=n-r+1,a=i-r+1,l=Math.log(s),c=.5*Math.exp(2*l/3),h=.5*Math.sqrt(l*c*(s-c)/s)*(a-s/2<0?-1:1);Jw(e,t,i,Math.max(r,Math.floor(i-a*c/s+h)),Math.min(n,Math.floor(i+(s-a)*c/s+h)),o)}const s=t[2*i+o];let a=r,l=n;for(Kw(e,t,r,i),t[2*n+o]>s&&Kw(e,t,r,n);a<l;){for(Kw(e,t,a,l),a++,l--;t[2*a+o]<s;)a++;for(;t[2*l+o]>s;)l--}t[2*r+o]===s?Kw(e,t,r,l):(l++,Kw(e,t,l,n)),l<=i&&(r=l+1),i<=l&&(n=l-1)}}function Kw(e,t,i,r){Qw(e,i,r),Qw(t,2*i,2*r),Qw(t,2*i+1,2*r+1)}function Qw(e,t,i){const r=e[t];e[t]=e[i],e[i]=r}function eT(e,t,i,r){const n=e-i,o=t-r;return n*n+o*o}t.$=ar,t.A=Zi,t.B=2,t.C=xi,t.D=Uy,t.E=pi,t.F=Ly,t.G=sr,t.H=va,t.I=fi,t.J=or,t.K=lr,t.L=Tb,t.M=jo,t.N=No,t.O=Vo,t.P=Ie,t.Q=Ko,t.R=Gt,t.S=ba,t.T=Pm,t.U=Qo,t.V=is,t.W=Mn,t.X=En,t.Y=An,t.Z=fr,t._=cr,t.a=function(e){return dt.API_CDN_URL_REGEX.test(e)},t.a$=xb,t.a0=gi,t.a1=wa,t.a2=/^(.*)-use-theme$/,t.a3=/^(.*)-transition$/,t.a4=Go,t.a5=Uo,t.a6=xa,t.a7=ca,t.a8=ya,t.a9=ma,t.aA=function(e){let t=1/0,i=1/0,r=-1/0,n=-1/0;for(const o of e)t=Math.min(t,o.x),i=Math.min(i,o.y),r=Math.max(r,o.x),n=Math.max(n,o.y);return{min:new Ie(t,i),max:new Ie(r,n)}},t.aB=ke,t.aC=d,t.aD=te,t.aE=Pc,t.aF=Yh,t.aG=jc,t.aH=th,t.aI=Uc,t.aJ=Gc,t.aK=je,t.aL=class{constructor(e){this.entries={},this.scheduler=e}request(e,t,i,r){const n=this.entries[e]=this.entries[e]||{callbacks:[]};if(n.result){const[e,i]=n.result;return this.scheduler?this.scheduler.add(()=>{r(e,i)},t):r(e,i),()=>{}}return n.callbacks.push(r),n.cancel||(n.cancel=i((i,r)=>{n.result=[i,r];for(const e of n.callbacks)this.scheduler?this.scheduler.add(()=>{e(i,r)},t):e(i,r);setTimeout(()=>delete this.entries[e],3e3)})),()=>{n.result||(n.callbacks=n.callbacks.filter(e=>e!==r),n.callbacks.length||(n.cancel(),delete this.entries[e]))}}},t.aM=function(e){if("provider"in e&&!e.provider)return null;let t=e.provider;if(!t&&"url"in e&&e.url&&(t=function(e){try{const t=new URL(e).pathname.split("/").pop()||"",i=t.lastIndexOf(".");return i>=0?t.slice(i+1):""}catch{return""}}(e.url)),!t)return null;const i=dt.TILE_PROVIDER_URLS[t];if(!i)return null;let r;try{r=new URL(i,dt.API_URL).href}catch(e){/* @__PURE__ */
|
|
2
|
-
return new Error(`TileProvider "${t}" has an invalid URL: "${i}"`)}return{name:t,url:r}},t.aN=function(e,t,i,r,n){const o=function(i,r){if(i)return n(i);if(r){e.url&&r.tiles&&e.tiles&&delete e.tiles;const i=Ub(e,r,t);if(i instanceof Error)return n(i);n(null,i)}},s=function(e,t,i){if(!e)return null;if(!t&&!i)return e;i=i||e.worldview_default;const r=Object.values(e.language||{});if(0===r.length)return null;const n=Object.values(e.worldview||{});if(0===n.length)return null;const o=r.every(e=>e===t),s=n.every(e=>e===i);return o&&s?e:t in(e.language_options||{})||i in(e.worldview_options||{})?null:e.language_options&&e.worldview_options?e:null}(e.data,i,r);return s?It.frame(()=>o(null,s)):e.url?Yt(t.transformRequest(t.normalizeSourceURL(e.url,null,i,r),Gt.Source),o):It.frame(()=>{const{data:t,...i}=e;o(null,i)})},t.aO=function(e,t){const i=e.url&&!e.tiles?t.transformRequest(e.url,Gt.Source):void 0;return{request:i,options:i?Object.assign({},e,{url:i.url}):e}},t.aP=function(e,t,i){return t?Ub(e,t,i):e.tiles&&e.tiles.length>0?{tiles:e.tiles}:/* @__PURE__ */new Error('TileJSON is missing required "tiles" property')},t.aQ=function(e,t,i){const r=JSON.stringify(e.request);return e.data&&(this.deduped.entries[r]={result:[null,e.data]}),this.deduped.request(r,{type:"parseTile",renderSourceType:e.renderSourceType,zoom:e.tileZoom},t=>{const r=Jt(e.request,(e,r,n)=>{e?$t(e)?t(null,null):t(e):r&&t(null,{rawData:r,vectorTile:i?void 0:new fh(new jg(r)),responseHeaders:new Map(n.entries())})});return()=>{r.cancel(),t(null,null)}},t)},t.aR=function(e){return e?{cacheControl:e.get("cache-control"),expires:e.get("expires")}:{cacheControl:void 0,expires:void 0}},t.aS=function(e){Ft++,Ft>Pt&&(e.getActor().send("enforceCacheSizeLimit",Ct),Ft=0)},t.aT=async function(e,t){const i=jb.get(e);if(i)return i;const r=Vb.get(e);if(void 0!==r)return r;const n=import(t).catch(t=>{throw new Error(`TileProvider "${e}" failed to load: ${t instanceof Error?t.message:String(t)}`)}).then(t=>{const i=t.default;if("function"!=typeof i)throw new Error(`TileProvider "${e}" module must default-export a class`);if("function"!=typeof i.prototype.loadTile)throw new Error(`TileProvider "${e}" class must have a loadTile method`);return jb.set(e,i),i}).finally(()=>{Vb.delete(e)});return Vb.set(e,n),n},t.aU=cu,t.aV=Hv,t.aW=Kv,t.aX=Nc,t.aY=Vv,t.aZ=function(e,t){const i=document.createElement("video");i.muted=!0,i.onloadstart=function(){t(null,i)};for(let r=0;r<e.length;r++){const t=document.createElement("source");Kt(e[r])||(i.crossOrigin="Anonymous"),t.src=e[r],i.appendChild(t)}return{cancel:()=>{}}},t.a_=Dm,t.aa=class{constructor(e){this.specification=e}possiblyEvaluate(e,t){return tt(e.expression.evaluate(t))}interpolate(e,t,i){return{x:yi(e.x,t.x,i),y:yi(e.y,t.y,i),z:yi(e.z,t.z,i),azimuthal:yi(e.azimuthal,t.azimuthal,i),polar:yi(e.polar,t.polar,i)}}},t.ab=sa,t.ac=ts,t.ad=Qc,t.ae=H,t.af=E,t.ag=Ne,t.ah=fa,t.ai=Fu,t.aj=yi,t.ak=Yr,t.al=Ti,t.am=Re,t.an=He,t.ao=Ve,t.ap=class{constructor(e,t,i){this.target=e,this.parent=t,this.mapId=i,this.callbacks={},this.cancelCallbacks={},qe(["receive"],this),this.target.addEventListener("message",this.receive,!1),this.scheduler=new Nb}send(e,t,i,r,n=!1,o){const s=Math.round(1e18*Math.random()).toString(36).substring(0,10);i&&(i.metadata=o,this.callbacks[s]=i);const a=/* @__PURE__ */new Set;return this.target.postMessage({id:s,type:e,hasCallback:!!i,targetMapId:r,mustQueue:n,sourceMapId:this.mapId,data:cs(t,a)},a),{cancel:()=>{i&&delete this.callbacks[s],this.target.postMessage({id:s,type:"<cancel>",targetMapId:r,sourceMapId:this.mapId})}}}receive(e){const t=e.data;if(!t)return;const i=t.id;if(i&&(!t.targetMapId||this.mapId===t.targetMapId))if("<cancel>"===t.type){const e=this.cancelCallbacks[i];delete this.cancelCallbacks[i],e&&e.cancel()}else if(t.mustQueue||it(self)){const e=this.callbacks[i],r=this.scheduler.add(()=>this.processTask(i,t),e&&e.metadata||{type:"message"});r&&(this.cancelCallbacks[i]=r)}else this.processTask(i,t)}processTask(e,t){if(delete this.cancelCallbacks[e],"<response>"===t.type){const i=this.callbacks[e];delete this.callbacks[e],i&&(t.error?i(hs(t.error)):i(null,hs(t.data)))}else{const i=/* @__PURE__ */new Set,r=t.hasCallback?(t,r)=>{this.target.postMessage({id:e,type:"<response>",sourceMapId:this.mapId,error:t?cs(t):null,data:cs(r,i)},i)}:()=>{},n=hs(t.data);if(this.parent[t.type])this.parent[t.type](t.sourceMapId,n,r);else if(this.parent.getWorkerSource){const e=t.type.split("."),{source:i,scope:o}=n;this.parent.getWorkerSource(t.sourceMapId,{type:e[0],source:i,scope:o,uid:0})[e[1]](n,r)}else r(/* @__PURE__ */new Error(`Could not find function ${t.type}`))}}remove(){this.scheduler.remove(),this.target.removeEventListener("message",this.receive,!1)}},t.aq=class{constructor(e){this.specification=e}possiblyEvaluate(e,t){return function([e,t]){const i=tt([1,e,t]);return{x:i.x,y:i.y,z:i.z}}(e.expression.evaluate(t))}interpolate(e,t,i){return{x:yi(e.x,t.x,i),y:yi(e.y,t.y,i),z:yi(e.z,t.z,i)}}},t.ar=function(e,t,i=0,r=!0){const n=new Ie(i,i),o=e.sub(n),s=t.add(n),a=[o,new Ie(s.x,o.y),s,new Ie(o.x,s.y)];return r&&a.push(o.clone()),a},t.as=function(e,t){const i=[];for(let r=0;r<e.length;r++){const n=Ue(r-1,-1,e.length-1),o=Ue(r+1,-1,e.length-1),s=e[r],a=e[o],l=e[n].sub(s).unit(),c=a.sub(s).unit(),h=c.angleWithSep(l.x,l.y),u=l.add(c).unit().mult(-1*t/Math.sin(h/2));i.push(s.add(u))}return i},t.at=$x,t.au=Jh,t.av=function(e,t,i=0){return A(((t.x-i)*e.scale-e.x)*Yr,(t.y*e.scale-e.y)*Yr,Zc(t.z,t.y))},t.aw=X,t.ax=U,t.ay=Sh,t.az=lg,t.b=function(e){return dt.API_FONTS_REGEX.test(e)},t.b$=ac,t.b0=qe,t.b1=$w,t.b2=jg,t.b3=class{constructor(e,t,i,r,n,o){this.tileID=e,this.uid=He(),this.uses=0,this.tileSize=t,this.tileZoom=i,this.buckets={},this.expirationTime=null,this.queryPadding=0,this.hasSymbolBuckets=!1,this.hasTunnelGeometry=!1,this.hasRTLText=!1,this.dependencies={},this.isRaster=n,r&&r.style&&(this._lastUpdatedBrightness=r.style.getBrightness()),this._lastAvailableImagesCount=0,this._firstPrepareComplete=!1,this.expiredRequestCount=0,this.state="loading",r&&r.transform&&(this.projection=r.transform.projection),this.worldview=o,this._hasAppearances=null}registerFadeDuration(e){const t=e+this.timeAdded;t<It.now()||void 0!==this.fadeEndTime&&t<this.fadeEndTime||(this.fadeEndTime=t)}wasRequested(){return"errored"===this.state||"loaded"===this.state||"reloading"===this.state}get tileTransform(){return this._tileTransform||(this._tileTransform=Hx(this.tileID.canonical,this.projection)),this._tileTransform}loadVectorData(e,t,i){if(this.unloadVectorData(),this.state="loaded",e){e.featureIndex&&(this.latestFeatureIndex=e.featureIndex,e.rawTileData?(this.latestRawTileData=e.rawTileData,this.latestFeatureIndex.rawTileData=e.rawTileData):this.latestRawTileData&&(this.latestFeatureIndex.rawTileData=this.latestRawTileData)),this.collisionBoxArray=e.collisionBoxArray,this.buckets=Cb(e.buckets,t.style),this.hasSymbolBuckets=!1,this.hasTunnelGeometry=!!e.hasTunnelGeometry;for(const e in this.buckets){const t=this.buckets[e];if(t instanceof Iv){if(this.hasSymbolBuckets=!0,!i)break;t.justReloaded=!0}}if(this.hasRTLText=!1,this.hasSymbolBuckets)for(const e in this.buckets){const t=this.buckets[e];if(t instanceof Iv&&t.hasRTLText){this.hasRTLText=!0,oa();break}}this.queryPadding=0;for(const e in this.buckets){const i=this.buckets[e],r=t.style.getOwnLayer(e);if(!r)continue;const n=r.queryRadius(i)||0;this.queryPadding=Math.max(this.queryPadding,n)}e.imageAtlas&&(this.imageAtlas=t.style.imageManager.imageAtlasCache.getOrCache(e.imageAtlas)),e.glyphAtlasImage&&(this.glyphAtlasImage=e.glyphAtlasImage),e.lineAtlas&&(this.lineAtlas=e.lineAtlas),this._lastUpdatedBrightness=e.brightness}else this.collisionBoxArray=new Ol}unloadVectorData(){if(this.hasData()){for(const e in this.buckets)this.buckets[e].destroy();this.buckets={},this.imageAtlas&&(this.imageAtlas=null),this.lineAtlas&&(this.lineAtlas=null),this.imageAtlasTexture&&(this.imageAtlasTexture=null),this.glyphAtlasTexture&&this.glyphAtlasTexture.destroy(),this.lineAtlasTexture&&this.lineAtlasTexture.destroy(),this._tileBoundsBuffer&&(this._tileBoundsBuffer.destroy(),this._tileBoundsIndexBuffer.destroy(),this._tileBoundsSegments.destroy(),this._tileBoundsBuffer=null),this._tileDebugBuffer&&(this._tileDebugBuffer.destroy(),this._tileDebugSegments.destroy(),this._tileDebugBuffer=null),this._tileDebugIndexBuffer&&(this._tileDebugIndexBuffer.destroy(),this._tileDebugIndexBuffer=null),this._globeTileDebugBorderBuffer&&(this._globeTileDebugBorderBuffer.destroy(),this._globeTileDebugBorderBuffer=null),this._tileDebugTextBuffer&&(this._tileDebugTextBuffer.destroy(),this._tileDebugTextSegments.destroy(),this._tileDebugTextIndexBuffer.destroy(),this._tileDebugTextBuffer=null),this._globeTileDebugTextBuffer&&(this._globeTileDebugTextBuffer.destroy(),this._globeTileDebugTextBuffer=null),this.latestFeatureIndex=null,this.state="unloaded"}}loadModelData(e,t,i){e&&(e.resourceTiming&&(this.resourceTiming=e.resourceTiming),this.buckets=Object.assign({},this.buckets,Cb(e.buckets,t.style)),e.featureIndex&&(this.latestFeatureIndex=e.featureIndex))}getBucket(e){return this.buckets[e.fqid]}upload(e,t){for(const n in this.buckets){const i=this.buckets[n];if(i.uploadPending()){let r={},n=[],o={zoom:0,pitch:0,brightness:0,worldview:""};if(t){if(t.style){n=t.style.listImages();const e=i.layers[0],o=e.sourceLayer||"_geojsonTileLayer",s=t.style.getLayerSourceCache(e);s&&(r=s._state.getState(o,void 0))}o={zoom:t.transform.zoom||0,pitch:t.transform.pitch||0,brightness:t.style.getBrightness()||0,worldview:t.worldview||""}}i.upload(e,this.tileID.canonical,r,n,o)}}const i=e.gl,r=this.imageAtlas;!r||this.imageAtlasTexture&&r.uploaded||(this.imageAtlasTexture=null,this.imageAtlasTexture=t.style.imageManager.imageAtlasCache.getTextureForAtlas(r,e,i.RGBA8),r.uploaded=!0),this.glyphAtlasImage&&(this.glyphAtlasTexture=new Pm(e,this.glyphAtlasImage,i.R8),this.glyphAtlasImage=null),this.lineAtlas&&!this.lineAtlas.uploaded&&(this.lineAtlasTexture=new Pm(e,this.lineAtlas.image,i.R8),this.lineAtlas.uploaded=!0)}prepare(e,t,i){if(this.imageAtlas&&this.imageAtlasTexture&&t){const r=t.style.getLut(i);this.imageAtlas.patchUpdatedImages(e,this.imageAtlasTexture,i,r)}if(!t||!this.latestFeatureIndex||!this.latestFeatureIndex.rawTileData)return;const r=t.style.getBrightness(),n=t.style.listImages(),o=n.length,s=t.style._changes.getUpdatedPaintProperties(),a=Object.keys(this.buckets).some(e=>this.buckets[e].layers.some(e=>s.has(e.fqid))),l=Object.keys(this.buckets).some(e=>this.buckets[e].layers.some(e=>e.hasTransition&&e.hasTransition())),c=this._firstPrepareComplete&&o!==this._lastAvailableImagesCount;null===this._hasAppearances&&(this._hasAppearances=this.hasAppearances(t));const h=this._lastUpdatedBrightness!==r;this._lastAvailableImagesCount=o,this._firstPrepareComplete=!0,(this._lastUpdatedBrightness||r||this._hasAppearances||a||l||c)&&(!(this._hasAppearances||a||l||c)&&this._lastUpdatedBrightness&&r&&Math.abs(this._lastUpdatedBrightness-r)<.001||(this.updateBuckets(t,h,void 0,c||a||l,s,n),this._lastUpdatedBrightness=r))}evaluateQueryRenderedFeaturePadding(){let e=0;for(const t in this.buckets){const i=this.buckets[t];i.evaluateQueryRenderedFeaturePadding&&(e=Math.max(e,i.evaluateQueryRenderedFeaturePadding()))}return e}queryRenderedFeatures(e,t,i,r,n,o,s){if(!this.latestFeatureIndex||!this.latestFeatureIndex.rawTileData&&!this.latestFeatureIndex.is3DTile)return{};const a=this.evaluateQueryRenderedFeaturePadding(),l=function(e,t){const i=x([],[.5*e.width,.5*-e.height,1]);return p(i,i,[1,-1,0]),d(i,i,e.calculateProjMatrix(t.toUnwrapped())),Float32Array.from(i)}(n,this.tileID);return this.latestFeatureIndex.query(e,{tilespaceGeometry:t,pixelPosMatrix:l,transform:r,availableImages:i,tileTransform:this.tileTransform,worldview:this.worldview,queryRadius:a,scope:s})}querySourceFeatures(e,t){const i=this.latestFeatureIndex;if(!i||!i.rawTileData)return;const r=i.loadVTLayers(),n=t?t.sourceLayer:"",o=r._geojsonTileLayer||r[n];if(!o)return;const s=Ta(t&&t.filter),{z:a,x:l,y:c}=this.tileID.canonical,h={z:a,x:l,y:c};for(let u=0;u<o.length;u++){const t=o.feature(u);if(s.needGeometry){const e=lh(t,!0);if(!s.filter(new sa(this.tileID.overscaledZ,{worldview:this.worldview}),e,this.tileID.canonical))continue}else if(!s.filter(new sa(this.tileID.overscaledZ,{worldview:this.worldview}),t))continue;const r=new yb(t,a,l,c,i.getId(t,n));r.tile=h,e.push(r)}}loaded(){return"loaded"===this.state||"errored"===this.state}hasData(){return"loaded"===this.state||"reloading"===this.state||"expired"===this.state}patternsLoaded(){return!!this.imageAtlas&&!!this.imageAtlas.patternPositions.size}setExpiryData(e){const t=this.expirationTime;if(e.cacheControl){const t=rt(e.cacheControl);t["max-age"]&&(this.expirationTime=Date.now()+1e3*t["max-age"])}else e.expires&&(this.expirationTime=new Date(e.expires).getTime());if(this.expirationTime){const e=Date.now();let i=!1;if(this.expirationTime>e)i=!1;else if(t)if(this.expirationTime<t)i=!0;else{const r=this.expirationTime-t;r?this.expirationTime=e+Math.max(r,3e4):i=!0}else i=!0;i?(this.expiredRequestCount++,this.state="expired"):this.expiredRequestCount=0}}getExpiryTimeout(){if(this.expirationTime)return this.expiredRequestCount?1e3*(1<<Math.min(this.expiredRequestCount-1,31)):Math.min(this.expirationTime-Date.now(),Math.pow(2,31)-1)}refreshFeatureState(e,t){if(!this.latestFeatureIndex||!this.latestFeatureIndex.rawTileData&&!this.latestFeatureIndex.is3DTile||!e)return;const i=e.style.listImages();this.updateBuckets(e,!1,t,void 0,void 0,i)}hasAppearances(e){for(const t in this.buckets)if(e.style.hasLayer(t)&&this.buckets[t].layers.some(e=>e.appearances&&e.appearances.length>0))return!0;return!1}updateBuckets(e,t,i,r,n,o){if(!this.latestFeatureIndex)return;if(!e.style)return;const s=o||e.style.listImages(),a=e.style.getBrightness(),l=n||/* @__PURE__ */new Set;for(const c in this.buckets){if(!e.style.hasLayer(c))continue;const n=this.buckets[c],o=n.layers[0],h=o.sourceLayer||"_geojsonTileLayer",u=e.style.getLayerSourceCache(o),d=n.layers.some(e=>l.has(e.fqid)),p=(r||d)&&n instanceof Iv?e.style.getOwnLayer(c):void 0;let f=i&&i[h]||{};u&&!i&&(f=u._state.getState(h,void 0));const m=this.imageAtlas?Object.fromEntries(this.imageAtlas.patternPositions):{},_=Object.keys(f).length>0&&!t;n.hasAppearances=n.layers.some(e=>e.appearances&&e.appearances.length>0);const g=_?n.stateDependentLayers:n.layers;if(_&&0!==n.stateDependentLayers.length||t||d||r){const i=this.latestFeatureIndex.loadVTLayers()[h];if(n.update(f,i,s,m,g,t,a,this.tileID.canonical),(r||d)&&(!t||t&&n instanceof Iv&&(!n.text.uboBinder||n.text.uboBinder.isLightConstant||!n.icon.uboBinder||n.icon.uboBinder.isLightConstant))&&n instanceof Iv&&p&&"symbol"===p.type){const e=n;e.text&&e.text.uboBinder&&e.text.uboBinder.updateDynamicExpressions(p,i,this.tileID.canonical,s,f,a),e.icon&&e.icon.uboBinder&&e.icon.uboBinder.updateDynamicExpressions(p,i,this.tileID.canonical,s,f,a)}if(n instanceof Iv){const t=n,i=e.context;t.text&&t.text.uboBinder&&t.text.uboBinder.upload(i),t.icon&&t.icon.uboBinder&&t.icon.uboBinder.upload(i)}}if(_&&0!==n.stateDependentLayers.length||t||n.hasAppearances){const t={zoom:e.transform.zoom,pitch:e.transform.pitch,brightness:e.style.getBrightness()||0,worldview:e.worldview},i=n.updateAppearances(this.tileID.canonical,f,s,t,e.imageManager,_&&0!==n.stateDependentLayers.length);if(i&&i.hasUboChanges){const t=e.context;n instanceof Iv&&n.text&&n.text.uboBinder&&n.text.uboBinder.upload(t),n instanceof Iv&&n.icon&&n.icon.uboBinder&&n.icon.uboBinder.upload(t)}}(n instanceof ng||n instanceof Mp)&&e._terrain&&e._terrain.enabled&&u&&n.uploadPending()&&e._terrain._clearRenderCacheForTile(u.id,this.tileID);const y=e&&e.style&&e.style.getOwnLayer(c);y&&(this.queryPadding=Math.max(this.queryPadding,y.queryRadius(n)||0))}}holdingForFade(){return void 0!==this.symbolFadeHoldUntil}symbolFadeFinished(){return!this.symbolFadeHoldUntil||this.symbolFadeHoldUntil<It.now()}clearFadeHold(){this.symbolFadeHoldUntil=void 0}setHoldDuration(e){this.symbolFadeHoldUntil=It.now()+e}setTexture(e,t){const i=t.context,r=i.gl;this.texture=this.texture||t.getTileTexture(e.width),this.texture&&this.texture instanceof Pm?this.texture.update(e):(this.texture=new Pm(i,e,r.RGBA8,{useMipmap:!0}),this.texture.bind(r.LINEAR,r.CLAMP_TO_EDGE))}setDependencies(e,t){const i={};for(const r of t)i[r]=!0;this.dependencies[e]=i}hasDependency(e,t){for(const i of e){const e=this.dependencies[i];if(e)for(const i of t)if(e[i])return!0}return!1}clearQueryDebugViz(){}_makeDebugTileBoundsBuffers(e,t){if(!t||"mercator"===t.name||this._tileDebugBuffer)return;const i=ah(kb,this.tileID.canonical,this.tileTransform)[0],r=new Ka,n=new Pl;for(let o=0;o<i.length;o++){const{x:e,y:t}=i[o];r.emplaceBack(e,t),n.emplaceBack(o)}n.emplaceBack(0),this._tileDebugIndexBuffer=e.createIndexBuffer(n),this._tileDebugBuffer=e.createVertexBuffer(r,fu.members),this._tileDebugSegments=Jl.simpleSegment(0,0,r.length,n.length)}_makeTileBoundsBuffers(e,t){if(this._tileBoundsBuffer||!t||"mercator"===t.name)return;const i=ah(kb,this.tileID.canonical,this.tileTransform)[0];let r,n;if(this.isRaster){const e=function(e,t){const i=Hx(e,t),r=Math.pow(2,e.z);for(let c=0;c<Db;c++)for(let n=0;n<Db;n++){const o=$c((e.x+(n+Ob(n))/Pb)/r),s=qc((e.y+(c+Ob(c))/Pb)/r),a=t.project(o,s),l=c*Db+n;zb[2*l+0]=Math.round((a.x*i.scale-i.x)*Yr),zb[2*l+1]=Math.round((a.y*i.scale-i.y)*Yr)}Lb.fill(0),Fb.fill(0);for(let c=2045;c>=0;c--){const e=4*c,t=Rb[e+0],i=Rb[e+1],r=Rb[e+2],n=Rb[e+3],o=t+r>>1,s=i+n>>1,a=o+s-i,l=s+t-o,h=i*Db+t,u=n*Db+r,d=s*Db+o,p=Math.hypot((zb[2*h+0]+zb[2*u+0])/2-zb[2*d+0],(zb[2*h+1]+zb[2*u+1])/2-zb[2*d+1])>=16;Lb[d]=Lb[d]||(p?1:0),c<1022&&(Lb[d]=Lb[d]||Lb[(i+l>>1)*Db+(t+a>>1)]||Lb[(n+l>>1)*Db+(r+a>>1)])}const n=new el,o=new vl;let s=0;function a(e,t){const i=t*Db+e;return 0===Fb[i]&&(n.emplaceBack(zb[2*i+0],zb[2*i+1],e*Yr/Pb,t*Yr/Pb),Fb[i]=++s),Fb[i]-1}function l(e,t,i,r,n,s){const c=e+i>>1,h=t+r>>1;if(Math.abs(e-n)+Math.abs(t-s)>1&&Lb[h*Db+c])l(n,s,e,t,c,h),l(i,r,n,s,c,h);else{const l=a(e,t),c=a(i,r),h=a(n,s);o.emplaceBack(l,c,h)}}return l(0,0,Pb,Pb,Pb,0),l(Pb,Pb,0,0,0,Pb),{vertices:n,indices:o}}(this.tileID.canonical,t);r=e.vertices,n=e.indices}else{r=new el,n=new vl;for(const{x:t,y:n}of i)r.emplaceBack(t,n,0,0);const e=hd(r.int16.subarray(0,4*r.length),void 0,4);for(let t=0;t<e.length;t+=3)n.emplaceBack(e[t],e[t+1],e[t+2])}this._tileBoundsBuffer=e.createVertexBuffer(r,Bv.members),this._tileBoundsIndexBuffer=e.createIndexBuffer(n),this._tileBoundsSegments=Jl.simpleSegment(0,0,r.length,n.length)}_makeGlobeTileDebugBuffers(e,t){const i=t.projection;if(!i||"globe"!==i.name||t.freezeTileCoverage)return;const r=this.tileID.canonical,n=Pu(wu(r,t)),o=Fu(t.zoom);let s;o>0&&(s=u(new Float64Array(16),t.globeMatrix)),this._makeGlobeTileDebugBorderBuffer(e,r,t,n,s,o),this._makeGlobeTileDebugTextBuffer(e,r,t,n,s,o)}_globePoint(e,t,i,r,n,o,s){let a=Au(e,t,i);if(o){const n=1<<i.z,l=jc(r.center.lng),c=Gc(r.center.lat),h=(i.x+.5)/n-l;let u=0;h>.5?u=-1:h<-.5&&(u=1);let d=(e/Yr+i.x)/n+u,p=(t/Yr+i.y)/n;d=(d-l)*r._pixelsPerMercatorPixel+l,p=(p-c)*r._pixelsPerMercatorPixel+c;const f=[d*r.worldSize,p*r.worldSize,0];H(f,f,o),a=bu(a,f,s)}return H(a,a,n)}_makeGlobeTileDebugBorderBuffer(e,t,i,r,n,o){const s=new Ka,a=new Pl,l=new Qa,c=(e,c,h,u,d)=>{const p=(h-e)/(d-1),f=(u-c)/(d-1),m=s.length;for(let _=0;_<d;_++){const h=e+_*p,u=c+_*f;s.emplaceBack(h,u);const d=this._globePoint(h,u,t,i,r,n,o);l.emplaceBack(d[0],d[1],d[2]),a.emplaceBack(m+_)}},h=Yr;c(0,0,h,0,16),c(h,0,h,h,16),c(h,h,0,h,16),c(0,h,0,0,16),this._tileDebugIndexBuffer=e.createIndexBuffer(a),this._tileDebugBuffer=e.createVertexBuffer(s,fu.members),this._globeTileDebugBorderBuffer=e.createVertexBuffer(l,pu.members),this._tileDebugSegments=Jl.simpleSegment(0,0,s.length,a.length)}_makeGlobeTileDebugTextBuffer(e,t,i,r,n,o){const s=new Ka,a=new vl,l=new Qa,c=25;a.reserve(32),s.reserve(c),l.reserve(c);const h=(e,t)=>c*e+t;for(let u=0;u<c;u++){const e=2048*u;for(let a=0;a<c;a++){const c=2048*a;s.emplaceBack(c,e);const h=this._globePoint(c,e,t,i,r,n,o);l.emplaceBack(h[0],h[1],h[2])}}for(let u=0;u<4;u++)for(let e=0;e<4;e++){const t=h(u,e),i=h(u,e+1),r=h(u+1,e),n=h(u+1,e+1);a.emplaceBack(t,i,r),a.emplaceBack(r,i,n)}this._tileDebugTextIndexBuffer=e.createIndexBuffer(a),this._tileDebugTextBuffer=e.createVertexBuffer(s,fu.members),this._globeTileDebugTextBuffer=e.createVertexBuffer(l,pu.members),this._tileDebugTextSegments=Jl.simpleSegment(0,0,c,32)}destroy(e=!0){for(const t in this.buckets)this.buckets[t].destroy(e);this.buckets={},this.imageAtlas&&(this.imageAtlas=null),this.lineAtlas&&(this.lineAtlas=null),this.imageAtlasTexture&&delete this.imageAtlasTexture,this.glyphAtlasTexture&&(this.glyphAtlasTexture.destroy(),delete this.glyphAtlasTexture),this.lineAtlasTexture&&(this.lineAtlasTexture.destroy(),delete this.lineAtlasTexture),this._tileBoundsBuffer&&(this._tileBoundsBuffer.destroy(),this._tileBoundsIndexBuffer.destroy(),this._tileBoundsSegments.destroy(),this._tileBoundsBuffer=null),this._tileDebugBuffer&&(this._tileDebugBuffer.destroy(),this._tileDebugSegments.destroy(),this._tileDebugBuffer=null),this._tileDebugIndexBuffer&&(this._tileDebugIndexBuffer.destroy(),this._tileDebugIndexBuffer=null),this._globeTileDebugBorderBuffer&&(this._globeTileDebugBorderBuffer.destroy(),this._globeTileDebugBorderBuffer=null),this._tileDebugTextBuffer&&(this._tileDebugTextBuffer.destroy(),this._tileDebugTextSegments.destroy(),this._tileDebugTextIndexBuffer.destroy(),this._tileDebugTextBuffer=null),this._globeTileDebugTextBuffer&&(this._globeTileDebugTextBuffer.destroy(),this._globeTileDebugTextBuffer=null),e&&this.texture&&this.texture instanceof Pm&&(this.texture.destroy(),delete this.texture),this.emissiveTexture&&this.emissiveTexture instanceof Pm&&(this.emissiveTexture.destroy(),delete this.emissiveTexture),this.hillshadeFBO&&(this.hillshadeFBO.destroy(),delete this.hillshadeFBO),this.dem&&delete this.dem,this.neighboringTiles&&delete this.neighboringTiles,this.demTexture&&(this.demTexture.destroy(),delete this.demTexture),this.rasterParticleState&&(this.rasterParticleState.destroy(),delete this.rasterParticleState),this.latestFeatureIndex=null,this.state="unloaded"}},t.b4=Jt,t.b5=$t,t.b6=function(e,t){const i=[];for(const r in e)r in t||i.push(r);return i},t.b7=Bb,t.b8=["type","source","source-layer","minzoom","maxzoom","filter","layout"],t.b9=Ee,t.bA=h,t.bB=p,t.bC=Lg,t.bD=qp,t.bE=nf,t.bF=tf,t.bG=rf,t.bH=lh,t.bI=K,t.bJ=fy,t.bK=yx,t.bL=Dx,t.bM=Xw,t.bN=L,t.bO=J,t.bP=re,t.bQ=function(e,t,i){i*=.5;var r=t[0],n=t[1],o=t[2],s=t[3],a=Math.sin(i),l=Math.cos(i);return e[0]=r*l+n*a,e[1]=n*l-r*a,e[2]=o*l+s*a,e[3]=s*l-o*a,e},t.bR=ne,t.bS=st,t.bT=x,t.bU=function(e,t){return e[0]=-t[0],e[1]=-t[1],e[2]=-t[2],e[3]=t[3],e},t.bV=w,t.bW=function(e,t,i,r,n){var o=1/Math.tan(t/2);if(e[0]=o/i,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=o,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=-1,e[12]=0,e[13]=0,e[15]=0,null!=n&&n!==1/0){var s=1/(r-n);e[10]=(n+r)*s,e[14]=2*n*r*s}else e[10]=-1,e[14]=-2*r;return e},t.bX=function(e,t,i,r,n,o,s){var a=1/(t-i),l=1/(r-n),c=1/(o-s);return e[0]=-2*a,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=-2*l,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[10]=2*c,e[11]=0,e[12]=(t+i)*a,e[13]=(n+r)*l,e[14]=(s+o)*c,e[15]=1,e},t.bY=Hc,t.bZ=qc,t.b_=function(e,t,i){e[4*t+0]=i[0],e[4*t+1]=i[1],e[4*t+2]=i[2],e[4*t+3]=i[3]},t.ba=u,t.bb=c,t.bc=g,t.bd=l,t.be=function(e,t){const{x:i,y:r}=e.point,n=Lu(i,r,e.worldSize/e._pixelsPerMercatorPixel,0,0);return d(n,n,Du(vu(t)))},t.bf=n,t.bg=Z,t.bh=O,t.bi=F,t.bj=j,t.bk=V,t.bl=Iy,t.bm=ry,t.bn=Sy,t.bo=function(e,t,i,r,n){const o=5*t+2;e.float32[o+0]=i,e.float32[o+1]=r,e.float32[o+2]=n},t.bp=vv,t.bq=os,t.br=de,t.bs=_e,t.bt=fe,t.bu=we,t.bv=Ue,t.bw=function(e,t,i,n){var o=new r(4);return o[0]=e,o[1]=t,o[2]=i,o[3]=n,o},t.bx=class{isDataAvailableAtPoint(e){const t=this._source();if(this.isUsingMockSource()||!t||e.y<0||e.y>1)return!1;const i=t.getSource().maxzoom,r=1<<i,n=Math.floor(e.x),o=Math.floor((e.x-n)*r),s=Math.floor(e.y*r),a=this.findDEMTileFor(new cu(i,n,i,o,s));return!(!a||!a.dem)}getAtPointOrZero(e,t=0){return this.getAtPoint(e,t)||0}getAtPoint(e,t,i=!0){if(this.isUsingMockSource())return null;t??=null;const r=this._source();if(!r)return t;if(e.y<0||e.y>1)return t;const n=r.getSource().maxzoom,o=1<<n,s=Math.floor(e.x),a=e.x-s,l=new cu(n,s,n,Math.floor(a*o),Math.floor(e.y*o)),c=this.findDEMTileFor(l);if(!c||!c.dem)return t;const h=c.dem,u=1<<c.tileID.canonical.z,d=(a*u-c.tileID.canonical.x)*h.dim,p=(e.y*u-c.tileID.canonical.y)*h.dim,f=Math.floor(d),m=Math.floor(p);return(i?this.exaggeration():1)*yi(yi(h.get(f,m),h.get(f,m+1),p-m),yi(h.get(f+1,m),h.get(f+1,m+1),p-m),d-f)}static getAtTileOffset(e,t,i,r){const n=1<<e.canonical.z;return r?r.pointElevation(t):i?i.getAtPointOrZero(new Qc(e.wrap+(e.canonical.x+t.x/Yr)/n,(e.canonical.y+t.y/Yr)/n)):0}static getAtTileOffsetFunc(e,t,i,r){return(n,o,s)=>{const a=this.getAtTileOffset(e,n,o,s),l=r.upVector(e.canonical,n.x,n.y);return L(l,l,a*r.upVectorScale(e.canonical,t,i).metersToTile),l}}getForTilePoints(e,t,i,r){if(this.isUsingMockSource())return!1;const n=nb.create(this,e,r);return!!n&&(t.forEach(e=>{e[2]=this.exaggeration()*n.getElevationAt(e[0],e[1],i,!0)}),!0)}getMinMaxForTile(e){if(this.isUsingMockSource())return null;const t=this.findDEMTileFor(e);if(!t||!t.dem)return null;const i=t.dem.tree,r=t.tileID,n=1<<e.canonical.z-r.canonical.z;let o=e.canonical.x/n-r.canonical.x,s=e.canonical.y/n-r.canonical.y,a=0;for(let l=0;l<e.canonical.z-r.canonical.z&&!i.leaves[a];l++){o*=2,s*=2;const e=2*Math.floor(s)+Math.floor(o);a=i.childOffsets[a]+e,o%=1,s%=1}return{min:this.exaggeration()*i.minimums[a],max:this.exaggeration()*i.maximums[a]}}getMinElevationBelowMSL(){throw new Error("Pure virtual method called.")}raycast(e,t,i){throw new Error("Pure virtual method called.")}pointCoordinate(e){throw new Error("Pure virtual method called.")}_source(){throw new Error("Pure virtual method called.")}isUsingMockSource(){throw new Error("Pure virtual method called.")}exaggeration(){throw new Error("Pure virtual method called.")}findDEMTileFor(e){throw new Error("Pure virtual method called.")}get visibleDemTiles(){throw new Error("Getter must be implemented in subclass.")}getMinMaxForVisibleTiles(){const e=this.visibleDemTiles;if(0===e.length)return null;let t=!1,i=Number.MAX_VALUE,r=Number.MIN_VALUE;for(const n of e){const e=this.getMinMaxForTile(n.tileID);e&&(i=Math.min(i,e.min),r=Math.max(r,e.max),t=!0)}return t?{min:i,max:r}:null}},t.by=Wf,t.bz=Nh,t.c=gt,t.c$=Am,t.c0=hc,t.c1=lc,t.c2=cc,t.c3=fc,t.c4=dv,t.c5=function(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]&&e[3]===t[3]},t.c6=W,t.c7=function(e){var t=e[0],i=e[1],r=e[2],n=e[3];return Math.sqrt(t*t+i*i+r*r+n*n)},t.c8=ce,t.c9=q,t.cA=Vm,t.cB=T,t.cC=Nm,t.cD=function(e){const t=Nm(e,!0);return n([],[t[0],t[1],t[4],t[5]])},t.cE=f,t.cF=Ih,t.cG=m,t.cH=function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e[6]=t[6],e[7]=t[7],e[8]=t[8],e[9]=t[9],e[10]=t[10],e[11]=t[11],e[12]=t[12],e[13]=t[13],e[14]=t[14],e[15]=t[15],e},t.cI=function(e){const{x:t,y:i}=e.point,{lng:r,lat:n}=e._center;return Lu(t,i,e.worldSize,r,n)},t.cJ=D,t.cK=y,t.cL=ze,t.cM=Kh,t.cN=5,t.cO=function(e,t,i){let r=0;for(let n=0;n<2;++n){const i=0;e[n]>i&&(r+=(e[n]-i)*(e[n]-i)),t[n]<i&&(r+=(i-t[n])*(i-t[n]))}return r},t.cP=function(e){return e*e*e*e*e},t.cQ=Vc,t.cR=45,t.cS=dc,t.cT=function(e,t,i){const r=Math.sqrt(e*e+t*t+i*i),n=r>0?Math.acos(i/r)*Me:0;let o=0!==e||0!==t?Math.atan2(-t,-e)*Me+90:0;return o<0&&(o+=360),[r,o,n]},t.cU=A,t.cV=tt,t.cW=Kc,t.cX=C,t.cY=Rh,t.cZ=P,t.c_=function(e){return[Math.pow(e[0],1/2.2),Math.pow(e[1],1/2.2),Math.pow(e[2],1/2.2)]},t.ca=lu,t.cb=3,t.cc=2,t.cd=7,t.ce=6,t.cf=G,t.cg=S,t.ch=I,t.ci=0,t.cj=1,t.ck=4,t.cl=5,t.cm=hu,t.cn=Dh,t.co=Um,t.cp=au,t.cq=Su,t.cr=function(e,t,i,r,n,o,s,a,l){if("globe"===l.name)return Su(e,t,new au(i,r,n),!1);const c=Hx({z:i,x:r,y:n},l);return new Rh([(o+c.x/c.scale)*t,t*(c.y/c.scale),s],[(o+c.x2/c.scale)*t,t*(c.y2/c.scale),a])},t.cs=function(e,t,i){return e[0]=Math.min(t[0],i[0]),e[1]=Math.min(t[1],i[1]),e[2]=Math.min(t[2],i[2]),e[3]=Math.min(t[3],i[3]),e},t.ct=function(e,t,i){return e[0]=Math.max(t[0],i[0]),e[1]=Math.max(t[1],i[1]),e[2]=Math.max(t[2],i[2]),e[3]=Math.max(t[3],i[3]),e},t.cu=function(e){return Le[Math.round((e+45+360)%360/90)%4]},t.cv=Wc,t.cw=Q,t.cx=6,t.cy=function(e){const t=h(new Float64Array(16));d(t,e.pixelMatrix,e.globeMatrix);const i=[0,zc,0],r=[0,Lc,0];return H(i,i,t),H(r,r,t),[i[0]>0&&i[0]<=e.width&&i[1]>0&&i[1]<=e.height&&!Bu(e,new Nc(e.center.lat,90)),r[0]>0&&r[0]<=e.width&&r[1]>0&&r[1]<=e.height&&!Bu(e,new Nc(e.center.lat,-90))]},t.cz=function(e,t){const{scale:i}=e.tileTransform,r=i*Yr/(e.tileSize*Math.pow(2,t.zoom-e.tileID.overscaledZ+e.tileID.canonical.z)),n=t.inverseAdjustmentMatrix;return new Float32Array([n[0]*r,n[1]*r,n[2]*r,n[3]*r])},t.d=function(e){return dt.API_TILEJSON_REGEX.test(e)},t.d$=$e,t.d0=x_,t.d1=Qm,t.d2=Vh,t.d3=class{static calculate(e,t,i){const r=/* @__PURE__ */new Set,n=/* @__PURE__ */new Map,o=/* @__PURE__ */new Set,s=/* @__PURE__ */new Set;for(const l of Object.values(e))for(const[e,i]of Object.entries(l.floors)){o.add(e),i.isDefault&&s.add(e),i.conflicts&&n.set(e,i.conflicts);const a=e===t,l=i.connections&&t&&i.connections.has(t);(a||l)&&r.add(e)}const a=e=>{const t=n.get(e)||/* @__PURE__ */new Set;for(const i of r)if((n.get(i)||/* @__PURE__ */new Set).has(e)||t.has(i))return!0;return!1};if(i)for(const l of i)o.has(l)&&(a(l)||r.add(l));for(const l of s)r.has(l)||a(l)||r.add(l);return r}},t.d4=ex,t.d5=Qy,t.d6=qt,t.d7=function(){return{API_URL:dt.API_URL,DRACO_URL:dt.DRACO_URL,MESHOPT_URL:dt.MESHOPT_URL,MESHOPT_SIMD_URL:dt.MESHOPT_SIMD_URL,BUILDING_GEN_URL:dt.BUILDING_GEN_URL}},t.d8=Qs,t.d9=At,t.dA=fu,t.dB=Jl,t.dC=nd,t.dD=mu,t.dE=Ka,t.dF=vl,t.dG=function(e,t){return[Math.pow(e[0],2.2)*t,Math.pow(e[1],2.2)*t,Math.pow(e[2],2.2)*t]},t.dH=o,t.dI=function(e,t){var i=Math.sin(t),r=Math.cos(t);return e[0]=r,e[1]=i,e[2]=0,e[3]=-i,e[4]=r,e[5]=0,e[6]=0,e[7]=0,e[8]=1,e},t.dJ=$,t.dK=zu,t.dL=ct,t.dM=ht,t.dN=jv,t.dO=function(e,t){const i=[0,0,0];return H(i,i,Pu(vu(t.canonical))),H(i,i,e),i},t.dP=e=>({u_matrix:new fc(e),u_texsize:new cc(e),u_pixels_to_tile_units:new mc(e),u_device_pixel_ratio:new lc(e),u_width_scale:new lc(e),u_floor_width_scale:new lc(e),u_image:new ac(e),u_units_to_pixels:new cc(e),u_tile_units_to_pixels:new lc(e),u_alpha_discard_threshold:new lc(e),u_trim_offset:new cc(e),u_trim_fade_range:new cc(e),u_trim_gradient_mix_range:new cc(e),u_trim_color:new dc(e),u_zbias_factor:new lc(e),u_tile_to_meter:new lc(e),u_ground_shadow_factor:new hc(e),u_pattern_transition:new lc(e)}),t.dQ=e=>({u_matrix:new fc(e),u_pixels_to_tile_units:new mc(e),u_device_pixel_ratio:new lc(e),u_width_scale:new lc(e),u_floor_width_scale:new lc(e),u_units_to_pixels:new cc(e),u_dash_image:new ac(e),u_gradient_image:new ac(e),u_image_height:new lc(e),u_texsize:new cc(e),u_tile_units_to_pixels:new lc(e),u_alpha_discard_threshold:new lc(e),u_trim_offset:new cc(e),u_trim_fade_range:new cc(e),u_trim_gradient_mix_range:new cc(e),u_trim_color:new dc(e),u_zbias_factor:new lc(e),u_tile_to_meter:new lc(e),u_ground_shadow_factor:new hc(e)}),t.dR=e=>({u_camera_to_center_distance:new lc(e),u_extrude_scale:new mc(e),u_device_pixel_ratio:new lc(e),u_matrix:new fc(e),u_inv_rot_matrix:new fc(e),u_merc_center:new cc(e),u_tile_id:new hc(e),u_zoom_transition:new lc(e),u_up_dir:new hc(e),u_emissive_strength:new lc(e)}),t.dS=yl,t.dT=Cg,t.dU=class{constructor(e,t,i,r){this.context=e,this.format=r,this.size=i,this.texture=e.gl.createTexture();const[n,o,s]=this.size,{gl:a}=e;a.bindTexture(a.TEXTURE_3D,this.texture),e.pixelStoreUnpackFlipY.set(!1),e.pixelStoreUnpack.set(1),e.pixelStoreUnpackPremultiplyAlpha.set(!1),"data"in t&&t.data&&a.texImage3D(a.TEXTURE_3D,0,this.format,n,o,s,0,Mm(this.format),Cm(this.format),t.data)}bind(e,t){const{context:i}=this,{gl:r}=i;r.bindTexture(r.TEXTURE_3D,this.texture),e!==this.minFilter&&(r.texParameteri(r.TEXTURE_3D,r.TEXTURE_MAG_FILTER,e),r.texParameteri(r.TEXTURE_3D,r.TEXTURE_MIN_FILTER,e),this.minFilter=e),t!==this.wrapS&&(r.texParameteri(r.TEXTURE_3D,r.TEXTURE_WRAP_S,t),r.texParameteri(r.TEXTURE_3D,r.TEXTURE_WRAP_T,t),this.wrapS=t)}destroy(){const{gl:e}=this.context;e.deleteTexture(this.texture),this.texture=null}},t.dV=ju,t.dW=(e,t,i,r,n,o)=>{const s=e.transform,a="globe"===s.projection.name;let l;if("map"===o.paint.get("circle-pitch-alignment"))if(a){const e=zu(s.zoom,t.canonical)*s._pixelsPerMercatorPixel;l=Float32Array.from([e,0,0,e])}else l=s.calculatePixelsToTileUnitsMatrix(i);else l=new Float32Array([s.pixelsToGLUnits[0],0,0,s.pixelsToGLUnits[1]]);const c={u_camera_to_center_distance:e.transform.getCameraToCenterDistance(s.projection),u_matrix:e.translatePosMatrix(t.projMatrix,i,o.paint.get("circle-translate"),o.paint.get("circle-translate-anchor")),u_device_pixel_ratio:It.devicePixelRatio,u_extrude_scale:l,u_inv_rot_matrix:Vu,u_merc_center:[0,0],u_tile_id:[0,0,0],u_zoom_transition:0,u_up_dir:[0,0,0],u_emissive_strength:o.paint.get("circle-emissive-strength")};if(a){c.u_inv_rot_matrix=r,c.u_merc_center=n,c.u_tile_id=[t.canonical.x,t.canonical.y,1<<t.canonical.z],c.u_zoom_transition=Fu(s.zoom);const e=n[0]*Yr,i=n[1]*Yr;c.u_up_dir=s.projection.upVector(new au(0,0,0),e,i)}return c},t.dX=dg,t.dY=Wi,t.dZ=(e,t,i,r,n,o,s,a,l,c)=>{const h=e.transform,u=h.pitch<15?cg(.07,.7,ke((14-h.zoom)/5,0,1)):.07,d="none"===i.paint.get("line-trim-color-use-theme").constantOr("default");return{u_matrix:ug(e,t,i,r),u_texsize:t.imageAtlasTexture?t.imageAtlasTexture.size:[0,0],u_pixels_to_tile_units:h.calculatePixelsToTileUnitsMatrix(t),u_device_pixel_ratio:n,u_width_scale:o,u_floor_width_scale:s,u_image:0,u_tile_units_to_pixels:hg(t,h),u_units_to_pixels:[1/h.pixelsToGLUnits[0],1/h.pixelsToGLUnits[1]],u_alpha_discard_threshold:0,u_trim_offset:a,u_trim_fade_range:i.paint.get("line-trim-fade-range"),u_trim_gradient_mix_range:[1,1],u_trim_color:i.paint.get("line-trim-color").toPremultipliedRenderColor(d?null:i.lut).toArray01(),u_zbias_factor:u,u_tile_to_meter:Kc(t.tileID.canonical,0),u_ground_shadow_factor:l,u_pattern_transition:c}},t.d_=(e,t,i,r,n,o,s,a,l,c)=>{const h=e.transform,u=h.calculatePixelsToTileUnitsMatrix(t),d="none"===i.paint.get("line-trim-color-use-theme").constantOr("default"),p=h.pitch<15?cg(.07,.7,ke((14-h.zoom)/5,0,1)):.07;return{u_matrix:ug(e,t,i,r),u_pixels_to_tile_units:u,u_device_pixel_ratio:o,u_width_scale:s,u_floor_width_scale:a,u_units_to_pixels:[1/h.pixelsToGLUnits[0],1/h.pixelsToGLUnits[1]],u_dash_image:0,u_gradient_image:1,u_image_height:n,u_texsize:pg(i)&&t.lineAtlasTexture?t.lineAtlasTexture.size:[0,0],u_tile_units_to_pixels:hg(t,e.transform),u_alpha_discard_threshold:0,u_trim_offset:l,u_trim_fade_range:i.paint.get("line-trim-fade-range"),u_trim_gradient_mix_range:[1,1],u_trim_color:i.paint.get("line-trim-color").toPremultipliedRenderColor(d?null:i.lut).toArray01(),u_zbias_factor:p,u_tile_to_meter:Kc(t.tileID.canonical,0),u_ground_shadow_factor:c}},t.da=li,t.db=Xe,t.dc=function(e){const t=e.indexOf(Fa);return t>=0?e.slice(0,t):e},t.dd=q_,t.de=function(e){return e.includes(Fa)},t.df=function(e){const t=e.lastIndexOf(Fa);return t>=0?e.slice(t+1):""},t.dg=function(e){const t=[],i=e.id;return void 0===i&&t.push({message:`layers.${i}: missing required property "id"`}),void 0===e.render&&t.push({message:`layers.${i}: missing required method "render"`}),e.renderingMode&&"2d"!==e.renderingMode&&"3d"!==e.renderingMode&&t.push({message:`layers.${i}: property "renderingMode" must be either "2d" or "3d"`}),t},t.dh=function(e,t,i,r){return"custom"===e.type?new Qv(e,t):new wb[e.type](e,t,i,r)},t.di=We,t.dj=Ta,t.dk=Ba,t.dl=class extends yb{constructor(e,t){super(e._vectorTileFeature,e._z,e._x,e._y,e.id),e.state&&(this.state=Object.assign({},e.state)),this.target=t.target,this.namespace=t.namespace,t.properties&&(this.properties=t.properties),this.target&&("featuresetId"in this.target&&!this.target.importId||"layerId"in this.target)&&(this.source=e.source,this.sourceLayer=e.sourceLayer,this.layer=e.layer)}toJSON(){const e=super.toJSON();return e.target=this.target,e.namespace=this.namespace,e}},t.dm=ta,t.dn=function(e){return e({pluginStatus:Js,pluginURL:Ks}),ta.on("pluginStateChange",e),e},t.dp=pc,t.dq=class extends sc{constructor(e){super(e),this.current=new Float32Array(9)}set(e,t,i){if(!this.fetchUniformLocation(e,t))return;const r=this.current;for(let n=0;n<9;n++)if(i[n]!==r[n]){r.set(i),this.gl.uniformMatrix3fv(this.location,!1,r);break}}},t.dr=Fe,t.ds=function(e,t,i){const r=Fu(i.zoom),n=e.style.map._antialias,o=e.terrain&&e.terrain.exaggeration()>0;return 0===r&&!n&&!o},t.dt=function(e){const t=e.pixelsPerMeter,i=t/Hc(1,e.center.lat),r=h(new Float64Array(16));return p(r,r,[e.point.x,e.point.y,0]),f(r,r,[i,i,t]),Float32Array.from(r)},t.du=Iu,t.dv=function(e){const t=80.051129;e=ke(e,-80.051129,t)/t*90;const i=Math.pow(Math.abs(Math.sin(Re(e))),3);return Math.round(i*(Rc.length-1))},t.dw=function(e,t,i,r){const n=t.getNorth(),o=t.getSouth(),s=t.getWest(),l=t.getEast(),c=1<<e.z,h=l-s,u=n-o,d=h/Dc,p=-u/Rc[i],f=[0,d,0,p,0,0,n,s,0];if(e.z>0){const e=180/r;a(f,f,[e/h+1,0,0,0,e/u+1,0,-.5*e/d,.5*e/p,1])}return f[2]=c,f[5]=e.x,f[8]=e.y,f},t.dx=Pu,t.dy=vu,t.dz=function(e,t,i){const r=h(new Float64Array(16)),n=(t/(1<<e)-.5)*Math.PI*2;return _(r,i.globeMatrix,n),Float32Array.from(r)},t.e=function(e){return 0===e.indexOf("mapbox:")},t.e$=Gm,t.e0=od,t.e1=Zc,t.e2=uu,t.e3=Mf,t.e4=Bf,t.e5=pf,t.e6=450,t.e7=7,t.e8=Yc,t.e9=function(e,t){if(e===t){var i=t[1],r=t[2],n=t[3],o=t[6],s=t[7],a=t[11];e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=i,e[6]=t[9],e[7]=t[13],e[8]=r,e[9]=o,e[11]=t[14],e[12]=n,e[13]=s,e[14]=a}else e[0]=t[0],e[1]=t[4],e[2]=t[8],e[3]=t[12],e[4]=t[1],e[5]=t[5],e[6]=t[9],e[7]=t[13],e[8]=t[2],e[9]=t[6],e[10]=t[10],e[11]=t[14],e[12]=t[3],e[13]=t[7],e[14]=t[11],e[15]=t[15];return e},t.eA=function(e,t){var r=2*Math.acos(t[3]),n=Math.sin(r/2);return n>i?(e[0]=t[0]/n,e[1]=t[1]/n,e[2]=t[2]/n):(e[0]=1,e[1]=0,e[2]=0),r},t.eB=vb,t.eC=Km,t.eD=Wm,t.eE=[1,1,1],t.eF=nb,t.eG=function(e,t,i,r){var n=t[0],o=t[1],s=t[2],a=t[3];return e[0]=n+r*(i[0]-n),e[1]=o+r*(i[1]-o),e[2]=s+r*(i[2]-s),e[3]=a+r*(i[3]-a),e},t.eH=Jm,t.eI=ml,t.eJ=class{constructor(){this._updateTime=0,this._sourceIds=[],this._activeRegions=[],this._prevRegions=[],this._globalClipBounds={min:new Ie(1/0,1/0),max:new Ie(-1/0,-1/0)}}clear(){this._activeRegions.length>0&&++this._updateTime,this._activeRegions=[],this._prevRegions=[]}get updateTime(){return this._updateTime}getReplacementRegionsForTile(e,t=!1){const i=Jp(new Ie(0,0),new Ie(Yr,Yr),e),r=[];if(t&&!Xp(i,this._globalClipBounds))return r;for(const n of this._activeRegions){if(n.hiddenByOverlap)continue;if(!Xp(i,n))continue;const t=Kp(n.min,n.max,e);r.push({min:t.min,max:t.max,sourceId:this._sourceIds[n.priority],footprint:n.footprint,footprintTileId:n.tileId,order:n.order,clipMask:n.clipMask,clipScope:n.clipScope})}return r}setSources(e){this._setSources(e.map(e=>({getSourceId:()=>e.cache.id,getFootprints:()=>{const t=[];for(const i of e.cache.getVisibleCoordinates()){const r=e.cache.getTile(i).buckets[e.layer];r&&r.updateFootprints(i.toUnwrapped(),t)}return t},getOrder:()=>e.order,getClipMask:()=>e.clipMask,getClipScope:()=>e.clipScope})))}_addSource(e){const t=e.getFootprints();if(0===t.length)return;const i=e.getOrder(),r=e.getClipMask(),n=e.getClipScope();for(const o of t){if(!o.footprint)continue;const e=Jp(o.footprint.min,o.footprint.max,o.id);this._activeRegions.push({min:e.min,max:e.max,hiddenByOverlap:!1,priority:this._sourceIds.length,tileId:o.id,footprint:o.footprint,order:i,clipMask:r,clipScope:n})}this._sourceIds.push(e.getSourceId())}_computeReplacement(){this._activeRegions.sort((e,t)=>e.priority-t.priority||Zp(e.min,t.min)||Zp(e.max,t.max)||e.order-t.order||e.clipMask-t.clipMask||function(e,t){const i=(e,t)=>e+t;return e.length-t.length||e.reduce(i,"").localeCompare(t.reduce(i,""))}(e.clipScope,t.clipScope));let e=this._activeRegions.length!==this._prevRegions.length;if(!e){let t=0;for(;!e&&t!==this._activeRegions.length;){const i=this._activeRegions[t],r=this._prevRegions[t];e=i.priority!==r.priority||!Wp(i,r)||i.order!==r.order||i.clipMask!==r.clipMask||!Ee(i.clipScope,r.clipScope),this._activeRegions[t].hiddenByOverlap=r.hiddenByOverlap,++t}}if(e){++this._updateTime;for(const t of this._activeRegions)t.order!==Hp&&(this._globalClipBounds.min.x=Math.min(this._globalClipBounds.min.x,t.min.x),this._globalClipBounds.min.y=Math.min(this._globalClipBounds.min.y,t.min.y),this._globalClipBounds.max.x=Math.max(this._globalClipBounds.max.x,t.max.x),this._globalClipBounds.max.y=Math.max(this._globalClipBounds.max.y,t.max.y));const e=e=>{const t=this._activeRegions;if(e>=t.length)return e;const i=t[e].priority;for(;e<t.length&&t[e].priority===i;)++e;return e};if(this._sourceIds.length>1){let t=0,i=e(t);for(;t!==i;){let r=t;const n=t;for(;r!==i;){const e=this._activeRegions[r];e.hiddenByOverlap=!1;for(let t=0;t<n;t++){const i=this._activeRegions[t];if(!i.hiddenByOverlap&&e.order===Hp&&Xp(e,i)&&(e.hiddenByOverlap=ef(e.footprint,e.tileId,i.footprint,i.tileId),e.hiddenByOverlap))break}++r}t=i,i=e(t)}}}}_setSources(e){[this._prevRegions,this._activeRegions]=[this._activeRegions,[]],this._sourceIds=[];for(let t=e.length-1;t>=0;t--)this._addSource(e[t]);this._computeReplacement()}},t.eK=el,t.eL=Bv,t.eM=Pl,t.eN=Hp,t.eO=class{constructor(e){this._createGrid(e),this._createPoles(e)}destroy(){this._poleIndexBuffer.destroy(),this._gridBuffer.destroy(),this._gridIndexBuffer.destroy(),this._poleNorthVertexBuffer.destroy(),this._poleSouthVertexBuffer.destroy();for(const e of this._poleSegments)e.destroy();for(const e of this._gridSegments)e.withSkirts.destroy(),e.withoutSkirts.destroy()}_fillGridMeshWithLods(e,t){const i=new Ka,r=new vl,n=[],o=e+1+2,s=t[0]+1,a=t[0]+1+(1+t.length),l=(e,t,i)=>{let r=e===o-1?e-2:0===e?e:e-1;return r+=i?24575:0,[r,t]};for(let c=0;c<o;++c)i.emplaceBack(...l(c,0,!0));for(let c=0;c<s;++c)for(let e=0;e<o;++e)i.emplaceBack(...l(e,c,(0===e||e===o-1)&&!0));for(let c=0;c<t.length;++c){const e=t[c];for(let t=0;t<o;++t)i.emplaceBack(...l(t,e,!0))}for(let c=0;c<t.length;++c){const e=r.length,s=t[c]+1+2,l=new vl;for(let i=0;i<s-1;i++){const e=i===s-2,n=e?o*(a-t.length+c-i):o;for(let t=0;t<o-1;t++){const s=i*o+t;0===i||e||0===t||t===o-2?(l.emplaceBack(s+1,s,s+n),l.emplaceBack(s+n,s+n+1,s+1)):(r.emplaceBack(s+1,s,s+n),r.emplaceBack(s+n,s+n+1,s+1))}}const h=Jl.simpleSegment(0,e,i.length,r.length-e);for(let t=0;t<l.uint16.length;t+=3)r.emplaceBack(l.uint16[t],l.uint16[t+1],l.uint16[t+2]);const u=Jl.simpleSegment(0,e,i.length,r.length-e);n.push({withoutSkirts:h,withSkirts:u})}return{vertices:i,indices:r,segments:n}}_createGrid(e){const t=this._fillGridMeshWithLods(Dc,Rc);this._gridSegments=t.segments,this._gridBuffer=e.createVertexBuffer(t.vertices,fu.members),this._gridIndexBuffer=e.createIndexBuffer(t.indices,!0)}_createPoles(e){const t=new vl;for(let s=0;s<=Dc;s++)t.emplaceBack(0,s+1,s+2);this._poleIndexBuffer=e.createIndexBuffer(t,!0);const i=new Sl,r=new Sl,n=new Sl,o=new Sl;this._poleSegments=[];for(let s=0,a=0;s<6;s++){const e=360/(1<<s);i.emplaceBack(0,-Pc,0,.5,0),r.emplaceBack(0,-Pc,0,.5,1),n.emplaceBack(0,-Pc,0,.5,.5),o.emplaceBack(0,-Pc,0,.5,.5);for(let t=0;t<=Dc;t++){let s=t/Dc,a=0;const l=yi(0,e,s),[c,h,u]=Fc(Nu,Uu,l,Pc);i.emplaceBack(c,h,u,s,a),r.emplaceBack(c,h,u,s,1-a);const d=Re(l);s=.5+.5*Math.sin(d),a=.5+.5*Math.cos(d),n.emplaceBack(c,h,u,s,a),o.emplaceBack(c,h,u,s,1-a)}this._poleSegments.push(Jl.simpleSegment(a,0,66,64)),a+=66}this._poleNorthVertexBuffer=e.createVertexBuffer(i,du,!1),this._poleSouthVertexBuffer=e.createVertexBuffer(r,du,!1),this._texturedPoleNorthVertexBuffer=e.createVertexBuffer(n,du,!1),this._texturedPoleSouthVertexBuffer=e.createVertexBuffer(o,du,!1)}getGridBuffers(e,t){return[this._gridBuffer,this._gridIndexBuffer,t?this._gridSegments[e].withSkirts:this._gridSegments[e].withoutSkirts]}getPoleBuffers(e,t){return[t?this._texturedPoleNorthVertexBuffer:this._poleNorthVertexBuffer,t?this._texturedPoleSouthVertexBuffer:this._poleSouthVertexBuffer,this._poleIndexBuffer,this._poleSegments[e]]}},t.eP=$p,t.eQ=Oe,t.eR=function(){return!!document.fullscreenElement||!!document.webkitFullscreenElement},t.eS=Be,t.eT=Jc,t.eU=function(e,t,i){return e[0]=t[0]/i[0],e[1]=t[1]/i[1],e[2]=t[2]/i[2],e},t.eV=Y,t.eW=Oc,t.eX=k,t.eY=M,t.eZ=function([e,t,i]){const r=Math.hypot(e,t,i),n=Math.atan2(e,i),o=.5*Math.PI-Math.acos(-t/r);return new Nc(ze(n),ze(o))},t.e_=ee,t.ea=Ya,t.eb=zl,t.ec=256,t.ed=function(e){return e>>>=0,e=Math.imul(2747636419^e,2654435769)>>>0,e=Math.imul(e^e>>>16,2654435769)>>>0,(e=Math.imul(e^e>>>16,2654435769)>>>0)/4294967296},t.ee=Ml,t.ef=Ao,t.eg=Bc,t.eh=Al,t.ei=El,t.ej=Gv,t.ek=wu,t.el=Du,t.em=al,t.en=function(e,t){var i=Math.sin(t),r=Math.cos(t);return e[0]=r,e[1]=0,e[2]=-i,e[3]=0,e[4]=0,e[5]=1,e[6]=0,e[7]=0,e[8]=i,e[9]=0,e[10]=r,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e},t.eo=function(e,t){var i=Math.sin(t),r=Math.cos(t);return e[0]=1,e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[5]=r,e[6]=i,e[7]=0,e[8]=0,e[9]=-i,e[10]=r,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,e},t.ep=function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[4],e[4]=t[5],e[5]=t[6],e[6]=t[8],e[7]=t[9],e[8]=t[10],e},t.eq=Sl,t.er=Il,t.es=function(e,t,i,r,n){return ke((e-t)/(i-t)*(n-r)+r,r,n)},t.et=oe,t.eu=function(e,t){var i=t[0],r=t[1],n=t[2],o=t[3],s=t[4],a=t[5],l=t[6],c=t[7],h=t[8],u=h*s-a*c,d=-h*o+a*l,p=c*o-s*l,f=i*u+r*d+n*p;return f?(e[0]=u*(f=1/f),e[1]=(-h*r+n*c)*f,e[2]=(a*r-n*s)*f,e[3]=d*f,e[4]=(h*i-n*l)*f,e[5]=(-a*i+n*o)*f,e[6]=p*f,e[7]=(-c*i+r*l)*f,e[8]=(s*i-r*o)*f,e):null},t.ev=2,t.ew=N,t.ex=ie,t.ey=b,t.ez=function(e,t){var i=new r(3);b(i,t);var n=1/i[0],o=1/i[1],s=1/i[2],a=t[0]*n,l=t[1]*o,c=t[2]*s,h=t[4]*n,u=t[5]*o,d=t[6]*s,p=t[8]*n,f=t[9]*o,m=t[10]*s,_=a+u+m,g=0;return _>0?(g=2*Math.sqrt(_+1),e[3]=.25*g,e[0]=(d-f)/g,e[1]=(p-c)/g,e[2]=(l-h)/g):a>u&&a>m?(g=2*Math.sqrt(1+a-u-m),e[3]=(d-f)/g,e[0]=.25*g,e[1]=(l+h)/g,e[2]=(p+c)/g):u>m?(g=2*Math.sqrt(1+u-a-m),e[3]=(p-c)/g,e[0]=(l+h)/g,e[1]=.25*g,e[2]=(d+f)/g):(g=2*Math.sqrt(1+m-a-u),e[3]=(l-h)/g,e[0]=(p+c)/g,e[1]=(d+f)/g,e[2]=.25*g),e},t.f=_t,t.f0=function(e){const t=e.navigator?e.navigator.userAgent:null;return!!function(e){if(null==ot){const t=e.navigator?e.navigator.userAgent:null;ot=!!e.safari||!(!t||!(Pe.test(t)||t.match("Safari")&&!t.match("Chrome")))}return ot}(e)&&!(!t||!(t.match("Version/15.4")||t.match("Version/15.5")||t.match(De)))},t.f1=function(e,t){Ct=e,Pt=t},t.f2=Bu,t.f3=Ou,t.f4=function(e){const t=[0,0,0],i=h(new Float64Array(16));return d(i,e.pixelMatrix,e.globeMatrix),H(t,t,i),new Ie(t[0],t[1])},t.f5=function(e,t){if(!e||!t)throw new Error("TileProvider name and URL are required");dt.TILE_PROVIDER_URLS[e]=It.resolveURL(t)},t.f6=ia,t.f7=function(e,t,i=!1){if(Js===Xs.deferred||Js===Xs.loading||Js===Xs.loaded)throw new Error("setRTLTextPlugin cannot be called multiple times.");Ks=It.resolveURL(e),Js=Xs.deferred,Ys=t,ea(),i||ra()},t.f8=mt,t.f9=ft,t.fA=ng,t.fB=fh,t.fC=function(e){return e<=1?1:Math.pow(2,Math.floor(Math.log2(e)))},t.fD=ew,t.fE=ch,t.fF=function(e){let t=0;if(new Uint32Array(e,0,1)[0]!==vm){const i=new Uint32Array(e,0,7),[,,r,n,o,s]=i;t=i.byteLength+n+o+s+o,(r!==e.byteLength||t>=e.byteLength)&&Ke("Invalid b3dm header information.")}return Em(e,t)},t.fG=function(e,t){const i=e.json.extensionsUsed&&e.json.extensionsUsed.includes("mbx_bvh"),r=x_(e);for(const n of r){if(!i)for(const e of n.meshes)v_(e);n.lights&&(n.lightMeshIndex=n.meshes.length,n.meshes.push(w_(n.lights,t)))}return r},t.fH=pb,t.fI=it,t.fJ=na,t.fK=Xs,t.fL=function(e){Lt(),Rt?.then(t=>{t.keys().then(i=>{for(let r=0;r<i.length-e;r++)t.delete(i[r]).catch(e=>Ke(e.message))}).catch(e=>Ke(e.message))}).catch(e=>Ke(e.message))},t.fa=pt,t.fb=function(e){const t=zt();if(!t)return;const i=t.delete(Mt);e&&i.then(()=>e()).catch(e)},t.fc=as,t.fd=id,t.fe=2,t.ff=ln,t.fg=Hx,t.fh=Ol,t.fi=Ib,t.fj=Eb,t.fk=eg,t.fl=_h,t.fm="hd_road_elevation",t.fn=Fh,t.fo=Ze,t.fp=Mp,t.fq=Vd,t.fr=Vy,t.fs=1,t.ft=Iv,t.fu=function(e,t,i,r,n,o,s,a=1,l,c,h,u){e.createArrays(),e.tilePixelRatio=Yr/(512*e.overscaling),e.compareText={},e.iconsNeedLinear=!1;const d=e.layers[0].layout,p=e.layers[0]._unevaluatedLayout._values,f={};f.scaleFactor=a,f.textSizeScaleRange=d.get("text-size-scale-range"),f.iconSizeScaleRange=d.get("icon-size-scale-range");const[m,_]=f.textSizeScaleRange,[g,y]=f.iconSizeScaleRange;f.textScaleFactor=ke(f.scaleFactor,m,_),f.iconScaleFactor=ke(f.scaleFactor,g,y);const x=p["text-size"],v=p["icon-size"];if("composite"===e.textSizeData.kind){const{minZoom:t,maxZoom:i}=e.textSizeData;f.compositeTextSizes=[x.possiblyEvaluate(new sa(t,{worldview:h}),o),x.possiblyEvaluate(new sa(i,{worldview:h}),o)]}if("composite"===e.iconSizeData.kind){const{minZoom:t,maxZoom:i}=e.iconSizeData;f.compositeIconSizes=[v.possiblyEvaluate(new sa(t,{worldview:h}),o,u),v.possiblyEvaluate(new sa(i,{worldview:h}),o,u)]}f.layoutTextSize=x.possiblyEvaluate(new sa(s+1,{worldview:h}),o),f.layoutIconSize=v.possiblyEvaluate(new sa(s+1,{worldview:h}),o,u),f.textMaxSize=x.possiblyEvaluate(new sa(18,{worldview:h}),o);const b=d.get("symbol-placement"),w="map"===d.get("text-rotation-alignment")&&"point"!==b,T=d.get("text-size");let S=!1;const I=[];for(const E of e.features){const s=d.get("text-font").evaluate(E,{},o).join(","),a=T.evaluate(E,{},o)*f.textScaleFactor,m=f.layoutTextSize.evaluate(E,{},o)*f.textScaleFactor,_=f.layoutIconSize.evaluate(E,{},o,u)*f.iconScaleFactor,g={horizontal:{},vertical:void 0},y=E.text;let x,v=[0,0];if(y){const r=y.toString(),c=d.get("text-letter-spacing").evaluate(E,{},o)*Lg,h=d.get("text-line-height").evaluate(E,{},o)*Lg,u=Ns(r)?c:0,p=d.get("text-anchor").evaluate(E,{},o),_=d.get("text-variable-anchor");if(!_){const e=d.get("text-radial-offset").evaluate(E,{},o);if(e)v=yx(p,[e*Lg,mx]);else{const e=d.get("text-offset").evaluate(E,{},o);v=[e[0]*Lg,e[1]*Lg]}}let x=w?"center":d.get("text-justify").evaluate(E,{},o);const T="point"===b,S=T?d.get("text-max-width").evaluate(E,{},o)*Lg:1/0,I=o=>{e.allowVerticalPlacement&&ks(r)&&(g.vertical=sy(y,t,i,n,s,S,h,p,o,u,v,ry.vertical,!0,m,a,l,f.textScaleFactor))};if(!w&&_){const e="auto"===x?_.map(e=>Dx(e)):[x];let r=!1;for(let o=0;o<e.length;o++){const c=e[o];if(!g.horizontal[c])if(r)g.horizontal[c]=g.horizontal[0];else{const e=sy(y,t,i,n,s,S,h,"center",c,u,v,ry.horizontal,!1,m,a,l,f.textScaleFactor);e&&(g.horizontal[c]=e,r=1===e.positionedLines.length)}}I("left")}else{if("auto"===x&&(x=Dx(p)),T||d.get("text-writing-mode").includes("horizontal")||!ks(r)){const e=sy(y,t,i,n,s,S,h,p,x,u,v,ry.horizontal,!1,m,a,l,f.textScaleFactor);e&&(g.horizontal[x]=e)}I(T?"left":x)}}let A,M,C,P,D,R,z=!1;const L=d.get("icon-text-fit").evaluate(E,{},o);if(E.icon&&E.icon.hasPrimary()){const t=Ex(E.icon,e.iconSizeData,p["icon-size"],o,e.zoom,E,l,f.iconScaleFactor,h,u);A=t.iconPrimary,C=t.iconSecondary;const i=A.toString();if(M=r.get(i),M&&(D=d.get("icon-offset").evaluate(E,{},o),R=d.get("icon-anchor").evaluate(E,{},o),x=gy(n.get(i),C?n.get(C.toString()):void 0,D,R),z=M.sdf,void 0===e.sdfIcons?e.sdfIcons=M.sdf:e.sdfIcons!==M.sdf&&Ke("Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer"),(M.pixelRatio!==e.pixelRatio||0!==d.get("icon-rotate").constantOr(1))&&(e.iconsNeedLinear=!0)),C){const e=C.toString();P=r.get(e)}}S=S||!(!E.icon||!E.icon.hasSecondary());const F=Nx(g.horizontal)||g.vertical;e.iconsInText||(e.iconsInText=!!F&&F.iconsInText);const O=m*f.textScaleFactor/Lg,{defaultShapedIcon:B,verticallyShapedIcon:k}=Rx(e,x,d,E,o,g,O,D,L);"none"!==L&&x&&(xy(x)||vy(x))&&(Sx(0,M,A,x,B,L,c,r,n),Sx(0,P,C,x,B,L,c,r,n),k&&(Sx(0,M,A,x,k,L,c,r,n),Sx(0,P,C,x,k,L,c,r,n))),x=B;const{iconBBox:N,iconVerticalBBox:U,textBBox:V,textVerticalBBox:j}=xx(e,x,k,d,E,o,_,D,f,n,R,g,m,v,u);I.push({feature:E,shapedTextOrientations:g,shapedText:F,shapedIcon:x,iconPrimary:A,iconSecondary:C,iconOffset:D,iconAnchor:R,verticallyShapedIcon:k,layoutTextSize:m,layoutIconSize:_,textOffset:v,isSDFIcon:z,iconTextFit:L,iconCollisionBounds:N,iconVerticalCollisionBounds:U,textCollisionBounds:V,textVerticalCollisionBounds:j})}return{featureData:I,sizes:f,hasAnySecondaryIcon:S,textAlongLine:w,symbolPlacement:b}},t.fv=jy,t.fw=Ny,t.fx=Gy,t.fy=Hy,t.fz=function(e,t,i,r,n,o,s,a,l,c){e.iconAtlasPositions=c.iconPositions;const{featureData:h,hasAnySecondaryIcon:u,sizes:d,textAlongLine:p,symbolPlacement:f}=t;for(const m of h){const{shapedIcon:t,verticallyShapedIcon:i,feature:o,shapedTextOrientations:h,shapedText:_,layoutTextSize:g,textOffset:y,isSDFIcon:x,iconPrimary:v,iconSecondary:b,iconTextFit:w,iconOffset:T,iconCollisionBounds:S,iconVerticalCollisionBounds:I,textCollisionBounds:E}=m;Mx(t,c.iconPositions,v,b),Mx(i,c.iconPositions,v,b),Cx(h,c.iconPositions),Ax(v,b,c.iconPositions),(_||t)&&Lx(e,o,h,t,i,l,d,g,0,y,x,r,n,s,a,u,w,T,p,f,S,I,E)}i&&e.generateCollisionDebugBuffers(o,e.collisionBoxArray,d.textScaleFactor)},t.g=dt,t.h=function(e,t){return Xt(Object.assign(e,{method:"GET"}),t)},t.i=function(e){return dt.API_STYLE_REGEX.test(e)&&!gt(e)},t.j=function(e){return btoa(encodeURIComponent(e).replace(/%([0-9A-F]{2})/g,(e,t)=>String.fromCharCode(Number("0x"+t))))},t.k=Ot,t.l=function(e){return decodeURIComponent(atob(e).split("").map(e=>"%"+("00"+e.charCodeAt(0).toString(16)).slice(-2)).join(""))},t.m=Yt,t.n=ti,t.o=It,t.p=function(e,t){return Xt(Object.assign(e,{method:"POST"}),t)},t.q=rd,t.r=St,t.s=function(e){try{const t=self[e];return t.setItem("_mapbox_test_",1),t.removeItem("_mapbox_test_"),!0}catch(e){return!1}},t.t=Oa,t.u=function(){return function e(t){return t?(t^Math.random()*(16>>t/4)).toString(16):([1e7]+-[1e3]+-4e3+-8e3+-1e11).replace(/[018]/g,e)}()},t.v=function(e){return!!e&&Ce.test(e)},t.w=Ke,t.x=class{constructor(e){this.cache=/* @__PURE__ */new Map,this.textures=/* @__PURE__ */new Map,this.textureAccessTimes=/* @__PURE__ */new Map,this.textureMemoryUsed=0,this.maxTextureMemory=1024*(e&&e.maxTextureMemoryMB?e.maxTextureMemoryMB:256)*1024,this.finalizationRegistry=new FinalizationRegistry(e=>{this.cache.delete(e),this.clearExpiredTextures()})}calculateTextureMemory(e){return e.image?Math.ceil(e.image.width*e.image.height*4*(e.patternPositions.size>0?1.33:1)):0}evictTexture(e){const t=this.textures.get(e);if(t){const i=this.calculateTextureMemory(e);t.destroy(),this.textures.delete(e),this.textureAccessTimes.delete(e),this.textureMemoryUsed-=i,e.uploaded=!1}}evictTexturesIfNeeded(e){for(;this.textureMemoryUsed+e>this.maxTextureMemory&&this.textures.size>0;){let e=null,t=1/0;for(const[i]of this.textures.entries()){const r=this.textureAccessTimes.get(i)||0;r<t&&(t=r,e=i)}if(!e)break;this.evictTexture(e)}}findCachedAtlas(e){const t=this.cache.get(e.hash);if(t){const i=t.deref();if(i&&i.contentDescriptor&&this.isMipmapCompatible(e,i.contentDescriptor))return i}for(const[,i]of this.cache.entries()){const t=i.deref();if(t&&t.contentDescriptor){const i=e.subsetOf(t.contentDescriptor),r=this.isMipmapCompatible(e,t.contentDescriptor);if(i&&r)return t}}}getTextureForAtlas(e,t,i){this.textureAccessTimes.set(e,performance.now());let r=this.textures.get(e);if(r)return r;if(e.image){const n=this.calculateTextureMemory(e);return this.evictTexturesIfNeeded(n),r=new Pm(t,e.image,i,{useMipmap:!!e.patternPositions.size}),this.textures.set(e,r),this.textureMemoryUsed+=n,r}return null}clearExpiredTextures(){for(const[e]of this.textures.entries())if(!this.isAtlasCached(e)){const t=this.textures.get(e);if(t){const i=this.calculateTextureMemory(e);t.destroy(),this.textureMemoryUsed-=i}this.textures.delete(e),this.textureAccessTimes.delete(e)}}isAtlasCached(e){if(!e.contentDescriptor)return!1;const t=this.cache.get(e.contentDescriptor.hash);return!!t&&t.deref()===e}getOrCache(e){if(!("image"in e)){const t=this.cache.get(e.sourceAtlasHash);if(t){const e=t.deref();if(e)return e}return Ke("ImageAtlasReference points to GC'd atlas - atlas may have been evicted"),null}if(!e.contentDescriptor)return e;const t=e.contentDescriptor,i=t.hash,r=this.cache.get(i);if(r){const e=r.deref();if(e&&e.contentDescriptor&&this.isMipmapCompatible(t,e.contentDescriptor))return e}return this.cache.set(i,new WeakRef(e)),this.finalizationRegistry.register(e,i,e),e}isMipmapCompatible(e,t){return!e.requiresMipMaps||t.requiresMipMaps}destroyTextures(){for(const e of this.textures.values())e&&e.destroy();this.textures.clear(),this.textureAccessTimes.clear(),this.textureMemoryUsed=0}clear(){for(const e of this.textures.values())e&&e.destroy();this.cache.clear(),this.textures.clear(),this.textureAccessTimes.clear(),this.textureMemoryUsed=0}},t.y=hi,t.z=ci}),r(0,function(e,t){function i(e){const t=e?e.url.toString():void 0;return t?performance.getEntriesByName(t):[]}function r(e){if("number"==typeof e||"boolean"==typeof e||"string"==typeof e||null==e)return JSON.stringify(e);if(Array.isArray(e)){let t="[";for(const i of e)t+=`${r(i)},`;return`${t}]`}let t="{";for(const i of Object.keys(e).sort())t+=`${i}:${r(e[i])},`;return`${t}}`}function n(e){let i="";for(const n of t.b8)i+=`/${r(e[n])}`;return i}function o(e,t){return function e(i){return"string"==typeof i&&i===t||(Array.isArray(i)?i.some(e):!(!i||"object"!=typeof i)&&Object.values(i).some(e))}(e)}class s{constructor(e){this.keyCache=Object.create(null),this._layers=Object.create(null),this._layerConfigs=Object.create(null),e&&this.replace(e)}replace(e,t){this._layerConfigs=Object.create(null),this._layers=Object.create(null),this.update(e,[],t)}update(e,i,s){this._options=s;for(const r of e)this._layerConfigs[r.id]=r,(this._layers[r.id]=t.dh(r,this.scope,null,this._options)).compileFilter(s),this.keyCache[r.id]&&delete this.keyCache[r.id];for(const t of i)delete this.keyCache[t],delete this._layerConfigs[t],delete this._layers[t];this.familiesBySource=Object.create(null);const a=function(e,t){const i=Object.create(null);for(let a=0;a<e.length;a++){const s=e[a];let l=t&&t[s.id];l||("symbol"===s.type?l=s.id:(l=n(s),"line"===s.type&&s.paint&&o(s.paint["line-width"],"line-progress")&&(l+=`/${r(s.paint["line-width"])}`))),t&&(t[s.id]=l);let c=i[l];c||(c=i[l]=[]),c.push(s)}const s=[];for(const r in i)s.push(i[r]);return s}(Object.values(this._layerConfigs),this.keyCache);for(const t of a){const e=t.map(e=>this._layers[e.id]),i=e[0];if("none"===i.visibility)continue;const r=i.source||"";let n=this.familiesBySource[r];n||(n=this.familiesBySource[r]=Object.create(null));const o=i.sourceLayer||"_geojsonTileLayer";let s=n[o];s||(s=n[o]=[]),s.push(e)}}}const a=1*t.fe;class l{constructor(e){const i={},r=[];for(const t in e){const n=e[t],o=i[t]={};for(const e in n.glyphs){const t=n.glyphs[+e];if(!t||0===t.bitmap.width||0===t.bitmap.height)continue;const i=t.metrics.localGlyph?a:1,s={x:0,y:0,w:t.bitmap.width+2*i,h:t.bitmap.height+2*i};r.push(s),o[e]=s}}const{w:n,h:o}=t.F(r),s=new t.fd({width:n||1,height:o||1});for(const l in e){const r=e[l];for(const e in r.glyphs){const n=r.glyphs[+e];if(!n||0===n.bitmap.width||0===n.bitmap.height)continue;const o=i[l][e],c=n.metrics.localGlyph?a:1;t.fd.copy(n.bitmap,s,{x:0,y:0},{x:o.x+c,y:o.y+c},n.bitmap)}}this.image=s,this.positions=i}}function c(e,t,i){e[t]?i&&(e[t].center=i):e[t]={floorIds:/* @__PURE__ */new Set,center:i||[0,0],floors:{}}}function h(e,t,i,r){for(const n of t)c(e,n),e[n].floors[i]=r,e[n].floorIds.add(i)}function u(e){return{id:e.properties.id.toString(),center:[e.properties.center_lon||0,e.properties.center_lat||0]}}function d(e,i){return{id:e.properties.id.toString(),isDefault:!!e.properties.is_default&&e.properties.is_default,connections:e.properties.connected_floor_ids?new Set(e.properties.connected_floor_ids.toString().split(";")):/* @__PURE__ */new Set,conflicts:e.properties.conflicted_floor_ids?new Set(e.properties.conflicted_floor_ids.toString().split(";")):/* @__PURE__ */new Set,buildings:e.properties.structure_ids?new Set(e.properties.structure_ids.toString().split(";")):/* @__PURE__ */new Set,name:e.properties.name.toString(),zIndex:e.properties.z_index,geometry:function(e,i){const r=e.loadGeometry();if(!r||0===r.length)return;const n=r.map(r=>r.map(r=>t.ff(r,i,e.extent)));return 0===n.length?void 0:{type:"Polygon",coordinates:[n[0]]}}(e,i)}}function p(e,t){return t.every(t=>e.properties&&null!=e.properties[t])}function f(e){return p(e,["type","id","name"])&&"structure"===e.properties.type}function m(e){return p(e,["type","id","name","z_index"])&&"floor"===e.properties.type}t.fc(l,"GlyphAtlas");class _{constructor(e){this.tileID=new t.aU(e.tileID.overscaledZ,e.tileID.wrap,e.tileID.canonical.z,e.tileID.canonical.x,e.tileID.canonical.y),this.tileZoom=e.tileZoom,this.uid=e.uid,this.zoom=e.zoom,this.lut=e.lut,this.canonical=e.tileID.canonical,this.pixelRatio=e.pixelRatio,this.tileSize=e.tileSize,this.source=e.source,this.scope=e.scope,this.overscaling=this.tileID.overscaleFactor(),this.showCollisionBoxes=e.showCollisionBoxes,this.showElevationIdDebug=e.showElevationIdDebug,this.collectResourceTiming=!!e.request&&e.request.collectResourceTiming,this.promoteId=e.promoteId,this.renderSourceType=e.renderSourceType,this.tileTransform=t.fg(e.tileID.canonical,e.projection),this.projection=e.projection,this.worldview=e.worldview,this.localizableLayerIds=e.localizableLayerIds,this.brightness=e.brightness,this.extraShadowCaster=!!e.extraShadowCaster,this.tessellationStep=e.tessellationStep,this.scaleFactor=e.scaleFactor,this.worldview=e.worldview,this.indoor=e.indoor}parse(e,i,r,n,o,s){this.status="parsing",this.data=e,this.collisionBoxArray=new t.fh;const a=new t.fi(Object.keys(e.layers).sort()),p=new t.fj(this.tileID,this.promoteId);p.bucketLayerIDs=[];const _={},y=new t.fk(256,256),x={featureIndex:p,iconDependencies:/* @__PURE__ */new Map,patternDependencies:/* @__PURE__ */new Map,glyphDependencies:{},lineAtlas:y,availableImages:r,brightness:this.brightness,scaleFactor:this.scaleFactor,showElevationIdDebug:this.showElevationIdDebug,elevationFeatures:void 0,activeFloors:void 0};this.indoor&&(x.activeFloors=function(e,i,r,n){const o=i.indoorState.activeFloorsVisible;if(!i.sourceLayers)return o?i.indoorState.activeFloors:void 0;const s=function(e,i){if(!e)return t.w("No source layers defined in indoor specification"),i;if(0===e.size)return i;const r=e.difference(i);for(const n of r)t.w(`Missing source layer required in indoor specification: ${n}`);return i.intersection(i)}(i.sourceLayers,new Set(Object.keys(e.layers))),a=i.indoorState,l=function(e,i,r,n,o){const s={};for(const a of i){const i=e.layers[a];if(i)for(let e=0;e<i.length;e++){const t=i.feature(e);if(f(t)){const{id:e,center:i}=u(t);c(s,e,i);continue}if(m(t)){const e=d(t,o);h(s,e.buildings,e.id,e)}}else t.w(`indoor source layer not found: ${a}`)}return{buildings:s,activeFloors:t.d3.calculate(s,n,r)}}(e,s,a.activeFloors,a.selectedFloorId,n);return r.send("setIndoorData",l),o?l.activeFloors:void 0}(e,this.indoor,o,this.canonical));const v=[],b=i.familiesBySource[this.source];for(const l in b){const i=e.layers[l];if(!i)continue;let o=!1,s=!1,c=!1,h=!1;for(const e of b[l])"symbol"===e[0].type?o=!0:"fill-extrusion"===e[0].type?s=!0:c=!0,e[0].is3D()&&"model"!==e[0].type&&(h=!0);if(this.extraShadowCaster&&!h)continue;if(this.renderSourceType===t.b7.Symbol&&!o)continue;if(this.renderSourceType===t.b7.FillExtrusion&&!s)continue;if(this.renderSourceType===t.b7.Other&&!c)continue;1===i.version&&t.w(`Vector tile source "${this.source}" layer "${l}" does not use vector tile spec v2 and therefore may have some rendering errors.`);const u=a.encode(l),d=[],f=this.localizableLayerIds&&this.localizableLayerIds.has(l);let m=!1;for(let e=0,r=0;e<i.length;e++){const n=i.feature(e),o=p.getId(n,l),s=n.properties?n.properties.worldview:null;if(f&&this.worldview&&"string"==typeof s)if("all"===s)n.properties.$localized=!0;else{if(!s.split(",").includes(this.worldview))continue;n.properties.$localized=!0,n.properties.worldview=this.worldview}!m&&n.properties&&Object.hasOwn(n.properties,t.fl)&&(m=!0),d.push({feature:n,id:o,index:r,sourceLayerIndex:u}),r++}m&&!x.elevationFeatures&&Object.hasOwn(e.layers,t.fm)&&(x.elevationFeatures=t.fn.parseFrom(e.layers[t.fm],this.canonical));for(const e of b[l]){const i=e[0];if(this.extraShadowCaster&&(!i.is3D()||"model"===i.type))continue;if(this.renderSourceType===t.b7.Symbol&&"symbol"!==i.type)continue;if(this.renderSourceType===t.b7.FillExtrusion&&"fill-extrusion"!==i.type)continue;if(this.renderSourceType===t.b7.Other&&("symbol"===i.type||"fill-extrusion"===i.type))continue;if(i.minzoom&&this.zoom<Math.floor(i.minzoom))continue;if(i.maxzoom&&this.zoom>=i.maxzoom)continue;if("none"===i.visibility)continue;g(e,this.zoom,x.brightness,r,this.worldview,x.activeFloors);const o=()=>{const o=_[i.id]=i.createBucket({index:p.bucketLayerIDs.length,layers:e,zoom:this.zoom,lut:this.lut,canonical:this.canonical,pixelRatio:this.pixelRatio,overscaling:this.overscaling,collisionBoxArray:this.collisionBoxArray,sourceLayerIndex:u,sourceID:this.source,projection:this.projection.spec,tessellationStep:this.tessellationStep,styleDefinedModelURLs:n,worldview:this.worldview,localizable:f,availableImages:r,maxUniformBufferBindings:this.maxUniformBufferBindings,maxUniformBlockSizeDwords:this.maxUniformBlockSizeDwords,disableSymbolUBO:this.disableSymbolUBO});p.bucketLayerIDs.push(e.map(e=>t.t(e.id,e.scope))),o.populate(d,x,this.tileID.canonical,this.tileTransform)};if("prepare"in i){const e=i.prepare().then(()=>o());v.push(e)}else o()}}const w=()=>{y.trim();const i=!(!x.elevationFeatures||!x.elevationFeatures.some(e=>e.heightRange.min<0));let n,c,h,u,d,f,m;const v={type:"maybePrepare",renderSourceType:this.renderSourceType,zoom:this.zoom},b=()=>{if(n)return this.status="done",s(n);if(this.extraShadowCaster)this.status="done",s(null,{buckets:Object.values(_).filter(e=>!e.isEmpty()),featureIndex:p,collisionBoxArray:null,hasTunnelGeometry:i,glyphAtlasImage:null,lineAtlas:null,imageAtlas:null,brightness:x.brightness,glyphMap:null,iconMap:null,glyphPositions:null});else if(c&&h&&u&&m){const e=void 0,i=new l(c),n=/* @__PURE__ */new Map;for(const[r,o]of h.entries()){const{imagePosition:e}=t.fr(r,o,t.fs);n.set(r,e)}const s={};for(const o in _){const e=_[o];e instanceof t.ft&&(g(e.layers,this.zoom,x.brightness,r,this.worldview,x.activeFloors),s[o]=t.fu(e,c,i.positions,h,n,this.tileID.canonical,this.tileZoom,this.scaleFactor,this.pixelRatio,d,this.worldview,r))}d.size||f.size?this.rasterizeTask=o.send("rasterizeImages",{scope:this.scope,iconTasks:d,patternTasks:f},(t,r)=>{if(!t)for(const[e,i]of r.entries())h.has(e)&&h.set(e,Object.assign(h.get(e),{data:i})),u.has(e)&&u.set(e,Object.assign(u.get(e),{data:i}));w(s,i,e,m)}):w(s,i,e,m)}},w=(e,n,a,l)=>{const c=h.size>0||u.size>0,d=Object.keys(e).length>0;if(!c&&!d)return this.status="done",void s(null,{buckets:Object.values(_).filter(e=>!e.isEmpty()),featureIndex:p,collisionBoxArray:this.collisionBoxArray,hasTunnelGeometry:i,glyphAtlasImage:n.image,lineAtlas:y,imageAtlas:null,brightness:x.brightness});const f=(o,a)=>{for(const i in _){const n=_[i];if(i in e)t.fz(n,e[i],this.showCollisionBoxes,r,this.tileID.canonical,this.tileZoom,this.projection,this.brightness,h,a);else if(n.hasPattern&&(n instanceof t.fA||n instanceof t.fp||n instanceof t.e3)){g(n.layers,this.zoom,x.brightness,r,this.worldview,x.activeFloors);const e=Object.fromEntries(a.patternPositions);n.addFeatures(x,this.tileID.canonical,e,r,this.tileTransform,this.brightness)}}this.status="done",s(null,{buckets:Object.values(_).filter(e=>!e.isEmpty()),featureIndex:p,collisionBoxArray:this.collisionBoxArray,hasTunnelGeometry:i,glyphAtlasImage:n.image,lineAtlas:y,imageAtlas:o,brightness:x.brightness})};if(c){const e=/* @__PURE__ */new Map,i=t.fv(h,e),r=t.fv(u,e),n=new t.fw(i,r,l,this.lut,e);o.send("checkAtlasCache",{descriptor:n,scope:this.scope},(e,i)=>{let r,n;if(e&&t.w(`[Worker] Error checking atlas cache: ${e.message}`),i)r=new t.fx(i.sourceHash),n=i;else{const e=new t.fy(h,u,this.lut,l);r=e,n=e}f(r,n)})}else f(null,{iconPositions:/* @__PURE__ */new Map,patternPositions:/* @__PURE__ */new Map})};if(!this.extraShadowCaster){const e=t.fo(x.glyphDependencies,e=>Object.keys(e).map(Number));Object.keys(e).length?o.send("getGlyphs",{uid:this.uid,stacks:e},(e,t)=>{n||(n=e,c=t,b())},void 0,!1,v):c={},m=/* @__PURE__ */new Map;const i=Array.from(x.iconDependencies.keys()).map(e=>t.I.parse(e)),r=Array.from(x.patternDependencies.keys()).map(e=>t.I.parse(e));i.length||r.length?o.send("getImages",{icons:i,patterns:r,source:this.source,scope:this.scope,tileID:this.tileID},(e,t)=>{if(!n){n=e,h=/* @__PURE__ */new Map,u=/* @__PURE__ */new Map,d=this.updateImageMapAndGetImageTaskQueue(h,t.images,x.iconDependencies),f=this.updateImageMapAndGetImageTaskQueue(u,t.images,x.patternDependencies);for(const[e,i]of t.versions.entries())m.set(e,i);b()}},void 0,!1,v):(h=/* @__PURE__ */new Map,u=/* @__PURE__ */new Map,d=/* @__PURE__ */new Map,f=/* @__PURE__ */new Map)}if(x.elevationFeatures&&x.elevationFeatures.length>0){const i=[];for(const e of Object.values(_))if(e instanceof t.fp){const t=e.getUnevaluatedPortalGraph();t&&i.push(t)}const r=t.fq.evaluate(i);for(const n of Object.values(_))if(n instanceof t.fp){const t=e.layers[a.decode(n.sourceLayerIndex)];n.setEvaluatedPortalGraph(r,t,this.tileID.canonical,x.availableImages,x.brightness)}}b()};v.length>0?Promise.allSettled(v).then(w).catch(s):w()}updateParameters(e){this.scaleFactor=e.scaleFactor,this.showCollisionBoxes=e.showCollisionBoxes,this.showElevationIdDebug=e.showElevationIdDebug,this.projection=e.projection,this.brightness=e.brightness,this.tileTransform=t.fg(e.tileID.canonical,e.projection),this.extraShadowCaster=e.extraShadowCaster,this.lut=e.lut,this.worldview=e.worldview,this.indoor=e.indoor}updateImageMapAndGetImageTaskQueue(e,t,i){const r=/* @__PURE__ */new Map;for(const n of t.keys()){const o=i.get(n)||[];for(const i of o){const n=i.toString(),o=t.get(i.id.toString());o.usvg?r.has(n)||(r.set(n,i),e.set(n,Object.assign({},o))):e.set(n,o)}}return r}cancelRasterize(){this.rasterizeTask&&this.rasterizeTask.cancel()}}function g(e,i,r,n,o,s){const a=new t.ab(i,{brightness:r,worldview:o,activeFloors:s});for(const t of e)t.recalculate(a,n)}class y extends t.E{constructor({actor:e,layerIndex:i,availableImages:r,availableModels:n,isSpriteLoaded:o,tileProvider:s,brightness:a,maxUniformBufferBindings:l,maxUniformBlockSizeDwords:c,disableSymbolUBO:h}){super(),this.actor=e,this.layerIndex=i,this.availableImages=r,this.availableModels=n,this.loadVectorData=t.aQ,this.tileProvider=s,this.loading={},this.loaded={},this.deduped=new t.aL(e.scheduler),this.isSpriteLoaded=o,this.scheduler=e.scheduler,this.brightness=a,this.maxUniformBufferBindings=l,this.maxUniformBlockSizeDwords=c,this.disableSymbolUBO=h}loadTileData(e,t){if(!this.tileProvider)return this.loadVectorData(e,t);const i=new AbortController;return this.loadTileWithProvider(this.tileProvider,e,i,t),()=>i.abort()}async loadTileWithProvider(e,t,i,r){const{z:n,x:o,y:s}=t.tileID.canonical;try{const a=await e.loadTile({z:n,x:o,y:s},{request:t.request,signal:i.signal});if(i.signal.aborted)return;if(null==a){const e=/* @__PURE__ */new Error("Tile not found");return e.status=404,r(e)}if(null==a.data)return r(null,null);const l=/* @__PURE__ */new Map;a.expires&&l.set("expires",a.expires),a.cacheControl&&l.set("cache-control",a.cacheControl),r(null,{rawData:a.data,responseHeaders:l})}catch(e){if(i.signal.aborted)return;r(e instanceof Error?e:new Error(String(e)))}}loadTile(e,r){const n=e.uid,o=e&&e.request,s=o&&o.collectResourceTiming,a=this.loading[n]=new _(e);a.maxUniformBufferBindings=this.maxUniformBufferBindings,a.maxUniformBlockSizeDwords=this.maxUniformBlockSizeDwords,a.disableSymbolUBO=this.disableSymbolUBO,a.abort=this.loadTileData(e,(l,c)=>{const h=!this.loading[n];if(delete this.loading[n],a.cancelRasterize(),h||l||!c)return a.status="done",h||(this.loaded[n]=a),r(l);const u=c.rawData,d={},p=t.aR(c.responseHeaders);p&&p.expires&&(d.expires=p.expires),p&&p.cacheControl&&(d.cacheControl=p.cacheControl),a.vectorTile=c.vectorTile||new t.fB(new t.b2(u));const f=()=>{a.parse(a.vectorTile,this.layerIndex,this.availableImages,this.availableModels,this.actor,(e,t)=>{if(e||!t)return r(e);const n={};if(s){const e=i(o);e.length>0&&(n.resourceTiming=JSON.parse(JSON.stringify(e)))}r(null,Object.assign({rawTileData:u.slice(0),responseHeaders:c.responseHeaders},t,d,n))})};this.isSpriteLoaded?f():this.once("isSpriteLoaded",()=>{this.scheduler?this.scheduler.add(f,{type:"parseTile",renderSourceType:e.renderSourceType,zoom:e.tileZoom}):f()}),this.loaded=this.loaded||{},this.loaded[n]=a})}reloadTile(e,t){const i=this.loaded,r=e.uid;if(i&&i[r]){const n=i[r];n.updateParameters(e);const o=(e,i)=>{const r=n.reloadCallback;r&&(delete n.reloadCallback,n.parse(n.vectorTile,this.layerIndex,this.availableImages,this.availableModels,this.actor,r)),t(e,i)};"parsing"===n.status?n.reloadCallback=o:"done"===n.status&&(n.vectorTile?n.parse(n.vectorTile,this.layerIndex,this.availableImages,this.availableModels,this.actor,o):o())}else t(null,void 0)}abortTile(e,t){const i=e.uid,r=this.loading[i];r&&(r.abort&&r.abort(),delete this.loading[i]),t()}removeTile(e,t){const i=this.loaded,r=e.uid;i&&i[r]&&delete i[r],t()}}class x{constructor(e){this.tileProvider=e.tileProvider,this.loading={}}loadTile(e,i){const r=e.uid;if(this.tileProvider){const t=new AbortController;return this.loading[r]={cancel:()=>t.abort()},void this.loadTileWithProvider(this.tileProvider,r,e,t,i)}const{cancel:n}=t.b4(e.request,(n,o,s)=>{const a=!this.loading[r];if(delete this.loading[r],a||n||!o)return i(n);this.decodeTile(r,o,e.encoding).then(e=>{const{expires:r,cacheControl:n}=t.aR(s);i(null,Object.assign(e,{expires:r,cacheControl:n}))}).catch(e=>i(e))});this.loading[r]={cancel:n}}async decodeTile(e,i,r){const n=await createImageBitmap(new Blob([new Uint8Array(i)],{type:"image/png"})),o=1-(n.width-t.fC(n.width))/2,s=o<1,a=this.getImageData(n,o);return n.close(),{dem:new t.fD(e,a,r,s),borderReady:s}}async loadTileWithProvider(e,t,i,r,n){const{z:o,x:s,y:a}=i.tileID.canonical;try{const l=await e.loadTile({z:o,x:s,y:a},{request:i.request,signal:r.signal});if(r.signal.aborted)return n(null,null);if(null==l){const e=/* @__PURE__ */new Error("Tile not found");return e.status=404,n(e)}if(null==l.data)return n(null,null);const c=await this.decodeTile(t,l.data,i.encoding);if(r.signal.aborted)return n(null,null);n(null,Object.assign(c,{expires:l.expires,cacheControl:l.cacheControl}))}catch(e){if(r.signal.aborted)return n(null,null);if(e instanceof DOMException&&"AbortError"===e.name)return n(null,null);n(e instanceof Error?e:new Error(String(e)))}finally{delete this.loading[t]}}reloadTile(e,t){t(null,null)}abortTile(e,t){const i=e.uid,r=this.loading[i];r&&(r.cancel(),delete this.loading[i]),t()}removeTile(e,t){t()}getImageData(e,t){this.offscreenCanvas&&this.offscreenCanvasContext||(this.offscreenCanvas=new OffscreenCanvas(e.width,e.height),this.offscreenCanvasContext=this.offscreenCanvas.getContext("2d",{willReadFrequently:!0})),this.offscreenCanvas.width=e.width,this.offscreenCanvas.height=e.height,this.offscreenCanvasContext.drawImage(e,0,0,e.width,e.height);const i=this.offscreenCanvasContext.getImageData(-t,-t,e.width+2*t,e.height+2*t);return this.offscreenCanvasContext.clearRect(0,0,this.offscreenCanvas.width,this.offscreenCanvas.height),i}}t.b1.setPbf(t.b2);class v{constructor(e){this._mrt=new t.b1(e.partial?30:1/0),this._isHeaderLoaded=!1,this.uid=e.uid,this.tileID=e.tileID,this.source=e.source}parse(e,i){const r=this._mrt;this.status="parsing",this._entireBuffer=e;try{r.parseHeader(e),this._isHeaderLoaded=!0;const n=[];for(const i in r.layers){const o=r.getLayer(i),s=o.getDataRange(o.getBandList()),a=r.createDecodingTask(s),l=e.slice(s.firstByte,s.lastByte+1),c=t.b1.performDecoding(l,a).then(e=>a.complete(null,e)).catch(e=>a.complete(e,null));n.push(c)}Promise.allSettled(n).then(()=>i(null,r)).catch(e=>i(e))}catch(e){i(e)}}}class b{constructor({actor:e}){this.actor=e,this.loading={},this.loaded={}}loadTile(e,i){const r=e.uid,n=e.request,o=this.loading[r]=new v(e),{cancel:s}=t.b4(n,(e,t,n)=>{const s=!this.loading[r];if(delete this.loading[r],s||e||!t)return o.status="done",s||(this.loaded[r]=o),i(e);o.parse(t,(e,t)=>{if(e||!t)return i(e);i(null,t,n)}),this.loaded[r]=o});o.abort=s}reloadTile(e,t){t(null,void 0)}abortTile(e,t){const i=e.uid,r=this.loading[i];r&&(r.abort&&r.abort(),delete this.loading[i]),t()}removeTile(e,t){const i=e.uid;this.loaded[i]&&delete this.loaded[i],t()}decodeRasterArray(e,i){t.b1.performDecoding(e.buffer,e.task).then(e=>i(null,e)).catch(e=>i(e))}}const w=t.fE.prototype.toGeoJSON;class T{constructor(e){this._feature=e,this.extent=t.ak,this.type=e.type,this.properties=e.tags,"id"in e&&!isNaN(e.id)&&(this.id=parseInt(e.id,10))}loadGeometry(){if(1===this._feature.type){const e=[];for(const i of this._feature.geometry)e.push([new t.P(i[0],i[1])]);return e}{const e=[];for(const i of this._feature.geometry){const r=[];for(const e of i)r.push(new t.P(e[0],e[1]));e.push(r)}return e}}toGeoJSON(e,t,i){return w.call(this,e,t,i)}}class S{constructor(e,i){this.name=e,this.extent=t.ak,this.length=i.length,this._jsonFeatures=i}feature(e){return new T(this._jsonFeatures[e])}}class I{constructor(e){this.layers={},this.extent=t.ak;for(const t of Object.keys(e))this.layers[t]=new S(t,e[t])}}const E=64/4096;class A{constructor(){this.features=/* @__PURE__ */new Map}clear(){this.features.clear()}load(e=[],t){for(const i of e){const e=i.id;if(null==e)continue;let r=this.features.get(e);r&&this.updateCache(r,t),i.geometry?(r=C(i),this.updateCache(r,t),this.features.set(e,r)):this.features.delete(e),this.updateCache(r,t)}}updateCache(e,t){for(const{canonical:i,uid:r}of Object.values(t)){const{z:n,x:o,y:s}=i;M(e,Math.pow(2,n),o,s)&&delete t[r]}}getTile(e,t,i){const r=Math.pow(2,e),n=[];for(const o of this.features.values())M(o,r,t,i)&&n.push(z(o,r,t,i));return{features:n}}getFeatures(){return[...this.features.values()]}}function M({minX:e,minY:t,maxX:i,maxY:r},n,o,s){return e<(o+1+E)/n&&t<(s+1+E)/n&&i>(o-E)/n&&r>(s-E)/n}function C(e){const{id:t,geometry:i,properties:r}=e;if(!i)return;if("GeometryCollection"===i.type)throw new Error("GeometryCollection not supported in dynamic mode.");const{type:n,coordinates:o}=i,s={id:t,type:1,geometry:[],tags:r,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0},a=s.geometry;if("Point"===n)P(o,a,s);else if("MultiPoint"===n)for(const l of o)P(l,a,s);else if("LineString"===n)s.type=2,D(o,a,s);else if("MultiLineString"===n)s.type=2,R(o,a,s);else if("Polygon"===n)s.type=3,R(o,a,s,!0);else{if("MultiPolygon"!==n)throw new Error("Input data is not a valid GeoJSON object.");s.type=3;for(const e of o)R(e,a,s,!0)}return s}function P([e,i],r,n){const o=t.aG(e);let s=t.aJ(i);s=s<0?0:s>1?1:s,r.push(o,s),n.minX=Math.min(n.minX,o),n.minY=Math.min(n.minY,s),n.maxX=Math.max(n.maxX,o),n.maxY=Math.max(n.maxY,s)}function D(e,t,i,r=!1,n=!1){const o=[];for(const s of e)P(s,o,i);t.push(o),r&&function(e,t){let i=0;for(let r=0,n=e.length,o=n-2;r<n;o=r,r+=2)i+=(e[r]-e[o])*(e[r+1]+e[o+1]);if(i>0===t)for(let r=0,n=e.length;r<n/2;r+=2){const t=e[r],i=e[r+1];e[r]=e[n-2-r],e[r+1]=e[n-1-r],e[n-2-r]=t,e[n-1-r]=i}}(o,n)}function R(e,t,i,r=!1){for(let n=0;n<e.length;n++)D(e[n],t,i,r,0===n)}function z(e,i,r,n){const{id:o,type:s,geometry:a,tags:l}=e,c=[];if(1===s)!function(e,i,r,n,o){for(let s=0;s<e.length;s+=2){const a=Math.round(t.ak*(e[s+0]*i-r)),l=Math.round(t.ak*(e[s+1]*i-n));o.push([a,l])}}(a,i,r,n,c);else if(2===s)for(const t of a)L(t,i,r,n,c);else if(3===s)for(const t of a)F(t,i,r,n,c);return{id:o,type:s,geometry:c,tags:l}}function L(e,i,r,n,o){const s=-128,a=t.ak+128;let l;for(let c=0;c<e.length-2;c+=2){let h=Math.round(t.ak*(e[c+0]*i-r)),u=Math.round(t.ak*(e[c+1]*i-n)),d=Math.round(t.ak*(e[c+2]*i-r)),p=Math.round(t.ak*(e[c+3]*i-n));const f=d-h,m=p-u;h<s&&d<s||(h<s?(u+=Math.round(m*((s-h)/f)),h=s):d<s&&(p=u+Math.round(m*((s-h)/f)),d=s),u<s&&p<s||(u<s?(h+=Math.round(f*((s-u)/m)),u=s):p<s&&(d=h+Math.round(f*((s-u)/m)),p=s),h>=a&&d>=a||(h>=a?(u+=Math.round(m*((a-h)/f)),h=a):d>=a&&(p=u+Math.round(m*((a-h)/f)),d=a),u>=a&&p>=a||(u>=a?(h+=Math.round(f*((a-u)/m)),u=a):p>=a&&(d=h+Math.round(f*((a-u)/m)),p=a),l&&h===l.at(-1)[0]&&u===l.at(-1)[1]||(l=[[h,u]],o.push(l)),l.push([d,p])))))}}function F(e,i,r,n,o){const s=(r-E)/i,a=(n-E)/i,l=(r+1+E)/i,c=(n+1+E)/i;function h(e,t){let i=0;return e<s?i|=1:e>l&&(i|=2),t<a?i|=4:t>c&&(i|=8),i}let u=[];for(let t=1;t<=8;t*=2){let i=e[e.length-2],r=e.at(-1),n=!(h(i,r)&t);for(let o=0;o<e.length;o+=2){const d=e[o],p=e[o+1],f=!(h(d,p)&t);f!==n&&(8&t?u.push(i+(d-i)*(c-r)/(p-r),c):4&t?u.push(i+(d-i)*(a-r)/(p-r),a):2&t?u.push(l,r+(p-r)*(l-i)/(d-i)):1&t&&u.push(s,r+(p-r)*(s-i)/(d-i))),f&&u.push(d,p),i=d,r=p,n=f}if(!(e=u).length||8===t)break;u=[]}const d=[];for(let p=0;p<u.length;p+=2)d.push([Math.round(t.ak*(u[p]*i-r)),Math.round(t.ak*(u[p+1]*i-n))]);d.length&&o.push(d)}function O({name:e,features:i},r){r.writeStringField(1,e),r.writeVarintField(5,t.ak);const n=/* @__PURE__ */new Map,o=/* @__PURE__ */new Map,s={keys:n,values:o,feature:null};for(const t of i)s.feature=t,r.writeMessage(2,B,s);for(const t of n.keys())r.writeStringField(3,t);for(const t of o.keys())r.writeMessage(4,j,t)}function B(e,t){const i=e.feature;void 0!==i.id&&Number.isSafeInteger(+i.id)&&t.writeVarintField(1,+i.id),i.tags&&t.writeMessage(2,k,e),t.writeVarintField(3,i.type),t.writeMessage(4,V,i)}function k({keys:e,values:t,feature:i},r){for(const n of Object.keys(i.tags)){let o=i.tags[n];if(null===o)continue;let s=e.get(n);void 0===s&&(s=e.size,e.set(n,s)),r.writeVarint(s);const a=typeof o;"string"!==a&&"boolean"!==a&&"number"!==a&&(o=JSON.stringify(o));let l=t.get(o);void 0===l&&(l=t.size,t.set(o,l)),r.writeVarint(l)}}function N(e,t){return(t<<3)+(7&e)}function U(e){return e<<1^e>>31}function V(e,t){const{geometry:i,type:r}=e;let n=0,o=0;if(1===r){t.writeVarint(N(1,i.length));for(const e of i){const i=e[0]-n,r=e[1]-o;t.writeVarint(U(i)),t.writeVarint(U(r)),n+=i,o+=r}}else for(const s of i){if(0===s.length)continue;t.writeVarint(N(1,1));const e=s.length-(3===r?1:0);for(let i=0;i<e;i++){1===i&&t.writeVarint(N(2,e-1));const r=s[i][0]-n,a=s[i][1]-o;t.writeVarint(U(r)),t.writeVarint(U(a)),n+=r,o+=a}3===r&&t.writeVarint(N(7,1))}}function j(e,t){const i=typeof e;"string"===i?t.writeStringField(1,e):"boolean"===i?t.writeBooleanField(7,e):"number"===i&&(e%1!=0?t.writeDoubleField(3,e):e<0?t.writeSVarintField(6,e):t.writeVarintField(5,e))}const G={minZoom:0,maxZoom:16,minPoints:2,radius:40,extent:512,nodeSize:64,log:!1,generateId:!1,reduce:null,map:e=>e},H=Math.fround||($=new Float32Array(1),e=>($[0]=+e,$[0]));var $;class q{constructor(e){this.options=Object.assign(Object.create(G),e),this.trees=new Array(this.options.maxZoom+1),this.stride=this.options.reduce?7:6,this.clusterProps=[]}load(e){const{log:t,minZoom:i,maxZoom:r}=this.options;t&&console.time("total time");const n=`prepare ${e.length} points`;t&&console.time(n),this.points=e;const o=[];for(let a=0;a<e.length;a++){const t=e[a];if(!t.geometry)continue;const[i,r]=t.geometry.coordinates,n=H(X(i)),s=H(Y(r));o.push(n,s,1/0,a,-1,1),this.options.reduce&&o.push(0)}let s=this.trees[r+1]=this._createTree(o);t&&console.timeEnd(n);for(let a=r;a>=i;a--){const e=+Date.now();s=this.trees[a]=this._createTree(this._cluster(s,a)),t&&console.log("z%d: %d clusters in %dms",a,s.numItems,+Date.now()-e)}return t&&console.timeEnd("total time"),this}getClusters(e,t){let i=((e[0]+180)%360+360)%360-180;const r=Math.max(-90,Math.min(90,e[1]));let n=180===e[2]?180:((e[2]+180)%360+360)%360-180;const o=Math.max(-90,Math.min(90,e[3]));if(e[2]-e[0]>=360)i=-180,n=180;else if(i>n){const e=this.getClusters([i,r,180,o],t),s=this.getClusters([-180,r,n,o],t);return e.concat(s)}const s=this.trees[this._limitZoom(t)],a=s.range(X(i),Y(o),X(n),Y(r)),l=s.data,c=[];for(const h of a){const e=this.stride*h;c.push(l[e+5]>1?Z(l,e,this.clusterProps):this.points[l[e+3]])}return c}getChildren(e){const t=this._getOriginId(e),i=this._getOriginZoom(e),r="No cluster with the specified id.",n=this.trees[i];if(!n)throw new Error(r);const o=n.data;if(t*this.stride>=o.length)throw new Error(r);const s=this.options.radius/(this.options.extent*Math.pow(2,i-1)),a=n.within(o[t*this.stride],o[t*this.stride+1],s),l=[];for(const c of a){const t=c*this.stride;o[t+4]===e&&l.push(o[t+5]>1?Z(o,t,this.clusterProps):this.points[o[t+3]])}if(0===l.length)throw new Error(r);return l}getLeaves(e,t,i){const r=[];return this._appendLeaves(r,e,t=t||10,i=i||0,0),r}getTile(e,t,i){const r=this.trees[this._limitZoom(e)],n=Math.pow(2,e),{extent:o,radius:s}=this.options,a=s/o,l=(i-a)/n,c=(i+1+a)/n,h={features:[]};return this._addTileFeatures(r.range((t-a)/n,l,(t+1+a)/n,c),r.data,t,i,n,h),0===t&&this._addTileFeatures(r.range(1-a/n,l,1,c),r.data,n,i,n,h),t===n-1&&this._addTileFeatures(r.range(0,l,a/n,c),r.data,-1,i,n,h),h.features.length?h:null}getClusterExpansionZoom(e){let t=this._getOriginZoom(e)-1;for(;t<=this.options.maxZoom;){const i=this.getChildren(e);if(t++,1!==i.length)break;e=i[0].properties.cluster_id}return t}_appendLeaves(e,t,i,r,n){const o=this.getChildren(t);for(const s of o){const t=s.properties;if(t&&t.cluster?n+t.point_count<=r?n+=t.point_count:n=this._appendLeaves(e,t.cluster_id,i,r,n):n<r?n++:e.push(s),e.length===i)break}return n}_createTree(e){const i=new t.bM(e.length/this.stride|0,this.options.nodeSize,Float32Array);for(let t=0;t<e.length;t+=this.stride)i.add(e[t],e[t+1]);return i.finish(),i.data=e,i}_addTileFeatures(e,t,i,r,n,o){for(const s of e){const e=s*this.stride,a=t[e+5]>1;let l,c,h;if(a)l=W(t,e,this.clusterProps),c=t[e],h=t[e+1];else{const i=this.points[t[e+3]];l=i.properties;const[r,n]=i.geometry.coordinates;c=X(r),h=Y(n)}const u={type:1,geometry:[[Math.round(this.options.extent*(c*n-i)),Math.round(this.options.extent*(h*n-r))]],tags:l};let d;d=a||this.options.generateId?t[e+3]:this.points[t[e+3]].id,void 0!==d&&(u.id=d),o.features.push(u)}}_limitZoom(e){return Math.max(this.options.minZoom,Math.min(Math.floor(+e),this.options.maxZoom+1))}_cluster(e,t){const{radius:i,extent:r,reduce:n,minPoints:o}=this.options,s=i/(r*Math.pow(2,t)),a=e.data,l=[],c=this.stride;for(let h=0;h<a.length;h+=c){if(a[h+2]<=t)continue;a[h+2]=t;const i=a[h],r=a[h+1],u=e.within(a[h],a[h+1],s),d=a[h+5];let p=d;for(const e of u){const i=e*c;a[i+2]>t&&(p+=a[i+5])}if(p>d&&p>=o){let e,o=i*d,s=r*d,f=-1;const m=(h/c<<5)+(t+1)+this.points.length;for(const i of u){const r=i*c;if(a[r+2]<=t)continue;a[r+2]=t;const l=a[r+5];o+=a[r]*l,s+=a[r+1]*l,a[r+4]=m,n&&(e||(e=this._map(a,h,!0),f=this.clusterProps.length,this.clusterProps.push(e)),n(e,this._map(a,r)))}a[h+4]=m,l.push(o/p,s/p,1/0,m,-1,p),n&&l.push(f)}else{for(let e=0;e<c;e++)l.push(a[h+e]);if(p>1)for(const e of u){const i=e*c;if(!(a[i+2]<=t)){a[i+2]=t;for(let e=0;e<c;e++)l.push(a[i+e])}}}}return l}_getOriginId(e){return e-this.points.length>>5}_getOriginZoom(e){return(e-this.points.length)%32}_map(e,t,i){if(e[t+5]>1){const r=this.clusterProps[e[t+6]];return i?Object.assign({},r):r}const r=this.points[e[t+3]].properties,n=this.options.map(r);return i&&n===r?Object.assign({},n):n}}function Z(e,t,i){return{type:"Feature",id:e[t+3],properties:W(e,t,i),geometry:{type:"Point",coordinates:[(r=e[t],360*(r-.5)),J(e[t+1])]}};var r}function W(e,t,i){const r=e[t+5],n=r>=1e4?`${Math.round(r/1e3)}k`:r>=1e3?Math.round(r/100)/10+"k":r,o=e[t+6],s=-1===o?{}:Object.assign({},i[o]);return Object.assign(s,{cluster:!0,cluster_id:e[t+3],point_count:r,point_count_abbreviated:n})}function X(e){return e/360+.5}function Y(e){const t=Math.sin(e*Math.PI/180),i=.5-.25*Math.log((1+t)/(1-t))/Math.PI;return i<0?0:i>1?1:i}function J(e){const t=(180-360*e)*Math.PI/180;return 360*Math.atan(Math.exp(t))/Math.PI-90}function K(e,t,i,r){let n=r;const o=t+(i-t>>1);let s,a=i-t;const l=e[t],c=e[t+1],h=e[i],u=e[i+1];for(let d=t+3;d<i;d+=3){const t=Q(e[d],e[d+1],l,c,h,u);if(t>n)s=d,n=t;else if(t===n){const e=Math.abs(d-o);e<a&&(s=d,a=e)}}n>r&&(s-t>3&&K(e,t,s,r),e[s+2]=n,i-s>3&&K(e,s,i,r))}function Q(e,t,i,r,n,o){let s=n-i,a=o-r;if(0!==s||0!==a){const l=((e-i)*s+(t-r)*a)/(s*s+a*a);l>1?(i=n,r=o):l>0&&(i+=s*l,r+=a*l)}return s=e-i,a=t-r,s*s+a*a}function ee(e,t,i,r){const n={id:e??null,type:t,geometry:i,tags:r,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0};if("Point"===t||"MultiPoint"===t||"LineString"===t)te(n,i);else if("Polygon"===t)te(n,i[0]);else if("MultiLineString"===t)for(const o of i)te(n,o);else if("MultiPolygon"===t)for(const o of i)te(n,o[0]);return n}function te(e,t){for(let i=0;i<t.length;i+=3)e.minX=Math.min(e.minX,t[i]),e.minY=Math.min(e.minY,t[i+1]),e.maxX=Math.max(e.maxX,t[i]),e.maxY=Math.max(e.maxY,t[i+1])}function ie(e,t,i,r){if(!t.geometry)return;const n=t.geometry.coordinates;if(n&&0===n.length)return;const o=t.geometry.type,s=Math.pow(i.tolerance/((1<<i.maxZoom)*i.extent),2);let a=[],l=t.id;if(i.promoteId?l=t.properties[i.promoteId]:i.generateId&&(l=r||0),"Point"===o)re(n,a);else if("MultiPoint"===o)for(const c of n)re(c,a);else if("LineString"===o)ne(n,a,s,!1);else if("MultiLineString"===o){if(i.lineMetrics){for(const i of n)a=[],ne(i,a,s,!1),e.push(ee(l,"LineString",a,t.properties));return}oe(n,a,s,!1)}else if("Polygon"===o)oe(n,a,s,!0);else{if("MultiPolygon"!==o){if("GeometryCollection"===o){for(const n of t.geometry.geometries)ie(e,{id:l,geometry:n,properties:t.properties},i,r);return}throw new Error("Input data is not a valid GeoJSON object.")}for(const e of n){const t=[];oe(e,t,s,!0),a.push(t)}}e.push(ee(l,o,a,t.properties))}function re(e,t){t.push(se(e[0]),ae(e[1]),0)}function ne(e,t,i,r){let n,o,s=0;for(let l=0;l<e.length;l++){const i=se(e[l][0]),a=ae(e[l][1]);t.push(i,a,0),l>0&&(s+=r?(n*a-i*o)/2:Math.sqrt(Math.pow(i-n,2)+Math.pow(a-o,2))),n=i,o=a}const a=t.length-3;t[2]=1,K(t,0,a,i),t[a+2]=1,t.size=Math.abs(s),t.start=0,t.end=t.size}function oe(e,t,i,r){for(let n=0;n<e.length;n++){const o=[];ne(e[n],o,i,r),t.push(o)}}function se(e){return e/360+.5}function ae(e){const t=Math.sin(e*Math.PI/180),i=.5-.25*Math.log((1+t)/(1-t))/Math.PI;return i<0?0:i>1?1:i}function le(e,t,i,r,n,o,s,a){if(r/=t,o>=(i/=t)&&s<r)return e;if(s<i||o>=r)return null;const l=[];for(const c of e){const e=c.geometry;let t=c.type;const o=0===n?c.minX:c.minY,s=0===n?c.maxX:c.maxY;if(o>=i&&s<r){l.push(c);continue}if(s<i||o>=r)continue;let h=[];if("Point"===t||"MultiPoint"===t)ce(e,h,i,r,n);else if("LineString"===t)he(e,h,i,r,n,!1,a.lineMetrics);else if("MultiLineString"===t)de(e,h,i,r,n,!1);else if("Polygon"===t)de(e,h,i,r,n,!0);else if("MultiPolygon"===t)for(const a of e){const e=[];de(a,e,i,r,n,!0),e.length&&h.push(e)}if(h.length){if(a.lineMetrics&&"LineString"===t){for(const e of h)l.push(ee(c.id,t,e,c.tags));continue}"LineString"!==t&&"MultiLineString"!==t||(1===h.length?(t="LineString",h=h[0]):t="MultiLineString"),"Point"!==t&&"MultiPoint"!==t||(t=3===h.length?"Point":"MultiPoint"),l.push(ee(c.id,t,h,c.tags))}}return l.length?l:null}function ce(e,t,i,r,n){for(let o=0;o<e.length;o+=3){const s=e[o+n];s>=i&&s<=r&&pe(t,e[o],e[o+1],e[o+2])}}function he(e,t,i,r,n,o,s){let a=ue(e);const l=0===n?fe:me;let c,h,u=e.start;for(let _=0;_<e.length-3;_+=3){const d=e[_],p=e[_+1],f=e[_+2],m=e[_+3],g=e[_+4],y=0===n?d:p,x=0===n?m:g;let v=!1;s&&(c=Math.sqrt(Math.pow(d-m,2)+Math.pow(p-g,2))),y<i?x>i&&(h=l(a,d,p,m,g,i),s&&(a.start=u+c*h)):y>r?x<r&&(h=l(a,d,p,m,g,r),s&&(a.start=u+c*h)):pe(a,d,p,f),x<i&&y>=i&&(h=l(a,d,p,m,g,i),v=!0),x>r&&y<=r&&(h=l(a,d,p,m,g,r),v=!0),!o&&v&&(s&&(a.end=u+c*h),t.push(a),a=ue(e)),s&&(u+=c)}let d=e.length-3;const p=e[d],f=e[d+1],m=0===n?p:f;m>=i&&m<=r&&pe(a,p,f,e[d+2]),d=a.length-3,o&&d>=3&&(a[d]!==a[0]||a[d+1]!==a[1])&&pe(a,a[0],a[1],a[2]),a.length&&t.push(a)}function ue(e){const t=[];return t.size=e.size,t.start=e.start,t.end=e.end,t}function de(e,t,i,r,n,o){for(const s of e)he(s,t,i,r,n,o,!1)}function pe(e,t,i,r){e.push(t,i,r)}function fe(e,t,i,r,n,o){const s=(o-t)/(r-t);return pe(e,o,i+(n-i)*s,1),s}function me(e,t,i,r,n,o){const s=(o-i)/(n-i);return pe(e,t+(r-t)*s,o,1),s}function _e(e,t){const i=[];for(let r=0;r<e.length;r++){const n=e[r],o=n.type;let s;if("Point"===o||"MultiPoint"===o||"LineString"===o)s=ge(n.geometry,t);else if("MultiLineString"===o||"Polygon"===o){s=[];for(const e of n.geometry)s.push(ge(e,t))}else if("MultiPolygon"===o){s=[];for(const e of n.geometry){const i=[];for(const r of e)i.push(ge(r,t));s.push(i)}}i.push(ee(n.id,o,s,n.tags))}return i}function ge(e,t){const i=[];i.size=e.size,void 0!==e.start&&(i.start=e.start,i.end=e.end);for(let r=0;r<e.length;r+=3)i.push(e[r]+t,e[r+1],e[r+2]);return i}function ye(e,t){if(e.transformed)return e;const i=1<<e.z,r=e.x,n=e.y;for(const o of e.features){const e=o.geometry,s=o.type;if(o.geometry=[],1===s)for(let a=0;a<e.length;a+=2)o.geometry.push(xe(e[a],e[a+1],t,i,r,n));else for(let a=0;a<e.length;a++){const s=[];for(let o=0;o<e[a].length;o+=2)s.push(xe(e[a][o],e[a][o+1],t,i,r,n));o.geometry.push(s)}}return e.transformed=!0,e}function xe(e,t,i,r,n,o){return[Math.round(i*(e*r-n)),Math.round(i*(t*r-o))]}function ve(e,t,i,r,n){const o=t===n.maxZoom?0:n.tolerance/((1<<t)*n.extent),s={features:[],numPoints:0,numSimplified:0,numFeatures:e.length,source:null,x:i,y:r,z:t,transformed:!1,minX:2,minY:1,maxX:-1,maxY:0};for(const a of e)be(s,a,o,n);return s}function be(e,t,i,r){const n=t.geometry,o=t.type,s=[];if(e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),"Point"===o||"MultiPoint"===o)for(let a=0;a<n.length;a+=3)s.push(n[a],n[a+1]),e.numPoints++,e.numSimplified++;else if("LineString"===o)we(s,n,e,i,!1,!1);else if("MultiLineString"===o||"Polygon"===o)for(let a=0;a<n.length;a++)we(s,n[a],e,i,"Polygon"===o,0===a);else if("MultiPolygon"===o)for(let a=0;a<n.length;a++){const t=n[a];for(let r=0;r<t.length;r++)we(s,t[r],e,i,!0,0===r)}if(s.length){let i=t.tags||null;if("LineString"===o&&r.lineMetrics){i={};for(const e in t.tags)i[e]=t.tags[e];i.mapbox_clip_start=n.start/n.size,i.mapbox_clip_end=n.end/n.size}const a={geometry:s,type:"Polygon"===o||"MultiPolygon"===o?3:"LineString"===o||"MultiLineString"===o?2:1,tags:i};null!==t.id&&(a.id=t.id),e.features.push(a)}}function we(e,t,i,r,n,o){const s=r*r;if(r>0&&t.size<(n?s:r))return void(i.numPoints+=t.length/3);const a=[];for(let l=0;l<t.length;l+=3)(0===r||t[l+2]>s)&&(i.numSimplified++,a.push(t[l],t[l+1])),i.numPoints++;n&&function(e,t){let i=0;for(let r=0,n=e.length,o=n-2;r<n;o=r,r+=2)i+=(e[r]-e[o])*(e[r+1]+e[o+1]);if(i>0===t)for(let r=0,n=e.length;r<n/2;r+=2){const t=e[r],i=e[r+1];e[r]=e[n-2-r],e[r+1]=e[n-1-r],e[n-2-r]=t,e[n-1-r]=i}}(a,o),e.push(a)}const Te={maxZoom:14,indexMaxZoom:5,indexMaxPoints:1e5,tolerance:3,extent:4096,buffer:64,lineMetrics:!1,promoteId:null,generateId:!1,debug:0};class Se{constructor(e,t){const i=(t=this.options=function(e,t){for(const i in t)e[i]=t[i];return e}(Object.create(Te),t)).debug;if(i&&console.time("preprocess data"),t.maxZoom<0||t.maxZoom>24)throw new Error("maxZoom should be in the 0-24 range");if(t.promoteId&&t.generateId)throw new Error("promoteId and generateId cannot be used together.");let r=function(e,t){const i=[];if("FeatureCollection"===e.type)for(let r=0;r<e.features.length;r++)ie(i,e.features[r],t,r);else ie(i,"Feature"===e.type?e:{geometry:e},t);return i}(e,t);this.tiles={},this.tileCoords=[],i&&(console.timeEnd("preprocess data"),console.log("index: maxZoom: %d, maxPoints: %d",t.indexMaxZoom,t.indexMaxPoints),console.time("generate tiles"),this.stats={},this.total=0),r=function(e,t){const i=t.buffer/t.extent;let r=e;const n=le(e,1,-1-i,i,0,-1,2,t),o=le(e,1,1-i,2+i,0,-1,2,t);return(n||o)&&(r=le(e,1,-i,1+i,0,-1,2,t)||[],n&&(r=_e(n,1).concat(r)),o&&(r=r.concat(_e(o,-1)))),r}(r,t),r.length&&this.splitTile(r,0,0,0),i&&(r.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(e,t,i,r,n,o,s){const a=[e,t,i,r],l=this.options,c=l.debug;for(;a.length;){r=a.pop(),i=a.pop(),t=a.pop(),e=a.pop();const h=1<<t,u=Ie(t,i,r);let d=this.tiles[u];if(!d&&(c>1&&console.time("creation"),d=this.tiles[u]=ve(e,t,i,r,l),this.tileCoords.push({z:t,x:i,y:r}),c)){c>1&&(console.log("tile z%d-%d-%d (features: %d, points: %d, simplified: %d)",t,i,r,d.numFeatures,d.numPoints,d.numSimplified),console.timeEnd("creation"));const e=`z${t}`;this.stats[e]=(this.stats[e]||0)+1,this.total++}if(d.source=e,null==n){if(t===l.indexMaxZoom||d.numPoints<=l.indexMaxPoints)continue}else{if(t===l.maxZoom||t===n)continue;if(null!=n){const e=n-t;if(i!==o>>e||r!==s>>e)continue}}if(d.source=null,0===e.length)continue;c>1&&console.time("clipping");const p=.5*l.buffer/l.extent,f=.5-p,m=.5+p,_=1+p;let g=null,y=null,x=null,v=null,b=le(e,h,i-p,i+m,0,d.minX,d.maxX,l),w=le(e,h,i+f,i+_,0,d.minX,d.maxX,l);e=null,b&&(g=le(b,h,r-p,r+m,1,d.minY,d.maxY,l),y=le(b,h,r+f,r+_,1,d.minY,d.maxY,l),b=null),w&&(x=le(w,h,r-p,r+m,1,d.minY,d.maxY,l),v=le(w,h,r+f,r+_,1,d.minY,d.maxY,l),w=null),c>1&&console.timeEnd("clipping"),a.push(g||[],t+1,2*i,2*r),a.push(y||[],t+1,2*i,2*r+1),a.push(x||[],t+1,2*i+1,2*r),a.push(v||[],t+1,2*i+1,2*r+1)}}getTile(e,t,i){e=+e,t=+t,i=+i;const{extent:r,debug:n}=this.options;if(e<0||e>24)return null;const o=1<<e,s=Ie(e,t=t+o&o-1,i);if(this.tiles[s])return ye(this.tiles[s],r);n>1&&console.log("drilling down to z%d-%d-%d",e,t,i);let a,l=e,c=t,h=i;for(;!a&&l>0;)l--,c>>=1,h>>=1,a=this.tiles[Ie(l,c,h)];return a&&a.source?(n>1&&(console.log("found parent tile z%d-%d-%d",l,c,h),console.time("drilling down")),this.splitTile(a.source,l,c,h,e,t,i),n>1&&console.timeEnd("drilling down"),this.tiles[s]?ye(this.tiles[s],r):null):null}}function Ie(e,t,i){return 32*((1<<e)*i+t)+e}function Ee(e,i){const r=e.tileID.canonical;if(!this._geoJSONIndex)return void i(null,null);const n=this._geoJSONIndex.getTile(r.z,r.x,r.y);if(!n)return void i(null,null);const o=e=>e.tags&&"3d_elevation_id"in e.tags&&"source"in e.tags&&"elevation"===e.tags.source,s=n.features.filter(e=>o(e));let a={_geojsonTileLayer:n.features};s.length>0&&(a={_geojsonTileLayer:n.features.filter(e=>!o(e)),hd_road_elevation:s});const l=new I(a),c=function(e){const i=new t.b2;for(const t of Object.keys(e))i.writeMessage(3,O,{name:t,features:e[t]});return i.finish()}(a).buffer;i(null,{vectorTile:l,rawData:c})}class Ae extends y{constructor(e){super(e),this.loadVectorData=Ee,this._dynamicIndex=new A}loadData(e,r){const n=e&&e.request,o=n&&n.collectResourceTiming;this._geoJSONIndex=null,this.loadGeoJSON(e,(s,a)=>{if(s||!a)return r(s);if("object"!=typeof a)return r(/* @__PURE__ */new Error(`Input data given to '${e.source}' is not a valid GeoJSON object.`));{try{if(e.filter){const i=t.U(e.filter,{type:"boolean","property-type":"data-driven",overridable:!1,transition:!1});if("error"===i.result)throw new Error(i.value.map(e=>`${e.key}: ${e.message}`).join(", "));a.features=a.features.filter(e=>i.value.evaluate({zoom:0},e))}e.dynamic?("Feature"===a.type&&(a={type:"FeatureCollection",features:[a]}),e.append||(this._dynamicIndex.clear(),this.loaded={}),this._dynamicIndex.load(a.features,this.loaded),e.cluster&&(a.features=this._dynamicIndex.getFeatures())):this.loaded={},this._geoJSONIndex=e.cluster?new q(function({superclusterOptions:e,clusterProperties:i}){if(!i||!e)return e;const r={},n={},o={accumulated:null,zoom:0},s={properties:null},a=Object.keys(i);for(const l of a){const[e,o]=i[l],s=t.U(o),a=t.U("string"==typeof e?[e,["accumulated"],["get",l]]:e);r[l]=s.value,n[l]=a.value}return e.map=e=>{s.properties=e;const t={};for(const i of a)t[i]=r[i].evaluate(o,s);return t},e.reduce=(e,t)=>{s.properties=t;for(const i of a)o.accumulated=e[i],e[i]=n[i].evaluate(o,s)},e}(e)).load(a.features):e.dynamic?this._dynamicIndex:function(e,t){return new Se(e,t)}(a,e.geojsonVtOptions)}catch(e){return r(e)}const s={};if(o){const t=i(n);t&&(s.resourceTiming={},s.resourceTiming[e.source]=JSON.parse(JSON.stringify(t)))}r(null,s)}})}reloadTile(e,t){const i=this.loaded;return i&&i[e.uid]?e.partial?t(null,void 0):super.reloadTile(e,t):this.loadTile(e,t)}loadGeoJSON(e,i){if(e.request)t.m(e.request,i);else{if("string"!=typeof e.data)return i(/* @__PURE__ */new Error(`Input data given to '${e.source}' is not a valid GeoJSON object.`));setTimeout(()=>{try{return i(null,JSON.parse(e.data))}catch(t){return i(/* @__PURE__ */new Error(`Input data given to '${e.source}' is not a valid GeoJSON object.`))}},0)}}getClusterExpansionZoom(e,t){try{t(null,this._geoJSONIndex.getClusterExpansionZoom(e.clusterId))}catch(e){t(e)}}getClusterChildren(e,t){try{t(null,this._geoJSONIndex.getChildren(e.clusterId))}catch(e){t(e)}}getClusterLeaves(e,t){try{t(null,this._geoJSONIndex.getLeaves(e.clusterId,e.limit,e.offset))}catch(e){t(e)}}}class Me{constructor(e,i,r){this.tileID=new t.aU(e.tileID.overscaledZ,e.tileID.wrap,e.tileID.canonical.z,e.tileID.canonical.x,e.tileID.canonical.y),this.tileZoom=e.tileZoom,this.uid=e.uid,this.zoom=e.zoom,this.canonical=e.tileID.canonical,this.pixelRatio=e.pixelRatio,this.tileSize=e.tileSize,this.source=e.source,this.overscaling=this.tileID.overscaleFactor(),this.projection=e.projection,this.brightness=i,this.worldview=r}parse(e,i,r,n){this.status="parsing";const o=new t.aU(r.tileID.overscaledZ,r.tileID.wrap,r.tileID.canonical.z,r.tileID.canonical.x,r.tileID.canonical.y),s=[],a=i.familiesBySource[r.source],l=new t.fj(o,r.promoteId);l.bucketLayerIDs=[],l.is3DTile=!0,t.fF(e).then(e=>{const i=e.json.extensionsUsed&&e.json.extensionsUsed.includes("MAPBOX_mesh_features")||e.json.asset.extras&&e.json.asset.extras.MAPBOX_mesh_features,c=e.json.extensionsUsed&&e.json.extensionsUsed.includes("EXT_meshopt_compression"),h=new t.ab(this.zoom,{brightness:this.brightness,worldview:this.worldview});for(const n in a)for(const u of a[n]){const n=u[0];l.bucketLayerIDs.push(u.map(e=>t.t(e.id,e.scope))),n.recalculate(h,[]);const a=t.fG(e,1/t.cW(r.tileID.canonical)),d=new t.fH(u,a,o,i,c,this.brightness,l,this.worldview);i||(d.needsUpload=!0),s.push(d),d.evaluate(n)}this.status="done",n(null,{buckets:s,featureIndex:l,collisionBoxArray:null,glyphAtlasImage:null,lineAtlas:null,imageAtlas:null,brightness:null})}).catch(e=>n(new Error(e.message)))}}class Ce{constructor({actor:e,layerIndex:t,availableImages:i,availableModels:r,brightness:n,worldview:o}){this.actor=e,this.layerIndex=t,this.availableImages=i,this.availableModels=r,this.brightness=n,this.loading={},this.loaded={},this.worldview=o}loadTile(e,i){const r=e.uid,n=this.loading[r]=new Me(e,this.brightness,this.worldview);t.b4(e.request,(t,o)=>{const s=!this.loading[r];return delete this.loading[r],s||t?(n.status="done",s||(this.loaded[r]=n),i(t)):o&&0!==o.byteLength?void n.parse(o,this.layerIndex,e,(e,t)=>{n.status="done",this.loaded=this.loaded||{},this.loaded[r]=n,e||!t?i(e):i(null,t)}):(n.status="done",this.loaded[r]=n,i())})}reloadTile(e,t){const i=this.loaded,r=e.uid;if(i&&i[r]){const n=i[r];n.projection=e.projection,n.brightness=e.brightness;const o=(i,r)=>{n.reloadCallback&&(delete n.reloadCallback,this.loadTile(e,t)),t(i,r)};"parsing"===n.status?n.reloadCallback=o:"done"===n.status&&this.loadTile(e,t)}}abortTile(e,t){const i=e.uid;this.loading[i]&&delete this.loading[i],t()}removeTile(e,t){const i=this.loaded,r=e.uid;i&&i[r]&&delete i[r],t()}}class Pe{constructor(e){this.self=e,this.actor=new t.ap(e,this),this.layerIndexes={},this.availableImages={},this.availableModels={},this.isSpriteLoaded={},this.rtlPluginParsingListeners=[],this.projections={},this.defaultProjection=t.c4({name:"mercator"}),this.workerSourceTypes={vector:y,geojson:Ae,"raster-dem":x,"raster-array":b,"batched-model":Ce},this.workerSources={},this.self.registerWorkerSource=(e,t)=>{if(this.workerSourceTypes[e])throw new Error(`Worker source with name "${e}" already registered.`);this.workerSourceTypes[e]=t},this.self.registerRTLTextPlugin=e=>{if(t.fJ.isParsed())throw new Error("RTL text plugin already registered.");t.fJ.setState({pluginStatus:t.fK.parsed,pluginURL:t.fJ.getPluginURL()}),t.fJ.applyArabicShaping=e.applyArabicShaping,t.fJ.processBidirectionalText=e.processBidirectionalText,t.fJ.processStyledBidirectionalText=e.processStyledBidirectionalText;for(const t of this.rtlPluginParsingListeners)t(null,!0);this.rtlPluginParsingListeners=[]}}clearCaches(e,t,i){delete this.layerIndexes[e],delete this.availableImages[e],delete this.availableModels[e],delete this.workerSources[e],i()}checkIfReady(e,t,i){i()}setReferrer(e,t){this.referrer=t}spriteLoaded(e,i){this.isSpriteLoaded[e]||(this.isSpriteLoaded[e]={});const{scope:r,isLoaded:n}=i;if(this.isSpriteLoaded[e][r]=n,this.workerSources[e]&&this.workerSources[e][r])for(const o in this.workerSources[e][r]){const i=this.workerSources[e][r][o];for(const e in i){const r=i[e];r instanceof y&&(r.isSpriteLoaded=n,r.fire(new t.z("isSpriteLoaded")))}}}setImages(e,t,i){this.availableImages[e]||(this.availableImages[e]={});const{scope:r,images:n}=t;if(this.availableImages[e][r]=n,this.workerSources[e]&&this.workerSources[e][r]){for(const t in this.workerSources[e][r]){const i=this.workerSources[e][r][t];for(const e in i)i[e].availableImages=n}i()}else i()}setModels(e,{scope:t,models:i},r){if(this.availableModels[e]||(this.availableModels[e]={}),this.availableModels[e][t]=i,this.workerSources[e]&&this.workerSources[e][t]){for(const r in this.workerSources[e][t]){const n=this.workerSources[e][t][r];for(const e in n)n[e].availableModels=i}r()}else r()}setProjection(e,i){this.projections[e]=t.c4(i)}setBrightness(e,t,i){this.brightness=t,i()}setContextParams(e,t,i){this.maxUniformBufferBindings=t.maxBindingPoints,this.maxUniformBlockSizeDwords=t.maxUniformBlockSizeDwords,this.disableSymbolUBO=t.disableSymbolUBO,i()}setWorldview(e,t,i){this.worldview=t,i()}setLayers(e,t,i){this.getLayerIndex(e,t.scope).replace(t.layers,t.options),i()}updateLayers(e,t,i){this.getLayerIndex(e,t.scope).update(t.layers,t.removedIds,t.options),i()}loadTile(e,t,i){t.projection=this.projections[e]||this.defaultProjection,this.getWorkerSource(e,t).loadTile(t,i)}decodeRasterArray(e,t,i){this.getWorkerSource(e,t).decodeRasterArray(t,i)}reloadTile(e,t,i){t.projection=this.projections[e]||this.defaultProjection,this.getWorkerSource(e,t).reloadTile(t,i)}abortTile(e,t,i){this.getWorkerSource(e,t).abortTile(t,i)}removeTile(e,t,i){this.getWorkerSource(e,t).removeTile(t,i)}removeSource(e,t,i){if(!(this.workerSources[e]&&this.workerSources[e][t.scope]&&this.workerSources[e][t.scope][t.type]&&this.workerSources[e][t.scope][t.type][t.source]))return;const r=this.workerSources[e][t.scope][t.type][t.source];delete this.workerSources[e][t.scope][t.type][t.source],void 0!==r.removeSource?r.removeSource(t,i):i()}loadTileProvider(e,i,r){t.aT(i.name,i.url).then(t=>{const r=new t(i.options);return this.getWorkerSource(e,{type:i.type,source:i.source,scope:i.scope},r),r.load&&i.request?r.load({request:i.request}):null}).then(e=>r(null,e)).catch(e=>r(e instanceof Error?e:new Error(String(e))))}async syncRTLPluginState(e,i,r){if(t.fJ.isParsed())return void r(null,!0);if(t.fJ.isParsing())return void this.rtlPluginParsingListeners.push(r);t.fJ.setState(i);const n=t.fJ.getPluginURL();if(!t.fJ.isLoaded()||t.fJ.isParsed()||t.fJ.isParsing())r(null,!1);else{t.fJ.setState({pluginStatus:t.fK.parsing,pluginURL:n});try{await import(n),t.fJ.isParsed()?r(null,!0):this.rtlPluginParsingListeners.push(r)}catch(e){t.fJ.setState({pluginStatus:t.fK.error,pluginURL:n}),r(e);for(const t of this.rtlPluginParsingListeners)t(e);this.rtlPluginParsingListeners=[]}}}setConfig(e,i){Object.assign(t.g,i)}getAvailableImages(e,t){this.availableImages[e]||(this.availableImages[e]={});let i=this.availableImages[e][t];return i||(i=[]),i}getAvailableModels(e,t){this.availableModels[e]||(this.availableModels[e]={});let i=this.availableModels[e][t];return i||(i={}),i}getLayerIndex(e,t){this.layerIndexes[e]||(this.layerIndexes[e]={});let i=this.layerIndexes[e][t];return i||(i=this.layerIndexes[e][t]=new s,i.scope=t),i}getWorkerSource(e,t,i){const{type:r,source:n,scope:o}=t,s=this.workerSources;if(s[e]||(s[e]={}),s[e][o]||(s[e][o]={}),s[e][o][r]||(s[e][o][r]={}),this.isSpriteLoaded[e]||(this.isSpriteLoaded[e]={}),s[e][o][r][n])i&&(s[e][o][r][n].tileProvider=i);else{const t={send:(t,i,r,n,o,s)=>this.actor.send(t,i,r,e,o,s),scheduler:this.actor.scheduler},a=this.workerSourceTypes[r];if(!a)throw new Error(`Unknown worker source type "${r}".`);s[e][o][r][n]=new a({actor:t,layerIndex:this.getLayerIndex(e,o),availableImages:this.getAvailableImages(e,o),availableModels:this.getAvailableModels(e,o),isSpriteLoaded:this.isSpriteLoaded[e][o],tileProvider:i,brightness:this.brightness,worldview:this.worldview,maxUniformBufferBindings:this.maxUniformBufferBindings,maxUniformBlockSizeDwords:this.maxUniformBlockSizeDwords,disableSymbolUBO:this.disableSymbolUBO})}return s[e][o][r][n]}enforceCacheSizeLimit(e,i){t.fL(i)}getWorkerPerformanceMetrics(e,t,i){i(void 0,void 0)}}return t.fI(self)&&(self.worker=new Pe(self)),Pe}),r(0,function(e){var t="3.24.0";const i={create:"create",load:"load",fullLoad:"fullLoad"},r={mark(e){performance.mark(e)},measure(e,t,i){performance.measure(e,t,i)}};function n(t){const i=t.name.split("?")[0];return e.a(i)&&i.includes("mapbox-gl.js")?"javascript":e.a(i)&&i.includes("mapbox-gl.css")?"css":e.b(i)?"fontRange":e.c(i)?"sprite":e.i(i)?"style":e.d(i)?"tilejson":"other"}var o,s={},a=function(){if(o)return s;function e(e){return!t(e)}function t(t){return"undefined"==typeof window||"undefined"==typeof document?"not a browser":function(){if(!("Worker"in window&&"Blob"in window&&"URL"in window))return!1;var e,t,i=new Blob([""],{type:"text/javascript"}),r=URL.createObjectURL(i);try{t=new Worker(r),e=!0}catch(t){e=!1}return t&&t.terminate(),URL.revokeObjectURL(r),e}()?function(){var e=document.createElement("canvas");e.width=e.height=1;var t=e.getContext("2d");if(!t)return!1;var i=t.getImageData(0,0,1,1);return i&&i.width===e.width}()?(void 0===i[r=t&&t.failIfMajorPerformanceCaveat]&&(i[r]=function(t){var i,r=function(t){var i=document.createElement("canvas"),r=Object.create(e.webGLContextAttributes);return r.failIfMajorPerformanceCaveat=t,i.getContext("webgl2",r)}(t);if(!r)return!1;try{i=r.createShader(r.VERTEX_SHADER)}catch(e){return!1}return!(!i||r.isContextLost())&&(r.shaderSource(i,"void main() {}"),r.compileShader(i),!0===r.getShaderParameter(i,r.COMPILE_STATUS))}(r)),i[r]?document.documentMode?"insufficient ECMAScript 6 support":void 0:"insufficient WebGL2 support"):"insufficient Canvas/getImageData support":"insufficient worker support";var r}o=1,s.supported=e,s.notSupportedReason=t;var i={};return e.webGLContextAttributes={antialias:!1,alpha:!0,stencil:!0,depth:!0},s}();const l=/firefox/i,c=/macintosh/i;function h(e,t,i){const r=document.createElement(e);return null!=t&&(r.className=t),i&&i.appendChild(r),r}function u(e,t,i){const r=document.createElementNS("http://www.w3.org/2000/svg",e);for(const n of Object.keys(t))r.setAttributeNS(null,n,String(t[n]));return i&&i.appendChild(r),r}const d="undefined"!=typeof document?document.documentElement&&document.documentElement.style:null,p=d&&void 0!==d.userSelect?"userSelect":"WebkitUserSelect";let f;function m(){d&&p&&(f=d[p],d[p]="none")}function _(){d&&p&&(d[p]=f)}function g(e){e.preventDefault(),e.stopPropagation(),window.removeEventListener("click",g,!0)}function y(){window.addEventListener("click",g,!0),window.setTimeout(()=>{window.removeEventListener("click",g,!0)},0)}function x(e,t){return w(e,e.getBoundingClientRect(),t)}function v(e,t){const i=e.getBoundingClientRect(),r=[];for(let n=0;n<t.length;n++)r.push(w(e,i,t[n]));return r}function b(e){return l.test(navigator.userAgent)&&c.test(navigator.userAgent)&&2===e.button&&e.ctrlKey?0:e.button}function w(t,i,r){const n=t.offsetWidth===i.width?1:t.offsetWidth/i.width;return new e.P((r.clientX-i.left)*n,(r.clientY-i.top)*n)}const T="01",S=/(\.(png|jpg)\d*)(?=$)/,I=/^.+\/v4\//,E=/\.[\w]+$/,A=/^(\/v4\/|\/(raster|rasterarrays)\/v1\/)/,M=/^access_token=(.*)$/,C="NO_ACCESS_TOKEN";class P{constructor(e,t,i){this._transformRequestFn=e,this._customAccessToken=t,this._silenceAuthErrors=!!i,this._createSkuToken()}_createSkuToken(){const e=function(){let e="";for(let t=0;t<10;t++)e+="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"[Math.floor(62*Math.random())];return{token:["1",T,e].join(""),tokenExpiresAt:Date.now()+432e5}}();this._skuToken=e.token,this._skuTokenExpiresAt=e.tokenExpiresAt}_isSkuTokenExpired(){return Date.now()>this._skuTokenExpiresAt}transformRequest(e,t){return this._transformRequestFn&&this._transformRequestFn(e,t)||{url:e}}normalizeStyleURL(i,r){if(!e.e(i))return i;const n=R(i);return n.params.push(`sdk=js-${t}`),n.path=`/styles/v1${n.path}`,this._makeAPIURL(n,this._customAccessToken||r)}normalizeGlyphsURL(t,i){if(!e.e(t))return t;const r=R(t);return r.path=`/fonts/v1${r.path}`,this._makeAPIURL(r,this._customAccessToken||i)}normalizeModelURL(t,i){if(!e.e(t))return t;const r=R(t);return r.path=`/models/v1${r.path}`,this._makeAPIURL(r,this._customAccessToken||i)}normalizeSourceURL(t,i,r,n){if(!e.e(t))return t;const o=R(t);return o.path=`/v4/${o.authority}.json`,o.params.push("secure"),r&&o.params.push(`language=${r}`),n&&o.params.push(`worldview=${n}`),this._makeAPIURL(o,this._customAccessToken||i)}normalizeIconsetURL(t,i){const r=R(t);return e.e(t)?(r.path=`/styles/v1${r.path}/iconset.pbf`,this._makeAPIURL(r,this._customAccessToken||i)):z(r)}normalizeSpriteURL(t,i,r,n){const o=R(t);return e.e(t)?(o.path=`/styles/v1${o.path}/sprite${i}${r}`,this._makeAPIURL(o,this._customAccessToken||n)):(o.path+=`${i}${r}`,z(o))}normalizeTileURL(t,i,r){if(this._isSkuTokenExpired()&&this._createSkuToken(),t&&!e.e(t))return t;const n=R(t);n.path=n.path.replace(S,`${i||r&&"raster"!==n.authority&&512===r?"@2x":""}${e.k.supported?".webp":"$1"}`),"raster"===n.authority?n.path=`/${e.g.RASTER_URL_PREFIX}${n.path}`:"rasterarrays"===n.authority?n.path=`/${e.g.RASTERARRAYS_URL_PREFIX}${n.path}`:"3dtiles"===n.authority?n.path=`/${e.g.TILES3D_URL_PREFIX}${n.path}`:(n.path=n.path.replace(I,"/"),n.path=`/${e.g.TILE_URL_VERSION}${n.path}`);const o=this._customAccessToken||function(e){for(const t of e){const e=t.match(M);if(e)return e[1]}return null}(n.params)||e.g.ACCESS_TOKEN;return e.g.REQUIRE_ACCESS_TOKEN&&o&&this._skuToken&&n.params.push(`sku=${this._skuToken}`),this._makeAPIURL(n,o)}canonicalizeTileURL(t,i){const r=R(t);if(!A.test(r.path)||!E.test(r.path))return t;let n="mapbox://";r.path.startsWith("/raster/v1/")?n+=`raster/${r.path.replace(`/${e.g.RASTER_URL_PREFIX}/`,"")}`:r.path.startsWith("/rasterarrays/v1/")?n+=`rasterarrays/${r.path.replace(`/${e.g.RASTERARRAYS_URL_PREFIX}/`,"")}`:n+=`tiles/${r.path.replace(`/${e.g.TILE_URL_VERSION}/`,"")}`;let o=r.params;return i&&(o=o.filter(e=>!e.match(M))),o.length&&(n+=`?${o.join("&")}`),n}canonicalizeTileset(t,i){const r=!!i&&e.e(i),n=[];for(const o of t.tiles||[])e.f(o)?n.push(this.canonicalizeTileURL(o,r)):n.push(o);return n}_makeAPIURL(t,i){const r="See https://docs.mapbox.com/api/overview/#access-tokens-and-token-scopes",n=R(e.g.API_URL);if(t.protocol=n.protocol,t.authority=n.authority,"http"===t.protocol){const e=t.params.indexOf("secure");e>=0&&t.params.splice(e,1)}if("/"!==n.path&&(t.path=`${n.path}${t.path}`),!e.g.REQUIRE_ACCESS_TOKEN)return z(t);if(i=i||e.g.ACCESS_TOKEN,!this._silenceAuthErrors){if(!i)throw new Error(`An API access token is required to use Mapbox GL. ${r}`);if("s"===i[0])throw new Error(`Use a public access token (pk.*) with Mapbox GL, not a secret access token (sk.*). ${r}`)}return t.params=t.params.filter(e=>!e.includes("access_token")),t.params.push(`access_token=${i||""}`),z(t)}}const D=/^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/;function R(e){const t=e.match(D);if(!t)throw new Error("Unable to parse URL object");return{protocol:t[1],authority:t[2],path:t[3]||"/",params:t[4]?t[4].split("&"):[]}}function z(e){const t=e.params.length?`?${e.params.join("&")}`:"";return`${e.protocol}://${e.authority}${e.path}${t}`}const L="mapbox.eventData";function F(t){if(!t)return null;const i=t.split(".");if(!i||3!==i.length)return null;try{return JSON.parse(e.l(i[1]))}catch(e){return null}}function O(t){return!(!e.g.EVENTS_URL||!t&&!e.g.ACCESS_TOKEN)}class B{constructor(e){this.type=e,this.anonId=null,this.anonIdTimestamp=null,this.eventData={},this.queue=[],this.pendingRequest=null}getStorageKey(t){const i=F(e.g.ACCESS_TOKEN);let r="";return r=i&&i.u?e.j(i.u):e.g.ACCESS_TOKEN||"",t?`${L}.${t}:${r}`:`${L}:${r}`}fetchEventData(){const t=e.s("localStorage"),i=this.getStorageKey(),r=this.getStorageKey("uuid"),n=this.getStorageKey("uuidTimestamp");if(t)try{const e=localStorage.getItem(i);e&&(this.eventData=JSON.parse(e));const t=localStorage.getItem(r);t&&(this.anonId=t);const o=localStorage.getItem(n);o&&(this.anonIdTimestamp=Number(o));const s=Date.now()-864e5;(!this.anonIdTimestamp||this.anonIdTimestamp<s)&&this.refreshUUID()}catch(t){e.w("Unable to read from LocalStorage")}}refreshUUID(){this.anonId=e.u(),this.anonIdTimestamp=Date.now()}saveEventData(){const t=e.s("localStorage"),i=this.getStorageKey(),r=this.getStorageKey("uuid"),n=this.getStorageKey("uuidTimestamp"),o=this.anonId,s=this.anonIdTimestamp;if(t&&o)try{localStorage.setItem(r,o),Object.keys(this.eventData).length>=1&&localStorage.setItem(i,JSON.stringify(this.eventData)),s&&localStorage.setItem(n,s.toString())}catch(t){e.w("Unable to write to LocalStorage")}}processRequests(e){}postEvent(t,i,r,n){if(!e.g.EVENTS_URL)return;const o=R(e.g.EVENTS_URL);o.params.push(`access_token=${n||e.g.ACCESS_TOKEN||""}`);const s={event:this.type,created:new Date(t).toISOString()},a=i?Object.assign(s,i):s,l={url:z(o),headers:{"Content-Type":"text/plain"},body:JSON.stringify([a])};this.pendingRequest=e.p(l,e=>{this.pendingRequest=null,r(e),this.saveEventData(),this.processRequests(n)})}queueRequest(e,t){this.queue.push(e),this.processRequests(t)}}class k extends B{constructor(e){super("metrics"),e&&(this.data=e)}postMetricsEvent(t){if(!O(t))return;this.anonId||this.fetchEventData(),e.v(this.anonId)||this.refreshUUID();const i=Object.assign({},this.data,{sessionId:this.anonId});this.queueRequest({timestamp:Date.now(),payload:i},t)}processRequests(e){if(this.pendingRequest||0===this.queue.length)return;const{timestamp:t,payload:i}=this.queue.shift();this.postEvent(t,i,()=>{},e)}}const N=new class extends B{constructor(e){super("appUserTurnstile"),this._customAccessToken=e}postTurnstileEvent(t,i){O(i)&&Array.isArray(t)&&t.some(t=>e.e(t)||e.f(t))&&this.queueRequest(Date.now(),i)}processRequests(i){if(this.pendingRequest||0===this.queue.length)return;this.anonId&&this.anonIdTimestamp&&this.eventData.lastSuccess&&this.eventData.tokenU||this.fetchEventData();const r=F(e.g.ACCESS_TOKEN),n=r?r.u:e.g.ACCESS_TOKEN;let o=n!==this.eventData.tokenU;e.v(this.anonId)||(this.refreshUUID(),o=!0);const s=this.queue.shift();if(this.eventData.lastSuccess){const e=new Date(this.eventData.lastSuccess),t=new Date(s),i=(s-this.eventData.lastSuccess)/864e5;o=o||i>=1||i<-1||e.getDate()!==t.getDate()}else o=!0;o?this.postEvent(s,{sdkIdentifier:"mapbox-gl-js",sdkVersion:t,skuId:T,"enabled.telemetry":!1,userId:this.anonId},e=>{e||(this.eventData.lastSuccess=s,this.eventData.tokenU=n)},i):this.processRequests()}},U=N.postTurnstileEvent.bind(N),V=new class extends B{constructor(){super("map.load"),this.success={},this.skuToken=""}postMapLoadEvent(t,i,r,n){this.skuToken=i,this.errorCb=n,e.g.EVENTS_URL&&(r||e.g.ACCESS_TOKEN?this.queueRequest({id:t,timestamp:Date.now()},r):this.errorCb(/* @__PURE__ */new Error(C)))}processRequests(i){if(this.pendingRequest||0===this.queue.length)return;const{id:r,timestamp:n}=this.queue.shift();r&&this.success[r]||(this.anonId&&this.anonIdTimestamp||this.fetchEventData(),e.v(this.anonId)||this.refreshUUID(),this.postEvent(n,{sdkIdentifier:"mapbox-gl-js",sdkVersion:t,skuId:T,skuToken:this.skuToken,userId:this.anonId},e=>{e?this.errorCb(e):r&&(this.success[r]=!0)},i))}remove(){this.errorCb=null}},j=V.postMapLoadEvent.bind(V),G=new class extends B{constructor(){super("style.load"),this.eventIdPerMapInstanceMap=/* @__PURE__ */new Map,this.mapInstanceIdMap=/* @__PURE__ */new WeakMap}getMapInstanceId(t){let i=this.mapInstanceIdMap.get(t);return i||(i=e.u(),this.mapInstanceIdMap.set(t,i)),i}getEventId(e){const t=this.eventIdPerMapInstanceMap.get(e)||0;return this.eventIdPerMapInstanceMap.set(e,t+1),t}postStyleLoadEvent(e,t){const{map:i,style:r,importedStyles:n}=t;if(!O(e))return;const o=this.getMapInstanceId(i),s={mapInstanceId:o,eventId:this.getEventId(o),style:r};n.length&&(s.importedStyles=n),this.queueRequest({timestamp:Date.now(),payload:s},e)}processRequests(e){if(this.pendingRequest||0===this.queue.length)return;const{timestamp:t,payload:i}=this.queue.shift();this.postEvent(t,i,()=>{},e)}},H=G.postStyleLoadEvent.bind(G),$=new k({attributes:[{name:"maps/js/layer-animations/style-with-appearances"}]}),q=$.postMetricsEvent.bind($),Z=new k({attributes:[{name:"maps/js/layer-animations/runtime-appearances"}]}),W=Z.postMetricsEvent.bind(Z),X=new class extends B{constructor(){super("gljs.performance")}postPerformanceEvent(e,t){O(e)&&this.queueRequest({timestamp:Date.now(),performanceData:t},e)}processRequests(r){if(this.pendingRequest||0===this.queue.length)return;const{timestamp:o,performanceData:s}=this.queue.shift(),a=function(r){const o=performance.getEntriesByType("resource"),s=performance.getEntriesByType("mark"),a=function(e){const t={};if(e)for(const i in e)if("other"!==i)for(const r of e[i]){const e=`${i}ResolveRangeMin`,n=`${i}ResolveRangeMax`,o=`${i}RequestCount`,s=`${i}RequestCachedCount`;t[e]=Math.min(t[e]||1/0,r.startTime),t[n]=Math.max(t[n]||-1/0,r.responseEnd);const a=e=>{void 0===t[e]&&(t[e]=0),++t[e]};void 0!==r.transferSize&&0===r.transferSize&&a(s),a(o)}return t}(function(e,t){const i={};if(e)for(const r of e){const e=t(r);void 0===i[e]&&(i[e]=[]),i[e].push(r)}return i}(o,n)),l=window.devicePixelRatio,c=navigator.connection||navigator.mozConnection||navigator.webkitConnection,h=c?c.effectiveType:void 0,u={counters:[],metadata:[],attributes:[]},d=(e,t,i)=>{null!=i&&e.push({name:t,value:i.toString()})};for(const e in a)d(u.counters,e,a[e]);if(r.interactionRange[0]!==1/0&&r.interactionRange[1]!==-1/0&&(d(u.counters,"interactionRangeMin",r.interactionRange[0]),d(u.counters,"interactionRangeMax",r.interactionRange[1])),s)for(const e of Object.values(i)){const t=s.find(t=>t.name===e);t&&d(u.counters,e,t.startTime)}return d(u.counters,"visibilityHidden",r.visibilityHidden),d(u.attributes,"style",function(t){if(t)for(const i of t){const t=i.name.split("?")[0];if(e.i(t)){const e=t.split("/").slice(-2);if(2===e.length)return`mapbox://styles/${e[0]}/${e[1]}`}}}(o)),d(u.attributes,"terrainEnabled",r.terrainEnabled?"true":"false"),d(u.attributes,"fogEnabled",r.fogEnabled?"true":"false"),d(u.attributes,"projection",r.projection),d(u.attributes,"zoom",r.zoom),d(u.metadata,"devicePixelRatio",l),d(u.metadata,"connectionEffectiveType",h),d(u.metadata,"navigatorUserAgent",navigator.userAgent),d(u.metadata,"screenWidth",window.screen.width),d(u.metadata,"screenHeight",window.screen.height),d(u.metadata,"windowWidth",window.innerWidth),d(u.metadata,"windowHeight",window.innerHeight),d(u.metadata,"mapWidth",r.width/l),d(u.metadata,"mapHeight",r.height/l),d(u.metadata,"webglRenderer",r.renderer),d(u.metadata,"webglVendor",r.vendor),d(u.metadata,"sdkVersion",t),d(u.metadata,"sdkIdentifier","mapbox-gl-js"),u}(s);for(const e of a.metadata);for(const e of a.counters);for(const e of a.attributes);this.postEvent(o,a,()=>{},r)}},Y=X.postPerformanceEvent.bind(X),J=new class extends B{constructor(){super("map.auth"),this.success={},this.skuToken=""}getSession(t,i,r,n){if(!e.g.API_URL||!e.g.SESSION_PATH)return;const o=R(e.g.API_URL+e.g.SESSION_PATH);o.params.push(`sku=${i||""}`),o.params.push(`access_token=${n||e.g.ACCESS_TOKEN||""}`);const s={url:z(o),headers:{"Content-Type":"text/plain"}};this.pendingRequest=e.h(s,e=>{this.pendingRequest=null,r(e),this.saveEventData(),this.processRequests(n)})}getSessionAPI(t,i,r,n){this.skuToken=i,this.errorCb=n,e.g.EVENTS_URL&&e.g.SESSION_PATH&&e.g.API_URL&&(r||e.g.ACCESS_TOKEN?this.queueRequest({id:t,timestamp:Date.now()},r):this.errorCb(/* @__PURE__ */new Error(C)))}processRequests(e){if(this.pendingRequest||0===this.queue.length)return;const{id:t,timestamp:i}=this.queue.shift();t&&this.success[t]||this.getSession(i,this.skuToken,e=>{e?this.errorCb(e):t&&(this.success[t]=!0)},e)}remove(){this.errorCb=null}},K=J.getSessionAPI.bind(J),Q=/* @__PURE__ */new Set;function ee(e,t){t?Q.add(e):Q.delete(e)}class te{constructor(){this._changed=!1,this._updatedLayers={},this._removedLayers={},this._updatedSourceCaches={},this._updatedPaintProps=/* @__PURE__ */new Set,this._updatedImages={}}isDirty(){return this._changed}setDirty(){this._changed=!0}getUpdatedSourceCaches(){return this._updatedSourceCaches}updateSourceCache(e,t){this._updatedSourceCaches[e]=t,this.setDirty()}discardSourceCacheUpdate(e){delete this._updatedSourceCaches[e]}updateLayer(e){const t=e.scope;this._updatedLayers[t]=this._updatedLayers[t]||/* @__PURE__ */new Set,this._updatedLayers[t].add(e.id),this.setDirty()}removeLayer(e){const t=e.scope;this._removedLayers[t]=this._removedLayers[t]||{},this._updatedLayers[t]=this._updatedLayers[t]||/* @__PURE__ */new Set,this._removedLayers[t][e.id]=e,this._updatedLayers[t].delete(e.id),this._updatedPaintProps.delete(e.fqid),this.setDirty()}getRemovedLayer(e){return this._removedLayers[e.scope]?this._removedLayers[e.scope][e.id]:null}discardLayerRemoval(e){this._removedLayers[e.scope]&&delete this._removedLayers[e.scope][e.id]}getLayerUpdatesByScope(){const e={};for(const t in this._updatedLayers)e[t]=e[t]||{},e[t].updatedIds=Array.from(this._updatedLayers[t].values());for(const t in this._removedLayers)e[t]=e[t]||{},e[t].removedIds=Object.keys(this._removedLayers[t]);return e}getUpdatedPaintProperties(){return this._updatedPaintProps}updatePaintProperties(e){this._updatedPaintProps.add(e.fqid),this.setDirty()}getUpdatedImages(e){return this._updatedImages[e]?Array.from(this._updatedImages[e].values()):[]}updateImage(t,i){this._updatedImages[i]=this._updatedImages[i]||/* @__PURE__ */new Set,this._updatedImages[i].add(e.I.toString(t)),this.setDirty()}resetUpdatedImages(e){this._updatedImages[e]&&this._updatedImages[e].clear()}reset(){this._changed=!1,this._updatedLayers={},this._removedLayers={},this._updatedSourceCaches={},this._updatedPaintProps.clear(),this._updatedImages={}}}function ie(e){const{userImage:t}=e;return!!(t&&t.render&&t.render())&&(e.data.replace(new Uint8Array(t.data.buffer)),!0)}const re=new e.C(0,0,0);function ne(e,t,i){1===e&&t.icons.push(function(e,t){return function(e){if(e.usvg_tree.height||(e.usvg_tree.height=e.usvg_tree.width),!e.metadata)return e;const{metadata:t}=e;if(t.content_area){const{content_area:i}=t;i.left??=0,i.top??=i.left,i.width??=e.usvg_tree.width,i.height??=i.width}if(t.text_placeholder){const{text_placeholder:e}=t;e.top??=e.left,e.height??=e.width}return t.stretch_x&&t.stretch_x.length&&oe(t,"x"),t.stretch_y&&t.stretch_y.length&&oe(t,"y"),e}(e.readFields(se,{name:void 0},t))}(i,i.readVarint()+i.pos))}function oe(e,t){const i=[],r=e[`stretch_${t}`];let n=null;for(let o=0;o<r.length;o++)null===n?n=0===i.length?r[0]:i.at(-1)[1]+r[o]:(i.push([n,n+r[o]]),n=null);e[`stretch_${t}_areas`]=i}function se(e,t,i){1===e?t.name=i.readString():2===e?t.metadata=function(e,t){return e.readFields(ae,{stretch_x:null,stretch_y:null,stretch_x_areas:null,stretch_y_areas:null,variables:[]},t)}(i,i.readVarint()+i.pos):3===e&&(t.usvg_tree=function(e,t){return e.readFields(ue,{width:20,children:[],linear_gradients:[],radial_gradients:[],clip_paths:[],masks:[]},t)}(i,i.readVarint()+i.pos),t.data="usvg_tree")}function ae(e,t,i){1===e?t.stretch_x=i.readPackedVarint():2===e?t.stretch_y=i.readPackedVarint():3===e?t.content_area=le(i,i.readVarint()+i.pos):4===e?t.variables.push(function(e,t){return e.readFields(he,{name:void 0},t)}(i,i.readVarint()+i.pos)):5===e&&(t.text_placeholder=le(i,i.readVarint()+i.pos))}function le(e,t){return e.readFields(ce,{},t)}function ce(e,t,i){1===e?t.left=i.readVarint():2===e?t.width=i.readVarint():3===e?t.top=i.readVarint():4===e&&(t.height=i.readVarint())}function he(e,t,i){1===e?t.name=i.readString():2===e&&(t.rgb_color=xe(i.readVarint()),t.value="rgb_color")}function ue(e,t,i){1===e?t.width=t.height=i.readVarint():2===e?t.height=i.readVarint():3===e?t.children.push(de(i,i.readVarint()+i.pos)):4===e?t.linear_gradients.push(function(e,t){return e.readFields(be,{spread_method:1,stops:[],x1:0,y1:0,x2:1,y2:0},t)}(i,i.readVarint()+i.pos)):5===e?t.radial_gradients.push(function(e,t){return e.readFields(Se,{spread_method:1,stops:[],cx:.5,cy:.5,r:.5,fx:.5,fy:.5,fr:0},t)}(i,i.readVarint()+i.pos)):7===e?t.clip_paths.push(function(e,t){return e.readFields(Ie,{children:[]},t)}(i,i.readVarint()+i.pos)):8===e&&t.masks.push(function(e,t){const i=e.readFields(Ee,{left:0,width:20,mask_type:1,children:[]},t);return i.height??=i.width,i.top??=i.left,i}(i,i.readVarint()+i.pos))}function de(e,t){return e.readFields(pe,{},t)}function pe(e,t,i){1===e?(t.group=function(e,t){return e.readFields(fe,{opacity:255,children:[]},t)}(i,i.readVarint()+i.pos),t.node="group"):2===e&&(t.path=function(e,t){return e.readFields(ge,{paint_order:1,commands:[],step:1,diffs:[],rule:1},t)}(i,i.readVarint()+i.pos),t.node="path")}function fe(e,t,i){1===e?t.transform=me(i,i.readVarint()+i.pos):2===e?t.opacity=i.readVarint():5===e?t.clip_path_idx=i.readVarint():6===e?t.mask_idx=i.readVarint():7===e&&t.children.push(de(i,i.readVarint()+i.pos))}function me(e,t){return e.readFields(_e,{sx:1,ky:0,kx:0,sy:1,tx:0,ty:0},t)}function _e(e,t,i){1===e?t.sx=i.readFloat():2===e?t.ky=i.readFloat():3===e?t.kx=i.readFloat():4===e?t.sy=i.readFloat():5===e?t.tx=i.readFloat():6===e&&(t.ty=i.readFloat())}function ge(e,t,i){1===e?t.fill=function(e,t){return e.readFields(ye,{rgb_color:re,paint:"rgb_color",opacity:255},t)}(i,i.readVarint()+i.pos):2===e?t.stroke=function(e,t){return e.readFields(ve,{rgb_color:re,paint:"rgb_color",dasharray:[],dashoffset:0,miterlimit:4,opacity:255,width:1,linecap:1,linejoin:1},t)}(i,i.readVarint()+i.pos):3===e?t.paint_order=i.readVarint():5===e?i.readPackedVarint(t.commands):6===e?t.step=i.readFloat():7===e?i.readPackedSVarint(t.diffs):8===e&&(t.rule=i.readVarint())}function ye(e,t,i){1===e?(t.rgb_color=xe(i.readVarint()),t.paint="rgb_color"):2===e?(t.linear_gradient_idx=i.readVarint(),t.paint="linear_gradient_idx"):3===e?(t.radial_gradient_idx=i.readVarint(),t.paint="radial_gradient_idx"):5===e&&(t.opacity=i.readVarint())}function xe(t){return new e.C((t>>16&255)/255,(t>>8&255)/255,(255&t)/255,1)}function ve(e,t,i){1===e?(t.rgb_color=xe(i.readVarint()),t.paint="rgb_color"):2===e?(t.linear_gradient_idx=i.readVarint(),t.paint="linear_gradient_idx"):3===e?(t.radial_gradient_idx=i.readVarint(),t.paint="radial_gradient_idx"):5===e?i.readPackedFloat(t.dasharray):6===e?t.dashoffset=i.readFloat():7===e?t.miterlimit=i.readFloat():8===e?t.opacity=i.readVarint():9===e?t.width=i.readFloat():10===e?t.linecap=i.readVarint():11===e&&(t.linejoin=i.readVarint())}function be(e,t,i){1===e?t.transform=me(i,i.readVarint()+i.pos):2===e?t.spread_method=i.readVarint():3===e?t.stops.push(we(i,i.readVarint()+i.pos)):4===e?t.x1=i.readFloat():5===e?t.y1=i.readFloat():6===e?t.x2=i.readFloat():7===e&&(t.y2=i.readFloat())}function we(e,t){return e.readFields(Te,{offset:0,opacity:255,rgb_color:re},t)}function Te(e,t,i){1===e?t.offset=i.readFloat():2===e?t.opacity=i.readVarint():3===e&&(t.rgb_color=xe(i.readVarint()))}function Se(e,t,i){1===e?t.transform=me(i,i.readVarint()+i.pos):2===e?t.spread_method=i.readVarint():3===e?t.stops.push(we(i,i.readVarint()+i.pos)):4===e?t.cx=i.readFloat():5===e?t.cy=i.readFloat():6===e?t.r=i.readFloat():7===e?t.fx=i.readFloat():8===e?t.fy=i.readFloat():9===e&&(t.fr=i.readFloat())}function Ie(e,t,i){1===e?t.transform=me(i,i.readVarint()+i.pos):2===e?t.clip_path_idx=i.readVarint():3===e&&t.children.push(de(i,i.readVarint()+i.pos))}function Ee(e,t,i){1===e?t.left=t.top=i.readFloat():2===e?t.width=t.height=i.readFloat():3===e?t.top=i.readFloat():4===e?t.height=i.readFloat():5===e?t.mask_type=i.readVarint():6===e?t.mask_idx=i.readVarint():7===e&&t.children.push(de(i,i.readVarint()+i.pos))}class Ae{static calculate(t={},i=[]){const r=/* @__PURE__ */new Map,n=/* @__PURE__ */new Map;if(0===Object.keys(t).length)return r;i.forEach(t=>{n.set(t.name,t.rgb_color||new e.C(0,0,0))});for(const[e,o]of Object.entries(t))n.has(e)?r.set(n.get(e).toString(),o):console.warn(`Ignoring unknown image variable "${e}"`);return r}}function Me(e,t=255,i){const r=i.get(e.toString())||e;if(255===t)return r.toString();const n=r.clone();return n.a*=t/255,n.toString()}const Ce=[];let Pe=0;function De(t,i){if(Pe>=Ce.length){const r=e.r()?new OffscreenCanvas(t,i):document.createElement("canvas");Ce.push(r.getContext("2d",{willReadFrequently:!0}))}const r=Ce[Pe++];return r.canvas.width=t,r.canvas.height=i,r}function Re(){Pe--}function ze(e,t,i,r,n){for(const o of r.children)Le(e,t,i,o,n)}function Le(e,t,i,r,n){r.group?(e.save(),function(e,t,i,r,n){const o=null!=r.mask_idx?i.masks[r.mask_idx]:null,s=null!=r.clip_path_idx?i.clip_paths[r.clip_path_idx]:null;if(r.transform&&(t=Ge(r.transform).preMultiplySelf(t)),!function(e,t,i){return 255!==e.opacity||t||i}(r,null!=s,null!=o))return void ze(e,t,i,r,n);const a=De(e.canvas.width,e.canvas.height);ze(a,t,i,r,n),s&&Ve(a,t,i,s),o&&je(a,t,i,o,n),e.globalAlpha=r.opacity/255,e.drawImage(a.canvas,0,0),Re()}(e,t,i,r.group,n),e.restore()):r.path&&(e.save(),function(e,t,i,r,n){e.setTransform(t),1===r.paint_order?(Fe(e,i,r,n),Be(e,i,r,n)):(Be(e,i,r,n),Fe(e,i,r,n))}(e,t,i,r.path,n),e.restore())}function Fe(e,t,i,r){const n=i.fill;if(!n)return;const o=n.opacity/255;switch(e.save(),e.beginPath(),He(i,e),n.paint){case"rgb_color":e.fillStyle=Me(n.rgb_color,n.opacity,r);break;case"linear_gradient_idx":{const i=t.linear_gradients[n.linear_gradient_idx];i.transform&&e.setTransform(Ge(i.transform).preMultiplySelf(e.getTransform())),e.fillStyle=ke(e,i,o,r);break}case"radial_gradient_idx":{const i=t.radial_gradients[n.radial_gradient_idx];i.transform&&e.setTransform(Ge(i.transform).preMultiplySelf(e.getTransform())),e.fillStyle=Ne(e,i,o,r)}}e.fill(Oe(i)),e.restore()}function Oe(e){return 1===e.rule?"nonzero":2===e.rule?"evenodd":void 0}function Be(e,t,i,r){const n=i.stroke;if(!n)return;const o=$e(i);e.lineWidth=n.width,e.miterLimit=n.miterlimit,e.setLineDash(n.dasharray),e.lineDashOffset=n.dashoffset;const s=n.opacity/255;switch(n.paint){case"rgb_color":e.strokeStyle=Me(n.rgb_color,n.opacity,r);break;case"linear_gradient_idx":e.strokeStyle=ke(e,t.linear_gradients[n.linear_gradient_idx],s,r,!0);break;case"radial_gradient_idx":e.strokeStyle=Ne(e,t.radial_gradients[n.radial_gradient_idx],s,r,!0)}switch(n.linejoin){case 2:case 1:e.lineJoin="miter";break;case 3:e.lineJoin="round";break;case 4:e.lineJoin="bevel"}switch(n.linecap){case 1:e.lineCap="butt";break;case 2:e.lineCap="round";break;case 3:e.lineCap="square"}e.stroke(o)}function ke(e,t,i,r,n=!1){if(1===t.stops.length){const e=t.stops[0];return Me(e.rgb_color,e.opacity*i,r)}const{x1:o,y1:s,x2:a,y2:l}=t;let c=new DOMPoint(o,s),h=new DOMPoint(a,l);if(n){const e=Ge(t.transform);c=e.transformPoint(c),h=e.transformPoint(h)}const u=e.createLinearGradient(c.x,c.y,h.x,h.y);for(const d of t.stops)u.addColorStop(d.offset,Me(d.rgb_color,d.opacity*i,r));return u}function Ne(e,t,i,r,n=!1){if(1===t.stops.length){const e=t.stops[0];return Me(e.rgb_color,e.opacity*i,r)}const o=Ge(t.transform),{fx:s,fy:a,fr:l,cx:c,cy:h,r:u}=t;let d=new DOMPoint(s,a),p=new DOMPoint(c,h),f=l,m=u;if(n){d=o.transformPoint(d),p=o.transformPoint(p);const e=(o.a+o.d)/2;f=l*e,m=t.r*e}const _=e.createRadialGradient(d.x,d.y,f,p.x,p.y,m);for(const g of t.stops)_.addColorStop(g.offset,Me(g.rgb_color,g.opacity*i,r));return _}function Ue(e,t,i,r){const n=r.transform?Ge(r.transform).preMultiplySelf(t):t,o=De(e.canvas.width,e.canvas.height);for(const a of r.children)if(a.group)Ue(o,n,i,a.group);else if(a.path){const e=a.path,t=new Path2D;t.addPath($e(e),n),o.fill(t,Oe(e))}const s=null!=r.clip_path_idx?i.clip_paths[r.clip_path_idx]:null;s&&Ve(o,n,i,s),e.globalCompositeOperation="source-over",e.drawImage(o.canvas,0,0),Re()}function Ve(e,t,i,r){const n=De(e.canvas.width,e.canvas.height);Ue(n,t,i,r),e.globalCompositeOperation="destination-in",e.drawImage(n.canvas,0,0),Re()}function je(e,t,i,r,n){if(0===r.children.length)return;const o=null!=r.mask_idx?i.masks[r.mask_idx]:null;o&&je(e,t,i,o,n);const s=e.canvas.width,a=e.canvas.height,l=De(s,a),c=r.width,h=r.height,u=r.left,d=r.top,p=new Path2D,f=new Path2D;f.rect(u,d,c,h),p.addPath(f,t),l.clip(p);for(const g of r.children)Le(l,t,i,g,n);const m=l.getImageData(0,0,s,a),_=m.data;if(1===r.mask_type)for(let g=0;g<_.length;g+=4)_[g+3]=_[g+3]/255*(.2126*_[g]+.7152*_[g+1]+.0722*_[g+2]);l.putImageData(m,0,0),e.globalCompositeOperation="destination-in",e.drawImage(l.canvas,0,0),Re()}function Ge(e){return e?new DOMMatrix([e.sx,e.ky,e.kx,e.sy,e.tx,e.ty]):new DOMMatrix}function He(e,t){const i=e.step;let r=e.diffs[0]*i,n=e.diffs[1]*i;t.moveTo(r,n);for(let o=0,s=2;o<e.commands.length;o++)switch(e.commands[o]){case 1:r+=e.diffs[s++]*i,n+=e.diffs[s++]*i,t.moveTo(r,n);break;case 2:r+=e.diffs[s++]*i,n+=e.diffs[s++]*i,t.lineTo(r,n);break;case 3:{const o=r+e.diffs[s++]*i,a=n+e.diffs[s++]*i;r=o+e.diffs[s++]*i,n=a+e.diffs[s++]*i,t.quadraticCurveTo(o,a,r,n);break}case 4:{const o=r+e.diffs[s++]*i,a=n+e.diffs[s++]*i,l=o+e.diffs[s++]*i,c=a+e.diffs[s++]*i;r=l+e.diffs[s++]*i,n=c+e.diffs[s++]*i,t.bezierCurveTo(o,a,l,c,r,n);break}case 5:t.closePath()}return t}function $e(e){return He(e,new Path2D)}class qe{constructor(){this.cacheMap=/* @__PURE__ */new Map,this.cacheDependenciesMap=/* @__PURE__ */new Map}static _getImage(t){return new e.q(t,t.data)}getFromCache(t,i,r){return this.cacheMap.has(r)||this.cacheMap.set(r,new e.L(150)),this.cacheMap.get(r).get(e.t(t.toString(),i))}setInCache(t,i,r,n){this.cacheDependenciesMap.has(n)||this.cacheDependenciesMap.set(n,/* @__PURE__ */new Map),this.cacheMap.has(n)||this.cacheMap.set(n,new e.L(150));const o=this.cacheDependenciesMap.get(n),s=e.t(t.id.toString(),r);o.get(s)||o.set(s,/* @__PURE__ */new Set);const a=this.cacheMap.get(n),l=t.toString();o.get(s).add(l),a.put(e.t(t.toString(),r),i)}removeImagesFromCacheByIds(t,i,r=0){if(!this.cacheMap.has(r)||!this.cacheDependenciesMap.has(r))return;const n=this.cacheMap.get(r),o=this.cacheDependenciesMap.get(r);for(const s of t){const t=e.t(s.toString(),i);if(o.has(t)){for(const e of o.get(t))n.delete(e);o.delete(t)}}}rasterize(e,t,i,r){const n=this.getFromCache(e,i,r);if(n)return n.clone();const o=function(e,t){const i=Ae.calculate(t.params,e.metadata?e.metadata.variables:[]),r=e.usvg_tree,n=r.width,o=r.height,s=Math.max(1,Math.round(n*t.sx)),a=Math.max(1,Math.round(o*t.sy)),l=new DOMMatrix([s/n,0,0,a/o,0,0]),c=De(s,a);ze(c,l,r,r,i);const h=c.getImageData(0,0,s,a);return Re(),h}(t.icon,e),s=qe._getImage(o);return this.setInCache(e,s,i,r),s.clone()}}class Ze extends e.E{constructor(t){super(),this.imageProviders=/* @__PURE__ */new Map,this.images=/* @__PURE__ */new Map,this.updatedImages=/* @__PURE__ */new Map,this.callbackDispatchedThisFrame=/* @__PURE__ */new Map,this.imageVersions=/* @__PURE__ */new Map,this.loaded=/* @__PURE__ */new Map,this.requestors=[],this.patterns=/* @__PURE__ */new Map,this.patternsInFlight=/* @__PURE__ */new Set,this.atlasImage=/* @__PURE__ */new Map,this.atlasTexture=/* @__PURE__ */new Map,this.imageAtlasCache=new e.x,this.dirty=!0,this.spriteFormat=t,this.imageRasterizer=new qe}addScope(t){this.loaded.set(t,!1),this.imageProviders.set(t,/* @__PURE__ */new Map),this.images.set(t,/* @__PURE__ */new Map),this.updatedImages.set(t,/* @__PURE__ */new Set),this.callbackDispatchedThisFrame.set(t,/* @__PURE__ */new Set),this.imageVersions.set(t,/* @__PURE__ */new Map),this.patterns.set(t,/* @__PURE__ */new Map),this.atlasImage.set(t,new e.q({width:1,height:1}))}removeScope(e){this.loaded.delete(e),this.imageProviders.delete(e),this.images.delete(e),this.updatedImages.delete(e),this.callbackDispatchedThisFrame.delete(e),this.imageVersions.delete(e),this.patterns.delete(e),this.atlasImage.delete(e);const t=this.atlasTexture.get(e);t&&(t.destroy(),this.atlasTexture.delete(e))}addImageProvider(e,t){this.imageProviders.has(t)||this.imageProviders.set(t,/* @__PURE__ */new Map),this.imageProviders.get(t).set(e.id,e)}removeImageProvider(e,t){this.imageProviders.has(t)&&this.imageProviders.get(t).delete(e)}getPendingImageProviders(){const e=[];for(const t of this.imageProviders.values())for(const i of t.values())i.hasPendingRequests()&&e.push(i);return e}isLoaded(){for(const e of this.loaded.keys())if(!this.loaded.get(e))return!1;return!0}setLoaded(e,t){if(this.loaded.get(t)!==e&&(this.loaded.set(t,e),e)){for(const{ids:e,callback:i}of this.requestors)this._notify(e,t,i);this.requestors=[]}}hasImage(e,t){return!!this.getImage(e,t)}getImage(e,t){return this.images.get(t).get(e.toString())}addImage(e,t,i){if(this._validate(e,i)){this.images.get(t).set(e.toString(),i);const r=this.imageVersions.get(t),n=r.get(e.toString())||0;r.set(e.toString(),n+1)}}_validate(t,i){let r=!0;return this._validateStretch(i.stretchX,i.data&&i.data.width)||(this.fire(new e.y(/* @__PURE__ */new Error(`Image "${t.name}" has invalid "stretchX" value`))),r=!1),this._validateStretch(i.stretchY,i.data&&i.data.height)||(this.fire(new e.y(/* @__PURE__ */new Error(`Image "${t.name}" has invalid "stretchY" value`))),r=!1),this._validateContent(i.content,i)||(this.fire(new e.y(/* @__PURE__ */new Error(`Image "${t.name}" has invalid "content" value`))),r=!1),r}_validateStretch(e,t){if(!e)return!0;let i=0;for(const r of e){if(r[0]<i||r[1]<r[0]||t<r[1])return!1;i=r[1]}return!0}_validateContent(e,t){if(!e)return!0;if(4!==e.length)return!1;if(!t.usvg){if(e[0]<0||t.data.width<e[0])return!1;if(e[1]<0||t.data.height<e[1])return!1;if(e[2]<0||t.data.width<e[2])return!1;if(e[3]<0||t.data.height<e[3])return!1}return!(e[2]<e[0]||e[3]<e[1])}updateImage(e,t,i){i.version=this.images.get(t).get(e.toString()).version+1,this.images.get(t).set(e.toString(),i),this.updatedImages.get(t).add(e);const r=this.imageVersions.get(t),n=r.get(e.toString())||0;r.set(e.toString(),n+1),this.removeFromImageRasterizerCache(e,t)}clearUpdatedImages(e){this.updatedImages.get(e).clear()}removeFromImageRasterizerCache(e,t){"raster"!==this.spriteFormat&&this.imageRasterizer.removeImagesFromCacheByIds([e],t)}removeImage(e,t){const i=this.images.get(t),r=i.get(e.toString());i.delete(e.toString());const n=this.imageVersions.get(t),o=n.get(e.toString())||0;n.set(e.toString(),o+1),this.patterns.get(t).delete(e.toString()),this.removeFromImageRasterizerCache(e,t),r.userImage&&r.userImage.onRemove&&r.userImage.onRemove()}listImages(t){return Array.from(this.images.get(t).keys()).map(t=>e.I.from(t))}getImageVersions(e){const t=this.imageVersions.get(e);if(t)return t}getImages(e,t,i){const r=[],n=[],o=this.imageProviders.get(t);for(const c of e){if(!c.iconsetId){r.push(c);continue}const e=o.get(c.iconsetId);e&&(this.getImage(c,t)?n.push(c):e.addPendingRequest(c))}if(0===r.length)return void this._notify(n,t,i);let s=!0;const a=!!this.loaded.get(t),l=this.images.get(t);if(!a)for(const c of r)l.has(c.toString())||(s=!1);a||s?this._notify(r,t,i):this.requestors.push({ids:r,scope:t,callback:i})}rasterizeImages(e,t){const i=/* @__PURE__ */new Map,{iconTasks:r,patternTasks:n,scope:o}=e;for(const s of[r,n])for(const[e,t]of s.entries()){const r=this.getImage(t.id,o);r&&i.set(e,{image:r,imageVariant:t})}t(null,this._rasterizeImages(o,i))}_rasterizeImages(e,t){const i=/* @__PURE__ */new Map;for(const[r,{image:n,imageVariant:o}]of t.entries())i.set(r,this.imageRasterizer.rasterize(o,n,e,0));return i}getUpdatedImages(e){return this.updatedImages.get(e)||/* @__PURE__ */new Set}_notify(t,i,r){const n=this.images.get(i),o=/* @__PURE__ */new Map;for(const s of t){if(!n.get(s.toString())){if(s.iconsetId)continue;this.fire(new e.z("styleimagemissing",{id:s.name}))}const t=n.get(s.toString());if(!t){e.w(`Image "${s.name}" could not be loaded. Please make sure you have added the image with map.addImage() or a "sprite" property in your style. You can provide missing images by listening for the "styleimagemissing" map event.`);continue}const i={data:t.usvg?null:t.data.clone(),pixelRatio:t.pixelRatio,sdf:t.sdf,usvg:t.usvg,stretchX:t.stretchX,stretchY:t.stretchY,content:t.content,hasRenderCallback:Boolean(t.userImage&&t.userImage.render)};t.usvg&&Object.assign(i,{width:t.icon.usvg_tree.width,height:t.icon.usvg_tree.height}),o.set(e.I.toString(s),i)}r(null,{images:o,versions:this.getImageVersions(i)})}getPixelSize(e){const{width:t,height:i}=this.atlasImage.get(e);return{width:t,height:i}}getPattern(t,i,r){const n=t.toString(),o=this.patterns.get(i),s=o.get(n),a=this.getImage(t,i);if(!a)return null;if(s){if(s.position.version===a.version)return s.position;s.position.version=a.version}else{if(a.usvg&&!a.data){const o=this.getPatternInFlightId(n,i);if(this.patternsInFlight.has(o))return null;this.patternsInFlight.add(o);const s=new e.A(t).scaleSelf(e.o.devicePixelRatio),l=new Map([[s.toString(),{image:a,imageVariant:s}]]),c=this._rasterizeImages(i,l);return this.storePatternImage(s,i,a,r,c),null}this.storePattern(t,i,a)}return this._updatePatternAtlas(i,r),o.get(n).position}getPatternInFlightId(t,i){return e.t(t,i)}hasPatternsInFlight(){return 0!==this.patternsInFlight.size}storePatternImage(e,t,i,r,n){const o=e.toString(),s=n?n.get(o):void 0;s&&(i.data=s,this.storePattern(e.id,t,i),this._updatePatternAtlas(t,r),this.patternsInFlight.delete(this.getPatternInFlightId(e.id.toString(),t)))}storePattern(t,i,r){const n={w:r.data.width+2*e.B,h:r.data.height+2*e.B,x:0,y:0},o=new e.D(n,r,e.B);this.patterns.get(i).set(t.toString(),{bin:n,position:o})}destroyAtlasTextures(){for(const e of this.atlasTexture.values())e&&e.destroy();this.atlasTexture.clear()}bind(t,i){const r=t.gl;let n=this.atlasTexture.get(i);n?this.dirty&&(n.update(this.atlasImage.get(i)),this.dirty=!1):(n=new e.T(t,this.atlasImage.get(i),r.RGBA8),this.atlasTexture.set(i,n)),n.bind(r.LINEAR,r.CLAMP_TO_EDGE)}_updatePatternAtlas(t,i){const r=this.patterns.get(t),n=Array.from(r.values()).map(({bin:e})=>e),{w:o,h:s}=e.F(n),a=this.atlasImage.get(t);a.resize({width:o||1,height:s||1});const l=this.images.get(t);for(const[c,{bin:h,position:u}]of r.entries()){let t=u.padding;const r=h.x+t,n=h.y+t,o=l.get(c).data,s=o.width,d=o.height;t=t>1?t-1:t,e.q.copy(o,a,{x:0,y:0},{x:r,y:n},{width:s,height:d},i),e.q.copy(o,a,{x:0,y:d-t},{x:r,y:n-t},{width:s,height:t},i),e.q.copy(o,a,{x:0,y:0},{x:r,y:n+d},{width:s,height:t},i),e.q.copy(o,a,{x:s-t,y:0},{x:r-t,y:n},{width:t,height:d},i),e.q.copy(o,a,{x:0,y:0},{x:r+s,y:n},{width:t,height:d},i),e.q.copy(o,a,{x:s-t,y:d-t},{x:r-t,y:n-t},{width:t,height:t},i),e.q.copy(o,a,{x:0,y:d-t},{x:r+s,y:n-t},{width:t,height:t},i),e.q.copy(o,a,{x:0,y:0},{x:r+s,y:n+d},{width:t,height:t},i),e.q.copy(o,a,{x:s-t,y:0},{x:r-t,y:n+d},{width:t,height:t},i)}this.dirty=!0}beginFrame(){for(const e of this.images.keys())this.callbackDispatchedThisFrame.set(e,/* @__PURE__ */new Set)}dispatchRenderCallbacks(e,t){const i=this.images.get(t);for(const r of e){if(this.callbackDispatchedThisFrame.get(t).has(r.toString()))continue;this.callbackDispatchedThisFrame.get(t).add(r.toString());const e=i.get(r.toString());ie(e)&&this.updateImage(r,t,e)}}}class We{constructor(e,t,i,r){this.message=(e?`${e}: `:"")+i,r&&(this.identifier=r),null!=t&&t.__line__&&(this.line=t.__line__)}}class Xe extends We{}function Ye(t){const i=t.value,r=t.valueSpec,n=t.style,o=t.styleSpec,s=t.key,a=t.arrayElementValidator||bt;if(!Array.isArray(i))return[new We(s,i,`array expected, ${e.J(i)} found`)];if(r.length&&i.length!==r.length)return[new We(s,i,`array length ${r.length} expected, length ${i.length} found`)];if(r["min-length"]&&i.length<r["min-length"])return[new We(s,i,`array length at least ${r["min-length"]} expected, length ${i.length} found`)];let l={type:r.value,values:r.values,minimum:r.minimum,maximum:r.maximum,function:void 0};o.$version<7&&(l.function=r.function),e.G(r.value)&&(l=r.value);let c=[];for(let e=0;e<i.length;e++)c=c.concat(a({array:i,arrayIndex:e,value:i[e],valueSpec:l,style:n,styleSpec:o,key:`${s}[${e}]`},!0));return c}function Je(t){const i=t.key,r=t.value,n=t.valueSpec;if(!e.K(r))return[new We(i,r,`number expected, ${e.J(r)} found`)];if(r!=r)return[new We(i,r,"number expected, NaN found")];if("minimum"in n){let e=n.minimum;if(Array.isArray(n.minimum)&&(e=n.minimum[t.arrayIndex]),r<e)return[new We(i,r,`${r} is less than the minimum value ${e}`)]}if("maximum"in n){let e=n.maximum;if(Array.isArray(n.maximum)&&(e=n.maximum[t.arrayIndex]),r>e)return[new We(i,r,`${r} is greater than the maximum value ${e}`)]}return[]}function Ke(t){const i=t.key,r=t.value;if(!e.G(r))return[new We(i,r,`object expected, ${e.J(r)} found`)];const n=t.valueSpec,o=e.H(r.type);let s,a,l,c={};const h="categorical"!==o&&void 0===r.property,u=!h,d=function(t){const i=t.stops;return Array.isArray(i)&&Array.isArray(i[0])&&e.G(i[0][0])}(r),p=wt({key:t.key,value:t.value,valueSpec:t.styleSpec.function,style:t.style,styleSpec:t.styleSpec,objectElementValidators:{stops:function(e){if("identity"===o)return[new We(e.key,e.value,'identity function may not have a "stops" property')];let t=[];const i=e.value;return t=t.concat(Ye({key:e.key,value:i,valueSpec:e.valueSpec,style:e.style,styleSpec:e.styleSpec,arrayElementValidator:f})),Array.isArray(i)&&0===i.length&&t.push(new We(e.key,i,"array must have at least one stop")),t},default:function(e){return bt({key:e.key,value:e.value,valueSpec:n,style:e.style,styleSpec:e.styleSpec})}}});return"identity"===o&&h&&p.push(new We(t.key,t.value,'missing required property "property"')),"identity"===o||r.stops||p.push(new We(t.key,t.value,'missing required property "stops"')),"exponential"===o&&n.expression&&!e.M(n)&&p.push(new We(t.key,t.value,"exponential functions not supported")),t.styleSpec.$version>=8&&(u&&!e.N(n)?p.push(new We(t.key,t.value,"property functions not supported")):h&&!e.O(n)&&p.push(new We(t.key,t.value,"zoom functions not supported"))),"categorical"!==o&&!d||void 0!==r.property||p.push(new We(t.key,t.value,'"property" property is required')),p;function f(t){let i=[];const r=t.value,o=t.key;if(!Array.isArray(r))return[new We(o,r,`array expected, ${e.J(r)} found`)];if(2!==r.length)return[new We(o,r,`array length 2 expected, length ${r.length} found`)];if(d){if(!e.G(r[0]))return[new We(o,r,`object expected, ${e.J(r[0])} found`)];const n=r[0];if(void 0===n.zoom)return[new We(o,r,"object stop key must have zoom")];if(void 0===n.value)return[new We(o,r,"object stop key must have value")];const s=e.H(n.zoom);if("number"!=typeof s)return[new We(o,n.zoom,"stop zoom values must be numbers")];if(l&&l>s)return[new We(o,n.zoom,"stop zoom values must appear in ascending order")];s!==l&&(l=s,a=void 0,c={}),i=i.concat(wt({key:`${o}[0]`,value:r[0],valueSpec:{zoom:{}},style:t.style,styleSpec:t.styleSpec,objectElementValidators:{zoom:Je,value:m}}))}else i=i.concat(m({key:`${o}[0]`,value:r[0],style:t.style,styleSpec:t.styleSpec},r));return e.Q(e.S(r[1]))?i.concat([new We(`${o}[1]`,r[1],"expressions are not allowed in function stops.")]):i.concat(bt({key:`${o}[1]`,value:r[1],valueSpec:n,style:t.style,styleSpec:t.styleSpec}))}function m(t,i){const r=e.J(t.value),l=e.H(t.value),h=null!==t.value?t.value:i;if(s){if(r!==s)return[new We(t.key,h,`${r} stop domain type must match previous stop domain type ${s}`)]}else s=r;if("number"!==r&&"string"!==r&&"boolean"!==r&&"number"!=typeof l&&"string"!=typeof l&&"boolean"!=typeof l)return[new We(t.key,h,"stop domain value must be a number, string, or boolean")];if("number"!==r&&"categorical"!==o){let i=`number expected, ${r} found`;return e.N(n)&&void 0===o&&(i+='\nIf you intended to use a categorical function, specify `"type": "categorical"`.'),[new We(t.key,h,i)]}return"categorical"!==o||"number"!==r||"number"==typeof l&&isFinite(l)&&Math.floor(l)===l?"categorical"!==o&&"number"===r&&"number"==typeof l&&"number"==typeof a&&void 0!==a&&l<a?[new We(t.key,h,"stop domain values must appear in ascending order")]:(a=l,"categorical"===o&&l in c?[new We(t.key,h,"stop domain values must be unique")]:(c[l]=!0,[])):[new We(t.key,h,`integer expected, found ${String(l)}`)]}}function Qe(t){const i=("property"===t.expressionContext?e.V:e.U)(e.S(t.value),t.valueSpec);if("error"===i.result)return i.value.map(e=>new We(`${t.key}${e.key}`,t.value,e.message));const r=i.value.expression||i.value._styleExpression.expression;if("property"===t.expressionContext&&"text-font"===t.propertyKey&&!r.outputDefined())return[new We(t.key,t.value,`Invalid data expression for "${t.propertyKey}". Output values must be contained as literals within the expression.`)];if("property"===t.expressionContext&&"layout"===t.propertyType&&!e.Y(r))return[new We(t.key,t.value,'"feature-state" data expressions are not supported with layout properties.')];if("filter"===t.expressionContext)return et(r,t);if("appearance"===t.expressionContext)return tt(r,t);if(t.expressionContext&&0===t.expressionContext.indexOf("cluster")){if(!e.W(r,["zoom","feature-state"]))return[new We(t.key,t.value,'"zoom" and "feature-state" expressions are not supported with cluster properties.')];if("cluster-initial"===t.expressionContext&&!e.X(r))return[new We(t.key,t.value,"Feature data expressions are not supported with initial expression part of cluster properties.")]}return[]}function et(t,i){const r=new Set(["zoom","feature-state","pitch","distance-from-center"]);if(i.valueSpec&&i.valueSpec.expression)for(const e of i.valueSpec.expression.parameters)r.delete(e);if(0===r.size)return[];const n=[];return t instanceof e.Z&&r.has(t.name)?[new We(i.key,i.value,`["${t.name}"] expression is not supported in a filter for a ${i.object.type} layer with id: ${i.object.id}`)]:(t.eachChild(e=>{n.push(...et(e,i))}),n)}function tt(t,i){const r=/* @__PURE__ */new Set;if(i.valueSpec&&i.valueSpec.expression)for(const e of i.valueSpec.expression.parameters)r.add(e);if(0===r.size)return[];const n=[];return t instanceof e.Z&&!r.has(t.name)?[new We(i.key,i.value,`["${t.name}"] is not an allowed parameter`)]:(t.eachChild(e=>{n.push(...tt(e,i))}),n)}function it(t){const i=t.key,r=t.value,n=t.valueSpec,o=[];return Array.isArray(n.values)?n.values.includes(e.H(r))||o.push(new We(i,r,`expected one of [${n.values.join(", ")}], ${JSON.stringify(r)} found`)):Object.keys(n.values).includes(e.H(r))||o.push(new We(i,r,`expected one of [${Object.keys(n.values).join(", ")}], ${JSON.stringify(r)} found`)),o}function rt(t){return e.a1(e.S(t.value))?Qe(Object.assign({},t,{expressionContext:"filter",valueSpec:t.styleSpec[`filter_${t.layerType||"fill"}`]})):nt(t)}function nt(t){const i=t.value,r=t.key;if(!Array.isArray(i))return[new We(r,i,`array expected, ${e.J(i)} found`)];if(i.length<1)return[new We(r,i,"filter array must have at least 1 element")];const n=t.styleSpec;let o=it({key:`${r}[0]`,value:i[0],valueSpec:n.filter_operator});const s=()=>{i.length>=2&&(e.$(i[1])||o.push(new We(`${r}[1]`,i[1],`string expected, ${e.J(i[1])} found`)));for(let t=2;t<i.length;t++)"$type"===e.H(i[1])?o=o.concat(it({key:`${r}[${t}]`,value:i[t],valueSpec:n.geometry_type})):e.$(i[t])||e.K(i[t])||e._(i[t])||o.push(new We(`${r}[${t}]`,i[t],`string, number, or boolean expected, ${e.J(i[t])} found.`))};switch(e.H(i[0])){case"<":case"<=":case">":case">=":i.length>=2&&"$type"===e.H(i[1])&&o.push(new We(r,i,`"$type" cannot be use with operator "${i[0]}"`)),3!==i.length&&o.push(new We(r,i,`filter array for operator "${i[0]}" must have 3 elements`)),s();break;case"==":case"!=":3!==i.length&&o.push(new We(r,i,`filter array for operator "${i[0]}" must have 3 elements`)),s();break;case"in":case"!in":s();break;case"any":case"all":case"none":for(let e=1;e<i.length;e++)o=o.concat(nt({key:`${r}[${e}]`,value:i[e],style:t.style,styleSpec:t.styleSpec}));break;case"has":case"!has":2!==i.length?o.push(new We(r,i,`filter array for "${i[0]}" operator must have 2 elements`)):e.$(i[1])||o.push(new We(`${r}[1]`,i[1],`string expected, ${e.J(i[1])} found`))}return o}const ot=/^{([^}]+)}$/;function st(t,i){const r=t.key,n=t.style,o=t.layer,s=t.styleSpec,a=t.value,l=t.objectKey,c=s[`${i}_${t.layerType}`];if(!c)return[];const h=l.match(e.a2);if(h&&c[h[1]])return e.Q(e.S(a))?[].concat(bt({key:r,value:a,valueSpec:{type:"string",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},style:n,styleSpec:s,expressionContext:"property",propertyType:i,propertyKey:l})):bt({key:r,value:a,valueSpec:{type:"string"},style:n,styleSpec:s});const u=l.match(e.a3);if("paint"===i&&u&&c[u[1]]&&c[u[1]].transition)return bt({key:r,value:a,valueSpec:s.transition,style:n,styleSpec:s});const d=t.valueSpec||c[l];if(!d)return[new Xe(r,a,`unknown property "${l}"`)];let p;if(e.$(a)&&e.N(d)&&!d.tokens&&(p=ot.exec(a)))return[new We(r,a,`"${l}" does not support interpolation syntax\nUse an identity property function instead: \`{ "type": "identity", "property": ${p?JSON.stringify(p[1]):'"_"'} }\`.`)];const f=[];if("symbol"===t.layerType)"text-field"!==l||!n||n.glyphs||n.imports||f.push(new We(r,a,'use of "text-field" requires a style "glyphs" property')),"text-font"===l&&e.a4(e.S(a))&&"identity"===e.H(a.type)&&f.push(new We(r,a,'"text-font" does not support identity functions'));else if("model"===t.layerType&&"paint"===i&&o&&o.layout&&Object.hasOwn(o.layout,"model-id")&&e.N(d)&&(e.a5(d)||e.O(d))){const t=e.V(e.S(a),d).value,i="expression"in t&&t.expression||"_styleExpression"in t&&t._styleExpression&&t._styleExpression.expression;i&&!e.W(i,["measure-light"])&&("model-emissive-strength"===l&&e.X(i)&&e.Y(i)||f.push(new We(r,a,`${l} does not support measure-light expressions when the model layer source is vector tile or GeoJSON.`)))}return f.concat(bt({key:t.key,value:a,valueSpec:d,style:n,styleSpec:s,expressionContext:"property",propertyType:i,propertyKey:l}))}function at(e){return st(e,"paint")}function lt(e){return st(e,"layout")}function ct(t){let i=[];const r=t.value,n=t.key,o=t.style,s=t.styleSpec;if(!e.G(r))return[new We(n,r,"object expected")];r.type||r.ref||i.push(new We(n,r,'either "type" or "ref" is required'));let a=e.H(r.type);const l=e.H(r.ref);if(r.id){const s=e.H(r.id);for(let a=0;a<t.arrayIndex;a++){const t=o.layers[a];e.H(t.id)===s&&i.push(new We(n,r.id,`duplicate layer id "${s}", previously used at line ${t.id.__line__}`))}}if("ref"in r){let t;["type","source","source-layer","filter","layout"].forEach(e=>{e in r&&i.push(new We(n,r[e],`"${e}" is prohibited for ref layers`))}),o.layers.forEach(i=>{e.H(i.id)===l&&(t=i)}),t?t.ref?i.push(new We(n,r.ref,"ref cannot reference another ref layer")):a=e.H(t.type):"string"==typeof l&&i.push(new We(n,r.ref,`ref layer "${l}" not found`))}else if("background"!==a&&"sky"!==a&&"slot"!==a)if(r.source)if(e.$(r.source)){const t=o.sources&&o.sources[r.source],s=t&&e.H(t.type);t?"vector"===s&&"raster"===a?i.push(new We(n,r.source,`layer "${r.id}" requires a raster source`)):"raster"===s&&"raster"!==a?i.push(new We(n,r.source,`layer "${r.id}" requires a vector source`)):"vector"!==s||r["source-layer"]?"raster-dem"===s&&"hillshade"!==a?i.push(new We(n,r.source,"raster-dem source can only be used with layer type 'hillshade'.")):"raster-array"!==s||["raster","raster-particle"].includes(a)?"line"===a&&r.paint&&r.paint["line-gradient"]&&"geojson"===s&&!t.lineMetrics?i.push(new We(n,r,`layer "${r.id}" specifies a line-gradient, which requires the GeoJSON source to have \`lineMetrics\` enabled.`)):"line"===a&&r.paint&&r.paint["line-trim-offset"]&&"geojson"===s&&!t.lineMetrics?i.push(new We(n,r,`layer "${r.id}" specifies a line-trim-offset, which requires the GeoJSON source to have \`lineMetrics\` enabled.`)):"raster-particle"===a&&"raster-array"!==s&&i.push(new We(n,r.source,`layer "${r.id}" requires a 'raster-array' source.`)):i.push(new We(n,r.source,"raster-array source can only be used with layer type 'raster'.")):i.push(new We(n,r,`layer "${r.id}" must specify a "source-layer"`)):i.push(new We(n,r.source,`source "${r.source}" not found`))}else i.push(new We(`${n}.source`,r.source,'"source" must be a string'));else i.push(new We(n,r,'missing required property "source"'));return i=i.concat(wt({key:n,value:r,valueSpec:s.layer,style:t.style,styleSpec:t.styleSpec,objectElementValidators:{"*":()=>[],type:()=>bt({key:`${n}.type`,value:r.type,valueSpec:s.layer.type,style:t.style,styleSpec:t.styleSpec,object:r,objectKey:"type"}),filter:e=>rt(Object.assign({layerType:a},e)),layout:e=>wt({layer:r,key:e.key,value:e.value,valueSpec:{},style:e.style,styleSpec:e.styleSpec,objectElementValidators:{"*":e=>lt(Object.assign({layerType:a},e))}}),paint:e=>wt({layer:r,key:e.key,value:e.value,valueSpec:{},style:e.style,styleSpec:e.styleSpec,objectElementValidators:{"*":e=>at(Object.assign({layerType:a,layer:r},e))}}),appearances(t){const i=Ye({key:t.key,value:t.value,valueSpec:t.valueSpec,style:t.style,styleSpec:t.styleSpec,arrayElementValidator:t=>function(t){const{key:i,layer:r,layerType:n}=t,o=e.H(t.value),s=e.H(o.name),a=e.H(o.condition),l=wt({key:i,value:o,valueSpec:t.styleSpec.appearance,style:t.style,styleSpec:t.styleSpec,objectElementValidators:{condition:t=>function(t){const i=[];return i.push(...Qe({key:t.key,value:t.object.condition,valueSpec:e.a6.appearance.condition,expressionContext:"appearance"})),i}(Object.assign({layer:r,layerType:n},t)),properties:e=>function(e){const t=[],{styleSpec:i,layer:r,layerType:n}=e,o=i[`paint_${n}`],s=i[`layout_${n}`],a=e.object[e.objectKey];for(const l in a){const i=l in o?"paint":l in s?"layout":void 0;if(!i){t.push(new We(e.key,l,`unknown property "${l}" for layer type "${n}"`));continue}const c=Object.assign({},e,{key:`${e.key}.${l}`,object:a,objectKey:l,layer:r,layerType:n,value:a[l],valueSpec:"paint"===i?o[l]:s[l]});t.push(...st(c,i))}return t}(Object.assign({layer:r,layerType:n},e))}});return"hidden"!==s&&void 0===a&&l.push(new We(t.key,"name",'Appearance with name different than "hidden" must have a condition')),l}(Object.assign({layerType:a,layer:r},t))}),n=Array.isArray(t.value)?t.value:[],o=/* @__PURE__ */new Set;return n.forEach((n,s)=>{const a=e.H(n.name);if(a)if(o.has(a)){const n=e.H(r.id);i.push(new We(t.key,a,`Duplicated appearance name "${a}" for layer "${n}"`))}else o.add(a)}),i}}})),i}function ht({key:t,value:i}){return e.$(i)?[]:[new We(t,i,`string expected, ${e.J(i)} found`)]}const ut={promoteId:function t({key:i,value:r}){if(e.$(r))return ht({key:i,value:r});if(Array.isArray(r)){const t=[],n=e.S(r),o=e.U(n);return"error"===o.result?(o.value.forEach(e=>{t.push(new We(`${i}${e.key}`,null,`${e.message}`))}),t):(e.W(o.value.expression,["zoom","heatmap-density","line-progress","raster-value","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center","measure-light","raster-particle-speed"])||t.push(new We(`${i}`,null,"promoteId expression should be only feature dependent")),t)}if(!e.G(r))return[new We(i,r,`string, expression or object expected, "${e.J(r)}" found`)];const n=[];for(const e in r)n.push(...t({key:`${i}.${e}`,value:r[e]}));return n}};function dt(t){const i=t.value,r=t.key,n=t.styleSpec,o=t.style;if(!e.G(i))return[new We(r,i,`object expected, ${e.J(i)} found`)];if(!("type"in i))return[new We(r,i,'"type" is required')];const s=e.H(i.type);let a=[];switch(["vector","raster","raster-dem","raster-array"].includes(s)&&("url"in i||"tiles"in i||a.push(new Xe(r,i,'Either "url" or "tiles" is required.'))),s){case"vector":case"raster":case"raster-dem":case"raster-array":return a=a.concat(wt({key:r,value:i,valueSpec:n[`source_${s.replace("-","_")}`],style:t.style,styleSpec:n,objectElementValidators:ut})),a;case"geojson":if(a=wt({key:r,value:i,valueSpec:n.source_geojson,style:o,styleSpec:n,objectElementValidators:ut}),"cluster"in i&&"clusterProperties"in i){if(!e.G(i.clusterProperties))return[new We(`${r}.clusterProperties`,i,`object expected, ${e.J(i)} found`)];for(const e in i.clusterProperties){const t=i.clusterProperties[e];if(!Array.isArray(t))return[new We(`${r}.clusterProperties.${e}`,t,"array expected")];const[n,o]=t,s="string"==typeof n?[n,["accumulated"],["get",e]]:n;a.push(...Qe({key:`${r}.${e}.map`,value:o,expressionContext:"cluster-map"})),a.push(...Qe({key:`${r}.${e}.reduce`,value:s,expressionContext:"cluster-reduce"}))}}return a;case"video":return wt({key:r,value:i,valueSpec:n.source_video,style:o,styleSpec:n});case"image":return wt({key:r,value:i,valueSpec:n.source_image,style:o,styleSpec:n});case"canvas":return[new We(r,null,"Please use runtime APIs to add canvas sources, rather than including them in stylesheets.","source.canvas")];default:return it({key:`${r}.type`,value:i.type,valueSpec:{values:pt(n)}})}}function pt(e){return e.source.reduce((t,i)=>{const r=e[i];return"enum"===r.type.type&&(t=t.concat(Object.keys(r.type.values||{}))),t},[])}function ft(e,t){const i=!e.includes("://");try{return new URL(e,i&&t?"http://example.com":void 0),!0}catch(e){return!1}}function mt(t){const i=t.value;return i?e.$(i)?ft(i,!0)?[]:[new We(t.key,i,`invalid url "${i}"`)]:[new We(t.key,i,`string expected, "${e.J(i)}" found`)]:[]}function _t(t){const i=t.value,r=t.styleSpec,n=r.light,o=t.style;if(void 0===i)return[];if(!e.G(i))return[new We("light",i,`object expected, ${e.J(i)} found`)];let s=[];for(const a in i){const t=a.match(e.a3),l=a.match(e.a2);s=s.concat(l&&n[l[1]]?bt({key:a,value:i[a],valueSpec:{type:"string"},style:o,styleSpec:r}):t&&n[t[1]]&&n[t[1]].transition?bt({key:a,value:i[a],valueSpec:r.transition,style:o,styleSpec:r}):n[a]?bt({key:a,value:i[a],valueSpec:n[a],style:o,styleSpec:r}):[new We(a,i[a],`unknown property "${a}"`)])}return s}function gt(t){const i=t.value;if(!i)return[];const r=t.key;if(!e.G(i))return[new We(r,i,`object expected, ${e.J(i)} found`)];let n=[];const o=t.styleSpec,s=o["light-3d"],a=t.style,l=t.style.lights;for(const e of["type","id"])if(!(e in i))return n=n.concat([new We(r,i,`missing property "${e}"`)]),n;if(!e.$(i.type))return n=n.concat([new We(`${r}.type`,i.type,"string expected")]),n;if(l)for(let u=0;u<t.arrayIndex;u++){const t=e.H(i.type),o=l[u];e.H(o.type)===t&&n.push(new We(r,i.id,`duplicate light type "${i.type}", previously defined at line ${o.id.__line__}`))}const c=`properties_light_${i.type}`;if(!(c in o))return n=n.concat([new We(`${r}.type`,i,`Invalid light type ${i.type}`)]),n;const h=o[c];for(const u in i)if("properties"===u){const r=i[u];if(!e.G(r))return n=n.concat([new We("properties",r,`object expected, ${e.J(r)} found`)]),n;for(const s in r){const l=s.match(e.a3),c=s.match(e.a2);n=n.concat(c&&h[c[1]]?bt({key:u,value:r[s],valueSpec:{type:"string"},style:a,styleSpec:o}):l&&h[l[1]]&&h[l[1]].transition?bt({key:u,value:i[u],valueSpec:o.transition,style:a,styleSpec:o}):h[s]?bt({key:s,value:r[s],valueSpec:h[s],style:a,styleSpec:o}):[new Xe(t.key,r[s],`unknown property "${s}"`)])}}else n=n.concat(s[u]?bt({key:u,value:i[u],valueSpec:s[u],style:a,styleSpec:o}):[new Xe(u,i[u],`unknown property "${u}"`)]);return n}function yt(t){const i=t.value,r=t.key,n=t.style,o=t.styleSpec,s=o.terrain;if(null==i)return[];if(!e.G(i))return[new We("terrain",i,`object expected, ${e.J(i)} found`)];let a=[];for(const l in i){const t=l.match(e.a3),r=l.match(e.a2);a=a.concat(r&&s[r[1]]?bt({key:l,value:i[l],valueSpec:{type:"string"},style:n,styleSpec:o}):t&&s[t[1]]&&s[t[1]].transition?bt({key:l,value:i[l],valueSpec:o.transition,style:n,styleSpec:o}):s[l]?bt({key:l,value:i[l],valueSpec:s[l],style:n,styleSpec:o}):[new Xe(l,i[l],`unknown property "${l}"`)])}if(i.source)if(e.$(i.source)){const t=n.sources&&n.sources[i.source],o=t&&e.H(t.type);t?"raster-dem"!==o&&a.push(new We(`${r}.source`,i.source,`terrain cannot be used with a source of type ${o}, it only be used with a "raster-dem" source type`)):a.push(new We(`${r}.source`,i.source,`source "${i.source}" not found`))}else a.push(new We(`${r}.source`,i.source,"source must be a string"));else a.push(new We(r,i,'terrain is missing required property "source"'));return a}function xt(t){const i=t.value,r=t.style,n=t.styleSpec,o=n.fog;if(void 0===i)return[];if(!e.G(i))return[new We("fog",i,`object expected, ${e.J(i)} found`)];let s=[];for(const a in i){const t=a.match(e.a3),l=a.match(e.a2);s=s.concat(l&&o[l[1]]?bt({key:a,value:i[a],valueSpec:{type:"string"},style:r,styleSpec:n}):t&&o[t[1]]&&o[t[1]].transition?bt({key:a,value:i[a],valueSpec:n.transition,style:r,styleSpec:n}):o[a]?bt({key:a,value:i[a],valueSpec:o[a],style:r,styleSpec:n}):[new Xe(a,i[a],`unknown property "${a}"`)])}return s}const vt={"*":()=>[],array:Ye,boolean:function(t){const i=t.value,r=t.key;return e._(i)?[]:[new We(r,i,`boolean expected, ${e.J(i)} found`)]},number:Je,color:function({key:t,value:i}){return e.$(i)?null===e.a0.parseCSSColor(i)?[new We(t,i,`color expected, "${i}" found`)]:[]:[new We(t,i,`color expected, ${e.J(i)} found`)]},enum:it,filter:rt,function:Ke,layer:ct,object:wt,source:dt,model:mt,light:_t,"light-3d":gt,terrain:yt,fog:xt,string:ht,formatted:function(e){return 0===ht(e).length?[]:Qe(e)},resolvedImage:function(e){return 0===ht(e).length?[]:Qe(e)},projection:function(t){const i=t.value,r=t.styleSpec,n=r.projection,o=t.style;if(e.G(i)){let e=[];for(const t in i)e=e.concat(bt({key:t,value:i[t],valueSpec:n[t],style:o,styleSpec:r}));return e}return e.$(i)?[]:[new We("projection",i,`object or string expected, ${e.J(i)} found`)]},import:function(t){const i=t.key,{value:r,styleSpec:n}=t;if(!e.G(r))return[new We(i,r,"import must be an object")];const{data:o,...s}=r;Object.defineProperty(s,"__line__",{value:r.__line__,enumerable:!1});let a=wt(Object.assign({},t,{value:s,valueSpec:n.import}));return""===e.H(s.id)&&a.push(new We(`${t.key}.id`,s,"import id can't be an empty string")),o&&(a=a.concat(St(o,n,{key:`${t.key}.data`}))),a},iconset:function(t){const i=t.value,r=t.key,n=t.styleSpec,o=t.style;if(!e.G(i))return[new We(r,i,"object expected")];if(!i.type)return[new We(r,i,'"type" is required')];const s=e.H(i.type);let a=[];if(a=a.concat(wt({key:r,value:i,valueSpec:n[`iconset_${s}`],style:o,styleSpec:n})),function(e,t){return!("source"!==e||!t.source)}(s,i)){const t=o.sources&&o.sources[i.source],n=t&&e.H(t.type);t?"raster-array"!==n&&a.push(new We(r,i.source,`iconset cannot be used with a source of type ${String(n)}, it only be used with a "raster-array" source type`)):a.push(new We(r,i.source,`source "${i.source}" not found`))}return a}};function bt(t,i=!1){const r=t.value,n=t.valueSpec,o=t.styleSpec;if(n.expression){if(e.a4(e.H(r)))return Ke(t);if(e.Q(e.S(r)))return Qe(t)}if(n.type&&vt[n.type]){const e=vt[n.type](t);return!0===i&&e.length>0&&Array.isArray(t.value)?Qe(t):e}return wt(Object.assign({},t,{valueSpec:n.type?o[n.type]:n}))}function wt(t){const i=t.key,r=t.value,n=t.valueSpec||{},o=t.objectElementValidators||{},s=t.style,a=t.styleSpec;if(!e.G(r))return[new We(i,r,`object expected, ${e.J(r)} found`)];let l=[];for(const e in r){const t=e.split(".")[0];let c;o[t]?c=o[t]:n[t]?c=bt:o["*"]?c=o["*"]:n["*"]&&(c=bt),c?l=l.concat(c({key:(i?`${i}.`:i)+e,value:r[e],valueSpec:n[t]||n["*"],style:s,styleSpec:a,object:r,objectKey:e},r)):l.push(new Xe(i,r[e],`unknown property "${e}"`))}for(const e in n){if(o[e])continue;const t=n[e];t.required&&void 0===t.default&&void 0===r[e]&&l.push(new We(i,r,`missing required property "${e}"`))}return l}function Tt({key:e,value:t}){const i=ht({key:e,value:t});if(i.length)return i;const r=t;return r.includes("{fontstack}")||i.push(new We(e,t,'"glyphs" url must include a "{fontstack}" token')),r.includes("{range}")||i.push(new We(e,t,'"glyphs" url must include a "{range}" token')),i}function St(t,i=e.a6,r={}){return wt({key:r.key||"",value:t,valueSpec:Object.assign({},i.$root,{"*":{type:"*"}}),styleSpec:i,style:t,objectElementValidators:{glyphs:Tt}})}function It(t,i=e.a6){return kt(St(t,i))}const Et=e=>kt(dt(e)),At=e=>kt(_t(e)),Mt=e=>kt(gt(e)),Ct=e=>kt(yt(e)),Pt=e=>kt(xt(e)),Dt=t=>kt(function(t){const i=t.value,r=t.style,n=t.styleSpec,o=n.snow;if(void 0===i)return[];if(!e.G(i))return[new We("snow",i,`object expected, ${e.J(i)} found`)];let s=[];for(const a in i){const t=a.match(e.a3);s=s.concat(t&&o[t[1]]&&o[t[1]].transition?bt({key:a,value:i[a],valueSpec:n.transition,style:r,styleSpec:n}):o[a]?bt({key:a,value:i[a],valueSpec:o[a],style:r,styleSpec:n}):[new Xe(a,i[a],`unknown property "${a}"`)])}return s}(t)),Rt=t=>kt(function(t){const i=t.value,r=t.style,n=t.styleSpec,o=n.rain;if(void 0===i)return[];if(!e.G(i))return[new We("rain",i,`object expected, ${e.J(i)} found`)];let s=[];for(const a in i){const t=a.match(e.a3);s=s.concat(t&&o[t[1]]&&o[t[1]].transition?bt({key:a,value:i[a],valueSpec:n.transition,style:r,styleSpec:n}):o[a]?bt({key:a,value:i[a],valueSpec:o[a],style:r,styleSpec:n}):[new Xe(a,i[a],`unknown property "${a}"`)])}return s}(t)),zt=e=>kt(ct(e)),Lt=e=>kt(rt(e)),Ft=e=>kt(at(e)),Ot=e=>kt(lt(e)),Bt=e=>kt(mt(e));function kt(e){return e.slice().sort((e,t)=>e.line&&t.line?e.line-t.line:0)}function Nt(t,i){let r=!1;if(i&&i.length)for(const n of i)n instanceof Xe?e.w(n.message):(t.fire(new e.y(new Error(n.message))),r=!0);return r}const Ut=e.a6.light;let Vt;class jt extends e.E{constructor(t,i="flat"){super(),this._transitionable=new e.a7(Vt||(Vt=new e.a8({anchor:new e.a9(Ut.anchor),position:new e.aa(Ut.position),color:new e.a9(Ut.color),intensity:new e.a9(Ut.intensity)}))),this.setLight(t,i),this._transitioning=this._transitionable.untransitioned()}getLight(){return this._transitionable.serialize()}setLight(e,t,i={}){this._validate(At,e,i)||(this._transitionable.setTransitionOrValue(e),this.id=t)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}_validate(t,i,r){return(!r||!1!==r.validate)&&Nt(this,t.call(It,Object.assign({value:i,style:{glyphs:!0,sprite:!0},styleSpec:e.a6})))}}const Gt=e.a6.terrain;let Ht=class extends e.E{constructor(t,i,r,n,o){super(),this.scope=r,this._transitionable=new e.a7(new e.a8({source:new e.a9(Gt.source),exaggeration:new e.a9(Gt.exaggeration)}),r,n),this._transitionable.setTransitionOrValue(t,n),this._transitioning=this._transitionable.untransitioned(),this.drapeRenderMode=i,this.worldview=o}get(){return this._transitionable.serialize()}set(e,t){this._transitionable.setTransitionOrValue(e,t)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}getExaggeration(t){return this._transitioning.possiblyEvaluate(new e.ab(t,{worldview:this.worldview})).get("exaggeration")}getAttenuationRange(){if(!this.isZoomDependent())return null;const t=this._transitionable._values.exaggeration;if(!t)return null;const i=t.value.expression;if(!i)return null;let r=-1,n=-1,o=1;for(const s of i.zoomStops)o=i.evaluate(new e.ab(s,{worldview:this.worldview})),o>.01?(r=s,n=-1):n=s;return o<.01&&r>0&&n>r?[r,n]:null}isZoomDependent(){const t=this._transitionable._values.exaggeration;return null!=t&&null!=t.value&&null!=t.value.expression&&t.value.expression instanceof e.ac}};const $t=.05;function qt(t,i,r){const n=e.ag(45,65,r),[o,s]=t.range;let a=1-Math.min(1,Math.exp((i-o)/(s-o)*-6));return a*=a*a,a=Math.min(1,1.00747*a),a*n*t.alpha}function Zt(t,i,r,n,o){const s=e.ae([],[i,r,n],o.mercatorFogMatrix);return qt(t,e.af(s),o.pitch)}function Wt(t,i,r,n,o,s,a){const l=[[r,n,0],[o,n,0],[o,s,0],[r,s,0]];let c=Number.MAX_VALUE,h=-Number.MAX_VALUE;for(const u of l){const t=e.ae([],u,i),r=e.af(t);c=Math.min(c,r),h=Math.max(h,r)}return[qt(t,c,a.pitch),qt(t,h,a.pitch)]}const Xt=e.a6.fog;class Yt extends e.E{constructor(t,i,r,n){super();const o=new e.a8({range:new e.a9(Xt.range),color:new e.a9(Xt.color),"color-use-theme":new e.a9({type:"string","property-type":"data-constant",default:"default"}),"high-color":new e.a9(Xt["high-color"]),"high-color-use-theme":new e.a9({type:"string","property-type":"data-constant",default:"default"}),"space-color":new e.a9(Xt["space-color"]),"space-color-use-theme":new e.a9({type:"string","property-type":"data-constant",default:"default"}),"horizon-blend":new e.a9(Xt["horizon-blend"]),"star-intensity":new e.a9(Xt["star-intensity"]),"vertical-range":new e.a9(Xt["vertical-range"])});this._transitionable=new e.a7(o,r,n),this.set(t,n),this._transitioning=this._transitionable.untransitioned(),this._transform=i,this.properties=new e.ah(o),this.scope=r}get state(){const t=this._transform,i="globe"===t.projection.name,r=e.ai(t.zoom),n=this.properties.get("range"),o=[2,4.5],s=.5/Math.tan(.5*t._fov),a=[n[0]+s,n[1]+s];return{range:i?[e.aj(o[0],a[0],r),e.aj(o[1],a[1],r)]:a,horizonBlend:this.properties.get("horizon-blend"),alpha:this.properties.get("color").a}}get(){return this._transitionable.serialize()}set(e,t,i={}){if(this._validate(Pt,e,i))return;const r=Object.assign({},e);for(const n of Object.keys(Xt))void 0===r[n]&&(r[n]=Xt[n].default);this._options=r,this._transitionable.setTransitionOrValue(this._options,t)}getOpacity(t){if(!this._transform.projection.supportsFog)return 0;const i=this.properties&&this.properties.get("color")||1;return("globe"===this._transform.projection.name?1:e.ag(45,65,t))*i.a}getOpacityAtLatLng(t,i){return this._transform.projection.supportsFog?function(t,i,r){const n=e.ad.fromLngLat(i),o=r.elevation?r.elevation.getAtPointOrZero(n):0;return Zt(t,n.x,n.y,o,r)}(this.state,t,i):0}getOpacityForTile(t){if(!this._transform.projection.supportsFog)return[1,1];const i=this._transform.calculateFogTileMatrix(t.toUnwrapped());return Wt(this.state,i,0,0,e.ak,e.ak,this._transform)}getOpacityForBounds(e,t,i,r,n){return this._transform.projection.supportsFog?Wt(this.state,e,t,i,r,n,this._transform):[1,1]}getRangeForProjection(){return this._transform.projection.supportsFog?this.state.range:[0,1]}isVisibleOnFrustum(t){if(!this._transform.projection.supportsFog)return!1;for(const i of[4,5,6,7]){const r=t.points[i];let n;if(r[2]>=0)n=r;else{const o=t.points[i-4];n=e.al(o,r,o[2]/(o[2]-r[2]))}if(Zt(this.state,n[0],n[1],0,this._transform)>=$t)return!0}return!1}updateConfig(e){this._transitionable.setTransitionOrValue(this._options,e)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}_validate(t,i,r){return(!r||!1!==r.validate)&&Nt(this,t.call(It,Object.assign({value:i,style:{glyphs:!0,sprite:!0},styleSpec:e.a6})))}}let Jt,Kt,Qt=class extends e.E{constructor(t,i,r,n){super();const o=Jt||(Jt=new e.a8({density:new e.a9(e.a6.snow.density),intensity:new e.a9(e.a6.snow.intensity),color:new e.a9(e.a6.snow.color),opacity:new e.a9(e.a6.snow.opacity),vignette:new e.a9(e.a6.snow.vignette),"vignette-color":new e.a9(e.a6.snow["vignette-color"]),"center-thinning":new e.a9(e.a6.snow["center-thinning"]),direction:new e.a9(e.a6.snow.direction),"flake-size":new e.a9(e.a6.snow["flake-size"])}));this._transitionable=new e.a7(o,r,n),this.set(t,n),this._transitioning=this._transitionable.untransitioned(),this.properties=new e.ah(o),this.scope=r}get state(){const t=this.properties.get("opacity"),i=this.properties.get("color"),r=this.properties.get("direction"),n=e.am(r[0]),o=-Math.max(e.am(r[1]),.01),s=[Math.cos(n)*Math.cos(o),Math.sin(n)*Math.cos(o),Math.sin(o)],a=this.properties.get("vignette"),l=this.properties.get("vignette-color");return l.a=a,{density:this.properties.get("density"),intensity:this.properties.get("intensity"),color:new e.C(i.r,i.g,i.b,i.a*t),direction:s,centerThinning:this.properties.get("center-thinning"),flakeSize:this.properties.get("flake-size"),vignetteColor:l}}get(){return this._transitionable.serialize()}set(t,i,r={}){if(this._validate(Dt,t,r))return;const n=Object.assign({},t),o=e.a6.snow;for(const e of Object.keys(o))void 0===n[e]&&(n[e]=o[e].default);this._options=n,this._transitionable.setTransitionOrValue(this._options,i)}updateConfig(e){this._transitionable.setTransitionOrValue(this._options,e)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}_validate(t,i,r){return(!r||!1!==r.validate)&&Nt(this,t.call(It,Object.assign({value:i,style:{glyphs:!0,sprite:!0},styleSpec:e.a6})))}},ei=class extends e.E{constructor(t,i,r,n){super();const o=Kt||(Kt=new e.a8({density:new e.a9(e.a6.rain.density),intensity:new e.a9(e.a6.rain.intensity),color:new e.a9(e.a6.rain.color),opacity:new e.a9(e.a6.rain.opacity),vignette:new e.a9(e.a6.rain.vignette),"vignette-color":new e.a9(e.a6.rain["vignette-color"]),"center-thinning":new e.a9(e.a6.rain["center-thinning"]),direction:new e.a9(e.a6.rain.direction),"droplet-size":new e.a9(e.a6.rain["droplet-size"]),"distortion-strength":new e.a9(e.a6.rain["distortion-strength"])}));this._transitionable=new e.a7(o,r,n),this.set(t,n),this._transitioning=this._transitionable.untransitioned(),this.properties=new e.ah(o),this.scope=r}get state(){const t=this.properties.get("opacity"),i=this.properties.get("color"),r=this.properties.get("direction"),n=e.am(r[0]),o=-Math.max(e.am(r[1]),.01),s=[Math.cos(n)*Math.cos(o),Math.sin(n)*Math.cos(o),Math.sin(o)],a=this.properties.get("vignette-color");return a.a=this.properties.get("vignette"),{density:this.properties.get("density"),intensity:this.properties.get("intensity"),color:new e.C(i.r,i.g,i.b,i.a*t),direction:s,centerThinning:this.properties.get("center-thinning"),dropletSize:this.properties.get("droplet-size"),distortionStrength:this.properties.get("distortion-strength"),vignetteColor:a}}get(){return this._transitionable.serialize()}set(t,i,r={}){if(this._validate(Rt,t,r))return;const n=Object.assign({},t),o=e.a6.rain;for(const e of Object.keys(o))void 0===n[e]&&(n[e]=o[e].default);this._options=n,this._transitionable.setTransitionOrValue(this._options,i)}updateConfig(e){this._transitionable.setTransitionOrValue(this._options,e)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}_validate(t,i,r){return(!r||!1!==r.validate)&&Nt(this,t.call(It,Object.assign({value:i,style:{glyphs:!0,sprite:!0},styleSpec:e.a6})))}};const ti={workerUrl:"",workerClass:null,workerParams:void 0};function ii(e){return null!=ti.workerClass?new ti.workerClass:new self.Worker(ti.workerUrl,Object.assign({name:e},ti.workerParams))}const ri="mapboxgl_preloaded_worker_pool";class ni{constructor(e){this.active={},this.name=e}acquire(e,t=ni.workerCount){if(!this.workers)for(this.workers=[];this.workers.length<t;){const t=ii(`${this.name||""}WorkerPool: ${e}-${this.workers.length}`);this.workers.push(t)}return this.active[e]=!0,this.workers.slice()}release(e){delete this.active[e],this.workers&&0===this.numActive()&&(this.workers.forEach(e=>{e.terminate()}),this.workers=null)}isPreloaded(){return!!this.active[ri]}numActive(){return Object.keys(this.active).length}}ni.workerCount=2;class oi{constructor(t,i,r="Worker",n=ni.workerCount){this.workerPool=t,this.actors=[],this.currentActor=0,this.id=e.an();const o=this.workerPool.acquire(this.id,n);for(let e=0;e<o.length;e++){const t=new oi.Actor(o[e],i,this.id);t.name=`${r} ${e}`,this.actors.push(t)}this.ready=!1,this.broadcast("checkIfReady",null,()=>{this.ready=!0})}broadcast(t,i,r){e.ao(this.actors,(e,r)=>{e.send(t,i,r)},r=r||function(){})}getActor(){return this.currentActor=(this.currentActor+1)%this.actors.length,this.actors[this.currentActor]}remove(){this.actors.forEach(e=>{e.remove()}),this.actors=[],this.workerPool.release(this.id)}}oi.Actor=e.ap;class si extends e.E{constructor(t,i,r,n){super(),this.scope=r,this._options=t,this.properties=new e.ah(i),this._transitionable=new e.a7(i,r,n),this._transitionable.setTransitionOrValue(t.properties),this._transitioning=this._transitionable.untransitioned()}updateConfig(e){this._transitionable.setTransitionOrValue(this._options.properties,e)}updateTransitions(e){this._transitioning=this._transitionable.transitioned(e,this._transitioning)}hasTransition(){return this._transitioning.hasTransition()}recalculate(e){this.properties=this._transitioning.possiblyEvaluate(e)}get(){return this._options.properties=this._transitionable.serialize(),this._options}set(e,t){this._options=e,this._transitionable.setTransitionOrValue(e.properties,t)}shadowsEnabled(){return!!this.properties&&!0===this.properties.get("cast-shadows")}}let ai;const li=()=>ai||(ai=new e.a8({color:new e.a9(e.a6.properties_light_ambient.color),"color-use-theme":new e.a9({type:"string",default:"default","property-type":"data-constant"}),intensity:new e.a9(e.a6.properties_light_ambient.intensity)}));let ci;const hi=()=>ci||(ci=new e.a8({direction:new e.aq(e.a6.properties_light_directional.direction),color:new e.a9(e.a6.properties_light_directional.color),"color-use-theme":new e.a9({type:"string",default:"default","property-type":"data-constant"}),intensity:new e.a9(e.a6.properties_light_directional.intensity),"cast-shadows":new e.a9(e.a6.properties_light_directional["cast-shadows"]),"shadow-quality":new e.a9(e.a6.properties_light_directional["shadow-quality"]),"shadow-intensity":new e.a9(e.a6.properties_light_directional["shadow-intensity"]),"shadow-draw-before-layer":new e.a9(e.a6.properties_light_directional["shadow-draw-before-layer"])}));class ui{constructor(e,t,i){this.screenBounds=e,this.cameraPoint=i.getCameraPoint(),this._screenRaycastCache={},this._cameraRaycastCache={},this.isAboveHorizon=t,this.screenGeometry=this.bufferedScreenGeometry(0),this.screenGeometryMercator=this._bufferedScreenMercator(0,i)}static createFromScreenPoints(t,i){let r,n;if(t instanceof e.P||"number"==typeof t[0]){const o=e.P.convert(t);r=[o],n=i.isPointAboveHorizon(o)}else{const o=e.P.convert(t[0]),s=e.P.convert(t[1]),a=o.add(s)._div(2);r=[o,s],n=e.ar(o,s).every(e=>i.isPointAboveHorizon(e))&&i.isPointAboveHorizon(a)}return new ui(r,n,i)}isPointQuery(){return 1===this.screenBounds.length}bufferedScreenGeometry(t){return e.ar(this.screenBounds[0],1===this.screenBounds.length?this.screenBounds[0]:this.screenBounds[1],t)}bufferedCameraGeometry(t){const i=this.screenBounds[0],r=1===this.screenBounds.length?this.screenBounds[0].add(new e.P(1,1)):this.screenBounds[1],n=e.ar(i,r,0,!1);return this.cameraPoint.y>r.y&&(this.cameraPoint.x>i.x&&this.cameraPoint.x<r.x?n.splice(3,0,this.cameraPoint):this.cameraPoint.x>=r.x?n[2]=this.cameraPoint:this.cameraPoint.x<=i.x&&(n[3]=this.cameraPoint)),e.as(n,t)}bufferedCameraGeometryGlobe(t){const i=this.screenBounds[0],r=1===this.screenBounds.length?this.screenBounds[0].add(new e.P(1,1)):this.screenBounds[1],n=e.ar(i,r,t),o=this.cameraPoint.clone(),s=Number(o.x>i.x)+Number(o.x>r.x);switch(3*(Number(o.y>i.y)+Number(o.y>r.y))+s){case 0:n[0]=o,n[4]=o.clone();break;case 1:n.splice(1,0,o);break;case 2:n[1]=o;break;case 3:n.splice(4,0,o);break;case 5:n.splice(2,0,o);break;case 6:n[3]=o;break;case 7:n.splice(3,0,o);break;case 8:n[2]=o}return n}containsTile(t,i,r,n=0){const o=Math.max(t.queryPadding,t.evaluateQueryRenderedFeaturePadding())/i._pixelsPerMercatorPixel+1,s=r?this._bufferedCameraMercator(o,i):this._bufferedScreenMercator(o,i);let a=t.tileID.wrap+(s.unwrapped?n:0);const l=s.polygon.map(i=>e.at(t.tileTransform,i,a));if(!e.au(l,0,0,e.ak,e.ak))return;a=t.tileID.wrap+(this.screenGeometryMercator.unwrapped?n:0);const c=this.screenGeometryMercator.polygon.map(i=>e.av(t.tileTransform,i,a)),h=c.map(t=>new e.P(t[0],t[1])),u=i.getFreeCameraOptions().position||new e.ad(0,0,0),d=e.av(t.tileTransform,u,a),p=c.map(t=>{const i=e.aw(t,t,d);return e.ax(i,i),new e.ay(d,i)}),f=e.az(t,1,i.zoom)*i._pixelsPerMercatorPixel;return{queryGeometry:this,tilespaceGeometry:h,tilespaceRays:p,bufferedTilespaceGeometry:l,bufferedTilespaceBounds:(m=e.aA(l),m.min.x=e.aB(m.min.x,0,e.ak),m.min.y=e.aB(m.min.y,0,e.ak),m.max.x=e.aB(m.max.x,0,e.ak),m.max.y=e.aB(m.max.y,0,e.ak),m),tile:t,tileID:t.tileID,pixelToTileUnitsFactor:f};var m}_bufferedScreenMercator(e,t){const i=fi(e);if(this._screenRaycastCache[i])return this._screenRaycastCache[i];{let r;return r="globe"===t.projection.name?this._projectAndResample(this.bufferedScreenGeometry(e),t):{polygon:this.bufferedScreenGeometry(e).map(e=>t.pointCoordinate3D(e)),unwrapped:!0},this._screenRaycastCache[i]=r,r}}_bufferedCameraMercator(e,t){const i=fi(e);if(this._cameraRaycastCache[i])return this._cameraRaycastCache[i];{let r;return r="globe"===t.projection.name?this._projectAndResample(this.bufferedCameraGeometryGlobe(e),t):{polygon:this.bufferedCameraGeometry(e).map(e=>t.pointCoordinate3D(e)),unwrapped:!0},this._cameraRaycastCache[i]=r,r}}_projectAndResample(t,i){const r=function(t,i){const r=e.aC([],i.pixelMatrix,i.globeMatrix),n=[0,-e.aE,0,1],o=[0,e.aE,0,1],s=[0,0,0,1];e.aD(n,n,r),e.aD(o,o,r),e.aD(s,s,r);const a=new e.P(n[0]/n[3],n[1]/n[3]),l=new e.P(o[0]/o[3],o[1]/o[3]),c=e.aF(t,a)&&n[3]<s[3],h=e.aF(t,l)&&o[3]<s[3];if(!c&&!h)return null;const u=function(e,t,i){for(let r=1;r<e.length;r++){const n=pi(t.pointCoordinate3D(e[r-1]).x),o=pi(t.pointCoordinate3D(e[r]).x);if(i<0){if(n<o)return{idx:r,t:-n/(o-1-n)}}else if(o<n)return{idx:r,t:(1-n)/(o+1-n)}}return null}(t,i,c?-1:1);if(!u)return null;const{idx:d,t:p}=u;let f=d>1?di(t.slice(0,d),i):[],m=d<t.length?di(t.slice(d),i):[];f=f.map(t=>new e.P(pi(t.x),t.y)),m=m.map(t=>new e.P(pi(t.x),t.y));const _=[...f];0===_.length&&_.push(m.at(-1));const g=_.at(-1),y=e.aj(g.y,(0===m.length?f[0]:m[0]).y,p);let x;return x=c?[new e.P(0,y),new e.P(0,0),new e.P(1,0),new e.P(1,y)]:[new e.P(1,y),new e.P(1,1),new e.P(0,1),new e.P(0,y)],_.push(...x),0===m.length?_.push(f[0]):_.push(...m),{polygon:_.map(t=>new e.ad(t.x,t.y)),unwrapped:!1}}(t,i);if(r)return r;const n=function(t,i){let r=!1,n=-1/0,o=0;for(let e=0;e<t.length-1;e++)t[e].x>n&&(n=t[e].x,o=e);for(let e=0;e<t.length-1;e++){const i=(o+e)%(t.length-1),n=t[i],s=t[i+1];Math.abs(n.x-s.x)>.5&&(n.x<s.x?(n.x+=1,0===i&&(t.at(-1).x+=1)):(s.x+=1,i+1===t.length-1&&(t[0].x+=1)),r=!0)}const s=e.aG(i.center.lng);return r&&s<Math.abs(s-1)&&t.forEach(e=>{e.x-=1}),{polygon:t,unwrapped:r}}(di(t,i).map(t=>new e.P(pi(t.x),t.y)),i);return{polygon:n.polygon.map(t=>new e.ad(t.x,t.y)),unwrapped:n.unwrapped}}}function di(t,i){return e.aH(t,e=>{const t=i.pointCoordinate3D(e);e.x=t.x,e.y=t.y},1/256)}function pi(e){return e<0?1+e%1:e%1}function fi(e){return 100*e|0}function mi(t,i){const r=Math.pow(2,i.z),n=Math.floor(e.aG(t.getWest())*r),o=Math.floor(e.aJ(t.getNorth())*r),s=Math.ceil(e.aG(t.getEast())*r),a=Math.ceil(e.aJ(t.getSouth())*r);return i.x>=n&&i.x<s&&i.y>=o&&i.y<a}class _i{constructor(t,i,r){this.bounds=t?e.aI.convert(this.validateBounds(t)):null,this.minzoom=i||0,this.maxzoom=r||24}validateBounds(e){return Array.isArray(e)&&4===e.length?[Math.max(-180,e[0]),Math.max(-90,e[1]),Math.min(180,e[2]),Math.min(90,e[3])]:[-180,-90,180,90]}addExtraBounds(t){if(t){this.extraBounds||(this.extraBounds=[]);for(const i of t)this.extraBounds.push(e.aI.convert(this.validateBounds(i)))}}contains(e){if(e.z>this.maxzoom||e.z<this.minzoom)return!1;if(this.bounds&&!mi(this.bounds,e))return!1;if(!this.extraBounds)return!0;for(const t of this.extraBounds)if(mi(t,e))return!0;return!1}static fromTileJSON(e){if(!e.bounds&&!e.extra_bounds)return null;const t=new _i(e.bounds,e.minzoom,e.maxzoom);return t.addExtraBounds(e.extra_bounds),t}}class gi extends e.E{constructor(t,i,r,n){if(super(),this.id=t,this.dispatcher=r,this.type="vector",this.provider=i.provider,this.minzoom=0,this.maxzoom=22,this.scheme="xyz",this.tileSize=512,this.reparseOverscaled=!0,this.isTileClipped=!0,this._loaded=!1,Object.assign(this,e.aK(i,["url","scheme","tileSize","promoteId"])),this._options=Object.assign({type:"vector"},i),this._collectResourceTiming=!!i.collectResourceTiming,512!==this.tileSize)throw new Error("vector tile sources must have a tileSize of 512");this.setEventedParent(n),this._tileWorkers={},this._deduped=new e.aL}load(t){this._loaded=!1,this.fire(new e.z("dataloading",{dataType:"source"}));const i=Array.isArray(this.map._language)?this.map._language.join():this.map._language,r=this.map.getWorldview(),n=(n,o)=>{this._tileJSONRequest=null,this._loaded=!0,n?(i&&console.warn(`Ensure that your requested language string is a valid BCP-47 code or list of codes. Found: ${i}`),r&&console.warn(`Requested worldview strings must be a valid ISO alpha-2 code. Found: ${r}`),this.fire(new e.y(n))):o&&(this._setTileJSON(o),U(o.tiles,this.map._requestManager._customAccessToken),this.fire(new e.z("data",{dataType:"source",sourceDataType:"metadata"})),this.fire(new e.z("data",{dataType:"source",sourceDataType:"content"}))),t&&t(n)};this.provider=this._options.provider;const o=e.aM(this._options);o instanceof Error?(this._loaded=!0,this.fire(new e.y(o)),t&&t()):this.provider&&!o?(this._loaded=!0,this.fire(new e.y(/* @__PURE__ */new Error(`TileProvider "${this.provider}" is not registered`))),t&&t()):this._tileJSONRequest=o?this.loadTileJSONWithProvider(o,n):e.aN(this._options,this.map._requestManager,i,r,n)}loadTileJSONWithProvider(t,i){this.provider=t.name;const{request:r,options:n}=e.aO(this._options,this.map._requestManager),o=new AbortController;return this.dispatcher.broadcast("loadTileProvider",{name:t.name,url:t.url,source:this.id,scope:this.scope,type:this.type,options:n,request:r},(t,r)=>{if(o.signal.aborted)return;if(t)return void i(t);const n=r?r.find(e=>null!=e):null,s=e.aP(this._options,n,this.map._requestManager);s instanceof Error?i(s):i(null,s)}),{cancel:()=>o.abort()}}_setTileJSON(e){if(Object.assign(this,e),this.hasWorldviews=!!e.worldview_options,e.worldview_default&&(this.worldviewDefault=e.worldview_default),e.vector_layers){this.vectorLayers=e.vector_layers,this.vectorLayerIds=[],this.localizableLayerIds=/* @__PURE__ */new Set;for(const t of e.vector_layers)this.vectorLayerIds.push(t.id),e.worldview&&e.worldview[t.source]&&this.localizableLayerIds.add(t.id)}this.tileBounds=_i.fromTileJSON(e)}loaded(){return this._loaded}hasTile(e){return!this.tileBounds||this.tileBounds.contains(e.canonical)}onAdd(e){this.map=e,this.load()}reload(){this.cancelTileJSONRequest();const t=e.t(this.id,this.scope);this.load(()=>this.map.style.clearSource(t))}setTiles(e){return this._options.tiles=e,this.reload(),this}setUrl(e){return this.url=e,this._options.url=e,this.reload(),this}onRemove(e){this.cancelTileJSONRequest()}serialize(){return Object.assign({},this._options)}loadTile(t,i){const r=t.tileID.canonical.url(this.tiles,this.scheme),n=this.map._requestManager.normalizeTileURL(r),o=this.map._requestManager.transformRequest(n,e.R.Tile),s=this.map.style?this.map.style.getLut(this.scope):null,a=s?{image:s.image.clone()}:null,l={request:o,data:void 0,uid:t.uid,tileID:t.tileID,tileZoom:t.tileZoom,zoom:t.tileID.overscaledZ,maxZoom:this.maxzoom,lut:a,tileSize:this.tileSize*t.tileID.overscaleFactor(),type:this.type,source:this.id,scope:this.scope,pixelRatio:e.o.devicePixelRatio,showCollisionBoxes:this.map.showCollisionBoxes,showElevationIdDebug:!!this.map.painter&&this.map.painter._debugParams.showElevationIdDebug,promoteId:this.promoteId,renderSourceType:t.renderSourceType,brightness:this.map.style&&this.map.style.getBrightness()||0,extraShadowCaster:t.isExtraShadowCaster,tessellationStep:this.map._tessellationStep,scaleFactor:this.map.getScaleFactor(),worldview:this.map.getWorldview()||this.worldviewDefault,indoor:this.map.getIndoorTileOptions(this.id,this.scope)};function c(r,n){return delete t.request,t.aborted?i(null):r?i(r):(n&&n.resourceTiming&&(t.resourceTiming=n.resourceTiming),this.map._refreshExpiredTiles&&n&&t.setExpiryData(n),t.loadVectorData(n,this.map.painter),e.aS(this.dispatcher),i(null,n),void(t.reloadCallback&&(this.loadTile(t,t.reloadCallback),t.reloadCallback=null)))}this.hasWorldviews&&e.e(r)&&(l.localizableLayerIds=this.localizableLayerIds),l.request.collectResourceTiming=this._collectResourceTiming,t.actor&&"expired"!==t.state?"loading"===t.state?t.reloadCallback=i:t.request=t.actor.send("reloadTile",l,c.bind(this)):(t.actor=this._tileWorkers[n]=this._tileWorkers[n]||this.dispatcher.getActor(),this.dispatcher.ready||this.provider?t.request=t.actor.send("loadTile",l,c.bind(this),void 0,!0):t.request={cancel:e.aQ.call({deduped:this._deduped},l,(i,r)=>{if(i||!r)c.call(this,i);else{const i=e.aR(r.responseHeaders);l.data={rawData:r.rawData.slice(0),expires:i.expires,cacheControl:i.cacheControl},t.actor&&t.actor.send("loadTile",l,c.bind(this),void 0,!0)}},!0)})}abortTile(e){e.request&&(e.request.cancel(),delete e.request),e.actor&&e.actor.send("abortTile",{uid:e.uid,type:this.type,source:this.id,scope:this.scope})}unloadTile(e,t){e.actor&&e.actor.send("removeTile",{uid:e.uid,type:this.type,source:this.id,scope:this.scope}),e.destroy()}hasTransition(){return!1}afterUpdate(){this._tileWorkers={}}cancelTileJSONRequest(){this._tileJSONRequest&&(this._tileJSONRequest.cancel(),this._tileJSONRequest=null)}}class yi extends e.E{constructor(t,i,r,n){super(),this.id=t,this.dispatcher=r,this.setEventedParent(n),this.type="raster",this.minzoom=0,this.maxzoom=22,this.roundZoom=!0,this.scheme="xyz",this.tileSize=512,this._loaded=!1,this._options=Object.assign({type:"raster"},i),Object.assign(this,e.aK(i,["url","scheme","tileSize"]))}load(t){this._loaded=!1,this.fire(new e.z("dataloading",{dataType:"source"}));const i=this.map.getWorldview(),r=(i,r)=>{this._tileJSONRequest=null,this._loaded=!0,i?this.fire(new e.y(i)):r&&(Object.assign(this,r),r.raster_layers&&(this.rasterLayers=r.raster_layers,this.rasterLayerIds=this.rasterLayers.map(e=>e.id)),this.tileBounds=_i.fromTileJSON(r),U(r.tiles),this.fire(new e.z("data",{dataType:"source",sourceDataType:"metadata"})),this.fire(new e.z("data",{dataType:"source",sourceDataType:"content"}))),t&&t(i)};this.provider="string"==typeof this._options.provider?this._options.provider:void 0,this._tileProvider=void 0;const n=e.aM(this._options);n instanceof Error?(this._loaded=!0,this.fire(new e.y(n)),t&&t()):this.provider&&!n?(this._loaded=!0,this.fire(new e.y(/* @__PURE__ */new Error(`TileProvider "${this.provider}" is not registered`))),t&&t()):this._tileJSONRequest=n?this.loadTileJSONWithProvider(n,r):e.aN(this._options,this.map._requestManager,null,i,r)}loadTileJSONWithProvider(t,i){this.provider=t.name;const{request:r,options:n}=e.aO(this._options,this.map._requestManager),o=new AbortController;return e.aT(t.name,t.url).then(e=>{if(o.signal.aborted)return;const t=new e(n);return t.load&&r?t.load({request:r}).then(e=>(this._tileProvider=t,e)):(this._tileProvider=t,null)}).then(t=>{if(o.signal.aborted)return;const r=e.aP(this._options,t,this.map._requestManager);r instanceof Error?i(r):i(null,r)}).catch(e=>{o.signal.aborted||i(e instanceof Error?e:new Error(String(e)))}),{cancel:()=>o.abort()}}loaded(){return this._loaded}onAdd(e){this.map=e,this.load()}reload(){this.cancelTileJSONRequest();const t=e.t(this.id,this.scope);this.load(()=>this.map.style.clearSource(t))}setTiles(e){return this._options.tiles=e,this.reload(),this}setUrl(e){return this.url=e,this._options.url=e,this.reload(),this}onRemove(e){this.cancelTileJSONRequest()}serialize(){return Object.assign({},this._options)}hasTile(e){return!this.tileBounds||this.tileBounds.contains(e.canonical)}loadTile(t,i){const r=e.o.devicePixelRatio>=2,n=this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles,this.scheme),r,this.tileSize),o=this.map._requestManager.transformRequest(n,e.R.Tile);if(this._tileProvider){const e=new AbortController;t.request={cancel:()=>e.abort()},this.loadTileWithProvider(t,this._tileProvider,o,e,i)}else t.request=e.n(o,(r,n,o)=>{if(delete t.request,t.aborted)return t.state="unloaded",i(null);if(r)return t.state="errored",i(r);if(!n)return i(null);const s=e.aR(o);this.map._refreshExpiredTiles&&t.setExpiryData(s),t.setTexture(n,this.map.painter),t.state="loaded",e.aS(this.dispatcher),i(null)})}async loadTileWithProvider(e,t,i,r,n){const{z:o,x:s,y:a}=e.tileID.canonical;try{const l=await t.loadTile({z:o,x:s,y:a},{request:i,signal:r.signal});if(r.signal.aborted)return e.state="unloaded",n(null);if(null==l){const t=/* @__PURE__ */new Error("Tile not found");return t.status=404,e.state="errored",n(t)}if(null==l.data)return e.state="loaded",n(null);const c=await createImageBitmap(new Blob([l.data]));if(r.signal.aborted)return e.state="unloaded",n(null);e.setTexture(c,this.map.painter),e.state="loaded",this.map._refreshExpiredTiles&&e.setExpiryData({cacheControl:l.cacheControl,expires:l.expires}),n(null)}catch(t){if(r.signal.aborted)return e.state="unloaded",n(null);if(t instanceof DOMException&&"AbortError"===t.name)return e.state="unloaded",n(null);e.state="errored",n(t instanceof Error?t:new Error(String(t)))}finally{delete e.request}}abortTile(e,t){e.request&&(e.request.cancel(),delete e.request),t&&t()}unloadTile(t,i){t.texture&&t.texture instanceof e.T?(t.destroy(!1),t.texture&&t.texture instanceof e.T&&this.map.painter.saveTileTexture(t.texture)):t.destroy(),i&&i()}hasTransition(){return!1}cancelTileJSONRequest(){this._tileJSONRequest&&(this._tileJSONRequest.cancel(),this._tileJSONRequest=null)}}function xi([t,i],r,n,{scaled:o=!0}={}){const{tileSize:s,buffer:a}=n,{x:l,y:c,z:h}=r;if(!isFinite(l)||!isFinite(c)||!isFinite(h))throw new Error("Invalid MRT header");const u=2**h,d=u*e.aG(t),p=u*e.aJ(i);return function([e,t],i,{scaled:r=!0}={}){if(!i)throw new Error("bandView is undefined");const{data:n,tileSize:o,buffer:s,offset:a,scale:l,dimension:c}=i;if(e<-s||e>o+s||t<-s||t>o+s)throw new Error(`Point (${e}, ${t}) out of bounds for tileSize=${o}, buffer=${s}`);const h=(t+s)*(o+2*s)+(e+s);if(4294967295===new Uint32Array(n.buffer)[h])return null;let u=[];u=r?[]:new i.data.constructor(c);for(let d=0;d<c;d++)u[d]=Math.round(1e12*(n[c*h+d]*l+a))/1e12;return u}([Math.min(Math.max(-a,Math.floor((d-l)*s)),s-1+a),Math.min(Math.max(-a,Math.floor((p-c)*s)),s-1+a)],n,{scaled:o})}class vi extends yi{constructor(e,t,i,r){super(e,t,i,r),this.type="raster-array",this.maxzoom=22,this.partial=!0,this._loadTilePending={},this._loadTileLoaded={},this._options=Object.assign({type:"raster-array"},t)}triggerRepaint(e){const t=this.map.painter._terrain,i=this.map.style.getSourceCache(this.id);t&&t.enabled&&i&&t._clearRenderCacheForTile(i.id,e.tileID),this.map.triggerRepaint()}loadTile(t,i){const r=this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles,this.scheme),!1,this.tileSize),n=this.map._requestManager.transformRequest(r,e.R.Tile),o={request:n,uid:t.uid,tileID:t.tileID,type:this.type,source:this.id,scope:this.scope,partial:this.partial};t.source=this.id,t.scope=this.scope,t.requestParams=n,t.actor||(t.actor=this.dispatcher.getActor());const s=(r,n,o)=>{if(delete t.request,t.aborted)return t.state="unloaded",i(null);if(r){if("AbortError"===r.name)return;return t.state="errored",i(r)}if(this.map._refreshExpiredTiles&&n){const i=e.aR(o);t.setExpiryData(i)}if(this.partial&&"expired"!==t.state)t.state="empty";else if(!this.partial){if(!n)return i(null);t.state="loaded",t._isHeaderLoaded=!0,t._mrt=n}i(null)};t.request=this.partial?t.fetchHeader(void 0,s.bind(this)):t.actor.send("loadTile",o,s.bind(this),void 0,!0)}abortTile(e){e.request&&(e.request.cancel(),delete e.request),e.actor&&e.actor.send("abortTile",{uid:e.uid,type:this.type,source:this.id,scope:this.scope})}unloadTile(e,t){const i=e.texturePerLayer;if(e.flushAllQueues(),i.size){e.destroy(!1);for(const e of i.values())this.map.painter.saveTileTexture(e)}else e.destroy()}prepareTile(t,i,r,n){t._isHeaderLoaded&&("empty"!==t.state&&(t.state="reloading"),t.fetchBandForRender(i,r,n,(i,n)=>{i?(t.state="errored",this.fire(new e.y(i))):n&&(t._isHeaderLoaded=!0,t.setTexturePerLayer(r,n,this.map.painter),t.state="loaded"),this.triggerRepaint(t)}))}getInitialBand(e){if(!this.rasterLayers)return 0;const t=this.rasterLayers.find(({id:t})=>t===e),i=t&&t.fields,r=i&&i.bands&&i.bands;return r?r[0]:0}getTextureDescriptor(t,i,r){if(!t)return;const n=i.sourceLayer||this.rasterLayerIds&&this.rasterLayerIds[0];if(!n)return;let o=null;i instanceof e.aV?o=i.paint.get("raster-array-band"):i instanceof e.aW&&(o=i.paint.get("raster-particle-array-band"));const s=o||this.getInitialBand(n);if(null==s)return;if(!t.textureDescriptorPerLayer.get(i.id))return void this.prepareTile(t,n,i.id,s);if(t.updateNeeded(i.id,s)&&!r)return;const a=t.textureDescriptorPerLayer.get(i.id);return Object.assign({},a,{texture:t.texturePerLayer.get(i.id)})}getImages(t,i){const r=/* @__PURE__ */new Map;for(const n of t)for(const t of i){const[i,o]=t.split("/"),s=n.getLayer(i);if(!s)continue;if(!s.hasBand(o)||!s.hasDataForBand(o))continue;const{bytes:a,tileSize:l,buffer:c}=s.getBandView(o),h=l+2*c,u={data:new e.q({width:h,height:h},a),pixelRatio:2,sdf:!1,usvg:!1,version:0};r.set(t,u)}return r}queryRasterArrayValueByBandId(t,i,r){const n=i._mrt;return new Promise(o=>{const s={},a=/* @__PURE__ */new Set;for(const[l,c]of Object.entries(n.layers)){if(r.layerName&&l!==r.layerName)continue;const h={};s[l]=h;for(const{bands:u}of c.dataIndex)for(const d of u)r.bands&&!r.bands.includes(d)||(a.add(e.t(l,d)),i.fetchBand(l,null,d,i=>{e.o.frame(()=>{h[d]=i?null:xi([t.lng,t.lat],n,c.getBandView(d)),a.delete(e.t(l,d)),0===a.size&&o(s)})},!1))}0===a.size&&o(s)})}_loadTileForQuery(t,i){if(this._loadTileLoaded[t.uid])return void i(null,t._mrt);if(this._loadTilePending[t.uid])return void this._loadTilePending[t.uid].push(i);this._loadTilePending[t.uid]=[i];const r=this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles,this.scheme),!1,this.tileSize),n=this.map._requestManager.transformRequest(r,e.R.Tile);t.actor.send("loadTile",{request:n,uid:t.uid,tileID:t.tileID,type:this.type,source:this.id,scope:this.scope,partial:!1},(i,r,n)=>{if(i)return this._loadTilePending[t.uid].forEach(e=>e(i,null)),void delete this._loadTilePending[t.uid];if(!r)return this._loadTilePending[t.uid].forEach(e=>e(null,null)),void delete this._loadTilePending[t.uid];if(this.map._refreshExpiredTiles&&r){const i=e.aR(n);t.setExpiryData(i)}t._mrt=r,t._isHeaderLoaded=!0,t.state="loaded",this._loadTilePending[t.uid].forEach(e=>e(null,r)),this._loadTileLoaded[t.uid]=!0,delete this._loadTilePending[t.uid]},void 0,!0)}queryRasterArrayValueByAllBands(e,t,i){return new Promise((r,n)=>{this._loadTileForQuery(t,(o,s)=>{o?n(o):r(s?this.queryRasterArrayValueByBandId(e,t,i):null)})})}queryRasterArrayValue(t,i){const r=e.aX.convert(t),n=this.findLoadedParent(r);return n&&n._mrt?i.bands||!this.partial?this.queryRasterArrayValueByBandId(r,n,i):this.queryRasterArrayValueByAllBands(r,n,i):Promise.resolve(null)}findLoadedParent(t){const i=e.ad.fromLngLat(t,this.map.transform.tileSize),r=this.maxzoom+1,n=1<<r,o=Math.floor(i.x),s=Math.floor((i.x-o)*n),a=Math.floor(i.y*n),l=this.map.style.getSourceCache(this.id),c=new e.aU(r,o,r,s,a);return l.findLoadedParent(c,this.minzoom)}}const bi={vector:gi,raster:yi,"raster-dem":class extends yi{constructor(e,t,i,r){super(e,t,i,r),this.type="raster-dem",this.maxzoom=22,this._options=Object.assign({type:"raster-dem"},t),this.encoding=t.encoding||"mapbox"}loadTileJSONWithProvider(t,i){this.provider=t.name;const{request:r,options:n}=e.aO(this._options,this.map._requestManager),o=new AbortController;return this.dispatcher.broadcast("loadTileProvider",{name:t.name,url:t.url,source:this.id,scope:this.scope,type:this.type,options:n,request:r},(t,r)=>{if(o.signal.aborted)return;if(t)return void i(t);const n=r?r.find(e=>null!=e):null,s=e.aP(this._options,n,this.map._requestManager);s instanceof Error?i(s):i(null,s)}),{cancel:()=>o.abort()}}loadTile(t,i){const r=this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles,this.scheme),!1,this.tileSize),n=this.map._requestManager.transformRequest(r,e.R.Tile),o={uid:t.uid,tileID:t.tileID,source:this.id,type:this.type,scope:this.scope,request:n,encoding:this.encoding};t.actor&&"expired"!==t.state||(t.actor=this.dispatcher.getActor(),t.request=t.actor.send("loadTile",o,function(e,r){return delete t.request,t.aborted?(t.state="unloaded",i(null)):e?(t.state="errored",i(e)):(r&&(this.map._refreshExpiredTiles&&t.setExpiryData(r),r.borderReady||t.neighboringTiles||(t.neighboringTiles=this._getNeighboringTiles(t.tileID)),t.dem=r.dem,t.dem.onDeserialize(),t.needsHillshadePrepare=!0,t.needsDEMTextureUpload=!0),t.state="loaded",void i(null))}.bind(this),void 0,!0))}abortTile(e,t){e.request&&(e.request.cancel(),delete e.request),e.actor&&e.actor.send("abortTile",{uid:e.uid,type:this.type,source:this.id,scope:this.scope}),t&&t()}_getNeighboringTiles(t){const i=t.canonical,r=Math.pow(2,i.z),n=(i.x-1+r)%r,o=0===i.x?t.wrap-1:t.wrap,s=(i.x+1+r)%r,a=i.x+1===r?t.wrap+1:t.wrap,l={};return l[new e.aU(t.overscaledZ,o,i.z,n,i.y).key]={backfilled:!1},l[new e.aU(t.overscaledZ,a,i.z,s,i.y).key]={backfilled:!1},i.y>0&&(l[new e.aU(t.overscaledZ,o,i.z,n,i.y-1).key]={backfilled:!1},l[new e.aU(t.overscaledZ,t.wrap,i.z,i.x,i.y-1).key]={backfilled:!1},l[new e.aU(t.overscaledZ,a,i.z,s,i.y-1).key]={backfilled:!1}),i.y+1<r&&(l[new e.aU(t.overscaledZ,o,i.z,n,i.y+1).key]={backfilled:!1},l[new e.aU(t.overscaledZ,t.wrap,i.z,i.x,i.y+1).key]={backfilled:!1},l[new e.aU(t.overscaledZ,a,i.z,s,i.y+1).key]={backfilled:!1}),l}},"raster-array":vi,geojson:class extends e.E{constructor(t,i,r,n){super(),this.id=t,this.type="geojson",this.minzoom=0,this.maxzoom=18,this.tileSize=512,this.isTileClipped=!0,this.reparseOverscaled=!0,this._loaded=!1,this.actor=r.getActor(),this.setEventedParent(n),this._data=i.data,this._options=Object.assign({},i),this._collectResourceTiming=i.collectResourceTiming,void 0!==i.maxzoom&&(this.maxzoom=i.maxzoom),void 0!==i.minzoom&&(this.minzoom=i.minzoom),i.type&&(this.type=i.type),i.attribution&&(this.attribution=i.attribution),this.promoteId=i.promoteId;const o=e.ak/this.tileSize;this.workerOptions=Object.assign({source:this.id,scope:this.scope,cluster:i.cluster||!1,geojsonVtOptions:{buffer:(void 0!==i.buffer?i.buffer:128)*o,tolerance:(void 0!==i.tolerance?i.tolerance:.375)*o,extent:e.ak,maxZoom:this.maxzoom,lineMetrics:i.lineMetrics||!1,generateId:i.generateId||!1},superclusterOptions:{maxZoom:void 0!==i.clusterMaxZoom?i.clusterMaxZoom:this.maxzoom-1,minPoints:Math.max(2,i.clusterMinPoints||2),extent:e.ak,radius:(void 0!==i.clusterRadius?i.clusterRadius:50)*o,log:!1,generateId:i.generateId||!1},clusterProperties:i.clusterProperties,filter:i.filter,dynamic:i.dynamic},i.workerOptions)}onAdd(e){this.map=e,this.setData(this._data)}setData(e){return this._data=e,this._updateWorkerData(),this}updateData(t){if(!this._options.dynamic)return this.fire(new e.y(/* @__PURE__ */new Error("Can't call updateData on a GeoJSON source with dynamic set to false.")));if("string"!=typeof t&&("Feature"===t.type&&(t={type:"FeatureCollection",features:[t]}),"FeatureCollection"!==t.type))return this.fire(new e.y(/* @__PURE__ */new Error("Data to update should be a feature or a feature collection.")));if(this._coalesce&&"string"!=typeof t&&"string"!=typeof this._data&&"FeatureCollection"===this._data.type){const e=/* @__PURE__ */new Map;for(const t of this._data.features)e.set(t.id,t);for(const i of t.features)e.set(i.id,i);this._data.features=[...e.values()]}else this._data=t;return this._updateWorkerData(!0),this}getClusterExpansionZoom(e,t){return this.actor.send("geojson.getClusterExpansionZoom",{clusterId:e,source:this.id,scope:this.scope},t),this}getClusterChildren(e,t){return this.actor.send("geojson.getClusterChildren",{clusterId:e,source:this.id,scope:this.scope},t),this}getClusterLeaves(e,t,i,r){return this.actor.send("geojson.getClusterLeaves",{source:this.id,scope:this.scope,clusterId:e,limit:t,offset:i},r),this}_updateWorkerData(t=!1){if(this._pendingLoad)return void(this._coalesce=!0);this.fire(new e.z("dataloading",{dataType:"source"})),this._loaded=!1;const i=Object.assign({append:t},this.workerOptions);i.scope=this.scope;const r=this._data;"string"==typeof r?(i.request=this.map._requestManager.transformRequest(e.o.resolveURL(r),e.R.Source),i.request.collectResourceTiming=this._collectResourceTiming):i.data=JSON.stringify(r),this._pendingLoad=this.actor.send(`${this.type}.loadData`,i,(i,r)=>{if(this._loaded=!0,this._pendingLoad=null,i)this.fire(new e.y(i));else{const i={dataType:"source",sourceDataType:this._metadataFired?"content":"metadata"};this._collectResourceTiming&&r&&r.resourceTiming&&r.resourceTiming[this.id]&&(i.resourceTiming=r.resourceTiming[this.id]),t&&(this._partialReload=!0),this.fire(new e.z("data",i)),this._partialReload=!1,this._metadataFired=!0}this._coalesce&&(this._updateWorkerData(t),this._coalesce=!1)})}loaded(){return this._loaded}reload(){const t=e.t(this.id,this.scope);this.map.style.clearSource(t),this._updateWorkerData()}loadTile(t,i){const r=t.actor?"reloadTile":"loadTile";t.actor=this.actor;const n=this.map.style?this.map.style.getLut(this.scope):null,o=n?{image:n.image.clone()}:null,s=this._partialReload,a={type:this.type,uid:t.uid,tileID:t.tileID,tileZoom:t.tileZoom,zoom:t.tileID.overscaledZ,maxZoom:this.maxzoom,tileSize:this.tileSize,source:this.id,lut:o,scope:this.scope,pixelRatio:e.o.devicePixelRatio,showCollisionBoxes:this.map.showCollisionBoxes,showElevationIdDebug:!!this.map.painter&&this.map.painter._debugParams.showElevationIdDebug,promoteId:this.promoteId,brightness:this.map.style&&this.map.style.getBrightness()||0,extraShadowCaster:t.isExtraShadowCaster,scaleFactor:this.map.getScaleFactor(),partial:s,worldview:this.map.getWorldview(),indoor:this.map.getIndoorTileOptions(this.id,this.scope)};t.request=this.actor.send(r,a,(e,n)=>s&&!n?(t.state="loaded",i(null)):(delete t.request,t.destroy(!1),t.aborted?i(null):e?i(e):(t.loadVectorData(n,this.map.painter,"reloadTile"===r),i(null))),void 0,"loadTile"===r)}abortTile(e){e.request&&(e.request.cancel(),delete e.request),e.aborted=!0}unloadTile(e,t){this.actor.send("removeTile",{uid:e.uid,type:this.type,source:this.id,scope:this.scope}),e.destroy()}onRemove(e){this._pendingLoad&&this._pendingLoad.cancel()}serialize(){return Object.assign({},this._options,{type:this.type,data:this._data})}hasTransition(){return!1}},video:class extends e.aY{constructor(e,t,i,r){super(e,t,i,r),this.roundZoom=!0,this.type="video",this.options=t}load(){this._loaded=!1;const t=this.options;this.urls=[];for(const i of t.urls)this.urls.push(this.map._requestManager.transformRequest(i,e.R.Source).url);e.aZ(this.urls,(t,i)=>{this._loaded=!0,t?this.fire(new e.y(t)):i&&(this.video=i,this.video.loop=!0,this.video.setAttribute("playsinline",""),this.video.addEventListener("playing",()=>{this.map.triggerRepaint()}),this.map&&this.video.play(),this._finishLoading())})}pause(){this.video&&this.video.pause()}play(){this.video&&this.video.play()}seek(t){if(this.video){const i=this.video.seekable;t<i.start(0)||t>i.end(0)?this.fire(new e.y(new We(`sources.${this.id}`,null,`Playback for this video can be set only between the ${i.start(0)} and ${i.end(0)}-second mark.`))):this.video.currentTime=t}}getVideo(){return this.video}onAdd(e){this.map||(this.map=e,this.load(),this.video&&(this.video.play(),this.setCoordinates(this.coordinates)))}prepare(){if(0===Object.keys(this.tiles).length||this.video.readyState<2)return;const t=this.map.painter.context,i=t.gl;this.texture?this.video.paused||(this.texture.bind(i.LINEAR,i.CLAMP_TO_EDGE),i.texSubImage2D(i.TEXTURE_2D,0,0,0,i.RGBA,i.UNSIGNED_BYTE,this.video)):(this.texture=new e.T(t,this.video,i.RGBA8),this.texture.bind(i.LINEAR,i.CLAMP_TO_EDGE),this.width=this.video.videoWidth,this.height=this.video.videoHeight),this._prepareData(t)}serialize(){return{type:"video",urls:this.urls,coordinates:this.coordinates}}hasTransition(){return this.video&&!this.video.paused}},image:e.aY,model:e.a$,"batched-model":class extends e.E{constructor(e,t,i,r){super(),this.type="batched-model",this.id=e,this.tileSize=512,this._options=t,this.tiles=this._options.tiles,this.maxzoom=t.maxzoom||19,this.minzoom=t.minzoom||0,this.roundZoom=!0,this.usedInConflation=!0,this.dispatcher=i,this.reparseOverscaled=!1,this.scheme="xyz",this._loaded=!1,this.setEventedParent(r)}onAdd(e){this.map=e,this.load()}reload(){this.cancelTileJSONRequest();const t=e.t(this.id,this.scope);this.load(()=>this.map.style.clearSource(t))}cancelTileJSONRequest(){this._tileJSONRequest&&(this._tileJSONRequest.cancel(),this._tileJSONRequest=null)}load(t){this._loaded=!1,this.fire(new e.z("dataloading",{dataType:"source"}));const i=Array.isArray(this.map._language)?this.map._language.join():this.map._language,r=this.map.getWorldview();this._tileJSONRequest=e.aN(this._options,this.map._requestManager,i,r,(n,o)=>{this._tileJSONRequest=null,this._loaded=!0,n?(i&&console.warn(`Ensure that your requested language string is a valid BCP-47 code or list of codes. Found: ${i}`),r&&2!==r.length&&console.warn(`Requested worldview strings must be a valid ISO alpha-2 code. Found: ${r}`),this.fire(new e.y(n))):o&&(Object.assign(this,o),o.bounds&&(this.tileBounds=new _i(o.bounds,this.minzoom,this.maxzoom)),U(o.tiles,this.map._requestManager._customAccessToken),this.fire(new e.z("data",{dataType:"source",sourceDataType:"metadata"})),this.fire(new e.z("data",{dataType:"source",sourceDataType:"content"}))),t&&t(n)})}hasTransition(){return!1}hasTile(e){return!this.tileBounds||this.tileBounds.contains(e.canonical)}loaded(){return this._loaded}loadTile(t,i){const r=this.map._requestManager.normalizeTileURL(t.tileID.canonical.url(this.tiles,this.scheme)),n={request:this.map._requestManager.transformRequest(r,e.R.Tile),data:void 0,uid:t.uid,tileID:t.tileID,tileZoom:t.tileZoom,zoom:t.tileID.overscaledZ,tileSize:this.tileSize*t.tileID.overscaleFactor(),type:this.type,source:this.id,scope:this.scope,showCollisionBoxes:this.map.showCollisionBoxes,renderSourceType:t.renderSourceType,brightness:this.map.style&&this.map.style.getBrightness()||0,pixelRatio:e.o.devicePixelRatio,promoteId:this.promoteId};if(t.actor&&"expired"!==t.state)if("loading"===t.state)t.reloadCallback=i;else{if(t.buckets){const e=Object.values(t.buckets);for(const t of e)t.dirty=!0;return void(t.state="loaded")}t.request=t.actor.send("reloadTile",n,o.bind(this))}else t.actor=this.dispatcher.getActor(),t.request=t.actor.send("loadTile",n,o.bind(this),void 0,!0);function o(e,r){return t.aborted?i(null):e&&404!==e.status?i(e):(this.map._refreshExpiredTiles&&r&&t.setExpiryData(r),t.loadModelData(r,this.map.painter),t.state="loaded",void i(null))}}serialize(){return Object.assign({},this._options)}},canvas:class extends e.aY{constructor(t,i,r,n){super(t,i,r,n),i.coordinates?Array.isArray(i.coordinates)&&4===i.coordinates.length&&!i.coordinates.some(e=>!Array.isArray(e)||2!==e.length||e.some(e=>"number"!=typeof e))||this.fire(new e.y(new We(`sources.${t}`,null,'"coordinates" property must be an array of 4 longitude/latitude array pairs'))):this.fire(new e.y(new We(`sources.${t}`,null,'missing required property "coordinates"'))),i.animate&&"boolean"!=typeof i.animate&&this.fire(new e.y(new We(`sources.${t}`,null,'optional "animate" property must be a boolean value'))),i.canvas?"string"==typeof i.canvas||i.canvas instanceof HTMLCanvasElement||this.fire(new e.y(new We(`sources.${t}`,null,'"canvas" must be either a string representing the ID of the canvas element from which to read, or an HTMLCanvasElement instance'))):this.fire(new e.y(new We(`sources.${t}`,null,'missing required property "canvas"'))),this.options=i,this.animate=void 0===i.animate||i.animate}load(){this._loaded=!0,this.canvas||(this.canvas=this.options.canvas instanceof HTMLCanvasElement?this.options.canvas:document.getElementById(this.options.canvas)),this.width=this.canvas.width,this.height=this.canvas.height,this._hasInvalidDimensions()?this.fire(new e.y(/* @__PURE__ */new Error("Canvas dimensions cannot be less than or equal to zero."))):(this.play=function(){this._playing=!0,this.map.triggerRepaint()},this.pause=function(){this._playing&&(this.prepare(),this._playing=!1)},this._finishLoading())}getCanvas(){return this.canvas}onAdd(e){this.map=e,this.load(),this.canvas&&this.animate&&this.play()}onRemove(e){this.pause()}prepare(){let t=!1;if(this.canvas.width!==this.width&&(this.width=this.canvas.width,t=!0),this.canvas.height!==this.height&&(this.height=this.canvas.height,t=!0),this._hasInvalidDimensions())return;if(0===Object.keys(this.tiles).length)return;const i=this.map.painter.context;this.texture?!t&&!this._playing||this.texture instanceof e.a_||this.texture.update(this.canvas,{premultiply:!0}):this.texture=new e.T(i,this.canvas,i.gl.RGBA8,{premultiply:!0}),this._prepareData(i)}serialize(){return{type:"canvas",coordinates:this.coordinates}}hasTransition(){return this._playing}_hasInvalidDimensions(){for(const e of[this.canvas.width,this.canvas.height])if(isNaN(e)||e<=0)return!0;return!1}},custom:class extends e.E{constructor(t,i,r,n){super(),this.id=t,this.type="custom",this._dataType="raster",this._dispatcher=r,this._implementation=i,this.setEventedParent(n),this.scheme="xyz",this.minzoom=0,this.maxzoom=22,this.tileSize=512,this._loaded=!1,this.roundZoom=!0,this._implementation||this.fire(new e.y(/* @__PURE__ */new Error(`Missing implementation for ${this.id} custom source`))),this._implementation.loadTile||this.fire(new e.y(/* @__PURE__ */new Error(`Missing loadTile implementation for ${this.id} custom source`))),this._implementation.bounds&&(this.tileBounds=new _i(this._implementation.bounds,this.minzoom,this.maxzoom));const o=i;o.update=this._update.bind(this),o.clearTiles=this._clearTiles.bind(this),o.coveringTiles=this._coveringTiles.bind(this),Object.assign(this,e.aK(i,["dataType","scheme","minzoom","maxzoom","tileSize","attribution","minTileCacheSize","maxTileCacheSize"]))}serialize(){return e.aK(this,["type","scheme","minzoom","maxzoom","tileSize","attribution"])}load(){this._loaded=!0,this.fire(new e.z("data",{dataType:"source",sourceDataType:"metadata"})),this.fire(new e.z("data",{dataType:"source",sourceDataType:"content"}))}loaded(){return this._loaded}onAdd(t){this.map=t,this._loaded=!1,this.fire(new e.z("dataloading",{dataType:"source"})),this._implementation.onAdd&&this._implementation.onAdd(t),this.load()}onRemove(e){this._implementation.onRemove&&this._implementation.onRemove(e)}hasTile(e){if(this._implementation.hasTile){const{x:t,y:i,z:r}=e.canonical;return this._implementation.hasTile({x:t,y:i,z:r})}return!this.tileBounds||this.tileBounds.contains(e.canonical)}loadTile(e,t){const{x:i,y:r,z:n}=e.tileID.canonical,o=new AbortController,s=Promise.resolve(this._implementation.loadTile({x:i,y:r,z:n},{signal:o.signal})).then(function(i){return delete e.request,e.aborted?(e.state="unloaded",t(null)):void 0===i?(e.state="errored",t(null)):null===i?(this.loadTileData(e,{width:this.tileSize,height:this.tileSize,data:null}),e.state="loaded",t(null)):function(e){return e instanceof ImageData||e instanceof HTMLCanvasElement||e instanceof ImageBitmap||e instanceof HTMLImageElement}(i)?(this.loadTileData(e,i),e.state="loaded",void t(null)):(e.state="errored",t(/* @__PURE__ */new Error(`Can't infer data type for ${this.id}, only raster data supported at the moment`)))}.bind(this)).catch(i=>{"AbortError"!==i.name&&(e.state="errored",t(i))});s.cancel=()=>o.abort(),e.request=s}loadTileData(e,t){e.setTexture(t,this.map.painter)}unloadTile(t,i){if(t.texture&&t.texture instanceof e.T?(t.destroy(!1),t.texture&&t.texture instanceof e.T&&this.map.painter.saveTileTexture(t.texture)):t.destroy(),this._implementation.unloadTile){const{x:e,y:i,z:r}=t.tileID.canonical;this._implementation.unloadTile({x:e,y:i,z:r})}i&&i()}abortTile(e,t){e.request&&e.request.cancel&&(e.request.cancel(),delete e.request),t&&t()}hasTransition(){return!1}_coveringTiles(){return this.map.transform.coveringTiles({tileSize:this.tileSize,minzoom:this.minzoom,maxzoom:this.maxzoom,roundZoom:this.roundZoom}).map(e=>({x:e.canonical.x,y:e.canonical.y,z:e.canonical.z}))}_clearTiles(){const t=e.t(this.id,this.scope);this.map.style.clearSource(t)}_update(){this.fire(new e.z("data",{dataType:"source",sourceDataType:"content"}))}}},wi=function(t,i,r,n){const o=new bi[i.type](t,i,r,n);if(o.id!==t)throw new Error(`Expected Source id to be ${t} instead of ${o.id}`);return e.b0(["load","abort","unload","serialize","prepare"],o),o};function Ti(e,t,i=""){return`${i}:${t.id||""}:${t.layer.id}:${function(e){if("layerId"in e)return`layer:${e.layerId}`;{const{featuresetId:t,importId:i}=e;return`featureset:${t}${i?`:import:${i}`:""}`}}(e.target)}`}function Si(e,t,i,r=""){if(e.uniqueFeatureID){const n=Ti(e,t,r);if(i.has(n))return!0;i.add(n)}return!1}function Ii(e,t,i,r,n=!1,o=void 0){const s=t.sourceCache.transform,a=t.sourceCache.tilesIn(e,t.has3DLayers,n);a.sort(Mi);const l=[];for(const c of a){const e=c.tile.queryRenderedFeatures(t,c,i,r,s,n,o);Object.keys(e).length&&l.push({wrappedTileID:c.tile.tileID.wrapped().key,queryResults:e})}for(const c in t.layers){const i=t.layers[c];if(i.styleLayer){const n=i.styleLayer.queryRenderedFeatures(e,t.sourceCache,r);Object.keys(n).length&&l.push({wrappedTileID:0,queryResults:n})}}return 0===l.length?{}:function(e){const t={},i={};for(const r of e){const e=r.queryResults,n=r.wrappedTileID,o=i[n]=i[n]||{};for(const i in e){const r=e[i],n=o[i]=o[i]||{},s=t[i]=t[i]||[];for(const e of r)n[e.featureIndex]||(n[e.featureIndex]=!0,s.push(e))}}return t}(l)}function Ei(e,t,i,r,n,o){const s={},a=r.queryRenderedSymbols(e),l=[];for(const c of Object.keys(a).map(Number))l.push(n[c]);l.sort(Mi);for(const c of l){const e=c.featureIndex.lookupSymbolFeatures(a[c.bucketInstanceId],c.bucketIndex,c.sourceLayerIndex,t,i,o);for(const t in e){const i=s[t]=s[t]||[],r=e[t];r.sort((e,t)=>{const i=c.featureSortOrder;if(i){const r=i.indexOf(e.featureIndex);return i.indexOf(t.featureIndex)-r}return t.featureIndex-e.featureIndex});for(const e of r)i.push(e)}}return s}function Ai(e,t){const i=e.getRenderableIds().map(t=>e.getTileByID(t)),r=[],n={};for(let o=0;o<i.length;o++){const e=i[o],s=e.tileID.canonical.key;n[s]||(n[s]=!0,e.querySourceFeatures(r,t))}return r}function Mi(e,t){const i=e.tileID,r=t.tileID;return i.overscaledZ-r.overscaledZ||i.canonical.y-r.canonical.y||i.wrap-r.wrap||i.canonical.x-r.canonical.x}e.b1.setPbf(e.b2);class Ci extends e.b3{constructor(e,t,i,r,n){super(e,t,i,r,n),this._workQueuePerLayer=/* @__PURE__ */new Map,this._fetchQueuePerLayer=/* @__PURE__ */new Map,this._taskQueue=/* @__PURE__ */new Map,this._isHeaderLoaded=!1,this.textureDescriptorPerLayer=/* @__PURE__ */new Map,this.texturePerLayer=/* @__PURE__ */new Map}getLayers(){return this._mrt?Object.values(this._mrt.layers):[]}getLayer(e){return this._mrt&&this._mrt.getLayer(e)}setTexturePerLayer(t,i,r){const n=r.context,o=n.gl;let s=this.texturePerLayer.get(t)||r.getTileTexture(i.width);s&&s instanceof e.T?s.update(i,{premultiply:!1}):s=new e.T(n,i,o.RGBA8,{premultiply:!1}),this.texturePerLayer.has(t)||this.texturePerLayer.set(t,s)}flushQueues(e){const t=this._workQueuePerLayer.get(e)||[],i=this._fetchQueuePerLayer.get(e)||[];for(;t.length;)t.pop()();for(;i.length;)i.pop()()}flushAllQueues(){for(const e of this._workQueuePerLayer.keys()){const t=this._workQueuePerLayer.get(e)||[];for(;t.length;)t.pop()()}for(const e of this._fetchQueuePerLayer.keys()){const t=this._fetchQueuePerLayer.get(e)||[];for(;t.length;)t.pop()()}}fetchHeader(t=16384,i){const r=this._mrt=new e.b1(30),n=Object.assign({},this.requestParams,{headers:{Range:"bytes=0-"+(t-1)}});return this.entireBuffer=null,this.request=e.b4(n,(e,n,o)=>{if(e)i(e);else try{const e=r.getHeaderLength(n);if(e>t)return void(this.request=this.fetchHeader(e,i));r.parseHeader(n),this._isHeaderLoaded=!0;let s=0;for(const t of Object.values(r.layers))s=Math.max(s,t.dataIndex.at(-1).lastByte);n.byteLength>=s&&(this.entireBuffer=n),i(null,this.entireBuffer||n,o)}catch(e){i(e)}}),this.request}fetchBandForRender(e,t,i,r){this.fetchBand(e,t,i,n=>{if(n)return void r(n);this.updateTextureDescriptor(e,t,i);const o=this.textureDescriptorPerLayer.get(t);r(null,o?o.img:null)})}fetchBand(t,i,r,n,o=!0){const s=this._mrt;if(!this._isHeaderLoaded||!s)return void n(/* @__PURE__ */new Error("Tile header is not ready"));const a=this.actor;if(!a)return void n(/* @__PURE__ */new Error("Can't fetch tile band without an actor"));let l;const c=e.t(String(r),e.t(this.tileID.key,t));let h=this._taskQueue.get(c);h?h.add(n):(h=/* @__PURE__ */new Set,h.add(n),this._taskQueue.set(c,h));const u=(e,t)=>{l.complete(e,t),e?n(e):(h.forEach(e=>e(null,t)),this._taskQueue.delete(c))},d=(e,t)=>{if(e)return n(e);const r=a.send("decodeRasterArray",{type:"raster-array",source:this.source,scope:this.scope,tileID:this.tileID,uid:this.uid,buffer:t,task:l},u,void 0,!0);if(null!==i){const e=this._workQueuePerLayer.get(i)||[];e.push(()=>{r&&r.cancel(),l.cancel()}),this._workQueuePerLayer.has(i)||this._workQueuePerLayer.set(i,e)}};let p;try{p=s.getLayer(t)}catch(e){if("reloading"===this.state)return;throw e}if(!p)return void n(/* @__PURE__ */new Error(`Unknown sourceLayer "${t}"`));if(p.hasDataForBand(r))return h.forEach(e=>e(null,null)),void this._taskQueue.delete(c);const f=p.getDataRange([r]);if(l=s.createDecodingTask(f),!l||l.tasks.length)if(null!==i&&this.flushQueues(i),this.entireBuffer)d(null,this.entireBuffer.slice(f.firstByte,f.lastByte+1));else{const t=Object.assign({},this.requestParams,{headers:{Range:`bytes=${f.firstByte}-${f.lastByte}`}}),r=e.b4(t,d);if(null!==i){const e=this._fetchQueuePerLayer.get(i)||[];e.push(()=>{r.cancel(),l.cancel()}),this._fetchQueuePerLayer.has(i)||this._fetchQueuePerLayer.set(i,e)}}}updateNeeded(e,t){return(!this.textureDescriptorPerLayer.get(e)||this.textureDescriptorPerLayer.get(e).band!==t||this.refreshedUponExpiration)&&"errored"!==this.state}updateTextureDescriptor(t,i,r){if(!this._mrt)return;const n=this._mrt.getLayer(t);if(!n||!n.hasBand(r)||!n.hasDataForBand(r))return;const{bytes:o,tileSize:s,buffer:a,offset:l,scale:c}=n.getBandView(r),h=s+2*a,u=new e.q({width:h,height:h},o),d=this.texturePerLayer.get(i);d&&d instanceof e.T&&d.update(u,{premultiply:!1}),this.textureDescriptorPerLayer.set(i,{layer:t,band:r,img:u,buffer:a,offset:l,tileSize:s,format:n.pixelFormat,mix:[c,256*c,65536*c,16777216*c]})}destroy(t=!1){if(super.destroy(t),delete this._mrt,!t)for(const i of this.texturePerLayer.values())i&&i instanceof e.T&&i.destroy();this.texturePerLayer.clear(),this.textureDescriptorPerLayer.clear(),this.fbo&&(this.fbo.destroy(),delete this.fbo),delete this.request,delete this.requestParams,this._isHeaderLoaded=!1}}class Pi{constructor(e,t){this.max=e,this.onRemove=t,this.reset()}reset(){for(const e in this.data)for(const t of this.data[e])t.timeout&&clearTimeout(t.timeout),this.onRemove(t.value);return this.data={},this.order=[],this}add(e,t,i){const r=e.wrapped().key;void 0===this.data[r]&&(this.data[r]=[]);const n={value:t,timeout:void 0};if(void 0!==i&&(n.timeout=setTimeout(()=>{this.remove(e,n)},i)),this.data[r].push(n),this.order.push(r),this.order.length>this.max){const e=this._getAndRemoveByKey(this.order[0]);e&&this.onRemove(e)}return this}has(e){return e.wrapped().key in this.data}getAndRemove(e){return this.has(e)?this._getAndRemoveByKey(e.wrapped().key):null}_getAndRemoveByKey(e){const t=this.data[e].shift();return t.timeout&&clearTimeout(t.timeout),0===this.data[e].length&&delete this.data[e],this.order.splice(this.order.indexOf(e),1),t.value}getByKey(e){const t=this.data[e];return t?t[0].value:null}get(e){return this.has(e)?this.data[e.wrapped().key][0].value:null}remove(e,t){if(!this.has(e))return this;const i=e.wrapped().key,r=void 0===t?0:this.data[i].indexOf(t),n=this.data[i][r];return this.data[i].splice(r,1),n.timeout&&clearTimeout(n.timeout),0===this.data[i].length&&delete this.data[i],this.onRemove(n.value),this.order.splice(this.order.indexOf(i),1),this}setMaxSize(e){for(this.max=e;this.order.length>this.max;){const e=this._getAndRemoveByKey(this.order[0]);e&&this.onRemove(e)}return this}filter(e){const t=[];for(const i in this.data)for(const r of this.data[i])e(r.value)||t.push(r);for(const i of t)this.remove(i.value.tileID,i)}}class Di{constructor(){this.state={},this.stateChanges={},this.deletedStates={}}updateState(e,t,i){const r=String(t);if(this.stateChanges[e]=this.stateChanges[e]||{},this.stateChanges[e][r]=this.stateChanges[e][r]||{},Object.assign(this.stateChanges[e][r],i),null===this.deletedStates[e]){this.deletedStates[e]={};for(const t in this.state[e])t!==r&&(this.deletedStates[e][t]=null)}else if(this.deletedStates[e]&&null===this.deletedStates[e][r]){this.deletedStates[e][r]={};for(const t in this.state[e][r])i[t]||(this.deletedStates[e][r][t]=null)}else for(const n in i)this.deletedStates[e]&&this.deletedStates[e][r]&&null===this.deletedStates[e][r][n]&&delete this.deletedStates[e][r][n]}removeFeatureState(e,t,i){if(null===this.deletedStates[e])return;const r=String(t);if(this.deletedStates[e]=this.deletedStates[e]||{},i&&void 0!==t)null!==this.deletedStates[e][r]&&(this.deletedStates[e][r]=this.deletedStates[e][r]||{},this.deletedStates[e][r][i]=null);else if(void 0!==t)if(this.stateChanges[e]&&this.stateChanges[e][r])for(i in this.deletedStates[e][r]={},this.stateChanges[e][r])this.deletedStates[e][r][i]=null;else this.deletedStates[e][r]=null;else this.deletedStates[e]=null}getState(e,t){const i=this.state[e]||{},r=this.stateChanges[e]||{},n=this.deletedStates[e];if(null===n)return{};if(void 0!==t){const e=String(t),o=Object.assign({},i[e],r[e]);if(n){const e=n[t];if(null===e)return{};for(const t in e)delete o[t]}return o}const o=Object.assign({},i,r);if(n)for(const s in n)delete o[s];return o}initializeTileState(e,t){e.refreshFeatureState(t)}coalesceChanges(e,t){const i={};for(const r in this.stateChanges){this.state[r]=this.state[r]||{};const e={};for(const t in this.stateChanges[r])this.state[r][t]||(this.state[r][t]={}),Object.assign(this.state[r][t],this.stateChanges[r][t]),e[t]=this.state[r][t];i[r]=e}for(const r in this.deletedStates){this.state[r]=this.state[r]||{};const e={};if(null===this.deletedStates[r])for(const t in this.state[r])e[t]={},this.state[r][t]={};else for(const t in this.deletedStates[r]){if(null===this.deletedStates[r][t])this.state[r][t]={};else if(this.state[r][t])for(const e of Object.keys(this.deletedStates[r][t]))delete this.state[r][t][e];e[t]=this.state[r][t]}i[r]=i[r]||{},Object.assign(i[r],e)}if(this.stateChanges={},this.deletedStates={},0!==Object.keys(i).length)for(const r in e)e[r].refreshFeatureState(t,i)}}class Ri extends e.E{constructor(e,t,i){super(),this.id=e,this._renderSourceType=i,this._maxzoomOverride=null,t.on("data",e=>{"source"===e.dataType&&"metadata"===e.sourceDataType&&(this._sourceLoaded=!0),this._sourceLoaded&&!this._paused&&"source"===e.dataType&&"content"===e.sourceDataType&&(this.reload(),this.transform&&this.update(this.transform))}),t.on("error",()=>{this._sourceErrored=!0}),this._source=t,this._tiles={},this._cache=new Pi(0,this._unloadTile.bind(this)),this._timers={},this._cacheTimers={},this._minTileCacheSize=t.minTileCacheSize,this._maxTileCacheSize=t.maxTileCacheSize,this._loadedParentTiles={},this.castsShadows=!1,this.tileCoverLift=0,this._coveredTiles={},this._shadowCasterTiles={},this._state=new Di,this._isRaster="raster"===this._source.type||"raster-dem"===this._source.type||"raster-array"===this._source.type||"custom"===this._source.type&&"_dataType"in this._source&&"raster"===this._source._dataType,this._supportsFading="raster"===this._source.type||"raster-array"===this._source.type||"image"===this._source.type||"video"===this._source.type||"custom"===this._source.type,this._isRasterElevatedOverTerrain=!1}onAdd(e){this.map=e,this._minTileCacheSize=void 0===this._minTileCacheSize&&e?e._minTileCacheSize:this._minTileCacheSize,this._maxTileCacheSize=void 0===this._maxTileCacheSize&&e?e._maxTileCacheSize:this._maxTileCacheSize}loaded(){if(this._sourceErrored)return!0;if(!this._sourceLoaded)return!1;if(!this._source.loaded())return!1;for(const e in this._tiles)if(!this._tiles[e].loaded())return!1;return!0}getSource(){return this._source}pause(){this._paused=!0}resume(){if(!this._paused)return;const e=this._shouldReloadOnResume;this._paused=!1,this._shouldReloadOnResume=!1,e&&this.reload(),this.transform&&this.update(this.transform)}setMaxzoomOverride(e){this._maxzoomOverride=e}_loadTile(e,t){return e.renderSourceType=this._renderSourceType,e.isExtraShadowCaster=this._shadowCasterTiles[e.tileID.key],this._source.loadTile(e,t)}_unloadTile(e){if(this._source.unloadTile)return this._source.unloadTile(e)}_abortTile(e){if(this._source.abortTile)return this._source.abortTile(e)}serialize(){return this._source.serialize()}prepare(e){this._source.prepare&&this._source.prepare(),this._state.coalesceChanges(this._tiles,this.map?this.map.painter:null);for(const t in this._tiles){const i=this._tiles[t];i.upload(e,this.map?this.map.painter:void 0),i.prepare(this.map.style.imageManager,this.map?this.map.painter:null,this._source.scope)}}getIds(){return Object.values(this._tiles).map(e=>e.tileID).sort(zi).map(e=>e.key)}getRenderableIds(t,i){const r=[];for(const e in this._tiles)this._isIdRenderable(+e,t,i)&&r.push(this._tiles[e]);return t?r.sort((t,i)=>{const r=t.tileID,n=i.tileID,o=new e.P(r.canonical.x,r.canonical.y)._rotate(this.transform.angle),s=new e.P(n.canonical.x,n.canonical.y)._rotate(this.transform.angle);return r.overscaledZ-n.overscaledZ||s.y-o.y||s.x-o.x}).map(e=>e.tileID.key):r.map(e=>e.tileID).sort(zi).map(e=>e.key)}hasRenderableParent(e){const t=this.findLoadedParent(e,0);return!!t&&this._isIdRenderable(t.tileID.key)}_isIdRenderable(e,t,i){return this._tiles[e]&&this._tiles[e].hasData()&&!this._coveredTiles[e]&&(t||!this._tiles[e].holdingForFade())&&(i||!this._shadowCasterTiles[e])}reload(){if(this._paused)this._shouldReloadOnResume=!0;else{this._cache.reset();for(const e in this._tiles)"errored"!==this._tiles[e].state&&this._reloadTile(+e,"reloading")}}_reloadTile(e,t){const i=this._tiles[e];i&&("loading"!==i.state&&(i.state=t),this._loadTile(i,this._tileLoaded.bind(this,i,e,t)))}_tileLoaded(t,i,r,n,o){if(n){if(t.state="errored",e.b5(n)){if(this._source.fire(new e.z("data",{dataType:"source",sourceDataType:"error",sourceId:this._source.id,tile:t})),!(t.tileID.key in this._loadedParentTiles))return;if("raster-dem"===this._source.type&&this.usedForTerrain&&this.map.painter.terrain){const e=this.map.painter.terrain;this.update(this.transform,e.getScaledDemTileSize(),!0),e.resetTileLookupCache(this.id)}else this.update(this.transform)}else this._source.fire(new e.y(n,{tile:t}));return}t.timeAdded=e.o.now(),"expired"===r&&(t.refreshedUponExpiration=!0),this._setTileReloadTimer(i,t),"raster-dem"===this._source.type&&t.dem&&this._backfillDEM(t),this._state.initializeTileState(t,this.map?this.map.painter:null);let s=/* @__PURE__ */new Map;o&&o.responseHeaders&&(s=o.responseHeaders),this._source.fire(new e.z("data",{dataType:"source",tile:t,coord:t.tileID,sourceCacheId:this.id,responseHeaders:s}))}_hasTunnelGeometry(){for(const e in this._tiles){const t=this._tiles[e];if(t&&t.hasTunnelGeometry)return!0}return!1}_backfillDEM(e){const t=this.getRenderableIds();for(let r=0;r<t.length;r++){const n=t[r];if(e.neighboringTiles&&e.neighboringTiles[n]){const t=this.getTileByID(n);i(e,t),i(t,e)}}function i(e,t){if(!e.dem||e.dem.borderReady)return;e.needsHillshadePrepare=!0,e.needsDEMTextureUpload=!0;let i=t.tileID.canonical.x-e.tileID.canonical.x;const r=t.tileID.canonical.y-e.tileID.canonical.y,n=Math.pow(2,e.tileID.canonical.z),o=t.tileID.key;0===i&&0===r||Math.abs(r)>1||(Math.abs(i)>1&&(1===Math.abs(i+n)?i+=n:1===Math.abs(i-n)&&(i-=n)),t.dem&&e.dem&&(e.dem.backfillBorder(t.dem,i,r),e.neighboringTiles&&e.neighboringTiles[o]&&(e.neighboringTiles[o].backfilled=!0)))}}getTile(e){return this.getTileByID(e.key)}getTileByID(e){return this._tiles[e]}_retainLoadedChildren(e,t,i,r){for(const n in this._tiles){let o=this._tiles[n];if(r[n]||!o.hasData()||o.tileID.overscaledZ<=t||o.tileID.overscaledZ>i)continue;let s=o.tileID;for(;o&&o.tileID.overscaledZ>t+1;){const e=o.tileID.scaledTo(o.tileID.overscaledZ-1);o=this._tiles[e.key],o&&o.hasData()&&(s=e)}let a=s;for(;a.overscaledZ>t;)if(a=a.scaledTo(a.overscaledZ-1),e[a.key]){r[s.key]=s;break}}}findLoadedParent(e,t){if(e.key in this._loadedParentTiles){const i=this._loadedParentTiles[e.key];return i&&i.tileID.overscaledZ>=t?i:null}for(let i=e.overscaledZ-1;i>=t;i--){const t=e.scaledTo(i),r=this._getLoadedTile(t);if(r)return r}}_getLoadedTile(e){const t=this._tiles[e.key];return t&&t.hasData()?t:this._cache.getByKey(this._source.reparseOverscaled?e.wrapped().key:e.canonical.key)}updateCacheSize(e,t){t=t||this._source.tileSize;const i=Math.ceil(e.width/t)+1,r=Math.ceil(e.height/t)+1,n=Math.floor(i*r*5),o="number"==typeof this._minTileCacheSize?Math.max(this._minTileCacheSize,n):n,s="number"==typeof this._maxTileCacheSize?Math.min(this._maxTileCacheSize,o):o;this._cache.setMaxSize(s)}handleWrapJump(e){const t=Math.round((e-(void 0===this._prevLng?e:this._prevLng))/360);if(this._prevLng=e,t){const e={};for(const i in this._tiles){const r=this._tiles[i];r.tileID=r.tileID.unwrapTo(r.tileID.wrap+t),e[r.tileID.key]=r}this._tiles=e;for(const t in this._timers)clearTimeout(this._timers[t]),delete this._timers[t];for(const t in this._tiles)this._setTileReloadTimer(+t,this._tiles[t])}}update(t,i,r,n,o){if(this.transform=t,!this._sourceLoaded||this._paused||this.transform.freezeTileCoverage)return;if(this.usedForTerrain&&!r)return;this.updateCacheSize(t,i),"globe"!==this.transform.projection.name&&this.handleWrapJump(this.transform.center.lng),this._shadowCasterTiles={},this._coveredTiles={};const s="batched-model"===this._source.type;let a,l=this._source.maxzoom;null!==this._maxzoomOverride&&(l=Math.min(l,this._maxzoomOverride));const c=this.map&&this.map.painter?this.map.painter._terrain:null;if(c&&c.sourceCache===this&&c.attenuationRange()){const e=c.attenuationRange()[0],t=Math.floor(e)-Math.log2(c.getDemUpscale());l>t&&(l=t)}const h=null===this._maxzoomOverride&&this._source.reparseOverscaled;if(this.used||this.usedForTerrain){if(this._source.tileID)a=t.getVisibleUnwrappedCoordinates(this._source.tileID).map(t=>new e.aU(t.canonical.z,t.wrap,t.canonical.z,t.canonical.x,t.canonical.y));else if(0!==this.tileCoverLift){const n=t.clone();n.tileCoverLift=this.tileCoverLift,a=n.coveringTiles({tileSize:i||this._source.tileSize,minzoom:this._source.minzoom,maxzoom:l,roundZoom:this._source.roundZoom&&!r,reparseOverscaled:h,isTerrainDEM:this.usedForTerrain,calculateQuadrantVisibility:s}),this._source.minzoom<=1&&"globe"===t.projection.name&&(a.push(new e.aU(1,0,1,0,0)),a.push(new e.aU(1,0,1,1,0)),a.push(new e.aU(1,0,1,0,1)),a.push(new e.aU(1,0,1,1,1)))}else if(a=t.coveringTiles({tileSize:i||this._source.tileSize,minzoom:this._source.minzoom,maxzoom:l,roundZoom:this._source.roundZoom&&!r,reparseOverscaled:h,isTerrainDEM:this.usedForTerrain,calculateQuadrantVisibility:s}),this._source.hasTile){const e=this._source.hasTile.bind(this._source);a=a.filter(t=>e(t))}}else a=[];if(a.length>0&&"globe"!==this.transform.projection.name&&!this.usedForTerrain&&!this._supportsFading){const e=t.coveringZoomLevel({tileSize:i||this._source.tileSize,roundZoom:this._source.roundZoom&&!r}),c=Math.min(e,l);if(s){const e=t.extendTileCover(a,c);for(const t of e)a.push(t)}else if(o){const e=this.transform.getFrustum(c),i=t.extendTileCoverToNearPlane(a,e,c);for(const t of i)a.push(t);if(c>=18&&this._hasTunnelGeometry()){const i=t.extendTileCoverForTunnels(a,e,c,20);for(const e of i)a.push(e)}}else if(this.castsShadows&&n){const e=t.extendTileCover(a,c,n,16);for(const t of e)this._shadowCasterTiles[t.key]=!0,a.push(t)}}const u=this._updateRetainedTiles(a);if(this._supportsFading&&0!==a.length){const t={},i={},r=e.o.now(),n=Object.keys(u);for(const e of n){const n=u[e],o=this._tiles[e];if(!o||void 0!==o.fadeEndTime&&o.fadeEndTime<=r)continue;const s=this.findLoadedParent(n,Math.max(n.overscaledZ-Ri.maxOverzooming,this._source.minzoom));s&&(this._addTile(s.tileID),t[s.tileID.key]=s.tileID),i[e]=n}const o=a.at(-1).overscaledZ;for(const e in this._tiles){const t=this._tiles[e];if(u[e]||!t.hasData())continue;let r=t.tileID;for(;r.overscaledZ>o;){r=r.scaledTo(r.overscaledZ-1);const n=this._tiles[r.key];if(n&&n.hasData()&&i[r.key]){u[e]=t.tileID;break}}}for(const e in t)u[e]||(this._coveredTiles[e]=!0,u[e]=t[e])}for(const e in u)this._tiles[e].clearFadeHold();const d=e.b6(this._tiles,u);for(const e of d){const t=this._tiles[e];t.hasSymbolBuckets&&!t.holdingForFade()?t.setHoldDuration(this.map._fadeDuration):t.hasSymbolBuckets&&!t.symbolFadeFinished()||this._removeTile(+e)}this._updateLoadedParentTileCache(),this._renderSourceType===e.b7.Symbol&&this._source.afterUpdate&&this._source.afterUpdate()}releaseSymbolFadeTiles(){for(const e in this._tiles)this._tiles[e].holdingForFade()&&this._removeTile(+e)}_updateRetainedTiles(e){const t={};if(0===e.length)return t;const i={},r=e.reduce((e,t)=>Math.min(e,t.overscaledZ),1/0),n=e[0].overscaledZ,o=Math.max(n-Ri.maxOverzooming,this._source.minzoom),s=Math.max(n+Ri.maxUnderzooming,this._source.minzoom),a={};for(const l of e){const e=this._addTile(l);t[l.key]=l,e.hasData()||r<this._source.maxzoom&&(a[l.key]=l)}this._retainLoadedChildren(a,r,s,t);for(const l of e){let e=this._tiles[l.key];if(e.hasData())continue;if(l.canonical.z>=this._source.maxzoom){const e=l.children(this._source.maxzoom)[0],i=this.getTile(e);if(i&&i.hasData()){t[e.key]=e;continue}}else{const e=l.children(this._source.maxzoom);if(t[e[0].key]&&t[e[1].key]&&t[e[2].key]&&t[e[3].key])continue}let r=e.wasRequested();for(let n=l.overscaledZ-1;n>=o;--n){const o=l.scaledTo(n);if(i[o.key])break;if(i[o.key]=!0,e=this.getTile(o),!e&&r&&(e=this._addTile(o)),e&&(t[o.key]=o,r=e.wasRequested(),e.hasData()))break}}return t}_updateLoadedParentTileCache(){this._loadedParentTiles={};for(const e in this._tiles){const t=[];let i,r=this._tiles[e].tileID;for(;r.overscaledZ>0;){if(r.key in this._loadedParentTiles){i=this._loadedParentTiles[r.key];break}t.push(r.key);const e=r.scaledTo(r.overscaledZ-1);if(i=this._getLoadedTile(e),i)break;r=e}for(const e of t)this._loadedParentTiles[e]=i}}_addTile(t){let i=this._tiles[t.key];if(i)return!0!==i.isExtraShadowCaster||this._shadowCasterTiles[t.key]||this._reloadTile(t.key,"reloading"),i;i=this._cache.getAndRemove(t),i&&(this._setTileReloadTimer(t.key,i),i.tileID=t,this._state.initializeTileState(i,this.map?this.map.painter:null),this._cacheTimers[t.key]&&(clearTimeout(this._cacheTimers[t.key]),delete this._cacheTimers[t.key],this._setTileReloadTimer(t.key,i)));const r=Boolean(i);if(!r){const r=this.map?this.map.painter:null,n=this._source.tileSize*t.overscaleFactor();i="raster-array"===this._source.type?new Ci(t,n,this.transform.tileZoom,r,this._isRaster):new e.b3(t,n,this.transform.tileZoom,r,this._isRaster,this._source.worldview),this._loadTile(i,this._tileLoaded.bind(this,i,t.key,i.state))}return i.uses++,this._tiles[t.key]=i,r||this._source.fire(new e.z("dataloading",{tile:i,coord:i.tileID,dataType:"source"})),i}_setTileReloadTimer(e,t){e in this._timers&&(clearTimeout(this._timers[e]),delete this._timers[e]);const i=t.getExpiryTimeout();i&&(this._timers[e]=setTimeout(()=>{this._reloadTile(e,"expired"),delete this._timers[e]},i))}_removeTile(e){const t=this._tiles[e];t&&(t.uses--,delete this._tiles[e],this._timers[e]&&(clearTimeout(this._timers[e]),delete this._timers[e]),t.uses>0||(t.hasData()&&"reloading"!==t.state||"empty"===t.state?this._cache.add(t.tileID,t,t.getExpiryTimeout()):(t.aborted=!0,this._abortTile(t),this._unloadTile(t))))}clearTiles(){this._shouldReloadOnResume=!1,this._paused=!1;for(const e in this._tiles)this._removeTile(+e);this._source._clear&&this._source._clear(),this._cache.reset(),this.map&&this.usedForTerrain&&this.map.painter.terrain&&this.map.painter.terrain.resetTileLookupCache(this.id)}tilesIn(t,i,r){const n=[],o=this.transform;if(!o)return n;const s="globe"===o.projection.name,a=e.aG(o.center.lng);for(const l in this._tiles){const c=this._tiles[l];if(r&&c.clearQueryDebugViz(),c.holdingForFade())continue;let h;if(s){const t=c.tileID.canonical;if(0===t.z){const i=[Math.abs(e.aB(a,...Li(t,-1))-a),Math.abs(e.aB(a,...Li(t,1))-a)];h=[0,2*i.indexOf(Math.min(...i))-1]}else{const i=[Math.abs(e.aB(a,...Li(t,-1))-a),Math.abs(e.aB(a,...Li(t,0))-a),Math.abs(e.aB(a,...Li(t,1))-a)];h=[i.indexOf(Math.min(...i))-1]}}else h=[0];for(const e of h){const r=t.containsTile(c,o,i,e);r&&n.push(r)}}return n}getShadowCasterCoordinates(){return this._getRenderableCoordinates(!1,!0)}getVisibleCoordinates(e){return this._getRenderableCoordinates(e)}_getRenderableCoordinates(e,t){const i=this.getRenderableIds(e,t).map(e=>this._tiles[e].tileID),r="globe"===this.transform.projection.name;for(const n of i)n.projMatrix=this.transform.calculateProjMatrix(n.toUnwrapped()),n.expandedProjMatrix=r?this.transform.calculateProjMatrix(n.toUnwrapped(),!1,!0):n.projMatrix;return i}sortCoordinatesByDistance(e){const t=e.slice(),i=this.transform._camera.position,r=this.transform._camera.forward(),n={};for(const o of t){const e=1/(1<<o.canonical.z);n[o.key]=((o.canonical.x+.5)*e+o.wrap-i[0])*r[0]+((o.canonical.y+.5)*e-i[1])*r[1]-i[2]*r[2]}return t.sort((e,t)=>n[e.key]-n[t.key]),t}hasTransition(){if(this._source.hasTransition())return!0;if(this._supportsFading){const t=e.o.now();for(const e in this._tiles){const i=this._tiles[e];if(void 0!==i.fadeEndTime&&i.fadeEndTime>=t)return!0}}return!1}setFeatureState(e,t,i){this._state.updateState(e=e||"_geojsonTileLayer",t,i)}removeFeatureState(e,t,i){this._state.removeFeatureState(e=e||"_geojsonTileLayer",t,i)}getFeatureState(e,t){return this._state.getState(e=e||"_geojsonTileLayer",t)}setDependencies(e,t,i){const r=this._tiles[e];r&&r.setDependencies(t,i)}reloadTilesForDependencies(e,t){for(const i in this._tiles)this._tiles[i].hasDependency(e,t)&&this._reloadTile(+i,"reloading");this._cache.filter(i=>!i.hasDependency(e,t))}_preloadTiles(t,i){if(!this._sourceLoaded){const e=()=>{this._sourceLoaded&&(this._source.off("data",e),this._preloadTiles(t,i))};return void this._source.on("data",e)}const r=/* @__PURE__ */new Map,n=Array.isArray(t)?t:[t],o=this.map.painter.terrain,s=this.usedForTerrain&&o?o.getScaledDemTileSize():this._source.tileSize;for(const e of n){const t=e.coveringTiles({tileSize:s,minzoom:this._source.minzoom,maxzoom:this._source.maxzoom,roundZoom:this._source.roundZoom&&!this.usedForTerrain,reparseOverscaled:this._source.reparseOverscaled,isTerrainDEM:this.usedForTerrain});for(const e of t)r.set(e.key,e);this.usedForTerrain&&e.updateElevation(!1)}const a=Array.from(r.values());e.ao(a,(t,i)=>{const r=new e.b3(t,this._source.tileSize*t.overscaleFactor(),this.transform.tileZoom,this.map.painter,this._isRaster,this._source.worldview);this._loadTile(r,e=>{"raster-dem"===this._source.type&&r.dem&&this._backfillDEM(r),i(e,r)})},i)}}function zi(e,t){const i=Math.abs(2*e.wrap)-+(e.wrap<0),r=Math.abs(2*t.wrap)-+(t.wrap<0);return e.overscaledZ-t.overscaledZ||r-i||t.canonical.y-e.canonical.y||t.canonical.x-e.canonical.x}function Li(e,t){const i=1<<e.z;return[e.x/i+t,(e.x+1)/i+t]}Ri.maxOverzooming=10,Ri.maxUnderzooming=3;class Fi{constructor(e){this.style=e,this.layersGotHidden=!1,this.layers=[]}processLayersChanged(){this.layers=[];const e=!1,t=!1;for(const i in this.style._mergedLayers){const r=this.style._mergedLayers[i];if("fill-extrusion"===r.type||"building"===r.type)this.layers.push({layer:r,visible:e,visibilityChanged:t});else if("model"===r.type){const i=this.style.getLayerSource(r);i&&"batched-model"===i.type&&this.layers.push({layer:r,visible:e,visibilityChanged:t})}}}onNewFrame(e){this.layersGotHidden=!1;for(const t of this.layers){const i=t.layer;let r=!1;"fill-extrusion"===i.type?r=!i.isHidden(e)&&i.paint.get("fill-extrusion-opacity")>0:"building"===i.type?r=!i.isHidden(e)&&i.paint.get("building-opacity")>0:"model"===i.type&&(r=!i.isHidden(e)&&i.paint.get("model-opacity").constantOr(1)>0),this.layersGotHidden=this.layersGotHidden||!r&&t.visible,t.visible=r}}updateZOffset(e,t){this.currentBuildingBuckets=[];for(const r of this.layers){const e=r.layer,i=this.style.getLayerSourceCache(e);let n=1;"fill-extrusion"===e.type?n=r.visible?e.paint.get("fill-extrusion-vertical-scale"):0:"building"===e.type&&(n=r.visible?e.paint.get("building-vertical-scale"):0);let o=i?i.getTile(t):null;if(!o&&i)for(const r in i._tiles){const e=i._tiles[r];if(t.canonical.isChildOf(e.tileID.canonical)){o=e;break}}this.currentBuildingBuckets.push({bucket:o?o.getBucket(e):null,tileID:o?o.tileID:t,verticalScale:n})}e.hasAnyZOffset=!1;let i=!1;for(let r=0;r<e.symbolInstances.length;r++){const n=e.symbolInstances.get(r),o=n.zOffset,s=this._getHeightAtTileOffset(t,n.tileAnchorX,n.tileAnchorY);n.zOffset=s!==Number.NEGATIVE_INFINITY?s:o,i||o===n.zOffset||(i=!0),e.hasAnyZOffset||0===n.zOffset||(e.hasAnyZOffset=!0)}i&&(e.zOffsetBuffersNeedUpload=!0,e.zOffsetSortDirty=!0)}_mapCoordToOverlappingTile(t,i,r,n){let o=i,s=r;if(t.canonical.z!==n.canonical.z){const a=n.canonical,l=1/(1<<t.canonical.z-a.z);o=(i+t.canonical.x*e.ak)*l-a.x*e.ak|0,s=(r+t.canonical.y*e.ak)*l-a.y*e.ak|0}return{tileX:o,tileY:s}}_getHeightAtTileOffset(e,t,i){let r,n;for(let o=0;o<this.layers.length;++o){const s=this.layers[o].layer;if("fill-extrusion"!==s.type&&"building"!==s.type)continue;const{bucket:a,tileID:l,verticalScale:c}=this.currentBuildingBuckets[o];if(!a)continue;const{tileX:h,tileY:u}=this._mapCoordToOverlappingTile(e,t,i,l),d=a.getHeightAtTileCoord(h,u);d&&void 0!==d.height&&(d.hidden?r=d.height:n=Math.max(d.height*c,n||0))}if(void 0!==n)return n;for(let o=0;o<this.layers.length;++o){const n=this.layers[o];if("model"!==n.layer.type||!n.visible)continue;const{bucket:s,tileID:a}=this.currentBuildingBuckets[o];if(!s)continue;const{tileX:l,tileY:c}=this._mapCoordToOverlappingTile(e,t,i,a),h=s.getHeightAtTileCoord(l,c);if(h&&!h.hidden)return void 0===h.height&&void 0!==r?Math.min(h.maxHeight,r)*h.verticalScale:h.height?h.height*h.verticalScale:Number.NEGATIVE_INFINITY}return this.layersGotHidden?0:Number.NEGATIVE_INFINITY}}let Oi;function Bi(){return Oi||(Oi=new ni),Oi}function ki(t,i){const r={};for(const e in t)"ref"!==e&&(r[e]=t[e]);return e.b8.forEach(e=>{e in i&&(r[e]=i[e])}),r}function Ni(e){e=e.slice();const t=Object.create(null);for(const i of e)t[i.id]=i;for(let i=0;i<e.length;i++){const r=e[i];if(r&&"ref"in r){const n=t[r.ref];n&&(e[i]=ki(r,n))}}return e}const Ui={setStyle:"setStyle",addLayer:"addLayer",removeLayer:"removeLayer",setPaintProperty:"setPaintProperty",setLayoutProperty:"setLayoutProperty",setSlot:"setSlot",setFilter:"setFilter",addSource:"addSource",removeSource:"removeSource",setGeoJSONSourceData:"setGeoJSONSourceData",setLayerZoomRange:"setLayerZoomRange",setLayerProperty:"setLayerProperty",setCenter:"setCenter",setZoom:"setZoom",setBearing:"setBearing",setPitch:"setPitch",setSprite:"setSprite",setGlyphs:"setGlyphs",setTransition:"setTransition",setLight:"setLight",setTerrain:"setTerrain",setFog:"setFog",setSnow:"setSnow",setRain:"setRain",setCamera:"setCamera",setLights:"setLights",setProjection:"setProjection",addImport:"addImport",removeImport:"removeImport",updateImport:"updateImport",addIconset:"addIconset",removeIconset:"removeIconset"};function Vi(e,t,i){i.push({command:Ui.addSource,args:[e,t[e]]})}function ji(e,t,i){t.push({command:Ui.removeSource,args:[e]}),i[e]=!0}function Gi(e,t,i,r){ji(e,i,r),Vi(e,t,i)}function Hi(t,i,r){let n;for(n in t[r])if(Object.hasOwn(t[r],n)&&"data"!==n&&!e.b9(t[r][n],i[r][n]))return!1;for(n in i[r])if(Object.hasOwn(i[r],n)&&"data"!==n&&!e.b9(t[r][n],i[r][n]))return!1;return!0}function $i(t,i,r,n,o,s){let a;for(a in i=i||{},t=t||{})Object.hasOwn(t,a)&&(e.b9(t[a],i[a])||r.push({command:s,args:[n,a,i[a],o]}));for(a in i)Object.hasOwn(i,a)&&!Object.hasOwn(t,a)&&(e.b9(t[a],i[a])||r.push({command:s,args:[n,a,i[a],o]}))}function qi(e){return e.id}function Zi(e,t){return e[t.id]=t,e}function Wi(t,i,r){const n=i.createTileMatrix(t,t.worldSize,r.toUnwrapped());return e.aC(new Float32Array(16),t.projMatrix,n)}function Xi(e,t,i){if(t.projection.name===i.projection.name)return e.projMatrix;const r=i.clone();return r.setProjection(t.projection),Wi(r,t.getProjection(),e)}function Yi(e,t,i){return t.name===i.projection.name?e.projMatrix:Wi(i,t,e)}class Ji{constructor(e,t){this.reset(e,t)}reset(e,t){this.points=e||[],this._distances=[0];for(let i=1;i<this.points.length;i++)this._distances[i]=this._distances[i-1]+this.points[i].dist(this.points[i-1]);this.length=this._distances.at(-1),this.padding=Math.min(t||0,.5*this.length),this.paddedLength=this.length-2*this.padding}lerp(t){if(1===this.points.length)return this.points[0];t=e.aB(t,0,1);let i=1,r=this._distances[i];const n=t*this.paddedLength+this.padding;for(;r<n&&i<this._distances.length;)r=this._distances[++i];const o=i-1,s=this._distances[o],a=r-s,l=a>0?(n-s)/a:0;return this.points[o].mult(1-l).add(this.points[i].mult(l))}}const Ki=Math.tan(85*Math.PI/180);function Qi(t,i,r,n,o,s,a){const l=e.bd();if(r)if("globe"===s.name){const t=e.be(o,i);e.aC(l,l,t)}else{const t=e.bf([],a);l[0]=t[0],l[1]=t[1],l[4]=t[2],l[5]=t[3],n||e.bc(l,l,o.angle)}else e.aC(l,o.labelPlaneMatrix,t);return l}function er(e,t,i,r,n,o,s){const a=Qi(e,t,i,r,n,o,s);return"globe"===o.name&&i||(a[2]=a[6]=a[10]=a[14]=0),a}function tr(t,i,r,n,o,s,a){if(r){if("globe"===s.name){const l=Qi(t,i,r,n,o,s,a);return e.ba(l,l),e.aC(l,t,l),l}{const i=e.bb(t),[r,s,l,c]=a,[h,u,d,p,f,m,_,g]=i;return i[0]=r*h+s*f,i[1]=r*u+s*m,i[2]=r*d+s*_,i[3]=r*p+s*g,i[4]=l*h+c*f,i[5]=l*u+c*m,i[6]=l*d+c*_,i[7]=l*p+c*g,n||e.bc(i,i,-o.angle),i}}return o.glCoordMatrix}function ir(t,i,r,n){const o=[t,i,r,1];r?e.aD(o,o,n):pr(o,o,n);const s=o[3];return o[0]/=s,o[1]/=s,o[2]/=s,o}function rr(e,t){return Math.min(.5+e/t*.5,1.5)}function nr(e,t){const i=e[0]/e[3],r=e[1]/e[3];return i>=-t[0]&&i<=t[0]&&r>=-t[1]&&r<=t[1]}function or(t,i,r,n,o,s,a,l,c,h,u=1){const d=r.transform,p=n?t.textSizeData:t.iconSizeData,f=e.bl(p,r.transform.zoom,u),m="globe"===d.projection.name,_=[256/r.width*2+1,256/r.height*2+1],g=n?t.text.dynamicLayoutVertexArray:t.icon.dynamicLayoutVertexArray;g.clear();let y=null;m&&(y=n?t.text.globeExtVertexArray:t.icon.globeExtVertexArray);const x=t.lineVertexArray,v=n?t.text.placedSymbolArray:t.icon.placedSymbolArray,b=r.transform.width/r.transform.height;let w,T=!1;for(let S=0;S<v.length;S++){const n=v.get(S),{numGlyphs:u,writingMode:m}=n;if(m!==e.bm.vertical||T||w===e.bm.horizontal||(T=!0),w=m,(n.hidden||m===e.bm.vertical)&&!T){dr(u,g);continue}T=!1;const I=new e.P(n.tileAnchorX,n.tileAnchorY),E="road"===t.elevationType,A=!!d.elevation||E;let{x:M,y:C,z:P}=d.projection.projectTilePoint(I.x,I.y,h.canonical),D=null;if(A){const e=E?t.getElevationFeatureForText(S):null;D={getElevation:c,elevation:d.elevation,elevationFeature:e};const[i,r,n]=c(I,d.elevation,e);M+=i,C+=r,P+=n}const R=[M,C,P,1];if(e.aD(R,R,i),!nr(R,_)){dr(u,g);continue}const z=R[3],L=rr(r.transform.getCameraToCenterDistance(d.projection),z),F=e.bn(p,f,n),O=a?F/L:F*L,B=ir(M,C,P,o);if(B[3]<=0){dr(u,g);continue}let k={};const N=e.am(t.layers[0].layout.get("text-max-angle")),U=Math.cos(N),V=a?null:D,j=lr(n,O,!1,l,i,o,s,t.glyphOffsetArray,x,g,y,B,I,k,b,V,d.projection,h,a,U);T=j.useVertical,V&&j.needsFlipping&&(k={}),(j.notEnoughRoom||T||j.needsFlipping&&lr(n,O,!0,l,i,o,s,t.glyphOffsetArray,x,g,y,B,I,k,b,V,d.projection,h,a,U).notEnoughRoom)&&dr(u,g)}n?(t.text.dynamicLayoutVertexBuffer.updateData(g),y&&t.text.globeExtVertexBuffer&&t.text.globeExtVertexBuffer.updateData(y)):(t.icon.dynamicLayoutVertexBuffer.updateData(g),y&&t.icon.globeExtVertexBuffer&&t.icon.globeExtVertexBuffer.updateData(y))}function sr(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_){const{lineStartIndex:g,glyphStartIndex:y,segment:x}=a,v=y+a.numGlyphs,b=g+a.lineLength,w=t.getoffsetX(y),T=t.getoffsetX(v-1),S=ur(e*w,i,r,n,o,s,x,g,b,l,c,h,u,d,!0,p,f,m,_);if(!S)return null;const I=ur(e*T,i,r,n,o,s,x,g,b,l,c,h,u,d,!0,p,f,m,_);return I?{first:S,last:I}:null}function ar(t,i,r,n){return t===e.bm.horizontal&&Math.abs(n)>Math.abs(r)?{useVertical:!0}:t===e.bm.vertical?n>0?{needsFlipping:!0}:null:0!==i&&function(e,t){return 0===e||Math.abs(t/e)>Ki}(r,n)?1===i?{needsFlipping:!0}:null:r<0?{needsFlipping:!0}:null}function lr(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v){const b=i/24,w=t.lineOffsetX*b,T=t.lineOffsetY*b,{lineStartIndex:S,glyphStartIndex:I,numGlyphs:E,segment:A,writingMode:M,flipState:C}=t,P=S+t.lineLength,D=t=>{if(u){const[i,r,n]=t.up,o=h.length;e.bo(u,o+0,i,r,n),e.bo(u,o+1,i,r,n),e.bo(u,o+2,i,r,n),e.bo(u,o+3,i,r,n)}const[i,r,n]=t.point;e.bp(h,i,r,n,t.angle)};if(E>1){const e=sr(b,l,w,T,r,d,p,t,c,s,f,_,!1,g,y,x,v);if(!e)return{notEnoughRoom:!0};if(n&&!r){let[i,r,n]=e.first.point,[o,s,l]=e.last.point;[i,r]=ir(i,r,n,a),[o,s]=ir(o,s,l,a);const c=ar(M,C,(o-i)*m,s-r);if(t.flipState=c&&c.needsFlipping?1:2,c)return c}D(e.first);for(let t=I+1;t<I+E-1;t++){const e=ur(b*l.getoffsetX(t),w,T,r,d,p,A,S,P,c,s,f,_,!1,!1,g,y,x,v);if(!e)return h.length-=4*(t-I),{notEnoughRoom:!0};D(e)}D(e.last)}else{if(n&&!r){const i=ir(p.x,p.y,0,o),r=S+A+1,n=new e.P(c.getx(r),c.gety(r)),s=ir(n.x,n.y,0,o),a=s[3]>0?s:hr(p,n,i,1,o,void 0,g,y.canonical),l=ar(M,C,(a[0]-i[0])*m,a[1]-i[1]);if(t.flipState=l&&l.needsFlipping?1:2,l)return l}const i=ur(b*l.getoffsetX(I),w,T,r,d,p,A,S,P,c,s,f,_,!1,!1,g,y,x,v);if(!i)return{notEnoughRoom:!0};D(i)}return{}}function cr(e,t,i,r,n){const{x:o,y:s,z:a}=r.projectTilePoint(e.x,e.y,t);if(!n)return ir(o,s,a,i);const[l,c,h]=n.getElevation(e,n.elevation,n.elevationFeature);return ir(o+l,s+c,a+h,i)}function hr(t,i,r,n,o,s,a,l){const c=cr(t.sub(i)._unit()._add(t),l,o,a,s);return e.aw(c,r,c),e.ax(c,c),e.bi(c,r,c,n)}function ur(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x){const v=n?t-i:t+i;let b=v>0?1:-1,w=0;n&&(b*=-1,w=Math.PI),b<0&&(w+=Math.PI);let T=l+a+(b>0?0:1)|0,S=o,I=o,E=0,A=0;const M=Math.abs(v),C=[],P=[];let D=s,R=D,z=e.bg([]);const L=()=>hr(R,D,I,M-E+1,u,p,_,g.canonical);for(;E+A<=M;){if(T+=b,T<l||T>=c)return null;if(I=S,R=D,C.push(I),f&&P.push(R),D=new e.P(h.getx(T),h.gety(T)),S=d[T],!S){const e=cr(D,g.canonical,u,_,p);S=e[3]>0?d[T]=e:L()}E+=A;const t=e.aw([],S,I),i=e.bh(I,S);if(r&&i>0&&A>0&&e.bk(z,t)/(A*i)<x)return null;A=i,z=t}m&&p&&(d[T]&&(S=L(),A=e.bh(I,S),z=e.aw([],S,I)),d[T]=S);const F=(M-E)/A,O=D.sub(R)._mult(F)._add(R),B=e.bi([],I,z,F);let k=[0,0,1],N=z[0],U=z[1];if(y&&(k=_.upVector(g.canonical,O.x,O.y),0!==k[0]||0!==k[1]||1!==k[2])){const t=[k[2],0,-k[0]],i=e.bj([],k,t);e.ax(t,t),e.ax(i,i),N=e.bk(z,t),U=e.bk(z,i)}if(r){const t=e.bj([],k,z);e.ax(t,t),e.bi(B,B,t,r*b)}const V=w+Math.atan2(U,N);return C.push(B),f&&P.push(O),{point:B,angle:V,path:C,tilePath:P,up:k}}function dr(e,t){const i=t.length,r=i+4*e;t.resize(r),t.float32.fill(-1/0,4*i,4*r)}function pr(e,t,i){const r=t[0],n=t[1];return e[0]=i[0]*r+i[4]*n+i[12],e[1]=i[1]*r+i[5]*n+i[13],e[3]=i[3]*r+i[7]*n+i[15],e}const fr=100;class mr{constructor(t,i,r=new e.bq(t.width+200,t.height+200,25),n=new e.bq(t.width+200,t.height+200,25)){this.transform=t,this.grid=r,this.ignoredGrid=n,this.pitchfactor=Math.cos(t._pitch)*t.cameraToCenterDistance,this.screenRightBoundary=t.width+fr,this.screenBottomBoundary=t.height+fr,this.gridRightBoundary=t.width+200,this.gridBottomBoundary=t.height+200,this.fogState=i,this.clippedSymbols=/* @__PURE__ */new Map}clearClippedSymbolsForBucket(e){this.clippedSymbols.delete(e)}markSymbolAsClipped(e,t){let i=this.clippedSymbols.get(e);i||(i=/* @__PURE__ */new Set,this.clippedSymbols.set(e,i)),i.add(t)}placeCollisionBox(t,i,r,n,o,s,a,l,c,h,u){let d=r.projectedAnchorX,p=r.projectedAnchorY,f=r.projectedAnchorZ;const m=r.tileAnchorX,_=r.tileAnchorY,g=r.elevation,y=r.tileID,x=t.getProjection();if(g&&y){const[e,t,i]=x.upVector(y.canonical,r.tileAnchorX,r.tileAnchorY),n=x.upVectorScale(y.canonical,this.transform.center.lat,this.transform.worldSize).metersToTile;d+=e*g*n,p+=t*g*n,f+=i*g*n}const v="globe"===t.projection.name,b="globe"===t.projection.name?e.ai(this.transform.zoom):0;if(y&&v&&b<1&&!s){const t=1<<y.canonical.z,i=e.br(m,_);e.bs(i,i,1/e.ak),e.bt(i,i,e.br(y.canonical.x,y.canonical.y)),e.bs(i,i,1/t),e.bu(i,i,e.br(n[0],n[1])),i[0]=e.bv(i[0],-.5,.5),e.bs(i,i,e.ak);const r=e.bw(i[0],i[1],e.ak/(2*Math.PI),1);e.aD(r,r,o),d=e.aj(d,r[0],b),p=e.aj(p,r[1],b),f=e.aj(f,r[2],b)}const w=this.projectAndGetPerspectiveRatio(h,d,p,f,r.tileID,"globe"===x.name||!!g||this.transform.pitch>0,x),T=c*w.perspectiveRatio,S=(r.x1*i+a.x-r.padding)*T+w.point.x,I=(r.y1*i+a.y-r.padding)*T+w.point.y,E=(r.x2*i+a.x+r.padding)*T+w.point.x,A=(r.y2*i+a.y+r.padding)*T+w.point.y,M=w.perspectiveRatio<=.55||w.occluded;return!this.isInsideGrid(S,I,E,A)||!l&&this.grid.hitTest(S,I,E,A,u)||M?{box:[],offscreen:!1,occluded:w.occluded}:{box:[S,I,E,A],offscreen:this.isOffscreen(S,I,E,A),occluded:!1}}placeCollisionCircles(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_){const g=[],y=this.transform.elevation,x=t.getProjection(),v="road"===t.elevationType,b=!!y||v,w=e.bx.getAtTileOffsetFunc(_,this.transform.center.lat,this.transform.worldSize,x),T=new e.P(r.tileAnchorX,r.tileAnchorY),S=new e.P(r.tileAnchorX,r.tileAnchorY);let{x:I,y:E,z:A}=x.projectTilePoint(S.x,S.y,_.canonical),M=null;if(b){const e=v?t.getElevationFeatureForText(n):null;M={getElevation:w,elevation:y,elevationFeature:e};const[i,r,o]=w(T,y,e);I+=i,E+=r,A+=o}const C="globe"===x.name,P=this.projectAndGetPerspectiveRatio(l,I,E,A,_,C||!!y||this.transform.pitch>0,x),{perspectiveRatio:D}=P,R=(d?a/D:a*D)/e.bC,z=ir(I,E,A,c),L=r.lineOffsetX*R,F=r.lineOffsetY*R,O=e.am(t.layers[0].layout.get("text-max-angle")),B=Math.cos(O),k=P.signedDistanceFromCamera>0?sr(R,s,L,F,v&&1===r.flipState,z,S,r,o,c,{},b&&!d?M:null,d&&b,x,_,d,B):null;let N=!1,U=!1,V=!0;if(k&&!P.occluded){const t=.5*f*D+m,r=new e.P(-100,-100),n=new e.P(this.screenRightBoundary,this.screenBottomBoundary),o=new Ji,{first:s,last:a}=k,l=s.path.length;let c=[];for(let e=l-1;e>=1;e--)c.push(s.path[e]);for(let e=1;e<a.path.length;e++)c.push(a.path[e]);const d=2.5*t;h&&(c=c.map(([e,t,i],r)=>(b&&!C&&(i=w(r<l-1?s.tilePath[l-1-r]:a.tilePath[r-l+2],y,M.elevationFeature)[2]),ir(e,t,i,h))),c.some(e=>e[3]<=0)&&(c=[]));let _=[];if(c.length>0){let t=1/0,i=-1/0,o=1/0,s=-1/0;for(const e of c)t=Math.min(t,e[0]),o=Math.min(o,e[1]),i=Math.max(i,e[0]),s=Math.max(s,e[1]);i>=r.x&&t<=n.x&&s>=r.y&&o<=n.y&&(_=[c.map(t=>new e.P(t[0],t[1]))],(t<r.x||i>n.x||o<r.y||s>n.y)&&(_=e.by(_,r.x,r.y,n.x,n.y)))}for(const e of _){o.reset(e,.25*t);let r=0;r=o.length<=.5*t?1:Math.ceil(o.paddedLength/d)+1;for(let e=0;e<r;e++){const n=e/Math.max(r-1,1),s=o.lerp(n),a=s.x+fr,l=s.y+fr;g.push(a,l,t,0);const c=a-t,h=l-t,d=a+t,f=l+t;if(V=V&&this.isOffscreen(c,h,d,f),U=U||this.isInsideGrid(c,h,d,f),!i&&this.grid.hitTestCircle(a,l,t,p)&&(N=!0,!u))return{circles:[],offscreen:!1,collisionDetected:N,occluded:!1}}}}return{circles:!u&&N||!U?[]:g,offscreen:V,collisionDetected:N,occluded:P.occluded}}queryRenderedSymbols(t){if(0===t.length||0===this.grid.keysLength()&&0===this.ignoredGrid.keysLength())return{};const i=[];let r=1/0,n=1/0,o=-1/0,s=-1/0;for(const h of t){const t=new e.P(h.x+fr,h.y+fr);r=Math.min(r,t.x),n=Math.min(n,t.y),o=Math.max(o,t.x),s=Math.max(s,t.y),i.push(t)}const a=this.grid.query(r,n,o,s).concat(this.ignoredGrid.query(r,n,o,s)),l={},c={};for(const h of a){const t=h.key;if(void 0===l[t.bucketInstanceId]&&(l[t.bucketInstanceId]={}),l[t.bucketInstanceId][t.featureIndex])continue;const r=this.clippedSymbols.get(t.bucketInstanceId);if(r&&r.has(t.featureIndex))continue;const n=[new e.P(h.x1,h.y1),new e.P(h.x2,h.y1),new e.P(h.x2,h.y2),new e.P(h.x1,h.y2)];e.bz(i,n)&&(l[t.bucketInstanceId][t.featureIndex]=!0,void 0===c[t.bucketInstanceId]&&(c[t.bucketInstanceId]=[]),c[t.bucketInstanceId].push(t.featureIndex))}return c}insertCollisionBox(e,t,i,r,n){(t?this.ignoredGrid:this.grid).insert({bucketInstanceId:i,featureIndex:r,collisionGroupID:n},e[0],e[1],e[2],e[3])}insertCollisionCircles(e,t,i,r,n){const o=t?this.ignoredGrid:this.grid,s={bucketInstanceId:i,featureIndex:r,collisionGroupID:n};for(let a=0;a<e.length;a+=4)o.insertCircle(s,e[a],e[a+1],e[a+2])}projectAndGetPerspectiveRatio(t,i,r,n,o,s,a){const l=[i,r,n,1];let c=!1;n||this.transform.pitch>0?(e.aD(l,l,t),this.fogState&&o&&"globe"!==a.name&&(c=function(t,i,r,n,o,s){const a=s.calculateFogTileMatrix(o),l=[i,r,n];return e.ae(l,l,a),qt(t,e.af(l),s.pitch)}(this.fogState,i,r,n,o.toUnwrapped(),this.transform)>.9)):pr(l,l,t);const h=l[3];return{point:new e.P((l[0]/h+1)/2*this.transform.width+fr,(-l[1]/h+1)/2*this.transform.height+fr),perspectiveRatio:Math.min(.5+this.transform.getCameraToCenterDistance(a)/h*.5,1.5),signedDistanceFromCamera:h,occluded:s&&l[2]>h||c}}isOffscreen(e,t,i,r){return i<fr||e>=this.screenRightBoundary||r<fr||t>this.screenBottomBoundary}isInsideGrid(e,t,i,r){return i>=0&&e<this.gridRightBoundary&&r>=0&&t<this.gridBottomBoundary}getViewportMatrix(){const t=e.bA([]);return e.bB(t,t,[-100,-100,0]),t}}class _r{constructor(e,t,i,r){this.opacity=e?Math.max(0,Math.min(1,e.opacity+(e.placed?t:-t))):r&&i?1:0,this.placed=i}isHidden(){return 0===this.opacity&&!this.placed}}class gr{constructor(e,t,i,r,n,o=!1){this.text=new _r(e?e.text:null,t,i,n),this.icon=new _r(e?e.icon:null,t,r,n),this.clipped=o}isHidden(){return this.text.isHidden()&&this.icon.isHidden()}}class yr{constructor(e,t,i,r=!1){this.text=e,this.icon=t,this.skipFade=i,this.clipped=r}}class xr{constructor(){this.invProjMatrix=e.bd(),this.viewportMatrix=e.bd(),this.circles=[]}}class vr{constructor(e,t,i,r,n){this.bucketInstanceId=e,this.featureIndex=t,this.sourceLayerIndex=i,this.bucketIndex=r,this.tileID=n}}class br{constructor(e){this.crossSourceCollisions=e,this.maxGroupID=0,this.collisionGroups={}}get(e){if(this.crossSourceCollisions)return{ID:0,predicate:null};if(!this.collisionGroups[e]){const t=++this.maxGroupID;this.collisionGroups[e]={ID:t,predicate:e=>e.collisionGroupID===t}}return this.collisionGroups[e]}}function wr(t,i,r,n,o){const{horizontalAlign:s,verticalAlign:a}=e.bJ(t),l=-(s-.5)*i,c=-(a-.5)*r,h=e.bK(t,n);return new e.P(l+h[0]*o,c+h[1]*o)}function Tr(t,i,r,n,o){const s=new e.P(t,i);return r&&s._rotate(n?o:-o),s}class Sr{constructor(e,t,i,r,n,o){this.transform=e.clone(),this.projection=e.projection.name,this.collisionIndex=new mr(this.transform,n),this.buildingIndex=o,this.frontCutoffStart=0,this.placements={},this.opacities={},this.variableOffsets={},this.stale=!1,this.commitTime=0,this.fadeDuration=t,this.retainedQueryData={},this.collisionGroups=new br(i),this.collisionCircleArrays={},this.prevPlacement=r,r&&(r.prevPlacement=void 0),this.placedOrientations={},this.lastReplacementSourceUpdateTime=0}getBucketParts(t,i,r,n,o=1){const s=r.getBucket(i),a=r.latestFeatureIndex;if(!s||!a||i.fqid!==s.layerIds[0])return;const l=s.layers[0].layout,c=s.layers[0].paint,h=r.collisionBoxArray,u=Math.pow(2,this.transform.zoom-r.tileID.overscaledZ),d=r.tileSize/e.ak,p=r.tileID.toUnwrapped();this.transform.setProjection(s.projection);const f=(m=r.tileID,_=s.getProjection(),g=this.transform,_.name===this.projection?g.calculateProjMatrix(m.toUnwrapped()):Wi(g,_,m));var m,_,g;const y="map"===l.get("text-pitch-alignment"),x="map"===l.get("text-rotation-alignment");i.compileFilter(i.options);const v=i.dynamicFilter(),b=i.dynamicFilterNeedsFeature(),w=i.dynamicFilterNeedsGeometry(),T=this.transform.calculatePixelsToTileUnitsMatrix(r),S=er(f,r.tileID.canonical,y,x,this.transform,s.getProjection(),T);let I=null;const E=s.getProjection().createInversionMatrix(this.transform,r.tileID.canonical);if(y){const t=tr(f,r.tileID.canonical,y,x,this.transform,s.getProjection(),T);I=e.aC([],this.transform.labelPlaneMatrix,t)}let A=null;v&&r.latestFeatureIndex&&(A={unwrappedTileID:p,dynamicFilter:v,dynamicFilterNeedsFeature:b,needGeometry:w}),this.retainedQueryData[s.bucketInstanceId]=new vr(s.bucketInstanceId,a,s.sourceLayerIndex,s.index,r.tileID);const[M,C]=s.layers[0].layout.get("text-size-scale-range"),P=e.aB(o,M,C),[D,R]=l.get("icon-size-scale-range"),z=e.aB(o,D,R),L={bucket:s,layout:l,paint:c,posMatrix:f,invMatrix:E,mercatorCenter:[e.aG(this.transform.center.lng),e.aJ(this.transform.center.lat)],textLabelPlaneMatrix:S,labelToScreenMatrix:I,clippingData:A,scale:u,textPixelRatio:d,holdingForFade:r.holdingForFade(),collisionBoxArray:h,partiallyEvaluatedTextSize:e.bl(s.textSizeData,this.transform.zoom,P),partiallyEvaluatedIconSize:e.bl(s.iconSizeData,this.transform.zoom,z),collisionGroup:this.collisionGroups.get(s.sourceID),latestFeatureIndex:r.latestFeatureIndex};if(n)for(const e of s.sortKeyRanges){const{sortKey:i,symbolInstanceStart:r,symbolInstanceEnd:n}=e;t.push({sortKey:i,symbolInstanceStart:r,symbolInstanceEnd:n,parameters:L})}else t.push({symbolInstanceStart:0,symbolInstanceEnd:s.symbolInstances.length,parameters:L})}attemptAnchorPlacement(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v){const{textOffset0:b,textOffset1:w,crossTileID:T}=f,S=[b,w],I=wr(e,o,s,S,a),E=this.collisionIndex.placeCollisionBox(_,a,t,i,r,n,Tr(I.x,I.y,l,c,this.transform.angle),p,h,u,d.predicate);if(y){const e=_.getSymbolInstanceIconSize(v,this.transform.zoom,f.placedIconSymbolIndex);if(0===this.collisionIndex.placeCollisionBox(_,e,y,i,r,n,Tr(I.x,I.y,l,c,this.transform.angle),p,h,u,d.predicate).box.length)return}if(E.box.length>0){let t;return this.prevPlacement&&this.prevPlacement.variableOffsets[T]&&this.prevPlacement.placements[T]&&this.prevPlacement.placements[T].text&&(t=this.prevPlacement.variableOffsets[T].anchor),this.variableOffsets[T]={textOffset:S,width:o,height:s,anchor:e,textScale:a,prevAnchor:t},this.markUsedJustification(_,e,f,g),_.allowVerticalPlacement&&(this.markUsedOrientation(_,g,f),this.placedOrientations[T]=g),{shift:I,placedGlyphBoxes:E}}}placeLayerBucketPart(t,i,r,n,o=1){const{bucket:s,layout:a,paint:l,posMatrix:c,textLabelPlaneMatrix:h,labelToScreenMatrix:u,clippingData:d,textPixelRatio:p,mercatorCenter:f,invMatrix:m,holdingForFade:_,collisionBoxArray:g,partiallyEvaluatedTextSize:y,partiallyEvaluatedIconSize:x,collisionGroup:v,latestFeatureIndex:b}=t.parameters,w=a.get("text-optional"),T=a.get("icon-optional"),S=a.get("text-allow-overlap"),I=a.get("icon-allow-overlap"),E="map"===a.get("text-rotation-alignment"),A="map"===a.get("icon-rotation-alignment"),M="map"===a.get("text-pitch-alignment"),C=l.get("symbol-z-offset"),P="sea"===a.get("symbol-elevation-reference"),D=a.get("symbol-placement"),[R,z]=a.get("text-size-scale-range"),[L,F]=a.get("icon-size-scale-range"),O=e.aB(o,R,z),B=e.aB(o,L,F),k=a.get("text-variable-anchor"),N=E&&"point"!==D,U=A&&"point"!==D,V=k&&s.hasTextData(),j=s.hasIconTextFit()&&V&&s.hasIconData();this.transform.setProjection(s.projection);const G=V||N,H=U||j;let $=S&&(I||!s.hasIconData()||T),q=I&&(S||!s.hasTextData()||w);const Z=!C.isConstant();!s.collisionArrays&&g&&s.deserializeCollisionBoxes(g),r&&n&&s.updateCollisionDebugBuffers(this.transform.zoom,g,O,B);const W=(t,n,o)=>{const{crossTileID:l,numVerticalGlyphVertices:g}=t;let A=null;if(d&&d.dynamicFilterNeedsFeature||Z){const i=this.retainedQueryData[s.bucketInstanceId],r=b.loadFeature({featureIndex:t.featureIndex,bucketIndex:i.bucketIndex,sourceLayerIndex:i.sourceLayerIndex,layoutVertexArrayOffset:0}),n=r.properties?r.properties.worldview:null;if(s.localizable&&s.worldview&&"string"==typeof n)if("all"===n)r.properties.$localized=!0;else{if(!n.split(",").includes(s.worldview))return;r.properties.$localized=!0,r.properties.worldview=s.worldview}A=d&&d.needGeometry?e.bH(r,!0):r}if(d&&!(0,d.dynamicFilter)({zoom:this.transform.zoom,pitch:this.transform.pitch,worldview:s.worldview},A,this.retainedQueryData[s.bucketInstanceId].tileID.canonical,new e.P(t.tileAnchorX,t.tileAnchorY),this.transform.calculateDistanceTileData(d.unwrappedTileID)))return this.placements[l]=new yr(!1,!1,!1,!0),void i.add(l);const D=C.evaluate(A,{});if((t.zOffset||0)+(D||0)>0&&this.frontCutoffStart>0){const r=2*this.frontCutoffStart-1,n=[t.tileAnchorX,t.tileAnchorY,0,1],o=e.aD(e.bI(),n,c);if(o[1]/o[3]<r)return this.placements[l]=new yr(!1,!1,!1,!0),void i.add(l)}if(i.has(l))return;if(_)return void(this.placements[l]=new yr(!1,!1,!1));let R=!1,z=!1,L=!0,F=!1,O=!1,B=null,N={box:null,offscreen:null,occluded:null},U={box:null},V=null,j=null,W=null,X=0,Y=0,J=0;o.textFeatureIndex?X=o.textFeatureIndex:t.useRuntimeCollisionCircles&&(X=t.featureIndex),o.verticalTextFeatureIndex&&(Y=o.verticalTextFeatureIndex);const K=s.elevationFeatures?s.elevationFeatures[t.elevationFeatureIndex]:void 0,Q=i=>{i.tileID=this.retainedQueryData[s.bucketInstanceId].tileID;const r=this.transform.elevation;i.elevation=P?D:D+e.bx.getAtTileOffset(i.tileID,new e.P(i.tileAnchorX,i.tileAnchorY),r,K),i.elevation+=t.zOffset},ee=o.textBox;if(ee){Q(ee);const i=i=>{let r=e.bm.horizontal;if(s.allowVerticalPlacement&&!i&&this.prevPlacement){const e=this.prevPlacement.placedOrientations[l];e&&(this.placedOrientations[l]=e,r=e,this.markUsedOrientation(s,r,t))}return r},r=(t,i)=>{if(s.allowVerticalPlacement&&g>0&&o.verticalTextBox){for(const r of s.writingModes)if(r===e.bm.vertical?(N=i(),U=N):N=t(),N&&N.box&&N.box.length)break}else N=t()};if(k){let a=k;if(this.prevPlacement&&this.prevPlacement.variableOffsets[l]){const e=this.prevPlacement.variableOffsets[l];a.indexOf(e.anchor)>0&&(a=a.filter(t=>t!==e.anchor),a.unshift(e.anchor))}const h=(e,i,r)=>{const o=s.getSymbolInstanceTextSize(y,t,this.transform.zoom,n),l=(e.x2-e.x1)*o+2*e.padding,h=(e.y2-e.y1)*o+2*e.padding,u=t.hasIconTextFit&&!I?i:null;u&&Q(u);let d={box:[],offscreen:!1,occluded:!1};const _=S?2*a.length:a.length;for(let g=0;g<_;++g){const i=this.attemptAnchorPlacement(a[g%a.length],e,f,m,G,l,h,o,E,M,p,c,v,g>=a.length,t,n,s,r,u,y,x);if(i&&(d=i.placedGlyphBoxes,d&&d.box&&d.box.length)){R=!0,B=i.shift;break}}return d};r(()=>h(ee,o.iconBox,e.bm.horizontal),()=>{const t=o.verticalTextBox;return t&&Q(t),s.allowVerticalPlacement&&!(N&&N.box&&N.box.length)&&g>0&&t?h(t,o.verticalIconBox,e.bm.vertical):{box:null,offscreen:null,occluded:null}}),N&&(R=N.box,L=N.offscreen,F=N.occluded);const u=i(!(!N||!N.box));if(!R&&this.prevPlacement){const e=this.prevPlacement.variableOffsets[l];e&&(this.variableOffsets[l]=e,this.markUsedJustification(s,e.anchor,t,u))}}else{const a=(i,r)=>{const o=s.getSymbolInstanceTextSize(y,t,this.transform.zoom,n),a=this.collisionIndex.placeCollisionBox(s,o,i,f,m,G,new e.P(0,0),S,p,c,v.predicate);return a&&a.box&&a.box.length&&(this.markUsedOrientation(s,r,t),this.placedOrientations[l]=r),a};r(()=>a(ee,e.bm.horizontal),()=>{const t=o.verticalTextBox;return s.allowVerticalPlacement&&g>0&&t?(Q(t),a(t,e.bm.vertical)):{box:null,offscreen:null,occluded:null}}),i(!!(N&&N.box&&N.box.length))}}if(V=N,R=V&&V.box&&V.box.length>0,L=V&&V.offscreen,F=V&&V.occluded,t.useRuntimeCollisionCircles){const i=t.centerJustifiedTextSymbolIndex>=0?t.centerJustifiedTextSymbolIndex:t.verticalPlacedTextSymbolIndex,n=s.text.placedSymbolArray.get(i),o=e.bn(s.textSizeData,y,n),l=a.get("text-padding");j=this.collisionIndex.placeCollisionCircles(s,S,n,i,s.lineVertexArray,s.glyphOffsetArray,o,c,h,u,r,M,v.predicate,t.collisionCircleDiameter*o/e.bC,l,this.retainedQueryData[s.bucketInstanceId].tileID),R=S||j.circles.length>0&&!j.collisionDetected,L=L&&j.offscreen,F=j.occluded}if(o.iconFeatureIndex&&(J=o.iconFeatureIndex),o.iconBox){const i=i=>{Q(i);const r=t.hasIconTextFit&&B?Tr(B.x,B.y,E,M,this.transform.angle):new e.P(0,0),n=s.getSymbolInstanceIconSize(x,this.transform.zoom,t.placedIconSymbolIndex);return this.collisionIndex.placeCollisionBox(s,n,i,f,m,H,r,I,p,c,v.predicate)};U&&U.box&&U.box.length&&o.verticalIconBox?(W=i(o.verticalIconBox),z=W.box.length>0):(W=i(o.iconBox),z=W.box.length>0),L=L&&W.offscreen,O=W.occluded}const te=w||0===t.numHorizontalGlyphVertices&&0===g,ie=T||0===t.numIconVertices;if(te||ie?ie?te||(z=z&&R):R=z&&R:z=R=z&&R,R&&V&&V.box&&this.collisionIndex.insertCollisionBox(V.box,a.get("text-ignore-placement"),s.bucketInstanceId,U&&U.box&&Y?Y:X,v.ID),z&&W&&this.collisionIndex.insertCollisionBox(W.box,a.get("icon-ignore-placement"),s.bucketInstanceId,J,v.ID),j&&(R&&this.collisionIndex.insertCollisionCircles(j.circles,a.get("text-ignore-placement"),s.bucketInstanceId,X,v.ID),r)){const e=s.bucketInstanceId;let t=this.collisionCircleArrays[e];void 0===t&&(t=this.collisionCircleArrays[e]=new xr);for(let i=0;i<j.circles.length;i+=4)t.circles.push(j.circles[i+0]),t.circles.push(j.circles[i+1]),t.circles.push(j.circles[i+2]),t.circles.push(j.collisionDetected?1:0)}const re="globe"!==s.projection.name;$=$&&(re||!F),q=q&&(re||!O),this.placements[l]=new yr(R||$,z||q,L||s.justReloaded),i.add(l)},X=this.retainedQueryData[s.bucketInstanceId].tileID;if("offset"===s.elevationType&&this.buildingIndex&&this.buildingIndex.updateZOffset(s,X),"road"===s.elevationType&&s.updateRoadElevation(X.canonical),s.updateZOffset(),s.sortFeaturesByY){const t=s.getSortedSymbolIndexes(this.transform.angle);for(let e=t.length-1;e>=0;--e){const i=t[e];W(s.symbolInstances.get(i),i,s.collisionArrays[i])}s.hasAnyZOffset&&e.w(`${s.layerIds[0]} layer symbol-z-elevate: symbols are not sorted by elevation if symbol-z-order is evaluated to viewport-y`)}else if(s.hasAnyZOffset){const e=s.getSortedIndexesByZOffset();for(let t=0;t<e.length;++t){const i=e[t];W(s.symbolInstances.get(i),i,s.collisionArrays[i])}}else for(let e=t.symbolInstanceStart;e<t.symbolInstanceEnd;e++)W(s.symbolInstances.get(e),e,s.collisionArrays[e]);if(r&&s.bucketInstanceId in this.collisionCircleArrays){const t=this.collisionCircleArrays[s.bucketInstanceId];e.ba(t.invProjMatrix,c),t.viewportMatrix=this.collisionIndex.getViewportMatrix()}s.justReloaded=!1}markUsedJustification(t,i,r,n){const{leftJustifiedTextSymbolIndex:o,centerJustifiedTextSymbolIndex:s,rightJustifiedTextSymbolIndex:a,verticalPlacedTextSymbolIndex:l,crossTileID:c}=r,h=e.bL(i),u=n===e.bm.vertical?l:"left"===h?o:"center"===h?s:"right"===h?a:-1;o>=0&&(t.text.placedSymbolArray.get(o).crossTileID=u>=0&&o!==u?0:c),s>=0&&(t.text.placedSymbolArray.get(s).crossTileID=u>=0&&s!==u?0:c),a>=0&&(t.text.placedSymbolArray.get(a).crossTileID=u>=0&&a!==u?0:c),l>=0&&(t.text.placedSymbolArray.get(l).crossTileID=u>=0&&l!==u?0:c)}markUsedOrientation(t,i,r){const n=i===e.bm.horizontal||i===e.bm.horizontalOnly?i:0,o=i===e.bm.vertical?i:0,{leftJustifiedTextSymbolIndex:s,centerJustifiedTextSymbolIndex:a,rightJustifiedTextSymbolIndex:l,verticalPlacedTextSymbolIndex:c}=r,h=t.text.placedSymbolArray;s>=0&&(h.get(s).placedOrientation=n),a>=0&&(h.get(a).placedOrientation=n),l>=0&&(h.get(l).placedOrientation=n),c>=0&&(h.get(c).placedOrientation=o)}commit(e){this.commitTime=e,this.zoomAtLastRecencyCheck=this.transform.zoom;const t=this.prevPlacement;let i=!1;this.prevZoomAdjustment=t?t.zoomAdjustment(this.transform.zoom):0;const r=t?t.symbolFadeChange(e):1,n=t?t.opacities:{},o=t?t.variableOffsets:{},s=t?t.placedOrientations:{};for(const a in this.placements){const e=this.placements[a],t=n[a];t?(this.opacities[a]=new gr(t,r,e.text,e.icon,null,e.clipped),i=i||e.text!==t.text.placed||e.icon!==t.icon.placed):(this.opacities[a]=new gr(null,r,e.text,e.icon,e.skipFade,e.clipped),i=i||e.text||e.icon)}for(const a in n){const e=n[a];if(!this.opacities[a]){const t=new gr(e,r,!1,!1);t.isHidden()||(this.opacities[a]=t,i=i||e.text.placed||e.icon.placed)}}for(const a in o)this.variableOffsets[a]||!this.opacities[a]||this.opacities[a].isHidden()||(this.variableOffsets[a]=o[a]);for(const a in s)this.placedOrientations[a]||!this.opacities[a]||this.opacities[a].isHidden()||(this.placedOrientations[a]=s[a]);i?this.lastPlacementChangeTime=e:"number"!=typeof this.lastPlacementChangeTime&&(this.lastPlacementChangeTime=t?t.lastPlacementChangeTime:e)}updateLayerOpacities(e,t,i,r){r&&(this.lastReplacementSourceUpdateTime=r.updateTime);const n=/* @__PURE__ */new Set;for(const o of t){const t=o.getBucket(e);t&&o.latestFeatureIndex&&e.fqid===t.layerIds[0]&&(this.updateBucketOpacities(t,n,o,o.collisionBoxArray,i,r,o.tileID,e.scope),"offset"===t.elevationType&&this.buildingIndex&&this.buildingIndex.updateZOffset(t,o.tileID),"road"===t.elevationType&&t.updateRoadElevation(o.tileID.canonical),t.updateZOffset())}}updateBucketOpacities(t,i,r,n,o,s,a,l){t.hasTextData()&&t.text.opacityVertexArray.clear(),t.hasIconData()&&t.icon.opacityVertexArray.clear(),t.hasIconCollisionBoxData()&&t.iconCollisionBox.collisionVertexArray.clear(),t.hasTextCollisionBoxData()&&t.textCollisionBox.collisionVertexArray.clear();const c=t.layers[0].layout,h=t.layers[0].paint,u=!!t.layers[0].dynamicFilter(),d=new gr(null,0,!1,!1,!0),p=c.get("text-allow-overlap"),f=c.get("icon-allow-overlap"),m=c.get("text-variable-anchor"),_="map"===c.get("text-rotation-alignment"),g="map"===c.get("text-pitch-alignment"),y=h.get("symbol-z-offset"),x="sea"===c.get("symbol-elevation-reference"),v=!y.isConstant(),b=new gr(null,0,p&&(f||!t.hasIconData()||c.get("icon-optional")),f&&(p||!t.hasTextData()||c.get("text-optional")),!0);!t.collisionArrays&&n&&(t.hasIconCollisionBoxData()||t.hasTextCollisionBoxData())&&t.deserializeCollisionBoxes(n);const w=(e,t,i)=>{for(let r=0;r<t/4;r++)e.opacityVertexArray.emplaceBack(i)};let T=0;s&&t.updateReplacement(a,s),this.collisionIndex.clearClippedSymbolsForBucket(t.bucketInstanceId);for(let S=0;S<t.symbolInstances.length;S++){const n=t.symbolInstances.get(S),{numHorizontalGlyphVertices:c,numVerticalGlyphVertices:h,crossTileID:p,numIconVertices:f,tileAnchorX:I,tileAnchorY:E}=n;let A=null;const M=this.retainedQueryData[t.bucketInstanceId];v&&n&&M&&(A=r.latestFeatureIndex.loadFeature({featureIndex:n.featureIndex,bucketIndex:M.bucketIndex,sourceLayerIndex:M.sourceLayerIndex,layoutVertexArrayOffset:0}));const C=y.evaluate(A,{}),P=i.has(p);let D=this.opacities[p];P?D=d:D||(D=b,this.opacities[p]=D),i.add(p);const R=c>0||h>0,z=f>0,L=this.placedOrientations[p],F=L===e.bm.vertical,O=L===e.bm.horizontal||L===e.bm.horizontalOnly;!R&&!z||D.isHidden()||T++;let B=!1;if((R||z)&&s)for(const i of t.activeReplacements){if(e.bD(i,o,e.bE.Symbol,l))continue;if(i.min.x>I||I>i.max.x||i.min.y>E||E>i.max.y)continue;const t=e.bF(I,E,a.canonical,i.footprintTileId.canonical);if(B=e.bG(t,i.footprint),B)break}if(B&&this.collisionIndex.markSymbolAsClipped(t.bucketInstanceId,n.featureIndex),R){const e=B?Lr:zr(D.text);w(t.text,c,F?Lr:e),w(t.text,h,O?Lr:e);const i=D.text.isHidden(),{leftJustifiedTextSymbolIndex:r,centerJustifiedTextSymbolIndex:o,rightJustifiedTextSymbolIndex:s,verticalPlacedTextSymbolIndex:a}=n,l=t.text.placedSymbolArray,u=i||F?1:0;r>=0&&(l.get(r).hidden=u),o>=0&&(l.get(o).hidden=u),s>=0&&(l.get(s).hidden=u),a>=0&&(l.get(a).hidden=i||O?1:0);const d=this.variableOffsets[p];d&&this.markUsedJustification(t,d.anchor,n,L);const f=this.placedOrientations[p];f&&(this.markUsedJustification(t,"left",n,f),this.markUsedOrientation(t,f,n))}if(z){const e=B?Lr:zr(D.icon),{placedIconSymbolIndex:i,verticalPlacedIconSymbolIndex:r}=n,o=t.icon.placedSymbolArray,s=D.icon.isHidden()?1:0;i>=0&&(w(t.icon,f,F?Lr:e),o.get(i).hidden=s),r>=0&&(w(t.icon,n.numVerticalIconVertices,O?Lr:e),o.get(r).hidden=s)}if(t.hasIconCollisionBoxData()||t.hasTextCollisionBoxData()){const i=t.collisionArrays[S];if(i){let r=new e.P(0,0),o=!0;if(i.textBox||i.verticalTextBox){if(m){const e=this.variableOffsets[p];e?(r=wr(e.anchor,e.width,e.height,e.textOffset,e.textScale),_&&r._rotate(g?this.transform.angle:-this.transform.angle)):o=!1}u&&(o=!D.clipped),i.textBox&&Ir(t.textCollisionBox.collisionVertexArray,D.text.placed,!o||F,C,x,r.x,r.y),i.verticalTextBox&&Ir(t.textCollisionBox.collisionVertexArray,D.text.placed,!o||O,C,x,r.x,r.y)}const s=o&&Boolean(!O&&i.verticalIconBox);i.iconBox&&Ir(t.iconCollisionBox.collisionVertexArray,D.icon.placed,s,C,x,n.hasIconTextFit?r.x:0,n.hasIconTextFit?r.y:0),i.verticalIconBox&&Ir(t.iconCollisionBox.collisionVertexArray,D.icon.placed,!s,C,x,n.hasIconTextFit?r.x:0,n.hasIconTextFit?r.y:0)}}}if(t.fullyClipped=0===T,t.sortFeatures(this.transform.angle),this.retainedQueryData[t.bucketInstanceId]&&(this.retainedQueryData[t.bucketInstanceId].featureSortOrder=t.featureSortOrder),t.hasTextData()&&t.text.opacityVertexBuffer&&t.text.opacityVertexBuffer.updateData(t.text.opacityVertexArray),t.hasIconData()&&t.icon.opacityVertexBuffer&&t.icon.opacityVertexBuffer.updateData(t.icon.opacityVertexArray),t.hasIconCollisionBoxData()&&t.iconCollisionBox.collisionVertexBuffer&&t.iconCollisionBox.collisionVertexBuffer.updateData(t.iconCollisionBox.collisionVertexArray),t.hasTextCollisionBoxData()&&t.textCollisionBox.collisionVertexBuffer&&t.textCollisionBox.collisionVertexBuffer.updateData(t.textCollisionBox.collisionVertexArray),t.bucketInstanceId in this.collisionCircleArrays){const e=this.collisionCircleArrays[t.bucketInstanceId];t.placementInvProjMatrix=e.invProjMatrix,t.placementViewportMatrix=e.viewportMatrix,t.collisionCircleArray=e.circles,delete this.collisionCircleArrays[t.bucketInstanceId]}}symbolFadeChange(e){return 0===this.fadeDuration?1:(e-this.commitTime)/this.fadeDuration+this.prevZoomAdjustment}zoomAdjustment(e){return Math.max(0,(this.transform.zoom-e)/1.5)}hasTransitions(e){return e-this.lastPlacementChangeTime<this.fadeDuration}stillRecent(e,t){const i=this.zoomAtLastRecencyCheck===t?1-this.zoomAdjustment(t):1;return this.zoomAtLastRecencyCheck=t,this.commitTime+this.fadeDuration*i>e}isStale(){return this.stale}setStale(){this.stale=!0}}function Ir(e,t,i,r,n,o,s){e.emplaceBack(t?1:0,i?1:0,o||0,s||0,r,n?1:0),e.emplaceBack(t?1:0,i?1:0,o||0,s||0,r,n?1:0),e.emplaceBack(t?1:0,i?1:0,o||0,s||0,r,n?1:0),e.emplaceBack(t?1:0,i?1:0,o||0,s||0,r,n?1:0)}const Er=Math.pow(2,25),Ar=Math.pow(2,24),Mr=Math.pow(2,17),Cr=Math.pow(2,16),Pr=Math.pow(2,9),Dr=Math.pow(2,8),Rr=Math.pow(2,1);function zr(e){if(0===e.opacity&&!e.placed)return 0;if(1===e.opacity&&e.placed)return 4294967295;const t=e.placed?1:0,i=Math.floor(127*e.opacity);return i*Er+t*Ar+i*Mr+t*Cr+i*Pr+t*Dr+i*Rr+t}const Lr=0;class Fr{constructor(e){this._sortAcrossTiles="viewport-y"!==e.layout.get("symbol-z-order")&&void 0!==e.layout.get("symbol-sort-key").constantOr(1),this._currentTileIndex=0,this._currentPartIndex=0,this._seenCrossTileIDs=/* @__PURE__ */new Set,this._bucketParts=[]}continuePlacement(e,t,i,r,n,o){const s=this._bucketParts;for(;this._currentTileIndex<e.length;)if(t.getBucketParts(s,r,e[this._currentTileIndex],this._sortAcrossTiles,o),this._currentTileIndex++,n())return!0;for(this._sortAcrossTiles&&(this._sortAcrossTiles=!1,s.sort((e,t)=>e.sortKey-t.sortKey));this._currentPartIndex<s.length;){const e=s[this._currentPartIndex];if(t.placeLayerBucketPart(e,this._seenCrossTileIDs,i,0===e.symbolInstanceStart,o),this._currentPartIndex++,n())return!0}return!1}}class Or{startNewPlacement(e,t,i,r,n,o,s,a){return this.placement=new Sr(e,r,n,o,s,a),this._currentPlacementIndex=t.length-1,this._forceFullPlacement=!1,this._showCollisionBoxes=i,this._fadeDuration=r,this._done=!1,this._inProgressLayer=null,this}requestFullPlacement(){this._forceFullPlacement=!0}isFullPlacementRequested(){return this._forceFullPlacement}setStale(){this.placement&&(this.placement.stale=!0)}isStale(){return!!this.placement&&this.placement.stale}isDone(){return this._done}continuePlacement(t,i,r,n,o){const s=e.o.now(),a=()=>{const t=e.o.now()-s;return!this.isFullPlacementRequested()&&0!==this._fadeDuration&&t>2};for(;this._currentPlacementIndex>=0;){const s=i[t[this._currentPlacementIndex]],l=this.placement.collisionIndex.transform.zoom;if("symbol"===s.type&&"none"!==s.visibility&&(!s.minzoom||s.minzoom<=l)&&(!s.maxzoom||s.maxzoom>l)){const t=s,i=t.layout.get("symbol-z-elevate"),l=void 0!==t.layout.get("symbol-sort-key").constantOr(1),c=t.layout.get("symbol-z-order"),h="viewport-y"===c||"auto"===c&&!("viewport-y"!==c&&l),u=t.layout.get("text-allow-overlap")||t.layout.get("icon-allow-overlap")||t.layout.get("text-ignore-placement")||t.layout.get("icon-ignore-placement"),d=h&&u,p=this._inProgressLayer=this._inProgressLayer||new Fr(t),f=e.t(s.source,s.scope);if(p.continuePlacement(i||d?n[f]:r[f],this.placement,this._showCollisionBoxes,s,a,o))return;delete this._inProgressLayer}this._currentPlacementIndex--}this._forceFullPlacement=!1,this._done=!0}commit(e){return this.placement.commit(e),this.placement}}const Br=512/e.ak/2;class kr{constructor(t,i,r){this.tileID=t,this.bucketInstanceId=r,this.index=new e.bM(i.length,16,Int32Array),this.keys=[],this.crossTileIDs=[];const n=t.canonical.x*e.ak,o=t.canonical.y*e.ak;for(let e=0;e<i.length;e++){const{key:t,crossTileID:r,tileAnchorX:s,tileAnchorY:a}=i.get(e),l=Math.floor((n+s)*Br),c=Math.floor((o+a)*Br);this.index.add(l,c),this.keys.push(t),this.crossTileIDs.push(r)}this.index.finish()}findMatches(t,i,r){const n=this.tileID.canonical.z<i.canonical.z?1:Math.pow(2,this.tileID.canonical.z-i.canonical.z),o=Br/Math.pow(2,i.canonical.z-this.tileID.canonical.z),s=i.canonical.x*e.ak,a=i.canonical.y*e.ak;for(let e=0;e<t.length;e++){const i=t.get(e);if(i.crossTileID)continue;const{key:l,tileAnchorX:c,tileAnchorY:h}=i,u=Math.floor((s+c)*o),d=Math.floor((a+h)*o),p=this.index.range(u-n,d-n,u+n,d+n).sort((e,t)=>e-t);for(const e of p){const t=this.crossTileIDs[e];if(this.keys[e]===l&&!r.has(t)){r.add(t),i.crossTileID=t;break}}}}}class Nr{constructor(){this.maxCrossTileID=0}generate(){return++this.maxCrossTileID}}class Ur{constructor(){this.indexes={},this.usedCrossTileIDs={},this.lng=0}handleWrapJump(e){const t=Math.round((e-this.lng)/360);if(0!==t)for(const i in this.indexes){const e=this.indexes[i],r={};for(const i in e){const n=e[i];n.tileID=n.tileID.unwrapTo(n.tileID.wrap+t),r[n.tileID.key]=n}this.indexes[i]=r}this.lng=e}addBucket(e,t,i){if(this.indexes[e.overscaledZ]&&this.indexes[e.overscaledZ][e.key]){if(this.indexes[e.overscaledZ][e.key].bucketInstanceId===t.bucketInstanceId)return!1;this.removeBucketCrossTileIDs(e.overscaledZ,this.indexes[e.overscaledZ][e.key])}for(let n=0;n<t.symbolInstances.length;n++)t.symbolInstances.get(n).crossTileID=0;this.usedCrossTileIDs[e.overscaledZ]||(this.usedCrossTileIDs[e.overscaledZ]=/* @__PURE__ */new Set);const r=this.usedCrossTileIDs[e.overscaledZ];for(const n in this.indexes){const i=this.indexes[n];if(Number(n)>e.overscaledZ)for(const n in i){const o=i[n];o.tileID.isChildOf(e)&&o.findMatches(t.symbolInstances,e,r)}else{const o=i[e.scaledTo(Number(n)).key];o&&o.findMatches(t.symbolInstances,e,r)}}for(let n=0;n<t.symbolInstances.length;n++){const e=t.symbolInstances.get(n);e.crossTileID||(e.crossTileID=i.generate(),r.add(e.crossTileID))}return void 0===this.indexes[e.overscaledZ]&&(this.indexes[e.overscaledZ]={}),this.indexes[e.overscaledZ][e.key]=new kr(e,t.symbolInstances,t.bucketInstanceId),!0}removeBucketCrossTileIDs(e,t){for(const i of t.crossTileIDs)this.usedCrossTileIDs[e].delete(i)}removeStaleBuckets(e){let t=!1;for(const i in this.indexes){const r=this.indexes[i];for(const n in r)e[r[n].bucketInstanceId]||(this.removeBucketCrossTileIDs(i,r[n]),delete r[n],t=!0)}return t}}class Vr{constructor(){this.layerIndexes={},this.crossTileIDs=new Nr,this.maxBucketInstanceId=0,this.bucketsInCurrentPlacement={}}addLayer(e,t,i,r){let n=this.layerIndexes[e.fqid];void 0===n&&(n=this.layerIndexes[e.fqid]=new Ur);let o=!1;const s={};"globe"!==r.name&&n.handleWrapJump(i);for(const a of t){const t=a.getBucket(e);t&&e.fqid===t.layerIds[0]&&(t.bucketInstanceId||(t.bucketInstanceId=++this.maxBucketInstanceId),n.addBucket(a.tileID,t,this.crossTileIDs)&&(o=!0),s[t.bucketInstanceId]=!0)}return n.removeStaleBuckets(s)&&(o=!0),o}pruneUnusedLayers(e){const t={};e.forEach(e=>{t[e]=!0});for(const i in this.layerIndexes)t[i]||delete this.layerIndexes[i]}}const jr=770,Gr=771;class Hr{constructor(e,t,i,r){this.blendFunction=e,this.blendColor=t.toNonPremultipliedRenderColor(null),this.mask=i,this.blendEquation=r}}Hr.Replace=[1,0,1,0],Hr.disabled=new Hr(Hr.Replace,e.C.transparent,[!1,!1,!1,!1]),Hr.unblended=new Hr(Hr.Replace,e.C.transparent,[!0,!0,!0,!0]),Hr.alphaBlended=new Hr([1,Gr,1,Gr],e.C.transparent,[!0,!0,!0,!0]),Hr.alphaBlendedNonPremultiplied=new Hr([jr,Gr,jr,Gr],e.C.transparent,[!0,!0,!0,!0]),Hr.multiply=new Hr([774,0,774,0],e.C.transparent,[!0,!0,!0,!0]),Hr.multiplyAccumulateAlpha=new Hr([774,0,1,Gr],e.C.transparent,[!0,!0,!0,!0]),Hr.additive=new Hr([1,1,1,1],e.C.transparent,[!0,!0,!0,!0]),Hr.additiveAlphaWeighted=new Hr([jr,1,773,1],e.C.transparent,[!0,!0,!0,!0]),Hr.additiveAlphaWeightedUnboundedAlpha=new Hr([jr,1,1,1],e.C.transparent,[!0,!0,!0,!0]);class $r{constructor(e,t,i){this.func=e,this.mask=t,this.range=i}}$r.ReadOnly=!1,$r.ReadWrite=!0,$r.disabled=new $r(519,$r.ReadOnly,[0,1]);const qr=7680;class Zr{constructor(e,t,i,r,n,o){this.test=e,this.ref=t,this.mask=i,this.fail=r,this.depthFail=n,this.pass=o}}Zr.disabled=new Zr({func:519,mask:0},0,0,qr,qr,qr);const Wr=1029,Xr=2305;class Yr{constructor(e,t,i){this.enable=e,this.mode=t,this.frontFace=i}}function Jr(t,i){const r=e.bS(t,3);e.bV(t,i),e.b_(t,3,r)}function Kr(t,i){const r=e.bP([]);return e.bQ(r,r,-i),e.bR(r,r,-t),r}function Qr(t,i){const r=[t[0],t[1],0],n=[i[0],i[1],0];if(e.af(r)>=1e-15){const t=e.ax([],r);e.bN(n,t,e.bk(n,t)),i[0]=n[0],i[1]=n[1]}const o=e.bj([],i,t);if(e.bO(o)<1e-15)return null;const s=Math.atan2(-o[1],o[0]);return Kr(Math.atan2(Math.sqrt(t[0]*t[0]+t[1]*t[1]),-t[2]),s)}Yr.disabled=new Yr(!1,Wr,Xr),Yr.backCCW=new Yr(!0,Wr,Xr),Yr.backCW=new Yr(!0,Wr,2304),Yr.frontCW=new Yr(!0,1028,2304),Yr.frontCCW=new Yr(!0,1028,Xr);class en{constructor(e,t){this.position=e,this.orientation=t}get position(){return this._position}set position(t){if(t){const i=t instanceof e.ad?t:new e.ad(t[0],t[1],t[2]);this._renderWorldCopies&&(i.x=e.bv(i.x,0,1)),this._position=i}else this._position=null}lookAtPoint(t,i,r){if(this.orientation=null,!this.position)return;const n=this.position,o=r||(this._elevation?this._elevation.getAtPointOrZero(e.ad.fromLngLat(t)):0),s=e.ad.fromLngLat(t,o),a=[s.x-n.x,s.y-n.y,s.z-n.z];i||(i=[0,0,1]),i[2]=Math.abs(i[2]),this.orientation=Qr(a,i)}setPitchBearing(t,i){this.orientation=Kr(e.am(t),e.am(-i))}}class tn{constructor(t,i){this._transform=e.bA([]),this.orientation=i,this.position=t}get mercatorPosition(){const t=this.position;return new e.ad(t[0],t[1],t[2])}get position(){const t=e.bS(this._transform,3);return[t[0],t[1],t[2]]}set position(t){var i;t&&e.b_(this._transform,3,[(i=t)[0],i[1],i[2],1])}get orientation(){return this._orientation}set orientation(t){this._orientation=t||e.bP([]),t&&Jr(this._transform,this._orientation)}getPitchBearing(){const e=this.forward(),t=this.right();return{bearing:Math.atan2(-t[1],t[0]),pitch:Math.atan2(Math.sqrt(e[0]*e[0]+e[1]*e[1]),-e[2])}}setPitchBearing(e,t){this._orientation=Kr(e,t),Jr(this._transform,this._orientation)}forward(){const t=e.bS(this._transform,2);return[-t[0],-t[1],-t[2]]}up(){const t=e.bS(this._transform,1);return[-t[0],-t[1],-t[2]]}right(){const t=e.bS(this._transform,0);return[t[0],t[1],t[2]]}getCameraToWorld(t,i){const r=new Float64Array(16);return e.ba(r,this.getWorldToCamera(t,i)),r}getCameraToWorldMercator(){return this._transform}getWorldToCameraPosition(t,i,r){const n=this.position;e.bN(n,n,-t);const o=new Float64Array(16);return e.bT(o,[r,r,r]),e.bB(o,o,n),o[10]*=i,o}getWorldToCamera(t,i){const r=new Float64Array(16),n=new Float64Array(4),o=this.position;return e.bU(n,this._orientation),e.bN(o,o,-t),e.bV(r,n),e.bB(r,r,o),r[1]*=-1,r[5]*=-1,r[9]*=-1,r[13]*=-1,r[8]*=i,r[9]*=i,r[10]*=i,r[11]*=i,r}getCameraToClipPerspective(t,i,r,n){const o=new Float64Array(16);return e.bW(o,t,i,r,n),o}getCameraToClipOrthographic(t,i,r,n,o,s){const a=new Float64Array(16);return e.bX(a,t,i,r,n,o,s),a}getDistanceToElevation(t,i=!1){const r=0===t?0:e.bY(t,i?e.bZ(this.position[1]):this.position[1]),n=this.forward();return(r-this.position[2])/n[2]}clone(){return new tn([...this.position],[...this.orientation])}}const rn=(e,t)=>({u_matrix:e,u_ground_shadow_factor:t});class nn{constructor(e=0,t=0,i=0,r=0){if(isNaN(e)||e<0||isNaN(t)||t<0||isNaN(i)||i<0||isNaN(r)||r<0)throw new Error("Invalid value for edge-insets, top, bottom, left and right must all be numbers");this.top=e,this.bottom=t,this.left=i,this.right=r}interpolate(t,i,r){return null!=i.top&&null!=t.top&&(this.top=e.aj(t.top,i.top,r)),null!=i.bottom&&null!=t.bottom&&(this.bottom=e.aj(t.bottom,i.bottom,r)),null!=i.left&&null!=t.left&&(this.left=e.aj(t.left,i.left,r)),null!=i.right&&null!=t.right&&(this.right=e.aj(t.right,i.right,r)),this}getCenter(t,i){const r=e.aB((this.left+t-this.right)/2,0,t),n=e.aB((this.top+i-this.bottom)/2,0,i);return new e.P(r,n)}equals(e){return this.top===e.top&&this.bottom===e.bottom&&this.left===e.left&&this.right===e.right}clone(){return new nn(this.top,this.bottom,this.left,this.right)}toJSON(){return{top:this.top,bottom:this.bottom,left:this.left,right:this.right}}}const on=15;class sn{constructor(t,i,r,n,o,s,a){this.tileSize=512,this._renderWorldCopies=void 0===o||o,this._minZoom=t||0,this._maxZoom=i||22,this._minPitch=r??0,this._maxPitch=n??60,this.setProjection(s),this.setMaxBounds(a),this.width=0,this.height=0,this._center=new e.aX(0,0),this.zoom=0,this.angle=0,this._fov=.6435011087932844,this._pitch=0,this._nearZ=0,this._farZ=0,this._nearClipOffset=0,this._unmodified=!0,this._edgeInsets=new nn,this._projMatrixCache={},this._alignedProjMatrixCache={},this._fogTileMatrixCache={},this._expandedProjMatrixCache={},this._distanceTileDataCache={},this._camera=new tn,this._centerAltitude=0,this._averageElevation=0,this.cameraElevationReference="ground",this._pixelsPerMercatorPixel=1,this.globeRadius=0,this.globeCenterInViewSpace=[0,0,0],this._tileCoverLift=0,this.freezeTileCoverage=!1,this._horizonShift=.1,this._orthographicProjectionAtLowPitch=!1,this._allowWorldUnderZoom=!1,this.mercatorMatrix=new Float64Array(16),this.mercatorFogMatrix=new Float32Array(16),this.invProjMatrix=new Float64Array(16),this._expandedFarZProjMatrixBuf=new Float64Array(16),this.expandedFarZProjMatrix=this._expandedFarZProjMatrixBuf,this.starsProjMatrix=new Float32Array(16),this.skyboxMatrix=new Float32Array(16),this._mat4Scratch=new Float64Array(16),this.alignedProjMatrix=new Float64Array(16),this.labelPlaneMatrix=new Float32Array(16),this.glCoordMatrix=new Float32Array(16),this.pixelMatrix=new Float64Array(16),this.pixelMatrixInverse=new Float64Array(16)}clone(){const e=new sn(this._minZoom,this._maxZoom,this._minPitch,this.maxPitch,this._renderWorldCopies,this.getProjection(),this.maxBounds);return e._elevation=this._elevation,e._centerAltitude=this._centerAltitude,e._centerAltitudeValidForExaggeration=this._centerAltitudeValidForExaggeration,e.tileSize=this.tileSize,e.mercatorFromTransition=this.mercatorFromTransition,e.width=this.width,e.height=this.height,e.cameraElevationReference=this.cameraElevationReference,e._center=this._center,e._setZoom(this.zoom),e._seaLevelZoom=this._seaLevelZoom,e.angle=this.angle,e._fov=this._fov,e._pitch=this._pitch,e._nearZ=this._nearZ,e._farZ=this._farZ,e._nearClipOffset=this._nearClipOffset,e._averageElevation=this._averageElevation,e._orthographicProjectionAtLowPitch=this._orthographicProjectionAtLowPitch,e._unmodified=this._unmodified,e._edgeInsets=this._edgeInsets.clone(),e._camera=this._camera.clone(),e._calcMatrices(),e.freezeTileCoverage=this.freezeTileCoverage,e.frustumCorners=this.frustumCorners,e._allowWorldUnderZoom=this._allowWorldUnderZoom,e}get isOrthographic(){return"globe"!==this.projection.name&&this._orthographicProjectionAtLowPitch&&this.pitch<on}get elevation(){return this._elevation}set elevation(e){this._elevation!==e&&(this._elevation=e,this._updateCameraOnTerrain(),this._calcMatrices())}get nearClipOffset(){return this._nearClipOffset}set nearClipOffset(e){this._nearClipOffset=e,this._calcMatrices()}get depthOcclusionForSymbolsAndCircles(){return"globe"!==this.projection.name&&!this.isOrthographic}updateElevation(e,t=!1){const i=this._elevation&&this._elevation.exaggeration()!==this._centerAltitudeValidForExaggeration;(null==this._seaLevelZoom||i)&&this._updateCameraOnTerrain(),(e||i)&&this._constrainCamera(t),this._calcMatrices()}getProjection(){return e.aK(this.projection,["name","center","parallels"])}setProjection(t){this.projectionOptions=t||{name:"mercator"};const i=this.projection?this.getProjection():void 0;this.projection=e.c4(this.projectionOptions);const r=this.getProjection(),n=!e.b9(i,r);return n&&this._calcMatrices(),this.mercatorFromTransition=!1,n}setOrthographicProjectionAtLowPitch(e){return this._orthographicProjectionAtLowPitch!==e&&(this._orthographicProjectionAtLowPitch=e,this._calcMatrices(),!0)}setMercatorFromTransition(){const t=this.projection.name;this.mercatorFromTransition=!0,this.projectionOptions={name:"mercator"},this.projection=e.c4({name:"mercator"});const i=t!==this.projection.name;return i&&this._calcMatrices(),i}get minZoom(){return this._minZoom}set minZoom(e){this._minZoom!==e&&(this._minZoom=e,this.zoom=Math.max(this.zoom,e))}get maxZoom(){return this._maxZoom}set maxZoom(e){this._maxZoom!==e&&(this._maxZoom=e,this.zoom=Math.min(this.zoom,e))}get minPitch(){return this._minPitch}set minPitch(e){this._minPitch!==e&&(this._minPitch=e,this.pitch=Math.max(this.pitch,e))}get maxPitch(){return this._maxPitch}set maxPitch(e){this._maxPitch!==e&&(this._maxPitch=e,this.pitch=Math.min(this.pitch,e))}get renderWorldCopies(){return this._renderWorldCopies&&!0===this.projection.supportsWorldCopies}set renderWorldCopies(e){void 0===e?e=!0:null===e&&(e=!1),this._renderWorldCopies=e}get worldSize(){return this.tileSize*this.scale}get cameraWorldSizeForFog(){const e=Math.max(this._camera.getDistanceToElevation(this._averageElevation),Number.EPSILON);return this._worldSizeFromZoom(this._zoomFromMercatorZ(e))}get cameraWorldSize(){const e=Math.max(this._camera.getDistanceToElevation(this._averageElevation,!0),Number.EPSILON);return this._worldSizeFromZoom(this._zoomFromMercatorZ(e))}get pixelsPerMeter(){return this.projection.pixelsPerMeter(this.center.lat,this.worldSize)}get cameraPixelsPerMeter(){return e.bY(1,this.center.lat)*this.cameraWorldSizeForFog}get centerOffset(){return this.centerPoint._sub(this.size._div(2))}get size(){return new e.P(this.width,this.height)}get bearing(){return e.bv(this.rotation,-180,180)}set bearing(e){this.rotation=e}get rotation(){return-this.angle/Math.PI*180}set rotation(e){const t=-e*Math.PI/180;if(this.angle===t)return;this._unmodified=!1,this.angle=t,this._calcMatrices();const i=Math.sin(this.angle),r=Math.cos(this.angle);this.rotationMatrix=[r,i,-i,r]}get pitch(){return this._pitch/Math.PI*180}set pitch(t){const i=e.aB(t,this.minPitch,this.maxPitch)/180*Math.PI;this._pitch!==i&&(this._unmodified=!1,this._pitch=i,this._calcMatrices())}get aspect(){return this.width/this.height}get fov(){return this._fov/Math.PI*180}set fov(t){t=Math.max(.01,Math.min(60,t)),this._fov!==t&&(this._unmodified=!1,this._fov=e.am(t),this._calcMatrices())}get fovX(){return this._fov}get fovY(){const e=1/Math.tan(.5*this.fovX);return 2*Math.atan(1/this.aspect/e)}get averageElevation(){return this._averageElevation}set averageElevation(e){this._averageElevation=e,this._calcFogMatrices(),this._distanceTileDataCache={}}get zoom(){return this._zoom}set zoom(e){const t=Math.min(Math.max(e,this.minZoom),this.maxZoom);this._zoom!==t&&(this._unmodified=!1,this._setZoom(t),this._updateSeaLevelZoom(),this._constrain(),this._calcMatrices())}_setZoom(e){this._zoom=e,this.scale=this.zoomScale(e),this.tileZoom=Math.floor(e),this.zoomFraction=e-this.tileZoom}get tileCoverLift(){return this._tileCoverLift}set tileCoverLift(e){this._tileCoverLift!==e&&(this._tileCoverLift=e)}_updateCameraOnTerrain(){const e=this.elevation?this.elevation.getAtPoint(this.locationCoordinate(this.center),Number.NEGATIVE_INFINITY):Number.NEGATIVE_INFINITY,t=this.elevation&&e===Number.NEGATIVE_INFINITY&&this.elevation.visibleDemTiles.length>0&&this.elevation.exaggeration()>0&&this._centerAltitudeValidForExaggeration;if(!this._elevation||e===Number.NEGATIVE_INFINITY&&(!t||!this._centerAltitude))return this._centerAltitude=0,this._seaLevelZoom=null,void(this._centerAltitudeValidForExaggeration=void 0);const i=this._elevation;t||this._centerAltitude&&this._centerAltitudeValidForExaggeration&&i.exaggeration()&&this._centerAltitudeValidForExaggeration!==i.exaggeration()?(this._centerAltitude=this._centerAltitude/this._centerAltitudeValidForExaggeration*i.exaggeration(),this._centerAltitudeValidForExaggeration=i.exaggeration()):(this._centerAltitude=e||0,this._centerAltitudeValidForExaggeration=i.exaggeration()),this._updateSeaLevelZoom()}_updateSeaLevelZoom(){if(void 0===this._centerAltitudeValidForExaggeration)return;const e=Math.max(0,(this.pixelsPerMeter*this._centerAltitude+this.cameraToCenterDistance)/this.worldSize);this._seaLevelZoom=this._zoomFromMercatorZ(e)}sampleAverageElevation(){if(!this._elevation)return 0;const t=this._elevation,i=[[.5,.2],[.3,.5],[.5,.5],[.7,.5],[.5,.8]],r=this.horizonLineFromTop();let n=0,o=0;for(let s=0;s<i.length;s++){const a=new e.P(i[s][0]*this.width,r+i[s][1]*(this.height-r)),l=t.pointCoordinate(a);if(!l)continue;const c=1/Math.hypot(l[0]-this._camera.position[0],l[1]-this._camera.position[1]);n+=l[3]*c,o+=c}return 0===o?NaN:n/o}get center(){return this._center}set center(e){e.lat===this._center.lat&&e.lng===this._center.lng||(this._unmodified=!1,this._center=e,this._terrainEnabled()&&("ground"===this.cameraElevationReference?this._updateCameraOnTerrain():this._updateZoomFromElevation()),this._constrain(),this._calcMatrices())}_updateZoomFromElevation(){if(null==this._seaLevelZoom||!this._elevation)return;const e=this._seaLevelZoom,t=this._elevation.getAtPointOrZero(this.locationCoordinate(this.center)),i=this.pixelsPerMeter/this.worldSize*t,r=this._mercatorZfromZoom(e),n=this._mercatorZfromZoom(this._maxZoom),o=Math.max(r-i,n);this._setZoom(this._zoomFromMercatorZ(o))}get padding(){return this._edgeInsets.toJSON()}set padding(e){this._edgeInsets.equals(e)||(this._unmodified=!1,this._edgeInsets.interpolate(this._edgeInsets,e,1),this._calcMatrices())}equals(e){const t=this.elevation,i=e.elevation,r=null!=t!=(null!=i)||t&&i&&t.exaggeration()!==i.exaggeration();return this.width===e.width&&this.height===e.height&&this.center.lng===e.center.lng&&this.center.lat===e.center.lat&&this.zoom===e.zoom&&this.bearing===e.bearing&&this.pitch===e.pitch&&this.fov===e.fov&&this.projection.name===e.projection.name&&this._edgeInsets.equals(e.padding)&&!r}computeZoomRelativeTo(t){const i=this.rayIntersectionCoordinate(this.pointRayIntersection(this.centerPoint,t.toAltitude()));let r;r=t.z<this._camera.position[2]?[i.x,i.y,i.z]:[t.x,t.y,t.z];const n=e.af(e.aw([],this._camera.position,r));return e.aB(this._zoomFromMercatorZ(n),this._minZoom,this._maxZoom)}setFreeCameraOptions(t){if(!this.height)return;if(!t.position&&!t.orientation)return;this._updateCameraState();let i=!1;if(t.orientation&&!e.c5(t.orientation,this._camera.orientation)&&(i=this._setCameraOrientation(t.orientation)),t.position){const r=[t.position.x,t.position.y,t.position.z];e.c6(r,this._camera.position)||(this._setCameraPosition(r),i=!0)}i&&(this._updateStateFromCamera(),this.recenterOnTerrain())}getFreeCameraOptions(){this._updateCameraState();const t=this._camera.position,i=new en;return i.position=new e.ad(t[0],t[1],t[2]),i.orientation=this._camera.orientation,i._elevation=this.elevation,i._renderWorldCopies=this.renderWorldCopies,i}_setCameraOrientation(t){if(!e.c7(t))return!1;e.c8(t,t);const i=e.c9([],[0,0,-1],t),r=e.c9([],[0,-1,0],t);if(r[2]<0)return!1;const n=Qr(i,r);return!!n&&(this._camera.orientation=n,!0)}_setCameraPosition(t){const i=this.zoomScale(this.minZoom)*this.tileSize,r=this.zoomScale(this.maxZoom)*this.tileSize,n=this.cameraToCenterDistance;t[2]=e.aB(t[2],n/r,n/i),this._camera.position=t}get centerPoint(){return this._edgeInsets.getCenter(this.width,this.height)}get fovAboveCenter(){return this._fov*(.5+this.centerOffset.y/this.height)}isPaddingEqual(e){return this._edgeInsets.equals(e)}interpolatePadding(e,t,i){this._unmodified=!1,this._edgeInsets.interpolate(e,t,i),this._constrain(),this._calcMatrices()}coveringZoomLevel(e){const t=(e.roundZoom?Math.round:Math.floor)(this.zoom+this.scaleZoom(this.tileSize/e.tileSize));return Math.max(0,t)}getVisibleUnwrappedCoordinates(t){const i=[new e.ca(0,t)];if(this.renderWorldCopies){const r=this.pointCoordinate(new e.P(0,0)),n=this.pointCoordinate(new e.P(this.width,0)),o=this.pointCoordinate(new e.P(this.width,this.height)),s=this.pointCoordinate(new e.P(0,this.height)),a=Math.floor(Math.min(r.x,n.x,o.x,s.x)),l=Math.floor(Math.max(r.x,n.x,o.x,s.x)),c=1;for(let h=a-c;h<=l+c;h++)0!==h&&i.push(new e.ca(h,t))}return i}isLODDisabled(e){return(!e||this.pitch<=60)&&this._edgeInsets.top<=this._edgeInsets.bottom&&!this._elevation&&!this.projection.isReprojectedInTileSpace}extendTileCover(t,i,r,n){let o=[];const s=null!=r,a=!s;if(a&&this.zoom<i)return o;if(s&&0===r[0]&&0===r[1])return o;const l=/* @__PURE__ */new Set,c=(t,i,r,n,s)=>{const a=e.cm(i,t,r,n,s);l.has(a)||(o.push(new e.aU(t,i,r,n,s)),l.add(a))};for(let e=0;e<t.length;e++){const o=t[e];if(a&&o.canonical.z!==i)continue;if(s&&void 0!==n&&n>o.canonical.z)continue;const l=o.canonical,h=o.overscaledZ,u=o.wrap,d=1<<l.z,p=l.x+1<d,f=l.x>0,m=l.y+1<d,_=l.y>0,g=o.wrap-(f?0:1),y=o.wrap+(p?0:1),x=f?l.x-1:d-1,v=p?l.x+1:0;if(s)r[0]<0?(c(h,y,l.z,v,l.y),r[1]<0&&m&&(c(h,u,l.z,l.x,l.y+1),c(h,y,l.z,v,l.y+1)),r[1]>0&&_&&(c(h,u,l.z,l.x,l.y-1),c(h,y,l.z,v,l.y-1))):r[0]>0?(c(h,g,l.z,x,l.y),r[1]<0&&m&&(c(h,u,l.z,l.x,l.y+1),c(h,g,l.z,x,l.y+1)),r[1]>0&&_&&(c(h,u,l.z,l.x,l.y-1),c(h,g,l.z,x,l.y-1))):r[1]<0&&m?c(h,u,l.z,l.x,l.y+1):_&&c(h,u,l.z,l.x,l.y-1);else{const e=o.visibleQuadrants;1&e&&(c(h,g,l.z,x,l.y),_&&(c(h,u,l.z,l.x,l.y-1),c(h,g,l.z,x,l.y-1))),2&e&&(c(h,y,l.z,v,l.y),_&&(c(h,u,l.z,l.x,l.y-1),c(h,y,l.z,v,l.y-1))),4&e&&(c(h,g,l.z,x,l.y),m&&(c(h,u,l.z,l.x,l.y+1),c(h,g,l.z,x,l.y+1))),8&e&&(c(h,y,l.z,v,l.y),m&&(c(h,u,l.z,l.x,l.y+1),c(h,y,l.z,v,l.y+1)))}}const h=[];for(const e of o)o.some(t=>e.isChildOf(t))||h.push(e);if(o=h.filter(e=>!t.some(t=>!!(e.overscaledZ<i&&t.isChildOf(e))||e.equals(t)||e.isChildOf(t))),a){const e=1<<i,t="globe"===this.projection.name?this._camera.mercatorPosition:this.pointCoordinate(this.getCameraPoint()),r=[e*t.x,e*t.y],n=4,s=n*n;o=o.filter(e=>{const t=e.canonical.x+.5-r[0],i=e.canonical.y+.5-r[1];return t*t+i*i<s})}return o}extendTileCoverToNearPlane(t,i,r){const n=[],o=/* @__PURE__ */new Set;for(const e of t)o.add(e.key);const s=(t,i,r,s,a)=>{const l=e.cm(i,t,r,s,a);o.has(l)||(n.push(new e.aU(t,i,r,s,a)),o.add(l))},a=t.reduce((e,t)=>Math.max(e,t.overscaledZ),r),l=1<<r,c=[new e.P(0,0),new e.P(e.ak,0),new e.P(e.ak,e.ak),new e.P(0,e.ak)],h=new e.P(0,0),u=new e.P(0,0),d=(t,i)=>{const n=Math.floor(t[0]),o=Math.floor(t[1]),d=(t[0]-n)*e.ak,p=(t[1]-o)*e.ak,f=Math.floor(i[0]),m=Math.floor(i[1]),_=(i[0]-f)*e.ak,g=(i[1]-m)*e.ak;for(let y=-1;y<=1;y++){const t=n+y;if(!(t<0||t>=l)){h.x=d-y*e.ak,u.x=_-(t-f)*e.ak;for(let i=-1;i<=1;i++){const n=o+i;h.y=p-i*e.ak,u.y=g-(n-m)*e.ak,e.cM(h,u,c)&&s(a,0,r,t,n)}}}},p=i.points,f=p[e.cb],m=p[e.cc],_=this._projectToGround(f,p[e.cd]),g=this._projectToGround(m,p[e.ce]);return d(f,_),d(m,g),n}_projectToGround(t,i){return e.cf(e.cg(),t,i,t[2]/(t[2]-i[2]))}_projectToZ(t,i,r){const n=t[2]-i[2];return Math.abs(n)<1e-6?e.ch(t):e.cf(e.cg(),t,i,(t[2]-r)/n)}extendTileCoverForTunnels(t,i,r,n){if(r<18)return[];const o=i.points,s=o[e.ci],a=o[e.cj],l=o[e.ck],c=o[e.cl];if(l[2]>=0&&c[2]>=0||s[2]<=0||a[2]<=0)return[];const h=l[2]<0?this._projectToZ(s,l,0):l,u=c[2]<0?this._projectToZ(a,c,0):c,d=-n,p=l[2]<d?this._projectToZ(s,l,d):l,f=c[2]<d?this._projectToZ(a,c,d):c,m=this._findExtensionTilesInQuad(t,r,[f,p,u,h],[.5*(h[0]+u[0]),.5*(h[1]+u[1])]);return m.length>3&&(m.length=3),m}_findExtensionTilesInQuad(t,i,r,n){const o=[],s=/* @__PURE__ */new Set;for(const e of t)s.add(e.key);const a=t.reduce((e,t)=>Math.max(e,t.overscaledZ),i),l=1<<i,c=[new e.P(r[0][0],r[0][1]),new e.P(r[1][0],r[1][1]),new e.P(r[3][0],r[3][1]),new e.P(r[2][0],r[2][1]),new e.P(r[0][0],r[0][1])],h=r[0][0],u=r[1][0],d=r[2][0],p=r[3][0],f=r[0][1],m=r[1][1],_=r[2][1],g=r[3][1],y=Math.max(0,Math.floor(Math.min(h,u,d,p))),x=Math.min(l-1,Math.ceil(Math.max(h,u,d,p))-1),v=Math.max(0,Math.floor(Math.min(f,m,_,g))),b=Math.min(l-1,Math.ceil(Math.max(f,m,_,g))-1);for(let S=v;S<=b;S++)for(let t=y;t<=x;t++){if(!e.au(c,t,S,t+1,S+1))continue;const r=e.cm(0,a,i,t,S);s.has(r)||(o.push(new e.aU(a,0,i,t,S)),s.add(r))}const w=n[0],T=n[1];return o.sort((e,t)=>{const i=e.canonical.x+.5-w,r=e.canonical.y+.5-T,n=t.canonical.x+.5-w,o=t.canonical.y+.5-T;return i*i+r*r-(n*n+o*o)||e.canonical.x-t.canonical.x||e.canonical.y-t.canonical.y}),o}coveringTiles(t){let i=this.coveringZoomLevel(t);const r=i,n=this.elevation&&this.elevation.exaggeration(),o=n&&!t.isTerrainDEM,s="mercator"===this.projection.name;if(void 0!==t.minzoom&&i<t.minzoom)return[];void 0!==t.maxzoom&&i>t.maxzoom&&(i=t.maxzoom);const a=this.locationCoordinate(this.center),l=this.center.lat,c=1<<i,h=[c*a.x,c*a.y,0],u="globe"===this.projection.name,d=!u,p=e.cn.fromInvProjectionMatrix(this.invProjMatrix,this.worldSize,i,d),f=u?this._camera.mercatorPosition:this.pointCoordinate(this.getCameraPoint()),m=c*e.bY(1,this.center.lat),_=this._camera.position[2]/e.bY(1,this.center.lat),g=[c*f.x,c*f.y,_*(d?1:m)],y=u||n,x=this.cameraToCenterDistance/t.tileSize*(t.roundZoom?1:.502),v=this.isLODDisabled(!0)?i:0;let b;if(this._elevation&&t.isTerrainDEM)b=1e4*this._elevation.exaggeration();else if(this._elevation){const e=this._elevation.getMinMaxForVisibleTiles();b=e?e.max:this._centerAltitude}else b=this._centerAltitude;const w=t.isTerrainDEM?-b:this._elevation?this._elevation.getMinElevationBelowMSL():0,T=this.projection.isReprojectedInTileSpace?e.co(this):1,S=t=>{const i=1/4e4,r=new e.ad(t.x+i,t.y,t.z),n=new e.ad(t.x,t.y+i,t.z),o=t.toLngLat(),s=r.toLngLat(),a=n.toLngLat(),l=this.locationCoordinate(o),c=this.locationCoordinate(s),h=this.locationCoordinate(a),u=Math.hypot(c.x-l.x,c.y-l.y),d=Math.hypot(h.x-l.x,h.y-l.y);return Math.sqrt(u*d)*T/i},I=t=>{const i=b,r=w;return{aabb:e.cr(this,c,0,0,0,t,r,i,this.projection),zoom:0,x:0,y:0,minZ:r,maxZ:i,wrap:t,fullyVisible:!1}},E=[];let A=[];const M=i,C=t.reparseOverscaled?r:i,P=(_-this._centerAltitude)*m,D=e=>{if(!this._elevation||!e.tileID||!s)return;const t=this._elevation.getMinMaxForTile(e.tileID),i=e.aabb;t?(i.min[2]=t.min,i.max[2]=t.max,i.center[2]=(i.min[2]+i.max[2])/2):(e.shouldSplit=z(e),e.shouldSplit||(i.min[2]=i.max[2]=i.center[2]=this._centerAltitude))},R=(e,t)=>{if(.707*t<e)return 1;const i=t/e;return i/(1.4144271570014144+(Math.pow(1.1,i-1.4144271570014144+1)-1)/.10000000000000009-1)},z=t=>{if(t.zoom<v)return!0;if(t.zoom===M)return!1;if(null!=t.shouldSplit)return t.shouldSplit;const i=t.aabb.distanceX(g),n=t.aabb.distanceY(g);let a=P,c=1;if(u){a=t.aabb.distanceZ(g);const i=Math.pow(2,t.zoom),r=e.bZ((t.y+1)/i),n=e.bZ(t.y/i),o=Math.min(Math.max(l,r),n),s=e.cQ(o)/e.cQ(l);if(c=o===l?1/Math.max(1,this._mercatorScaleRatio-.3):Math.min(1,s/this._mercatorScaleRatio),this.zoom<=e.cN&&t.zoom===M-1&&s>=.9)return!0}else if(o&&(a=t.aabb.distanceZ(g)*m),this.projection.isReprojectedInTileSpace&&r<=5){const i=Math.pow(2,t.zoom),r=S(new e.ad((t.x+.5)/i,(t.y+.5)/i));c=r>.85?1:r}if(!s&&!u){const e=Math.sqrt(i*i+n*n+a*a);let r=(1<<M-t.zoom)*x*c;return r*=R(Math.max(a,P),e),e<r}let d=Number.MAX_VALUE,p=0;const f=t.aabb.getCorners(),_=[0,0,0];for(const r of f){e.aw(_,r,g),u||(o?_[2]*=m:_[2]=P);const t=e.bk(_,this._camera.forward());t<d&&(d=t,p=Math.abs(_[2]))}let y=(1<<M-t.zoom)*x*c;if(y*=R(Math.max(p,P),d),d<y)return!0;const b=t.aabb.closestPoint(h);return b[0]===h[0]&&b[1]===h[1]};if(this.renderWorldCopies)for(let e=1;e<=3;e++)E.push(I(-e)),E.push(I(e));for(E.push(I(0));E.length>0;){const r=E.pop(),n=r.x,a=r.y;let l=r.fullyVisible;const d=()=>"globe"===this.projection.name&&(0===r.y||r.y===(1<<r.zoom)-1);if(!l){let t=y?r.aabb.intersects(p):r.aabb.intersectsFlat(p);if(0===t&&d()){const i=new e.cp(r.zoom,n,a);t=e.cq(this,c,i,!0).intersects(p)}if(0===t)continue;l=2===t}if(r.zoom===M||!z(r)){const o=r.zoom===M?C:r.zoom;if(t.minzoom&&t.minzoom>o)continue;let s=0;if(!l){let i=y?r.aabb.intersectsPrecise(p):r.aabb.intersectsPreciseFlat(p);if(0===i&&d()){const t=new e.cp(r.zoom,n,a);i=e.cq(this,c,t,!0).intersectsPrecise(p)}if(0===i)continue;if(t.calculateQuadrantVisibility)if(p.containsPoint(r.aabb.center))s=15;else for(let e=0;e<4;e++)0!==r.aabb.quadrant(e).intersects(p)&&(s|=1<<e)}const u=h[0]-(.5+n+(r.wrap<<r.zoom))*(1<<i-r.zoom),f=h[1]-.5-a,m=r.tileID?r.tileID:new e.aU(o,r.wrap,r.zoom,n,a);t.calculateQuadrantVisibility&&(m.visibleQuadrants=s),A.push({tileID:m,distanceSq:u*u+f*f});continue}for(let t=0;t<4;t++){const i=(n<<1)+t%2,h=(a<<1)+(t>>1),d={aabb:s?r.aabb.quadrant(t):e.cr(this,c,r.zoom+1,i,h,r.wrap,r.minZ,r.maxZ,this.projection),zoom:r.zoom+1,x:i,y:h,wrap:r.wrap,fullyVisible:l,tileID:void 0,shouldSplit:void 0,minZ:r.minZ,maxZ:r.maxZ};o&&!u&&(d.tileID=new e.aU(r.zoom+1===M?C:r.zoom+1,r.wrap,r.zoom+1,i,h),D(d)),E.push(d)}}if(this.fogCullDistSq){const i=this.fogCullDistSq,r=this.horizonLineFromTop();A=A.filter(n=>{const o=[0,0,0,1],s=[e.ak,e.ak,0,1],a=this.calculateFogTileMatrix(n.tileID.toUnwrapped());e.aD(o,o,a),e.aD(s,s,a);const l=e.cs([],o,s),c=e.ct([],o,s),h=e.cO(l,c);if(0===h)return!0;let u=!1;const d=this._elevation;if(d&&h>i&&0!==r){const i=this.calculateProjMatrix(n.tileID.toUnwrapped());let o;t.isTerrainDEM||(o=d.getMinMaxForTile(n.tileID)),o||(o={min:w,max:b});const s=e.cu(this.rotation),a=[s[0]*e.ak,s[1]*e.ak,o.max];e.ae(a,a,i),u=(1-a[1])*this.height*.5<r}return h<i||u})}return A.sort((e,t)=>e.distanceSq-t.distanceSq).map(e=>e.tileID)}resize(e,t){this.width=e,this.height=t,this.pixelsToGLUnits=[2/e,-2/t],this._constrain(),this._calcMatrices()}get unmodified(){return this._unmodified}zoomScale(e){return Math.pow(2,e)}scaleZoom(e){return Math.log2(e)}project(t){const i=e.aB(t.lat,-e.cv,e.cv),r=this.projection.project(t.lng,i);return new e.P(r.x*this.worldSize,r.y*this.worldSize)}unproject(e){return this.projection.unproject(e.x/this.worldSize,e.y/this.worldSize)}get point(){return this.project(this.center)}get pointMerc(){return this.point._div(this.worldSize)}get pixelsPerMeterRatio(){return this.pixelsPerMeter/e.bY(1,this.center.lat)/this.worldSize}setLocationAtPoint(t,i){let r,n;const o=this.centerPoint;if("globe"===this.projection.name){const e=this.worldSize;r=(i.x-o.x)/e,n=(i.y-o.y)/e}else{const e=this.pointCoordinate(i),t=this.pointCoordinate(o);r=e.x-t.x,n=e.y-t.y}const s=this.locationCoordinate(t);this.setLocation(new e.ad(s.x-r,s.y-n))}setLocation(e){this.center=this.coordinateLocation(e),this.projection.wrap&&(this.center=this.center.wrap())}locationPoint(e,t){return this.projection.locationPoint(this,e,t)}locationPoint3D(e,t){return this.projection.locationPoint(this,e,t,!0)}pointLocation(e){return this.coordinateLocation(this.pointCoordinate(e))}pointLocation3D(e,t){return this.coordinateLocation(this.pointCoordinate3D(e,t))}locationCoordinate(t,i){const r=i?e.bY(i,t.lat):void 0,n=this.projection.project(t.lng,t.lat);return new e.ad(n.x,n.y,r)}coordinateLocation(e){return this.projection.unproject(e.x,e.y)}pointRayIntersection(t,i){const r=null!=i?i:this._centerAltitude,n=[t.x,t.y,0,1],o=[t.x,t.y,1,1];e.aD(n,n,this.pixelMatrixInverse),e.aD(o,o,this.pixelMatrixInverse);const s=o[3];e.cw(n,n,1/n[3]),e.cw(o,o,1/s);const a=n[2],l=o[2];return{p0:n,p1:o,t:a===l?0:(r-a)/(l-a)}}screenPointToMercatorRay(t){const i=[t.x,t.y,0,1],r=[t.x,t.y,1,1];return e.aD(i,i,this.pixelMatrixInverse),e.aD(r,r,this.pixelMatrixInverse),e.cw(i,i,1/i[3]),e.cw(r,r,1/r[3]),i[2]=e.bY(i[2],this._center.lat)*this.worldSize,r[2]=e.bY(r[2],this._center.lat)*this.worldSize,e.cw(i,i,1/this.worldSize),e.cw(r,r,1/this.worldSize),new e.ay([i[0],i[1],i[2]],e.ax([],e.aw([],r,i)))}rayIntersectionCoordinate(t){const{p0:i,p1:r,t:n}=t,o=e.bY(i[2],this._center.lat),s=e.bY(r[2],this._center.lat);return new e.ad(e.aj(i[0],r[0],n)/this.worldSize,e.aj(i[1],r[1],n)/this.worldSize,e.aj(o,s,n))}pointCoordinate(e,t=this._centerAltitude){return this.projection.pointCoordinate(this,e.x,e.y,t)}pointCoordinate3D(t,i){if(!this.elevation)return this.pointCoordinate(t,i);let r=this.projection.pointCoordinate3D(this,t.x,t.y);if(r)return new e.ad(r[0],r[1],r[2]);let n=0,o=this.horizonLineFromTop();if(t.y>o)return this.pointCoordinate(t,i);const s=.02*o,a=t.clone();for(let l=0;l<10&&o-n>s;l++){a.y=e.aj(n,o,.66);const t=this.projection.pointCoordinate3D(this,a.x,a.y);t?(o=a.y,r=t):n=a.y}return r?new e.ad(r[0],r[1],r[2]):this.pointCoordinate(t)}isPointAboveHorizon(e){return this.projection.isPointAboveHorizon(this,e)}isPointOnSurface(t){if(t.y<0||t.y>this.height||t.x<0||t.x>this.width)return!1;if(this.elevation||this.zoom>=e.cx)return!this.isPointAboveHorizon(t);const i=this.pointCoordinate(t);return i.y>=0&&i.y<=1}_coordinatePoint(t,i){const r=i&&this.elevation?this.elevation.getAtPointOrZero(t,this._centerAltitude):this._centerAltitude,n=[t.x*this.worldSize,t.y*this.worldSize,r+t.toAltitude(),1];return e.aD(n,n,this.pixelMatrix),n[3]>0?new e.P(n[0]/n[3],n[1]/n[3]):new e.P(Number.MAX_VALUE,Number.MAX_VALUE)}_getBoundsNonRectangular(){const{top:t,left:i}=this._edgeInsets,r=this.height-this._edgeInsets.bottom,n=this.width-this._edgeInsets.right,o=this.pointLocation3D(new e.P(i,t)),s=this.pointLocation3D(new e.P(n,t)),a=this.pointLocation3D(new e.P(n,r)),l=this.pointLocation3D(new e.P(i,r));let c=Math.min(o.lng,s.lng,a.lng,l.lng),h=Math.max(o.lng,s.lng,a.lng,l.lng),u=Math.min(o.lat,s.lat,a.lat,l.lat),d=Math.max(o.lat,s.lat,a.lat,l.lat);const p=Math.pow(2,-this.zoom)/16*270,f="globe"===this.projection.name?1:4,m=(t,i,r,n,o)=>{const s=(t+r)/2,a=(i+n)/2,l=new e.P(s,a),{lng:_,lat:g}=this.pointLocation3D(l),y=Math.max(0,c-_,u-g,_-h,g-d);c=Math.min(c,_),h=Math.max(h,_),u=Math.min(u,g),d=Math.max(d,g),(o<f||y>p)&&(m(t,i,s,a,o+1),m(s,a,r,n,o+1))};if(m(i,t,n,t,1),m(n,t,n,r,1),m(n,r,i,r,1),m(i,r,i,t,1),"globe"===this.projection.name){const[t,i]=e.cy(this);t?(d=90,h=180,c=-180):i&&(u=-90,h=180,c=-180)}return new e.aI(new e.aX(c,u),new e.aX(h,d))}_getBoundsRectangular(t,i){const{top:r,left:n}=this._edgeInsets,o=this.height-this._edgeInsets.bottom,s=this.width-this._edgeInsets.right,a=new e.P(n,r),l=new e.P(s,r),c=new e.P(s,o),h=new e.P(n,o);let u=this.pointCoordinate(a,t),d=this.pointCoordinate(l,t);const p=this.pointCoordinate(c,i),f=this.pointCoordinate(h,i),m=(e,t)=>(t.y-e.y)/(t.x-e.x);return u.y>1&&d.y>=0?u=new e.ad((1-f.y)/m(f,u)+f.x,1):u.y<0&&d.y<=1&&(u=new e.ad(-f.y/m(f,u)+f.x,0)),d.y>1&&u.y>=0?d=new e.ad((1-p.y)/m(p,d)+p.x,1):d.y<0&&u.y<=1&&(d=new e.ad(-p.y/m(p,d)+p.x,0)),(new e.aI).extend(this.coordinateLocation(u)).extend(this.coordinateLocation(d)).extend(this.coordinateLocation(f)).extend(this.coordinateLocation(p))}_getBoundsRectangularTerrain(){const e=this.elevation;if(!e.visibleDemTiles.length||e.isUsingMockSource())return this._getBoundsRectangular(0,0);const t=e.visibleDemTiles.reduce((e,t)=>{if(t.dem){const i=t.dem.tree;e.min=Math.min(e.min,i.minimums[0]),e.max=Math.max(e.max,i.maximums[0])}return e},{min:Number.MAX_VALUE,max:0});return this._getBoundsRectangular(t.min*e.exaggeration(),t.max*e.exaggeration())}getBounds(){return"mercator"===this.projection.name||"equirectangular"===this.projection.name?this._terrainEnabled()?this._getBoundsRectangularTerrain():this._getBoundsRectangular(0,0):this._getBoundsNonRectangular()}horizonLineFromTop(e=!0){const t=this.height/2/Math.tan(this._fov/2)/Math.tan(Math.max(this._pitch,.1))-this.centerOffset.y,i=this.height/2-t*(1-this._horizonShift);return e?Math.max(0,i):i}getMaxBounds(){return this.maxBounds}setMaxBounds(t){this.maxBounds=t,this.minLat=-e.cv,this.maxLat=e.cv,this.minLng=-180,this.maxLng=180,t&&(this.minLat=t.getSouth(),this.maxLat=t.getNorth(),this.minLng=t.getWest(),this.maxLng=t.getEast(),this.maxLng<this.minLng&&(this.maxLng+=360)),this.worldMinX=e.aG(this.minLng)*this.tileSize,this.worldMaxX=e.aG(this.maxLng)*this.tileSize,this.worldMinY=e.aJ(this.maxLat)*this.tileSize,this.worldMaxY=e.aJ(this.minLat)*this.tileSize,this._constrain()}calculatePosMatrix(e,t){return this.projection.createTileMatrix(this,t,e)}calculateDistanceTileData(t){const i=t.key,r=this._distanceTileDataCache;if(r[i])return r[i];const n=t.canonical,o=1/this.height,s=this.cameraWorldSize,a=s/this.zoomScale(n.z),l=(n.x+Math.pow(2,n.z)*t.wrap)*a,c=n.y*a,h=this.point;h.x*=s/this.worldSize,h.y*=s/this.worldSize;const u=this.angle;return r[i]={bearing:[Math.sin(-u),-Math.cos(-u)],center:[(h.x-l)*o,(h.y-c)*o],scale:a/e.ak*o},r[i]}calculateFogTileMatrix(t){const i=t.key,r=this._fogTileMatrixCache;if(r[i])return r[i];const n=this.projection.createTileMatrix(this,this.cameraWorldSizeForFog,t);return e.aC(n,this.worldToFogMatrix,n),r[i]=new Float32Array(n),r[i]}calculateProjMatrix(t,i=!1,r=!1){const n=t.key;let o;if(o=r?this._expandedProjMatrixCache:i?this._alignedProjMatrixCache:this._projMatrixCache,o[n])return o[n];const s=this.calculatePosMatrix(t,this.worldSize);let a;return a=this.projection.isReprojectedInTileSpace?this.mercatorMatrix:r?this.expandedFarZProjMatrix:i?this.alignedProjMatrix:this.projMatrix,e.aC(s,a,s),o[n]=new Float32Array(s),o[n]}calculatePixelsToTileUnitsMatrix(t){const i=t.tileID.key,r=this._pixelsToTileUnitsCache;return r[i]||(r[i]=e.cz(t,this)),r[i]}customLayerMatrix(){return this.mercatorMatrix.slice()}globeToMercatorMatrix(){if("globe"===this.projection.name){const t=1/this.worldSize,i=e.bT([],[t,t,t]);return e.aC(i,i,this.globeMatrix),i}}recenterOnTerrain(){if(!this._elevation||"globe"===this.projection.name)return;const t=this._elevation;this._updateCameraState();const i=e.bY(1,this._center.lat)*this.worldSize,r=this._computeCameraPosition(i),n=this._camera.forward(),o=e.bY(1,this._center.lat);r[2]/=o,n[2]/=o,e.ax(n,n);const s=t.raycast(r,n,t.exaggeration());if(s){const t=e.bi([],r,n,s),i=new e.ad(t[0],t[1],e.bY(t[2],e.bZ(t[1]))),a=(i.z+e.af([i.x-r[0],i.y-r[1],i.z-r[2]*o]))*this._pixelsPerMercatorPixel;this._seaLevelZoom=this._zoomFromMercatorZ(a),this._centerAltitude=i.toAltitude(),this._center=this.coordinateLocation(i),this._updateZoomFromElevation(),this._constrain(),this._calcMatrices()}}_constrainCamera(t=!1){if(!this._elevation)return;const i=this._elevation,r=e.bY(1,this._center.lat)*this.worldSize,n=this._computeCameraPosition(r),o=i.getAtPointOrZero(new e.ad(...n)),s=this.pixelsPerMeter/this.worldSize*o,a=this._minimumHeightOverTerrain(),l=n[2]-s;if(l<=a)if(l<0||t){const t=this.locationCoordinate(this._center,this._centerAltitude),i=[n[0],n[1],t.z-n[2]],r=e.af(i);i[2]-=(a-l)/this._pixelsPerMercatorPixel;const o=e.af(i);if(0===o)return;e.bN(i,i,r/o*this._pixelsPerMercatorPixel),this._camera.position=[n[0],n[1],t.z*this._pixelsPerMercatorPixel-i[2]],this._updateStateFromCamera()}else this._isCameraConstrained=!0}_constrain(){if(!this.center||!this.width||!this.height||this._constraining)return;this._constraining=!0;const t="globe"===this.projection.name||this.mercatorFromTransition;if(this.projection.isReprojectedInTileSpace||t){const i=this.center;return i.lat=e.aB(i.lat,this.minLat,this.maxLat),(this.maxBounds||!this.renderWorldCopies&&!t)&&(i.lng=e.aB(i.lng,this.minLng,this.maxLng)),this.center=i,void(this._constraining=!1)}const i=this._unmodified,{x:r,y:n}=this.point;let o=0,s=r,a=n;const l=this.width/2,c=this.height/2,h=this.worldMinY*this.scale,u=this.worldMaxY*this.scale;if(n-c<h&&(a=h+c),n+c>u&&(a=u-c),u-h<this.height&&(o=Math.max(o,this.height/(u-h)),a=(u+h)/2),this.maxBounds||!this._renderWorldCopies||!this.projection.wrap){const e=this.worldMinX*this.scale,t=this.worldMaxX*this.scale,i=this.worldSize/2-(e+t)/2;s=(r+i+this.worldSize)%this.worldSize-i,s-l<e&&(s=e+l),s+l>t&&(s=t-l),t-e<this.width&&(o=Math.max(o,this.width/(t-e)),s=(t+e)/2)}s===r&&a===n||this._allowWorldUnderZoom||(this.center=this.unproject(new e.P(s,a))),o&&!this._allowWorldUnderZoom&&(this.zoom+=this.scaleZoom(o)),this._constrainCamera(),this._unmodified=i,this._constraining=!1}_minZoomForBounds(){let e=Math.max(0,this.scaleZoom(Math.max(0,this.height)/(this.worldMaxY-this.worldMinY)));return this.maxBounds&&(e=Math.max(e,this.scaleZoom(this.width/(this.worldMaxX-this.worldMinX)))),e}_maxCameraBoundsDistance(){return this._mercatorZfromZoom(this._minZoomForBounds())}_calcMatrices(){if(!this.height)return;const t=this.centerOffset,i="globe"===this.projection.name,r=this.pixelsPerMeter;"globe"===this.projection.name&&(this._mercatorScaleRatio=e.bY(1,this.center.lat)/e.bY(1,e.cR));const n=e.cA(this.projection,this.zoom,this.width,this.height,1024);this._pixelsPerMercatorPixel=this.projection.pixelSpaceConversion(this.center.lat,this.worldSize,n),this.cameraToCenterDistance=.5/Math.tan(.5*this._fov)*this.height*this._pixelsPerMercatorPixel,this._updateCameraState(),this._farZ=this.projection.farthestPixelDistance(this),this._nearZ=this.height/50;const o="meters"===this.projection.zAxisUnit?r:1,s=this._camera.getWorldToCamera(this.worldSize,o);let a;const l=this._camera.getCameraToClipPerspective(this._fov,this.width/this.height,this._nearZ,this._farZ);if(l[8]=2*-t.x/this.width,l[9]=2*t.y/this.height,this.isOrthographic){let i=.5*this.height/Math.tan(this._fov/2)*1*Math.tan(.5*this._fov),r=i*this.aspect,n=-r,o=-i;r-=t.x,n-=t.x,i+=t.y,o+=t.y,a=this._camera.getCameraToClipOrthographic(n,r,o,i,this._nearZ+this._nearClipOffset,this._farZ),((t,i,r,n)=>{for(let o=0;o<16;o++)t[o]=e.aj(i[o],r[o],n)})(a,a,l,e.cP(this.pitch>=on?1:this.pitch/on))}else a=l;const c=e.cB([],l,s),h=e.cB([],a,s);if(this.projection.isReprojectedInTileSpace){const t=this.locationCoordinate(this.center);e.bA(this._mat4Scratch);const i=this._mat4Scratch;e.bB(i,i,[t.x*this.worldSize,t.y*this.worldSize,0]),e.aC(i,i,e.cC(this)),e.bB(i,i,[-t.x*this.worldSize,-t.y*this.worldSize,0]),e.aC(h,h,i),e.aC(c,c,i),this.inverseAdjustmentMatrix=e.cD(this)}else this.inverseAdjustmentMatrix=[1,0,0,1];if(e.cE(this.mercatorMatrix,h,[this.worldSize,this.worldSize,this.worldSize/o,1]),this.projMatrix=h,e.ba(this.invProjMatrix,this.projMatrix),i){const i=this._camera.getCameraToClipPerspective(this._fov,this.width/this.height,this._nearZ,1/0);i[8]=2*-t.x/this.width,i[9]=2*t.y/this.height,e.cB(this._expandedFarZProjMatrixBuf,i,s),this.expandedFarZProjMatrix=this._expandedFarZProjMatrixBuf}else this.expandedFarZProjMatrix=this.projMatrix;e.ba(this._mat4Scratch,a),this.frustumCorners=e.cF.fromInvProjectionMatrix(this._mat4Scratch,this.horizonLineFromTop(),this.height),this.cameraFrustum=e.cn.fromInvProjectionMatrix(this.invProjMatrix,this.worldSize,0,!i),e.bT(this.skyboxMatrix,[1,-1,1]),e.cG(this.skyboxMatrix,this.skyboxMatrix,this._pitch),e.bc(this.skyboxMatrix,this.skyboxMatrix,this.angle),e.bW(this.starsProjMatrix,this._fov,this.width/this.height,this._nearZ,this._farZ);const u=(Math.PI/2-this._pitch)*(this.height/this._fov)*this._horizonShift;e.cH(this._mat4Scratch,this.starsProjMatrix),this._mat4Scratch[8]=2*-t.x/this.width,this._mat4Scratch[9]=2*(t.y+u)/this.height,e.aC(this.skyboxMatrix,this._mat4Scratch,this.skyboxMatrix);const d=this.point,p=d.x,f=d.y,m=this.width%2/2,_=this.height%2/2,g=Math.cos(this.angle),y=Math.sin(this.angle),x=p-Math.round(p)+g*m+y*_,v=f-Math.round(f)+g*_+y*m;if(e.cH(this.alignedProjMatrix,h),e.bB(this.alignedProjMatrix,this.alignedProjMatrix,[x>.5?x-1:x,v>.5?v-1:v,0]),e.bT(this.labelPlaneMatrix,[this.width/2,-this.height/2,1]),e.bB(this.labelPlaneMatrix,this.labelPlaneMatrix,[1,-1,0]),e.bT(this.glCoordMatrix,[1,-1,1]),e.bB(this.glCoordMatrix,this.glCoordMatrix,[-1,-1,0]),e.cE(this.glCoordMatrix,this.glCoordMatrix,[2/this.width,2/this.height,1]),e.aC(this.pixelMatrix,this.labelPlaneMatrix,c),this._calcFogMatrices(),this._distanceTileDataCache={},!e.ba(this.pixelMatrixInverse,this.pixelMatrix))throw new Error("failed to invert matrix");if("globe"===this.projection.name||this.mercatorFromTransition){this.globeMatrix=e.cI(this);const t=[this.globeMatrix[12],this.globeMatrix[13],this.globeMatrix[14]];this.globeCenterInViewSpace=e.ae(t,t,s),this.globeRadius=this.worldSize/2/Math.PI-1}else this.globeMatrix=this.pixelMatrixInverse;this._projMatrixCache={},this._alignedProjMatrixCache={},this._pixelsToTileUnitsCache={},this._expandedProjMatrixCache={}}_calcFogMatrices(){this._fogTileMatrixCache={};const t=this.cameraWorldSizeForFog,i=this.cameraPixelsPerMeter,r=this._camera.position,n=1/this.height/this._pixelsPerMercatorPixel,o=[t,t,i];e.bN(o,o,n),e.bN(r,r,-1),e.cJ(r,r,o),e.cK(this.mercatorFogMatrix,r),e.cE(this.mercatorFogMatrix,this.mercatorFogMatrix,o),this.worldToFogMatrix=this._camera.getWorldToCameraPosition(t,i,n)}_computeCameraPosition(e){const t=(e=e||this.pixelsPerMeter)/this.pixelsPerMeter,i=this._camera.forward(),r=this.point,n=this._mercatorZfromZoom(this._seaLevelZoom?this._seaLevelZoom:this._zoom)*t-e/this.worldSize*this._centerAltitude;return[r.x/this.worldSize-i[0]*n,r.y/this.worldSize-i[1]*n,e/this.worldSize*this._centerAltitude-i[2]*n]}_updateCameraState(){this.height&&(this._camera.setPitchBearing(this._pitch,this.angle),this._camera.position=this._computeCameraPosition())}_translateCameraConstrained(t){const i=this._maxCameraBoundsDistance()*Math.cos(this._pitch),r=this._camera.position[2],n=t[2];let o=1;this.projection.wrap&&(this.center=this.center.wrap()),n>0&&(o=Math.min((i-r)/n,1)),this._camera.position=e.bi([],this._camera.position,t,o),this._updateStateFromCamera()}_updateStateFromCamera(){const t=this._camera.position,i=this._camera.forward(),{pitch:r,bearing:n}=this._camera.getPitchBearing(),o=e.bY(this._centerAltitude,this.center.lat)*this._pixelsPerMercatorPixel,s=this._mercatorZfromZoom(this._maxZoom)*Math.cos(e.am(this._maxPitch)),a=Math.max((t[2]-o)/Math.cos(r),s),l=this._zoomFromMercatorZ(a);e.bi(t,t,i,a),this._pitch=e.aB(r,e.am(this.minPitch),e.am(this.maxPitch)),this.angle=e.bv(n,-Math.PI,Math.PI),this._setZoom(e.aB(l,this._minZoom,this._maxZoom)),this._updateSeaLevelZoom(),this._center=this.coordinateLocation(new e.ad(t[0],t[1],t[2])),this._unmodified=!1,this._constrain(),this._calcMatrices()}_worldSizeFromZoom(e){return Math.pow(2,e)*this.tileSize}_mercatorZfromZoom(e){return this.cameraToCenterDistance/this._worldSizeFromZoom(e)}_minimumHeightOverTerrain(){const e=Math.min(null!=this._seaLevelZoom?this._seaLevelZoom:this._zoom,this._maxZoom)+4;return this._mercatorZfromZoom(e)}_zoomFromMercatorZ(e){return this.scaleZoom(this.cameraToCenterDistance/(Math.max(0,e)*this.tileSize))}zoomFromMercatorZAdjusted(t){let i=0,r=e.cx,n=0,o=1/0;for(;r-i>1e-6&&r>i;){const e=i+.5*(r-i),s=this.tileSize*Math.pow(2,e),a=this.getCameraToCenterDistance(this.projection,e,s),l=this.scaleZoom(a/(Math.max(0,t)*this.tileSize)),c=Math.abs(e-l);c<o&&(o=c,n=e),e<l?i=e:r=e}return n}_terrainEnabled(){return!(!this._elevation||!this.projection.supportsTerrain&&(e.w("Terrain is not yet supported with alternate projections. Use mercator or globe to enable terrain."),1))}anyCornerOffEdge(t,i){const r=Math.min(t.x,i.x),n=Math.max(t.x,i.x),o=Math.min(t.y,i.y),s=Math.max(t.y,i.y);if(o<this.horizonLineFromTop(!1))return!0;if("mercator"!==this.projection.name)return!1;const a=[new e.P(r,o),new e.P(n,s),new e.P(r,s),new e.P(n,o)],l=this.renderWorldCopies?-3:0,c=this.renderWorldCopies?4:1;for(const e of a){const t=this.pointRayIntersection(e);if(t.t<0)return!0;const i=this.rayIntersectionCoordinate(t);if(i.x<l||i.y<0||i.x>c||i.y>1)return!0}return!1}isHorizonVisible(){return this.pitch+e.cL(this.fovAboveCenter)>88||this.anyCornerOffEdge(new e.P(0,0),new e.P(this.width,this.height))}zoomDeltaToMovement(t,i){const r=e.af(e.aw([],this._camera.position,t)),n=this._zoomFromMercatorZ(r)+i;return r-this._mercatorZfromZoom(n)}getCameraPoint(){if("globe"===this.projection.name){const t=function([t,i,r],n){const o=[t,i,r,1];e.aD(o,o,n);const s=o[3]=Math.max(o[3],1e-6);return o[0]/=s,o[1]/=s,o[2]/=s,o}([this.globeMatrix[12],this.globeMatrix[13],this.globeMatrix[14]],this.pixelMatrix);return new e.P(t[0],t[1])}{const t=Math.tan(this._pitch)*(this.cameraToCenterDistance||1);return this.centerPoint.add(new e.P(0,t))}}getCameraToCenterDistance(t,i=this.zoom,r=this.worldSize){const n=e.cA(t,i,this.width,this.height,1024),o=t.pixelSpaceConversion(this.center.lat,r,n);let s=.5/Math.tan(.5*this._fov)*this.height*o;return this.isOrthographic&&(s=e.aj(1,s,e.cP(this.pitch>=on?1:this.pitch/on))),s}getWorldToCameraMatrix(){const t=this._camera.getWorldToCamera(this.worldSize,"meters"===this.projection.zAxisUnit?this.pixelsPerMeter:1);return"globe"===this.projection.name&&e.aC(t,t,this.globeMatrix),t}getFrustum(t){return e.cn.fromInvProjectionMatrix(this.invProjMatrix,this.worldSize,t,"meters"===this.projection.zAxisUnit)}}const an=(t,i)=>{if(i>0&&t.terrain&&e.w("Cutoff is currently disabled on terrain"),i<=0||t.terrain)return{shouldRenderCutoff:!1,uniformValues:{u_cutoff_params:[0,0,0,1]}};const r=t.transform,n=r.pitch,o=r.isLODDisabled(!1)?60:30;if(n<o-15)return{shouldRenderCutoff:!1,uniformValues:{u_cutoff_params:[0,0,0,1]}};const s=r._farZ-r._nearZ,a=i*r.height*1.3,l=Math.pow(2,.85*Math.max(r._zoom-t.minCutoffZoom,0)),c=1.4*r.cameraToCenterDistance*l,h=e.ag(o-15,o,n),u=(1-(d=h))*(r._farZ+a)+d*c;var d;const p=Math.min(a,u-r._nearZ);return{shouldRenderCutoff:h>0,uniformValues:{u_cutoff_params:[r._nearZ,r._farZ,(u-r._nearZ)/s,(u-p-r._nearZ)/s]}}},ln=[];function cn(e){return ln[e]=ln[e]||new Float64Array(16)}class hn{constructor(e,t){this.aabb=e,this.lastCascade=t}}class un{add(e,t){const i=this.receivers[e.key];void 0!==i?(i.aabb.min[0]=Math.min(i.aabb.min[0],t.min[0]),i.aabb.min[1]=Math.min(i.aabb.min[1],t.min[1]),i.aabb.min[2]=Math.min(i.aabb.min[2],t.min[2]),i.aabb.max[0]=Math.max(i.aabb.max[0],t.max[0]),i.aabb.max[1]=Math.max(i.aabb.max[1],t.max[1]),i.aabb.max[2]=Math.max(i.aabb.max[2],t.max[2])):this.receivers[e.key]=new hn(t,null)}clear(){this.receivers={}}get(e){return this.receivers[e.key]}computeRequiredCascades(t,i,r){const n=e.cY.fromPoints(t.points);let o=0;for(const s in this.receivers){const t=this.receivers[s];if(!t)continue;if(!n.intersectsAabb(t.aabb))continue;t.aabb.min=n.closestPoint(t.aabb.min),t.aabb.max=n.closestPoint(t.aabb.max);const a=t.aabb.getCorners();for(let n=0;n<r.length;n++){let s=!0;for(const t of a){const o=[t[0]*i,t[1]*i,t[2]];if(e.ae(o,o,r[n].matrix),o[0]<-1||o[0]>1||o[1]<-1||o[1]>1){s=!1;break}}if(t.lastCascade=n,o=Math.max(o,n),s)break}}return o+1}}class dn{constructor(e){this.painter=e,this._enabled=!1,this._drawShadowAfterLayer=-1,this._numCascadesToRender=0,this._cascades=[],this._groundShadowTiles=[],this._receivers=new un,this._depthMode=new $r(e.context.gl.LEQUAL,$r.ReadWrite,[0,1]),this._uniformValues={u_light_matrix_0:new Float32Array(16),u_light_matrix_1:new Float32Array(16),u_shadow_intensity:0,u_fade_range:[0,0],u_shadow_normal_offset:[1,1,1],u_shadow_texel_size:1,u_shadow_map_resolution:1,u_shadow_direction:[0,0,1],u_shadow_bias:[36e-5,.0012,.012],u_shadowmap_0:0,u_shadowmap_1:0},this._forceDisable=!1,this._devtoolsFolder=null,this.useNormalOffset=!1,this._shadowParameters={cascadeCount:2,normalOffset:3,shadowMapResolution:2048}}destroy(){for(const e of this._cascades)e.texture.destroy(),e.framebuffer.destroy();this._cascades=[]}updateShadowParameters(t,i){const r=this.painter;if(this._enabled=!1,this._drawShadowAfterLayer=-1,this._receivers.clear(),!i||!i.properties)return;const n=i.properties.get("shadow-intensity"),o=i.properties.get("shadow-draw-before-layer");if(!i.shadowsEnabled()||n<=0)return;let s=-1,a=0;for(const e of r.style.order){const i=r.style._mergedLayers[e];i.hasShadowPass()&&!i.isHidden(t.zoom)&&(s=a),!o||o!==e&&o!==i.slot||(this._drawShadowAfterLayer=a>0?a-1:0),a+=1}if(this._enabled=s>=0,!this.enabled)return;this._drawShadowAfterLayer<0&&(this._drawShadowAfterLayer=s);const l=r.context,c=this._shadowParameters.shadowMapResolution,h=this._shadowParameters.shadowMapResolution;if(0===this._cascades.length||this._shadowParameters.shadowMapResolution!==this._cascades[0].texture.size[0]){this._cascades=[];for(let t=0;t<this._shadowParameters.cascadeCount;++t){const t=l.gl,i=l.createFramebuffer(c,h,0,"texture"),r=new e.T(l,{width:c,height:h,data:null},t.DEPTH_COMPONENT16);i.depthAttachment.set(r.texture),this._cascades.push({framebuffer:i,texture:r,matrix:[],far:0,boundingSphereRadius:0,frustum:new e.cn,scale:0})}}this.shadowDirection=fn(i);let u=0;if(t.elevation){const e=t.elevation,i=[1e4,-1e4];e.visibleDemTiles.filter(e=>e.dem).forEach(e=>{const t=e.dem.tree;i[0]=Math.min(i[0],t.minimums[0]),i[1]=Math.max(i[1],t.maximums[0])}),1e4!==i[0]&&(u=(i[1]-i[0])*e.exaggeration())}const d=1.5*t.cameraToCenterDistance,p=3*d,f=new Float64Array(16);for(let g=0;g<this._cascades.length;++g){const i=this._cascades[g];let r=t.height/50,n=1;1===this._shadowParameters.cascadeCount?n=p:0===g?n=d:(r=d,n=p);const[o,s]=_n(t,this.shadowDirection,r,n,this._shadowParameters.shadowMapResolution,u);i.scale=t.scale,i.matrix=o,i.boundingSphereRadius=s,e.ba(f,i.matrix),i.frustum=e.cn.fromInvProjectionMatrix(f,1,0,!0),i.far=n}const m=this._cascades.length-1;this._uniformValues.u_fade_range=[.75*this._cascades[m].far,this._cascades[m].far],this._uniformValues.u_shadow_intensity=n,this._uniformValues.u_shadow_direction=[this.shadowDirection[0],this.shadowDirection[1],this.shadowDirection[2]],this._uniformValues.u_shadow_texel_size=1/this._shadowParameters.shadowMapResolution,this._uniformValues.u_shadow_map_resolution=this._shadowParameters.shadowMapResolution,this._uniformValues.u_shadowmap_0=11,this._uniformValues.u_shadowmap_1=12,this._groundShadowTiles=r.transform.coveringTiles({tileSize:512,renderWorldCopies:!0});const _=r.transform.elevation;for(const e of this._groundShadowTiles){let t={min:0,max:0};if(_){const i=_.getMinMaxForTile(e);i&&(t=i)}this.addShadowReceiver(e.toUnwrapped(),t.min,t.max)}}get enabled(){return this._enabled&&!this._forceDisable}set enabled(e){this._enabled=e}drawShadowPass(t,i){if(!this.enabled)return;const r=this.painter,n=r.context;this._numCascadesToRender=this._receivers.computeRequiredCascades(r.transform.getFrustum(0),r.transform.worldSize,this._cascades),n.viewport.set([0,0,this._shadowParameters.shadowMapResolution,this._shadowParameters.shadowMapResolution]);for(let o=0;o<this._numCascadesToRender;++o){r.currentShadowCascade=o,n.bindFramebuffer.set(this._cascades[o].framebuffer.framebuffer),n.clear({color:e.C.white,depth:1});for(const e of t.order){const n=t._mergedLayers[e];if(!n.hasShadowPass()||n.isHidden(r.transform.zoom))continue;const o=t.getLayerSourceCache(n),s=o?i[o.id]:void 0;("model"===n.type||s&&s.length)&&r.renderLayer(r,o,n,s)}}r.currentShadowCascade=0}drawGroundShadows(){if(!this.enabled)return;const e=this.painter,t=e.style,i=e.context,r=i.gl,n=t.directionalLight,o=t.ambientLight;if(!n||!o)return;const s=[],a=an(e,e.longestCutoffRange);a.shouldRenderCutoff&&s.push("RENDER_CUTOFF"),s.push("RENDER_SHADOWS"),this.useNormalOffset&&s.push("NORMAL_OFFSET");const l=mn(t,n,o),c=new $r(r.LEQUAL,$r.ReadOnly,e.depthRangeFor3D),h=new Zr({func:r.EQUAL,mask:255},0,255,r.KEEP,r.KEEP,r.KEEP);for(const u of this._groundShadowTiles){const t=u.toUnwrapped(),n=e.isTileAffectedByFog(u),o=e.getOrCreateProgram("groundShadow",{defines:s,overrideFog:n});this.setupShadows(t,o),e.uploadCommonUniforms(i,o,t,null,a);const d=rn(e.transform.calculateProjMatrix(t),l);o.draw(e,r.TRIANGLES,c,h,Hr.multiply,Yr.disabled,d,"ground_shadow",e.tileExtentBuffer,e.quadTriangleIndexBuffer,e.tileExtentSegments,null,e.transform.zoom,null,null)}}getShadowPassDepthMode(){return this._depthMode}getGroundShadowLayerIndex(){return this._drawShadowAfterLayer}calculateShadowPassMatrixFromTile(t){const i=this.painter.transform,r=i.calculatePosMatrix(t,i.worldSize);return e.aC(r,this._cascades[this.painter.currentShadowCascade].matrix,r),Float32Array.from(r)}calculateShadowPassMatrixFromMatrix(t){const i=e.bb(t);return e.aC(i,this._cascades[this.painter.currentShadowCascade].matrix,t),i}setupShadows(t,i,r){if(!this.enabled)return;const n=this.painter.transform,o=this.painter.context,s=o.gl,a=this._uniformValues,l=n.calculatePosMatrix(t,n.worldSize);for(let c=0;c<this._cascades.length;c++){const t=cn(c);e.aC(t,this._cascades[c].matrix,l),a[0===c?"u_light_matrix_0":"u_light_matrix_1"]=t,o.activeTexture.set(s.TEXTURE0+11+c),this._cascades[c].texture.bindExtraParam(s.LINEAR,s.LINEAR,s.CLAMP_TO_EDGE,s.CLAMP_TO_EDGE,s.GREATER)}if(this.useNormalOffset=!!r,this.useNormalOffset){const i=e.cW(t.canonical),o=2/n.tileSize*e.ak/this._shadowParameters.shadowMapResolution,s=o*this._cascades[0].boundingSphereRadius,l=o*this._cascades.at(-1).boundingSphereRadius,c=("vector-tile"===r?1:3)*function(t){const i=e.aB((t-22)/-22,0,1);return.125*(1-i)+4*i}(n.zoom);a.u_shadow_normal_offset=[i,s*c,l*c],a.u_shadow_bias=[1e-4,.0012,.012]}else a.u_shadow_bias=[36e-5,.0012,.012];i.setShadowUniformValues(o,a)}setupShadowsFromMatrix(t,i,r=!1){if(!this.enabled)return;const n=this.painter.context,o=n.gl,s=this._uniformValues;for(let a=0;a<this._shadowParameters.cascadeCount;a++){const i=cn(a);e.aC(i,this._cascades[a].matrix,t),s[0===a?"u_light_matrix_0":"u_light_matrix_1"]=i,n.activeTexture.set(o.TEXTURE0+11+a),this._cascades[a].texture.bindExtraParam(o.LINEAR,o.LINEAR,o.CLAMP_TO_EDGE,o.CLAMP_TO_EDGE,o.GREATER)}if(this.useNormalOffset=r,r){const e=this._shadowParameters.normalOffset;s.u_shadow_normal_offset=[1,e,e],s.u_shadow_bias=[6e-5,.0012,.012]}else s.u_shadow_bias=[36e-5,.0012,.012];i.setShadowUniformValues(n,s)}getShadowUniformValues(){return this._uniformValues}getCurrentCascadeFrustum(){return this._cascades[this.painter.currentShadowCascade].frustum}computeSimplifiedTileShadowVolume(t,i,r,n){if(n[2]>=0)return{};const o=function(t,i,r){const n=r/(1<<t.canonical.z);return new e.cY([t.canonical.x*n+t.wrap*r,t.canonical.y*n+t.wrap*r,0],[(t.canonical.x+1)*n+t.wrap*r,(t.canonical.y+1)*n+t.wrap*r,i])}(t,i,r).getCorners(),s=i/-n[2];n[0]<0?(e.cX(o[0],o[0],[n[0]*s,0,0]),e.cX(o[3],o[3],[n[0]*s,0,0])):n[0]>0&&(e.cX(o[1],o[1],[n[0]*s,0,0]),e.cX(o[2],o[2],[n[0]*s,0,0])),n[1]<0?(e.cX(o[0],o[0],[0,n[1]*s,0]),e.cX(o[1],o[1],[0,n[1]*s,0])):n[1]>0&&(e.cX(o[2],o[2],[0,n[1]*s,0]),e.cX(o[3],o[3],[0,n[1]*s,0]));const a={};return a.vertices=o,a.planes=[pn(o[1],o[0],o[4]),pn(o[2],o[1],o[5]),pn(o[3],o[2],o[6]),pn(o[0],o[3],o[7])],a}addShadowReceiver(t,i,r){this._receivers.add(t,e.cY.fromTileIdAndHeight(t,i,r))}getMaxCascadeForTile(e){const t=this._receivers.get(e);return t&&t.lastCascade?t.lastCascade:0}}function pn(t,i,r){const n=e.aw([],r,i),o=e.aw([],t,i),s=e.bj([],n,o),a=e.af(s);return 0===a?[0,0,1,0]:(e.bN(s,s,1/a),[s[0],s[1],s[2],-e.bk(s,i)])}function fn(t){const i=t.properties.get("direction"),r=e.cT(i.x,i.y,i.z);r[2]=e.aB(r[2],0,75);const n=e.cV([r[0],r[1],r[2]]);return e.cU(n.x,n.y,n.z)}function mn(t,i,r){const n="none"===i.properties.get("color-use-theme"),o=i.properties.get("color"),s=i.properties.get("intensity"),a=i.properties.get("direction"),l=[a.x,a.y,a.z],c="none"===r.properties.get("color-use-theme"),h=r.properties.get("color"),u=r.properties.get("intensity"),d=Math.max(e.bk([0,0,1],l),0),p=[0,0,0];e.bN(p,h.toPremultipliedRenderColor(c?null:t.getLut(i.scope)).toArray01Linear().slice(0,3),u);const f=[0,0,0];return e.bN(f,o.toPremultipliedRenderColor(n?null:t.getLut(r.scope)).toArray01Linear().slice(0,3),d*s),e.c_([p[0]>0?p[0]/(p[0]+f[0]):0,p[1]>0?p[1]/(p[1]+f[1]):0,p[2]>0?p[2]/(p[2]+f[2]):0])}function _n(t,i,r,n,o,s){const a=t.zoom,l=t.scale,c=t.worldSize,h=1/c,u=t.aspect,d=Math.sqrt(1+u*u)*Math.tan(.5*t.fovX),p=d*d,f=n-r,m=n+r;let _,g;p>f/m?(_=n,g=n*d):(_=.5*m*(1+p),g=.5*Math.sqrt(f*f+2*(n*n+r*r)*p+m*m*p*p));const y=t.projection.pixelsPerMeter(t.center.lat,c),x=t._camera.getCameraToWorldMercator(),v=[0,0,-_*h];e.ae(v,v,x);let b=g*h;const w=function(i){return i[0]/=l,i[1]/=l,i[2]=e.bY(i[2],t._center.lat),i},T=t._edgeInsets;if(!(0===T.left&&0===T.top&&0===T.right&&0===T.bottom||T.left===T.right&&T.top===T.bottom)){const i=t._camera.getWorldToCamera(t.worldSize,"meters"===t.projection.zAxisUnit?y:1),o=t._camera.getCameraToClipPerspective(t._fov,t.width/t.height,r,n);o[8]=2*-t.centerOffset.x/t.width,o[9]=2*t.centerOffset.y/t.height;const s=new Float64Array(16);e.cB(s,o,i);const l=new Float64Array(16);e.ba(l,s);const h=e.cn.fromInvProjectionMatrix(l,c,a,!0);for(const t of h.points){const i=w(t);b=Math.max(b,e.bO(e.cZ([],v,i)))}}b*=o/(o-1);const S=Math.acos(i[2]),I=Math.atan2(-i[0],-i[1]),E=new tn;E.position=v,E.setPitchBearing(S,I);const A=E.getWorldToCamera(c,y),M=b*c,C=Math.min(t._mercatorZfromZoom(17)*c*-2,-2*M),P=E.getCameraToClipOrthographic(-M,M,-M,M,C,(M+s*y)/i[2]),D=new Float64Array(16);e.aC(D,P,A);const R=e.cU(Math.floor(1e6*v[0])/1e6*c,Math.floor(1e6*v[1])/1e6*c,0),z=.5*o,L=[0,0,0];e.ae(L,R,D),e.bN(L,L,z);const F=[Math.floor(L[0]),Math.floor(L[1]),Math.floor(L[2])],O=[0,0,0];e.aw(O,L,F),e.bN(O,O,-1/z);const B=new Float64Array(16);return e.bA(B),e.bB(B,B,O),e.aC(D,B,D),[D,M]}class gn extends e.E{constructor(e){super(),this.requestManager=e,this.models={"":{}},this.modelUris={"":{}},this.modelByURL={},this.numModelsLoading={}}loadModel(t,i){return e.c$(this.requestManager.transformRequest(i,e.R.Model).url).then(r=>{const n=e.d0(r),o=new e.d1(t,i,void 0,void 0,n);return o.computeBoundsAndApplyParent(),o}).catch(r=>{if(r&&404===r.status)return null;this.fire(new e.y(/* @__PURE__ */new Error(`Could not load model ${t} from ${i}: ${r.message}`)))})}load(t,i,r={forceReload:!1}){this.models[i]||(this.models[i]={});const n=Object.keys(t),o=[],s=[];for(const e of n){const n=t[e];this.hasURLBeenRequested(n)&&!r.forceReload||(this.modelByURL[n]={modelId:e,scope:i},o.push(this.loadModel(e,n)),s.push(e)),this.models[i][e]||(this.models[i][e]={model:null,numReferences:1})}this.numModelsLoading[i]=(this.numModelsLoading[i]||0)+s.length,Promise.allSettled(o).then(t=>{for(let e=0;e<t.length;e++){const{status:r}=t[e];if("rejected"===r)continue;const{value:n}=t[e];this.models[i][s[e]]||(this.models[i][s[e]]={model:null,numReferences:1}),this.models[i][s[e]].model=n}this.numModelsLoading[i]-=s.length,this.fire(new e.z("data",{dataType:"style"}))}).catch(t=>{this.fire(new e.y(/* @__PURE__ */new Error(`Could not load models: ${t.message}`)))})}isLoaded(){for(const e in this.numModelsLoading)if(this.numModelsLoading[e]>0)return!1;return!0}hasModel(e,t,i={exactIdMatch:!1}){return!!(i.exactIdMatch?this.getModel(e,t):this.getModelByURL(this.modelUris[t][e]))}getModel(e,t){return this.models[t]||(this.models[t]={}),this.models[t][e]?this.models[t][e].model:void 0}getModelByURL(e){if(!e)return null;const t=this.modelByURL[e];return t?this.models[t.scope][t.modelId].model:null}hasModelBeenAdded(e,t){return this.models[t]&&void 0!==this.models[t][e]}getModelURIs(e){return this.modelUris[e]||{}}addModel(e,t,i){this.models[i]||(this.models[i]={}),this.modelUris[i]||(this.modelUris[i]={});const r=this.requestManager.normalizeModelURL(t);if((this.hasModel(e,i,{exactIdMatch:!0})||this.hasModelBeenAdded(e,i))&&this.modelUris[i][e]===r)this.models[i][e].numReferences++;else if(this.hasURLBeenRequested(r)){const{scope:e,modelId:t}=this.modelByURL[r];this.models[e][t].numReferences++}else this.modelUris[i][e]=r,this.load({[e]:this.modelUris[i][e]},i)}addModelURLs(e,t){this.models[t]||(this.models[t]={}),this.modelUris[t]||(this.modelUris[t]={});const i=this.modelUris[t];for(const r in e)i[r]=this.requestManager.normalizeModelURL(e[r])}reloadModels(e){this.load(this.modelUris[e],e,{forceReload:!0})}addModelsFromBucket(e,t){this.models[t]||(this.models[t]={}),this.modelUris[t]||(this.modelUris[t]={});const i={};for(const r of e)this.hasModel(r,t,{exactIdMatch:!0})||this.hasURLBeenRequested(r)?this.models[t][r].numReferences++:this.modelUris[t][r]&&!this.hasURLBeenRequested(r)?i[r]=this.modelUris[t][r]:!this.hasURLBeenRequested(r)&&ft(r,!1)&&(this.modelUris[t][r]=this.requestManager.normalizeModelURL(r),i[r]=this.modelUris[t][r]);this.load(i,t)}hasURLBeenRequested(e){return void 0!==this.modelByURL[e]}removeModel(e,t,i=!1,r=!1){if(this.models[t]&&this.models[t][e]&&(this.models[t][e].numReferences--,0===this.models[t][e].numReferences||r)){const r=this.modelUris[t][e];i||delete this.modelUris[t][e],delete this.modelByURL[r];const n=this.models[t][e].model;if(!n)return;delete this.models[t][e],n.destroy()}}destroy(){for(const e of Object.keys(this.models))for(const t of Object.keys(this.models[e])){const i=this.models[e][t].model;delete this.models[e][t],i&&i.destroy()}this.models={"":{}},this.modelUris={"":{}},this.modelByURL={},this.numModelsLoading={}}listModels(e){return this.models[e]||(this.models[e]={}),Object.keys(this.models[e])}upload(e,t){this.models[t]||(this.models[t]={});for(const i in this.models[t])this.models[t][i].model&&this.models[t][i].model.upload(e.context)}}const yn=["RENDER_SHADOWS","NORMAL_OFFSET"],xn=new Set(["symbol","circle"]),vn=class t{constructor(){this._queue=[],this._needsBuild=!0,this._idleHandle=null}needsBuild(){return this._needsBuild}buildQueue(e,t,i){null!=this._idleHandle&&"undefined"!=typeof cancelIdleCallback&&cancelIdleCallback(this._idleHandle),this._idleHandle=null,this._queue=[],this._needsBuild=!1;const r=i.stylesheet,n=!!i.fog,o=!!(i.getTerrain()||r&&r.terrain),s=!(!i.projection||"globe"!==i.projection.name),a=o||s,l=!(!i.directionalLight||!i.directionalLight.shadowsEnabled()),c=i.map&&i.map.painter,h=!c||!c.context.extParallelShaderCompile,u=!!c&&"mrt-fallback"===c.emissiveMode,d=(e,t=[],i={})=>{this._queue.push({programId:e,params:Object.assign({},i.params,{defines:t,overrideFog:!!i.fog,overrideTerrain:!!i.terrain,overrideGlobe:!!i.globe,overrideRtt:!!i.rtt,precompiled:!0})})};for(const p of e){if("none"===p.visibility)continue;const e=p.getProgramIds();if(e)for(const r of e){if(xn.has(r))continue;const e=p.getDefaultProgramParams(r,t.zoom,i._styleColorTheme.lut);if(!e)continue;const f=c?c.getShaderSource(r):null,m=a&&(!f||f.usedDefines.has("RENDER_TO_TEXTURE")),_=u&&m?(e.defines||[]).concat("USE_MRT1"):e.defines;if(h){d(r,e.defines,{params:e}),m&&d(r,_,{params:e,rtt:!0});continue}const g=n&&(!f||f.usedDefines.has("FOG")),y=o&&!p.isDraped()&&(!f||f.usedDefines.has("TERRAIN")),x=s&&(!f||f.usedDefines.has("GLOBE")),v=l&&p.hasElevation()&&(!f||f.usedDefines.has("RENDER_SHADOWS"));for(const t of v?[!1,!0]:[!1]){const i=t?(e.defines||[]).concat(yn):e.defines||[];for(const t of y?[!1,!0]:[!1])for(const n of x?[!1,!0]:[!1])for(const o of g?[!1,!0]:[!1])d(r,i,{params:e,fog:o,terrain:t,globe:n})}m&&d(r,_,{params:e,rtt:!0})}}if(d("clippingMask"),o)for(const p of[!1,!0])d("terrainRaster",p?["TERRAIN_VERTEX_MORPHING"]:[],{terrain:!0,fog:n});if(!h){if(e.some(e=>"hillshade"===e.type)&&d("hillshadePrepare"),l)for(const e of[!1,!0])for(const t of[!1,!0]){const i=[];e&&i.push("RENDER_CUTOFF"),i.push("RENDER_SHADOWS"),t&&i.push("NORMAL_OFFSET"),d("groundShadow",i),n&&d("groundShadow",i,{fog:!0})}if(s){for(const e of[[],["TERRAIN_VERTEX_MORPHING"],["GLOBE_POLES"]])for(const t of[!1,!0]){const i=[...e,"PROJECTION_GLOBE_VIEW"];t&&i.push("CUSTOM_ANTIALIASING"),d("globeRaster",i,{terrain:o,globe:!0,fog:n})}for(const e of[!1,!0]){const t=e?["PROJECTION_GLOBE_VIEW","FOG"]:["FOG"];d("globeAtmosphere",t,{fog:!0,terrain:o,globe:e}),d("globeAtmosphere",[...t,"ALPHA_PASS"],{fog:!0,terrain:o,globe:e})}d("stars",[],{fog:n,terrain:o,globe:!0})}}}_executeBatch(i,r,n){if(n.map&&n.map.isMoving())return void(this._idleHandle=e.o.requestIdleCallback(e=>this._executeBatch(e,r,n)));r.context.sweepPendingPrograms();const o=r.context.extParallelShaderCompile?t.DEADLINE_MARGIN_KHR_MS:t.DEADLINE_MARGIN_SYNC_MS;let s=0;for(;this._queue.length>0;){const e=this._queue.shift();if(!e)break;if(r.style=n,r._fogVisible=!!e.params.overrideFog,r.getOrCreateProgram(e.programId,e.params),s++,i.timeRemaining()<=o)break}const a=0===this._queue.length||i.timeRemaining()>o;s>0&&a&&r.context.gl.flush(),this._idleHandle=this._queue.length>0||r.context._pendingPrograms.size>0?e.o.requestIdleCallback(e=>this._executeBatch(e,r,n)):null}processQueue(t,i){0!==this._queue.length&&(null!=this._idleHandle&&"undefined"!=typeof cancelIdleCallback&&cancelIdleCallback(this._idleHandle),this._idleHandle=e.o.requestIdleCallback(e=>this._executeBatch(e,t,i)))}reset(){null!=this._idleHandle&&"undefined"!=typeof cancelIdleCallback&&cancelIdleCallback(this._idleHandle),this._queue=[],this._idleHandle=null,this._needsBuild=!0}};vn.DEADLINE_MARGIN_KHR_MS=5,vn.DEADLINE_MARGIN_SYNC_MS=25;let bn=vn;const wn=e.a6.colorTheme,Tn=new e.a8({data:new e.a9(wn.data)});function Sn(t){if(!t.metadata||!t.metadata.content_area)return;const i=e.o.devicePixelRatio,{left:r,top:n,width:o,height:s}=t.metadata.content_area,a=r*i,l=n*i;return[a,l,a+o*i,l+s*i]}function In(t){if(t)return t.map(([t,i])=>[t*e.o.devicePixelRatio,i*e.o.devicePixelRatio])}class En{constructor(e,t,i){this.id=e,this.scope=t,this.sourceCache=i,this.pendingRequests=/* @__PURE__ */new Set,this.missingRequests=/* @__PURE__ */new Set}addPendingRequest(e){this.missingRequests.has(e.name)||this.pendingRequests.has(e.name)||this.pendingRequests.add(e.name)}hasPendingRequests(){return this.pendingRequests.size>0}resolvePendingRequests(){const t=/* @__PURE__ */new Map;if(!this.sourceCache.loaded())return t;const i=this.sourceCache.getVisibleCoordinates();if(0===i.length)return t;const r=this.sourceCache.getSource();if(!(r instanceof vi))return t;const n=i.map(e=>this.sourceCache.getTile(e)),o=r.getImages(n,Array.from(this.pendingRequests));for(const[s,a]of o)t.set(e.I.from({name:s,iconsetId:this.id}),a),this.pendingRequests.delete(s);for(const e of this.pendingRequests)this.missingRequests.add(e);return this.pendingRequests.clear(),t}}class An{constructor(){this._previousClosestBuildingId=null,this._hysteresisRatio=.8,this._indoorMinimumZoom=16}findClosestBuilding(e,t,i,r,n){if(i<this._indoorMinimumZoom)return this._previousClosestBuildingId=null,null;let o=null,s=Number.MAX_VALUE,a=Number.MAX_VALUE,l=!1;const c=this._previousClosestBuildingId?e[this._previousClosestBuildingId]:null;this._previousClosestBuildingId&&c&&this._isBuildingVisible(c,r,n)&&(l=!0,a=this._calculateDistance(t,c));for(const[h,u]of Object.entries(e)){if(!this._isBuildingVisible(u,r,n))continue;const e=this._calculateDistance(t,u);e<s&&(s=e,o=h)}return l&&o&&this._previousClosestBuildingId&&o!==this._previousClosestBuildingId?s>a*this._hysteresisRatio&&(o=this._previousClosestBuildingId):l&&!o&&(o=this._previousClosestBuildingId),this._previousClosestBuildingId=o,o}_calculateDistance(e,t){if(!t.center)return Number.MAX_VALUE;const i=e.lat-t.center[1],r=e.lng-t.center[0];return i*i+r*r}_isBuildingVisible(t,i,r){if(!r)return!1;for(const n of t.floorIds){const i=t.floors[n];if(!i.geometry)continue;const o=i.geometry;if("Polygon"===o.type){const t=this._convertRingToPoints(o.coordinates[0]);if(e.bz(t,r))return!0}else if("MultiPolygon"===o.type){const t=this._convertMultiPolygonToPoints(o.coordinates);if(e.d2(r,t))return!0}}return!1}_convertRingToPoints(t){return t.map(t=>new e.P(t[0],t[1]))}_convertMultiPolygonToPoints(t){return t.map(t=>0===t.length?[]:t[0].map(t=>new e.P(t[0],t[1])))}}class Mn extends e.E{constructor(t){super(),this._style=t,this._buildings={},this._activeFloors=/* @__PURE__ */new Set,this._closestBuildingId=null,this._indoorState={selectedFloorId:null,activeFloorsVisible:!0,activeFloors:this._activeFloors},this._buildingDetectionStrategy=new An,this._initialLoadDone=!1,e.b0(["_updateUI"],this),this._style.on("style.load",()=>{this._style.isIndoorEnabled()&&(this._style.map.on("load",()=>{this._initialLoadDone=!0,this._indoorState&&this._indoorState.needsUpdate&&(this._indoorState.needsUpdate=!1,this._style.updateIndoorDependentLayers()),this._updateUI()}),this._style.map.on("move",this._updateUI),this._style.map.on("idle",this._updateUI))})}destroy(){this._buildings={},this._activeFloors=/* @__PURE__ */new Set,this._indoorState=null}selectFloor(e){e===this._selectedFloorId&&this._indoorState&&this._indoorState.activeFloorsVisible||(this._selectedFloorId=e,this._recalculateActiveFloors())}setActiveFloorsVisibility(e){this._updateActiveFloors(e),this._updateIndoorSelector()}setIndoorData(e){let t=!1;for(const[i,r]of Object.entries(e.buildings))if(this._buildings[i])for(const e of r.floorIds)this._buildings[i].floorIds.add(e),this._buildings[i].floors[e]?this._mergeFloors(this._buildings[i].floors[e],r.floors[e]):(this._buildings[i].floors[e]=r.floors[e],t=!0);else this._buildings[i]=r,t=!0;t&&this._recalculateActiveFloors()}getIndoorTileOptions(e,t){return this._indoorState?{sourceLayers:this._style.getIndoorSourceLayers(e,t),indoorState:this._indoorState}:null}getControlState(){const e=this._buildings,t=this._closestBuildingId,i=t&&e?e[t]:void 0;if(!i)return{selectedFloorId:null,activeFloorsVisible:!!this._indoorState&&this._indoorState.activeFloorsVisible,floors:[]};let r=null;for(const o of i.floorIds)if(this._activeFloors&&this._activeFloors.has(o)){r=o;break}const n=Array.from(i.floorIds).map(e=>({id:e,name:i.floors[e].name,zIndex:i.floors[e].zIndex})).sort((e,t)=>t.zIndex-e.zIndex).filter((e,t,i)=>0===t||e.zIndex!==i[t-1].zIndex);return{selectedFloorId:r,activeFloorsVisible:!!this._indoorState&&this._indoorState.activeFloorsVisible,floors:n}}_updateUI(){this._initialLoadDone=!0;const e=this._style.map.transform,t=this._buildingDetectionStrategy.findClosestBuilding(this._buildings,e.center,e.zoom,e.getBounds(),this._makeViewportPolygon());if(t!==this._closestBuildingId){const e=this._closestBuildingId;this._closestBuildingId=t,this._onBuildingTransition(e,t),this._updateIndoorSelector()}}_onBuildingTransition(e,t){this._indoorState&&(!t&&e?(this._indoorState.activeFloors=/* @__PURE__ */new Set,this._indoorState.activeFloorsVisible=!1,this._style.updateIndoorDependentLayers()):t&&!e&&(this._recalculateActiveFloors(),this._updateActiveFloors(!0)))}_updateIndoorSelector(){this.fire(new e.z("selector-update",this.getControlState()))}_updateActiveFloors(e){this._indoorState={selectedFloorId:this._selectedFloorId,activeFloorsVisible:e,activeFloors:this._activeFloors},this._initialLoadDone?this._style.updateIndoorDependentLayers():this._indoorState.needsUpdate=!0}_recalculateActiveFloors(){if(!this._buildings)return;const t=e.d3.calculate(this._buildings,this._selectedFloorId,this._activeFloors);(function(e,t){if(e===t)return!0;if(!e||!t)return!1;if(e.size!==t.size)return!1;for(const i of e)if(!t.has(i))return!1;return!0})(t,this._activeFloors)||(this._activeFloors=t,this._updateActiveFloors(!!this._indoorState&&this._indoorState.activeFloorsVisible),this._updateIndoorSelector())}_mergeFloors(e,t){t.geometry&&(e.geometry?("Polygon"===e.geometry.type&&(e.geometry={type:"MultiPolygon",coordinates:[e.geometry.coordinates]}),"Polygon"===t.geometry.type?e.geometry.coordinates.push(t.geometry.coordinates):"MultiPolygon"===t.geometry.type&&e.geometry.coordinates.push(...t.geometry.coordinates)):e.geometry=t.geometry)}_makeViewportPolygon(){const t=this._style.map.transform,i=t.width,r=t.height;return[t.pointLocation(new e.P(0,0)),t.pointLocation(new e.P(i,0)),t.pointLocation(new e.P(i,r)),t.pointLocation(new e.P(0,r))].map(t=>new e.P(t.lng,t.lat))}}const Cn=(e,t)=>Nt(e,t&&t.filter(e=>"source.canvas"!==e.identifier)),Pn=e.aK(Ui,["addLayer","removeLayer","setLights","setPaintProperty","setLayoutProperty","setLayerProperty","setSlot","setFilter","addSource","removeSource","setLayerZoomRange","setLight","setTransition","setGeoJSONSourceData","setTerrain","setFog","setSnow","setRain","setProjection","setCamera","addImport","removeImport","updateImport","addIconset","removeIconset"]),Dn=e.aK(Ui,["setCenter","setZoom","setBearing","setPitch"]),Rn=new Set(["background","sky","slot","custom"]),zn=new Set(["building"]),Ln={version:8,layers:[],sources:{}},Fn={duration:300,delay:0};class On extends e.E{constructor(t,i={}){if(super(),this.map=t,this.scope=i.scope||"",this.globalId=null,this.fragments=[],this.importDepth=i.importDepth||0,this.importsCache=i.importsCache||/* @__PURE__ */new Map,this.resolvedImports=i.resolvedImports||/* @__PURE__ */new Set,this.transition=Object.assign({},Fn),this._buildingIndex=new Fi(this),this.crossTileSymbolIndex=new Vr,this._mergedOrder=[],this._drapedFirstOrder=[],this._mergedLayers={},this._mergedIndoor={},this._mergedSourceCaches={},this._mergedOtherSourceCaches={},this._mergedSymbolSourceCaches={},this._mergedFillExtrusionSourceCaches={},this._clipLayerPresent=!1,this._hasAppearances=!1,this._has3DLayers=!1,this._hasCircleLayers=!1,this._hasSymbolLayers=!1,this._importedAsBasemap=!1,this._changes=i.styleChanges||new te,this._hasDataDrivenEmissive=!1,this.indoorManager=new Mn(this),this.dispatcher=i.dispatcher?i.dispatcher:new oi(Bi(),this),this.map.painter&&this.map.painter.context){const e=this.map.painter.context.maxUniformBufferBindings,t=Math.floor(this.map.painter.context.maxUniformBlockSize/4);this.dispatcher.broadcast("setContextParams",{maxBindingPoints:e,maxUniformBlockSizeDwords:t,disableSymbolUBO:this.map.painter.context.disableSymbolUBO})}i.imageManager?this.imageManager=i.imageManager:(this.imageManager=new Ze(this.map._spriteFormat),this.imageManager.setEventedParent(this)),this.imageManager.addScope(this.scope),this.glyphManager=i.glyphManager?i.glyphManager:new e.d4(t._requestManager,i.localFontFamily?e.d5.all:i.localIdeographFontFamily?e.d5.ideographs:e.d5.none,i.localFontFamily||i.localIdeographFontFamily,i.fontstackCompositing),i.modelManager?this.modelManager=i.modelManager:(this.modelManager=new gn(t._requestManager),this.modelManager.setEventedParent(this)),this._layers={},this._sourceCaches={},this._otherSourceCaches={},this._symbolSourceCaches={},this._fillExtrusionSourceCaches={},this._loaded=!1,this._initialBroadcastDone=!1,this._programPrecompiler=this.map._precompilePrograms&&this.isRootStyle()?new bn:null,this._availableImages=[],this._availableModels={},this._order=[],this._markersNeedUpdate=!1,this.options=i.configOptions?i.configOptions:/* @__PURE__ */new Map,this._configDependentLayers=i.configDependentLayers?i.configDependentLayers:/* @__PURE__ */new Set,this._indoorDependentLayers=i.indoorDependentLayers?i.indoorDependentLayers:/* @__PURE__ */new Set,this._config=i.config,this._styleColorTheme={lut:null,lutLoading:!1,lutLoadingCorrelationID:0,colorTheme:null,colorThemeOverride:i.colorThemeOverride},this._styleColorThemeForScope={},this._initialConfig=i.initialConfig,this.dispatcher.broadcast("setReferrer",e.d6()),this.dispatcher.broadcast("setConfig",e.d7());const r=this;this._rtlTextPluginCallback=On.registerForPluginStateChange(t=>{r.dispatcher.broadcast("syncRTLPluginState",{pluginStatus:t.pluginStatus,pluginURL:t.pluginURL},(t,i)=>{if(e.d8(t),i&&i.every(e=>e))for(const e in r._sourceCaches){const t=r._sourceCaches[e],i=t.getSource().type;"vector"!==i&&"geojson"!==i||t.reload()}})}),this.on("data",e=>{if("source"!==e.dataType||"metadata"!==e.sourceDataType)return;const t=this.getOwnSource(e.sourceId);if(t&&t.vectorLayerIds)for(const i in this._layers){const e=this._layers[i];e.source===t.id&&this._validateLayer(e)}})}load(e){return e?("string"==typeof e?this.loadURL(e):this.loadJSON(e),this):this}_getGlobalId(t){if(!t)return null;if("string"==typeof t){if(e.e(t))return t;const i=e.d9(t);if(!i.startsWith("http"))try{return new URL(i,location.href).toString()}catch(e){return i}return i}return`json://${e.da(JSON.stringify(t))}`}_diffStyle(t,i,r){this.globalId=this._getGlobalId(t);const n=(e,t)=>{try{t(null,this.setState(e,r))}catch(e){t(e,!1)}};if("string"==typeof t){const r=this.map._requestManager.normalizeStyleURL(t),o=this.map._requestManager.transformRequest(r,e.R.Style);e.m(o,(t,r)=>{t?this.fire(new e.y(t)):r&&n(r,i)})}else"object"==typeof t&&n(t,i)}loadURL(t,i={}){this.fire(new e.z("dataloading",{dataType:"style"}));const r="boolean"==typeof i.validate?i.validate:!e.e(t);this.globalId=this._getGlobalId(t),t=this.map._requestManager.normalizeStyleURL(t,i.accessToken),this.resolvedImports.add(t);const n=this.importsCache.get(t);if(n)return this._load(n,r);const o=this.map._requestManager.transformRequest(t,e.R.Style);this._request=e.m(o,(i,n)=>{if(this._request=null,i)this.fire(new e.y(i));else if(n)return this.importsCache.set(t,n),this._load(n,r)})}loadJSON(t,i={}){this.fire(new e.z("dataloading",{dataType:"style"})),this.globalId=this._getGlobalId(t),this._request=e.o.frame(()=>{this._request=null,this._load(t,!1!==i.validate)})}loadEmpty(){this.fire(new e.z("dataloading",{dataType:"style"})),this._load(Ln,!1)}_loadImports(t,i,r){if(this.importDepth>=4)return e.w("Style doesn't support nesting deeper than 5"),Promise.resolve();const n=[];for(const o of t){const t=this._createFragmentStyle(o),s=new Promise(e=>{t.once("style.import.load",e),t.once("error",e)}).then(()=>{this.mergeAll(),this.fire(new e.z("data",{dataType:"style"}))});if(n.push(s),this.resolvedImports.has(o.url)){t.loadEmpty();continue}const a=o.data||this.importsCache.get(o.url);a?(o.data?(t.fire(new e.z("dataloading",{dataType:"style"})),t.globalId=t._getGlobalId(a),queueMicrotask(()=>t._load(a,i))):t.loadJSON(a,{validate:i}),this._isInternalStyle(a)&&(t.globalId=null)):o.url?t.loadURL(o.url,{validate:i}):t.loadEmpty();const l={style:t,id:o.id,config:o.config};if(r){const e=this.fragments.findIndex(({id:e})=>e===r);this.fragments=this.fragments.slice(0,e).concat(l).concat(this.fragments.slice(e))}else this.fragments.push(l)}return Promise.allSettled(n)}getImportGlobalIds(e=this,t=/* @__PURE__ */new Set){for(const i of e.fragments)i.style.globalId&&t.add(i.style.globalId),this.getImportGlobalIds(i.style,t);return[...t.values()]}_createFragmentStyle(t){const i=this.scope?e.t(t.id,this.scope):t.id;let r;const n=this._initialConfig&&this._initialConfig[i];(t.config||n)&&(r=Object.assign({},t.config,n));const o=new On(this.map,{scope:i,styleChanges:this._changes,importDepth:this.importDepth+1,importsCache:this.importsCache,resolvedImports:new Set(this.resolvedImports),dispatcher:this.dispatcher,imageManager:this.imageManager,glyphManager:this.glyphManager,modelManager:this.modelManager,config:r,configOptions:this.options,colorThemeOverride:t["color-theme"],configDependentLayers:this._configDependentLayers,indoorDependentLayers:this._indoorDependentLayers});return o.setEventedParent(this.map,{style:o}),o}_reloadImports(e=!1){this.mergeAll(),this._updateMapProjection(),e||this.updateConfigDependencies(),this._updateLayers(this._indoorDependentLayers),this.map._triggerCameraUpdate(this.camera),(!e||this.isRootStyle()||this.map.style._initialBroadcastDone)&&(e&&this.isRootStyle()?(this.forEachFragmentStyle(e=>{this.dispatcher.broadcast("setLayers",{layers:e._serializeLayers(e._order),scope:e.scope,options:e.options})}),this._initialBroadcastDone=!0):this.dispatcher.broadcast("setLayers",{layers:this._serializeLayers(this._order),scope:this.scope,options:this.options}))}_isInternalStyle(e){return this.isRootStyle()&&(e.fragment||!!e.schema&&!1!==e.fragment)}_load(t,i){if(this._isInternalStyle(t)){const e=Object.assign({},Ln,{imports:[{id:"basemap",data:t,url:""}]},t.center?{center:t.center}:{},t.bearing?{bearing:t.bearing}:{},t.pitch?{pitch:t.pitch}:{},t.zoom?{zoom:t.zoom}:{},t.light?{light:t.light}:{});return this._importedAsBasemap=!0,void this._load(e,i)}if(this.updateConfig(this._config,t.schema),i&&Cn(this,It(t)))return;this._loaded=!0;for(const e in t.sources)this.addSource(e,t.sources[e],{validate:!1,isInitialLoad:!0});this.stylesheet=e.db(t);const r=()=>{if(t.iconsets)for(const e in t.iconsets)this.addIconset(e,t.iconsets[e]);t.sprite?this._loadIconset(t.sprite):(this.imageManager.setLoaded(!0,this.scope),this.dispatcher.broadcast("spriteLoaded",{scope:this.scope,isLoaded:!0})),!this.glyphManager.url&&t.glyphs&&this.glyphManager.setURL(t.glyphs);const r=Ni(this.stylesheet.layers);if(this._order=r.map(e=>e.id),this.stylesheet.light&&e.w("The `light` root property is deprecated, prefer using `lights` with `flat` light type instead."),this.stylesheet.lights)if(1===this.stylesheet.lights.length&&"flat"===this.stylesheet.lights[0].type){const e=this.stylesheet.lights[0];this.light=new jt(e.properties,e.id)}else this.setLights(this.stylesheet.lights);this.light||(this.light=new jt(this.stylesheet.light)),this._layers={};for(const t of r){const i=e.dh(t,this.scope,this._styleColorTheme.lut,this.options);0!==i.expressionDependencies.configDependencies.size&&this._configDependentLayers.add(i.fqid),i.expressionDependencies.isIndoorDependent&&this._indoorDependentLayers.add(i.fqid),this._hasAppearances=this._hasAppearances||0!==i.getAppearances().length,i.setEventedParent(this,{layer:{id:i.id}}),this._layers[i.id]=i;const r=this.getOwnLayerSourceCache(i),n=!!this.directionalLight&&this.directionalLight.shadowsEnabled();r&&i.canCastShadows()&&n&&(r.castsShadows=!0)}if(this.glyphManager.url){const e=/* @__PURE__ */new Set;for(const t in this._layers){const i=this._layers[t];if("symbol"===i.type&&i.layout){const t=i.layout.get("text-font");t&&t.value&&"constant"===t.value.kind&&e.add(t.value.value.join(","))}}for(const t of e)this.glyphManager.prefetchRange(t,0)}this.stylesheet.featuresets&&this.setFeaturesetSelectors(this.stylesheet.featuresets),this.stylesheet.models&&this.addModelURLs(this.stylesheet.models);const n=this.stylesheet.terrain;n&&(this.checkCanvasFingerprintNoise(),this.disableElevatedTerrain||this.terrainSetForDrapingOnly()||this._createTerrain(n,1)),this.stylesheet.fog&&this._createFog(this.stylesheet.fog),this.stylesheet.snow&&this._createSnow(this.stylesheet.snow),this.stylesheet.rain&&this._createRain(this.stylesheet.rain),this.stylesheet.transition&&this.setTransition(this.stylesheet.transition),this.fire(new e.z("data",{dataType:"style"}));const o=this.isRootStyle();t.imports?this._loadImports(t.imports,i).then(()=>{this._reloadImports(!0),this.fire(new e.z(o?"style.load":"style.import.load"))}).catch(t=>{this.fire(new e.y(new Error("Failed to load imports",t))),this.fire(new e.z(o?"style.load":"style.import.load"))}):(this._reloadImports(!0),this.fire(new e.z(o?"style.load":"style.import.load")))};this._styleColorTheme.colorTheme=this.stylesheet["color-theme"];const n=this._styleColorTheme.colorThemeOverride?this._styleColorTheme.colorThemeOverride:this._styleColorTheme.colorTheme;if(n){const t=this._evaluateColorThemeData(n);this._loadColorTheme(t).then(()=>{r()}).catch(t=>{e.w(`Couldn't load color theme from the stylesheet: ${t}`),r()})}else this._styleColorTheme.lut=null,r()}isRootStyle(){return 0===this.importDepth}hasAppearances(){return this._hasAppearances||this.fragments.some(e=>e.style.hasAppearances())}mergeAll(){let e,t,i,r,n,o,s,a,l,c;const h={};this.terrain&&this.terrain.scope!==this.scope&&delete this.terrain,this.forEachFragmentStyle(u=>{if(u.stylesheet){if(u.disableElevatedTerrain&&(this.disableElevatedTerrain=!0),null!=u.light&&(e=u.light),u.stylesheet.lights)for(const e of u.stylesheet.lights)"ambient"===e.type&&null!=u.ambientLight&&(t=u.ambientLight),"directional"===e.type&&null!=u.directionalLight&&(i=u.directionalLight);r=this._prioritizeTerrain(r,u.terrain,u.stylesheet.terrain),u.stylesheet.fog&&null!=u.fog&&(n=u.fog),u.stylesheet.snow&&null!=u.snow&&(o=u.snow),u.stylesheet.rain&&null!=u.rain&&(s=u.rain),null!=u.stylesheet.camera&&(c=u.stylesheet.camera),null!=u.stylesheet.projection&&(a=u.stylesheet.projection),null!=u.stylesheet.transition&&(l=u.stylesheet.transition),h[u.scope]=u._styleColorTheme}}),this.light=e,this.ambientLight=t,this.directionalLight=i,this.fog=n,this.snow=o,this.rain=s,this._styleColorThemeForScope=h,null===r?delete this.terrain:this.terrain=r,this.camera=c||{"camera-projection":"perspective"},this.projection=a||{name:"mercator"},this.transition=Object.assign({},Fn,l),this.mergeSources(),this.mergeLayers(),this.mergeIndoor(),this._programPrecompiler&&this._programPrecompiler.reset()}forEachFragmentStyle(e){const t=i=>{for(const e of i.fragments)t(e.style);e(i)};t(this)}_prioritizeTerrain(e,t,i){const r=e&&0===e.drapeRenderMode;return null===i?t&&0===t.drapeRenderMode?t:r?e:null:null!=t&&(!e||r||t&&1===t.drapeRenderMode)?t:e}mergeTerrain(){let e;this.terrain&&this.terrain.scope!==this.scope&&delete this.terrain,this.forEachFragmentStyle(t=>{e=this._prioritizeTerrain(e,t.terrain,t.stylesheet.terrain)}),null===e?delete this.terrain:this.terrain=e,this._programPrecompiler&&this._programPrecompiler.reset()}mergeProjection(){let e;this.forEachFragmentStyle(t=>{null!=t.stylesheet.projection&&(e=t.stylesheet.projection)}),this.projection=e||{name:"mercator"},this._programPrecompiler&&this._programPrecompiler.reset()}mergeSources(){const t={},i={},r={},n={};this.forEachFragmentStyle(o=>{for(const i in o._sourceCaches){const r=e.t(i,o.scope);t[r]=o._sourceCaches[i]}for(const t in o._otherSourceCaches){const r=e.t(t,o.scope);i[r]=o._otherSourceCaches[t]}for(const t in o._symbolSourceCaches){const i=e.t(t,o.scope);r[i]=o._symbolSourceCaches[t]}for(const t in o._fillExtrusionSourceCaches){const i=e.t(t,o.scope);n[i]=o._fillExtrusionSourceCaches[t]}}),this._mergedSourceCaches=t,this._mergedOtherSourceCaches=i,this._mergedSymbolSourceCaches=r,this._mergedFillExtrusionSourceCaches=n}mergeIndoor(){this.forEachFragmentStyle(t=>{if(t.stylesheet&&t.stylesheet.indoor)for(const i of Object.values(t.stylesheet.indoor)){const r=i,n=e.t(r.sourceId,t.scope);this._mergedIndoor[n]=new Set(r.sourceLayers||[])}})}mergeLayers(){const t={},i=[],r={};this._mergedSlots=[],this._has3DLayers=!1,this._hasCircleLayers=!1,this._hasSymbolLayers=!1,this.forEachFragmentStyle(r=>{for(const n of r._order){const o=r._layers[n];if("slot"===o.type){const i=e.dc(n);if(t[i])continue;t[i]=[]}o.slot&&t[o.slot]?t[o.slot].push(o):i.push(o)}}),this._mergedOrder=[];let n=-1;const o=(i=[])=>{for(const s of i)if("slot"===s.type){const i=e.dc(s.id);t[i]&&o(t[i]),this._mergedSlots.push(i)}else{const t=e.t(s.id,s.scope);this._mergedOrder.push(t),r[t]=s,s.is3D(!!this.terrain)&&(this._has3DLayers=!0,n=this._mergedOrder.length-1),"circle"===s.type&&(this._hasCircleLayers=!0),"symbol"===s.type&&(this._hasSymbolLayers=!0),"clip"===s.type&&(this._clipLayerPresent=!0)}};if(o(i),this._has3DLayers){const e={};for(let t=0;t<this._mergedOrder.length;++t){const i=this._mergedOrder[t];e[i]=t===n?1:t<n?r[i].hasOcclusionOpacityProperties?2:0:4}this._mergedOrder.sort((t,i)=>e[t]-e[i])}this._mergedLayers=r,this.updateDrapeFirstLayers(),this._buildingIndex.processLayersChanged(),this._updateDataDrivenEmissiveStrength()}terrainSetForDrapingOnly(){return!!this.terrain&&0===this.terrain.drapeRenderMode}getCamera(){return this.stylesheet.camera}setCamera(e){return this.stylesheet.camera=Object.assign({},this.stylesheet.camera,e),this.camera=this.stylesheet.camera,this}_evaluateColorThemeData(t){return t.data?function(t,i,r){const n=Object.assign({},i);for(const e of Object.keys(wn))void 0===n[e]&&(n[e]=wn[e].default);const o=new e.a7(Tn,t,new Map(r));return o.setTransitionOrValue(n,r),o.untransitioned().possiblyEvaluate(new e.ab(0,{worldview:void 0}))}(this.scope,t,this.options).get("data"):null}_loadColorTheme(t){this._styleColorTheme.lutLoading=!0,this._styleColorTheme.lutLoadingCorrelationID+=1;const i=this._styleColorTheme.lutLoadingCorrelationID;return new Promise((r,n)=>{const o="data:image/png;base64,";if(!t||0===t.length)return this._styleColorTheme.lut=null,this._styleColorTheme.lutLoading=!1,void r();let s=t;s.startsWith(o)||(s=o+s);const a=e.I.from("mapbox-reserved-lut"),l=new Image;l.src=s,l.onerror=()=>{this._styleColorTheme.lutLoading=!1,n(/* @__PURE__ */new Error("Failed to load image data"))},l.onload=()=>{if(this._styleColorTheme.lutLoadingCorrelationID!==i)return void r();this._styleColorTheme.lutLoading=!1;const{width:o,height:s,data:c}=e.o.getImageData(l);if(s>32)return void n(/* @__PURE__ */new Error("The height of the image must be less than or equal to 32 pixels."));if(o!==s*s)return void n(/* @__PURE__ */new Error("The width of the image must be equal to the height squared."));this.getImage(a)&&this.removeImage(a),this.addImage(a,{data:new e.q({width:o,height:s},c),pixelRatio:1,sdf:!1,usvg:!1,version:0});const h=this.imageManager.getImage(a,this.scope);h?(this._styleColorTheme.lut={image:h.data,data:t},r()):n(/* @__PURE__ */new Error("Missing LUT image."))}})}getLut(e){const t=this._styleColorThemeForScope[e];return t?t.lut:null}setProjection(e){e?this.stylesheet.projection=e:delete this.stylesheet.projection,this.mergeProjection(),this._updateMapProjection()}applyProjectionUpdate(){this._loaded&&(this.dispatcher.broadcast("setProjection",this.map.transform.projectionOptions),this.map.transform.projection.requiresDraping?(this.getTerrain()||this.stylesheet.terrain)&&!this.disableElevatedTerrain||this.setTerrainForDraping():this.terrainSetForDrapingOnly()&&this.setTerrain(null,0))}_updateMapProjection(){this.isRootStyle()&&(this.map._useExplicitProjection?this.applyProjectionUpdate():this.map._prioritizeAndUpdateProjection(null,this.projection))}_loadSprite(t){this._spriteRequest=function(t,i,r){let n,o,s;const a=e.o.devicePixelRatio>1?"@2x":"";let l=e.m(i.transformRequest(i.normalizeSpriteURL(t,a,".json"),e.R.SpriteJSON),(e,t)=>{l=null,s||(s=e,n=t,h())}),c=e.n(i.transformRequest(i.normalizeSpriteURL(t,a,".png"),e.R.SpriteImage),(e,t)=>{c=null,s||(s=e,o=t,h())});function h(){if(s)r(s);else if(n&&o){const t=e.o.getImageData(o),i={};for(const r in n){const{width:o,height:s,x:a,y:l,sdf:c,pixelRatio:h,stretchX:u,stretchY:d,content:p}=n[r],f=new e.q({width:o,height:s});e.q.copy(t,f,{x:a,y:l},{x:0,y:0},{width:o,height:s},null),i[r]={data:f,pixelRatio:void 0!==h?h:1,sdf:void 0!==c&&c,stretchX:u,stretchY:d,content:p,usvg:!1,version:0}}r(null,i)}}return{cancel(){l&&(l.cancel(),l=null),c&&(c.cancel(),c=null)}}}(t,this.map._requestManager,(t,i)=>{if(this._spriteRequest=null,t)this.fire(new e.y(t));else if(i){const t=/* @__PURE__ */new Map;for(const r in i)t.set(e.I.from(r),i[r]);this.addImages(t)}this.imageManager.setLoaded(!0,this.scope),this.dispatcher.broadcast("spriteLoaded",{scope:this.scope,isLoaded:!0}),this.fire(new e.z("data",{dataType:"style"}))})}addIconset(t,i){if("sprite"===i.type)return void this._loadSprite(i.url);const r=this.getOwnSourceCache(i.source);if(!r)return void this.fire(new e.y(/* @__PURE__ */new Error(`Source "${i.source}" as specified by iconset "${t}" does not exist and cannot be used as an iconset source`)));const n=r.getSource();if("raster-array"!==n.type)return void this.fire(new e.y(/* @__PURE__ */new Error(`Source "${i.source}" as specified by iconset "${t}" is not a "raster-array" source and cannot be used as an iconset source`)));n.partial=!1;const o=new En(t,this.scope,r);this.imageManager.addImageProvider(o,this.scope)}removeIconset(e){this.imageManager.removeImageProvider(e,this.scope)}_loadIconset(t){if(!e.e(t)&&"icon_set"!==this.map._spriteFormat||"raster"===this.map._spriteFormat)return void this._loadSprite(t);const i="auto"===this.map._spriteFormat;var r,n;this._spriteRequest=(n=(r,n)=>{if(this._spriteRequest=null,r)i?this._loadSprite(t):this.fire(new e.y(r));else if(n){const t=/* @__PURE__ */new Map;for(const i in n)t.set(e.I.from(i),n[i]);this.addImages(t)}this.imageManager.setLoaded(!0,this.scope),this.dispatcher.broadcast("spriteLoaded",{scope:this.scope,isLoaded:!0}),this.fire(new e.z("data",{dataType:"style"}))},e.b4((r=this.map._requestManager).transformRequest(r.normalizeIconsetURL(t),e.R.Iconset),(t,i)=>{if(t)return void n(t);const r={},o=new e.b2(i).readFields(ne,{icons:[]},void 0);for(const n of o.icons){const t={version:1,pixelRatio:e.o.devicePixelRatio,content:Sn(n),stretchX:n.metadata?In(n.metadata.stretch_x_areas):void 0,stretchY:n.metadata?In(n.metadata.stretch_y_areas):void 0,sdf:!1,usvg:!0,icon:n};r[n.name]=t}n(null,r)}))}_validateLayer(t){const i=this.getOwnSource(t.source);if(!i)return;const r=t.sourceLayer;r&&("geojson"===i.type||i.vectorLayerIds&&!i.vectorLayerIds.includes(r))&&this.fire(new e.y(/* @__PURE__ */new Error(`Source layer "${r}" does not exist on source "${i.id}" as specified by style layer "${t.id}"`)))}loaded(){if(!this._loaded)return!1;if(Object.keys(this._changes.getUpdatedSourceCaches()).length)return!1;for(const e in this._sourceCaches)if(!this._sourceCaches[e].loaded())return!1;if(!this.imageManager.isLoaded())return!1;if(this.imageManager.hasPatternsInFlight())return!1;if(!this.modelManager.isLoaded())return!1;if(this._styleColorTheme.lutLoading)return!1;for(const{style:e}of this.fragments)if(!e.loaded())return!1;return!0}_serializeImports(){if(this.stylesheet.imports)return this.stylesheet.imports.map((e,t)=>{const i=this.fragments[t];return i&&i.style&&(e.data=i.style.serialize()),e})}_serializeSources(){const e={};for(const t in this._sourceCaches){const i=this._sourceCaches[t].getSource();e[i.id]||(e[i.id]=i.serialize())}return e}_serializeLayers(e){const t=[];for(const i of e){const e=this._layers[i];e&&"custom"!==e.type&&t.push(e.serialize())}return t}hasLightTransitions(){return!(!this.light||!this.light.hasTransition())||!(!this.ambientLight||!this.ambientLight.hasTransition())||!(!this.directionalLight||!this.directionalLight.hasTransition())}hasFogTransition(){return!!this.fog&&this.fog.hasTransition()}hasSnowTransition(){return!!this.snow&&this.snow.hasTransition()}hasRainTransition(){return!!this.rain&&this.rain.hasTransition()}hasTransitions(){if(this.hasLightTransitions())return!0;if(this.hasFogTransition())return!0;if(this.hasSnowTransition())return!0;if(this.hasRainTransition())return!0;for(const e in this._sourceCaches)if(this._sourceCaches[e].hasTransition())return!0;for(const e in this._layers)if(this._layers[e].hasTransition())return!0;return!1}_updateDataDrivenEmissiveStrength(){for(const e in this._mergedLayers){const t=this._mergedLayers[e];if(t._transitionablePaint&&t._transitionablePaint._values){const e=t._transitionablePaint._values["line-emissive-strength"];if(e&&e.value&&e.value.isDataDriven())return void(this._hasDataDrivenEmissive=!0)}}this._hasDataDrivenEmissive=!1}hasDataDrivenEmissiveStrength(){return this._hasDataDrivenEmissive}get order(){return this.terrain?this._drapedFirstOrder:this._mergedOrder}_getOrder(e){return e?this.order:this._mergedOrder}isLayerDraped(e){return!!this.terrain&&e.isDraped(this.getLayerSourceCache(e))}_checkLoaded(){if(!this._loaded)throw new Error("Style is not done loading")}_checkLayer(t){const i=this.getOwnLayer(t);if(i)return i;this.fire(new e.y(/* @__PURE__ */new Error(`The layer '${t}' does not exist in the map's style.`)))}_checkSource(t){const i=this.getOwnSource(t);if(i)return i;this.fire(new e.y(/* @__PURE__ */new Error(`The source '${t}' does not exist in the map's style.`)))}handleIdle(){const e=this.map.painter;e&&(e.context.sweepPendingPrograms(),this._programPrecompiler&&this._programPrecompiler.processQueue(e,this))}handleContextLost(){this._programPrecompiler&&this._programPrecompiler.reset()}update(t){if(!this._loaded)return;this.ambientLight&&this.ambientLight.recalculate(t),this.directionalLight&&this.directionalLight.recalculate(t);const i=this.calculateLightsBrightness();t.brightness=i||0,i!==this._brightness&&(this._brightness=i,this.dispatcher.broadcast("setBrightness",i)),t.worldview!==this._worldview&&(this._worldview=t.worldview,this.dispatcher.broadcast("setWorldview",this._worldview));const r=this._changes.isDirty();let n=!1;if(this._changes.isDirty()){const e=this._changes.getLayerUpdatesByScope();for(const t in e){const{updatedIds:i,removedIds:r}=e[t];(i||r)&&(this._updateWorkerLayers(t,i,r),n=!0)}this.updateSourceCaches(),this._updateTilesForChangedImages(),this.updateLayers(t),this.light&&this.light.updateTransitions(t),this.ambientLight&&this.ambientLight.updateTransitions(t),this.directionalLight&&this.directionalLight.updateTransitions(t),this.fog&&this.fog.updateTransitions(t),this.snow&&this.snow.updateTransitions(t),this.rain&&this.rain.updateTransitions(t),this._changes.reset()}const o={};for(const e in this._mergedSourceCaches){const t=this._mergedSourceCaches[e];o[e]=t.used,t.used=!1,t.tileCoverLift=0}const s={};for(const l of this._mergedOrder){const i=this._mergedLayers[l];if(("none"!==i.visibility||i.hasTransition())&&i.recalculate(t,this._availableImages),!i.isHidden(t.zoom)){zn.has(i.type)&&e.dd();const t=this.getLayerSourceCache(i);t&&(t.used=!0,t.tileCoverLift=Math.max(t.tileCoverLift,i.tileCoverLift()))}if("fill-extrusion"===i.type){const t=e.t(i.source,i.scope);if(t in this._mergedFillExtrusionSourceCaches){const e=i.layout&&i.layout.get("source-max-zoom");if(null!=e){const i=s[t];s[t]=null==i?e:Math.min(i,e)}}}}if(this._programPrecompiler&&this._programPrecompiler.needsBuild()){const e=this._mergedOrder.map(e=>this._mergedLayers[e]);this._programPrecompiler.buildQueue(e,t,this)}for(const e in this._mergedFillExtrusionSourceCaches)this._mergedFillExtrusionSourceCaches[e].setMaxzoomOverride(null!=s[e]?s[e]:null);this.terrain&&n&&this.mergeLayers();const a=this.imageManager.getPendingImageProviders();for(const e of a)e.sourceCache.used=!0;for(const l in o){const t=this._mergedSourceCaches[l];o[l]!==t.used&&t.getSource().fire(new e.z("data",{sourceDataType:"visibility",dataType:"source",sourceId:t.getSource().id}))}this.light&&this.light.recalculate(t),this.terrain&&this.terrain.recalculate(t),this.fog&&this.fog.recalculate(t),this.snow&&this.snow.recalculate(t),this.rain&&this.rain.recalculate(t),this.z=t.zoom,this._markersNeedUpdate&&(this._updateMarkersOpacity(),this._markersNeedUpdate=!1),this.imageManager.clearUpdatedImages(this.scope),r&&this.fire(new e.z("data",{dataType:"style"}))}updateImageProviders(){const e=this.imageManager.getPendingImageProviders();for(const t of e){const e=t.resolvePendingRequests(),i=this.getFragmentStyle(t.scope);i&&i.addImages(e)}}_updateTilesForChangedImages(){const e={};for(const t in this._mergedSourceCaches){const i=this._mergedSourceCaches[t].getSource().scope;e[i]=e[i]||this._changes.getUpdatedImages(i),0!==e[i].length&&this._mergedSourceCaches[t].reloadTilesForDependencies(["icons","patterns"],e[i])}for(const t in e)this._changes.resetUpdatedImages(t)}_updateWorkerLayers(e,t,i){const r=this.getFragmentStyle(e);r&&this.dispatcher.broadcast("updateLayers",{layers:t?r._serializeLayers(t):[],scope:e,removedIds:i||[],options:r.options})}setState(t,i){if(this._checkLoaded(),Cn(this,It(t)))return!1;(t=e.db(t)).layers=Ni(t.layers);const r=function(t,i){if(!t)return[{command:Ui.setStyle,args:[i]}];let r=[];try{if(!e.b9(t.version,i.version))return[{command:Ui.setStyle,args:[i]}];if(e.b9(t.center,i.center)||r.push({command:Ui.setCenter,args:[i.center]}),e.b9(t.zoom,i.zoom)||r.push({command:Ui.setZoom,args:[i.zoom]}),e.b9(t.bearing,i.bearing)||r.push({command:Ui.setBearing,args:[i.bearing]}),e.b9(t.pitch,i.pitch)||r.push({command:Ui.setPitch,args:[i.pitch]}),e.b9(t.sprite,i.sprite)||r.push({command:Ui.setSprite,args:[i.sprite]}),e.b9(t.glyphs,i.glyphs)||r.push({command:Ui.setGlyphs,args:[i.glyphs]}),e.b9(t.imports,i.imports)||function(t=[],i=[],r){i=i||[];const n=(t=t||[]).map(qi),o=i.map(qi),s=t.reduce(Zi,{}),a=i.reduce(Zi,{}),l=n.slice();let c,h,u,d;for(c=0,h=0;c<n.length;c++)u=n[c],Object.hasOwn(a,u)?h++:(r.push({command:Ui.removeImport,args:[u]}),l.splice(l.indexOf(u,h),1));for(c=0,h=0;c<o.length;c++)u=o[o.length-1-c],l[l.length-1-c]!==u&&(Object.hasOwn(s,u)?(r.push({command:Ui.removeImport,args:[u]}),l.splice(l.lastIndexOf(u,l.length-h),1)):h++,d=l[l.length-c],r.push({command:Ui.addImport,args:[a[u],d]}),l.splice(l.length-c,0,u));for(const p of i){const t=s[p.id];t&&(delete t.data,e.b9(t,p)||r.push({command:Ui.updateImport,args:[p.id,p]}))}}(t.imports,i.imports,r),e.b9(t.transition,i.transition)||r.push({command:Ui.setTransition,args:[i.transition]}),e.b9(t.light,i.light)||r.push({command:Ui.setLight,args:[i.light]}),e.b9(t.fog,i.fog)||r.push({command:Ui.setFog,args:[i.fog]}),e.b9(t.snow,i.snow)||r.push({command:Ui.setSnow,args:[i.snow]}),e.b9(t.rain,i.rain)||r.push({command:Ui.setRain,args:[i.rain]}),e.b9(t.projection,i.projection)||r.push({command:Ui.setProjection,args:[i.projection]}),e.b9(t.lights,i.lights)||r.push({command:Ui.setLights,args:[i.lights]}),e.b9(t.camera,i.camera)||r.push({command:Ui.setCamera,args:[i.camera]}),e.b9(t.iconsets,i.iconsets)||function(t,i,r){let n;for(n in i=i||{},t=t||{})Object.hasOwn(t,n)&&(Object.hasOwn(i,n)||r.push({command:Ui.removeIconset,args:[n]}));for(n in i){if(!Object.hasOwn(i,n))continue;const o=i[n];Object.hasOwn(t,n)?e.b9(t[n],o)||(r.push({command:Ui.removeIconset,args:[n]}),r.push({command:Ui.addIconset,args:[n,o]})):r.push({command:Ui.addIconset,args:[n,o]})}}(t.iconsets,i.iconsets,r),!e.b9(t["color-theme"],i["color-theme"]))return[{command:Ui.setStyle,args:[i]}];const n={},o=[];!function(t,i,r,n){let o;for(o in i=i||{},t=t||{})Object.hasOwn(t,o)&&(Object.hasOwn(i,o)||ji(o,r,n));for(o in i){if(!Object.hasOwn(i,o))continue;const s=i[o];Object.hasOwn(t,o)?e.b9(t[o],s)||("geojson"===t[o].type&&"geojson"===s.type&&Hi(t,i,o)?r.push({command:Ui.setGeoJSONSourceData,args:[o,s.data]}):Gi(o,i,r,n)):Vi(o,i,r)}}(t.sources,i.sources,o,n);const s=[];t.layers&&t.layers.forEach(e=>{e.source&&n[e.source]?r.push({command:Ui.removeLayer,args:[e.id]}):s.push(e)});let a=t.terrain;a&&n[a.source]&&(r.push({command:Ui.setTerrain,args:[void 0]}),a=void 0),r=r.concat(o),e.b9(a,i.terrain)||r.push({command:Ui.setTerrain,args:[i.terrain]}),function(t,i,r){i=i||[];const n=(t=t||[]).map(qi),o=i.map(qi),s=t.reduce(Zi,{}),a=i.reduce(Zi,{}),l=n.slice(),c=Object.create(null);let h,u,d,p,f,m,_;for(h=0,u=0;h<n.length;h++)d=n[h],Object.hasOwn(a,d)?u++:(r.push({command:Ui.removeLayer,args:[d]}),l.splice(l.indexOf(d,u),1));for(h=0,u=0;h<o.length;h++)d=o[o.length-1-h],l[l.length-1-h]!==d&&(Object.hasOwn(s,d)?(r.push({command:Ui.removeLayer,args:[d]}),l.splice(l.lastIndexOf(d,l.length-u),1)):u++,m=l[l.length-h],r.push({command:Ui.addLayer,args:[a[d],m]}),l.splice(l.length-h,0,d),c[d]=!0);for(h=0;h<o.length;h++)if(d=o[h],p=s[d],f=a[d],!c[d]&&!e.b9(p,f))if(e.b9(p.source,f.source)&&e.b9(p["source-layer"],f["source-layer"])&&e.b9(p.type,f.type)){for(_ in $i(p.layout,f.layout,r,d,null,Ui.setLayoutProperty),$i(p.paint,f.paint,r,d,null,Ui.setPaintProperty),e.b9(p.slot,f.slot)||r.push({command:Ui.setSlot,args:[d,f.slot]}),e.b9(p.filter,f.filter)||r.push({command:Ui.setFilter,args:[d,f.filter]}),e.b9(p.minzoom,f.minzoom)&&e.b9(p.maxzoom,f.maxzoom)||r.push({command:Ui.setLayerZoomRange,args:[d,f.minzoom,f.maxzoom]}),p)Object.hasOwn(p,_)&&"layout"!==_&&"paint"!==_&&"filter"!==_&&"metadata"!==_&&"minzoom"!==_&&"maxzoom"!==_&&"slot"!==_&&(0===_.indexOf("paint.")?$i(p[_],f[_],r,d,_.slice(6),Ui.setPaintProperty):e.b9(p[_],f[_])||r.push({command:Ui.setLayerProperty,args:[d,_,f[_]]}));for(_ in f)Object.hasOwn(f,_)&&!Object.hasOwn(p,_)&&"layout"!==_&&"paint"!==_&&"filter"!==_&&"metadata"!==_&&"minzoom"!==_&&"maxzoom"!==_&&"slot"!==_&&(0===_.indexOf("paint.")?$i(p[_],f[_],r,d,_.slice(6),Ui.setPaintProperty):e.b9(p[_],f[_])||r.push({command:Ui.setLayerProperty,args:[d,_,f[_]]}))}else r.push({command:Ui.removeLayer,args:[d]}),m=l[l.lastIndexOf(d)+1],r.push({command:Ui.addLayer,args:[f,m]})}(s,i.layers,r)}catch(e){console.warn("Unable to compute style diff:",e),r=[{command:Ui.setStyle,args:[i]}]}return r}(this.serialize(),t).filter(e=>!(e.command in Dn));if(0===r.length)return!1;const n=r.filter(e=>!(e.command in Pn));if(n.length>0)throw new Error(`Unimplemented: ${n.map(e=>e.command).join(", ")}.`);const o=[];return r.forEach(e=>{o.push(this[e.command](...e.args))}),i&&Promise.all(o).then(i).catch(i),this.stylesheet=t,this.mergeAll(),this.dispatcher.broadcast("setLayers",{layers:this._serializeLayers(this._order),scope:this.scope,options:this.options}),!0}_updateWorkerImages(){this._availableImages=this.imageManager.listImages(this.scope),this.dispatcher.broadcast("setImages",{scope:this.scope,images:this._availableImages})}_updateWorkerModels(){this._availableModels=this.modelManager.getModelURIs(this.scope),this.dispatcher.broadcast("setModels",{scope:this.scope,models:this._availableModels})}addImages(t){if(0===t.size)return this;for(const[i,r]of t.entries()){if(this.getImage(i))return this.fire(new e.y(/* @__PURE__ */new Error(`An image with the name "${i.name}" already exists.`)));this.imageManager.addImage(i,this.scope,r),this._changes.updateImage(i,this.scope)}return this._updateWorkerImages(),this.fire(new e.z("data",{dataType:"style"})),this}addImage(t,i){return this.getImage(t)?this.fire(new e.y(/* @__PURE__ */new Error(`An image with the name "${t.name}" already exists.`))):(this.imageManager.addImage(t,this.scope,i),this._changes.updateImage(t,this.scope),this._updateWorkerImages(),this.fire(new e.z("data",{dataType:"style"})),this)}updateImage(t,i,r=!1){this.imageManager.updateImage(t,this.scope,i),r&&(this._changes.updateImage(t,this.scope),this._updateWorkerImages(),this.fire(new e.z("data",{dataType:"style"})))}getImage(e){return this.imageManager.getImage(e,this.scope)}removeImage(t){return this.getImage(t)?(this.imageManager.removeImage(t,this.scope),this._changes.updateImage(t,this.scope),this._updateWorkerImages(),this.fire(new e.z("data",{dataType:"style"})),this):this.fire(new e.y(/* @__PURE__ */new Error("No image with this name exists.")))}listImages(){return this._checkLoaded(),this._availableImages.slice()}getActualScope(){return this._importedAsBasemap?"basemap":this.scope}addModelURLs(t){return this.modelManager.addModelURLs(t,this.getActualScope()),this._updateWorkerModels(),this.fire(new e.z("data",{dataType:"style"})),this}addModel(t,i,r={}){return this._checkLoaded(),this._validate(Bt,`models.${t}`,i,null,r)||(this.modelManager.addModel(t,i,this.getActualScope()),this.fire(new e.z("data",{dataType:"style"}))),this}hasModel(e){return this.modelManager.hasModel(e,this.getActualScope())}removeModel(t){return this.hasModel(t)?(this.modelManager.removeModel(t,this.getActualScope(),!1,!0),this.fire(new e.z("data",{dataType:"style"})),this):this.fire(new e.y(/* @__PURE__ */new Error("No model with this ID exists.")))}listModels(){return this._checkLoaded(),this.modelManager.listModels(this.getActualScope())}addSource(t,i,r={}){if(this._checkLoaded(),void 0!==this.getOwnSource(t))throw new Error(`There is already a source with ID "${t}".`);if(!i.type)throw new Error(`The type property must be defined, but only the following properties were given: ${Object.keys(i).join(", ")}.`);if(["vector","raster","geojson","video","image"].includes(i.type)&&this._validate(Et,`sources.${t}`,i,null,r))return;this.map&&this.map._collectResourceTiming&&(i.collectResourceTiming=!0);const n=wi(t,i,this.dispatcher,this);n.scope=this.scope,n.setEventedParent(this,()=>({isSourceLoaded:this._isSourceCacheLoaded(n.id),source:n.serialize(),sourceId:n.id}));const o=t=>{const i=(t===e.b7.Symbol?"symbol:":t===e.b7.FillExtrusion?"fill-extrusion:":"other:")+n.id,r=e.t(i,this.scope),o=this._sourceCaches[i]=new Ri(r,n,t);t===e.b7.Symbol?this._symbolSourceCaches[n.id]=o:t===e.b7.FillExtrusion?this._fillExtrusionSourceCaches[n.id]=o:this._otherSourceCaches[n.id]=o,o.onAdd(this.map)};o(e.b7.Other),"vector"!==i.type&&"geojson"!==i.type||(o(e.b7.Symbol),"vector"===i.type&&o(e.b7.FillExtrusion)),n.onAdd&&n.onAdd(this.map),r.isInitialLoad||(this.mergeSources(),this._changes.setDirty())}removeSource(t){this._checkLoaded();const i=this.getOwnSource(t);if(!i)throw new Error("There is no source with this ID");for(const n in this._layers)if(this._layers[n].source===t)return this.fire(new e.y(/* @__PURE__ */new Error(`Source "${t}" cannot be removed while layer "${n}" is using it.`)));if(this.terrain&&this.terrain.scope===this.scope&&this.terrain.get().source===t)return this.fire(new e.y(/* @__PURE__ */new Error(`Source "${t}" cannot be removed while terrain is using it.`)));if(this.stylesheet.iconsets){const i=Object.entries(this.stylesheet.iconsets).find(([e,i])=>"source"===i.type&&i.source===t);if(i)return this.fire(new e.y(/* @__PURE__ */new Error(`Source "${t}" cannot be removed while iconset "${i[0]}" is using it.`)))}const r=this.getOwnSourceCaches(t);for(const n of r){const t=e.dc(n.id);delete this._sourceCaches[t],this._changes.discardSourceCacheUpdate(n.id),n.fire(new e.z("data",{sourceDataType:"metadata",dataType:"source",sourceId:n.getSource().id})),n.setEventedParent(null),n.clearTiles()}return delete this._otherSourceCaches[t],delete this._symbolSourceCaches[t],delete this._fillExtrusionSourceCaches[t],this.mergeSources(),i.setEventedParent(null),i.onRemove&&i.onRemove(this.map),this._changes.setDirty(),this}setGeoJSONSourceData(e,t){this._checkLoaded(),this.getOwnSource(e).setData(t),this._changes.setDirty()}getOwnSource(e){const t=this.getOwnSourceCache(e);return t&&t.getSource()}getOwnSources(){const e=[];for(const t in this._otherSourceCaches){const i=this.getOwnSourceCache(t);i&&e.push(i.getSource())}return e}areTilesLoaded(){const e=this._mergedSourceCaches;for(const t in e){const i=e[t]._tiles;for(const e in i){const t=i[e];if("loaded"!==t.state&&"errored"!==t.state)return!1}}return!0}setLights(t){if(this._checkLoaded(),this._programPrecompiler&&this._programPrecompiler.reset(),!t)return delete this.ambientLight,void delete this.directionalLight;const i=this._getTransitionParameters();for(const e of t){if(this._validate(Mt,"lights",e))return;switch(e.type){case"ambient":if(this.ambientLight){const t=this.ambientLight;t.set(e),t.updateTransitions(i)}else this.ambientLight=new si(e,li(),this.scope,this.options);break;case"directional":if(this.directionalLight){const t=this.directionalLight;t.set(e),t.updateTransitions(i)}else this.directionalLight=new si(e,hi(),this.scope,this.options)}}const r=Object.assign(i,{worldview:this.map.getWorldview()}),n=new e.ab(this.z||0,r);this.ambientLight&&this.ambientLight.recalculate(n),this.directionalLight&&this.directionalLight.recalculate(n),this._brightness=this.calculateLightsBrightness(),this.dispatcher.broadcast("setBrightness",this._brightness)}calculateLightsBrightness(){const t=this.directionalLight,i=this.ambientLight;if(!t||!i)return;const r=e=>.2126*(e[0]<=.03928?e[0]/12.92:Math.pow((e[0]+.055)/1.055,2.4))+.7152*(e[1]<=.03928?e[1]/12.92:Math.pow((e[1]+.055)/1.055,2.4))+.0722*(e[2]<=.03928?e[2]/12.92:Math.pow((e[2]+.055)/1.055,2.4)),n=t.properties.get("color").toNonPremultipliedRenderColor(null).toArray01(),o=t.properties.get("intensity"),s=t.properties.get("direction"),a=1-e.cT(s.x,s.y,s.z)[2]/90,l=r(n)*o*a,c=i.properties.get("color").toNonPremultipliedRenderColor(null).toArray01(),h=i.properties.get("intensity"),u=r(c)*h;return Number(((l+u)/2).toFixed(6))}getBrightness(){return this._brightness}getLights(){if(!this.enable3dLights())return null;const e=[];return this.directionalLight&&e.push(this.directionalLight.get()),this.ambientLight&&e.push(this.ambientLight.get()),e}enable3dLights(){return!!this.ambientLight&&!!this.directionalLight}getFragmentStyle(t){if(null==t||""===t&&this.isRootStyle())return this;if(e.de(t)){const i=e.df(t),r=this.fragments.find(({id:e})=>e===i);if(!r)return;const n=e.dc(t);return r.style.getFragmentStyle(n)}{const e=this.fragments.find(({id:e})=>e===t);return e?e.style:void 0}}setFeaturesetSelectors(t){if(!t)return;const i=(e,t="")=>`${e}::${t}`;this._featuresetSelectors={};for(const r in t){const n={},o=this._featuresetSelectors[r]=[];for(const s of t[r].selectors){if(s.featureNamespace){const t=this.getOwnLayer(s.layer);if(!t){e.w(`Layer is undefined for selector: ${s.layer}`);continue}const o=i(t.source,t.sourceLayer);if(o in n&&n[o]!==s.featureNamespace){e.w(`"featureNamespace ${s.featureNamespace} of featureset ${r}'s selector is not associated to the same source, skip this selector`);continue}n[o]=s.featureNamespace}let t;if(s.properties)for(const i in s.properties){const r=e.U(s.properties[i]);"success"===r.result&&(t=t||{},t[i]=r.value)}o.push({layerId:s.layer,namespace:s.featureNamespace,properties:t,uniqueFeatureID:s._uniqueFeatureID})}}}getFeaturesetDescriptors(e){const t=this.getFragmentStyle(e);if(!t||!t.stylesheet.featuresets)return[];const i=[];for(const r in t.stylesheet.featuresets)i.push({featuresetId:r,importId:t.scope?t.scope:void 0});return i}getFeaturesetLayers(t,i){const r=this.getFragmentStyle(i),n=r.stylesheet.featuresets;if(!n||!n[t])return this.fire(new e.y(/* @__PURE__ */new Error(`The featureset '${t}' does not exist in the map's style and cannot be queried.`))),[];const o=[];for(const e of n[t].selectors){const t=r.getOwnLayer(e.layer);t&&o.push(t)}return o}getConfigProperty(t,i){const r=this.getFragmentStyle(t);if(!r)return null;const n=e.t(i,r.scope),o=r.options.get(n),s=o?o.value||o.default:null;return s?s.serialize():null}isIndoorEnabled(){return Object.keys(this._mergedIndoor).length>0}getIndoorSourceLayers(t,i){const r=e.t(t,i);return this._mergedIndoor[r]}setIndoorData(e,t){this.indoorManager.setIndoorData(t)}updateIndoorDependentLayers(){this._updateLayers(this._indoorDependentLayers),this.map._styleDirty=!0,this.map.triggerRepaint()}setConfigProperty(t,i,r){const n=this.getFragmentStyle(t);if(!n)return;const o=n.stylesheet.schema;if(!o||!o[i])return;const s=e.U(r);if("success"!==s.result)return void Cn(this,s.value);const a=s.value.expression,l=e.t(i,n.scope),c=n.options.get(l);if(!c)return;let h;const{minValue:u,maxValue:d,stepValue:p,type:f,values:m}=o[i],_=e.U(o[i].default);"success"===_.result&&(h=_.value.expression),h?(this.options.set(l,Object.assign({},c,{value:a,default:h,minValue:u,maxValue:d,stepValue:p,type:f,values:m})),this.updateConfigDependencies(i)):this.fire(new e.y(/* @__PURE__ */new Error(`No schema defined for the config option "${i}" in the "${t}" fragment.`)))}getConfig(t){const i=this.getFragmentStyle(t);if(!i)return null;const r=i.stylesheet.schema;if(!r)return null;const n={};for(const o in r){const t=e.t(o,i.scope),r=i.options.get(t),s=r?r.value||r.default:null;n[o]=s?s.serialize():null}return n}setConfig(e,t){const i=this.getFragmentStyle(e);i&&(i.updateConfig(t,i.stylesheet.schema),this.updateConfigDependencies())}getSchema(e){const t=this.getFragmentStyle(e);return t?t.stylesheet.schema:null}setSchema(e,t){const i=this.getFragmentStyle(e);i&&(i.stylesheet.schema=t,i.updateConfig(i._config,t),this.updateConfigDependencies())}updateConfig(t,i){if(this._config=t,t||i)if(i)for(const r in i){let n,o;const s=e.U(i[r].default);if("success"===s.result&&(n=s.value.expression),t&&void 0!==t[r]){const i=e.U(t[r]);"success"===i.result&&(o=i.value.expression)}const{minValue:a,maxValue:l,stepValue:c,type:h,values:u}=i[r];if(n){const t=e.t(r,this.scope);this.options.set(t,{default:n,value:o,minValue:a,maxValue:l,stepValue:c,type:h,values:u})}else this.fire(new e.y(/* @__PURE__ */new Error(`No schema defined for config option "${r}".`)))}else this.fire(new e.y(/* @__PURE__ */new Error("Attempting to set config for a style without schema.")))}_updateLayers(e,t=()=>!0){for(const i of e){const e=this.getLayer(i);e&&t(e)&&(e.possiblyEvaluateVisibility(),this._updateLayer(e),this._changes.setDirty())}}updateConfigDependencies(e){this._updateLayers(this._configDependentLayers,t=>!e||t.expressionDependencies.configDependencies.has(e)),this.ambientLight&&this.ambientLight.updateConfig(this.options),this.directionalLight&&this.directionalLight.updateConfig(this.options),this.fog&&this.fog.updateConfig(this.options),this.snow&&this.snow.updateConfig(this.options),this.rain&&this.rain.updateConfig(this.options),this.forEachFragmentStyle(e=>{const t=e._styleColorTheme.colorThemeOverride?e._styleColorTheme.colorThemeOverride:e._styleColorTheme.colorTheme;if(t){const i=e._evaluateColorThemeData(t);(!e._styleColorTheme.lut&&""!==i||e._styleColorTheme.lut&&i!==e._styleColorTheme.lut.data)&&e.setColorTheme(t)}}),this._changes.setDirty()}addLayer(t,i,r={}){this._checkLoaded();const n=t.id;if(this._layers[n])return void this.fire(new e.y(/* @__PURE__ */new Error(`Layer with id "${n}" already exists on this map`)));let o;if("custom"===t.type){if(Cn(this,e.dg(t)))return;o=e.dh(t,this.scope,this._styleColorTheme.lut,this.options)}else{if("object"==typeof t.source&&(this.addSource(n,t.source),t=e.db(t),t=Object.assign(t,{source:n})),this._validate(zt,`layers.${n}`,t,{arrayIndex:-1},r))return;o=e.dh(t,this.scope,this._styleColorTheme.lut,this.options),this._validateLayer(o),o.setEventedParent(this,{layer:{id:n}})}const s=e.t(o.source,o.scope);0!==o.expressionDependencies.configDependencies.size&&this._configDependentLayers.add(s),o.expressionDependencies.isIndoorDependent&&this._indoorDependentLayers.add(s);let a=this._order.length;if(i){const t=this._order.indexOf(i);if(-1===t)return void this.fire(new e.y(/* @__PURE__ */new Error(`Layer with id "${i}" does not exist on this map.`)));o.slot&&o.slot!==this._layers[i].slot?e.w(`Layer with id "${i}" has a different slot. Layers can only be rearranged within the same slot.`):a=t}this._order.splice(a,0,n),this._handleLayerOrderChange(),this._layers[n]=o;const l=this.getOwnLayerSourceCache(o),c=!!this.directionalLight&&this.directionalLight.shadowsEnabled();l&&o.canCastShadows()&&c&&(l.castsShadows=!0);const h=this._changes.getRemovedLayer(o);if(h&&o.source&&l&&"custom"!==o.type){this._changes.discardLayerRemoval(o);const t=e.t(o.source,o.scope);h.type!==o.type?this._changes.updateSourceCache(t,"clear"):(this._changes.updateSourceCache(t,"reload"),l.pause())}this._updateLayer(o),o.onAdd&&o.onAdd(this.map),o.scope=this.scope,this.mergeLayers()}moveLayer(t,i){this._checkLoaded();const r=this._checkLayer(t);if(!r)return;if(t===i)return;const n=this._order.indexOf(t);this._order.splice(n,1);let o=this._order.length;if(i){const t=this._order.indexOf(i);if(-1===t)return void this.fire(new e.y(/* @__PURE__ */new Error(`Layer with id "${i}" does not exist on this map.`)));r.slot&&r.slot!==this._layers[i].slot?e.w(`Layer with id "${i}" has a different slot. Layers can only be rearranged within the same slot.`):o=t}this._order.splice(o,0,t),this._changes.setDirty(),this._handleLayerOrderChange(),this.mergeLayers()}removeLayer(e){this._checkLoaded();const t=this._checkLayer(e);if(!t)return;t.setEventedParent(null);const i=this._order.indexOf(e);this._order.splice(i,1),delete this._layers[e],this._changes.setDirty(),this._handleLayerOrderChange(),this._configDependentLayers.delete(t.fqid),this._indoorDependentLayers.delete(t.fqid),this._changes.removeLayer(t);const r=this.getOwnLayerSourceCache(t);if(r&&r.castsShadows){let e=!1;for(const i in this._layers)if(this._layers[i].source===t.source&&this._layers[i].canCastShadows()){e=!0;break}r.castsShadows=e}t.onRemove&&t.onRemove(this.map),this.mergeLayers()}getOwnLayer(e){return this._layers[e]}hasLayer(e){return e in this._mergedLayers}hasLayerType(e){for(const t in this._layers)if(this._layers[t].type===e)return!0;return!1}setLayerZoomRange(e,t,i){this._checkLoaded();const r=this._checkLayer(e);r&&(r.minzoom===t&&r.maxzoom===i||(null!=t&&(r.minzoom=t),null!=i&&(r.maxzoom=i),this._updateLayer(r)))}getSlots(){return this._checkLoaded(),this._mergedSlots}setSlot(e,t){this._checkLoaded();const i=this._checkLayer(e);i&&i.slot!==t&&(i.slot=t,this._updateLayer(i))}setFilter(t,i,r={}){this._checkLoaded();const n=this._checkLayer(t);if(n&&!e.b9(n.filter,i))return null==i?(n.filter=void 0,void this._updateLayer(n)):void(this._validate(Lt,`layers.${n.id}.filter`,i,{layerType:n.type},r)||(n.filter=e.db(i),this._updateLayer(n)))}getFilter(t){const i=this._checkLayer(t);if(i)return e.db(i.filter)}setLayoutProperty(t,i,r,n={}){this._checkLoaded();const o=this._checkLayer(t);if(o&&!e.b9(o.getLayoutProperty(i),r)){if(null!=r&&(!n||!1!==n.validate)&&Cn(o,Ot.call(It,{key:`layers.${t}.layout.${i}`,layerType:o.type,objectKey:i,value:r,styleSpec:e.a6,style:{glyphs:!0,sprite:!0}})))return;o.setLayoutProperty(i,r),0!==o.expressionDependencies.configDependencies.size&&this._configDependentLayers.add(o.fqid),o.expressionDependencies.isIndoorDependent&&this._indoorDependentLayers.add(o.fqid),this._updateLayer(o)}}setLayerProperty(e,t,i,r={}){this._checkLoaded();const n=this._checkLayer(e);n&&("appearances"===t?(n.setAppearances(i),this._updateLayer(n)):n.isPaintProperty(t)?this.setPaintProperty(e,t,i,r):this.setLayoutProperty(e,t,i,r))}getLayoutProperty(e,t){const i=this._checkLayer(e);if(i)return i.getLayoutProperty(t)}setPaintProperty(t,i,r,n={}){this._checkLoaded();const o=this._checkLayer(t);if(!o)return;if(e.b9(o.getPaintProperty(i),r))return;if(null!=r&&(!n||!1!==n.validate)&&Cn(o,Ft.call(It,{key:`layers.${t}.paint.${i}`,layerType:o.type,objectKey:i,value:r,styleSpec:e.a6})))return;const s=o.setPaintProperty(i,r);0!==o.expressionDependencies.configDependencies.size&&this._configDependentLayers.add(o.fqid),o.expressionDependencies.isIndoorDependent&&this._indoorDependentLayers.add(o.fqid),s&&this._updateLayer(o),this._changes.updatePaintProperties(o)}getPaintProperty(e,t){const i=this._checkLayer(e);if(i)return i.getPaintProperty(t)}setFeatureState(t,i){if(this._checkLoaded(),"target"in t){if("featuresetId"in t.target){const{featuresetId:e,importId:r}=t.target,n=this.getFragmentStyle(r),o=n.getFeaturesetLayers(e);for(const{source:s,sourceLayer:a}of o)n.setFeatureState({id:t.id,source:s,sourceLayer:a},i)}else if("layerId"in t.target){const{layerId:e}=t.target,r=this.getLayer(e);this.setFeatureState({id:t.id,source:r.source,sourceLayer:r.sourceLayer},i)}return}const r=t.source,n=t.sourceLayer,o=this._checkSource(r);if(!o)return;const s=o.type;if("geojson"===s&&n)return void this.fire(new e.y(/* @__PURE__ */new Error("GeoJSON sources cannot have a sourceLayer parameter.")));if("vector"===s&&!n)return void this.fire(new e.y(/* @__PURE__ */new Error("The sourceLayer parameter must be provided for vector source types.")));void 0===t.id&&this.fire(new e.y(/* @__PURE__ */new Error("The feature id parameter must be provided.")));const a=this.getOwnSourceCaches(r);for(const e of a)e.setFeatureState(n,t.id,i)}removeFeatureState(t,i){if(this._checkLoaded(),"target"in t){if("featuresetId"in t.target){const{featuresetId:e,importId:r}=t.target,n=this.getFragmentStyle(r),o=n.getFeaturesetLayers(e);for(const{source:s,sourceLayer:a}of o)n.removeFeatureState({id:t.id,source:s,sourceLayer:a},i)}else if("layerId"in t.target){const{layerId:e}=t.target,r=this.getLayer(e);this.removeFeatureState({id:t.id,source:r.source,sourceLayer:r.sourceLayer},i)}return}const r=t.source,n=this._checkSource(r);if(!n)return;const o=n.type,s="vector"===o?t.sourceLayer:void 0;if("vector"===o&&!s)return void this.fire(new e.y(/* @__PURE__ */new Error("The sourceLayer parameter must be provided for vector source types.")));if(i&&"string"!=typeof t.id&&"number"!=typeof t.id)return void this.fire(new e.y(/* @__PURE__ */new Error("A feature id is required to remove its specific state property.")));const a=this.getOwnSourceCaches(r);for(const e of a)e.removeFeatureState(s,t.id,i)}getFeatureState(t){if(this._checkLoaded(),"target"in t){let i;if("featuresetId"in t.target){const{featuresetId:r,importId:n}=t.target,o=this.getFragmentStyle(n),s=o.getFeaturesetLayers(r);for(const{source:a,sourceLayer:l}of s){const r=o.getFeatureState({id:t.id,source:a,sourceLayer:l});if(r&&!i)i=r;else if(!e.b9(i,r))return void this.fire(new e.y(/* @__PURE__ */new Error("The same feature id exists in multiple sources in the featureset, but their feature states are not consistent through the sources.")))}}else if("layerId"in t.target){const{layerId:e}=t.target,r=this.getLayer(e);i=this.getFeatureState({id:t.id,source:r.source,sourceLayer:r.sourceLayer})}return i}const i=t.source,r=t.sourceLayer,n=this._checkSource(i);if(n){if("vector"!==n.type||r)return void 0===t.id&&this.fire(new e.y(/* @__PURE__ */new Error("The feature id parameter must be provided."))),this.getOwnSourceCaches(i)[0].getFeatureState(r,t.id);this.fire(new e.y(/* @__PURE__ */new Error("The sourceLayer parameter must be provided for vector source types.")))}}setTransition(e){return this.stylesheet.transition=Object.assign({},this.stylesheet.transition,e),this.transition=this.stylesheet.transition,this}getTransition(){return Object.assign({},this.stylesheet.transition)}setWorldview(e){e!==this._worldview&&(this._worldview=e,this.dispatcher.broadcast("setWorldview",this._worldview),this.reloadSources())}serialize(){this._checkLoaded();const t=this.getTerrain(),i=t&&this.terrain&&this.terrain.scope===this.scope?t:this.stylesheet.terrain;return e.di({version:this.stylesheet.version,name:this.stylesheet.name,metadata:this.stylesheet.metadata,fragment:this.stylesheet.fragment,iconsets:this.stylesheet.iconsets,featuresets:this.stylesheet.featuresets,imports:this._serializeImports(),schema:this.stylesheet.schema,camera:this.stylesheet.camera,light:this.stylesheet.light,lights:this.stylesheet.lights,terrain:i,fog:this.stylesheet.fog,snow:this.stylesheet.snow,rain:this.stylesheet.rain,indoor:this.stylesheet.indoor,center:this.stylesheet.center,"color-theme":this.stylesheet["color-theme"],zoom:this.stylesheet.zoom,bearing:this.stylesheet.bearing,pitch:this.stylesheet.pitch,sprite:this.stylesheet.sprite,glyphs:this.stylesheet.glyphs,transition:this.stylesheet.transition,projection:this.stylesheet.projection,sources:this._serializeSources(),layers:this._serializeLayers(this._order)},e=>void 0!==e)}_updateFilteredLayers(e){for(const t of Object.values(this._mergedLayers))e(t)&&this._updateLayer(t)}_updateLayer(t){this._changes.updateLayer(t);const i=this.getLayerSourceCache(t),r=e.t(t.source,t.scope),n=this._changes.getUpdatedSourceCaches();t.source&&!n[r]&&i&&"raster"!==i.getSource().type&&(this._changes.updateSourceCache(r,"reload"),i.pause()),t.invalidateCompiledFilter()}_flattenAndSortRenderedFeatures(e){const t=e=>this._mergedLayers[e].is3D(!!this.terrain),i=this.order,r={},n=[];for(let s=i.length-1;s>=0;s--){const o=i[s];if(t(o)){r[o]=s;for(const t of e){const e=t[o];if(e)for(const t of e)n.push(t)}}}n.sort((e,t)=>t.intersectionZ-e.intersectionZ);const o=[];for(let s=i.length-1;s>=0;s--){const a=i[s];if(t(a))for(let e=n.length-1;e>=0;e--){const t=n[e].feature;if(t.layer&&r[t.layer.id]<s)break;o.push(t),n.pop()}else for(const t of e){const e=t[a];if(e)for(const t of e)o.push(t.feature)}}return o}queryRasterValue(t,i,r){const n=this.getOwnSource(t);return n?"raster-array"!==n.type?(this.fire(new e.y(/* @__PURE__ */new Error('queryRasterValue support only "raster-array" sources.'))),Promise.resolve(null)):n.queryRasterArrayValue(i,r):(this.fire(new e.y(/* @__PURE__ */new Error(`Source with id "${t}" does not exist in the style.`))),Promise.resolve(null))}queryRenderedFeatures(t,i,r){let n;i&&!Array.isArray(i)&&i.filter&&(this._validate(Lt,"queryRenderedFeatures.filter",i.filter,null,i),n=e.dj(i.filter));const o={},s=e=>{if(Rn.has(e.type))return;const t=this.getOwnLayerSourceCache(e),i=o[t.id]=o[t.id]||{sourceCache:t,layers:{},has3DLayers:!1};e.is3D(!!this.terrain)&&(i.has3DLayers=!0),i.layers[e.fqid]=i.layers[e.fqid]||{styleLayer:e,targets:[]},i.layers[e.fqid].targets.push({filter:n})};if(i&&i.layers){if(!Array.isArray(i.layers))return this.fire(new e.y(/* @__PURE__ */new Error("parameters.layers must be an Array."))),[];for(const t of i.layers){const i=this._layers[t];if(!i)return this.fire(new e.y(/* @__PURE__ */new Error(`The layer '${t}' does not exist in the map's style and cannot be queried for features.`))),[];s(i)}}else for(const e in this._layers)s(this._layers[e]);const a=this._queryRenderedFeatures(t,o,r),l=this._flattenAndSortRenderedFeatures(a),c=[];for(const h of l)e.dk(h.layer.id)===this.scope&&c.push(h);return c}queryRenderedFeatureset(t,i,r){let n;i&&!Array.isArray(i)&&i.filter&&(this._validate(Lt,"queryRenderedFeatures.filter",i.filter,null,i),n=e.dj(i.filter));const o="mock",s=[];if(i&&i.target)s.push(Object.assign({},i,{targetId:o,filter:n}));else{const e=this.getFeaturesetDescriptors();for(const t of e)s.push({targetId:o,filter:n,target:t});for(const{style:t}of this.fragments){const e=t.getFeaturesetDescriptors();for(const t of e)s.push({targetId:o,filter:n,target:t})}}const a=this.queryRenderedTargets(t,s,r),l=[],c=/* @__PURE__ */new Set;for(const h of a)for(const t of h.variants[o])Si(t,h,c)||l.push(new e.dl(h,t));return l}queryRenderedTargets(t,i,r){const n={},o=(e,t,i,r)=>{const o=n[t.id]=n[t.id]||{sourceCache:t,layers:{},has3DLayers:!1};if(o.layers[e.fqid]=o.layers[e.fqid]||{styleLayer:e,targets:[]},e.is3D(!!this.terrain)&&(o.has3DLayers=!0),!r)return i.uniqueFeatureID=!1,void o.layers[e.fqid].targets.push(i);o.layers[e.fqid].targets.push(Object.assign({},i,{namespace:r.namespace,properties:r.properties,uniqueFeatureID:r.uniqueFeatureID}))};for(const a of i)if("featuresetId"in a.target){const{featuresetId:t,importId:i}=a.target,r=this.getFragmentStyle(i);if(!r||!r._featuresetSelectors)continue;const n=r._featuresetSelectors[t];if(!n){this.fire(new e.y(/* @__PURE__ */new Error(`The featureset '${t}' does not exist in the map's style and cannot be queried for features.`)));continue}for(const e of n){const t=r.getOwnLayer(e.layerId);t&&!Rn.has(t.type)&&o(t,r.getOwnLayerSourceCache(t),a,e)}}else if("layerId"in a.target){const{layerId:e}=a.target,t=this.getLayer(e);if(!t||Rn.has(t.type))continue;o(t,this.getLayerSourceCache(t),a)}const s=this._queryRenderedFeatures(t,n,r);return this._flattenAndSortRenderedFeatures(s)}_queryRenderedFeatures(t,i,r){const n=[],o=!!this.map._showQueryGeometry,s=ui.createFromScreenPoints(t,r);for(const e in i){const t=Ii(s,i[e],this._availableImages,r,o,this.getActualScope());Object.keys(t).length&&n.push(t)}if(this.placement)for(const a in i){if(i[a].sourceCache._renderSourceType!==e.b7.Symbol)continue;const t=Ei(s.screenGeometry,i[a],this._availableImages,this.placement.collisionIndex,this.placement.retainedQueryData,this.map.getWorldview());Object.keys(t).length&&n.push(t)}return n}querySourceFeatures(e,t){const i=t&&t.filter;i&&this._validate(Lt,"querySourceFeatures.filter",i,null,t);let r=[];const n=this.getOwnSourceCaches(e);for(const o of n)r=r.concat(Ai(o,t));return r}addSourceType(e,t,i){return On.getSourceType(e)?i(/* @__PURE__ */new Error(`A source type called "${e}" already exists.`)):(On.setSourceType(e,t),i(null,null))}getFlatLight(){return this.light.getLight()}setFlatLight(t,i,r={}){this._checkLoaded();const n=this.light.getLight();let o=!1;for(const a in t)if(!e.b9(t[a],n[a])){o=!0;break}if(!o)return;const s=this._getTransitionParameters();this.light.setLight(t,i,r),this.light.updateTransitions(s)}getTerrain(){return this.terrain&&1===this.terrain.drapeRenderMode?this.terrain.get():null}setTerrainForDraping(){this.setTerrain({source:"",exaggeration:0},0)}checkCanvasFingerprintNoise(){void 0===this.disableElevatedTerrain&&(this.disableElevatedTerrain=e.o.hasCanvasFingerprintNoise(),this.disableElevatedTerrain&&e.w("Terrain and hillshade are disabled because of Canvas2D limitations when fingerprinting protection is enabled (e.g. in private browsing mode)."))}setTerrain(t,i=1){if(this._checkLoaded(),!t)return this.terrainSetForDrapingOnly()||(delete this.terrain,this.map.transform.projection.requiresDraping&&this.setTerrainForDraping()),0===i&&delete this.terrain,null===t?this.stylesheet.terrain=null:delete this.stylesheet.terrain,this._force3DLayerUpdate(),void(this._markersNeedUpdate=!0);this.checkCanvasFingerprintNoise();let r=t;const n=!("source"in t)||null==t.source;if(1===i){if(this.disableElevatedTerrain)return;if("source"in r&&"object"==typeof r.source){const t="terrain-dem-src";this.addSource(t,r.source),r=e.db(r),r=Object.assign(r,{source:t})}const t=Object.assign({},r),i={};if(this.terrain&&n){t.source=this.terrain.get().source;const e=this.terrain?this.getFragmentStyle(this.terrain.scope):null;e&&(i.style=e.serialize())}if(this._validate(Ct,"terrain",t,i))return}if(!this.terrain||this.terrain.scope!==this.scope&&!n||this.terrain&&i!==this.terrain.drapeRenderMode){if(!r)return;this._createTerrain(r,i),this.fire(new e.z("data",{dataType:"style"}))}else{const i=this.terrain,n=i.get();for(const t of Object.keys(e.a6.terrain))!Object.hasOwn(r,t)&&e.a6.terrain[t].default&&(r[t]=e.a6.terrain[t].default);for(const r in t)if(!e.b9(t[r],n[r])){i.set(t,this.options),this.stylesheet.terrain=t;const r=this._getTransitionParameters({duration:0});i.updateTransitions(r),this.fire(new e.z("data",{dataType:"style"}));break}}this.mergeTerrain(),this.updateDrapeFirstLayers(),this._markersNeedUpdate=!0}_createFog(e){const t=this.fog=new Yt(e,this.map.transform,this.scope,this.options);this.stylesheet.fog=t.get();const i=this._getTransitionParameters({duration:0});t.updateTransitions(i)}_createSnow(e){const t=this.snow=new Qt(e,this.map.transform,this.scope,this.options);this.stylesheet.snow=t.get();const i=this._getTransitionParameters({duration:0});t.updateTransitions(i)}_createRain(e){const t=this.rain=new ei(e,this.map.transform,this.scope,this.options);this.stylesheet.rain=t.get();const i=this._getTransitionParameters({duration:0});t.updateTransitions(i)}_updateMarkersOpacity(){0!==this.map._markers.length&&this.map._requestDomTask(()=>{for(const e of this.map._markers)e._evaluateOpacity()})}getFog(){return this.fog?this.fog.get():null}setFog(t){if(this._checkLoaded(),t)if(this.fog){const i=this.fog;if(!e.b9(i.get(),t)){i.set(t,this.options),this.stylesheet.fog=i.get();const e=this._getTransitionParameters({duration:0});i.updateTransitions(e)}}else this._createFog(t);else delete this.fog,delete this.stylesheet.fog;this._markersNeedUpdate=!0,this._programPrecompiler&&this._programPrecompiler.reset()}getSnow(){return this.snow?this.snow.get():null}setSnow(t){if(this._checkLoaded(),!t)return delete this.snow,void delete this.stylesheet.snow;if(this.snow){const i=this.snow;if(!e.b9(i.get(),t)){i.set(t,this.options),this.stylesheet.snow=i.get();const e=this._getTransitionParameters({duration:0});i.updateTransitions(e)}}else this._createSnow(t);this._markersNeedUpdate=!0}getRain(){return this.rain?this.rain.get():null}setRain(t){if(this._checkLoaded(),!t)return delete this.rain,void delete this.stylesheet.rain;if(this.rain){const i=this.rain;if(!e.b9(i.get(),t)){i.set(t,this.options),this.stylesheet.rain=i.get();const e=this._getTransitionParameters({duration:0});i.updateTransitions(e)}}else this._createRain(t);this._markersNeedUpdate=!0}_reloadColorTheme(){const t=()=>{for(const e in this._layers)this._layers[e].lut=this._styleColorTheme.lut;for(const e in this._sourceCaches)this._sourceCaches[e].clearTiles()},i=this._styleColorTheme.colorThemeOverride?this._styleColorTheme.colorThemeOverride:this._styleColorTheme.colorTheme;if(!i)return this._styleColorTheme.lut=null,void t();const r=this._evaluateColorThemeData(i);this._loadColorTheme(r).then(()=>{this.fire(new e.z("colorthemeset")),t()}).catch(t=>{e.w(`Couldn't set color theme: ${t}`)})}setColorTheme(t){this._checkLoaded(),this._styleColorTheme.colorThemeOverride&&e.w("Note: setColorTheme is called on a style with a color-theme override, the passed color-theme won't be visible."),this._styleColorTheme.colorTheme=t,this._reloadColorTheme()}setImportColorTheme(e,t){const i=this.getFragmentStyle(e);i&&(i._styleColorTheme.colorThemeOverride=t,i._reloadColorTheme())}_getTransitionParameters(t){return{now:e.o.now(),transition:Object.assign(this.transition,t)}}updateDrapeFirstLayers(){if(!this.terrain)return;const e=[],t=[];for(const i of this._mergedOrder)this.isLayerDraped(this._mergedLayers[i])?e.push(i):t.push(i);this._drapedFirstOrder=[],this._drapedFirstOrder.push(...e),this._drapedFirstOrder.push(...t)}_createTerrain(e,t){const i=this.terrain=new Ht(e,t,this.scope,this.options,this.map.getWorldview());1===t&&(this.stylesheet.terrain=e),this.mergeTerrain(),this.updateDrapeFirstLayers(),this._force3DLayerUpdate();const r=this._getTransitionParameters({duration:0});i.updateTransitions(r)}_force3DLayerUpdate(){for(const e in this._layers){const t=this._layers[e];"fill-extrusion"===t.type&&this._updateLayer(t)}}_forceSymbolLayerUpdate(){for(const e in this._layers){const t=this._layers[e];"symbol"===t.type&&this._updateLayer(t)}}_validate(t,i,r,n,o={}){if(o&&!1===o.validate)return!1;const s=Object.assign({},this.serialize());return Cn(this,t.call(It,Object.assign({key:i,style:s,value:r,styleSpec:e.a6},n)))}_remove(){this._programPrecompiler&&(this._programPrecompiler.reset(),this._programPrecompiler=null),this._request&&(this._request.cancel(),this._request=null),this._spriteRequest&&(this._spriteRequest.cancel(),this._spriteRequest=null),e.dm.off("pluginStateChange",this._rtlTextPluginCallback);for(const e in this._mergedLayers)this._mergedLayers[e].setEventedParent(null);for(const e in this._mergedSourceCaches){const t=this._mergedSourceCaches[e];t.clearTiles(),t.setEventedParent(null);const i=t.getSource();i&&i.onRemove&&i.onRemove(this.map)}this.imageManager.removeScope(this.scope),this.imageManager.imageAtlasCache.clear(),this.setEventedParent(null),delete this.fog,delete this.snow,delete this.rain,delete this.terrain,delete this.ambientLight,delete this.directionalLight,this.indoorManager.destroy(),this.isRootStyle()&&(this.imageManager.setEventedParent(null),this.modelManager.setEventedParent(null),this.modelManager.destroy(),this.dispatcher.remove())}clearSource(e){const t=this.getSourceCaches(e);for(const i of t)i.clearTiles()}clearSources(){for(const e in this._mergedSourceCaches)this._mergedSourceCaches[e].clearTiles()}clearLayers(){for(const e in this._mergedLayers){const t=this._mergedLayers[e];t._clear&&t._clear()}}reloadSource(e){const t=this.getSourceCaches(e);for(const i of t)i.resume(),i.reload()}reloadSources(){for(const e of this.getSources())e.reload&&e.reload()}reloadModels(){this.modelManager.reloadModels(""),this.forEachFragmentStyle(e=>{e.modelManager.reloadModels(e.scope)})}updateSources(e){let t;this.directionalLight&&(t=fn(this.directionalLight));const i=/* @__PURE__ */new Set,r=/* @__PURE__ */new Set,n=/* @__PURE__ */new Set;for(const o in this._mergedLayers){const e=this._mergedLayers[o];"building"===e.type?i.add(e.source):"raster"===e.type&&e.paint&&"ground"===e.paint.get("raster-elevation-reference")&&n.add(e.source),e.hasElevation()&&!r.has(e.source)&&r.add(e.source)}for(const o in this._mergedSourceCaches){const s=this._mergedSourceCaches[o],a=r.has(s._source.id);s._isRasterElevatedOverTerrain=n.has(s._source.id),i.has(s._source.id)&&(s._source.reparseOverscaled=!1),s.update(e,void 0,void 0,t,a)}}_reloadSources(){for(const e in this._sourceCaches){const t=this._sourceCaches[e];t.resume(),t.reload()}}_handleLayerOrderChange(){this._requestFullLabelPlacement(),this.fire(new e.z("neworder"))}_requestFullLabelPlacement(){this.pauseablePlacement||(this.pauseablePlacement=new Or),this.pauseablePlacement.requestFullPlacement()}_setLabelPlacementStale(){this.placement&&this.placement.setStale()}_updatePlacement(t,i,r,n,o){this.pauseablePlacement||(this.pauseablePlacement=new Or);let s=!1,a=!1;const l={},c={};for(const m of this._mergedOrder){const i=this._mergedLayers[m];if("symbol"!==i.type)continue;const r=e.t(i.source,i.scope);let n=l[r];if(!n){const e=this.getLayerSourceCache(i);if(!e)continue;const t=e.getRenderableIds(!0).map(t=>e.getTileByID(t));c[r]=t.slice(),n=l[r]=t.sort((e,t)=>t.tileID.overscaledZ-e.tileID.overscaledZ||(e.tileID.isLessThan(t.tileID)?-1:1))}const o=this.crossTileSymbolIndex.addLayer(i,n,t.center.lng,t.projection);s=s||o}this.crossTileSymbolIndex.pruneUnusedLayers(this._mergedOrder);const h=Boolean(this.placement&&!t.equals(this.placement.transform)),u=Boolean(this.placement&&(0!==this.placement.lastReplacementSourceUpdateTime&&!o||this.placement.lastReplacementSourceUpdateTime!==o.updateTime)),d=h||u||s,p=(d||this.pauseablePlacement.isStale())&&0===r,f=this.pauseablePlacement.isDone()&&!this.placement.stillRecent(e.o.now(),t.zoom)&&0!==r;if((this.pauseablePlacement.isFullPlacementRequested()||!this.pauseablePlacement.placement||p||f)&&(this.pauseablePlacement=this.pauseablePlacement.startNewPlacement(t,this._mergedOrder,i,r,n,this.placement,this.fog&&t.projection.supportsFog?this.fog.state:null,this._buildingIndex),this.map.painter)){const e=this.map.painter.maxFrontCutoffRawStart;if(e>0){const i=180*t.pitch/Math.PI;if(i>=15){const t=Math.min(1,Math.max(0,(i-15)/5)),r=t*t*(3-2*t);this.pauseablePlacement.placement.frontCutoffStart=-.5*(1-r)+e*r}}}if(this.pauseablePlacement.isDone()?d&&0!==r&&this.pauseablePlacement.setStale():(this.pauseablePlacement.continuePlacement(this._mergedOrder,this._mergedLayers,l,c,this.map.painter.scaleFactor),this.pauseablePlacement.isDone()&&(this.placement=this.pauseablePlacement.commit(e.o.now()),a=!0),s&&this.pauseablePlacement.setStale()),a||s){this._buildingIndex.onNewFrame(t.zoom);for(let t=0;t<this._mergedOrder.length;t++){const i=this._mergedLayers[this._mergedOrder[t]];if("symbol"!==i.type)continue;if("none"===i.visibility)continue;const r=this.isLayerClipped(i);this.placement.updateLayerOpacities(i,l[e.t(i.source,i.scope)],t,r?o:null)}}return!this.pauseablePlacement.isDone()||this.placement.isStale()||this.placement.hasTransitions(e.o.now())}_releaseSymbolFadeTiles(){for(const e in this._sourceCaches)this._sourceCaches[e].releaseSymbolFadeTiles()}addImport(t,i){this._checkLoaded();const r=this.stylesheet.imports=this.stylesheet.imports||[];if(-1!==r.findIndex(({id:e})=>e===t.id))return void this.fire(new e.y(/* @__PURE__ */new Error(`Import with id '${t.id}' already exists in the map's style.`)));if(!i)return r.push(t),this._loadImports([t],!0);const n=r.findIndex(({id:e})=>e===i);return-1===n&&this.fire(new e.y(/* @__PURE__ */new Error(`Import with id "${i}" does not exist on this map.`))),this.stylesheet.imports=r.slice(0,n).concat(t).concat(r.slice(n)),this._loadImports([t],!0,i)}updateImport(t,i){this._checkLoaded();const r=this.stylesheet.imports||[],n=this.getImportIndex(t);return-1===n?this:"string"==typeof i?(this.setImportUrl(t,i),this):(i.url&&i.url!==r[n].url&&this.setImportUrl(t,i.url),e.b9(i.config,r[n].config)||this.setImportConfig(t,i.config,i.data.schema),e.b9(i.data,r[n].data)||this.setImportData(t,i.data),this)}moveImport(e,t){this._checkLoaded();let i=this.stylesheet.imports||[];const r=this.getImportIndex(e);if(-1===r)return this;const n=this.getImportIndex(t);if(-1===n)return this;const o=i[r],s=this.fragments[r];return i=i.filter(({id:t})=>t!==e),this.fragments=this.fragments.filter(({id:t})=>t!==e),this.stylesheet.imports=i.slice(0,n).concat(o).concat(i.slice(n)),this.fragments=this.fragments.slice(0,n).concat(s).concat(this.fragments.slice(n)),this.mergeLayers(),this}setImportUrl(e,t){this._checkLoaded();const i=this.stylesheet.imports||[],r=this.getImportIndex(e);if(-1===r)return this;i[r].url=t;const n=this.fragments[r];return n.style=this._createFragmentStyle(i[r]),n.style.on("style.import.load",()=>this.mergeAll()),n.style.loadURL(t),this}setImportData(e,t){this._checkLoaded();const i=this.getImportIndex(e),r=this.stylesheet.imports||[];return-1===i?this:t?(this.fragments[i].style.setState(t),this._reloadImports(),this):(delete r[i].data,this.setImportUrl(e,r[i].url))}setImportConfig(e,t,i){this._checkLoaded();const r=this.getImportIndex(e),n=this.stylesheet.imports||[];if(-1===r)return this;t?n[r].config=t:delete n[r].config;const o=this.fragments[r];i&&o.style.stylesheet&&(o.style.stylesheet.schema=i);const s=o.style.stylesheet&&o.style.stylesheet.schema;return o.config=t,o.style.updateConfig(t,s),this.updateConfigDependencies(),this}removeImport(e){this._checkLoaded();const t=this.stylesheet.imports||[],i=this.getImportIndex(e);-1!==i&&(t.splice(i,1),this.fragments[i].style._remove(),this.fragments.splice(i,1),this._reloadImports())}getImportIndex(t){const i=(this.stylesheet.imports||[]).findIndex(e=>e.id===t);return-1===i&&this.fire(new e.y(/* @__PURE__ */new Error(`Import '${t}' does not exist in the map's style and cannot be updated.`))),i}getLayer(e){return this._mergedLayers[e]}getSources(){const e=[];for(const t in this._mergedOtherSourceCaches){const i=this._mergedOtherSourceCaches[t];i&&e.push(i.getSource())}return e}getSource(e,t){const i=this.getSourceCache(e,t);return i&&i.getSource()}getLayerSource(e){const t=this.getLayerSourceCache(e);return t&&t.getSource()}getSourceCache(t,i){const r=e.t(t,i);return this._mergedOtherSourceCaches[r]}getLayerSourceCache(t){const i=e.t(t.source,t.scope);return"symbol"===t.type?this._mergedSymbolSourceCaches[i]:"fill-extrusion"===t.type&&this._mergedFillExtrusionSourceCaches[i]||this._mergedOtherSourceCaches[i]}getSourceCaches(e){if(null==e)return Object.values(this._mergedSourceCaches);const t=[];return this._mergedOtherSourceCaches[e]&&t.push(this._mergedOtherSourceCaches[e]),this._mergedSymbolSourceCaches[e]&&t.push(this._mergedSymbolSourceCaches[e]),this._mergedFillExtrusionSourceCaches[e]&&t.push(this._mergedFillExtrusionSourceCaches[e]),t}updateSourceCaches(){const e=this._changes.getUpdatedSourceCaches();for(const t in e){const i=e[t];"reload"===i?this.reloadSource(t):"clear"===i&&this.clearSource(t)}}updateLayers(e){const t=this._changes.getUpdatedPaintProperties();for(const i of t){const t=this.getLayer(i);t&&t.updateTransitions(e)}}getGlyphsUrl(){return this.stylesheet.glyphs}setGlyphsUrl(e){this.stylesheet.glyphs=e,this.glyphManager.setURL(e)}getImages(t,i,r){this.imageManager.getImages(i.icons.concat(i.patterns),i.scope,r),this._updateTilesForChangedImages();const n=i.icons.map(t=>e.I.toString(t)),o=i.patterns.map(t=>e.I.toString(t)),s=e=>{e&&(e.setDependencies(i.tileID.key,"icons",n),e.setDependencies(i.tileID.key,"patterns",o))},a=e.t(i.source,i.scope);s(this._mergedOtherSourceCaches[a]),s(this._mergedSymbolSourceCaches[a]),(i.icons.some(e=>e.iconsetId)||i.patterns.some(e=>e.iconsetId))&&this.fire(new e.z("data",{dataType:"style"}))}rasterizeImages(e,t,i){this.imageManager.rasterizeImages(t,i)}checkAtlasCache(e,t,i){const r=this.imageManager.imageAtlasCache.findCachedAtlas(t.descriptor);i(null,r&&r.contentDescriptor?{iconPositions:r.iconPositions,patternPositions:r.patternPositions,sourceHash:r.contentDescriptor.hash}:null)}getGlyphs(e,t,i){this.glyphManager.getGlyphs(t.stacks,i)}getOwnSourceCache(e){return this._otherSourceCaches[e]}getOwnLayerSourceCache(e){return"symbol"===e.type?this._symbolSourceCaches[e.source]:"fill-extrusion"===e.type&&this._fillExtrusionSourceCaches[e.source]||this._otherSourceCaches[e.source]}getOwnSourceCaches(e){const t=[];return this._otherSourceCaches[e]&&t.push(this._otherSourceCaches[e]),this._symbolSourceCaches[e]&&t.push(this._symbolSourceCaches[e]),this._fillExtrusionSourceCaches[e]&&t.push(this._fillExtrusionSourceCaches[e]),t}_isSourceCacheLoaded(t){const i=this.getOwnSourceCaches(t);return 0===i.length?(this.fire(new e.y(/* @__PURE__ */new Error(`There is no source with ID '${t}'`))),!1):i.every(e=>e.loaded())}has3DLayers(){return this._has3DLayers}hasSymbolLayers(){return this._hasSymbolLayers}hasCircleLayers(){return this._hasCircleLayers}isLayerClipped(e,t){if(!this._clipLayerPresent&&"fill-extrusion"!==e.type&&"building"!==e.type)return!1;const i="fill-extrusion"===e.type&&("building"===e.sourceLayer||"procedural_buildings"===e.sourceLayer),r="building"===e.type;if(e.is3D(!!this.terrain)){if(i||r||t&&"batched-model"===t.type)return!0;if("model"===e.type)return!0}else if("symbol"===e.type)return!0;return!1}_clearWorkerCaches(){this.dispatcher.broadcast("clearCaches")}getBOMObject(){}destroy(){this._clearWorkerCaches(),this.imageManager.imageAtlasCache.clear(),this.fragments.forEach(e=>{e.style._remove()}),this.terrainSetForDrapingOnly()&&(delete this.terrain,delete this.stylesheet.terrain)}}On.getSourceType=function(e){return bi[e]},On.setSourceType=function(e,t){bi[e]=t},On.registerForPluginStateChange=e.dn;var Bn="\n#define EPSILON 0.0000001\n#define PI 3.141592653589793\n#ifdef RENDER_CUTOFF\nfloat cutoff_opacity(vec4 cutoff_params,float depth) {float near=cutoff_params.x;float far=cutoff_params.y;float cutoffStart=cutoff_params.z;float cutoffEnd=cutoff_params.w;float linearDepth=(depth-near)/(far-near);return clamp((linearDepth-cutoffStart)/(cutoffEnd-cutoffStart),0.0,1.0);}\n#endif",kn="\n#ifdef DUAL_SOURCE_BLENDING\nlayout(location=0,index=0) out vec4 glFragColor;layout(location=0,index=1) out vec4 glFragColorSrc1;\n#elif defined(FLOAT_RENDER_TARGET)\nlayout(location=0) out highp vec4 glFragColor;\n#else\nlayout(location=0) out vec4 glFragColor;\n#endif\n#ifdef USE_MRT1\nlayout(location=1) out vec4 out_Target1;\n#endif\nhighp float unpack_depth(highp vec4 rgba_depth)\n{const highp vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);return dot(rgba_depth,bit_shift)*2.0-1.0;}highp vec4 pack_depth(highp float ndc_z) {highp float depth=ndc_z*0.5+0.5;const highp vec4 bit_shift=vec4(255.0*255.0*255.0,255.0*255.0,255.0,1.0);const highp vec4 bit_mask =vec4(0.0,1.0/255.0,1.0/255.0,1.0/255.0);highp vec4 res=fract(depth*bit_shift);res-=res.xxyz*bit_mask;return res;}\n#ifdef INDICATOR_CUTOUT\nuniform vec3 u_indicator_cutout_centers;uniform vec4 u_indicator_cutout_params;\n#endif\nconst float DITHER_THRESHOLDS[16]=float[16](\n1.0/17.0, 9.0/17.0, 3.0/17.0,11.0/17.0,13.0/17.0, 5.0/17.0,15.0/17.0, 7.0/17.0,4.0/17.0,12.0/17.0, 2.0/17.0,10.0/17.0,16.0/17.0, 8.0/17.0,14.0/17.0, 6.0/17.0\n);vec4 applyCutout(vec4 color,float height) {\n#ifdef INDICATOR_CUTOUT\nfloat verticalFadeRange=u_indicator_cutout_centers.z*0.25;float holeMinOpacity=mix(1.0,u_indicator_cutout_params.x,smoothstep(u_indicator_cutout_centers.z,u_indicator_cutout_centers.z+verticalFadeRange,height));float holeRadius=max(u_indicator_cutout_params.y,0.0);float holeAspectRatio=u_indicator_cutout_params.z;float fadeStart=u_indicator_cutout_params.w;float distA=distance(vec2(gl_FragCoord.x,gl_FragCoord.y*holeAspectRatio),vec2(u_indicator_cutout_centers[0],u_indicator_cutout_centers[1]*holeAspectRatio));return color*min(smoothstep(fadeStart,holeRadius,distA)+holeMinOpacity,1.0);\n#else\nreturn color;\n#endif\n}float cutoutGroundRoofOpacity(vec4 groundRoof) {\n#ifdef INDICATOR_CUTOUT\nfloat fadeStartX=u_indicator_cutout_params.w;float holeRadius=u_indicator_cutout_params.y;float holeMinOpacity=mix(u_indicator_cutout_params.x,1.0,smoothstep(u_indicator_cutout_params.z,u_indicator_cutout_centers.z,groundRoof.y));float distX=abs(u_indicator_cutout_centers.x-groundRoof.x);float roofOpacity=mix(holeMinOpacity,1.0,smoothstep(fadeStartX,holeRadius,u_indicator_cutout_centers.y-groundRoof.w));float groundOpacity=min(smoothstep(fadeStartX,holeRadius,distX)+holeMinOpacity,1.0);return max(roofOpacity,groundOpacity);\n#else\nreturn 1.0;\n#endif\n}\n#ifdef DEBUG_WIREFRAME\n#define HANDLE_WIREFRAME_DEBUG \\\nglFragColor=vec4(0.7,0.0,0.0,0.7); \\\ngl_FragDepth=gl_FragCoord.z-0.0001;\n#else\n#define HANDLE_WIREFRAME_DEBUG\n#endif\n#ifdef RENDER_CUTOFF\nuniform highp vec4 u_cutoff_params;in float v_cutoff_opacity;\n#endif\nvec4 textureLodCustom(sampler2D image,highp vec2 pos,highp vec2 lod_coord) {highp vec2 size=vec2(textureSize(image,0));highp vec2 dx=dFdx(lod_coord.xy*size);highp vec2 dy=dFdy(lod_coord.xy*size);highp float delta_max_sqr=max(dot(dx,dx),dot(dy,dy));highp float lod=0.5*log2(delta_max_sqr);return textureLod(image,pos,lod);}vec4 premultiplyColor(vec3 nonPremultipliedColor,float a) {return vec4(nonPremultipliedColor*a,a);}vec3 unpremultiplyColor(vec4 premultipliedColor) {if (premultipliedColor.a > 0.0) {return premultipliedColor.rgb/premultipliedColor.a;}return premultipliedColor.rgb;}vec3 applyLUT(highp sampler3D lut,vec3 col) {vec3 size=vec3(textureSize(lut,0));vec3 uvw=(col.rbg*float(size-1.0)+0.5)/size;return texture(lut,uvw).rgb;}vec4 applyLUT(highp sampler3D lut,vec4 premultipliedColor) {return premultiplyColor(applyLUT(lut,unpremultiplyColor(premultipliedColor)),premultipliedColor.a);}",Nn="\n#define EXTENT 8192.0\n#define RAD_TO_DEG 180.0/PI\n#define DEG_TO_RAD PI/180.0\n#define GLOBE_RADIUS EXTENT/PI/2.0\nfloat wrap(float n,float min,float max) {float d=max-min;float w=mod(mod(n-min,d)+d,d)+min;return (w==min) ? max : w;}\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 mercator_tile_position(mat4 matrix,vec2 tile_anchor,vec3 tile_id,vec2 mercator_center) {\n#ifndef PROJECTED_POS_ON_VIEWPORT\nfloat tiles=tile_id.z;vec2 mercator=(tile_anchor/EXTENT+tile_id.xy)/tiles;mercator-=mercator_center;mercator.x=wrap(mercator.x,-0.5,0.5);vec4 mercator_tile=vec4(mercator.xy*EXTENT,EXTENT/(2.0*PI),1.0);mercator_tile=matrix*mercator_tile;return mercator_tile.xyz;\n#else\nreturn vec3(0.0);\n#endif\n}vec3 mix_globe_mercator(vec3 globe,vec3 mercator,float t) {return mix(globe,mercator,t);}mat3 globe_mercator_surface_vectors(vec3 pos_normal,vec3 up_dir,float zoom_transition) {vec3 normal=zoom_transition==0.0 ? pos_normal : normalize(mix(pos_normal,up_dir,zoom_transition));vec3 xAxis=normalize(vec3(normal.z,0.0,-normal.x));vec3 yAxis=normalize(cross(normal,xAxis));return mat3(xAxis,yAxis,normal);}\n#endif\nvec2 unpack_float(const float packedValue) {int packedIntValue=int(packedValue);int v0=packedIntValue/256;return vec2(v0,packedIntValue-v0*256);}vec4 decode_color(const vec2 encodedColor) {return vec4(\nunpack_float(encodedColor[0])/255.0,unpack_float(encodedColor[1])/255.0\n);}float unpack_mix_vec2(const vec2 packedValue,const float t) {return mix(packedValue[0],packedValue[1],t);}vec4 unpack_mix_color(const vec4 packedColors,const float t) {vec4 minColor=decode_color(vec2(packedColors[0],packedColors[1]));vec4 maxColor=decode_color(vec2(packedColors[2],packedColors[3]));return mix(minColor,maxColor,t);}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const vec2 units_to_pixels,const vec2 pos) {vec2 offset=mod(mod(mod(pixel_coord_upper,pattern_size)*256.0,pattern_size)*256.0+pixel_coord_lower,pattern_size);return (units_to_pixels*pos+offset)/pattern_size;}vec2 get_pattern_pos(const vec2 pixel_coord_upper,const vec2 pixel_coord_lower,const vec2 pattern_size,const float tile_units_to_pixels,const vec2 pos) {return get_pattern_pos(pixel_coord_upper,pixel_coord_lower,pattern_size,vec2(tile_units_to_pixels),pos);}float mercatorXfromLng(float lng) {return (180.0+lng)/360.0;}float mercatorYfromLat(float lat) {return (180.0-(RAD_TO_DEG*log(tan(PI/4.0+lat/2.0*DEG_TO_RAD))))/360.0;}vec3 latLngToECEF(vec2 latLng) {latLng=DEG_TO_RAD*latLng;float cosLat=cos(latLng[0]);float sinLat=sin(latLng[0]);float cosLng=cos(latLng[1]);float sinLng=sin(latLng[1]);float sx=cosLat*sinLng*GLOBE_RADIUS;float sy=-sinLat*GLOBE_RADIUS;float sz=cosLat*cosLng*GLOBE_RADIUS;return vec3(sx,sy,sz);}\n#ifdef RENDER_CUTOFF\nuniform vec4 u_cutoff_params;out float v_cutoff_opacity;\n#endif\nconst vec4 AWAY=vec4(-1000.0,-1000.0,-1000.0,1);const float skirtOffset=24575.0;vec3 decomposeToPosAndSkirt(ivec2 posWithComposedSkirt)\n{float skirt=float(float(posWithComposedSkirt.x) >=skirtOffset);vec2 pos=vec2(posWithComposedSkirt)-vec2(skirt*skirtOffset,0.0);return vec3(pos,skirt);}\n#ifndef HAS_SHADER_STORAGE_BLOCK_material_buffer\n#define GET_ATTRIBUTE_float(attrib,matInfo,attrib_id) attrib\n#define GET_ATTRIBUTE_vec4(attrib,matInfo,attrib_id) attrib\n#define GET_ATTRIBUTE_vec2(attrib,matInfo,attrib_id) attrib\n#define DECLARE_MATERIAL_TABLE_INFO\n#endif",Un="in highp vec3 a_pos_3f;uniform lowp mat4 u_matrix;out highp vec3 v_uv;void main() {const mat3 half_neg_pi_around_x=mat3(1.0,0.0, 0.0,0.0,0.0,-1.0,0.0,1.0, 0.0);v_uv=half_neg_pi_around_x*a_pos_3f;vec4 pos=u_matrix*vec4(a_pos_3f,1.0);gl_Position=pos.xyww;}",Vn="\n#define ELEVATION_SCALE 7.0\n#define ELEVATION_OFFSET 450.0\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_tl_up;uniform vec3 u_tile_tr_up;uniform vec3 u_tile_br_up;uniform vec3 u_tile_bl_up;uniform float u_tile_up_scale;vec3 elevationVector(vec2 pos) {vec2 uv=pos/EXTENT;vec3 up=normalize(mix(\nmix(u_tile_tl_up,u_tile_tr_up,uv.xxx),mix(u_tile_bl_up,u_tile_br_up,uv.xxx),uv.yyy));return up*u_tile_up_scale;}\n#else\nvec3 elevationVector(vec2 pos) { return vec3(0,0,1); }\n#endif\n#ifdef TERRAIN\nuniform highp sampler2D u_dem;uniform highp sampler2D u_dem_prev;uniform vec2 u_dem_tl;uniform vec2 u_dem_tl_prev;uniform float u_dem_scale;uniform float u_dem_scale_prev;uniform float u_dem_size;uniform float u_dem_lerp;uniform float u_exaggeration;uniform float u_meter_to_dem;uniform mat4 u_label_plane_matrix_inv;vec4 tileUvToDemSample(vec2 uv,float dem_size,float dem_scale,vec2 dem_tl) {vec2 pos=dem_size*(uv*dem_scale+dem_tl)+1.0;vec2 f=fract(pos);return vec4((pos-f+0.5)/(dem_size+2.0),f);}float currentElevation(vec2 apos) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nvec2 pos=(u_dem_size*(apos/8192.0*u_dem_scale+u_dem_tl)+1.5)/(u_dem_size+2.0);return u_exaggeration*texture(u_dem,pos).r;\n#else\nfloat dd=1.0/(u_dem_size+2.0);vec4 r=tileUvToDemSample(apos/8192.0,u_dem_size,u_dem_scale,u_dem_tl);vec2 pos=r.xy;vec2 f=r.zw;float tl=texture(u_dem,pos).r;float tr=texture(u_dem,pos+vec2(dd,0)).r;float bl=texture(u_dem,pos+vec2(0,dd)).r;float br=texture(u_dem,pos+vec2(dd,dd)).r;return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);\n#endif\n}float prevElevation(vec2 apos) {\n#ifdef TERRAIN_DEM_FLOAT_FORMAT\nvec2 pos=(u_dem_size*(apos/8192.0*u_dem_scale_prev+u_dem_tl_prev)+1.5)/(u_dem_size+2.0);return u_exaggeration*texture(u_dem_prev,pos).r;\n#else\nfloat dd=1.0/(u_dem_size+2.0);vec4 r=tileUvToDemSample(apos/8192.0,u_dem_size,u_dem_scale_prev,u_dem_tl_prev);vec2 pos=r.xy;vec2 f=r.zw;float tl=texture(u_dem_prev,pos).r;float tr=texture(u_dem_prev,pos+vec2(dd,0)).r;float bl=texture(u_dem_prev,pos+vec2(0,dd)).r;float br=texture(u_dem_prev,pos+vec2(dd,dd)).r;return u_exaggeration*mix(mix(tl,tr,f.x),mix(bl,br,f.x),f.y);\n#endif\n}\n#ifdef TERRAIN_VERTEX_MORPHING\nfloat elevation(vec2 apos) {\n#ifdef ZERO_EXAGGERATION\nreturn 0.0;\n#endif\nfloat nextElevation=currentElevation(apos);float prevElevation=prevElevation(apos);return mix(prevElevation,nextElevation,u_dem_lerp);}\n#else\nfloat elevation(vec2 apos) {\n#ifdef ZERO_EXAGGERATION\nreturn 0.0;\n#endif\nreturn currentElevation(apos);}\n#endif\nvec4 fourSample(vec2 pos,vec2 off) {float tl=texture(u_dem,pos).r;float tr=texture(u_dem,pos+vec2(off.x,0.0)).r;float bl=texture(u_dem,pos+vec2(0.0,off.y)).r;float br=texture(u_dem,pos+off).r;return vec4(tl,tr,bl,br);}float flatElevation(vec2 pack) {vec2 apos=floor(pack/8.0);vec2 span=10.0*(pack-apos*8.0);vec2 uvTex=(apos-vec2(1.0,1.0))/8190.0;float size=u_dem_size+2.0;float dd=1.0/size;vec2 pos=u_dem_size*(uvTex*u_dem_scale+u_dem_tl)+1.0;vec2 f=fract(pos);pos=(pos-f+0.5)*dd;vec4 h=fourSample(pos,vec2(dd));float z=mix(mix(h.x,h.y,f.x),mix(h.z,h.w,f.x),f.y);vec2 w=floor(0.5*(span*u_meter_to_dem-1.0));vec2 d=dd*w;h=fourSample(pos-d,2.0*d+vec2(dd));vec4 diff=abs(h.xzxy-h.ywzw);vec2 slope=min(vec2(0.25),u_meter_to_dem*0.5*(diff.xz+diff.yw)/(2.0*w+vec2(1.0)));vec2 fix=slope*span;float base=z+max(fix.x,fix.y);return u_exaggeration*base;}float elevationFromUint16(float word) {return u_exaggeration*(word/ELEVATION_SCALE-ELEVATION_OFFSET);}\n#else\nfloat elevation(vec2 pos) { return 0.0; }\n#endif\n#ifdef DEPTH_OCCLUSION\nuniform highp sampler2D u_depth;uniform highp vec2 u_depth_size_inv;uniform highp vec2 u_depth_range_unpack;uniform highp float u_occluder_half_size;uniform highp float u_occlusion_depth_offset;\n#ifdef DEPTH_D24\nfloat unpack_depth(float depth) {return depth*u_depth_range_unpack.x+u_depth_range_unpack.y;}vec4 unpack_depth4(vec4 depth) {return depth*u_depth_range_unpack.x+vec4(u_depth_range_unpack.y);}\n#else\nhighp float unpack_depth_rgba(vec4 rgba_depth)\n{const highp vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);return dot(rgba_depth,bit_shift)*2.0-1.0;}\n#endif\nbool isOccluded(vec4 frag) {vec3 coord=frag.xyz/frag.w;\n#ifdef CLIP_ZERO_TO_ONE\ncoord.z=-1.0+2.0*coord.z; \n#endif\n#ifdef DEPTH_D24\nfloat depth=unpack_depth(texture(u_depth,(coord.xy+1.0)*0.5).r);\n#else\nfloat depth=unpack_depth_rgba(texture(u_depth,(coord.xy+1.0)*0.5));\n#endif\nreturn coord.z+u_occlusion_depth_offset > depth;}highp vec4 getCornerDepths(vec2 coord) {highp vec3 df=vec3(u_occluder_half_size*u_depth_size_inv,0.0);highp vec2 uv=0.5*coord.xy+0.5;\n#ifdef DEPTH_D24\nhighp vec4 depth=vec4(\ntexture(u_depth,uv-df.xz).r,texture(u_depth,uv+df.xz).r,texture(u_depth,uv-df.zy).r,texture(u_depth,uv+df.zy).r\n);depth=unpack_depth4(depth);\n#else\nhighp vec4 depth=vec4(\nunpack_depth_rgba(texture(u_depth,uv-df.xz)),unpack_depth_rgba(texture(u_depth,uv+df.xz)),unpack_depth_rgba(texture(u_depth,uv-df.zy)),unpack_depth_rgba(texture(u_depth,uv+df.zy))\n);\n#endif\nreturn depth;}highp float occlusionFadeMultiSample(vec4 frag) {highp vec3 coord=frag.xyz/frag.w;highp vec2 uv=0.5*coord.xy+0.5;\n#ifdef CLIP_ZERO_TO_ONE\ncoord.z=-1.0+2.0*coord.z; \n#endif\nint NX=3;int NY=4;highp vec2 df=u_occluder_half_size*u_depth_size_inv;highp vec2 oneStep=2.0*u_occluder_half_size*u_depth_size_inv/vec2(NX-1,NY-1);highp float res=0.0;for (int y=0; y < NY;++y) {for (int x=0; x < NX;++x) {\n#ifdef DEPTH_D24\nhighp float depth=unpack_depth(texture(u_depth,uv-df+vec2(float(x)*oneStep.x,float(y)*oneStep.y)).r);\n#else\nhighp float depth=unpack_depth_rgba(texture(u_depth,uv-df+vec2(float(x)*oneStep.x,float(y)*oneStep.y)));\n#endif\nres+=1.0-clamp(300.0*(coord.z+u_occlusion_depth_offset-depth),0.0,1.0);}}res=clamp(2.0*res/float(NX*NY)-0.5,0.0,1.0);return res;}highp float occlusionFade(vec4 frag) {highp vec3 coord=frag.xyz/frag.w;\n#ifdef CLIP_ZERO_TO_ONE\ncoord.z=-1.0+2.0*coord.z; \n#endif\nhighp vec4 depth=getCornerDepths(coord.xy);return dot(vec4(0.25),vec4(1.0)-clamp(300.0*(vec4(coord.z+u_occlusion_depth_offset)-depth),0.0,1.0));}\n#else\nbool isOccluded(vec4 frag) { return false; }highp float occlusionFade(vec4 frag) { return 1.0; }highp float occlusionFadeMultiSample(vec4 frag) { return 1.0; }\n#endif",jn="#ifdef FOG\nuniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump mat4 u_fog_matrix;out vec3 v_fog_pos;float fog_range(float depth) {return (depth-u_fog_range[0])/(u_fog_range[1]-u_fog_range[0]);}float fog_horizon_blending(vec3 camera_dir) {float t=max(0.0,camera_dir.z/u_fog_horizon_blend);return u_fog_color.a*exp(-3.0*t*t);}float fog_opacity(float t) {const float decay=6.0;float falloff=1.0-min(1.0,exp(-decay*t));falloff*=falloff*falloff;return u_fog_color.a*min(1.0,1.00747*falloff);}vec3 fog_position(vec3 pos) {return (u_fog_matrix*vec4(pos,1.0)).xyz;}vec3 fog_position(vec2 pos) {return fog_position(vec3(pos,0.0));}float fog(vec3 pos) {float depth=length(pos);float opacity=fog_opacity(fog_range(depth));return opacity*fog_horizon_blending(pos/depth);}\n#endif",Gn="#ifdef FOG\nuniform mediump vec4 u_fog_color;uniform mediump vec2 u_fog_range;uniform mediump float u_fog_horizon_blend;uniform mediump vec2 u_fog_vertical_limit;uniform mediump float u_fog_temporal_offset;in vec3 v_fog_pos;uniform highp vec3 u_frustum_tl;uniform highp vec3 u_frustum_tr;uniform highp vec3 u_frustum_br;uniform highp vec3 u_frustum_bl;uniform highp vec3 u_globe_pos;uniform highp float u_globe_radius;uniform highp vec2 u_viewport;uniform float u_globe_transition;uniform int u_is_globe;float fog_range(float depth) {return (depth-u_fog_range[0])/(u_fog_range[1]-u_fog_range[0]);}float fog_horizon_blending(vec3 camera_dir) {float t=max(0.0,camera_dir.z/u_fog_horizon_blend);return u_fog_color.a*exp(-3.0*t*t);}float fog_opacity(float t) {const float decay=6.0;float falloff=1.0-min(1.0,exp(-decay*t));falloff*=falloff*falloff;return u_fog_color.a*min(1.0,1.00747*falloff);}float globe_glow_progress() {highp vec2 uv=gl_FragCoord.xy/u_viewport;\n#ifdef FLIP_Y\nuv.y=1.0-uv.y;\n#endif\nhighp vec3 ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,uv.x),mix(u_frustum_bl,u_frustum_br,uv.x),1.0-uv.y);highp vec3 dir=normalize(ray_dir);highp vec3 closest_point=dot(u_globe_pos,dir)*dir;highp float sdf=length(closest_point-u_globe_pos)/u_globe_radius;return sdf+PI*0.5;}float fog_opacity(vec3 pos) {float depth=length(pos);return fog_opacity(fog_range(depth));}vec3 fog_apply(vec3 color,vec3 pos,float opacity_limit) {float depth=length(pos);float opacity;if (u_is_globe==1) {float glow_progress=globe_glow_progress();float t=mix(glow_progress,depth,u_globe_transition);opacity=fog_opacity(fog_range(t));} else {opacity=fog_opacity(fog_range(depth));opacity*=fog_horizon_blending(pos/depth);}return mix(color,u_fog_color.rgb,min(opacity,opacity_limit));}vec3 fog_apply(vec3 color,vec3 pos) {return fog_apply(color,pos,1.0);}vec4 fog_apply_from_vert(vec4 color,float fog_opac) {float alpha=EPSILON+color.a;color.rgb=mix(color.rgb/alpha,u_fog_color.rgb,fog_opac)*alpha;return color;}vec3 fog_apply_sky_gradient(vec3 camera_ray,vec3 sky_color) {float horizon_blend=fog_horizon_blending(normalize(camera_ray));return mix(sky_color,u_fog_color.rgb,horizon_blend);}vec4 fog_apply_premultiplied(vec4 color,vec3 pos) {float alpha=EPSILON+color.a;color.rgb=fog_apply(color.rgb/alpha,pos)*alpha;return color;}vec4 fog_apply_premultiplied(vec4 color,vec3 pos,float heightMeters) {float verticalProgress=(u_fog_vertical_limit.x > 0.0 || u_fog_vertical_limit.y > 0.0) ? smoothstep(u_fog_vertical_limit.x,u_fog_vertical_limit.y,heightMeters) : 0.0;float opacityLimit=1.0-smoothstep(0.9,1.0,fog_opacity(pos));return mix(fog_apply_premultiplied(color,pos),color,min(verticalProgress,opacityLimit));}vec3 fog_dither(vec3 color) {return color;}vec4 fog_dither(vec4 color) {return vec4(fog_dither(color.rgb),color.a);}\n#endif",Hn="\n#ifdef LIGHTING_3D_MODE\nuniform mediump vec3 u_lighting_ambient_color;uniform mediump vec3 u_lighting_directional_dir;uniform mediump vec3 u_lighting_directional_color;uniform mediump vec3 u_ground_radiance;float calculate_ambient_directional_factor(vec3 normal) {float NdotL=dot(normal,u_lighting_directional_dir);const float factor_reduction_max=0.3;float dir_luminance=dot(u_lighting_directional_color,vec3(0.2126,0.7152,0.0722));float directional_factor_min=1.0-factor_reduction_max*min(dir_luminance,1.0);float ambient_directional_factor=mix(directional_factor_min,1.0,min((NdotL+1.0),1.0));const float vertical_factor_min=0.92;float vertical_factor=mix(vertical_factor_min,1.0,normal.z*0.5+0.5);return vertical_factor*ambient_directional_factor;}vec3 linearProduct(vec3 srgbIn,vec3 k) {return srgbIn*pow(k,vec3(1./2.2));}vec3 apply_lighting(vec3 color,vec3 normal,float dir_factor) {float ambient_directional_factor=calculate_ambient_directional_factor(normal);vec3 ambient_contrib=ambient_directional_factor*u_lighting_ambient_color;vec3 directional_contrib=u_lighting_directional_color*dir_factor;return linearProduct(color,ambient_contrib+directional_contrib);}vec4 apply_lighting(vec4 color,vec3 normal,float dir_factor) {return vec4(apply_lighting(color.rgb,normal,dir_factor),color.a);}vec3 apply_lighting(vec3 color,vec3 normal) {float dir_factor=max(dot(normal,u_lighting_directional_dir),0.0);return apply_lighting(color.rgb,normal,dir_factor);}vec4 apply_lighting(vec4 color,vec3 normal) {float dir_factor=max(dot(normal,u_lighting_directional_dir),0.0);return vec4(apply_lighting(color.rgb,normal,dir_factor),color.a);}vec3 apply_lighting_ground(vec3 color) {return color*u_ground_radiance;}vec4 apply_lighting_ground(vec4 color) {return vec4(apply_lighting_ground(color.rgb),color.a);}float calculate_NdotL(vec3 normal) {const float ext=0.70710678118;return (clamp(dot(normal,u_lighting_directional_dir),-ext,1.0)+ext)/(1.0+ext);}vec4 apply_lighting_with_emission_ground(vec4 color,float emissive_strength) {return mix(apply_lighting_ground(color),color,emissive_strength);}vec3 compute_flood_lighting(vec3 flood_light_color,float fully_occluded_factor,float occlusion,vec3 ground_shadow_factor) {vec3 fully_occluded_color=flood_light_color*mix(ground_shadow_factor,vec3(1.0),fully_occluded_factor);float occlusion_ramp=smoothstep(0.0,0.2,1.0-occlusion);return mix(fully_occluded_color,flood_light_color,occlusion_ramp);}vec3 compute_emissive_draped(vec3 unlit_color,float fully_occluded_factor,float occlusion,vec3 ground_shadow_factor) {vec3 fully_occluded_color=unlit_color*mix(ground_shadow_factor,vec3(1.0),fully_occluded_factor);return mix(fully_occluded_color,unlit_color,1.0-occlusion);}\n#endif",$n="#ifdef RASTER_ARRAY\nuniform highp sampler2D u_image0;uniform sampler2D u_image1;const vec4 NODATA=vec4(1);ivec4 _raTexLinearCoord(highp vec2 texCoord,highp vec2 texResolution,out highp vec2 fxy) {texCoord=texCoord*texResolution-0.5;fxy=fract(texCoord);texCoord-=fxy;return ivec4(texCoord.xxyy+vec2(1.5,0.5).xyxy);}vec2 _raTexLinearMix(highp vec2 fxy,highp vec4 colorMix,highp float colorOffset,highp vec4 t00,highp vec4 t10,highp vec4 t01,highp vec4 t11) {vec2 c00=t00==NODATA ? vec2(0) : vec2(colorOffset+dot(t00,colorMix),1);vec2 c10=t10==NODATA ? vec2(0) : vec2(colorOffset+dot(t10,colorMix),1);vec2 c01=t01==NODATA ? vec2(0) : vec2(colorOffset+dot(t01,colorMix),1);vec2 c11=t11==NODATA ? vec2(0) : vec2(colorOffset+dot(t11,colorMix),1);return mix(mix(c01,c11,fxy.x),mix(c00,c10,fxy.x),fxy.y);}vec2 raTexture2D_image0_linear(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec2 fxy;ivec4 c=_raTexLinearCoord(texCoord,texResolution,fxy);return _raTexLinearMix(fxy,colorMix,colorOffset,texelFetch(u_image0,c.yz,0),texelFetch(u_image0,c.xz,0),texelFetch(u_image0,c.yw,0),texelFetch(u_image0,c.xw,0)\n);}vec2 raTexture2D_image1_linear(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec2 fxy;ivec4 c=_raTexLinearCoord(texCoord,texResolution,fxy);return _raTexLinearMix(fxy,colorMix,colorOffset,texelFetch(u_image1,c.yz,0),texelFetch(u_image1,c.xz,0),texelFetch(u_image1,c.yw,0),texelFetch(u_image1,c.xw,0)\n);}vec2 raTexture2D_image0_nearest(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec4 t=texelFetch(u_image0,ivec2(texCoord*texResolution),0);return t==NODATA ? vec2(0) : vec2(colorOffset+dot(t,colorMix),1);}vec2 raTexture2D_image1_nearest(highp vec2 texCoord,highp vec2 texResolution,highp vec4 colorMix,highp float colorOffset) {vec4 t=texelFetch(u_image1,ivec2(texCoord*texResolution),0);return t==NODATA ? vec2(0) : vec2(colorOffset+dot(t,colorMix),1);}\n#endif",qn="#ifdef RENDER_SHADOWS\nuniform mediump vec3 u_shadow_direction;uniform highp vec3 u_shadow_normal_offset;vec3 shadow_normal_offset(vec3 normal) {float tileInMeters=u_shadow_normal_offset[0];vec3 n=vec3(-normal.xy,tileInMeters*normal.z);float dotScale=min(1.0-dot(normal,u_shadow_direction),1.0)*0.5+0.5;return n*dotScale;}vec3 shadow_normal_offset_model(vec3 normal) {vec3 transformed_normal=vec3(-normal.xy,normal.z);float NDotL=dot(normalize(transformed_normal),u_shadow_direction);float dotScale=min(1.0-NDotL,1.0)*0.5+0.5;return normal*dotScale;}float shadow_normal_offset_multiplier0() {return u_shadow_normal_offset[1];}float shadow_normal_offset_multiplier1() {return u_shadow_normal_offset[2];}\n#endif",Zn="#ifdef RENDER_SHADOWS\nprecision highp sampler2DShadow;uniform sampler2DShadow u_shadowmap_0;uniform sampler2DShadow u_shadowmap_1;uniform float u_shadow_intensity;uniform float u_shadow_map_resolution;uniform float u_shadow_texel_size;uniform highp vec3 u_shadow_normal_offset;uniform vec2 u_fade_range;uniform mediump vec3 u_shadow_direction;uniform highp vec3 u_shadow_bias;float shadow_sample(sampler2DShadow shadowmap,highp vec3 pos,highp float bias) {\n#ifdef CLIP_ZERO_TO_ONE\nhighp vec3 coord=vec3(pos.xy*0.5+0.5,pos.z-bias);\n#else\nhighp vec3 coord=vec3(pos.xy*0.5+0.5,pos.z*0.5+0.5-bias);\n#endif\nreturn texture(shadowmap,coord);}float shadow_occlusion(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth,highp float bias) {light_view_pos0.xyz/=light_view_pos0.w;\n#ifdef SHADOWS_SINGLE_CASCADE\nvec2 abs_bounds=abs(light_view_pos0.xy);if (abs_bounds.x >=1.0 || abs_bounds.y >=1.0) {return 0.0;}return shadow_sample(u_shadowmap_0,light_view_pos0.xyz,bias);\n#else\nlight_view_pos1.xyz/=light_view_pos1.w;vec4 abs_bounds=abs(vec4(light_view_pos0.xy,light_view_pos1.xy));if (abs_bounds.x < 1.0 && abs_bounds.y < 1.0) {return shadow_sample(u_shadowmap_0,light_view_pos0.xyz,bias);}if (abs_bounds.z >=1.0 || abs_bounds.w >=1.0) {return 0.0;}float occlusion1=shadow_sample(u_shadowmap_1,light_view_pos1.xyz,bias);return clamp(mix(occlusion1,0.0,smoothstep(u_fade_range.x,u_fade_range.y,view_depth)),0.0,1.0);\n#endif\n}highp float calculate_shadow_bias(float NDotL) {\n#ifdef NORMAL_OFFSET\nreturn 0.5*u_shadow_bias.x;\n#else\nreturn 0.5*(u_shadow_bias.x+clamp(u_shadow_bias.y*tan(acos(NDotL)),0.0,u_shadow_bias.z));\n#endif\n}float shadowed_light_factor_normal(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float NDotL=dot(N,u_shadow_direction);float bias=calculate_shadow_bias(NDotL);float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}float shadowed_light_factor_normal_opacity(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth,float shadow_opacity) {float NDotL=dot(N,u_shadow_direction);float bias=calculate_shadow_bias(NDotL);float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias)*shadow_opacity;return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}float shadowed_light_factor_normal_unbiased(vec3 N,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float NDotL=dot(N,u_shadow_direction);float bias=0.0;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return mix(0.0,(1.0-(u_shadow_intensity*occlusion))*NDotL,step(0.0,NDotL));}highp vec2 compute_receiver_plane_depth_bias(highp vec3 pos_dx,highp vec3 pos_dy)\n{highp vec2 biasUV=vec2(\npos_dy.y*pos_dx.z-pos_dx.y*pos_dy.z,pos_dx.x*pos_dy.z-pos_dy.x*pos_dx.z);biasUV*=1.0/((pos_dx.x*pos_dy.y)-(pos_dx.y*pos_dy.x));return biasUV;}float shadowed_light_factor_plane_bias(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {highp vec3 light_view_pos0_xyz=light_view_pos0.xyz/light_view_pos0.w*0.5+0.5;highp vec3 light_view_pos0_ddx=dFdx(light_view_pos0_xyz);highp vec3 light_view_pos0_ddy=dFdy(light_view_pos0_xyz);highp vec2 plane_depth_bias=compute_receiver_plane_depth_bias(light_view_pos0_ddx,light_view_pos0_ddy);highp float bias=dot(vec2(u_shadow_texel_size,u_shadow_texel_size),plane_depth_bias)+0.0001;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return 1.0-(u_shadow_intensity*occlusion);}float shadowed_light_factor(highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float bias=0.0;float occlusion=shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);return 1.0-(u_shadow_intensity*occlusion);}float shadow_occlusion(float ndotl,highp vec4 light_view_pos0,highp vec4 light_view_pos1,float view_depth) {float bias=calculate_shadow_bias(ndotl);return shadow_occlusion(light_view_pos0,light_view_pos1,view_depth,bias);}\n#endif";const Wn=/#include\s+"([^"]+)"/g,Xn=/#pragma mapbox: ([\w\-]+) ([\w]+) ([\w]+) ([\w]+)/g,Yn=/\b[A-Za-z_][A-Za-z0-9_]*\b/g,Jn=new Set(["ifdef","ifndef","elif","if","defined"]),Kn=/* @__PURE__ */new Set;lo(Bn,Kn),lo(Nn,Kn),lo(kn,Kn);const Qn={"_prelude_fog.vertex.glsl":jn,"_prelude_terrain.vertex.glsl":Vn,"_prelude_shadow.vertex.glsl":qn,"_prelude_material_table.vertex.glsl":"#ifdef HAS_SHADER_STORAGE_BLOCK_material_buffer\n#define MATERIAL_TABLE_DEBUG 0\nuniform int u_material_offset;uniform int u_vertex_offset;layout(std140,binding=0)readonly buffer material_buffer{uvec4 material_data[];};struct MaterialInfo{uint dataOffset;\n#if MATERIAL_TABLE_DEBUG\nvec4 colorDebug;\n#endif\n};uint read_buf_no_offset(uint iDword) {return material_data[iDword/4u][iDword % 4u];}uint read_buf(uint iDword) {iDword+=uint(u_material_offset/4);return read_buf_no_offset(iDword);}float read_buf_float(uint iDword){return uintBitsToFloat(read_buf(iDword));}uint read_buf_uint8(uint iDword,uint iUint8){uint dwordOffset=iDword+(iUint8/4u);uint byteOffset=iUint8 & 3u;uint bitOffset=8u*byteOffset;uint mask=0xffu << bitOffset;uint dwordVal=read_buf(dwordOffset);return (dwordVal & mask) >> bitOffset;}uint read_buf_uint16(uint iDword,uint iUint16){uint dwordOffset=iDword+(iUint16 >> 1u);uint bitOffset=(iUint16 & 1u)*16u;uint mask=0xffffu << bitOffset;uint dwordVal=read_buf(dwordOffset);return (dwordVal & mask) >> bitOffset;}uint nrDwordsForVertexIdEntries(uint nrMaterialLookupEntries) {return nrMaterialLookupEntries;}uint nrDwordsForMaterialIdEntries(uint nrMaterialLookupEntries) {return (nrMaterialLookupEntries*2u+3u)/4u;}uint findRangeBinarySearch(uint vertexId,uint numRanges,uint dwordOffset) {uint left=0u;uint right=numRanges-1u;for (uint i=0u; i < 16u; i++) { \nif (left > right) {break;}uint mid=(left+right)/2u;uint start=read_buf(dwordOffset+mid);uint nextStart=(mid+1u < numRanges) ? read_buf(dwordOffset+mid+1u) : 0xffffffffu;if (vertexId >=start && vertexId < nextStart) {return mid;} else if (vertexId < start) {if (mid==0u) {break;}right=mid-1u;} else {left=mid+1u;}}return 0u; \n}uint readVertexId(uint dwordOffset,uint iMaterialLookupEntry) {return read_buf(dwordOffset+iMaterialLookupEntry);}uint findRange(uint vertexId,uint numRanges,uint dwordOffset) {uint iRange;if(numRanges <=64u){uint vertexBegin;for(iRange=0u; iRange < numRanges;++iRange) {vertexBegin=readVertexId(dwordOffset,iRange);if(vertexBegin > vertexId) {break;}}iRange=iRange==0u? 0u : iRange-1u;} else { \niRange=findRangeBinarySearch(vertexId,numRanges,dwordOffset);}return iRange;}MaterialInfo read_material_info(uint vertex_id) {MaterialInfo info;\n#if MATERIAL_TABLE_DEBUG\nconst vec4 red=vec4(1.0,0.0,0.0,1.0);const vec4 orange=vec4(1.0,0.5,0.0,1.0);const vec4 yellow=vec4(1.0,1.0,0.0,1.0);const vec4 green=vec4(0.0,1.0,0.0,1.0);const vec4 indigo=vec4(0.294,0.0,0.510,1.0);const vec4 blue=vec4(0.0,0.0,1.0,1.0);const vec4 purple=vec4(0.5,0.0,0.5,1.0);const vec4 pink=vec4(1.0,0.0,1.0,1.0);info.colorDebug=green;\n#endif\nuint offset=0u;\n#if MATERIAL_TABLE_DEBUG\nbool keepFinding=true;uint magic=read_buf(offset);if(magic !=0xCAFEBABEu) {info.colorDebug=red;keepFinding=false;return info;}\n#endif\noffset++;\n#if MATERIAL_TABLE_DEBUG\nuint nrMaterials=read_buf(offset);uint nrVertices=read_buf(offset+1u);if(keepFinding && vertex_id >=nrVertices) {info.colorDebug=red;keepFinding=false;}\n#endif\noffset+=2u;uint nrMaterialLookupEntries=read_buf(offset++);uint perMaterialEntrySizeDwords=read_buf(offset++);\n#if MATERIAL_TABLE_DEBUG\nif(keepFinding && perMaterialEntrySizeDwords !=1u) {info.colorDebug=red;keepFinding=false;}\n#endif\nuint iMaterialLookup=findRange(vertex_id,nrMaterialLookupEntries,offset);\n#if MATERIAL_TABLE_DEBUG\nif(keepFinding)\n{uint vertexBeginCheck=readVertexId(offset,iMaterialLookup);if(vertexBeginCheck > vertex_id) {info.colorDebug=red;keepFinding=false;}if(iMaterialLookup < nrMaterialLookupEntries-1u) {uint vertexEndCheck=readVertexId(offset,iMaterialLookup+1u);if(vertexEndCheck <=vertex_id) {info.colorDebug=red;keepFinding=false;}}}\n#endif\noffset+=nrDwordsForVertexIdEntries(nrMaterialLookupEntries);uint materialId=iMaterialLookup;\n#if MATERIAL_TABLE_DEBUG\nif(keepFinding) {if(materialId >=nrMaterialLookupEntries) {info.colorDebug=red;}}\n#endif\ninfo.dataOffset=offset+materialId*perMaterialEntrySizeDwords;return info;}uint get_data_location(const MaterialInfo matInfo,uint attribOffsetBytes)\n{uint attribFieldOffsetDwords=attribOffsetBytes/4u;return matInfo.dataOffset+attribFieldOffsetDwords;}vec4 read_material_vec4(const MaterialInfo matInfo,uint attribOffsetBytes){uint loc=get_data_location(matInfo,attribOffsetBytes);return vec4(read_buf_float(loc),read_buf_float(loc+1u),read_buf_float(loc+2u),read_buf_float(loc+3u));}vec2 read_material_vec2(const MaterialInfo matInfo,uint attribOffsetBytes){uint loc=get_data_location(matInfo,attribOffsetBytes);return vec2(read_buf_float(loc),read_buf_float(loc+1u));}float read_material_float(const MaterialInfo matInfo,uint attribOffsetBytes){uint loc=get_data_location(matInfo,attribOffsetBytes);return read_buf_float(loc);}\n#define GET_ATTRIBUTE_float(attrib,matInfo,attrib_offset) read_material_float(matInfo,attrib_offset)\n#define GET_ATTRIBUTE_vec4(attrib,matInfo,attrib_offset) read_material_vec4(matInfo,attrib_offset)\n#define GET_ATTRIBUTE_vec2(attrib,matInfo,attrib_offset) read_material_vec2(matInfo,attrib_offset)\n#define DECLARE_MATERIAL_TABLE_INFO MaterialInfo materialInfo=read_material_info(uint(gl_VertexID));\n#define DECLARE_MATERIAL_TABLE_INFO_DEBUG(dbgColor) MaterialInfo materialInfo=read_material_info(uint(gl_VertexID)); dbgColor=materialInfo.colorDebug;\n#endif","_prelude_fog.fragment.glsl":Gn,"_prelude_shadow.fragment.glsl":Zn,"_prelude_lighting.glsl":Hn,"_prelude_raster_array.glsl":$n},eo={},to="precision highp float;",io="precision mediump float;",ro="\n#if defined(GL_EXT_blend_func_extended) && defined(DUAL_SOURCE_BLENDING)\n#extension GL_EXT_blend_func_extended : require\n#endif",no={preludeTerrain:ho("",Vn),preludeFog:ho(Gn,jn),preludeShadow:ho(Zn,qn),preludeRasterArray:ho($n,""),preludeLighting:ho(Hn,Hn),preludePrecisionQualifiers:ho(io,to),prelude:ho(kn,Nn),preludeExtensions:ho(ro,"")},oo=[ro,io,Bn,no.prelude.fragmentSource].join("\n"),so=[to,Bn,no.prelude.vertexSource].join("\n");var ao={background:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform vec4 u_color;uniform float u_opacity;uniform mediump float u_emissive_strength;\n#ifdef LIGHTING_3D_MODE\nin vec4 v_color;\n#endif\nvoid main() {vec4 out_color;\n#ifdef FEATURE_CUTOUT\nvec2 uv=gl_FragCoord.xy*u_inv_viewport_size.xy;\n#ifdef FLIP_Y\nuv.y=1.0-uv.y;\n#endif\nfloat factorTex=min(texture(u_cutout_factor_image,uv).r,1.0);float cutoutFactor=(1.0-u_feature_cutout_params.x)*factorTex;out_color=u_color*(1.0-cutoutFactor);\n#else\n#ifdef LIGHTING_3D_MODE\nout_color=v_color;\n#else\nout_color=u_color;\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\n#endif\nglFragColor=out_color*u_opacity;\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_lighting.glsl"\nin ivec2 a_pos;uniform mat4 u_matrix;uniform mediump float u_emissive_strength;\n#ifdef LIGHTING_3D_MODE\nuniform mediump vec4 u_color;out vec4 v_color;\n#endif\nvoid main() {gl_Position=u_matrix*vec4(a_pos,0,1);\n#ifndef FEATURE_CUTOUT\n#ifdef LIGHTING_3D_MODE\nv_color=apply_lighting_with_emission_ground(u_color,u_emissive_strength);\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n#endif\n}'),backgroundPattern:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform vec2 u_pattern_tl;uniform vec2 u_pattern_br;uniform vec2 u_texsize;uniform float u_opacity;uniform float u_emissive_strength;uniform sampler2D u_image;in highp vec2 v_pos;void main() {highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(u_pattern_tl/u_texsize,u_pattern_br/u_texsize,imagecoord);vec4 out_color=textureLodCustom(u_image,pos,v_pos);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\nglFragColor=out_color*u_opacity;\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\nuniform mat4 u_matrix;uniform vec2 u_pattern_size;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform vec2 u_pattern_units_to_pixels;in ivec2 a_pos;out highp vec2 v_pos;void main() {vec2 pos=vec2(a_pos);gl_Position=u_matrix*vec4(pos,0,1);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,u_pattern_size,u_pattern_units_to_pixels,pos);\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}'),circle:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nin vec3 v_data;in float v_visibility;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define mediump float radius\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp vec4 stroke_color\n#pragma mapbox: define mediump float stroke_width\n#pragma mapbox: define lowp float stroke_opacity\nuniform float u_emissive_strength;void main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize mediump float radius\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp vec4 stroke_color\n#pragma mapbox: initialize mediump float stroke_width\n#pragma mapbox: initialize lowp float stroke_opacity\nvec2 extrude=v_data.xy;float blur_positive=blur < 0.0 ? 0.0 : 1.0;lowp float antialiasblur=v_data.z;float extrude_length=length(extrude)+antialiasblur*(1.0-blur_positive);float antialiased_blur=-max(abs(blur),antialiasblur);float antialiase_blur_opacity=smoothstep(0.0,antialiasblur,extrude_length-1.0);float opacity_t=blur_positive==1.0 ? \nsmoothstep(0.0,-antialiased_blur,1.0-extrude_length) : \nsmoothstep(antialiased_blur,0.0,extrude_length-1.0)-antialiase_blur_opacity;float color_t=stroke_width < 0.01 ? 0.0 : smoothstep(\nantialiased_blur,0.0,extrude_length-radius/(radius+stroke_width)\n);vec4 out_color=mix(color*opacity,stroke_color*stroke_opacity,color_t);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#endif\n#ifdef FOG\nout_color=fog_apply_premultiplied(out_color,v_fog_pos);\n#endif\nglFragColor=out_color*(v_visibility*opacity_t);\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\n}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\n#define NUM_VISIBILITY_RINGS 2\n#define INV_SQRT2 0.70710678\n#define ELEVATION_BIAS 0.0001\n#define NUM_SAMPLES_PER_RING 16\nuniform mat4 u_matrix;uniform mat2 u_extrude_scale;uniform lowp float u_device_pixel_ratio;uniform highp float u_camera_to_center_distance;in ivec2 a_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_pos_3;in ivec4 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;\n#endif\n#ifdef ELEVATED_ROADS\nin float a_circle_z_offset;\n#endif\nout vec3 v_data;out float v_visibility;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define mediump float radius\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp vec4 stroke_color\n#pragma mapbox: define mediump float stroke_width\n#pragma mapbox: define lowp float stroke_opacity\nvec2 calc_offset(vec2 extrusion,float radius,float stroke_width, float view_scale) {return extrusion*(radius+stroke_width)*u_extrude_scale*view_scale;}float cantilevered_elevation(vec2 pos,float radius,float stroke_width,float view_scale) {vec2 c1=pos+calc_offset(vec2(-1.0,-1.0),radius,stroke_width,view_scale);vec2 c2=pos+calc_offset(vec2(1.0,-1.0),radius,stroke_width,view_scale);vec2 c3=pos+calc_offset(vec2(1.0,1.0),radius,stroke_width,view_scale);vec2 c4=pos+calc_offset(vec2(-1.0,1.0),radius,stroke_width,view_scale);float h1=elevation(c1)+ELEVATION_BIAS;float h2=elevation(c2)+ELEVATION_BIAS;float h3=elevation(c3)+ELEVATION_BIAS;float h4=elevation(c4)+ELEVATION_BIAS;return max(h4,max(h3,max(h1,h2)));}float circle_elevation(vec2 pos) {\n#if defined(TERRAIN)\nreturn elevation(pos)+ELEVATION_BIAS;\n#else\nreturn 0.0;\n#endif\n}vec4 project_vertex(vec2 extrusion,vec4 world_center,vec4 projected_center,float radius,float stroke_width, float view_scale,mat3 surface_vectors) {vec2 sample_offset=calc_offset(extrusion,radius,stroke_width,view_scale);\n#ifdef PITCH_WITH_MAP\n#ifdef PROJECTION_GLOBE_VIEW\nreturn u_matrix*( world_center+vec4(sample_offset.x*surface_vectors[0]+sample_offset.y*surface_vectors[1],0) );\n#else\nreturn u_matrix*( world_center+vec4(sample_offset,0,0) );\n#endif\n#else\nreturn projected_center+vec4(sample_offset,0,0);\n#endif\n}float get_sample_step() {\n#ifdef PITCH_WITH_MAP\nreturn 2.0*PI/float(NUM_SAMPLES_PER_RING);\n#else\nreturn PI/float(NUM_SAMPLES_PER_RING);\n#endif\n}void main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize mediump float radius\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp vec4 stroke_color\n#pragma mapbox: initialize mediump float stroke_width\n#pragma mapbox: initialize lowp float stroke_opacity\nvec2 pos2=vec2(a_pos);vec2 extrude=vec2(mod(pos2,2.0)*2.0-1.0);vec2 circle_center=floor(pos2*0.5);float height=circle_elevation(circle_center);vec4 world_center;mat3 surface_vectors;\n#ifdef PROJECTION_GLOBE_VIEW\nsurface_vectors=globe_mercator_surface_vectors(vec3(a_pos_normal_3)/16384.0,u_up_dir,u_zoom_transition);vec3 surface_extrusion=extrude.x*surface_vectors[0]+extrude.y*surface_vectors[1];vec3 globe_elevation=elevationVector(circle_center)*height;vec3 globe_pos=vec3(a_pos_3)+surface_extrusion+globe_elevation;vec3 mercator_elevation=u_up_dir*u_tile_up_scale*height;vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,circle_center,u_tile_id,u_merc_center)+surface_extrusion+mercator_elevation;vec3 pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);world_center=vec4(pos,1);\n#else \nsurface_vectors=mat3(1.0);world_center=vec4(circle_center,height,1);\n#endif\n#ifdef ELEVATED_ROADS\nworld_center.z+=a_circle_z_offset+ELEVATION_BIAS;\n#endif\nvec4 projected_center=u_matrix*world_center;float view_scale=0.0;\n#ifdef PITCH_WITH_MAP\n#ifdef SCALE_WITH_MAP\nview_scale=1.0;\n#else\nview_scale=projected_center.w/u_camera_to_center_distance;\n#endif\n#else\n#ifdef SCALE_WITH_MAP\nview_scale=u_camera_to_center_distance;\n#else\nview_scale=projected_center.w;\n#endif\n#endif\ngl_Position=project_vertex(extrude,world_center,projected_center,radius,stroke_width,view_scale,surface_vectors);float visibility=0.0;\n#ifdef TERRAIN\nfloat step=get_sample_step();vec4 occlusion_world_center;vec4 occlusion_projected_center;\n#ifdef PITCH_WITH_MAP\nfloat cantilevered_height=cantilevered_elevation(circle_center,radius,stroke_width,view_scale);occlusion_world_center=vec4(circle_center,cantilevered_height,1);occlusion_projected_center=u_matrix*occlusion_world_center;\n#else\nocclusion_world_center=world_center;occlusion_projected_center=projected_center;\n#endif\nfor(int ring=0; ring < NUM_VISIBILITY_RINGS; ring++) {float scale=(float(ring)+1.0)/float(NUM_VISIBILITY_RINGS);for(int i=0; i < NUM_SAMPLES_PER_RING; i++) {vec2 extrusion=vec2(cos(step*float(i)),-sin(step*float(i)))*scale;vec4 frag_pos=project_vertex(extrusion,occlusion_world_center,occlusion_projected_center,radius,stroke_width,view_scale,surface_vectors);visibility+=float(!isOccluded(frag_pos));}}visibility/=float(NUM_VISIBILITY_RINGS)*float(NUM_SAMPLES_PER_RING);\n#else\nvisibility=1.0;\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nvisibility=1.0;\n#endif\nv_visibility=visibility;lowp float antialiasblur=1.0/u_device_pixel_ratio/(radius+stroke_width);v_data=vec3(extrude.x,extrude.y,antialiasblur);\n#ifdef FOG\nv_fog_pos=fog_position(world_center.xyz);\n#endif\n}'),clippingMask:ho("void main() {glFragColor=vec4(1.0);}","in ivec2 a_pos;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);}"),heatmap:ho('#include "_prelude_fog.fragment.glsl"\nuniform highp float u_intensity;in vec2 v_extrude;\n#pragma mapbox: define highp float weight\n#define GAUSS_COEF 0.3989422804014327\nvoid main() {\n#pragma mapbox: initialize highp float weight\nfloat d=-0.5*3.0*3.0*dot(v_extrude,v_extrude);float val=weight*u_intensity*GAUSS_COEF*exp(d);glFragColor=vec4(val,1.0,1.0,1.0);\n#ifdef FOG\nif (u_is_globe==0) {glFragColor.r*=pow(1.0-fog_opacity(v_fog_pos),2.0);}\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_terrain.vertex.glsl"\n#include "_prelude_fog.vertex.glsl"\nuniform mat4 u_matrix;uniform float u_extrude_scale;uniform float u_opacity;uniform float u_intensity;in ivec2 a_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_pos_3;in ivec4 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;\n#endif\nout vec2 v_extrude;\n#pragma mapbox: define highp float weight\n#pragma mapbox: define mediump float radius\nconst highp float ZERO=1.0/255.0/16.0;\n#define GAUSS_COEF 0.3989422804014327\nvoid main() {\n#pragma mapbox: initialize highp float weight\n#pragma mapbox: initialize mediump float radius\nvec2 unscaled_extrude=vec2(mod(vec2(a_pos),2.0)*2.0-1.0);float S=sqrt(-2.0*log(ZERO/weight/u_intensity/GAUSS_COEF))/3.0;v_extrude=S*unscaled_extrude;vec2 extrude=v_extrude*radius*u_extrude_scale;vec2 tilePos=floor(vec2(a_pos)*0.5);vec3 pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 pos_normal_3=vec3(a_pos_normal_3)/16384.0;mat3 surface_vectors=globe_mercator_surface_vectors(pos_normal_3,u_up_dir,u_zoom_transition);vec3 surface_extrusion=extrude.x*surface_vectors[0]+extrude.y*surface_vectors[1];vec3 globe_elevation=elevationVector(tilePos)*elevation(tilePos);vec3 globe_pos=vec3(a_pos_3)+surface_extrusion+globe_elevation;vec3 mercator_elevation=u_up_dir*u_tile_up_scale*elevation(tilePos);vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,tilePos,u_tile_id,u_merc_center)+surface_extrusion+mercator_elevation;pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#else\npos=vec3(tilePos+extrude,elevation(tilePos));\n#endif\ngl_Position=u_matrix*vec4(pos,1);\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}'),heatmapTexture:ho("uniform sampler2D u_image;uniform sampler2D u_color_ramp;uniform float u_opacity;in vec2 v_pos;void main() {float t=texture(u_image,v_pos).r;vec4 color=texture(u_color_ramp,vec2(t,0.5));glFragColor=color*u_opacity;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(0.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}","in ivec2 a_pos;out vec2 v_pos;void main() {gl_Position=vec4(a_pos,0,1);v_pos=vec2(a_pos)*0.5+0.5;}"),collisionBox:ho("in float v_placed;in float v_notUsed;void main() {vec4 red =vec4(1.0,0.0,0.0,1.0);vec4 blue=vec4(0.0,0.0,1.0,0.5);glFragColor =mix(red,blue,step(0.5,v_placed))*0.5;glFragColor*=mix(1.0,0.1,step(0.5,v_notUsed));}",'#include "_prelude_terrain.vertex.glsl"\nin ivec4 a_pos;in ivec2 a_anchor_pos;in ivec2 a_extrude;in uvec2 a_placed;in vec2 a_shift;in vec2 a_elevation_from_sea;in float a_size_scale;in vec2 a_padding;in float a_auto_z_offset;uniform mat4 u_matrix;uniform vec2 u_extrude_scale;uniform float u_camera_to_center_distance;\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_id;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform float u_zoom_transition;\n#endif\nout float v_placed;out float v_notUsed;void main() {vec2 anchor_pos=vec2(a_anchor_pos);float feature_elevation=a_elevation_from_sea.x+a_auto_z_offset;float terrain_elevation=(a_elevation_from_sea.y==1.0 ? 0.0 : elevation(anchor_pos));vec3 proj_pos=vec3(a_pos)+elevationVector(anchor_pos)*(feature_elevation+terrain_elevation);\n#ifdef PROJECTION_GLOBE_VIEW\n#ifndef PROJECTED_POS_ON_VIEWPORT\nvec3 globe_pos=proj_pos;vec3 mercator_pos=mercator_tile_position(u_inv_rot_matrix,anchor_pos,u_tile_id,u_merc_center);proj_pos=mix_globe_mercator(globe_pos,mercator_pos,u_zoom_transition);\n#endif\n#endif\nvec4 projectedPoint=u_matrix*vec4(proj_pos,1);highp float camera_to_anchor_distance=projectedPoint.w;highp float collision_perspective_ratio=clamp(\n0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,1.5);gl_Position=projectedPoint;gl_Position.xy+=(vec2(a_extrude)*a_size_scale+a_shift+a_padding)*u_extrude_scale*gl_Position.w*collision_perspective_ratio;v_placed=float(a_placed.x);v_notUsed=float(a_placed.y);}'),collisionCircle:ho("in float v_radius;in vec2 v_extrude;in float v_perspective_ratio;in float v_collision;void main() {float alpha=0.5*min(v_perspective_ratio,1.0);float stroke_radius=0.9*max(v_perspective_ratio,1.0);float distance_to_center=length(v_extrude);float distance_to_edge=abs(distance_to_center-v_radius);float opacity_t=smoothstep(-stroke_radius,0.0,-distance_to_edge);vec4 color=mix(vec4(0.0,0.0,1.0,0.5),vec4(1.0,0.0,0.0,1.0),v_collision);glFragColor=color*alpha*opacity_t;}","in vec2 a_pos_2f;in float a_radius;in ivec2 a_flags;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform vec2 u_viewport_size;uniform float u_camera_to_center_distance;out float v_radius;out vec2 v_extrude;out float v_perspective_ratio;out float v_collision;vec3 toTilePosition(vec2 screenPos) {vec4 rayStart=u_inv_matrix*vec4(screenPos,-1.0,1.0);vec4 rayEnd =u_inv_matrix*vec4(screenPos, 1.0,1.0);rayStart.xyz/=rayStart.w;rayEnd.xyz /=rayEnd.w;highp float t=(0.0-rayStart.z)/(rayEnd.z-rayStart.z);return mix(rayStart.xyz,rayEnd.xyz,t);}void main() {vec2 quadCenterPos=a_pos_2f;float radius=a_radius;int vertexIdx=a_flags.y;vec2 quadVertexOffset=vec2(\nmix(-1.0,1.0,float(vertexIdx >=2)),mix(-1.0,1.0,float(vertexIdx >=1 && vertexIdx <=2)));vec2 quadVertexExtent=quadVertexOffset*radius;vec3 tilePos=toTilePosition(quadCenterPos);vec4 clipPos=u_matrix*vec4(tilePos,1.0);highp float camera_to_anchor_distance=clipPos.w;highp float collision_perspective_ratio=clamp(\n0.5+0.5*(u_camera_to_center_distance/camera_to_anchor_distance),0.0,4.0);float padding_factor=1.2;v_radius=radius;v_extrude=quadVertexExtent*padding_factor;v_perspective_ratio=collision_perspective_ratio;v_collision=float(a_flags.x);gl_Position=vec4(clipPos.xyz/clipPos.w,1.0)+vec4(quadVertexExtent*padding_factor/u_viewport_size*2.0,0.0,0.0);}"),debug:ho("uniform highp vec4 u_color;uniform sampler2D u_overlay;in vec2 v_uv;void main() {vec4 overlay_color=texture(u_overlay,v_uv);glFragColor=mix(u_color,overlay_color,overlay_color.a);}",'#include "_prelude_terrain.vertex.glsl"\nin ivec2 a_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_pos_3;\n#endif\nout vec2 v_uv;uniform mat4 u_matrix;uniform float u_overlay_scale;void main() {vec2 pos=vec2(a_pos);float h=elevation(pos);v_uv=pos/8192.0;\n#ifdef PROJECTION_GLOBE_VIEW\ngl_Position=u_matrix*vec4(vec3(a_pos_3)+elevationVector(pos)*h,1);\n#else\ngl_Position=u_matrix*vec4(pos*u_overlay_scale,h,1);\n#endif\n}'),elevatedStructuresDepth:ho("void main() {}","in ivec2 a_pos;in float a_height;uniform mat4 u_matrix;uniform float u_depth_bias;void main() {gl_Position=u_matrix*vec4(a_pos,a_height,1);gl_Position.z=gl_Position.z+u_depth_bias;}"),elevatedStructuresDepthReconstruct:ho("#ifdef DEPTH_RECONSTRUCTION\nin float v_height;\n#endif\nvoid main() {\n#ifdef DEPTH_RECONSTRUCTION\nif (v_height >=0.0)\ndiscard;\n#else\n#ifdef FEATURE_CUTOUT\napply_feature_cutout(vec4(0.0,0.0,0.0,1.0),gl_FragCoord,get_cutout_factors(gl_FragCoord).x);\n#endif\n#endif\nglFragColor=vec4(1.0,0.0,0.0,1.0);}","in ivec2 a_pos;in float a_height;uniform mat4 u_matrix;uniform vec3 u_camera_pos;uniform highp float u_depth_bias;uniform lowp float u_height_scale;uniform lowp float u_reset_depth;\n#ifdef DEPTH_RECONSTRUCTION\nout float v_height;\n#endif\nvoid main() {vec3 vpos=vec3(a_pos,a_height*u_height_scale);\n#ifdef DEPTH_RECONSTRUCTION\nif (u_camera_pos.z > vpos.z) {vpos-=(u_camera_pos-vpos)*(vpos.z/(u_camera_pos.z-vpos.z));}v_height=a_height;\n#endif\ngl_Position=u_matrix*vec4(vpos,1);gl_Position.z=u_reset_depth==1.0 ? gl_Position.w : gl_Position.z+u_depth_bias;}"),elevatedStructures:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nin vec3 v_normal;in float v_height;\n#ifdef RENDER_SHADOWS\nin highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in float v_depth;\n#endif\nvec3 linearTosRGB(vec3 color) {return pow(color,vec3(1./2.2));}vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}vec3 compute_view_dependent_emissive_color(float ndotl,float emissive_strength,vec3 color)\n{color=sRGBToLinear(color);color=color*(ndotl+(1.0-min(ndotl*57.29,1.0))*emissive_strength);color=linearTosRGB(color.rgb);return color;}uniform float u_emissive_strength;\n#pragma mapbox: define highp vec4 structure_color\nvoid main() {\n#pragma mapbox: initialize highp vec4 structure_color\nvec3 color=structure_color.xyz;vec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef LIGHTING_3D_MODE\nvec3 normal=normalize(v_normal);vec3 transformed_normal=vec3(-normal.xy,normal.z);float ndotl=calculate_NdotL(transformed_normal);float emissive_strength=u_emissive_strength;emissive_strength=0.0;vec3 emissive_color=compute_view_dependent_emissive_color(ndotl,emissive_strength,color.xyz);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor_normal(transformed_normal,v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);color.rgb=apply_lighting(color.rgb,transformed_normal,light);\n#else\ncolor=apply_lighting(color,transformed_normal);\n#endif\ncolor=mix(color,emissive_color,emissive_strength);if (v_height < 0.0) {float penetration=max(v_height+7.5,0.0);float occlusion=1.0-1.0/PI*acos(1.0-penetration/4.0);color=color*(1.0-pow(occlusion,2.0)*0.3);}\n#endif\n#ifdef FOG\ncolor=fog_apply(color,v_fog_pos);\n#endif\nvec4 out_color=vec4(color,1.0);\n#ifdef INDICATOR_CUTOUT\nout_color=applyCutout(out_color,v_height);\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\nglFragColor=out_color;HANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nin ivec2 a_pos;in float a_height;in ivec4 a_pos_normal_3;uniform mat4 u_matrix;out vec3 v_normal;out float v_height;\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out float v_depth;\n#endif\n#pragma mapbox: define highp vec4 structure_color\nvoid main() {\n#pragma mapbox: initialize highp vec4 structure_color\nv_normal=vec3(a_pos_normal_3)/16384.0;v_height=a_height;vec3 pos=vec3(vec2(a_pos),a_height);gl_Position=u_matrix*vec4(pos,1);\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=pos;vec3 shd_pos1=pos;\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(vec3(-v_normal.xy,v_normal.z));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n}'),fill:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\nuniform float u_emissive_strength;\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\n#ifdef ELEVATED_ROADS\nin highp float v_road_z_offset;\n#endif\n#ifdef INDICATOR_CUTOUT\nin highp float v_z_offset;\n#endif\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\nvec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\nvec4 out_color=color;\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\nout_color*=opacity;\n#ifdef INDICATOR_CUTOUT\nif (v_z_offset >=0.0) {out_color=applyCutout(out_color,v_z_offset);}\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\nglFragColor=out_color;\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nin ivec2 a_pos;\n#ifdef ELEVATED_ROADS\nin float a_road_z_offset;out highp float v_road_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\n#ifdef INDICATOR_CUTOUT\nout highp float v_z_offset;\n#endif\nuniform mat4 u_matrix;\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp float z_offset\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp float z_offset\n#ifdef ELEVATED_ROADS\nz_offset+=a_road_z_offset;v_road_z_offset=z_offset;\n#endif\nfloat hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden);\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset);\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n#ifdef INDICATOR_CUTOUT\nv_z_offset=z_offset;\n#endif\n}'),fillOutline:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nin highp vec2 v_pos;uniform float u_emissive_strength;\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\nfloat dist=length(v_pos-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);vec4 out_color=outline_color;vec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\nglFragColor=out_color*(alpha*opacity);\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nin ivec2 a_pos;\n#ifdef ELEVATED_ROADS\nin float a_road_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\nuniform mat4 u_matrix;uniform vec2 u_world;out highp vec2 v_pos;\n#pragma mapbox: define highp vec4 outline_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define highp float z_offset\nvoid main() {\n#pragma mapbox: initialize highp vec4 outline_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize highp float z_offset\n#ifdef ELEVATED_ROADS\nz_offset+=a_road_z_offset;\n#endif\nfloat hidden=float(opacity==0.0);gl_Position=mix(u_matrix*vec4(a_pos,z_offset,1),AWAY,hidden);\n#ifdef FLIP_Y\nv_pos=(vec2(gl_Position.x,-gl_Position.y)/gl_Position.w+1.0)/2.0*u_world;\n#else\nv_pos=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;\n#endif\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=vec3(a_pos,z_offset);vec3 shd_pos1=vec3(a_pos,z_offset);\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n}'),fillOutlinePattern:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nuniform vec2 u_texsize;uniform sampler2D u_image;\n#ifdef FILL_PATTERN_TRANSITION\nuniform float u_pattern_transition;\n#endif\nuniform float u_emissive_strength;\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\nin highp vec2 v_pos;in highp vec2 v_pos_world;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);float dist=length(v_pos_world-gl_FragCoord.xy);float alpha=1.0-smoothstep(0.0,1.0,dist);vec4 out_color=textureLodCustom(u_image,pos,lod_pos);\n#ifdef APPLY_LUT_ON_GPU\nout_color=applyLUT(u_lutTexture,out_color);\n#endif\n#ifdef FILL_PATTERN_TRANSITION\nvec2 pattern_b_tl=pattern_b.xy;vec2 pattern_b_br=pattern_b.zw;highp vec2 pos_b=mix(pattern_b_tl/u_texsize,pattern_b_br/u_texsize,imagecoord);vec4 color_b=textureLodCustom(u_image,pos_b,lod_pos);out_color=out_color*(1.0-u_pattern_transition)+color_b*u_pattern_transition;\n#endif\nvec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);out_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\nglFragColor=out_color*(alpha*opacity);\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nuniform mat4 u_matrix;uniform vec2 u_world;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_tile_units_to_pixels;in ivec2 a_pos;\n#ifdef ELEVATED_ROADS\nin float a_road_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\nout highp vec2 v_pos;out highp vec2 v_pos_world;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define lowp float pixel_ratio\n#pragma mapbox: define highp float z_offset\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\n#pragma mapbox: initialize lowp float pixel_ratio\n#pragma mapbox: initialize highp float z_offset\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);\n#ifdef ELEVATED_ROADS\nz_offset+=a_road_z_offset;\n#endif\nfloat hidden=float(opacity==0.0);vec2 pos=vec2(a_pos);gl_Position=mix(u_matrix*vec4(pos,z_offset,1),AWAY,hidden);vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,pos);\n#ifdef FLIP_Y\nv_pos_world=(vec2(gl_Position.x,-gl_Position.y)/gl_Position.w+1.0)/2.0*u_world;\n#else\nv_pos_world=(gl_Position.xy/gl_Position.w+1.0)/2.0*u_world;\n#endif\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=vec3(pos,z_offset);vec3 shd_pos1=vec3(pos,z_offset);\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}'),fillPattern:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nuniform vec2 u_texsize;uniform sampler2D u_image;\n#ifdef FILL_PATTERN_TRANSITION\nuniform float u_pattern_transition;\n#endif\nin highp vec2 v_pos;uniform float u_emissive_strength;\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\n#ifdef ELEVATED_ROADS\nin highp float v_road_z_offset;\n#endif\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);vec4 out_color=textureLodCustom(u_image,pos,lod_pos);\n#ifdef APPLY_LUT_ON_GPU\nout_color=applyLUT(u_lutTexture,out_color);\n#endif\n#ifdef FILL_PATTERN_TRANSITION\nvec2 pattern_b_tl=vec2(pattern_b.xy);vec2 pattern_b_br=vec2(pattern_b.zw);highp vec2 pos_b=mix(pattern_b_tl/u_texsize,pattern_b_br/u_texsize,imagecoord);vec4 color_b=textureLodCustom(u_image,pos_b,lod_pos);out_color=out_color*(1.0-u_pattern_transition)+color_b*u_pattern_transition;\n#endif\nvec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,u_emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);\n#ifdef ELEVATED_ROADS\nout_color.rgb*=mix(v_road_z_offset !=0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light);\n#else\nout_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\nglFragColor=out_color*opacity;\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nuniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_tile_units_to_pixels;in ivec2 a_pos;\n#ifdef ELEVATED_ROADS\nin float a_road_z_offset;out highp float v_road_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\nout highp vec2 v_pos;\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp uvec4 pattern\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define lowp float pixel_ratio\n#pragma mapbox: define highp float z_offset\nvoid main() {\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump uvec4 pattern\n#pragma mapbox: initialize lowp float pixel_ratio\n#pragma mapbox: initialize highp float z_offset\n#ifdef FILL_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;\n#ifdef ELEVATED_ROADS\nz_offset+=a_road_z_offset;v_road_z_offset=z_offset;\n#endif\nfloat hidden=float(opacity==0.0);vec2 pos=vec2(a_pos);gl_Position=mix(u_matrix*vec4(pos,z_offset,1),AWAY,hidden);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,pos);\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=vec3(pos,z_offset);vec3 shd_pos1=vec3(pos,z_offset);\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n}'),lineBlendComposite:ho("uniform highp sampler2D u_image;uniform float u_opacity;uniform int u_blend_mode;uniform highp float u_max_density;in vec2 v_pos;\n#define ADDITIVE 1\nvoid main() {vec4 color=texture(u_image,v_pos);if (u_blend_mode==ADDITIVE) {if (color.a <=0.0) {discard;}highp float density=color.a;vec3 avgColor=color.rgb/max(density,0.001);highp float n=density/max(u_max_density,0.001);highp float t=sqrt(n/(n+1.0));glFragColor=vec4(avgColor*t,t);} else {vec3 multiplyFactor=color.rgb*u_opacity+(1.0-u_opacity);glFragColor=vec4(multiplyFactor,1.0);}\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(0.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}","in ivec2 a_pos;out vec2 v_pos;void main() {gl_Position=vec4(a_pos,0,1);v_pos=vec2(a_pos)*0.5+0.5;}"),lineBlendReduce:ho("uniform highp sampler2D u_image;uniform vec2 u_texel_size;uniform bool u_first_pass;in vec2 v_pos;void main() {vec2 o=u_texel_size*0.5;vec4 s0=texture(u_image,v_pos+vec2(-o.x,-o.y));vec4 s1=texture(u_image,v_pos+vec2( o.x,-o.y));vec4 s2=texture(u_image,v_pos+vec2(-o.x, o.y));vec4 s3=texture(u_image,v_pos+vec2( o.x, o.y));float r0; float g0;float r1; float g1;float r2; float g2;float r3; float g3;if (u_first_pass) {float a0=s0.a;float a1=s1.a;float a2=s2.a;float a3=s3.a;r0=a0; g0=a0 > 0.0 ? 1.0 : 0.0;r1=a1; g1=a1 > 0.0 ? 1.0 : 0.0;r2=a2; g2=a2 > 0.0 ? 1.0 : 0.0;r3=a3; g3=a3 > 0.0 ? 1.0 : 0.0;} else {r0=s0.r; g0=s0.g;r1=s1.r; g1=s1.g;r2=s2.r; g2=s2.g;r3=s3.r; g3=s3.g;}glFragColor=vec4((r0+r1+r2+r3)*0.25,(g0+g1+g2+g3)*0.25,0.0,0.0);}","in ivec2 a_pos;out vec2 v_pos;void main() {gl_Position=vec4(a_pos,0,1);v_pos=vec2(a_pos)*0.5+0.5;}"),fillExtrusion:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#include "_prelude_lighting.glsl"\nin vec4 v_color;in vec4 v_flat;\n#ifdef RENDER_SHADOWS\nin highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;\n#endif\nuniform lowp float u_opacity;\n#ifdef RENDER_FRONT_CUTOFF\nin float v_front_cutoff_opacity;\n#endif\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nin vec4 v_ground_roof;\n#endif\n#endif\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;in vec2 v_ao;\n#endif\n#if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE)\nin vec4 v_roof_color;\n#endif\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE)\nin highp vec3 v_normal;\n#endif\nuniform vec3 u_flood_light_color;uniform highp float u_vertical_scale;uniform float u_flood_light_intensity;uniform vec3 u_ground_shadow_factor;\n#if defined(LIGHTING_3D_MODE) && defined(FLOOD_LIGHT)\nin float v_flood_radius;in float v_has_floodlight;\n#endif\nin float v_height;\n#pragma mapbox: define highp float emissive_strength\nvoid main() {\n#pragma mapbox: initialize highp float emissive_strength\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE)\nvec3 normal=normalize(v_normal);\n#endif\nfloat z;vec4 color=v_color;\n#ifdef ZERO_ROOF_RADIUS\nz=float(normal.z > 0.00001);\n#ifdef LIGHTING_3D_MODE\nnormal=mix(normal,vec3(0.0,0.0,1.0),z);\n#else\ncolor=mix(v_color,v_roof_color,z);\n#endif\n#endif\nfloat h=max(0.0,v_height);float ao_shade=1.0;\n#ifdef FAUX_AO\nfloat intensity=u_ao[0];float h_floors=h/(u_ao[1]*u_vertical_scale);float y_shade=1.0-0.9*intensity*min(v_ao.y,1.0);ao_shade=(1.0-0.08*intensity)*(y_shade+(1.0-y_shade)*(1.0-pow(1.0-min(h_floors/16.0,1.0),16.0)))+0.08*intensity*min(h_floors/160.0,1.0);float concave=v_ao.x*v_ao.x;\n#ifdef ZERO_ROOF_RADIUS\nconcave*=(1.0-z);\n#endif\nfloat x_shade=mix(1.0,mix(0.6,0.75,min(h_floors/30.0,1.0)),intensity)+0.1*intensity*min(h,1.0);ao_shade*=mix(1.0,x_shade*x_shade*x_shade,concave);\n#ifdef LIGHTING_3D_MODE\n#ifdef FLOOD_LIGHT\ncolor.rgb*=mix(ao_shade,1.0,v_has_floodlight);\n#else\ncolor.rgb*=ao_shade;\n#endif\n#else\ncolor.rgb*=ao_shade;\n#endif\n#endif\n#ifdef LIGHTING_3D_MODE\nfloat flood_radiance=0.0;\n#ifdef FLOOD_LIGHT\nflood_radiance=(1.0-min(h/v_flood_radius,1.0))*u_flood_light_intensity*v_has_floodlight;\n#endif\n#ifdef RENDER_SHADOWS\n#ifdef FLOOD_LIGHT\nfloat ndotl_unclamped=dot(normal,u_shadow_direction);float ndotl=max(0.0,ndotl_unclamped);float occlusion=ndotl_unclamped < 0.0 ? 1.0 : shadow_occlusion(ndotl,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);vec3 litColor=apply_lighting(color.rgb,normal,(1.0-u_shadow_intensity*occlusion)*ndotl);vec3 floodLitColor=compute_flood_lighting(u_flood_light_color*u_opacity,1.0-u_shadow_intensity,occlusion,u_ground_shadow_factor);color.rgb=mix(litColor,floodLitColor,flood_radiance);\n#else\nfloat shadowed_lighting_factor;\n#ifdef RENDER_CUTOFF\nshadowed_lighting_factor=shadowed_light_factor_normal_opacity(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w,v_cutoff_opacity);if (v_cutoff_opacity==0.0) {discard;}\n#else\nshadowed_lighting_factor=shadowed_light_factor_normal(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);\n#endif\ncolor.rgb=apply_lighting(color.rgb,normal,shadowed_lighting_factor);\n#endif\n#else\ncolor.rgb=apply_lighting(color.rgb,normal);\n#ifdef FLOOD_LIGHT\ncolor.rgb=mix(color.rgb,u_flood_light_color*u_opacity,flood_radiance);\n#endif\n#endif\ncolor.rgb=mix(color.rgb,v_flat.rgb,emissive_strength);color*=u_opacity;\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos,h));\n#endif\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\n{float ditherOpacity=cutoutGroundRoofOpacity(v_ground_roof);if (ditherOpacity < 1.0) {int index=(int(gl_FragCoord.x) % 4)*4+(int(gl_FragCoord.y) % 4);if (ditherOpacity < DITHER_THRESHOLDS[index]) {discard;}}}\n#else\ncolor=applyCutout(color,h);\n#endif\n#endif\n#ifdef RENDER_FRONT_CUTOFF\nif (v_front_cutoff_opacity < 1.0) {int index=(int(gl_FragCoord.x) % 4)*4+(int(gl_FragCoord.y) % 4);if (v_front_cutoff_opacity < DITHER_THRESHOLDS[index]) {discard;}}\n#endif\n#ifdef FEATURE_CUTOUT\ncolor=apply_feature_cutout(color,gl_FragCoord,get_cutout_factors(gl_FragCoord).x);\n#endif\nglFragColor=color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_material_table.vertex.glsl"\nuniform mat4 u_matrix;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform float u_edge_radius;uniform float u_width_scale;in ivec4 a_pos_normal_ed;\n#if defined(HAS_CENTROID) || defined(TERRAIN)\nin uvec2 a_centroid_pos;\n#endif\n#ifdef RENDER_WALL_MODE\nin ivec4 a_join_normal_inside;\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_pos_3;in ivec4 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;uniform float u_height_lift;\n#endif\n#ifdef TERRAIN\nuniform int u_height_type;uniform int u_base_type;\n#endif\nuniform highp float u_vertical_scale;\n#ifdef RENDER_FRONT_CUTOFF\nuniform vec3 u_front_cutoff_params;out float v_front_cutoff_opacity;\n#endif\nout vec4 v_color;out vec4 v_flat;\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;\n#endif\n#if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE)\nout vec4 v_roof_color;\n#endif\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE)\nout highp vec3 v_normal;\n#endif\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;out vec2 v_ao;\n#endif\n#if defined(LIGHTING_3D_MODE) && defined(FLOOD_LIGHT)\nout float v_flood_radius;out float v_has_floodlight;\n#endif\nout float v_height;\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nout vec4 v_ground_roof;\n#endif\n#endif\nvec3 linearTosRGB(vec3 color) {return pow(color,vec3(1./2.2));}vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define highp float flood_light_wall_radius\n#pragma mapbox: define highp float line_width\n#pragma mapbox: define highp float emissive_strength\nvoid main() {DECLARE_MATERIAL_TABLE_INFO\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize highp float flood_light_wall_radius\n#pragma mapbox: initialize highp float line_width\n#pragma mapbox: initialize highp float emissive_strength\nbase*=u_vertical_scale;height*=u_vertical_scale;vec4 top_up_ny_start=vec4(a_pos_normal_ed & 1);vec4 pos_nx=vec4(a_pos_normal_ed >> 1);float x_normal=pos_nx.z/8192.0;vec3 normal=top_up_ny_start.y==1.0 ? vec3(0.0,0.0,1.0) : normalize(vec3(x_normal,(2.0*top_up_ny_start.z-1.0)*(1.0-abs(x_normal)),0.0));\n#if defined(ZERO_ROOF_RADIUS) || defined(RENDER_SHADOWS) || defined(LIGHTING_3D_MODE)\nv_normal=normal;\n#endif\nbase=max(0.0,base);float attr_height=height;height=max(0.0,top_up_ny_start.y==0.0 && top_up_ny_start.x==1.0 ? height-u_edge_radius : height);float t=top_up_ny_start.x;vec2 centroid_pos=vec2(0.0);\n#if defined(HAS_CENTROID) || defined(TERRAIN)\ncentroid_pos=vec2(a_centroid_pos);\n#endif\nfloat ele=0.0;float h=0.0;float c_ele=0.0;vec3 pos;\n#ifdef TERRAIN\nbool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;ele=elevation(pos_nx.xy);bool is_elevation_encoded=centroid_pos.y==0.0 || (centroid_pos.y > 0.0 && (int(centroid_pos.y) & 7)==7);c_ele=is_flat_height || is_flat_base ? (is_elevation_encoded ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);h=t > 0.0 ? max(h_base,h_height) : h_base;\n#else\nh=t > 0.0 ? height : base;\n#endif\npos=vec3(pos_nx.xy,h);\n#ifdef PROJECTION_GLOBE_VIEW\nfloat lift=float((t+base) > 0.0)*u_height_lift;h+=lift;vec3 globe_normal=normalize(mix(vec3(a_pos_normal_3)/16384.0,u_up_dir,u_zoom_transition));vec3 globe_pos=vec3(a_pos_3)+globe_normal*(u_tile_up_scale*h);vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,pos.xy,u_tile_id,u_merc_center)+u_up_dir*u_tile_up_scale*pos.z;pos=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#endif\nfloat cutoff=1.0;vec3 scaled_pos=pos;\n#if defined(RENDER_CUTOFF) || defined(RENDER_FRONT_CUTOFF)\nvec2 centroid_decoded=pos.xy;bool isBorderCentroid=false;if (centroid_pos.x > 0.0 && centroid_pos.y > 0.0) {int iy=int(centroid_pos.y);int spanYbits=iy & 7;if (spanYbits==7) {isBorderCentroid=true;int borderID=(iy >> 3) & 3;float coordAlongBorder=float(iy >> 5)*4.0;if (borderID==0) centroid_decoded=vec2(0.0,coordAlongBorder);else if (borderID==1) centroid_decoded=vec2(EXTENT,coordAlongBorder);else if (borderID==2) centroid_decoded=vec2(coordAlongBorder,0.0);else centroid_decoded=vec2(coordAlongBorder,EXTENT);} else {centroid_decoded=floor(centroid_pos/8.0);}}\n#endif\n#if defined(RENDER_CUTOFF) || defined(RENDER_FRONT_CUTOFF)\nvec4 ground=u_matrix*vec4(centroid_decoded,ele,1.0);\n#endif\n#ifdef RENDER_CUTOFF\n#ifdef CLIP_ZERO_TO_ONE\ncutoff=cutoff_opacity(u_cutoff_params,ground.z*2.0-ground.w);\n#else\ncutoff=cutoff_opacity(u_cutoff_params,ground.z);\n#endif\nif (centroid_pos.y !=0.0 && centroid_pos.x !=0.0) {vec3 centroid_random=vec3(centroid_pos.xy,centroid_pos.x+centroid_pos.y+1.0);vec3 ground_pos=centroid_random/8.0;vec3 g=floor(ground_pos);vec3 mod_=centroid_random-g*8.0;float seed=min(1.0,0.1*(min(3.5,max(mod_.x+mod_.y,0.2*attr_height))*0.35+mod_.z));if (cutoff < 0.8-seed) {cutoff=0.0;}}float cutoff_scale=cutoff;v_cutoff_opacity=cutoff;scaled_pos.z=mix(c_ele,h,cutoff_scale);\n#endif\nfloat hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (cutoff==0.0 && centroid_pos.x !=0.0) || (color.a==0.0));\n#ifdef RENDER_FRONT_CUTOFF\nv_front_cutoff_opacity=1.0;if (centroid_pos.x > 0.0 && centroid_pos.y > 0.0) {hidden=max(hidden,float(ground.w <=0.0));float ndc_y=ground.y/max(ground.w,0.001);float threshold=u_front_cutoff_params.x*2.0-1.0;float range_ndc=u_front_cutoff_params.y*2.0;if (!isBorderCentroid) {hidden=max(hidden,float(ndc_y < threshold-range_ndc));}float t=clamp((ndc_y-(threshold-range_ndc))/max(range_ndc,0.001),0.0,1.0);v_front_cutoff_opacity=mix(u_front_cutoff_params.z,1.0,t);}\n#endif\n#ifdef RENDER_WALL_MODE\nvec3 join_normal_inside=vec3(a_join_normal_inside);vec2 wall_offset=u_width_scale*line_width*(join_normal_inside.xy/EXTENT);scaled_pos.xy+=(1.0-join_normal_inside.z)*wall_offset*0.5;scaled_pos.xy-=join_normal_inside.z*wall_offset*0.5;\n#endif\ngl_Position=mix(u_matrix*vec4(scaled_pos,1),AWAY,hidden);h=h-ele;v_height=h;\n#ifdef RENDER_SHADOWS\nvec3 shd_pos0=pos;vec3 shd_pos1=pos;\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset(normal);shd_pos0+=offset*shadow_normal_offset_multiplier0();shd_pos1+=offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);\n#endif\nfloat NdotL=0.0;float colorvalue=0.0;\n#ifndef LIGHTING_3D_MODE\ncolorvalue=color.r*0.2126+color.g*0.7152+color.b*0.0722;vec4 ambientlight=vec4(0.03,0.03,0.03,1.0);color+=ambientlight;NdotL=clamp(dot(normal,u_lightpos),0.0,1.0);NdotL=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),NdotL);if (normal.y !=0.0) {float r=0.84;r=mix(0.7,0.98,1.0-u_lightintensity);NdotL*=(\n(1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));}\n#endif\n#ifdef FAUX_AO\nfloat concave=pos_nx.w-floor(pos_nx.w*0.5)*2.0;float start=top_up_ny_start.w;float y_ground=1.0-clamp(t+base,0.0,1.0);float top_height=height;\n#ifdef TERRAIN\ntop_height=mix(max(c_ele+height,ele+base+2.0),ele+height,float(centroid_pos.x==0.0))-ele;y_ground+=y_ground*5.0/max(3.0,top_height);\n#endif\nv_ao=vec2(mix(concave,-concave,start),y_ground);NdotL*=(1.0+0.05*(1.0-top_up_ny_start.y)*u_ao[0]);\n#ifdef PROJECTION_GLOBE_VIEW\ntop_height+=u_height_lift;\n#endif\ngl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w;\n#endif\n#ifdef LIGHTING_3D_MODE\n#ifdef FLOOD_LIGHT\nfloat is_wall=1.0-float(t > 0.0 && top_up_ny_start.y > 0.0);v_has_floodlight=float(flood_light_wall_radius > 0.0 && is_wall > 0.0);v_flood_radius=flood_light_wall_radius*u_vertical_scale;\n#endif\nv_color=vec4(color.rgb,1.0);float ndotl=calculate_NdotL(normal);v_flat.rgb=sRGBToLinear(color.rgb);v_flat.rgb=v_flat.rgb*(ndotl+(1.0-min(ndotl*57.29,1.0))*emissive_strength);v_flat=vec4(linearTosRGB(v_flat.rgb),1.0);\n#else\nv_color=vec4(0.0,0.0,0.0,1.0);v_color.rgb+=clamp(color.rgb*NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_color*=u_opacity;\n#endif\n#if defined(ZERO_ROOF_RADIUS) && !defined(LIGHTING_3D_MODE)\nfloat roofNdotL=clamp(u_lightpos.z,0.0,1.0);roofNdotL=mix((1.0-u_lightintensity),max((1.0-colorvalue+u_lightintensity),1.0),roofNdotL);v_roof_color=vec4(0.0,0.0,0.0,1.0);v_roof_color.rgb+=clamp(color.rgb*roofNdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_roof_color*=u_opacity;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nvec4 pos_ground=u_matrix*vec4(pos.xy,ele,1.0);vec4 pos_roof=u_matrix*vec4(pos.xy,ele+height,1.0);v_ground_roof=vec4(pos_ground.xy/pos_ground.w,pos_roof.xy/pos_roof.w);\n#endif\n#endif\n}'),fillExtrusionDepth:ho("void main() {}",'#include "_prelude_terrain.vertex.glsl"\n#include "_prelude_material_table.vertex.glsl"\nuniform mat4 u_matrix;uniform float u_edge_radius;uniform float u_width_scale;uniform float u_vertical_scale;\n#ifdef TERRAIN\nuniform int u_height_type;uniform int u_base_type;\n#endif\nin ivec4 a_pos_normal_ed;\n#if defined(HAS_CENTROID) || defined(TERRAIN)\nin uvec2 a_centroid_pos;\n#endif\n#ifdef RENDER_WALL_MODE\nin ivec4 a_join_normal_inside;\n#endif\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define highp float line_width\n#pragma mapbox: define highp vec4 color\nvoid main() {DECLARE_MATERIAL_TABLE_INFO\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize highp float line_width\n#pragma mapbox: initialize highp vec4 color\nbase*=u_vertical_scale;height*=u_vertical_scale;vec3 top_up_ny=vec3(a_pos_normal_ed.xyz & 1);vec3 pos_nx=vec3(a_pos_normal_ed.xyz >> 1);base=max(0.0,base);height=max(0.0,top_up_ny.y==0.0 && top_up_ny.x==1.0 ? height-u_edge_radius : height);float t=top_up_ny.x;vec2 centroid_pos=vec2(0.0);\n#if defined(HAS_CENTROID) || defined(TERRAIN)\ncentroid_pos=vec2(a_centroid_pos);\n#endif\nvec3 pos;\n#ifdef TERRAIN\nbool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;float ele=elevation(pos_nx.xy);bool is_elevation_encoded=centroid_pos.y==0.0 || (centroid_pos.y > 0.0 && int(centroid_pos.y)-(int(centroid_pos.y)/8)*8==7);float c_ele=is_flat_height || is_flat_base ? (is_elevation_encoded ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);float h=t > 0.0 ? max(h_base,h_height) : h_base;pos=vec3(pos_nx.xy,h);\n#else\npos=vec3(pos_nx.xy,t > 0.0 ? height : base);\n#endif\n#ifdef RENDER_WALL_MODE\nvec3 join_normal_inside=vec3(a_join_normal_inside);vec2 wall_offset=u_width_scale*line_width*(join_normal_inside.xy/EXTENT);pos.xy+=(1.0-join_normal_inside.z)*wall_offset*0.5;pos.xy-=join_normal_inside.z*wall_offset*0.5;\n#endif\nfloat hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (color.a==0.0));gl_Position=mix(u_matrix*vec4(pos,1),AWAY,hidden);}'),fillExtrusionPattern:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform vec2 u_texsize;uniform sampler2D u_image;\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\nuniform float u_pattern_transition;\n#endif\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;in vec3 v_ao;\n#endif\n#ifdef LIGHTING_3D_MODE\nin vec3 v_normal;\n#endif\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\nin highp vec2 v_pos;in vec4 v_lighting;uniform lowp float u_opacity;\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define mediump uvec4 pattern\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define highp float pixel_ratio\nvoid main() {\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\n#pragma mapbox: initialize highp float pixel_ratio\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);highp vec2 imagecoord=mod(v_pos,1.0);highp vec2 pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,imagecoord);highp vec2 lod_pos=mix(pattern_tl/u_texsize,pattern_br/u_texsize,v_pos);vec4 out_color=textureLodCustom(u_image,pos,lod_pos);\n#ifdef APPLY_LUT_ON_GPU\nout_color=applyLUT(u_lutTexture,out_color);\n#endif\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\nvec2 pattern_b_tl=vec2(pattern_b.xy);vec2 pattern_b_br=vec2(pattern_b.zw);highp vec2 pos_b=mix(pattern_b_tl/u_texsize,pattern_b_br/u_texsize,imagecoord);vec4 color_b=textureLodCustom(u_image,pos_b,lod_pos);out_color=out_color*(1.0-u_pattern_transition)+color_b*u_pattern_transition;\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting(out_color,normalize(v_normal))*u_opacity;\n#else\nout_color=out_color*v_lighting;\n#endif\n#ifdef FAUX_AO\nfloat intensity=u_ao[0];float h=max(0.0,v_ao.z);float h_floors=h/u_ao[1];float y_shade=1.0-0.9*intensity*min(v_ao.y,1.0);float shade=(1.0-0.08*intensity)*(y_shade+(1.0-y_shade)*(1.0-pow(1.0-min(h_floors/16.0,1.0),16.0)))+0.08*intensity*min(h_floors/160.0,1.0);float concave=v_ao.x*v_ao.x;float x_shade=mix(1.0,mix(0.6,0.75,min(h_floors/30.0,1.0)),intensity)+0.1*intensity*min(h,1.0);shade*=mix(1.0,x_shade*x_shade*x_shade,concave);out_color.rgb=out_color.rgb*shade;\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\n#ifdef INDICATOR_CUTOUT\nout_color=applyCutout(out_color,height);\n#endif\nglFragColor=out_color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_material_table.vertex.glsl"\nuniform mat4 u_matrix;uniform vec2 u_pixel_coord_upper;uniform vec2 u_pixel_coord_lower;uniform float u_height_factor;uniform float u_tile_units_to_pixels;uniform float u_vertical_gradient;uniform lowp float u_opacity;uniform float u_width_scale;uniform vec3 u_lightcolor;uniform lowp vec3 u_lightpos;uniform lowp float u_lightintensity;in ivec4 a_pos_normal_ed;\n#if defined(HAS_CENTROID) || defined(TERRAIN)\nin uvec2 a_centroid_pos;\n#endif\n#ifdef RENDER_WALL_MODE\nin ivec4 a_join_normal_inside;\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_pos_3;in ivec4 a_pos_normal_3;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_tile_id;uniform float u_zoom_transition;uniform vec3 u_up_dir;uniform float u_height_lift;\n#endif\n#ifdef TERRAIN\nuniform int u_height_type;uniform int u_base_type;\n#endif\nout highp vec2 v_pos;out vec4 v_lighting;\n#ifdef FAUX_AO\nuniform lowp vec2 u_ao;out vec3 v_ao;\n#endif\n#ifdef LIGHTING_3D_MODE\nout vec3 v_normal;\n#endif\n#pragma mapbox: define highp float base\n#pragma mapbox: define highp float height\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define mediump uvec4 pattern\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define highp float pixel_ratio\n#pragma mapbox: define highp float line_width\nvoid main() {DECLARE_MATERIAL_TABLE_INFO\n#pragma mapbox: initialize highp float base\n#pragma mapbox: initialize highp float height\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef FILL_EXTRUSION_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\n#pragma mapbox: initialize highp float pixel_ratio\n#pragma mapbox: initialize highp float line_width\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);vec4 top_up_ny_start=vec4(a_pos_normal_ed & 1);vec4 pos_nx=vec4(a_pos_normal_ed >> 1);float x_normal=pos_nx.z/8192.0;vec3 normal=top_up_ny_start.y==1.0 ? vec3(0.0,0.0,1.0) : normalize(vec3(x_normal,(2.0*top_up_ny_start.z-1.0)*(1.0-abs(x_normal)),0.0));float edgedistance=float(a_pos_normal_ed.w);vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;base=max(0.0,base);height=max(0.0,height);float t=top_up_ny_start.x;float z=t > 0.0 ? height : base;vec2 centroid_pos=vec2(0.0);\n#if defined(HAS_CENTROID) || defined(TERRAIN)\ncentroid_pos=vec2(a_centroid_pos);\n#endif\nfloat ele=0.0;float h=z;vec3 p;float c_ele;\n#ifdef TERRAIN\nbool is_flat_height=centroid_pos.x !=0.0 && u_height_type==1;bool is_flat_base=centroid_pos.x !=0.0 && u_base_type==1;ele=elevation(pos_nx.xy);bool is_elevation_encoded=centroid_pos.y==0.0 || (centroid_pos.y > 0.0 && int(centroid_pos.y)-(int(centroid_pos.y)/8)*8==7);c_ele=is_flat_height || is_flat_base ? (is_elevation_encoded ? elevationFromUint16(centroid_pos.x) : flatElevation(centroid_pos)) : ele;float h_height=is_flat_height ? max(c_ele+height,ele+base+2.0) : ele+height;float h_base=is_flat_base ? max(c_ele+base,ele+base) : ele+(base==0.0 ?-5.0 : base);h=t > 0.0 ? max(h_base,h_height) : h_base;p=vec3(pos_nx.xy,h);\n#else\np=vec3(pos_nx.xy,z);\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nfloat lift=float((t+base) > 0.0)*u_height_lift;h+=lift;vec3 globe_normal=normalize(mix(vec3(a_pos_normal_3)/16384.0,u_up_dir,u_zoom_transition));vec3 globe_pos=vec3(a_pos_3)+globe_normal*(u_tile_up_scale*(p.z+lift));vec3 merc_pos=mercator_tile_position(u_inv_rot_matrix,p.xy,u_tile_id,u_merc_center)+u_up_dir*u_tile_up_scale*p.z;p=mix_globe_mercator(globe_pos,merc_pos,u_zoom_transition);\n#endif\n#ifdef RENDER_WALL_MODE\nvec3 join_normal_inside=vec3(a_join_normal_inside);vec2 wall_offset=u_width_scale*line_width*(join_normal_inside.xy/EXTENT);p.xy+=(1.0-join_normal_inside.z)*wall_offset*0.5;p.xy-=join_normal_inside.z*wall_offset*0.5;\n#endif\nfloat hidden=float((centroid_pos.x==0.0 && centroid_pos.y==1.0) || (color.a==0.0));gl_Position=mix(u_matrix*vec4(p,1),AWAY,hidden);vec2 pos=normal.z==1.0\n? pos_nx.xy\n: vec2(edgedistance,z*u_height_factor);v_pos=get_pattern_pos(u_pixel_coord_upper,u_pixel_coord_lower,display_size,u_tile_units_to_pixels,pos);v_lighting=vec4(0.0,0.0,0.0,1.0);float NdotL=0.0;\n#ifdef LIGHTING_3D_MODE\nNdotL=calculate_NdotL(normal);\n#else\nNdotL=clamp(dot(normal,u_lightpos),0.0,1.0);NdotL=mix((1.0-u_lightintensity),max((0.5+u_lightintensity),1.0),NdotL);\n#endif\nif (normal.y !=0.0) {float r=0.84;\n#ifndef LIGHTING_3D_MODE\nr=mix(0.7,0.98,1.0-u_lightintensity);\n#endif\nNdotL*=(\n(1.0-u_vertical_gradient)+(u_vertical_gradient*clamp((t+base)*pow(height/150.0,0.5),r,1.0)));}\n#ifdef FAUX_AO\nfloat concave=pos_nx.w-floor(pos_nx.w*0.5)*2.0;float start=top_up_ny_start.w;float y_ground=1.0-clamp(t+base,0.0,1.0);float top_height=height;\n#ifdef TERRAIN\ntop_height=mix(max(c_ele+height,ele+base+2.0),ele+height,float(centroid_pos.x==0.0))-ele;y_ground+=y_ground*5.0/max(3.0,top_height);\n#endif\nv_ao=vec3(mix(concave,-concave,start),y_ground,h-ele);NdotL*=(1.0+0.05*(1.0-top_up_ny_start.y)*u_ao[0]);\n#ifdef PROJECTION_GLOBE_VIEW\ntop_height+=u_height_lift;\n#endif\ngl_Position.z-=(0.0000006*(min(top_height,500.)+2.0*min(base,500.0)+60.0*concave+3.0*start))*gl_Position.w;\n#endif\n#ifdef LIGHTING_3D_MODE\nv_normal=normal;\n#else\nv_lighting.rgb+=clamp(NdotL*u_lightcolor,mix(vec3(0.0),vec3(0.3),1.0-u_lightcolor),vec3(1.0));v_lighting*=u_opacity;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(p);\n#endif\n}'),groundShadow:ho('#include "_prelude_shadow.fragment.glsl"\nprecision highp float;uniform vec3 u_ground_shadow_factor;in vec4 v_pos_light_view_0;in vec4 v_pos_light_view_1;\n#ifdef FOG\nin float v_fog_opacity;\n#endif\nvoid main() {float light=shadowed_light_factor_plane_bias(v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);vec3 shadow=mix(u_ground_shadow_factor,vec3(1.0),light);\n#ifdef RENDER_CUTOFF\nshadow=mix(vec3(1.0),shadow,cutoff_opacity(u_cutoff_params,1.0/gl_FragCoord.w));\n#endif\n#ifdef FOG\nshadow=mix(shadow,vec3(1.0),v_fog_opacity);\n#endif\n#ifdef INDICATOR_CUTOUT\nshadow=mix(shadow,vec3(1.0),1.0-applyCutout(vec4(1.0),0.0).r);\n#endif\n#ifdef FEATURE_CUTOUT\nshadow=mix(shadow,vec3(1.0),get_cutout_factors(gl_FragCoord).y);\n#endif\nglFragColor=vec4(shadow,1.0);}','#include "_prelude_fog.vertex.glsl"\nuniform mat4 u_matrix;uniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;in ivec2 a_pos;out vec4 v_pos_light_view_0;out vec4 v_pos_light_view_1;\n#ifdef FOG\nout float v_fog_opacity;\n#endif\nvoid main() {gl_Position=u_matrix*vec4(a_pos,0.0,1.0);v_pos_light_view_0=u_light_matrix_0*vec4(a_pos,0.0,1.0);v_pos_light_view_1=u_light_matrix_1*vec4(a_pos,0.0,1.0);\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));v_fog_opacity=fog(v_fog_pos);\n#endif\n}'),fillExtrusionGroundEffect:ho("uniform highp float u_ao_pass;uniform highp float u_opacity;uniform highp float u_flood_light_intensity;uniform highp vec3 u_flood_light_color;uniform highp float u_attenuation;uniform sampler2D u_fb;uniform float u_fb_size;\n#ifdef SDF_SUBPASS\nin highp vec2 v_pos;in highp vec4 v_line_segment;in highp float v_flood_light_radius_tile;in highp vec2 v_ao;float line_df(highp vec2 a,highp vec2 b,highp vec2 p) {highp vec2 ba=b-a;highp vec2 pa=p-a;highp float r=clamp(dot(pa,ba)/dot(ba,ba),0.0,1.0);return length(pa-r*ba);}\n#ifdef FOG\nin highp float v_fog;\n#endif\n#endif\nvoid main() {\n#ifdef CLEAR_SUBPASS\nvec4 color=vec4(1.0);\n#ifdef CLEAR_FROM_TEXTURE\ncolor=texture(u_fb,gl_FragCoord.xy/vec2(u_fb_size));\n#endif\nglFragColor=color;\n#else\n#ifdef SDF_SUBPASS\nhighp float d=line_df(v_line_segment.xy,v_line_segment.zw,v_pos);highp float effect_radius=mix(v_flood_light_radius_tile,v_ao.y,u_ao_pass);d/=effect_radius;d=min(d,1.0);d=1.0-pow(1.0-d,u_attenuation);highp float effect_intensity=mix(u_flood_light_intensity,v_ao.x,u_ao_pass);highp float fog=1.0;\n#ifdef FOG\nfog=v_fog;\n#endif\n#ifdef RENDER_CUTOFF\nfog*=v_cutoff_opacity;\n#endif\nglFragColor=vec4(vec3(0.0),mix(1.0,d,effect_intensity*u_opacity*fog));\n#else\n#ifdef USE_MRT1\nout_Target1=vec4(1.0-texture(u_fb,gl_FragCoord.xy/vec2(u_fb_size)).a,0.0,0.0,0.0);\n#else\nvec4 color=mix(vec4(u_flood_light_color,1.0),vec4(vec3(0.0),1.0),u_ao_pass);\n#ifdef OVERDRAW_INSPECTOR\ncolor=vec4(1.0);\n#endif\nglFragColor=color;\n#endif\n#endif\nHANDLE_WIREFRAME_DEBUG;\n#endif\n}",'#include "_prelude_fog.vertex.glsl"\nin highp ivec4 a_pos_end;in highp int a_angular_offset_factor;in highp uint a_hidden_by_landmark;\n#ifdef SDF_SUBPASS\nout highp vec2 v_pos;out highp vec4 v_line_segment;out highp float v_flood_light_radius_tile;out highp vec2 v_ao;\n#ifdef FOG\nout highp float v_fog;\n#endif\n#endif\nuniform highp float u_flood_light_intensity;uniform highp mat4 u_matrix;uniform highp float u_ao_pass;uniform highp float u_meter_to_tile;uniform highp float u_edge_radius;uniform highp float u_dynamic_offset;uniform highp vec2 u_ao;\n#pragma mapbox: define highp float flood_light_ground_radius\nconst float TANGENT_CUTOFF=4.0;const float NORM=32767.0;void main() {\n#pragma mapbox: initialize highp float flood_light_ground_radius\nvec4 pos_end=vec4(a_pos_end);vec2 p=pos_end.xy;vec2 q=floor(pos_end.zw*0.5);vec2 start_bottom=pos_end.zw-q*2.0;float fl_ground_radius=abs(flood_light_ground_radius);float direction=flood_light_ground_radius < 0.0 ?-1.0 : 1.0;float flood_radius_tile=fl_ground_radius*u_meter_to_tile;vec2 v=normalize(q-p);float ao_radius=u_ao.y/3.5;float effect_radius=mix(flood_radius_tile,ao_radius,u_ao_pass)+u_edge_radius;float angular_offset_factor=float(a_angular_offset_factor)/NORM*TANGENT_CUTOFF;float angular_offset=direction*angular_offset_factor*effect_radius;float top=1.0-start_bottom.y;float side=(0.5-start_bottom.x)*2.0;vec2 extrusion_parallel=v*side*mix(u_dynamic_offset,angular_offset,top);vec2 perp=vec2(v.y,-v.x);vec2 extrusion_perp=direction*perp*effect_radius*top;vec3 pos=vec3(mix(q,p,start_bottom.x),0.0);pos.xy+=extrusion_parallel+extrusion_perp;\n#ifdef SDF_SUBPASS\nv_pos=pos.xy;v_line_segment=vec4(p,q)+perp.xyxy*u_edge_radius;v_flood_light_radius_tile=flood_radius_tile;v_ao=vec2(u_ao.x,ao_radius);\n#ifdef FOG\nv_fog_pos=fog_position(pos);v_fog=1.0-fog(v_fog_pos);\n#endif\n#endif\nfloat hidden_by_landmark=0.0;\n#ifdef HAS_CENTROID\nhidden_by_landmark=float(a_hidden_by_landmark);\n#endif\nfloat isFloodlit=float(fl_ground_radius > 0.0 && u_flood_light_intensity > 0.0);float hidden=mix(1.0-isFloodlit,isFloodlit,u_ao_pass);hidden+=hidden_by_landmark;gl_Position=mix(u_matrix*vec4(pos,1.0),AWAY,float(hidden > 0.0));\n#ifdef RENDER_CUTOFF\nv_cutoff_opacity=cutoff_opacity(u_cutoff_params,gl_Position.z);\n#endif\n}'),hillshadePrepare:ho("precision highp float;uniform highp sampler2D u_image;in vec2 v_pos;uniform vec2 u_dimension;uniform float u_zoom;float getElevation(vec2 coord) {return texture(u_image,coord).r/4.0;}void main() {vec2 epsilon=1.0/u_dimension;float a=getElevation(v_pos+vec2(-epsilon.x,-epsilon.y));float b=getElevation(v_pos+vec2(0,-epsilon.y));float c=getElevation(v_pos+vec2(epsilon.x,-epsilon.y));float d=getElevation(v_pos+vec2(-epsilon.x,0));float e=getElevation(v_pos+vec2(epsilon.x,0));float f=getElevation(v_pos+vec2(-epsilon.x,epsilon.y));float g=getElevation(v_pos+vec2(0,epsilon.y));float h=getElevation(v_pos+vec2(epsilon.x,epsilon.y));float exaggerationFactor=u_zoom < 2.0 ? 0.4 : u_zoom < 4.5 ? 0.35 : 0.3;float exaggeration=u_zoom < 15.0 ? (u_zoom-15.0)*exaggerationFactor : 0.0;vec2 deriv=vec2(\n(c+e+e+h)-(a+d+d+f),(f+g+g+h)-(a+b+b+c)\n)/pow(2.0,exaggeration+(19.2562-u_zoom));glFragColor=clamp(vec4(\nderiv.x/2.0+0.5,deriv.y/2.0+0.5,1.0,1.0),0.0,1.0);}","uniform mat4 u_matrix;uniform vec2 u_dimension;in ivec2 a_pos;in uvec2 a_texture_pos;out vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);highp vec2 epsilon=1.0/u_dimension;float scale=(u_dimension.x-2.0)/u_dimension.x;v_pos=(vec2(a_texture_pos)/8192.0)*scale+epsilon;}"),hillshade:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform sampler2D u_image;in vec2 v_pos;uniform vec2 u_latrange;uniform vec2 u_light;uniform vec4 u_shadow;uniform vec4 u_highlight;uniform vec4 u_accent;uniform float u_emissive_strength;void main() {vec4 pixel=texture(u_image,v_pos);vec2 deriv=((pixel.rg*2.0)-1.0);float scaleFactor=cos(radians((u_latrange[0]-u_latrange[1])*(1.0-v_pos.y)+u_latrange[1]));float slope=atan(1.25*length(deriv)/scaleFactor);float aspect=deriv.x !=0.0 ? atan(deriv.y,-deriv.x) : PI/2.0*(deriv.y > 0.0 ? 1.0 :-1.0);float intensity=u_light.x;float azimuth=u_light.y+PI;float base=1.875-intensity*1.75;float maxValue=0.5*PI;float scaledSlope=intensity !=0.5 ? ((pow(base,slope)-1.0)/(pow(base,maxValue)-1.0))*maxValue : slope;float accent=cos(scaledSlope);vec4 accent_color=(1.0-accent)*u_accent*clamp(intensity*2.0,0.0,1.0);float shade=abs(mod((aspect+azimuth)/PI+0.5,2.0)-1.0);vec4 shade_color=mix(u_shadow,u_highlight,shade)*sin(scaledSlope)*clamp(intensity*2.0,0.0,1.0);glFragColor=accent_color*(1.0-shade_color.a)+shade_color;\n#ifdef LIGHTING_3D_MODE\nglFragColor=apply_lighting_with_emission_ground(glFragColor,u_emissive_strength);\n#endif\n#ifdef FOG\nglFragColor=fog_dither(fog_apply_premultiplied(glFragColor,v_fog_pos));\n#endif\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\nuniform mat4 u_matrix;in ivec2 a_pos;in uvec2 a_texture_pos;out vec2 v_pos;void main() {gl_Position=u_matrix*vec4(a_pos,0,1);v_pos=vec2(a_texture_pos)/8192.0;\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n}'),line:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nuniform lowp float u_device_pixel_ratio;uniform highp float u_width_scale;uniform highp float u_floor_width_scale;uniform float u_alpha_discard_threshold;uniform highp vec2 u_trim_offset;uniform highp vec2 u_trim_fade_range;uniform highp vec2 u_trim_gradient_mix_range;uniform lowp vec4 u_trim_color;uniform bool u_emissive_in_shadows;uniform bool u_clip_to_tile_borders;in vec4 v_width2_dilute;in vec2 v_normal;in float v_gamma_scale;in highp vec3 v_uv;in vec2 v_tile_pos;\n#ifdef ELEVATED_ROADS\nin highp float v_road_z_offset;\n#endif\n#ifdef VARIABLE_LINE_WIDTH\nin float stub_side;\n#endif\n#ifdef RENDER_LINE_DASH\nuniform sampler2D u_dash_image;in vec2 v_tex;\n#endif\n#ifdef DEBUG_ELEVATION_ID\nin vec3 v_elevation_id_col;\n#endif\n#ifdef RENDER_LINE_GRADIENT\nuniform sampler2D u_gradient_image;\n#endif\n#ifdef INDICATOR_CUTOUT\nin highp float v_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\nfloat luminance(vec3 c) {return (c.r+c.r+c.b+c.g+c.g+c.g)*0.1667;}\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define mediump uvec4 dash\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float side_z_offset\n#pragma mapbox: define lowp float border_width\n#pragma mapbox: define lowp vec4 border_color\n#pragma mapbox: define lowp float emissive_strength\nfloat linearstep(float edge0,float edge1,float x) {return clamp((x-edge0)/(edge1-edge0),0.0,1.0);}void main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float floorwidth\n#pragma mapbox: initialize mediump uvec4 dash\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float side_z_offset\n#pragma mapbox: initialize lowp float border_width\n#pragma mapbox: initialize lowp vec4 border_color\n#pragma mapbox: initialize lowp float emissive_strength\nfloat dist=length(v_normal)*v_width2_dilute.x;\n#ifdef VARIABLE_LINE_WIDTH\nblur=mix(blur,0.0,stub_side);\n#endif\nfloat diluted_opacity=opacity*v_width2_dilute.z;float blur2=(u_width_scale*blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2_dilute.y-blur2),v_width2_dilute.x-dist)/blur2,0.0,1.0);\n#ifdef VARIABLE_LINE_WIDTH\nalpha=mix(alpha,1.0,stub_side);\n#endif\nalpha=side_z_offset > 0.0 ? 1.0-alpha : alpha;\n#ifdef RENDER_LINE_DASH\nfloat sdfdist=texture(u_dash_image,v_tex).r;float sdfgamma=1.0/(2.0*u_device_pixel_ratio)/(float(dash.z)+float(dash.w)/65535.0);float scaled_floorwidth=(floorwidth*u_floor_width_scale);alpha*=linearstep(0.5-sdfgamma/scaled_floorwidth,0.5+sdfgamma/scaled_floorwidth,sdfdist);\n#endif\nhighp vec4 out_color;\n#ifdef RENDER_LINE_GRADIENT\nout_color=texture(u_gradient_image,v_uv.xy);\n#else\nout_color=color;\n#endif\nfloat trim_alpha=1.0;\n#ifdef RENDER_LINE_TRIM_OFFSET\nhighp float trim_start=u_trim_offset[0];highp float trim_end=u_trim_offset[1];highp float line_progress=v_uv[2];if (trim_end > trim_start) {highp float start_transition=max(0.0,min(1.0,(line_progress-trim_start)/max(u_trim_fade_range[0],1.0e-9)));highp float end_transition=max(0.0,min(1.0,(trim_end-line_progress)/max(u_trim_fade_range[1],1.0e-9)));highp float transition_factor=min(start_transition,end_transition);highp float gradient_trim_color_mix_factor=0.0;\n#ifdef RENDER_LINE_GRADIENT\ngradient_trim_color_mix_factor=smoothstep(u_trim_gradient_mix_range.x,u_trim_gradient_mix_range.y,line_progress);\n#endif\nhighp vec4 trim_color=mix(u_trim_color,out_color,gradient_trim_color_mix_factor);out_color=mix(u_trim_gradient_mix_range.x < 1.0 ? color : out_color,trim_color,transition_factor);trim_alpha=1.0-transition_factor;}\n#endif\nif (u_alpha_discard_threshold !=0.0) {if (alpha < u_alpha_discard_threshold) {discard;}}\n#ifdef RENDER_LINE_BORDER\n#ifndef VARIABLE_LINE_WIDTH\nfloat edgeBlur=((border_width*u_width_scale)+1.0/u_device_pixel_ratio);float alpha2=clamp(min(dist-(v_width2_dilute.y-edgeBlur),v_width2_dilute.x-dist)/edgeBlur,0.0,1.0);if (alpha2 < 1.) {float smoothAlpha=smoothstep(0.6,1.0,alpha2);if (border_color.a==0.0) {float Y=(out_color.a > 0.01) ? luminance(out_color.rgb/out_color.a) : 1.;float adjustment=(Y > 0.) ? 0.5/Y : 0.45;if (out_color.a > 0.25 && Y < 0.25) {vec3 borderColor=(Y > 0.) ? out_color.rgb : vec3(1,1,1)*out_color.a;out_color.rgb=out_color.rgb+borderColor*(adjustment*(1.0-smoothAlpha));} else {out_color.rgb*=(0.6 +0.4*smoothAlpha);}} else {out_color=mix(border_color*trim_alpha,out_color,smoothAlpha);}out_color*=v_width2_dilute.w;}\n#endif\n#endif\nvec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);light=u_emissive_in_shadows ? mix(light,1.0,emissive_strength) : light;\n#ifdef ELEVATED_ROADS\nout_color.rgb*=mix(v_road_z_offset !=0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light);\n#else\nout_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#endif\n#ifdef FOG\nout_color=fog_dither(fog_apply_premultiplied(out_color,v_fog_pos));\n#endif\nout_color*=(alpha*diluted_opacity);\n#ifdef INDICATOR_CUTOUT\nout_color=applyCutout(out_color,v_z_offset);\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\n#ifdef LINE_BLEND_ADDITIVE\n{float cov=alpha*diluted_opacity;glFragColor=vec4(cov > 0.0 ? out_color.rgb/cov : vec3(0.0),cov);}\n#else\n#ifdef LINE_BLEND_MULTIPLY\nglFragColor=vec4(out_color.rgb+(1.0-out_color.a),1.0);\n#else\nglFragColor=out_color;\n#endif\n#endif\n#ifdef DUAL_SOURCE_BLENDING\nglFragColorSrc1=vec4(vec3(0.0),emissive_strength);\n#else\n#ifdef USE_MRT1\nout_Target1=vec4(emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\n#ifdef DEBUG_ELEVATION_ID\nglFragColor=vec4(v_elevation_id_col,1.0);\n#endif\nif (u_clip_to_tile_borders) {if (v_tile_pos.x > 1.0 || v_tile_pos.y > 1.0 || v_tile_pos.x < 0.0 || v_tile_pos.y < 0.0) {discard;}}HANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\n#define EXTRUDE_SCALE 0.015873016\nin ivec2 a_pos_normal;in uvec4 a_data;\n#if defined(ELEVATED) || defined(ELEVATED_ROADS) || defined(VARIABLE_LINE_WIDTH)\nin vec3 a_z_offset_width;\n#endif\n#ifdef DEBUG_ELEVATION_ID\nin vec3 a_elevation_id_col;\n#endif\n#ifdef DEBUG_ELEVATION_ID\nout vec3 v_elevation_id_col;\n#endif\n#ifdef ELEVATION_GROUND_SCALE\nin float a_elevation_ground_scale;\n#endif\n#if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET) || defined(RENDER_LINE_CURVE)\nin highp vec3 a_packed;\n#endif\n#ifdef RENDER_LINE_DASH\nin float a_linesofar;\n#endif\nuniform mat4 u_matrix;uniform mat2 u_pixels_to_tile_units;uniform vec2 u_units_to_pixels;uniform lowp float u_device_pixel_ratio;uniform float u_width_scale;uniform float u_z_offset;uniform highp float u_floor_width_scale;\n#ifdef RENDER_LINE_CURVE\nuniform mat3 u_curve_points_x;uniform mat3 u_curve_points_y;uniform mat3 u_curve_points_z;uniform float u_curve_point_count;\n#endif\n#ifdef ELEVATED\nuniform lowp float u_zbias_factor;uniform lowp float u_tile_to_meter;float sample_elevation(vec2 apos) {\n#ifdef ELEVATION_REFERENCE_SEA\nreturn 0.0;\n#else\nreturn elevation(apos);\n#endif\n}\n#endif\nout vec2 v_normal;out vec4 v_width2_dilute;out float v_gamma_scale;out highp vec3 v_uv;out vec2 v_tile_pos;\n#ifdef ELEVATED_ROADS\nout highp float v_road_z_offset;\n#endif\n#ifdef VARIABLE_LINE_WIDTH\nout float stub_side;\n#endif\n#ifdef RENDER_LINE_DASH\nuniform vec2 u_texsize;uniform float u_tile_units_to_pixels;out vec2 v_tex;\n#endif\n#ifdef RENDER_LINE_GRADIENT\nuniform float u_image_height;\n#endif\n#ifdef INDICATOR_CUTOUT\nout highp float v_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\n#pragma mapbox: define highp vec4 color\n#pragma mapbox: define lowp float floorwidth\n#pragma mapbox: define mediump uvec4 dash\n#pragma mapbox: define lowp float blur\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define lowp float offset\n#pragma mapbox: define mediump float width\n#pragma mapbox: define mediump float side_z_offset\n#pragma mapbox: define lowp float border_width\n#pragma mapbox: define lowp vec4 border_color\n#pragma mapbox: define lowp float emissive_strength\n#ifdef RENDER_LINE_CURVE\nvec3 getCurvePoint(int index) {int row=index/3;int col=index-row*3;float x=u_curve_points_x[row][col];float y=u_curve_points_y[row][col];float z=u_curve_points_z[row][col];return vec3(x,y,z);}vec3 catmullRom(vec3 p0,vec3 p1,vec3 p2,vec3 p3,float t) {float t2=t*t;float t3=t2*t;return 0.5*(\n2.0*p1+(-p0+p2)*t+(2.0*p0-5.0*p1+4.0*p2-p3)*t2+(-p0+3.0*p1-3.0*p2+p3)*t3\n);}vec2 catmullRomTangent(vec2 p0,vec2 p1,vec2 p2,vec2 p3,float t) {float t2=t*t;return 0.5*(\n(-p0+p2)+(2.0*p0-5.0*p1+4.0*p2-p3)*2.0*t+(-p0+3.0*p1-3.0*p2+p3)*3.0*t2\n);}struct CurveResult {vec3 point;vec2 tangent;};CurveResult calculateCurve(float line_progress) {float curve_progress=line_progress*(u_curve_point_count-1.0);float curve_progress_local=fract(curve_progress);float curve_segment=floor(curve_progress);int seg=int(curve_segment);vec3 p1=getCurvePoint(seg);vec3 p2=getCurvePoint(seg+1);float is_first_seg=step(curve_segment,0.5);vec3 p0_extrapolated=p1-(p2-p1);vec3 p0_fetched=getCurvePoint(max(seg-1,0));vec3 p0=mix(p0_fetched,p0_extrapolated,is_first_seg);int last_seg=int(u_curve_point_count)-2;float is_last_seg=step(float(last_seg)-0.5,curve_segment);vec3 p3_extrapolated=p2+(p2-p1);vec3 p3_fetched=getCurvePoint(min(seg+2,int(u_curve_point_count)-1));vec3 p3=mix(p3_fetched,p3_extrapolated,is_last_seg);vec3 point=catmullRom(p0,p1,p2,p3,curve_progress_local);vec2 tangent=catmullRomTangent(p0.xy,p1.xy,p2.xy,p3.xy,curve_progress_local)*(u_curve_point_count-1.0);CurveResult result;result.point=point;result.tangent=tangent;return result;}\n#endif\nvoid main() {\n#pragma mapbox: initialize highp vec4 color\n#pragma mapbox: initialize lowp float floorwidth\n#pragma mapbox: initialize mediump uvec4 dash\n#pragma mapbox: initialize lowp float blur\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize lowp float offset\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize mediump float side_z_offset\n#pragma mapbox: initialize lowp float border_width\n#pragma mapbox: initialize lowp vec4 border_color\n#pragma mapbox: initialize lowp float emissive_strength\nfloat a_z_offset=u_z_offset;\n#if defined(ELEVATED) || defined(ELEVATED_ROADS)\na_z_offset+=a_z_offset_width.x;\n#endif\n#ifdef DEBUG_ELEVATION_ID\nv_elevation_id_col=a_elevation_id_col;\n#endif\nhighp float line_progress=0.0;\n#if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET) || defined(RENDER_LINE_CURVE)\nline_progress=a_packed[2];\n#endif\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=vec2(a_data.xy)-128.0;float a_direction=float(a_data.z & 3u)-1.0;vec2 pos_normal=vec2(a_pos_normal);vec2 pos=floor(pos_normal*0.5);mediump vec2 normal=pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;offset=-1.0*offset*u_width_scale;bool left=normal.y==1.0;\n#ifdef RENDER_LINE_CURVE\nCurveResult curve=calculateCurve(line_progress);pos=curve.point.xy*8192.0;a_extrude=length(a_extrude)*normalize(curve.tangent);a_extrude=left ? vec2(-a_extrude.y,a_extrude.x) : vec2(a_extrude.y,-a_extrude.x);a_z_offset+=curve.point.z;\n#endif\ngapwidth=gapwidth/2.0;float halfwidth;float dilute_scale=1.0;float dilute_border_scale=1.0;\n#ifdef VARIABLE_LINE_WIDTH\nfloat left_width=a_z_offset_width.y;float right_width=a_z_offset_width.z;halfwidth=(u_width_scale*(left ? left_width : right_width))/2.0;if (side_z_offset !=0.0) {float left_f=step(1.0,normal.y);float is_negative=step(side_z_offset,0.0);float apply=mix(1.0-left_f,left_f,is_negative);a_extrude*=apply;a_z_offset+=abs(side_z_offset)*apply;v_normal*=left_f;}offset=border_width > 0.0 ? (left_width+right_width)*u_width_scale*0.5 : offset;halfwidth=border_width > 0.0 ? border_width*u_width_scale*0.5 : halfwidth;bool zero_right_width=border_width==0.0 && right_width==0.0;stub_side=zero_right_width ?-normal.y : 0.0;v_normal=!left && zero_right_width ? vec2(0.0) : v_normal;ANTIALIASING=!left && zero_right_width ? 0.0 : ANTIALIASING;\n#else\nhalfwidth=(u_width_scale*width)/2.0;\n#endif\nfloat inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);mediump vec2 dist=outset*a_extrude*EXTRUDE_SCALE;mediump float u=0.5*a_direction;mediump float t=1.0-abs(u);mediump vec2 offset2=offset*a_extrude*EXTRUDE_SCALE*normal.y*mat2(t,-u,u,t);float hidden=float(opacity==0.0);vec2 extrude=dist*u_pixels_to_tile_units;vec4 projected_extrude=u_matrix*vec4(extrude,0.0,0.0);vec2 projected_extrude_xy=projected_extrude.xy;\n#ifdef ELEVATED_ROADS\nv_road_z_offset=a_z_offset;v_tile_pos=pos+offset2*u_pixels_to_tile_units;gl_Position=u_matrix*vec4(v_tile_pos,a_z_offset,1.0);\n#else\n#ifdef ELEVATED\nvec2 offsetTile=offset2*u_pixels_to_tile_units;vec2 offset_pos=pos+offsetTile;float ele=0.0;float scaled_z_offset=a_z_offset;\n#ifdef ELEVATION_GROUND_SCALE\nscaled_z_offset=a_z_offset*mix(1.0,u_exaggeration,a_elevation_ground_scale);\n#endif\n#ifdef CROSS_SLOPE_VERTICAL\nfloat top=pos_normal.y-2.0*floor(pos_normal.y*0.5);float line_height=2.0*u_tile_to_meter*outset*top*u_pixels_to_tile_units[1][1]+scaled_z_offset;ele=sample_elevation(offset_pos)+line_height;projected_extrude=vec4(0);\n#else\n#ifdef CROSS_SLOPE_HORIZONTAL\nfloat ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,max(ele1,ele2));ele=ele_max+scaled_z_offset;\n#else\nfloat ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,0.5*(ele1+ele2));ele=ele_max-ele0+ele1+scaled_z_offset;\n#endif\n#endif\nv_tile_pos=offset_pos;gl_Position=u_matrix*vec4(v_tile_pos,ele,1.0)+projected_extrude;float z=clamp(gl_Position.z/gl_Position.w,0.5,1.0);float zbias=max(0.00005,(pow(z,0.8)-z)*u_zbias_factor*u_exaggeration);gl_Position.z-=(gl_Position.w*zbias);gl_Position=mix(gl_Position,AWAY,hidden);\n#else\nv_tile_pos=pos+offset2*u_pixels_to_tile_units;gl_Position=u_matrix*vec4(v_tile_pos,0.0,1.0);\n#endif\n#endif\n#ifndef ELEVATED\n#ifndef VARIABLE_LINE_WIDTH\n#ifndef RENDER_TO_TEXTURE\nfloat base_w=gl_Position.w;vec2 screen_width=abs(projected_extrude.xy/base_w*u_units_to_pixels);float max_extrude_component=max(screen_width.x,screen_width.y);if (width >=1.0 && base_w > 0.0 && max_extrude_component > 0.0001) {float min_pixel=1.05;if (max_extrude_component < min_pixel) {vec2 abs_pos=abs(gl_Position.xy);float is_out=max(abs_pos.x,abs_pos.y)/base_w;dilute_scale=mix(max_extrude_component/min_pixel,1.0,smoothstep(2.5,4.5,is_out));projected_extrude/=dilute_scale;}else if (gapwidth > 0.0) {float visible_ratio=(halfwidth+ANTIALIASING)/outset;vec2 visible_screen_width=screen_width*visible_ratio;float max_visible_component=max(visible_screen_width.x,visible_screen_width.y);dilute_scale=min(1.0,max_visible_component/min_pixel);}else\n{\n#ifdef RENDER_LINE_BORDER\nfloat border_ratio=(border_width*u_width_scale+ANTIALIASING)/outset;screen_width*=border_ratio;float max_border_component=max(screen_width.x,screen_width.y);dilute_border_scale=min(1.0,max_border_component/min_pixel);\n#endif\n}}\n#endif\n#endif\nv_tile_pos=(v_tile_pos+extrude)/EXTENT;\n#ifdef ELEVATED_ROADS\ngl_Position=gl_Position+projected_extrude;\n#else\ngl_Position=mix(gl_Position+projected_extrude,AWAY,hidden);\n#endif\n#endif\n#ifdef ELEVATED_ROADS\n#ifdef RENDER_SHADOWS\nvec3 shd_pos=vec3(pos+(offset2+dist)*u_pixels_to_tile_units,a_z_offset);vec3 shd_pos0=shd_pos;vec3 shd_pos1=shd_pos;\n#ifdef NORMAL_OFFSET\nvec3 shd_pos_offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=shd_pos_offset*shadow_normal_offset_multiplier0();shd_pos1+=shd_pos_offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#endif\n#ifndef RENDER_TO_TEXTURE\nfloat epsilon=0.0001;float extrude_length_without_perspective=max(length(dist),epsilon);float extrude_length_with_perspective=max(length(projected_extrude_xy/gl_Position.w*u_units_to_pixels),epsilon);v_gamma_scale=mix(extrude_length_without_perspective/extrude_length_with_perspective,1.0,step(0.01,blur));\n#else\nv_gamma_scale=1.0;\n#endif\n#if defined(RENDER_LINE_GRADIENT) || defined(RENDER_LINE_TRIM_OFFSET)\nhighp float a_uv_x=a_packed[0];float a_split_index=a_packed[1];\n#ifdef RENDER_LINE_GRADIENT\nhighp float texel_height=1.0/u_image_height;highp float half_texel_height=0.5*texel_height;v_uv=vec3(a_uv_x,a_split_index*texel_height-half_texel_height,line_progress);\n#else\nv_uv=vec3(a_uv_x,0.0,line_progress);\n#endif\n#endif\n#ifdef RENDER_LINE_DASH\nvec4 dashf=vec4(dash);float totalLength=dashf.z+dashf.w/65535.0;float scale=totalLength==0.0 ? 0.0 : u_tile_units_to_pixels/totalLength;v_tex=vec2(a_linesofar*scale/(floorwidth*u_floor_width_scale),(-normal.y*dashf.y+dashf.x+0.5)/u_texsize.y);\n#endif\nv_width2_dilute=vec4(outset,inset,dilute_scale,dilute_border_scale);\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n#ifdef INDICATOR_CUTOUT\nv_z_offset=a_z_offset;\n#endif\n}'),linePattern:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\nuniform highp float u_device_pixel_ratio;uniform highp float u_width_scale;uniform highp float u_alpha_discard_threshold;uniform highp vec2 u_texsize;uniform highp float u_tile_units_to_pixels;uniform highp vec2 u_trim_offset;uniform highp vec2 u_trim_fade_range;uniform lowp vec4 u_trim_color;uniform sampler2D u_image;\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\n#ifdef LINE_PATTERN_TRANSITION\nuniform float u_pattern_transition;\n#endif\nin vec2 v_normal;in vec2 v_width2;in highp float v_linesofar;in float v_gamma_scale;in float v_width;\n#ifdef RENDER_LINE_TRIM_OFFSET\nin highp vec3 v_uv;\n#endif\n#ifdef ELEVATED_ROADS\nin highp float v_road_z_offset;\n#endif\n#ifdef LINE_JOIN_NONE\nin vec2 v_pattern_data;\n#endif\n#ifdef INDICATOR_CUTOUT\nin highp float v_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\n#pragma mapbox: define mediump uvec4 pattern\n#ifdef LINE_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define mediump float pixel_ratio\n#pragma mapbox: define mediump float blur\n#pragma mapbox: define mediump float opacity\n#pragma mapbox: define lowp float emissive_strength\nvoid main() {\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef LINE_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\n#pragma mapbox: initialize mediump float pixel_ratio\n#pragma mapbox: initialize mediump float blur\n#pragma mapbox: initialize mediump float opacity\n#pragma mapbox: initialize lowp float emissive_strength\nvec2 pattern_tl=vec2(pattern.xy);vec2 pattern_br=vec2(pattern.zw);vec2 display_size=(pattern_br-pattern_tl)/pixel_ratio;highp float pattern_size=display_size.x/u_tile_units_to_pixels;float aspect=display_size.y/v_width;float dist=length(v_normal)*v_width2.s;float blur2=(u_width_scale*blur+1.0/u_device_pixel_ratio)*v_gamma_scale;float alpha=clamp(min(dist-(v_width2.t-blur2),v_width2.s-dist)/blur2,0.0,1.0);highp float pattern_x=v_linesofar/pattern_size*aspect;highp float x=mod(pattern_x,1.0);highp float y=0.5*v_normal.y+0.5;vec2 texel_size=1.0/u_texsize;highp vec2 pos=mix(pattern_tl*texel_size-texel_size,pattern_br*texel_size+texel_size,vec2(x,y));highp vec2 lod_pos=mix(pattern_tl*texel_size-texel_size,pattern_br*texel_size+texel_size,vec2(pattern_x,y));vec4 color=textureLodCustom(u_image,pos,lod_pos);\n#ifdef APPLY_LUT_ON_GPU\ncolor=applyLUT(u_lutTexture,color);\n#endif\n#ifdef LINE_PATTERN_TRANSITION\nvec2 pattern_b_tl=vec2(pattern_b.xy);vec2 pattern_b_br=vec2(pattern_b.zw);highp vec2 pos_b=mix(pattern_b_tl*texel_size-texel_size,pattern_b_br*texel_size+texel_size,vec2(x,y));vec4 color_b=textureLodCustom(u_image,pos_b,lod_pos);color=color*(1.0-u_pattern_transition)+color_b*u_pattern_transition;\n#endif\n#ifdef RENDER_LINE_TRIM_OFFSET\nhighp float trim_start=u_trim_offset[0];highp float trim_end=u_trim_offset[1];highp float line_progress=v_uv[2];if (trim_end > trim_start) {highp float start_transition=max(0.0,min(1.0,(line_progress-trim_start)/max(u_trim_fade_range[0],1.0e-9)));highp float end_transition=max(0.0,min(1.0,(trim_end-line_progress)/max(u_trim_fade_range[1],1.0e-9)));highp float transition_factor=min(start_transition,end_transition);color=mix(color,color.a*u_trim_color,transition_factor);}\n#endif\n#ifdef LINE_JOIN_NONE\nhighp float pattern_len=pattern_size/aspect;highp float segment_phase=pattern_len-mod(v_linesofar-v_pattern_data.x+pattern_len,pattern_len);highp float visible_start=segment_phase-step(pattern_len*0.5,segment_phase)*pattern_len;highp float visible_end=floor((v_pattern_data.y-segment_phase)/pattern_len)*pattern_len+segment_phase;visible_end+=step(pattern_len*0.5,v_pattern_data.y-visible_end)*pattern_len;if (v_pattern_data.x < visible_start || v_pattern_data.x >=visible_end) {color=vec4(0.0);}\n#endif\n#ifdef LIGHTING_3D_MODE\ncolor=apply_lighting_with_emission_ground(color,emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);\n#ifdef ELEVATED_ROADS\ncolor.rgb*=mix(v_road_z_offset !=0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light);\n#else\ncolor.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#endif\n#endif\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#endif\ncolor*=(alpha*opacity);if (u_alpha_discard_threshold !=0.0) {if (color.a < u_alpha_discard_threshold) {discard;}}\n#ifdef INDICATOR_CUTOUT\ncolor=applyCutout(color,v_z_offset);\n#endif\nglFragColor=color;\n#ifdef DUAL_SOURCE_BLENDING\nglFragColorSrc1=vec4(vec3(0.0),emissive_strength);\n#else\n#ifdef USE_MRT1\nout_Target1=vec4(emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\n#define scale 0.015873016\nin ivec2 a_pos_normal;in uvec4 a_data;\n#if defined(ELEVATED) || defined(ELEVATED_ROADS)\nin vec3 a_z_offset_width;\n#endif\n#ifdef ELEVATION_GROUND_SCALE\nin float a_elevation_ground_scale;\n#endif\n#ifdef RENDER_LINE_TRIM_OFFSET\nin highp vec3 a_packed;\n#endif\nin highp float a_linesofar;\n#ifdef LINE_JOIN_NONE\nin highp vec3 a_pattern_data;out vec2 v_pattern_data;\n#endif\n#ifdef INDICATOR_CUTOUT\nout highp float v_z_offset;\n#endif\nuniform mat4 u_matrix;uniform float u_tile_units_to_pixels;uniform vec2 u_units_to_pixels;uniform mat2 u_pixels_to_tile_units;uniform float u_device_pixel_ratio;uniform float u_width_scale;uniform float u_floor_width_scale;\n#ifdef ELEVATED\nuniform lowp float u_zbias_factor;uniform lowp float u_tile_to_meter;float sample_elevation(vec2 apos) {\n#ifdef ELEVATION_REFERENCE_SEA\nreturn 0.0;\n#else\nreturn elevation(apos);\n#endif\n}\n#endif\nout vec2 v_normal;out vec2 v_width2;out highp float v_linesofar;out float v_gamma_scale;out float v_width;\n#ifdef RENDER_LINE_TRIM_OFFSET\nout highp vec3 v_uv;\n#endif\n#ifdef ELEVATED_ROADS\nout highp float v_road_z_offset;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\n#pragma mapbox: define mediump float blur\n#pragma mapbox: define mediump float opacity\n#pragma mapbox: define mediump float offset\n#pragma mapbox: define mediump float gapwidth\n#pragma mapbox: define mediump float width\n#pragma mapbox: define mediump float floorwidth\n#pragma mapbox: define mediump uvec4 pattern\n#ifdef LINE_PATTERN_TRANSITION\n#pragma mapbox: define mediump uvec4 pattern_b\n#endif\n#pragma mapbox: define mediump float pixel_ratio\n#pragma mapbox: define lowp float emissive_strength\nvoid main() {\n#pragma mapbox: initialize mediump float blur\n#pragma mapbox: initialize mediump float opacity\n#pragma mapbox: initialize mediump float offset\n#pragma mapbox: initialize mediump float gapwidth\n#pragma mapbox: initialize mediump float width\n#pragma mapbox: initialize mediump float floorwidth\n#pragma mapbox: initialize mediump uvec4 pattern\n#ifdef LINE_PATTERN_TRANSITION\n#pragma mapbox: initialize mediump uvec4 pattern_b\n#endif\n#pragma mapbox: initialize mediump float pixel_ratio\n#pragma mapbox: initialize lowp float emissive_strength\nfloat a_z_offset;\n#if defined(ELEVATED) || defined(ELEVATED_ROADS)\na_z_offset=a_z_offset_width.x;\n#endif\nfloat ANTIALIASING=1.0/u_device_pixel_ratio/2.0;vec2 a_extrude=vec2(a_data.xy)-128.0;float a_direction=float(a_data.z & 3u)-1.0;vec2 pos_normal=vec2(a_pos_normal);vec2 pos=floor(pos_normal*0.5);vec2 normal=pos_normal-2.0*pos;normal.y=normal.y*2.0-1.0;v_normal=normal;gapwidth=gapwidth/2.0;float halfwidth=(u_width_scale*width)/2.0;offset=-1.0*offset*u_width_scale;float inset=gapwidth+(gapwidth > 0.0 ? ANTIALIASING : 0.0);float outset=gapwidth+halfwidth*(gapwidth > 0.0 ? 2.0 : 1.0)+(halfwidth==0.0 ? 0.0 : ANTIALIASING);vec2 dist=outset*a_extrude*scale;float u=0.5*a_direction;float t=1.0-abs(u);vec2 offset2=offset*a_extrude*scale*normal.y*mat2(t,-u,u,t);float hidden=float(opacity==0.0);vec2 extrude=dist*u_pixels_to_tile_units;vec4 projected_extrude=u_matrix*vec4(extrude,0.0,0.0);vec2 projected_extrude_xy=projected_extrude.xy;\n#ifdef ELEVATED_ROADS\nv_road_z_offset=a_z_offset;gl_Position=u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,a_z_offset,1.0)+projected_extrude;\n#else\n#ifdef ELEVATED\nvec2 offsetTile=offset2*u_pixels_to_tile_units;vec2 offset_pos=pos+offsetTile;float ele=0.0;float scaled_z_offset=a_z_offset;\n#ifdef ELEVATION_GROUND_SCALE\nscaled_z_offset=a_z_offset*mix(1.0,u_exaggeration,a_elevation_ground_scale);\n#endif\n#ifdef CROSS_SLOPE_VERTICAL\nfloat top=pos_normal.y-2.0*floor(pos_normal.y*0.5);float line_height=2.0*u_tile_to_meter*outset*top*u_pixels_to_tile_units[1][1]+scaled_z_offset;ele=sample_elevation(offset_pos)+line_height;projected_extrude=vec4(0);\n#else\n#ifdef CROSS_SLOPE_HORIZONTAL\nfloat ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,max(ele1,ele2));ele=ele_max+scaled_z_offset;\n#else\nfloat ele0=sample_elevation(offset_pos);float ele1=max(sample_elevation(offset_pos+extrude),sample_elevation(offset_pos+extrude/2.0));float ele2=max(sample_elevation(offset_pos-extrude),sample_elevation(offset_pos-extrude/2.0));float ele_max=max(ele0,0.5*(ele1+ele2));ele=ele_max-ele0+ele1+scaled_z_offset;\n#endif\n#endif\ngl_Position=u_matrix*vec4(offset_pos,ele,1.0)+projected_extrude;float z=clamp(gl_Position.z/gl_Position.w,0.5,1.0);float zbias=max(0.00005,(pow(z,0.8)-z)*u_zbias_factor*u_exaggeration);gl_Position.z-=(gl_Position.w*zbias);gl_Position=mix(gl_Position,AWAY,hidden);\n#else\ngl_Position=mix(u_matrix*vec4(pos+offset2*u_pixels_to_tile_units,0.0,1.0)+projected_extrude,AWAY,hidden);\n#endif\n#endif\n#ifdef ELEVATED_ROADS\n#ifdef RENDER_SHADOWS\nvec3 shd_pos=vec3(pos+(offset2+dist)*u_pixels_to_tile_units,a_z_offset);vec3 shd_pos0=shd_pos;vec3 shd_pos1=shd_pos;\n#ifdef NORMAL_OFFSET\nvec3 shd_pos_offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=shd_pos_offset*shadow_normal_offset_multiplier0();shd_pos1+=shd_pos_offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#endif\n#ifndef RENDER_TO_TEXTURE\nfloat extrude_length_without_perspective=length(dist);float extrude_length_with_perspective=length(projected_extrude_xy/gl_Position.w*u_units_to_pixels);v_gamma_scale=mix(extrude_length_without_perspective/extrude_length_with_perspective,1.0,step(0.01,blur));\n#else\nv_gamma_scale=1.0;\n#endif\n#ifdef RENDER_LINE_TRIM_OFFSET\nhighp float a_uv_x=a_packed[0];highp float line_progress=a_packed[2];v_uv=vec3(a_uv_x,0.0,line_progress);\n#endif\nv_linesofar=a_linesofar;v_width2=vec2(outset,inset);v_width=(floorwidth*u_floor_width_scale);\n#ifdef LINE_JOIN_NONE\nv_width=(floorwidth*u_floor_width_scale)+ANTIALIASING;mediump float pixels_to_tile_units=1.0/u_tile_units_to_pixels;mediump float pixel_ratio_inverse=1.0/pixel_ratio;mediump float aspect=v_width/(float(pattern.w-pattern.y)*pixel_ratio_inverse);highp float subt_multiple=float(pattern.z-pattern.x)*pixel_ratio_inverse*pixels_to_tile_units*aspect*32.0;highp float subt=floor(a_pattern_data.z/subt_multiple)*subt_multiple;float offset_sign=(fract(a_pattern_data.x)-0.5)*4.0;float line_progress_offset=offset_sign*v_width*0.5*pixels_to_tile_units;v_linesofar=(a_pattern_data.z-subt)+a_linesofar+line_progress_offset;v_pattern_data=vec2(a_pattern_data.x+line_progress_offset,a_pattern_data.y);\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(pos);\n#endif\n#ifdef INDICATOR_CUTOUT\nv_z_offset=a_z_offset;\n#endif\n}'),raster:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\n#include "_prelude_raster_array.glsl"\nuniform float u_fade_t;uniform float u_opacity;uniform highp float u_raster_elevation;uniform highp float u_zoom_transition;in vec2 v_pos0;in vec2 v_pos1;in float v_depth;\n#ifdef PROJECTION_GLOBE_VIEW\nin float v_split_fade;\n#endif\nuniform float u_brightness_low;uniform float u_brightness_high;uniform float u_saturation_factor;uniform float u_contrast_factor;uniform vec3 u_spin_weights;uniform float u_emissive_strength;\n#ifndef RASTER_ARRAY\nuniform highp sampler2D u_image0;uniform sampler2D u_image1;\n#endif\n#ifdef RASTER_COLOR\nuniform sampler2D u_color_ramp;uniform highp vec4 u_colorization_mix;uniform highp float u_colorization_offset;uniform vec2 u_texture_res;\n#endif\nvoid main() {vec4 color0,color1,color;vec2 value;\n#ifdef RASTER_COLOR\n#ifdef RASTER_ARRAY\n#ifdef RASTER_ARRAY_LINEAR\nvalue=mix(\nraTexture2D_image0_linear(v_pos0,u_texture_res,u_colorization_mix,u_colorization_offset),raTexture2D_image1_linear(v_pos1,u_texture_res,u_colorization_mix,u_colorization_offset),u_fade_t\n);\n#else\nvalue=mix(\nraTexture2D_image0_nearest(v_pos0,u_texture_res,u_colorization_mix,u_colorization_offset),raTexture2D_image1_nearest(v_pos1,u_texture_res,u_colorization_mix,u_colorization_offset),u_fade_t\n);\n#endif\nif (value.y > 0.0) value.x/=value.y;\n#else\ncolor=mix(texture(u_image0,v_pos0),texture(u_image1,v_pos1),u_fade_t);value=vec2(u_colorization_offset+dot(color.rgb,u_colorization_mix.rgb),color.a);\n#endif\ncolor=texture(u_color_ramp,vec2(value.x,0.5));if (color.a > 0.0) color.rgb/=color.a;color.a*=value.y;\n#else\ncolor0=texture(u_image0,v_pos0);color1=texture(u_image1,v_pos1);if (color0.a > 0.0) color0.rgb/=color0.a;if (color1.a > 0.0) color1.rgb/=color1.a;color=mix(color0,color1,u_fade_t);\n#endif\ncolor.a*=u_opacity;\n#ifdef GLOBE_POLES\ncolor.a*=1.0-smoothstep(0.0,0.05,u_zoom_transition);\n#endif\nvec3 rgb=color.rgb;rgb=vec3(\ndot(rgb,u_spin_weights.xyz),dot(rgb,u_spin_weights.zxy),dot(rgb,u_spin_weights.yzx));float average=(color.r+color.g+color.b)/3.0;rgb+=(average-rgb)*u_saturation_factor;rgb=(rgb-0.5)*u_contrast_factor+0.5;vec3 u_high_vec=vec3(u_brightness_low,u_brightness_low,u_brightness_low);vec3 u_low_vec=vec3(u_brightness_high,u_brightness_high,u_brightness_high);vec3 out_color=mix(u_high_vec,u_low_vec,rgb);\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(vec4(out_color,1.0),u_emissive_strength).rgb;\n#endif\n#ifdef FOG\nhighp float fog_limit_high_meters=1000000.0;highp float fog_limit_low_meters=600000.0;float fog_limit=1.0-smoothstep(fog_limit_low_meters,fog_limit_high_meters,u_raster_elevation);out_color=fog_dither(fog_apply(out_color,v_fog_pos,fog_limit));\n#endif\nglFragColor=vec4(out_color*color.a,color.a);\n#ifdef PROJECTION_GLOBE_VIEW\nglFragColor*=mix(1.0,1.0-smoothstep(0.0,0.05,u_zoom_transition),smoothstep(0.8,0.9,v_split_fade));\n#endif\n#ifdef RENDER_CUTOFF\nglFragColor=glFragColor*cutoff_opacity(u_cutoff_params,v_depth);\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\n#ifdef USE_MRT1\nout_Target1=vec4(u_emissive_strength*glFragColor.a,0.0,0.0,glFragColor.a);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\nuniform mat4 u_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform mat3 u_grid_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform vec2 u_perspective_transform;uniform vec2 u_texture_offset;uniform float u_raster_elevation;uniform float u_zoom_transition;uniform vec2 u_merc_center;\n#ifdef ELEVATED\nuniform lowp float u_zbias_factor;\n#endif\n#define GLOBE_UPSCALE GLOBE_RADIUS/6371008.8\n#ifdef GLOBE_POLES\nin vec3 a_globe_pos;in vec2 a_uv;\n#else\nin ivec2 a_pos;in uvec2 a_texture_pos;\n#endif\nout vec2 v_pos0;out vec2 v_pos1;out float v_depth;\n#ifdef PROJECTION_GLOBE_VIEW\nout float v_split_fade;\n#endif\nvoid main() {vec2 uv;\n#ifdef GLOBE_POLES\nvec3 globe_pos=a_globe_pos;uv=a_uv;float ele=u_raster_elevation;\n#ifdef ELEVATION_REFERENCE_GROUND\nele+=elevation(uv*EXTENT);\n#endif\nglobe_pos+=normalize(globe_pos)*ele*GLOBE_UPSCALE;gl_Position=u_matrix*u_globe_matrix*vec4(globe_pos,1.0);\n#ifdef FOG\nv_fog_pos=fog_position((u_normalize_matrix*vec4(a_globe_pos,1.0)).xyz);\n#endif\n#else\nvec4 world_pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec2 texture_pos=vec2(a_texture_pos);uv=texture_pos/8192.0;vec3 decomposed_pos_and_skirt=decomposeToPosAndSkirt(a_pos);vec3 latLng=u_grid_matrix*vec3(decomposed_pos_and_skirt.xy,1.0);float mercatorY=mercatorYfromLat(latLng[0]);float mercatorX=mercatorXfromLng(latLng[1]); \nfloat tiles=u_grid_matrix[0][2];if (tiles > 0.0) {float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];float uvY=mercatorY*tiles-idy;float uvX=mercatorX*tiles-idx;uv=vec2(uvX,uvY);}float ele=u_raster_elevation;\n#ifdef ELEVATION_REFERENCE_GROUND\nele+=elevation(uv*EXTENT)-decomposed_pos_and_skirt.z;\n#endif\nvec4 merc_world_pos=vec4(0.0); \nv_split_fade=0.0;if (u_zoom_transition > 0.0) {vec2 merc_pos=vec2(mercatorX,mercatorY);merc_world_pos=vec4(merc_pos,ele,1.0);merc_world_pos.xy-=u_merc_center;merc_world_pos.x=wrap(merc_world_pos.x,-0.5,0.5);merc_world_pos=u_merc_matrix*merc_world_pos;float opposite_merc_center=mod(u_merc_center.x+0.5,1.0);float dist_from_poles=(abs(mercatorY-0.5)*2.0);float range=0.1;v_split_fade=abs(opposite_merc_center-mercatorX);v_split_fade=clamp(1.0-v_split_fade,0.0,1.0);v_split_fade=max(smoothstep(1.0-range,1.0,dist_from_poles),max(smoothstep(1.0-range,1.0,v_split_fade),smoothstep(1.0-range,1.0,1.0-v_split_fade)));}vec3 globe_pos=latLngToECEF(latLng.xy);globe_pos+=normalize(globe_pos)*ele*GLOBE_UPSCALE;vec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);world_pos=vec4(mix(globe_world_pos.xyz,merc_world_pos.xyz,u_zoom_transition),1.0);\n#ifdef FOG\nv_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz);\n#endif\n#else\nfloat ele=0.0;vec2 decodedPos=vec2(a_pos);\n#ifdef ELEVATION_REFERENCE_GROUND\nvec3 decomposedPosAndSkirt=decomposeToPosAndSkirt(a_pos);float skirt=decomposedPosAndSkirt.z;decodedPos=decomposedPosAndSkirt.xy;uv=decodedPos/8192.0;ele=elevation(decodedPos)-skirt;\n#else\nuv=vec2(a_texture_pos)/8192.0;\n#endif\nworld_pos=vec4(decodedPos,(u_raster_elevation+ele),1.0);\n#ifdef FOG\nv_fog_pos=fog_position(decodedPos);\n#endif\n#endif\nfloat w=1.0+dot(uv*EXTENT,u_perspective_transform);gl_Position=u_matrix*world_pos*w;\n#endif\nv_pos0=uv;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;v_pos0=u_texture_offset.x+u_texture_offset.y*v_pos0;v_pos1=u_texture_offset.x+u_texture_offset.y*v_pos1;\n#ifdef ELEVATED\nfloat z=clamp(gl_Position.z/gl_Position.w,0.5,1.0);float zbias=max(0.00005,(pow(z,0.8)-z)*u_zbias_factor);gl_Position.z-=(gl_Position.w*zbias);\n#endif\n#ifdef RENDER_CUTOFF\nv_depth=gl_Position.z;\n#endif\n}'),symbol:ho('#include "_prelude_lighting.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#define SDF_PX 8.0\n#define SDF 1.0\n#define ICON 0.0\nuniform sampler2D u_texture;uniform sampler2D u_texture_icon;uniform highp float u_gamma_scale;uniform lowp float u_device_pixel_ratio;uniform bool u_is_text;uniform bool u_is_halo;uniform lowp float u_scale_factor;\n#ifdef ICON_TRANSITION\nuniform float u_icon_transition;\n#endif\n#ifdef COLOR_ADJUSTMENT\nuniform mat4 u_color_adj_mat;\n#endif\n#ifdef INDICATOR_CUTOUT\nin highp float v_z_offset;\n#else\n#ifdef RENDER_SHADOWS\nin highp float v_z_offset;\n#endif\n#endif\nin vec2 v_tex_a;\n#ifdef ICON_TRANSITION\nin vec2 v_tex_b;\n#endif\nin float v_draw_halo;in vec3 v_gamma_scale_size_fade_opacity;\n#ifdef RENDER_TEXT_AND_SYMBOL\nin float is_sdf;in vec2 v_tex_a_icon;\n#endif\n#ifdef RENDER_SHADOWS\nuniform vec3 u_ground_shadow_factor;in highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in highp float v_depth;\n#endif\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\n#ifdef USE_PAINT_PROPERTIES_UBO\nin lowp float v_opacity;\n#ifdef RENDER_SDF\nin lowp vec4 v_fill_np_color;in lowp vec4 v_halo_np_color;in lowp float v_halo_width;in lowp float v_halo_blur;\n#endif\n#ifdef LIGHTING_3D_MODE\nin lowp float v_emissive_strength;\n#endif\n#else\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\n#pragma mapbox: define lowp float emissive_strength\n#endif\nvoid main() {\n#ifdef USE_PAINT_PROPERTIES_UBO\nlowp float opacity=v_opacity;lowp vec4 fill_color=vec4(0.0);lowp vec4 halo_color=vec4(0.0);lowp float halo_width=0.0;lowp float halo_blur=0.0;\n#ifdef RENDER_SDF\nfill_color=vec4(v_fill_np_color.rgb*v_fill_np_color.a,v_fill_np_color.a);halo_color=vec4(v_halo_np_color.rgb*v_halo_np_color.a,v_halo_np_color.a);halo_width=v_halo_width;halo_blur=v_halo_blur;\n#endif\nlowp float emissive_strength=0.0;\n#ifdef LIGHTING_3D_MODE\nemissive_strength=v_emissive_strength;\n#endif\n#else\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\n#pragma mapbox: initialize lowp float emissive_strength\n#endif\nvec4 out_color;float fade_opacity=v_gamma_scale_size_fade_opacity[2];\n#ifdef RENDER_TEXT_AND_SYMBOL\nif (is_sdf==ICON) {vec2 tex_icon=v_tex_a_icon;lowp float alpha=opacity*fade_opacity;glFragColor=texture(u_texture_icon,tex_icon)*alpha;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nreturn;}\n#endif\nvec2 cutout_factors=vec2(0.0);\n#ifdef FEATURE_CUTOUT\ncutout_factors=get_cutout_factors(gl_FragCoord);\n#endif\n#ifdef RENDER_SDF\nfloat EDGE_GAMMA=0.105/u_device_pixel_ratio;float gamma_scale=v_gamma_scale_size_fade_opacity.x;float size=v_gamma_scale_size_fade_opacity.y;float fontScale=u_is_text ? size/24.0 : size;out_color=fill_color;highp float gamma=EDGE_GAMMA/(fontScale*u_gamma_scale);lowp float buff=(256.0-64.0)/256.0;bool draw_halo=v_draw_halo > 0.0;if (draw_halo) {out_color=halo_color;gamma=(halo_blur*u_scale_factor*1.19/SDF_PX+EDGE_GAMMA)/(fontScale*u_gamma_scale);buff=(6.0-halo_width*u_scale_factor/fontScale)/SDF_PX;}lowp float dist=texture(u_texture,v_tex_a).r;highp float gamma_scaled=gamma*gamma_scale;highp float alpha=smoothstep(buff-gamma_scaled,buff+gamma_scaled,dist);out_color*=alpha;\n#else\n#ifdef ICON_TRANSITION\nvec4 a=texture(u_texture,v_tex_a)*(1.0-u_icon_transition);vec4 b=texture(u_texture,v_tex_b)*u_icon_transition;out_color=(a+b);\n#else\nout_color=texture(u_texture,v_tex_a);\n#endif\n#ifdef APPLY_LUT_ON_GPU\nout_color=applyLUT(u_lutTexture,out_color);\n#endif\n#ifdef COLOR_ADJUSTMENT\nout_color=u_color_adj_mat*out_color;\n#endif\n#endif\nout_color*=opacity*fade_opacity;\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(out_color,emissive_strength);\n#ifdef RENDER_SHADOWS\nfloat light=shadowed_light_factor(v_pos_light_view_0,v_pos_light_view_1,v_depth);light=mix(light,1.0,cutout_factors.y);\n#ifdef TERRAIN\nout_color.rgb*=mix(u_ground_shadow_factor,vec3(1.0),light);\n#else\nout_color.rgb*=mix(v_z_offset !=0.0 ? u_ground_shadow_factor : vec3(1.0),vec3(1.0),light);\n#endif\n#endif\n#endif\n#ifdef INDICATOR_CUTOUT\nout_color=applyCutout(out_color,v_z_offset);\n#endif\n#ifdef FEATURE_CUTOUT\nout_color=apply_feature_cutout(out_color,gl_FragCoord,cutout_factors.x);\n#endif\nglFragColor=out_color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_terrain.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\n#define USING_APPEARANCE 1.0\nin ivec4 a_pos_offset;in uvec4 a_tex_size;in ivec4 a_pixeloffset;in vec4 a_projected_pos;in uint a_fade_opacity;\n#ifdef Z_OFFSET\nin float a_auto_z_offset;\n#endif\n#ifdef PROJECTION_GLOBE_VIEW\nin ivec4 a_globe_anchor;in vec3 a_globe_normal;\n#endif\n#ifdef ICON_TRANSITION\nin uvec2 a_texb;\n#endif\n#ifdef OCCLUSION_QUERIES\nin float a_occlusion_query_opacity;\n#endif\n#ifdef ELEVATED_ROADS\nin vec3 a_x_axis;in vec3 a_y_axis;uniform float u_normal_scale;\n#endif\n#ifdef INDICATOR_CUTOUT\nout highp float v_z_offset;\n#else\n#ifdef RENDER_SHADOWS\nout highp float v_z_offset;\n#endif\n#endif\nuniform bool u_is_size_zoom_constant;uniform bool u_is_size_feature_constant;uniform highp float u_size_t;uniform highp float u_size;uniform mat4 u_matrix;uniform mat4 u_inv_matrix;uniform mat4 u_label_plane_matrix;uniform mat4 u_coord_matrix;uniform bool u_is_text;uniform bool u_elevation_from_sea;uniform bool u_pitch_with_map;uniform bool u_rotate_symbol;uniform highp float u_aspect_ratio;uniform highp float u_camera_to_center_distance;uniform float u_fade_change;uniform vec2 u_texsize;uniform vec3 u_up_vector;uniform vec2 u_texsize_icon;uniform bool u_is_halo;\n#ifdef PROJECTION_GLOBE_VIEW\nuniform vec3 u_tile_id;uniform mat4 u_inv_rot_matrix;uniform vec2 u_merc_center;uniform vec3 u_camera_forward;uniform float u_zoom_transition;uniform vec3 u_ecef_origin;uniform mat4 u_tile_matrix;\n#endif\nout vec2 v_tex_a;\n#ifdef ICON_TRANSITION\nout vec2 v_tex_b;\n#endif\nout float v_draw_halo;out vec3 v_gamma_scale_size_fade_opacity;\n#ifdef RENDER_TEXT_AND_SYMBOL\nout float is_sdf;out vec2 v_tex_a_icon;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out highp float v_depth;\n#endif\n#ifdef USE_PAINT_PROPERTIES_UBO\n#ifndef MAX_UBO_SIZE_VEC4\n#define MAX_UBO_SIZE_VEC4 1024u\n#endif\n#define SPP_HEADER_SIZE_VEC4 3u\n#define DWORDS_PER_VEC4 4u\nstruct SymbolPaintProperties {vec4 fill_np_color;vec4 halo_np_color;float opacity;float halo_width;float halo_blur;float emissive_strength;float occlusion_opacity;float z_offset;vec2 translate;};struct PropertyType {bool isDataDriven;bool isZoomDependent;uint offsetDwords;};struct SymbolPropertyHeader {uint dataDrivenBlockSizeVec4;PropertyType fill_np_color;PropertyType halo_np_color;PropertyType opacity;PropertyType halo_width;PropertyType halo_blur;PropertyType emissive_strength;PropertyType occlusion_opacity;PropertyType z_offset;PropertyType translate;};uniform float u_zoom;uniform lowp vec4 u_spp_fill_np_color;uniform lowp vec4 u_spp_halo_np_color;uniform lowp float u_spp_opacity;uniform lowp float u_spp_halo_width;uniform lowp float u_spp_halo_blur;uniform lowp float u_spp_emissive_strength;uniform lowp float u_spp_occlusion_opacity;uniform highp float u_spp_z_offset;uniform lowp vec2 u_spp_translate_rotation;in float a_feature_index;layout(std140) uniform SymbolPaintPropertiesHeaderUniform {uvec4 header[SPP_HEADER_SIZE_VEC4];} u_spp_header;layout(std140) uniform SymbolPaintPropertiesUniform {vec4 properties[MAX_UBO_SIZE_VEC4];} u_spp_properties;layout(std140) uniform SymbolPaintPropertiesIndexUniform {uvec4 block_indices[MAX_UBO_SIZE_VEC4];} u_spp_index;out lowp float v_opacity;\n#ifdef RENDER_SDF\nout lowp vec4 v_fill_np_color;out lowp vec4 v_halo_np_color;out lowp float v_halo_width;out lowp float v_halo_blur;\n#endif\n#ifdef LIGHTING_3D_MODE\nout lowp float v_emissive_strength;\n#endif\nPropertyType getPropertyType(uint propertyIndex,uint dataDrivenMask,uint zoomDependentMask,uint offsetDwords) {PropertyType type;type.isDataDriven=(dataDrivenMask & (1u << propertyIndex)) !=0u;type.isZoomDependent=(zoomDependentMask & (1u << propertyIndex)) !=0u;type.offsetDwords=offsetDwords;return type;}SymbolPropertyHeader readSymbolPropertiesHeader() {SymbolPropertyHeader header;uint dataDrivenMask=u_spp_header.header[0][0];uint zoomDependentMask=u_spp_header.header[0][1];header.dataDrivenBlockSizeVec4=u_spp_header.header[0][2];header.fill_np_color =getPropertyType(0u,dataDrivenMask,zoomDependentMask,u_spp_header.header[0][3]);header.halo_np_color =getPropertyType(1u,dataDrivenMask,zoomDependentMask,u_spp_header.header[1][0]);header.opacity =getPropertyType(2u,dataDrivenMask,zoomDependentMask,u_spp_header.header[1][1]);header.halo_width =getPropertyType(3u,dataDrivenMask,zoomDependentMask,u_spp_header.header[1][2]);header.halo_blur =getPropertyType(4u,dataDrivenMask,zoomDependentMask,u_spp_header.header[1][3]);header.emissive_strength =getPropertyType(5u,dataDrivenMask,zoomDependentMask,u_spp_header.header[2][0]);header.occlusion_opacity =getPropertyType(6u,dataDrivenMask,zoomDependentMask,u_spp_header.header[2][1]);header.z_offset =getPropertyType(7u,dataDrivenMask,zoomDependentMask,u_spp_header.header[2][2]);header.translate =getPropertyType(8u,dataDrivenMask,zoomDependentMask,u_spp_header.header[2][3]);return header;}uint uvec4At(uvec4 v,uint index) {return (index==0u) ? v.x :\n(index==1u) ? v.y :\n(index==2u) ? v.z : v.w;}float vec4At(vec4 v,uint index) {return (index==0u) ? v.x :\n(index==1u) ? v.y :\n(index==2u) ? v.z : v.w;}vec4 readVec4(uint baseOffsetVec4,uint propertyOffsetDwords) {return u_spp_properties.properties[baseOffsetVec4+propertyOffsetDwords/DWORDS_PER_VEC4];}float readFloat(vec4 slot,uint propertyOffsetDwords) {return slot[propertyOffsetDwords % DWORDS_PER_VEC4];}uint readUint(uvec4 slot,uint offset) {return slot[offset % DWORDS_PER_VEC4];}vec2 readVec2(vec4 slot,uint propertyOffsetDwords) {float x=vec4At(slot,propertyOffsetDwords % DWORDS_PER_VEC4);float y=vec4At(slot,propertyOffsetDwords % DWORDS_PER_VEC4+1u);return vec2(x,y);}uint getDataDrivenBlockOffsetVec4(uint dataDrivenBlockSizeVec4) {uint featureIndex=uint(a_feature_index);uvec4 slot=u_spp_index.block_indices[featureIndex/DWORDS_PER_VEC4];uint blockIndex=uvec4At(slot,featureIndex % DWORDS_PER_VEC4);return blockIndex*dataDrivenBlockSizeVec4;}vec4 readColorProperty(PropertyType propertyType,uint dataDrivenBlockSizeVec4) {uint blockOffsetVec4=getDataDrivenBlockOffsetVec4(dataDrivenBlockSizeVec4);vec4 color=readVec4(blockOffsetVec4,propertyType.offsetDwords);if (propertyType.isZoomDependent) {color=unpack_mix_color(color,u_zoom);} else {vec2 packedColor=readVec2(color,propertyType.offsetDwords);color=decode_color(packedColor);}return color;}vec2 readVec2Property(PropertyType propertyType,uint dataDrivenBlockSizeVec4) {uint blockOffsetVec4=getDataDrivenBlockOffsetVec4(dataDrivenBlockSizeVec4);vec4 slot=readVec4(blockOffsetVec4,propertyType.offsetDwords);if (propertyType.isZoomDependent) {vec2 minVal=slot.xy;vec2 maxVal=slot.zw;return mix(minVal,maxVal,u_zoom);}return readVec2(slot,propertyType.offsetDwords);}float readFloatProperty(PropertyType propertyType,uint dataDrivenBlockSizeVec4) {uint blockOffsetVec4=getDataDrivenBlockOffsetVec4(dataDrivenBlockSizeVec4);vec4 slot=readVec4(blockOffsetVec4,propertyType.offsetDwords);float value;if (propertyType.isZoomDependent) {vec2 packedValues=readVec2(slot,propertyType.offsetDwords);value=unpack_mix_vec2(packedValues,u_zoom);} else {value=readFloat(slot,propertyType.offsetDwords);}return value;}SymbolPaintProperties readSymbolPaintProperties() {SymbolPropertyHeader header=readSymbolPropertiesHeader();uint sizeVec4=header.dataDrivenBlockSizeVec4;SymbolPaintProperties props;props.fill_np_color =header.fill_np_color.isDataDriven ? readColorProperty(header.fill_np_color,sizeVec4) : u_spp_fill_np_color;props.halo_np_color =header.halo_np_color.isDataDriven ? readColorProperty(header.halo_np_color,sizeVec4) : u_spp_halo_np_color;props.opacity =header.opacity.isDataDriven ? readFloatProperty(header.opacity,sizeVec4) : u_spp_opacity;props.halo_width =header.halo_width.isDataDriven ? readFloatProperty(header.halo_width,sizeVec4) : u_spp_halo_width;props.halo_blur =header.halo_blur.isDataDriven ? readFloatProperty(header.halo_blur,sizeVec4) : u_spp_halo_blur;props.emissive_strength =header.emissive_strength.isDataDriven ? readFloatProperty(header.emissive_strength,sizeVec4) : u_spp_emissive_strength;props.occlusion_opacity =header.occlusion_opacity.isDataDriven ? readFloatProperty(header.occlusion_opacity,sizeVec4) : u_spp_occlusion_opacity;props.z_offset =header.z_offset.isDataDriven ? readFloatProperty(header.z_offset,sizeVec4) : u_spp_z_offset;props.translate =header.translate.isDataDriven ? readVec2Property(header.translate,sizeVec4) : vec2(0.0);return props;}\n#else\n#pragma mapbox: define highp vec4 fill_color\n#pragma mapbox: define highp vec4 halo_color\n#pragma mapbox: define lowp float opacity\n#pragma mapbox: define lowp float halo_width\n#pragma mapbox: define lowp float halo_blur\n#pragma mapbox: define lowp float emissive_strength\n#pragma mapbox: define lowp float occlusion_opacity\n#pragma mapbox: define highp float z_offset\n#endif\nvec2 unpack_opacity(uint packedOpacity) {return vec2(float(packedOpacity/2u)/127.0,float(packedOpacity & 1u));}void main() {\n#ifdef USE_PAINT_PROPERTIES_UBO\nSymbolPaintProperties paint_properties=readSymbolPaintProperties();lowp float opacity=paint_properties.opacity;v_opacity=opacity;\n#ifdef RENDER_SDF\nv_fill_np_color=paint_properties.fill_np_color;v_halo_np_color=paint_properties.halo_np_color;v_halo_width=paint_properties.halo_width;v_halo_blur=paint_properties.halo_blur;\n#endif\n#ifdef LIGHTING_3D_MODE\nv_emissive_strength=paint_properties.emissive_strength;\n#endif\nlowp float occlusion_opacity=paint_properties.occlusion_opacity;highp float z_offset=paint_properties.z_offset;\n#else\n#pragma mapbox: initialize highp vec4 fill_color\n#pragma mapbox: initialize highp vec4 halo_color\n#pragma mapbox: initialize lowp float opacity\n#pragma mapbox: initialize lowp float halo_width\n#pragma mapbox: initialize lowp float halo_blur\n#pragma mapbox: initialize lowp float emissive_strength\n#pragma mapbox: initialize lowp float occlusion_opacity\n#pragma mapbox: initialize highp float z_offset\n#endif\nvec2 a_pos=vec2(a_pos_offset.xy);vec2 a_offset=vec2(a_pos_offset.zw);vec2 a_tex=vec2(a_tex_size.xy);vec2 a_size=vec2(a_tex_size.zw);float a_size_min=floor(a_size[0]*0.5);float a_size_max= floor(a_size[1]*0.5);float a_apperance=a_size[1]-2.0*a_size_max;vec2 a_pxoffset=vec2(a_pixeloffset.xy);vec2 a_min_font_scale=vec2(a_pixeloffset.zw)/256.0;highp float segment_angle=-a_projected_pos[3];float size;if (a_apperance==USING_APPEARANCE) {size=a_size_max/128.0;} else if (!u_is_size_zoom_constant && !u_is_size_feature_constant) {size=mix(a_size_min,a_size_max,u_size_t)/128.0;} else if (u_is_size_zoom_constant && !u_is_size_feature_constant) {size=a_size_min/128.0;} else {size=u_size;}vec2 tile_anchor=a_pos;float e=u_elevation_from_sea ? z_offset : z_offset+elevation(tile_anchor);\n#ifdef Z_OFFSET\ne+=a_auto_z_offset;\n#endif\nvec3 h=elevationVector(tile_anchor)*e;float globe_occlusion_fade;vec3 world_pos;vec3 mercator_pos;vec3 world_pos_globe;\n#ifdef PROJECTION_GLOBE_VIEW\nmercator_pos=mercator_tile_position(u_inv_rot_matrix,tile_anchor,u_tile_id,u_merc_center);world_pos_globe=vec3(a_globe_anchor)+h;world_pos=mix_globe_mercator(world_pos_globe,mercator_pos,u_zoom_transition);vec4 ecef_point=u_tile_matrix*vec4(world_pos,1.0);vec3 origin_to_point=ecef_point.xyz-u_ecef_origin;globe_occlusion_fade=dot(origin_to_point,u_camera_forward) >=0.0 ? 0.0 : 1.0;\n#else\nworld_pos=vec3(tile_anchor,0)+h;globe_occlusion_fade=1.0;\n#endif\nvec4 projected_point=u_matrix*vec4(world_pos,1);highp float camera_to_anchor_distance=projected_point.w;highp float distance_ratio=u_pitch_with_map ?\ncamera_to_anchor_distance/u_camera_to_center_distance :\nu_camera_to_center_distance/camera_to_anchor_distance;highp float perspective_ratio=clamp(\n0.5+0.5*distance_ratio,0.0,1.5);size*=perspective_ratio;float font_scale=u_is_text ? size/24.0 : size;highp float symbol_rotation=0.0;if (u_rotate_symbol) {vec4 offsetprojected_point;vec2 a;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 displacement=vec3(a_globe_normal.z,0,-a_globe_normal.x);offsetprojected_point=u_matrix*vec4(vec3(a_globe_anchor)+displacement,1);vec4 projected_point_globe=u_matrix*vec4(world_pos_globe,1);a=projected_point_globe.xy/projected_point_globe.w;\n#else\noffsetprojected_point=u_matrix*vec4(tile_anchor+vec2(1,0),0,1);a=projected_point.xy/projected_point.w;\n#endif\nvec2 b=offsetprojected_point.xy/offsetprojected_point.w;symbol_rotation=atan((b.y-a.y)/u_aspect_ratio,b.x-a.x);}vec4 projected_pos;\n#ifdef PROJECTION_GLOBE_VIEW\n#ifdef PROJECTED_POS_ON_VIEWPORT\nprojected_pos=u_label_plane_matrix*vec4(a_projected_pos.xyz+h,1.0);\n#else\nvec3 proj_pos=mix_globe_mercator(a_projected_pos.xyz,mercator_pos,u_zoom_transition)+h;projected_pos=u_label_plane_matrix*vec4(proj_pos,1.0); \n#endif\n#else\nprojected_pos=u_label_plane_matrix*vec4(a_projected_pos.xy,h.z,1.0);\n#endif\nhighp float angle_sin=sin(segment_angle+symbol_rotation);highp float angle_cos=cos(segment_angle+symbol_rotation);mat2 rotation_matrix=mat2(angle_cos,-1.0*angle_sin,angle_sin,angle_cos);float z=0.0;vec2 offset=rotation_matrix*(a_offset/32.0*max(a_min_font_scale,font_scale)+a_pxoffset/16.0);\n#ifdef TERRAIN\n#ifdef PITCH_WITH_MAP_TERRAIN\nvec4 tile_pos=u_label_plane_matrix_inv*vec4(a_projected_pos.xy+offset,0.0,1.0);z=elevation(tile_pos.xy);\n#endif\n#endif\n#ifdef Z_OFFSET\nz+=u_pitch_with_map ? a_auto_z_offset+z_offset : 0.0;\n#else\nz+=u_pitch_with_map ? z_offset : 0.0;\n#endif\nfloat occlusion_fade=globe_occlusion_fade;vec2 fade_opacity=unpack_opacity(a_fade_opacity);float fade_change=fade_opacity[1] > 0.5 ? u_fade_change :-u_fade_change;float out_fade_opacity=max(0.0,min(occlusion_fade,fade_opacity[0]+fade_change));\n#ifdef DEPTH_OCCLUSION\nfloat depth_occlusion=occlusionFadeMultiSample(projected_point);float depth_occlusion_multplier=mix(occlusion_opacity,1.0,depth_occlusion);out_fade_opacity*=depth_occlusion_multplier;\n#endif\n#ifdef OCCLUSION_QUERIES\nfloat occludedFadeMultiplier=mix(occlusion_opacity,1.0,a_occlusion_query_opacity);out_fade_opacity*=occludedFadeMultiplier;\n#endif\n#ifdef Z_TEST_OCCLUSION\nout_fade_opacity*=occlusion_opacity;\n#endif\nfloat alpha=opacity*out_fade_opacity;float hidden=float(alpha==0.0 || projected_point.w <=0.0 || occlusion_fade==0.0);vec3 pos;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 xAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,u_up_vector)) : vec3(1,0,0);vec3 yAxis=u_pitch_with_map ? normalize(cross(a_globe_normal,xAxis)) : vec3(0,1,0);pos=projected_pos.xyz/projected_pos.w+xAxis*offset.x+yAxis*offset.y;\n#else\n#ifdef ELEVATED_ROADS\nvec3 xAxis=vec3(a_x_axis.xy,a_x_axis.z*u_normal_scale);vec3 yAxis=vec3(a_y_axis.xy,a_y_axis.z*u_normal_scale);pos=projected_pos.xyz/projected_pos.w+xAxis*offset.x+yAxis*offset.y;\n#else\npos=vec3(projected_pos.xy/projected_pos.w+offset,z);\n#endif\n#endif\ngl_Position=mix(u_coord_matrix*vec4(pos,1.0),AWAY,hidden);\n#ifdef USE_PAINT_PROPERTIES_UBO\n{vec2 tr=paint_properties.translate;vec2 rotated_tr=vec2(\nu_spp_translate_rotation.x*tr.x-u_spp_translate_rotation.y*tr.y,u_spp_translate_rotation.y*tr.x+u_spp_translate_rotation.x*tr.y\n);gl_Position.xy+=(u_coord_matrix*vec4(rotated_tr,0.0,0.0)).xy;}\n#endif\nfloat gamma_scale=gl_Position.w;v_draw_halo=(u_is_halo && float(gl_InstanceID)==0.0) ? 1.0 : 0.0;v_gamma_scale_size_fade_opacity=vec3(gamma_scale,size,out_fade_opacity);v_tex_a=a_tex/u_texsize;\n#ifdef RENDER_TEXT_AND_SYMBOL\nis_sdf=a_size[0]-2.0*a_size_min;v_tex_a_icon=a_tex/u_texsize_icon;\n#endif\n#ifdef ICON_TRANSITION\nv_tex_b=vec2(a_texb)/u_texsize;\n#endif\n#ifdef RENDER_SHADOWS\nvec4 shd_pos=u_inv_matrix*vec4(pos,1.0);vec3 shd_pos0=shd_pos.xyz;vec3 shd_pos1=shd_pos.xyz;\n#ifdef NORMAL_OFFSET\nvec3 shd_pos_offset=shadow_normal_offset(vec3(0.0,0.0,1.0));shd_pos0+=shd_pos_offset*shadow_normal_offset_multiplier0();shd_pos1+=shd_pos_offset*shadow_normal_offset_multiplier1();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shd_pos0,1);v_pos_light_view_1=u_light_matrix_1*vec4(shd_pos1,1);v_depth=gl_Position.w;\n#endif\n#ifdef INDICATOR_CUTOUT\nv_z_offset=e;\n#else\n#ifdef RENDER_SHADOWS\nv_z_offset=e;\n#endif\n#endif\n}'),terrainRaster:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform sampler2D u_image0;\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nuniform sampler2D u_image1;uniform float u_emissive_texture_available;\n#endif\nin vec2 v_pos0;\n#ifdef FOG\nin float v_fog_opacity;\n#endif\n#ifdef RENDER_SHADOWS\nin vec4 v_pos_light_view_0;in vec4 v_pos_light_view_1;\n#endif\nuniform vec3 u_ground_shadow_factor;void main() {vec4 image_color=texture(u_image0,v_pos0);vec4 color;\n#ifdef LIGHTING_3D_MODE\nconst vec3 normal=vec3(0.0,0.0,1.0);\n#ifdef RENDER_SHADOWS\nfloat cutoffOpacity=1.0;\n#ifdef RENDER_CUTOFF\ncutoffOpacity=cutoff_opacity(u_cutoff_params,1.0/gl_FragCoord.w);\n#endif\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nfloat emissive_strength=u_emissive_texture_available > 0.5 ? texture(u_image1,v_pos0).r : image_color.a;vec3 unlit_base=image_color.rgb*(1.0-emissive_strength);vec3 emissive_base=image_color.rgb*emissive_strength;float ndotl=u_shadow_direction.z;float occlusion=ndotl < 0.0 ? 1.0 : shadow_occlusion(v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w,0.0);ndotl=max(0.0,ndotl);vec3 lit=apply_lighting(unlit_base,normal,mix(1.0,(1.0-(u_shadow_intensity*occlusion))*ndotl,cutoffOpacity));vec3 emissive=compute_emissive_draped(emissive_base,1.0-u_shadow_intensity,occlusion,u_ground_shadow_factor);color.rgb=lit+emissive;color.a=1.0;\n#else\nfloat lighting_factor=shadowed_light_factor_normal_unbiased(normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);color=apply_lighting(image_color,normal,mix(1.0,lighting_factor,cutoffOpacity));\n#endif\n#else\nfloat lighting_factor=u_lighting_directional_dir.z;color=apply_lighting(image_color,normal,lighting_factor);\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nfloat emissive_strength=u_emissive_texture_available > 0.5 ? texture(u_image1,v_pos0).r : image_color.a;color.rgb=mix(color.rgb,image_color.rgb,emissive_strength);color.a=1.0;\n#endif\n#endif\n#else\ncolor=image_color;\n#endif\n#ifdef FOG\n#ifdef ZERO_EXAGGERATION\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#else\ncolor=fog_dither(fog_apply_from_vert(color,v_fog_opacity));\n#endif\n#endif\nglFragColor=color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\nuniform mat4 u_matrix;uniform float u_skirt_height;in ivec2 a_pos;out vec2 v_pos0;\n#ifdef FOG\nout float v_fog_opacity;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out vec4 v_pos_light_view_0;out vec4 v_pos_light_view_1;\n#endif\nvoid main() {vec3 decomposedPosAndSkirt=decomposeToPosAndSkirt(a_pos);float skirt=decomposedPosAndSkirt.z;vec2 decodedPos=decomposedPosAndSkirt.xy;float elevation=elevation(decodedPos)-skirt*u_skirt_height;v_pos0=decodedPos/8192.0;gl_Position=u_matrix*vec4(decodedPos,elevation,1.0);\n#ifdef FOG\n#ifdef ZERO_EXAGGERATION\nv_fog_pos=fog_position(decodedPos);\n#else\nv_fog_opacity=fog(fog_position(vec3(decodedPos,elevation)));\n#endif\n#endif\n#ifdef RENDER_SHADOWS\nvec3 pos=vec3(decodedPos,elevation);v_pos_light_view_0=u_light_matrix_0*vec4(pos,1.);v_pos_light_view_1=u_light_matrix_1*vec4(pos,1.);\n#endif\n}'),terrainDepth:ho("precision highp float;in float v_depth;void main() {glFragColor=pack_depth(v_depth);}",'#include "_prelude_terrain.vertex.glsl"\nuniform mat4 u_matrix;in ivec2 a_pos;out float v_depth;void main() {float elevation=elevation(vec2(a_pos));gl_Position=u_matrix*vec4(a_pos,elevation,1.0);v_depth=gl_Position.z/gl_Position.w;}'),skybox:ho('#include "_prelude_fog.fragment.glsl"\nin lowp vec3 v_uv;uniform lowp samplerCube u_cubemap;uniform lowp float u_opacity;uniform highp float u_temporal_offset;uniform highp vec3 u_sun_direction;float sun_disk(highp vec3 ray_direction,highp vec3 sun_direction) {highp float cos_angle=dot(normalize(ray_direction),sun_direction);const highp float cos_sun_angular_diameter=0.99996192306;const highp float smoothstep_delta=1e-5;return smoothstep(\ncos_sun_angular_diameter-smoothstep_delta,cos_sun_angular_diameter+smoothstep_delta,cos_angle);}float map(float value,float start,float end,float new_start,float new_end) {return ((value-start)*(new_end-new_start))/(end-start)+new_start;}void main() {vec3 uv=v_uv;const float y_bias=0.015;uv.y+=y_bias;uv.y=pow(abs(uv.y),1.0/5.0);uv.y=map(uv.y,0.0,1.0,-1.0,1.0);vec3 sky_color=texture(u_cubemap,uv).rgb;\n#ifdef FOG\nsky_color=fog_apply_sky_gradient(v_uv.xzy,sky_color);\n#endif\nsky_color+=0.1*sun_disk(v_uv,u_sun_direction);glFragColor=vec4(sky_color*u_opacity,u_opacity);\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\n}',Un),skyboxGradient:ho('#include "_prelude_fog.fragment.glsl"\nin highp vec3 v_uv;uniform lowp sampler2D u_color_ramp;uniform highp vec3 u_center_direction;uniform lowp float u_radius;uniform lowp float u_opacity;uniform highp float u_temporal_offset;void main() {float progress=acos(dot(normalize(v_uv),u_center_direction))/u_radius;vec4 color=texture(u_color_ramp,vec2(progress,0.5));\n#ifdef FOG\ncolor.rgb=fog_apply_sky_gradient(v_uv.xzy,color.rgb/color.a)*color.a;\n#endif\ncolor*=u_opacity;glFragColor=color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\n}',Un),skyboxCapture:ho("\nin highp vec3 v_position;uniform highp float u_sun_intensity;uniform highp float u_luminance;uniform lowp vec3 u_sun_direction;uniform highp vec4 u_color_tint_r;uniform highp vec4 u_color_tint_m;precision highp float;\n#define BETA_R vec3(5.5e-6,13.0e-6,22.4e-6)\n#define BETA_M vec3(21e-6,21e-6,21e-6)\n#define MIE_G 0.76\n#define DENSITY_HEIGHT_SCALE_R 8000.0\n#define DENSITY_HEIGHT_SCALE_M 1200.0\n#define PLANET_RADIUS 6360e3\n#define ATMOSPHERE_RADIUS 6420e3\n#define SAMPLE_STEPS 10\n#define DENSITY_STEPS 4\nfloat ray_sphere_exit(vec3 orig,vec3 dir,float radius) {float a=dot(dir,dir);float b=2.0*dot(dir,orig);float c=dot(orig,orig)-radius*radius;float d=sqrt(b*b-4.0*a*c);return (-b+d)/(2.0*a);}vec3 extinction(vec2 density) {return exp(-vec3(BETA_R*u_color_tint_r.a*density.x+BETA_M*u_color_tint_m.a*density.y));}vec2 local_density(vec3 point) {float height=max(length(point)-PLANET_RADIUS,0.0);float exp_r=exp(-height/DENSITY_HEIGHT_SCALE_R);float exp_m=exp(-height/DENSITY_HEIGHT_SCALE_M);return vec2(exp_r,exp_m);}float phase_ray(float cos_angle) {return (3.0/(16.0*PI))*(1.0+cos_angle*cos_angle);}float phase_mie(float cos_angle) {return (3.0/(8.0*PI))*((1.0-MIE_G*MIE_G)*(1.0+cos_angle*cos_angle))/((2.0+MIE_G*MIE_G)*pow(1.0+MIE_G*MIE_G-2.0*MIE_G*cos_angle,1.5));}vec2 density_to_atmosphere(vec3 point,vec3 light_dir) {float ray_len=ray_sphere_exit(point,light_dir,ATMOSPHERE_RADIUS);float step_len=ray_len/float(DENSITY_STEPS);vec2 density_point_to_atmosphere=vec2(0.0);for (int i=0; i < DENSITY_STEPS;++i) {vec3 point_on_ray=point+light_dir*((float(i)+0.5)*step_len);density_point_to_atmosphere+=local_density(point_on_ray)*step_len;;}return density_point_to_atmosphere;}vec3 atmosphere(vec3 ray_dir,vec3 sun_direction,float sun_intensity) {vec2 density_orig_to_point=vec2(0.0);vec3 scatter_r=vec3(0.0);vec3 scatter_m=vec3(0.0);vec3 origin=vec3(0.0,PLANET_RADIUS,0.0);float ray_len=ray_sphere_exit(origin,ray_dir,ATMOSPHERE_RADIUS);float step_len=ray_len/float(SAMPLE_STEPS);for (int i=0; i < SAMPLE_STEPS;++i) {vec3 point_on_ray=origin+ray_dir*((float(i)+0.5)*step_len);vec2 density=local_density(point_on_ray)*step_len;density_orig_to_point+=density;vec2 density_point_to_atmosphere=density_to_atmosphere(point_on_ray,sun_direction);vec2 density_orig_to_atmosphere=density_orig_to_point+density_point_to_atmosphere;vec3 extinction=extinction(density_orig_to_atmosphere);scatter_r+=density.x*extinction;scatter_m+=density.y*extinction;}float cos_angle=dot(ray_dir,sun_direction);float phase_r=phase_ray(cos_angle);float phase_m=phase_mie(cos_angle);vec3 beta_r=BETA_R*u_color_tint_r.rgb*u_color_tint_r.a;vec3 beta_m=BETA_M*u_color_tint_m.rgb*u_color_tint_m.a;return (scatter_r*phase_r*beta_r+scatter_m*phase_m*beta_m)*sun_intensity;}const float A=0.15;const float B=0.50;const float C=0.10;const float D=0.20;const float E=0.02;const float F=0.30;vec3 uncharted2_tonemap(vec3 x) {return ((x*(A*x+C*B)+D*E)/(x*(A*x+B)+D*F))-E/F;}void main() {vec3 ray_direction=v_position;ray_direction.y=pow(ray_direction.y,5.0);const float y_bias=0.015;ray_direction.y+=y_bias;vec3 color=atmosphere(normalize(ray_direction),u_sun_direction,u_sun_intensity);float white_scale=1.0748724675633854;color=uncharted2_tonemap((log2(2.0/pow(u_luminance,4.0)))*color)*white_scale;glFragColor=vec4(color,1.0);}","in highp vec3 a_pos_3f;uniform mat3 u_matrix_3f;out highp vec3 v_position;float map(float value,float start,float end,float new_start,float new_end) {return ((value-start)*(new_end-new_start))/(end-start)+new_start;}void main() {vec4 pos=vec4(u_matrix_3f*a_pos_3f,1.0);v_position=pos.xyz;v_position.y*=-1.0;v_position.y=map(v_position.y,-1.0,1.0,0.0,1.0);gl_Position=vec4(a_pos_3f.xy,0.0,1.0);}"),globeRaster:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform sampler2D u_image0;\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nuniform sampler2D u_image1;uniform float u_emissive_texture_available;\n#endif\nuniform float u_far_z_cutoff;in vec2 v_pos0;\n#ifndef FOG\nuniform highp vec3 u_frustum_tl;uniform highp vec3 u_frustum_tr;uniform highp vec3 u_frustum_br;uniform highp vec3 u_frustum_bl;uniform highp vec3 u_globe_pos;uniform highp float u_globe_radius;uniform vec2 u_viewport;\n#endif\nvoid main() {vec4 color;\n#ifdef CUSTOM_ANTIALIASING\nhighp vec2 uv=gl_FragCoord.xy/u_viewport;\n#ifdef FLIP_Y\nuv.y=1.0-uv.y;\n#endif\nhighp vec3 ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,uv.x),mix(u_frustum_bl,u_frustum_br,uv.x),1.0-uv.y);highp vec3 dir=normalize(ray_dir);highp vec3 closest_point=dot(u_globe_pos,dir)*dir;highp float norm_dist_from_center=1.0-length(closest_point-u_globe_pos)/u_globe_radius;const float antialias_pixel=2.0;highp float antialias_factor=antialias_pixel*fwidth(norm_dist_from_center);highp float antialias=smoothstep(0.0,antialias_factor,norm_dist_from_center);vec4 raster=texture(u_image0,v_pos0);\n#ifdef LIGHTING_3D_MODE\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nfloat emissive_strength=u_emissive_texture_available > 0.5 ? texture(u_image1,v_pos0).r : raster.a;raster=apply_lighting_with_emission_ground(raster,emissive_strength);color=vec4(clamp(raster.rgb,vec3(0),vec3(1))*antialias,antialias);\n#else\nraster=apply_lighting_ground(raster);color=vec4(raster.rgb*antialias,raster.a*antialias);\n#endif\n#else\ncolor=vec4(raster.rgb*antialias,raster.a*antialias);\n#endif\n#else\ncolor=texture(u_image0,v_pos0);\n#ifdef LIGHTING_3D_MODE\n#ifdef LIGHTING_3D_ALPHA_EMISSIVENESS\nfloat emissive_strength=u_emissive_texture_available > 0.5 ? texture(u_image1,v_pos0).r : color.a;color=apply_lighting_with_emission_ground(color,emissive_strength);color.a=1.0;\n#else\ncolor=apply_lighting_ground(color);\n#endif\n#endif\n#endif\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos));\n#endif\ncolor*=1.0-step(u_far_z_cutoff,1.0/gl_FragCoord.w);glFragColor=color;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_terrain.vertex.glsl"\nuniform mat4 u_proj_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform float u_zoom_transition;uniform vec2 u_merc_center;uniform mat3 u_grid_matrix;uniform float u_skirt_height;\n#ifdef GLOBE_POLES\nin vec3 a_globe_pos;in vec2 a_uv;\n#else\nin ivec2 a_pos;\n#endif\nout vec2 v_pos0;void main() {\n#ifdef GLOBE_POLES\nvec3 globe_pos=a_globe_pos;vec2 uv=a_uv;\n#else\nfloat tiles=u_grid_matrix[0][2];float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];vec3 decomposed_pos_and_skirt=decomposeToPosAndSkirt(a_pos);vec3 latLng=u_grid_matrix*vec3(decomposed_pos_and_skirt.xy,1.0);float mercatorY=mercatorYfromLat(latLng[0]);float uvY=mercatorY*tiles-idy;float mercatorX=mercatorXfromLng(latLng[1]);float uvX=mercatorX*tiles-idx;vec3 globe_pos=latLngToECEF(latLng.xy);vec2 merc_pos=vec2(mercatorX,mercatorY);vec2 uv=vec2(uvX,uvY);\n#endif\nv_pos0=uv;vec2 tile_pos=uv*EXTENT;vec3 globe_derived_up_vector=normalize(globe_pos)*u_tile_up_scale;\n#ifdef GLOBE_POLES\nvec3 up_vector=globe_derived_up_vector;\n#else\nvec3 up_vector=elevationVector(tile_pos);\n#endif\nfloat height=elevation(tile_pos);globe_pos+=up_vector*height;\n#ifndef GLOBE_POLES\nglobe_pos-=globe_derived_up_vector*u_skirt_height*decomposed_pos_and_skirt.z;\n#endif\n#ifdef GLOBE_POLES\nvec4 interpolated_pos=u_globe_matrix*vec4(globe_pos,1.0);\n#else\nvec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);vec4 merc_world_pos=vec4(0.0);if (u_zoom_transition > 0.0) {merc_world_pos=vec4(merc_pos,height-u_skirt_height*decomposed_pos_and_skirt.z,1.0);merc_world_pos.xy-=u_merc_center;merc_world_pos.x=wrap(merc_world_pos.x,-0.5,0.5);merc_world_pos=u_merc_matrix*merc_world_pos;}vec4 interpolated_pos=vec4(mix(globe_world_pos.xyz,merc_world_pos.xyz,u_zoom_transition),1.0);\n#endif\ngl_Position=u_proj_matrix*interpolated_pos;\n#ifdef FOG\nv_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz);\n#endif\n}'),globeAtmosphere:ho('#include "_prelude_fog.fragment.glsl"\nuniform float u_transition;uniform highp float u_fadeout_range;uniform highp float u_temporal_offset;uniform vec4 u_atmosphere_fog_color;uniform vec4 u_high_color;uniform vec4 u_space_color;uniform float u_horizon_angle;in highp vec3 v_ray_dir;in highp vec3 v_horizon_dir;void main() {highp vec3 dir=normalize(v_ray_dir);float globe_pos_dot_dir;\n#ifdef PROJECTION_GLOBE_VIEW\nglobe_pos_dot_dir=dot(u_globe_pos,dir);highp vec3 closest_point_forward=abs(globe_pos_dot_dir)*dir;float norm_dist_from_center=length(closest_point_forward-u_globe_pos)/u_globe_radius;if (norm_dist_from_center < 0.98) {\n#ifdef ALPHA_PASS\nglFragColor=vec4(0,0,0,0);return;\n#else\n#ifdef NATIVE\nglFragColor=vec4(1,1,1,1);\n#else\nglFragColor=vec4(0,0,0,1);\n#endif\nreturn;\n#endif\n}\n#endif\nhighp vec3 horizon_dir=normalize(v_horizon_dir);float horizon_angle_mercator=dir.y < horizon_dir.y ?\n0.0 : max(acos(clamp(dot(dir,horizon_dir),-1.0,1.0)),0.0);float horizon_angle;\n#ifdef PROJECTION_GLOBE_VIEW\nhighp vec3 closest_point=globe_pos_dot_dir*dir;highp float closest_point_to_center=length(closest_point-u_globe_pos);highp float theta=asin(clamp(closest_point_to_center/length(u_globe_pos),-1.0,1.0));horizon_angle=globe_pos_dot_dir < 0.0 ?\nPI-theta-u_horizon_angle : theta-u_horizon_angle;float angle_t=pow(u_transition,10.0);horizon_angle=mix(horizon_angle,horizon_angle_mercator,angle_t);\n#else\nhorizon_angle=horizon_angle_mercator;\n#endif\nhorizon_angle/=PI;float t=exp(-horizon_angle/u_fadeout_range);float alpha_0=u_atmosphere_fog_color.a;float alpha_1=u_high_color.a;float alpha_2=u_space_color.a;vec3 color_stop_0=u_atmosphere_fog_color.rgb;vec3 color_stop_1=u_high_color.rgb;vec3 color_stop_2=u_space_color.rgb;\n#ifdef ALPHA_PASS\nfloat a0=mix(alpha_2,1.0,alpha_1);float a1=mix(a0,1.0,alpha_0);float a2=mix(a0,a1,t);float a =mix(alpha_2,a2,t);glFragColor=vec4(1.0,1.0,1.0,a);\n#else\nvec3 c0=mix(color_stop_2,color_stop_1,alpha_1);vec3 c1=mix(c0,color_stop_0,alpha_0);vec3 c2=mix(c0,c1,t);vec3 c=c2;glFragColor=vec4(c*t,t);\n#endif\n}',"in vec3 a_pos;in vec2 a_uv;uniform vec3 u_frustum_tl;uniform vec3 u_frustum_tr;uniform vec3 u_frustum_br;uniform vec3 u_frustum_bl;uniform float u_horizon;out highp vec3 v_ray_dir;out highp vec3 v_horizon_dir;void main() {v_ray_dir=mix(\nmix(u_frustum_tl,u_frustum_tr,a_uv.x),mix(u_frustum_bl,u_frustum_br,a_uv.x),a_uv.y);v_horizon_dir=mix(\nmix(u_frustum_tl,u_frustum_bl,u_horizon),mix(u_frustum_tr,u_frustum_br,u_horizon),a_uv.x);gl_Position=vec4(a_pos,1.0);}"),model:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform float u_opacity;\n#ifdef DITHERED_DISCARD\nuniform float u_dithered_discard_threshold;\n#endif\nuniform vec3 u_lightcolor;uniform vec3 u_lightpos;uniform float u_lightintensity;uniform vec4 u_baseColorFactor;uniform vec4 u_emissiveFactor;uniform float u_metallicFactor;uniform float u_roughnessFactor;uniform float u_emissive_strength;in highp vec4 v_position_height;in lowp vec4 v_color_mix;\n#ifdef RENDER_SHADOWS\nin highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;in float v_depth_shadows;\n#endif\n#ifdef OCCLUSION_TEXTURE_TRANSFORM\nuniform vec4 u_occlusionTextureTransform;\n#endif\n#pragma mapbox: define-attribute highp vec3 normal_3f\n#pragma mapbox: define-attribute highp vec3 color_3f\n#pragma mapbox: define-attribute highp vec4 color_4f\n#pragma mapbox: define-attribute highp vec2 uv_2f\n#pragma mapbox: initialize-attribute highp vec3 normal_3f\n#pragma mapbox: initialize-attribute highp vec3 color_3f\n#pragma mapbox: initialize-attribute highp vec4 color_4f\n#pragma mapbox: initialize-attribute highp vec2 uv_2f\n#ifdef HAS_ATTRIBUTE_a_pbr\nin lowp vec4 v_roughness_metallic_emissive_alpha;in mediump vec4 v_height_based_emission_params;\n#endif\n#ifdef HAS_TEXTURE_u_baseColorTexture\nuniform sampler2D u_baseColorTexture;uniform bool u_baseTextureIsAlpha;uniform bool u_alphaMask;uniform float u_alphaCutoff;\n#endif\n#ifdef HAS_TEXTURE_u_metallicRoughnessTexture\nuniform sampler2D u_metallicRoughnessTexture;\n#endif\n#ifdef HAS_TEXTURE_u_occlusionTexture\nuniform sampler2D u_occlusionTexture;uniform float u_aoIntensity;\n#endif\n#ifdef HAS_TEXTURE_u_normalTexture\nuniform sampler2D u_normalTexture;\n#endif\n#ifdef HAS_TEXTURE_u_emissionTexture\nuniform sampler2D u_emissionTexture;\n#endif\n#ifdef APPLY_LUT_ON_GPU\nuniform highp sampler3D u_lutTexture;\n#endif\n#ifdef TERRAIN_FRAGMENT_OCCLUSION\nin highp float v_depth;uniform highp sampler2D u_depthTexture;uniform highp vec2 u_inv_depth_size;uniform highp vec2 u_depth_range_unpack;\n#ifdef DEPTH_D24\nhighp float unpack_depth(highp float depth) {return depth*u_depth_range_unpack.x+u_depth_range_unpack.y;}\n#else\nhighp float unpack_depth_rgba(highp vec4 rgba_depth)\n{const highp vec4 bit_shift=vec4(1.0/(255.0*255.0*255.0),1.0/(255.0*255.0),1.0/255.0,1.0);return dot(rgba_depth,bit_shift)*2.0-1.0;}\n#endif\nbool isOccluded() {highp vec2 coord=gl_FragCoord.xy*u_inv_depth_size;\n#ifdef FLIP_Y\ncoord.y=1.0-coord.y;\n#endif\n#ifdef DEPTH_D24\nhighp float depth=unpack_depth(texture(u_depthTexture,coord).r);\n#else\nhighp float depth=unpack_depth_rgba(texture(u_depthTexture,coord));\n#endif\nreturn v_depth > depth+0.0005;}\n#endif\n#define saturate(_x) clamp(_x,0.,1.)\nvec3 linearTosRGB(vec3 color) {return pow(color,vec3(1./2.2));}vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}float calculate_NdotL(vec3 normal,vec3 lightDir) {const float ext=0.70710678118;return (clamp(dot(normal,lightDir),-ext,1.0)+ext)/(1.0+ext);}vec3 getDiffuseShadedColor(vec3 albedo,vec3 normal,vec3 lightDir,vec3 lightColor)\n{\n#ifdef LIGHTING_3D_MODE\nvec3 transformed_normal=vec3(-normal.xy,normal.z);float lighting_factor;\n#ifdef RENDER_SHADOWS\nlighting_factor=shadowed_light_factor_normal(transformed_normal,v_pos_light_view_0,v_pos_light_view_1,v_depth_shadows);\n#else\nlighting_factor=saturate(dot(transformed_normal,u_lighting_directional_dir));\n#endif\nreturn apply_lighting(albedo,transformed_normal,lighting_factor);\n#else\nvec3 n=normal;float colorvalue=((albedo.x*0.2126)+(albedo.y*0.7152))+(albedo.z*0.0722);vec3 c=vec3(0.03,0.03,0.03);float directional=clamp(dot(n,vec3(lightDir)),0.0,1.0);directional=mix(1.0-u_lightintensity,max((1.0-colorvalue)+u_lightintensity,1.0),directional);vec3 c3=c+clamp((albedo*directional)*lightColor,mix(vec3(0.0),vec3(0.3),vec3(1.0)-lightColor),vec3(1.0));return c3;\n#endif\n}vec4 getBaseColor() {vec4 albedo=u_baseColorFactor;\n#ifdef HAS_ATTRIBUTE_a_color_3f\nalbedo*=vec4(color_3f,1.0);\n#endif\n#ifdef HAS_ATTRIBUTE_a_pbr\n#else\n#ifdef HAS_ATTRIBUTE_a_color_4f\nalbedo*=color_4f;\n#endif\n#endif\n#if defined (HAS_TEXTURE_u_baseColorTexture) && defined (HAS_ATTRIBUTE_a_uv_2f)\nvec4 texColor=texture(u_baseColorTexture,uv_2f);if(u_alphaMask) {if (texColor.w < u_alphaCutoff) {discard;}}\n#ifdef UNPREMULT_TEXTURE_IN_SHADER\ntexColor=vec4(unpremultiplyColor(texColor),1.0);\n#endif\nif(u_baseTextureIsAlpha) {if (texColor.r < 0.5) {discard;}} else {texColor.rgb=sRGBToLinear(texColor.rgb);albedo*=texColor;}\n#endif\nvec4 color=vec4(mix(albedo.rgb,v_color_mix.rgb,v_color_mix.a),albedo.a);\n#ifdef APPLY_LUT_ON_GPU\ncolor=applyLUT(u_lutTexture,color);\n#endif\nreturn color;}highp mat3 cotangentFrame(highp vec3 N,highp vec3 p,highp vec2 uv ) {\n#ifdef HAS_TEXTURE_u_normalTexture\nhighp vec3 dp1=vec3(dFdx(p.x),dFdx(p.y),dFdx(p.z));highp vec3 dp2=vec3(dFdy(p.x),dFdy(p.y),dFdy(p.z));highp vec2 duv1=vec2(dFdx(uv.x),dFdx(uv.y));highp vec2 duv2=vec2(dFdy(uv.x),dFdy(uv.y));highp vec3 dp2perp=cross( dp2,N );highp vec3 dp1perp=cross( N,dp1 );highp vec3 T=dp2perp*duv1.x+dp1perp*duv2.x;highp vec3 B=dp2perp*duv1.y+dp1perp*duv2.y;\n#ifdef FLIP_Y\nT=-T;B=-B;\n#endif\nhighp float lengthT=dot(T,T);highp float lengthB=dot(B,B);highp float maxLength=max(lengthT,lengthB);highp float invmax=inversesqrt( maxLength );highp mat3 res=mat3( T*invmax,B*invmax,N );return res;\n#else\nreturn mat3(1.0);\n#endif\n}highp vec3 getNormal(){highp vec3 n;\n#ifdef HAS_ATTRIBUTE_a_normal_3f\nn=normalize(normal_3f);\n#else\nhighp vec3 fdx=vec3(dFdx(v_position_height.x),dFdx(v_position_height.y),dFdx(v_position_height.z));highp vec3 fdy=vec3(dFdy(v_position_height.x),dFdy(v_position_height.y),dFdy(v_position_height.z));\n#ifdef FLIP_Y\nn=normalize(cross(fdx,fdy));\n#else\nn=normalize(cross(fdx,fdy))*-1.0;\n#endif\n#endif\n#if defined(HAS_TEXTURE_u_normalTexture) && defined(HAS_ATTRIBUTE_a_uv_2f)\nvec3 nMap=texture( u_normalTexture,uv_2f).xyz;nMap=normalize(2.0*nMap-vec3(1.0));highp vec3 v=normalize(-v_position_height.xyz);highp mat3 TBN=cotangentFrame(n,v,uv_2f);n=normalize(TBN*nMap);\n#endif\nreturn n;}struct Material {float perceptualRoughness;float alphaRoughness;float metallic;vec3 f90;vec4 baseColor;vec3 diffuseColor;vec3 specularColor;highp vec3 normal;};Material getPBRMaterial() {Material mat;mat.baseColor=getBaseColor();mat.perceptualRoughness=u_roughnessFactor;mat.metallic=u_metallicFactor;\n#ifdef HAS_ATTRIBUTE_a_pbr\nmat.perceptualRoughness=v_roughness_metallic_emissive_alpha.x;mat.metallic=v_roughness_metallic_emissive_alpha.y;mat.baseColor.w*=v_roughness_metallic_emissive_alpha.w;\n#endif\n#if defined(HAS_TEXTURE_u_metallicRoughnessTexture) && defined(HAS_ATTRIBUTE_a_uv_2f)\nvec4 mrSample=texture(u_metallicRoughnessTexture,uv_2f);mat.perceptualRoughness*=mrSample.g;mat.metallic*=mrSample.b;\n#endif\nconst float c_minRoughness=0.04;mat.perceptualRoughness=clamp(mat.perceptualRoughness,c_minRoughness,1.0);mat.metallic=saturate(mat.metallic);mat.alphaRoughness=mat.perceptualRoughness*mat.perceptualRoughness;const vec3 f0=vec3(0.04);mat.diffuseColor=mat.baseColor.rgb*(vec3(1.0)-f0);mat.diffuseColor*=1.0-mat.metallic;mat.specularColor=mix(f0,mat.baseColor.rgb,mat.metallic);highp float reflectance=max(max(mat.specularColor.r,mat.specularColor.g),mat.specularColor.b);highp float reflectance90=saturate(reflectance*25.0);mat.f90=vec3(reflectance90);mat.normal=getNormal();return mat;}float V_GGX(float NdotL,float NdotV,float roughness)\n{float a2=roughness*roughness;float GGXV=NdotL*sqrt(NdotV*NdotV*(1.0-a2)+a2);float GGXL=NdotV*sqrt(NdotL*NdotL*(1.0-a2)+a2);return 0.5/(GGXV+GGXL);}float V_GGXFast(float NdotL,float NdotV,float roughness) {float a=roughness;float GGXV=NdotL*(NdotV*(1.0-a)+a);float GGXL=NdotV*(NdotL*(1.0-a)+a);return 0.5/(GGXV+GGXL);}vec3 F_Schlick(vec3 specularColor,vec3 f90,float VdotH)\n{return specularColor+(f90-specularColor)*pow(clamp(1.0-VdotH,0.0,1.0),5.0);}vec3 F_SchlickFast(vec3 specularColor,float VdotH)\n{float x=1.0-VdotH;float x4=x*x*x*x;return specularColor+(1.0-specularColor)*x4*x;}float D_GGX(highp float NdotH,float alphaRoughness)\n{highp float a4=alphaRoughness*alphaRoughness;highp float f=(NdotH*a4-NdotH)*NdotH+1.0;return a4/(PI*f*f);}vec3 diffuseBurley(Material mat,float LdotH,float NdotL,float NdotV)\n{float f90=2.0*LdotH*LdotH*mat.alphaRoughness-0.5;return (mat.diffuseColor/PI)*(1.0+f90*pow((1.0-NdotL),5.0))*(1.0+f90*pow((1.0-NdotV),5.0));}vec3 diffuseLambertian(Material mat)\n{\n#ifdef LIGHTING_3D_MODE\nreturn mat.diffuseColor;\n#else\nreturn mat.diffuseColor/PI;\n#endif\n}vec3 EnvBRDFApprox(vec3 specularColor,float roughness,highp float NdotV)\n{vec4 c0=vec4(-1,-0.0275,-0.572,0.022);vec4 c1=vec4(1,0.0425,1.04,-0.04);highp vec4 r=roughness*c0+c1;highp float a004=min(r.x*r.x,exp2(-9.28*NdotV))*r.x+r.y;vec2 AB=vec2(-1.04,1.04)*a004+r.zw;return specularColor*AB.x+AB.y;}vec3 computeIndirectLightContribution(Material mat,float NdotV,vec3 normal)\n{vec3 env_light=vec3(0.65,0.65,0.65);\n#ifdef LIGHTING_3D_MODE\nfloat ambient_factor=calculate_ambient_directional_factor(normal);env_light=u_lighting_ambient_color*ambient_factor;\n#endif\nvec3 envBRDF=EnvBRDFApprox(mat.specularColor,mat.perceptualRoughness,NdotV);vec3 indirectSpecular= envBRDF*env_light;vec3 indirectDiffuse=mat.diffuseColor*env_light;return indirectSpecular+indirectDiffuse;}vec3 computeLightContribution(Material mat,vec3 lightPosition,vec3 lightColor)\n{highp vec3 n=mat.normal;highp vec3 v=normalize(-v_position_height.xyz);highp vec3 l=normalize(lightPosition);highp vec3 h=normalize(v+l);float NdotV=clamp(abs(dot(n,v)),0.001,1.0);float NdotL=saturate(dot(n,l));highp float NdotH=saturate(dot(n,h));float VdotH=saturate(dot(v,h));vec3 f=F_SchlickFast(mat.specularColor,VdotH);float g=V_GGXFast(NdotL,NdotV,mat.alphaRoughness);float d=D_GGX(NdotH,mat.alphaRoughness);vec3 diffuseTerm=(1.0-f)*diffuseLambertian(mat);vec3 specularTerm=f*g*d;vec3 transformed_normal=vec3(-n.xy,n.z);float lighting_factor;\n#ifdef RENDER_SHADOWS\nlighting_factor=shadowed_light_factor_normal(transformed_normal,v_pos_light_view_0,v_pos_light_view_1,v_depth_shadows);\n#else\nlighting_factor=NdotL;\n#endif\nvec3 directLightColor=(specularTerm+diffuseTerm)*lighting_factor*lightColor;vec3 indirectLightColor=computeIndirectLightContribution(mat,NdotV,transformed_normal);vec3 color=(saturate(directLightColor)+indirectLightColor);float intensityFactor=1.0;\n#if !defined(LIGHTING_3D_MODE)\nconst vec3 luminosityFactor=vec3(0.2126,0.7152,0.0722);float luminance=dot(diffuseTerm,luminosityFactor);intensityFactor=mix((1.0-u_lightintensity),max((1.0-luminance+u_lightintensity),1.0),NdotL);\n#endif\ncolor*=intensityFactor;return color;}void main() {\n#ifdef TERRAIN_FRAGMENT_OCCLUSION\nif (isOccluded()) {discard;}\n#endif\nvec3 lightDir=u_lightpos;vec3 lightColor=u_lightcolor;\n#ifdef LIGHTING_3D_MODE\nlightDir=u_lighting_directional_dir;lightDir.xy=-lightDir.xy;lightColor=u_lighting_directional_color;\n#endif\nvec4 finalColor;\n#ifdef DIFFUSE_SHADED\nvec3 N=getNormal();vec3 baseColor=getBaseColor().rgb;vec3 diffuse=getDiffuseShadedColor(baseColor,N,lightDir,lightColor);\n#ifdef HAS_TEXTURE_u_occlusionTexture\nfloat ao=(texture(u_occlusionTexture,uv_2f).r-1.0)*u_aoIntensity+1.0;diffuse*=ao;\n#endif\nfinalColor=vec4(mix(diffuse,baseColor,u_emissive_strength),1.0)*u_opacity;\n#else\nMaterial mat=getPBRMaterial();vec3 color=computeLightContribution(mat,lightDir,lightColor);float ao=1.0;\n#if defined (HAS_TEXTURE_u_occlusionTexture) && defined(HAS_ATTRIBUTE_a_uv_2f)\n#ifdef OCCLUSION_TEXTURE_TRANSFORM\nvec2 uv=uv_2f.xy*u_occlusionTextureTransform.zw+u_occlusionTextureTransform.xy;\n#else\nvec2 uv=uv_2f;\n#endif\nao=(texture(u_occlusionTexture,uv).x-1.0)*u_aoIntensity+1.0;color*=ao;\n#endif\nvec4 emissive=u_emissiveFactor;\n#if defined(HAS_TEXTURE_u_emissionTexture) && defined(HAS_ATTRIBUTE_a_uv_2f)\nemissive.rgb*=sRGBToLinear(texture(u_emissionTexture,uv_2f).rgb);\n#endif\n#ifdef APPLY_LUT_ON_GPU\nfloat emissiveFactorLength=max(length(u_emissiveFactor.rgb),0.001);emissive.rgb=sRGBToLinear(applyLUT(u_lutTexture,linearTosRGB(emissive.rgb/emissiveFactorLength).rbg))*emissiveFactorLength;\n#endif\ncolor+=emissive.rgb;float opacity=mat.baseColor.w*u_opacity;\n#ifdef HAS_ATTRIBUTE_a_pbr\nfloat resEmission=v_roughness_metallic_emissive_alpha.z;resEmission*=v_height_based_emission_params.z+v_height_based_emission_params.w*pow(clamp(v_height_based_emission_params.x,0.0,1.0),v_height_based_emission_params.y);vec3 color_mix=v_color_mix.rgb;\n#ifdef APPLY_LUT_ON_GPU\ncolor_mix=applyLUT(u_lutTexture,color_mix);\n#endif\ncolor=mix(color,color_mix,min(1.0,resEmission));\n#ifdef HAS_ATTRIBUTE_a_color_4f\nfloat distance=length(vec2(1.3*max(0.0,abs(color_4f.x)-color_4f.z),color_4f.y));distance+= mix(0.5,0.0,clamp(resEmission-1.0,0.0,1.0));opacity*=v_roughness_metallic_emissive_alpha.w*saturate(1.0-distance*distance);\n#endif\n#endif\nvec3 unlitColor=mat.baseColor.rgb*ao+emissive.rgb;color=mix(color,unlitColor,u_emissive_strength);color=linearTosRGB(color);color*=opacity;finalColor=vec4(color,opacity);\n#endif\n#ifdef DITHERED_DISCARD\nif (abs(u_dithered_discard_threshold) < 1.0) {float ditherValue=fract(52.9829189*fract(0.06711056*gl_FragCoord.x+0.00583715*gl_FragCoord.y));float compareValue=mix(1.0-ditherValue,ditherValue,step(0.0,u_dithered_discard_threshold));if (abs(u_dithered_discard_threshold) < compareValue) {discard;}}\n#endif\n#ifdef FOG\nfinalColor=fog_dither(fog_apply_premultiplied(finalColor,v_fog_pos,v_position_height.w));\n#endif\n#ifdef RENDER_CUTOFF\nfinalColor*=v_cutoff_opacity;\n#endif\n#ifdef INDICATOR_CUTOUT\nfinalColor=applyCutout(finalColor,v_position_height.w);\n#endif\n#ifdef FEATURE_CUTOUT\nfinalColor=apply_feature_cutout(finalColor,gl_FragCoord,get_cutout_factors(gl_FragCoord).x);\n#endif\nglFragColor=finalColor;\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nin vec3 a_pos_3f;\n#pragma mapbox: define-attribute highp vec3 normal_3f\n#pragma mapbox: define-attribute highp vec2 uv_2f\n#pragma mapbox: define-attribute highp vec3 color_3f\n#pragma mapbox: define-attribute highp vec4 color_4f\n#pragma mapbox: define-attribute-vertex-shader-only highp uvec4 pbr\n#pragma mapbox: define-attribute-vertex-shader-only highp vec3 heightBasedEmissiveStrength\nuniform mat4 u_matrix;uniform mat4 u_node_matrix;uniform mat4 u_lighting_matrix;uniform vec3 u_camera_pos;uniform vec4 u_color_mix;\n#ifdef INSTANCED_ARRAYS\nin vec4 a_normal_matrix0;in vec4 a_normal_matrix1;in vec4 a_normal_matrix2;in vec4 a_normal_matrix3;\n#else\nuniform highp mat4 u_normal_matrix;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;out float v_depth_shadows;\n#endif\nout vec4 v_position_height;out lowp vec4 v_color_mix;\n#ifdef TERRAIN_FRAGMENT_OCCLUSION\nout highp float v_depth;\n#endif\n#ifdef HAS_ATTRIBUTE_a_pbr\nout lowp vec4 v_roughness_metallic_emissive_alpha;out mediump vec4 v_height_based_emission_params;\n#endif\nvec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}void main() {\n#pragma mapbox: initialize-attribute highp vec3 normal_3f\n#pragma mapbox: initialize-attribute highp vec2 uv_2f\n#pragma mapbox: initialize-attribute highp vec3 color_3f\n#pragma mapbox: initialize-attribute highp vec4 color_4f\n#pragma mapbox: initialize-attribute-custom highp uvec4 pbr\n#pragma mapbox: initialize-attribute-custom highp vec3 heightBasedEmissiveStrength\nhighp mat4 normal_matrix;\n#ifdef INSTANCED_ARRAYS\nnormal_matrix=mat4(a_normal_matrix0,a_normal_matrix1,a_normal_matrix2,a_normal_matrix3);\n#else\nnormal_matrix=u_normal_matrix;\n#endif\nvec3 local_pos;mat3 rs;\n#ifdef MODEL_POSITION_ON_GPU\nvec3 pos_color=normal_matrix[0].xyz;vec4 translate=normal_matrix[1];vec3 pos_a=floor(pos_color);vec3 rgb=1.05*(pos_color-pos_a);float hidden=float(pos_a.x > EXTENT);float color_mix=pos_a.z/100.0;v_color_mix=vec4(sRGBToLinear(rgb),color_mix);float meter_to_tile=normal_matrix[0].w;vec4 pos=vec4(pos_a.xy,translate.z,1.0);rs[0].x=normal_matrix[1].w;rs[0].yz=normal_matrix[2].xy;rs[1].xy=normal_matrix[2].zw;rs[1].z=normal_matrix[3].x;rs[2].xyz=normal_matrix[3].yzw;vec4 pos_node=u_lighting_matrix*vec4(a_pos_3f,1.0);vec3 rotated_pos_node=rs*pos_node.xyz;vec3 pos_model_tile=(rotated_pos_node+vec3(translate.xy,0.0))*vec3(meter_to_tile,meter_to_tile,1.0);pos.xyz+=pos_model_tile;local_pos=pos.xyz;gl_Position=mix(u_matrix*pos,AWAY,hidden);pos.z*=meter_to_tile;v_position_height.xyz=pos.xyz-u_camera_pos;\n#else\nlocal_pos=a_pos_3f;gl_Position=u_matrix*vec4(a_pos_3f,1);v_position_height.xyz=vec3(u_lighting_matrix*vec4(a_pos_3f,1));v_color_mix=vec4(sRGBToLinear(u_color_mix.rgb),u_color_mix.a);\n#endif\nv_position_height.w=a_pos_3f.z;\n#ifdef HAS_ATTRIBUTE_a_pbr\nvec4 albedo_c=decode_color(vec2(pbr.xy));vec2 e_r_m=unpack_float(float(pbr.z));vec2 r_m= unpack_float(e_r_m.y*16.0);r_m.r=r_m.r*16.0;v_color_mix=vec4(albedo_c.rgb,1.0);v_roughness_metallic_emissive_alpha=vec4(vec3(r_m,e_r_m.x)/255.0,albedo_c.a);v_roughness_metallic_emissive_alpha.z*=2.0;float heightBasedRelativeIntepolation=a_pos_3f.z*heightBasedEmissiveStrength.x+heightBasedEmissiveStrength.y;v_height_based_emission_params.x=heightBasedRelativeIntepolation;v_height_based_emission_params.y=heightBasedEmissiveStrength.z;vec2 emissionMultiplierValues=unpack_float(float(pbr.w))/256.0;v_height_based_emission_params.z=emissionMultiplierValues.x;v_height_based_emission_params.w=emissionMultiplierValues.y-emissionMultiplierValues.x;\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(local_pos);\n#endif\n#ifdef RENDER_CUTOFF\nv_cutoff_opacity=cutoff_opacity(u_cutoff_params,gl_Position.z);\n#endif\n#ifdef TERRAIN_FRAGMENT_OCCLUSION\nv_depth=gl_Position.z/gl_Position.w;\n#ifdef CLIP_ZERO_TO_ONE\nv_depth=-1.0+2.0*v_depth; \n#endif\n#endif\n#ifdef HAS_ATTRIBUTE_a_normal_3f\n#ifdef MODEL_POSITION_ON_GPU\nfloat x_squared_scale=dot(rs[0],rs[0]);float y_squared_scale=dot(rs[1],rs[1]);float z_squared_scale=dot(rs[2],rs[2]);vec3 squared_scale=vec3(x_squared_scale,y_squared_scale,z_squared_scale);normal_3f=rs*((u_lighting_matrix*vec4(normal_3f,0.0)).xyz/squared_scale);normal_3f=normalize(normal_3f);\n#else\nnormal_3f=vec3(normal_matrix*vec4(normal_3f,0));\n#endif\n#endif\n#ifdef HAS_ATTRIBUTE_a_pbr\n#ifdef HAS_ATTRIBUTE_a_color_4f\nv_roughness_metallic_emissive_alpha.w=clamp(color_4f.a*v_roughness_metallic_emissive_alpha.w*(v_roughness_metallic_emissive_alpha.z-1.0),0.0,1.0);\n#endif\n#endif\n#ifdef RENDER_SHADOWS\nvec4 shadow_pos=u_node_matrix*vec4(local_pos,1.0);\n#ifdef NORMAL_OFFSET\n#ifdef HAS_ATTRIBUTE_a_normal_3f\n#ifdef MODEL_POSITION_ON_GPU\nvec3 offset=shadow_normal_offset(vec3(-normal_3f.xy,normal_3f.z));shadow_pos.xyz+=offset*shadow_normal_offset_multiplier0();\n#else\nvec3 offset=shadow_normal_offset_model(normal_3f);shadow_pos.xyz+=offset*shadow_normal_offset_multiplier0();\n#endif\n#endif\n#endif\nv_pos_light_view_0=u_light_matrix_0*shadow_pos;v_pos_light_view_1=u_light_matrix_1*shadow_pos;v_depth_shadows=gl_Position.w;\n#endif\n}'),modelDepth:ho("void main() {}","in vec3 a_pos_3f;uniform mat4 u_matrix;\n#ifdef MODEL_POSITION_ON_GPU\n#ifdef INSTANCED_ARRAYS\nin vec4 a_normal_matrix0;in vec4 a_normal_matrix1;in vec4 a_normal_matrix2;in vec4 a_normal_matrix3;\n#else\nuniform highp mat4 u_instance;\n#endif\nuniform highp mat4 u_node_matrix;\n#endif\nvoid main() {\n#ifdef MODEL_POSITION_ON_GPU\nhighp mat4 instance;\n#ifdef INSTANCED_ARRAYS\ninstance=mat4(a_normal_matrix0,a_normal_matrix1,a_normal_matrix2,a_normal_matrix3);\n#else\ninstance=u_instance;\n#endif\nvec3 pos_color=instance[0].xyz;vec4 translate=instance[1];vec3 pos_a=floor(pos_color);float hidden=float(pos_a.x > EXTENT);float meter_to_tile=instance[0].w;vec4 pos=vec4(pos_a.xy,translate.z,1.0);mat3 rs;rs[0].x=instance[1].w;rs[0].yz=instance[2].xy;rs[1].xy=instance[2].zw;rs[1].z=instance[3].x;rs[2].xyz=instance[3].yzw;vec4 pos_node=u_node_matrix*vec4(a_pos_3f,1.0);vec3 rotated_pos_node=rs*pos_node.xyz;vec3 pos_model_tile=(rotated_pos_node+vec3(translate.xy,0.0))*vec3(meter_to_tile,meter_to_tile,1.0);pos.xyz+=pos_model_tile;gl_Position=mix(u_matrix*pos,AWAY,hidden);\n#else\ngl_Position=u_matrix*vec4(a_pos_3f,1);\n#endif\n}"),stars:ho("in highp vec2 v_uv;in mediump float v_intensity;float shapeCircle(in vec2 uv)\n{float beginFade=0.6;float lengthFromCenter=length(v_uv);return 1.0-clamp((lengthFromCenter-beginFade)/(1.0-beginFade),0.0,1.0);}void main() {float alpha=shapeCircle(v_uv);vec3 color=vec3(1.0,1.0,1.0);alpha*=v_intensity;glFragColor=vec4(color*alpha,alpha);HANDLE_WIREFRAME_DEBUG;}","\nin vec3 a_pos_3f;in vec2 a_uv;in float a_size_scale;in float a_opacity;uniform mat4 u_matrix;uniform vec3 u_up;uniform vec3 u_right;uniform float u_intensity_multiplier;out highp vec2 v_uv;out mediump float v_intensity;void main() {v_uv=a_uv;v_intensity=a_opacity*u_intensity_multiplier;vec3 pos=a_pos_3f;pos+=a_uv.x*u_right*a_size_scale;pos+=a_uv.y*u_up*a_size_scale;gl_Position=u_matrix*vec4(pos,1.0);}"),occlusion:ho("uniform vec4 u_color;void main() {glFragColor=u_color;}",'#include "_prelude_terrain.vertex.glsl"\nin highp vec2 a_offset_xy;uniform highp vec3 u_anchorPos;uniform mat4 u_matrix;uniform vec2 u_screenSizePx;uniform vec2 u_occluderSizePx;void main() {vec3 world_pos=u_anchorPos;\n#ifdef TERRAIN\nfloat e=elevation(world_pos.xy);world_pos.z+=e;\n#endif\nvec4 projected_point=u_matrix*vec4(world_pos,1.0);projected_point.xy+=projected_point.w*a_offset_xy*0.5*u_occluderSizePx/u_screenSizePx;gl_Position=projected_point;}')};function lo(e,t){const i=e.split("\n");for(let r of i){if(r=r.trimStart(),"#"!==r[0])continue;if(!r.includes("if"))continue;if(r.startsWith("#endif"))continue;const e=r.match(Yn);if(e)for(const i of e)Jn.has(i)||t.add(i)}}function co(e){return new Set(["uint","int","uvec2","ivec2","uvec3","ivec3","uvec4","ivec4"]).has(e)}function ho(e,t){const i=/* @__PURE__ */new Set,r=[],n=[];e=e.replace(Wn,(e,t)=>(n.push(t),"")),t=t.replace(Wn,(e,t)=>(r.push(t),""));let o=new Set(Kn);lo(e,o),lo(t,o);for(const s of[...r,...n])eo[s]||(eo[s]=/* @__PURE__ */new Set,lo(Qn[s],eo[s])),o=new Set([...o,...eo[s]]);return{fragmentSource:e=e.replace(Xn,(e,t,r,n,o)=>(i.add(o),"define"===t?`\n#ifndef HAS_UNIFORM_u_${o}\n${co(n)?"flat ":""}in ${r} ${n} ${o};\n#else\nuniform ${r} ${n} u_${o};\n#endif\n`:"initialize"===t?`\n#ifdef HAS_UNIFORM_u_${o}\n ${r} ${n} ${o} = u_${o};\n#endif\n`:"define-attribute"===t?`\n#ifdef HAS_ATTRIBUTE_a_${o}\n in ${r} ${n} ${o};\n#endif\n`:"initialize-attribute"===t?"":void 0)),vertexSource:t=t.replace(Xn,(e,t,r,n,o)=>{const s=`MATERIAL_ATTRIBUTE_OFFSET_${o}`,a="float"===n?"vec2":n,l=`GET_ATTRIBUTE_${a}(a_${o}, materialInfo, ${s})`,c=o.includes("color")?"color":a;return"define-attribute-vertex-shader-only"===t?`\n#ifdef HAS_ATTRIBUTE_a_${o}\nin ${r} ${n} a_${o};\n#endif\n`:i.has(o)?"define"===t?`\n#ifndef HAS_UNIFORM_u_${o}\nuniform lowp float u_${o}_t;\n #if !defined(${s})\n in ${r} ${a} a_${o};\n #endif\n${co(n)?"flat ":""}out ${r} ${n} ${o};\n#else\nuniform ${r} ${n} u_${o};\n#endif\n`:"initialize"===t?"vec4"===c||"uvec4"===c?`\n#ifndef HAS_UNIFORM_u_${o}\n ${o} = a_${o};\n#else\n ${r} ${n} ${o} = u_${o};\n#endif\n`:`\n#if !defined(HAS_UNIFORM_u_${o})\n #ifdef ${s}\n ${o} = unpack_mix_${c}(${l}, u_${o}_t);\n #else\n ${o} = unpack_mix_${c}(a_${o}, u_${o}_t);\n #endif\n#else\n ${r} ${n} ${o} = u_${o};\n#endif\n`:"define-attribute"===t?`\n#ifdef HAS_ATTRIBUTE_a_${o}\n in ${r} ${n} a_${o};\n out ${r} ${n} ${o};\n#endif\n`:"initialize-attribute"===t?`\n#ifdef HAS_ATTRIBUTE_a_${o}\n ${o} = a_${o};\n#endif\n`:void 0:"define"===t?`\n#ifndef HAS_UNIFORM_u_${o}\nuniform lowp float u_${o}_t;\n #if !defined(${s})\n in ${r} ${a} a_${o};\n #endif\n#else\nuniform ${r} ${n} u_${o};\n#endif\n`:"define-instanced"===t?"mat4"===c?`\n#ifdef INSTANCED_ARRAYS\nin vec4 a_${o}0;\nin vec4 a_${o}1;\nin vec4 a_${o}2;\nin vec4 a_${o}3;\n#else\nuniform ${r} ${n} u_${o};\n#endif\n`:`\n#ifdef INSTANCED_ARRAYS\nin ${r} ${a} a_${o};\n#else\nuniform ${r} ${n} u_${o};\n#endif\n`:"initialize-attribute-custom"===t?`\n#ifdef HAS_ATTRIBUTE_a_${o}\n ${r} ${n} ${o} = a_${o};\n#endif\n`:"vec4"===c||"uvec4"===c?`\n#ifndef HAS_UNIFORM_u_${o}\n #ifdef ${s}\n ${r} ${n} ${o} = ${l};\n #else\n ${r} ${n} ${o} = a_${o};\n #endif\n#else\n ${r} ${n} ${o} = u_${o};\n#endif\n`:`\n#ifndef HAS_UNIFORM_u_${o}\n #ifdef ${s}\n ${r} ${n} ${o} = unpack_mix_${c}(${l}, u_${o}_t);\n #else\n ${r} ${n} ${o} = unpack_mix_${c}(a_${o}, u_${o}_t);\n #endif\n#else\n ${r} ${n} ${o} = u_${o};\n#endif\n`}),usedDefines:o,vertexIncludes:r,fragmentIncludes:n}}class uo{constructor(){this.boundProgram=null,this.boundLayoutVertexBuffer=null,this.boundPaintVertexBuffers=[],this.boundIndexBuffer=null,this.boundVertexOffset=null,this.boundDynamicVertexBuffers=[],this.vao=null}bind(e,t,i,r,n,o,s,a){this.context=e;let l=this.boundPaintVertexBuffers.length!==r.length;for(let h=0;!l&&h<r.length;h++)this.boundPaintVertexBuffers[h]!==r[h]&&(l=!0);let c=this.boundDynamicVertexBuffers.length!==s.length;for(let h=0;!c&&h<s.length;h++)this.boundDynamicVertexBuffers[h]!==s[h]&&(c=!0);if(!this.vao||this.boundProgram!==t||this.boundLayoutVertexBuffer!==i||l||c||this.boundIndexBuffer!==n||this.boundVertexOffset!==o)this.freshBind(t,i,r,n,o,s,a);else{e.bindVertexArrayOES.set(this.vao);for(const i of s)i&&(i.bind(),a&&i.instanceCount&&i.setVertexAttribDivisor(e.gl,t,a));n&&n.dynamicDraw&&n.bind()}}freshBind(e,t,i,r,n,o,s){const a=this.context,l=a.gl;this.vao&&this.destroy(),this.vao=a.gl.createVertexArray(),a.bindVertexArrayOES.set(this.vao),this.boundProgram=e,this.boundLayoutVertexBuffer=t,this.boundPaintVertexBuffers=i,this.boundIndexBuffer=r,this.boundVertexOffset=n,this.boundDynamicVertexBuffers=o,t.enableAttributes(l,e),t.bind(),t.setVertexAttribPointers(l,e,n);for(const c of i)c.enableAttributes(l,e),c.bind(),c.setVertexAttribPointers(l,e,n);for(const c of o)c&&(c.enableAttributes(l,e),c.bind(),c.setVertexAttribPointers(l,e,n),s&&c.instanceCount&&c.setVertexAttribDivisor(l,e,s));r&&r.bind()}destroy(){this.vao&&(this.context.gl.deleteVertexArray(this.vao),this.vao=null)}}function po(t,i){const r=Math.pow(2,i.canonical.z),n=i.canonical.y;return[new e.ad(0,n/r).toLngLat().lat,new e.ad(0,(n+1)/r).toLngLat().lat]}function fo(t,i,r,n,o,s,a){const l=t.context,c=l.gl,h=r.hillshadeFBO;if(!h)return;t.prepareDrawTile();const u=t.isTileAffectedByFog(i),d=[];t.terrain&&t.terrain.renderingToTexture&&"mrt-fallback"===t.emissiveMode&&d.push("USE_MRT1");const p=t.getOrCreateProgram("hillshade",{overrideFog:u,defines:d});l.activeTexture.set(c.TEXTURE0),c.bindTexture(c.TEXTURE_2D,h.colorAttachment0.get());const f=((t,i,r,n)=>{const o=r.paint.get("hillshade-shadow-color"),s="none"===r.paint.get("hillshade-shadow-color-use-theme").constantOr("default"),a=r.paint.get("hillshade-highlight-color"),l="none"===r.paint.get("hillshade-highlight-color-use-theme").constantOr("default"),c=r.paint.get("hillshade-accent-color"),h="none"===r.paint.get("hillshade-accent-color-use-theme").constantOr("default"),u=r.paint.get("hillshade-emissive-strength");let d=e.am(r.paint.get("hillshade-illumination-direction"));if("viewport"===r.paint.get("hillshade-illumination-anchor"))d-=t.transform.angle;else if(t.style&&t.style.enable3dLights()&&t.style.directionalLight){const i=t.style.directionalLight.properties.get("direction"),r=e.cT(i.x,i.y,i.z);d=e.am(r[1])}const p=!t.options.moving;return{u_matrix:n||t.transform.calculateProjMatrix(i.tileID.toUnwrapped(),p),u_image:0,u_latrange:po(0,i.tileID),u_light:[r.paint.get("hillshade-exaggeration"),d],u_shadow:o.toPremultipliedRenderColor(s?null:r.lut),u_highlight:a.toPremultipliedRenderColor(l?null:r.lut),u_emissive_strength:u,u_accent:c.toPremultipliedRenderColor(h?null:r.lut)}})(t,r,n,t.terrain?i.projMatrix:null);t.uploadCommonUniforms(l,p,i.toUnwrapped());const{tileBoundsBuffer:m,tileBoundsIndexBuffer:_,tileBoundsSegments:g}=t.getTileBoundsBuffers(r);p.draw(t,c.TRIANGLES,o,s,a,Yr.disabled,f,n.id,m,_,g)}function mo(t,i,r){if(!i.needsDEMTextureUpload)return;const n=t.context,o=n.gl;n.pixelStoreUnpackPremultiplyAlpha.set(!1),i.demTexture=i.demTexture||t.getTileTexture(r.stride);const s=r.getPixels();i.demTexture?i.demTexture.update(s,{premultiply:!1}):i.demTexture=new e.T(n,s,o.R32F,{premultiply:!1}),i.needsDEMTextureUpload=!1}function _o(t,i,r){const n=t.context,o=n.gl;if(!i.dem)return;const s=i.dem;if(n.activeTexture.set(o.TEXTURE1),mo(t,i,s),!i.demTexture)return;i.demTexture.bind(o.NEAREST,o.CLAMP_TO_EDGE);const a=s.dim;n.activeTexture.set(o.TEXTURE0);let l=i.hillshadeFBO;if(!l){const t=new e.T(n,{width:a,height:a,data:null},o.RGBA8);t.bind(o.LINEAR,o.CLAMP_TO_EDGE),l=i.hillshadeFBO=n.createFramebuffer(a,a,1,"renderbuffer"),l.colorAttachment0.set(t.texture)}n.bindFramebuffer.set(l.framebuffer),n.viewport.set([0,0,a,a]);const{tileBoundsBuffer:c,tileBoundsIndexBuffer:h,tileBoundsSegments:u}=t.getMercatorTileBoundsBuffers(),d=[];t.linearFloatFilteringSupported()&&d.push("TERRAIN_DEM_FLOAT_FORMAT"),t.terrain&&t.terrain.renderingToTexture&&"mrt-fallback"===t.emissiveMode&&d.push("USE_MRT1"),t.getOrCreateProgram("hillshadePrepare",{defines:d}).draw(t,o.TRIANGLES,$r.disabled,Zr.disabled,Hr.unblended,Yr.disabled,((t,i)=>{const r=i.stride,n=e.bd();return e.bX(n,0,e.ak,-e.ak,0,0,1),e.bB(n,n,[0,-e.ak,0]),{u_matrix:n,u_image:1,u_dimension:[r,r],u_zoom:t.overscaledZ}})(i.tileID,s),r.id,c,h,u),i.needsHillshadePrepare=!1}class go{constructor(e){this.gl=e.gl,this.default=this.getDefault(),this.current=this.default,this.dirty=!1}get(){return this.current}set(e){}getDefault(){return this.default}setDefault(){this.set(this.default)}}class yo extends go{getDefault(){return e.C.transparent.toNonPremultipliedRenderColor(null)}set(e){const t=this.current;(e.r!==t.r||e.g!==t.g||e.b!==t.b||e.a!==t.a||this.dirty)&&(this.gl.clearColor(e.r,e.g,e.b,e.a),this.current=e,this.dirty=!1)}}class xo extends go{getDefault(){return 1}set(e){(e!==this.current||this.dirty)&&(this.gl.clearDepth(e),this.current=e,this.dirty=!1)}}class vo extends go{getDefault(){return 0}set(e){(e!==this.current||this.dirty)&&(this.gl.clearStencil(e),this.current=e,this.dirty=!1)}}class bo extends go{getDefault(){return[!0,!0,!0,!0]}set(e){const t=this.current;(e[0]!==t[0]||e[1]!==t[1]||e[2]!==t[2]||e[3]!==t[3]||this.dirty)&&(this.gl.colorMask(e[0],e[1],e[2],e[3]),this.current=e,this.dirty=!1)}}class wo extends go{getDefault(){return!0}set(e){(e!==this.current||this.dirty)&&(this.gl.depthMask(e),this.current=e,this.dirty=!1)}}class To extends go{getDefault(){return 255}set(e){(e!==this.current||this.dirty)&&(this.gl.stencilMask(e),this.current=e,this.dirty=!1)}}class So extends go{getDefault(){return{func:this.gl.ALWAYS,ref:0,mask:255}}set(e){const t=this.current;(e.func!==t.func||e.ref!==t.ref||e.mask!==t.mask||this.dirty)&&(this.gl.stencilFunc(e.func,e.ref,e.mask),this.current=e,this.dirty=!1)}}class Io extends go{getDefault(){const e=this.gl;return[e.KEEP,e.KEEP,e.KEEP]}set(e){const t=this.current;(e[0]!==t[0]||e[1]!==t[1]||e[2]!==t[2]||this.dirty)&&(this.gl.stencilOp(e[0],e[1],e[2]),this.current=e,this.dirty=!1)}}class Eo extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;e?t.enable(t.STENCIL_TEST):t.disable(t.STENCIL_TEST),this.current=e,this.dirty=!1}}class Ao extends go{getDefault(){return[0,1]}set(e){const t=this.current;(e[0]!==t[0]||e[1]!==t[1]||this.dirty)&&(this.gl.depthRange(e[0],e[1]),this.current=e,this.dirty=!1)}}class Mo extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;e?t.enable(t.DEPTH_TEST):t.disable(t.DEPTH_TEST),this.current=e,this.dirty=!1}}class Co extends go{getDefault(){return this.gl.LESS}set(e){(e!==this.current||this.dirty)&&(this.gl.depthFunc(e),this.current=e,this.dirty=!1)}}class Po extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;e?t.enable(t.BLEND):t.disable(t.BLEND),this.current=e,this.dirty=!1}}class Do extends go{getDefault(){const e=this.gl;return[e.ONE,e.ZERO,e.ONE,e.ZERO]}set(e){const t=this.current;(e[0]!==t[0]||e[1]!==t[1]||e[2]!==t[2]||e[3]!==t[3]||this.dirty)&&(this.gl.blendFuncSeparate(e[0],e[1],e[2],e[3]),this.current=e,this.dirty=!1)}}class Ro extends go{getDefault(){return e.C.transparent.toNonPremultipliedRenderColor(null)}set(e){const t=this.current;(e.r!==t.r||e.g!==t.g||e.b!==t.b||e.a!==t.a||this.dirty)&&(this.gl.blendColor(e.r,e.g,e.b,e.a),this.current=e,this.dirty=!1)}}class zo extends go{getDefault(){return this.gl.FUNC_ADD}set(e){(e!==this.current||this.dirty)&&(this.gl.blendEquationSeparate(e,e),this.current=e,this.dirty=!1)}}class Lo extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;e?t.enable(t.CULL_FACE):t.disable(t.CULL_FACE),this.current=e,this.dirty=!1}}class Fo extends go{getDefault(){return this.gl.BACK}set(e){(e!==this.current||this.dirty)&&(this.gl.cullFace(e),this.current=e,this.dirty=!1)}}class Oo extends go{getDefault(){return this.gl.CCW}set(e){(e!==this.current||this.dirty)&&(this.gl.frontFace(e),this.current=e,this.dirty=!1)}}let Bo=class extends go{getDefault(){return null}set(e){(e!==this.current||this.dirty)&&(this.gl.useProgram(e),this.current=e,this.dirty=!1)}};class ko extends go{getDefault(){return this.gl.TEXTURE0}set(e){(e!==this.current||this.dirty)&&(this.gl.activeTexture(e),this.current=e,this.dirty=!1)}}class No extends go{getDefault(){const e=this.gl;return[0,0,e.drawingBufferWidth,e.drawingBufferHeight]}set(e){const t=this.current;(e[0]!==t[0]||e[1]!==t[1]||e[2]!==t[2]||e[3]!==t[3]||this.dirty)&&(this.gl.viewport(e[0],e[1],e[2],e[3]),this.current=e,this.dirty=!1)}}class Uo extends go{getDefault(){return null}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.bindFramebuffer(t.FRAMEBUFFER,e),this.current=e,this.dirty=!1}}class Vo extends go{getDefault(){return null}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.bindRenderbuffer(t.RENDERBUFFER,e),this.current=e,this.dirty=!1}}class jo extends go{getDefault(){return null}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.bindTexture(t.TEXTURE_2D,e),this.current=e,this.dirty=!1}}class Go extends go{getDefault(){return null}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.bindBuffer(t.ARRAY_BUFFER,e),this.current=e,this.dirty=!1}}class Ho extends go{getDefault(){return null}set(e){const t=this.gl;t.bindBuffer(t.ELEMENT_ARRAY_BUFFER,e),this.current=e,this.dirty=!1}}class $o extends go{getDefault(){return null}set(e){this.gl&&(e!==this.current||this.dirty)&&(this.gl.bindVertexArray(e),this.current=e,this.dirty=!1)}}class qo extends go{getDefault(){return 4}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.pixelStorei(t.UNPACK_ALIGNMENT,e),this.current=e,this.dirty=!1}}class Zo extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.pixelStorei(t.UNPACK_PREMULTIPLY_ALPHA_WEBGL,e),this.current=e,this.dirty=!1}}class Wo extends go{getDefault(){return!1}set(e){if(e===this.current&&!this.dirty)return;const t=this.gl;t.pixelStorei(t.UNPACK_FLIP_Y_WEBGL,e),this.current=e,this.dirty=!1}}class Xo extends go{constructor(e,t){super(e),this.context=e,this.parent=t}getDefault(){return null}}class Yo extends Xo{constructor(e,t,i=0){super(e,t),this.attachmentPoint=e.gl.COLOR_ATTACHMENT0+i}setDirty(){this.dirty=!0}set(e){if(e===this.current&&!this.dirty)return;this.context.bindFramebuffer.set(this.parent);const t=this.gl;t.framebufferTexture2D(t.FRAMEBUFFER,this.attachmentPoint,t.TEXTURE_2D,e,0),this.current=e,this.dirty=!1}}class Jo extends Xo{attachment(){return this.gl.DEPTH_ATTACHMENT}set(e){if(e===this.current&&!this.dirty)return;this.context.bindFramebuffer.set(this.parent);const t=this.gl;t.framebufferRenderbuffer(t.FRAMEBUFFER,this.attachment(),t.RENDERBUFFER,e),this.current=e,this.dirty=!1}}class Ko extends Xo{attachment(){return this.gl.DEPTH_ATTACHMENT}set(e){if(e===this.current&&!this.dirty)return;this.context.bindFramebuffer.set(this.parent);const t=this.gl;t.framebufferTexture2D(t.FRAMEBUFFER,this.attachment(),t.TEXTURE_2D,e,0),this.current=e,this.dirty=!1}}class Qo extends Jo{attachment(){return this.gl.DEPTH_STENCIL_ATTACHMENT}}const es=(e,t,i,r)=>({u_matrix:e,u_image0:0,u_image1:1,u_skirt_height:t,u_ground_shadow_factor:i,u_emissive_texture_available:r}),ts=(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_)=>({u_proj_matrix:Float32Array.from(e),u_globe_matrix:t,u_normalize_matrix:Float32Array.from(r),u_merc_matrix:i,u_zoom_transition:n,u_merc_center:o,u_image0:0,u_image1:1,u_frustum_tl:s,u_frustum_tr:a,u_frustum_br:l,u_frustum_bl:c,u_globe_pos:h,u_globe_radius:u,u_viewport:d,u_grid_matrix:_?Float32Array.from(_):new Float32Array(9),u_skirt_height:p,u_far_z_cutoff:f,u_emissive_texture_available:m});function is(e,t){return null!=e&&null!=t&&!(!e.hasData()||!t.hasData())&&null!=e.demTexture&&null!=t.demTexture&&e.tileID.key!==t.tileID.key}const rs=new class{constructor(){this.operations={}}newMorphing(e,t,i,r,n){if(e in this.operations){const t=this.operations[e];t.to.tileID.key!==i.tileID.key&&(t.queued=i)}else this.operations[e]={startTime:r,phase:0,duration:n,from:t,to:i,queued:null}}getMorphValuesForProxy(e){if(!(e in this.operations))return null;const t=this.operations[e];return{from:t.from,to:t.to,phase:t.phase}}update(e){for(const t in this.operations){const i=this.operations[t];for(i.phase=(e-i.startTime)/i.duration;i.phase>=1||!this._validOp(i);)if(!this._nextOp(i,e)){delete this.operations[t];break}}}_nextOp(e,t){return!!e.queued&&(e.from=e.to,e.to=e.queued,e.queued=null,e.phase=0,e.startTime=t,!0)}_validOp(e){return e.from.hasData()&&e.to.hasData()}};function ns(e,t,i){if(0===t)return 0;const r=t<1&&514===i?.25/t:1;return 6*Math.pow(1.5,22-e)*Math.max(t,1)*r}function os(e,t){const i=1<<e.z;return!t&&(0===e.x||e.x===i-1)||0===e.y||e.y===i-1}function ss(e,t){if(!e.style||!e.style.enable3dLights())return;const i=e.context,r=i.gl;i.activeTexture.set(r.TEXTURE1),t?t.bind(r.LINEAR,r.CLAMP_TO_EDGE):e.emptyTexture.bind(r.LINEAR,r.CLAMP_TO_EDGE)}const as=e=>({u_matrix:e});function ls(t,i,r,n,o){if(o>0){const s=e.o.now(),a=(s-t.timeAdded)/o,l=i?(s-i.timeAdded)/o:-1,c=r.getSource(),h=n.coveringZoomLevel({tileSize:c.tileSize,roundZoom:c.roundZoom}),u=!i||Math.abs(i.tileID.overscaledZ-h)>Math.abs(t.tileID.overscaledZ-h),d=u&&t.refreshedUponExpiration?1:e.aB(u?a:1-l,0,1);return i?{opacity:1,mix:1-d,isFading:a<1}:{opacity:d,mix:0,isFading:a<1}}return{opacity:1,mix:0,isFading:!1}}class cs extends Ri{constructor(e){const t=wi("mock-dem",{type:"raster-dem",maxzoom:Math.ceil(e.transform.maxZoom)},e.style.dispatcher,e.style);super("mock-dem",t,null),t.setEventedParent(this),this._sourceLoaded=!0}_loadTile(e,t){e.state="loaded",t(null)}}class hs extends Ri{constructor(e){const t=wi("proxy",{type:"geojson",maxzoom:Math.ceil(e.transform.maxZoom)},e.style.dispatcher,e.style);super("proxy",t,null),t.setEventedParent(this),this.map=this.getSource().map=e,this.used=this._sourceLoaded=!0,this.renderCache=[],this.renderCachePool=[],this.proxyCachedFBO={}}update(t,i,r){if(t.freezeTileCoverage)return;this.transform=t;const n=t.coveringTiles({tileSize:this._source.tileSize,minzoom:this._source.minzoom,maxzoom:this._source.maxzoom,roundZoom:this._source.roundZoom,reparseOverscaled:this._source.reparseOverscaled}).reduce((i,r)=>{if(i[r.key]="",!this._tiles[r.key]){const i=new e.b3(r,this._source.tileSize*r.overscaleFactor(),t.tileZoom,void 0,void 0,this._source.worldview);i.state="loaded",this._tiles[r.key]=i}return i},{});for(const e in this._tiles)e in n||(this.freeFBO(e),this._tiles[e].unloadVectorData(),delete this._tiles[e])}freeFBO(e){const t=this.proxyCachedFBO[e];if(void 0!==t){const i=Object.values(t);this.renderCachePool.push(...i),delete this.proxyCachedFBO[e]}}deallocRenderCache(){this.renderCache.forEach(e=>e.fb.destroy()),this.renderCache=[],this.renderCachePool=[],this.proxyCachedFBO={}}}class us extends e.aU{constructor(e,t,i){super(e.overscaledZ,e.wrap,e.canonical.z,e.canonical.x,e.canonical.y),this.proxyTileKey=t,this.projMatrix=i}}class ds extends e.bx{constructor(t,i){super(),this.painter=t,this.terrainTileForTile={},this.prevTerrainTileForTile={};const[r,n,o]=function(){const t=new e.dE,i=new e.dF,r=131;t.reserve(17161),i.reserve(33800);const n=e.ak/128,o=e.ak+n/2,s=o+n;for(let l=-n;l<s;l+=n)for(let i=-n;i<s;i+=n){const r=i<0||i>o||l<0||l>o?24575:0,n=e.aB(Math.round(i),0,e.ak),s=e.aB(Math.round(l),0,e.ak);t.emplaceBack(n+r,s)}const a=(e,t)=>{const n=t*r+e;i.emplaceBack(n+1,n,n+r),i.emplaceBack(n+r,n+r+1,n+1)};for(let e=1;e<129;e++)for(let t=1;t<129;t++)a(t,e);return[0,129].forEach(e=>{for(let t=0;t<130;t++)a(t,e),a(e,t)}),[t,i,32768]}(),s=t.context;this.gridBuffer=s.createVertexBuffer(r,e.dA.members),this.gridIndexBuffer=s.createIndexBuffer(n),this.gridSegments=e.dB.simpleSegment(0,0,r.length,n.length),this.gridNoSkirtSegments=e.dB.simpleSegment(0,0,r.length,o),this.proxyCoords=[],this.proxiedCoords={},this._visibleDemTiles=[],this._drapedRenderBatches=[],this._sourceTilesOverlap={},this.proxySourceCache=new hs(i.map),this.orthoMatrix=e.bd(),e.bX(this.orthoMatrix,"globe"===this.painter.transform.projection.name?.015:0,e.ak,0,e.ak,0,1);const a=s.gl;this._overlapStencilMode=new Zr({func:a.GEQUAL,mask:255},0,255,a.KEEP,a.KEEP,a.REPLACE),this._previousZoom=t.transform.zoom,this.pool=[],this._findCoveringTileCache={},this._tilesDirty={},this.style=i,this._useVertexMorphing=!0,this._exaggeration=1,this._mockSourceCache=new cs(i.map),this._pendingGroundEffectLayers=[],this._emissiveTexture=!1,this._devtoolsFolder=null}set style(e){e.on("data",this._onStyleDataEvent.bind(this)),this._style=e,this._style.map.on("moveend",()=>{this._clearLineLayersFromRenderCache()})}update(t,i,r){if(t&&t.terrain){this._style!==t&&(this.style=t,this._evaluationZoom=void 0);const n=t.terrain.properties,o=0===t.terrain.drapeRenderMode,s=t.terrain.isZoomDependent();this._previousUpdateTimestamp=this.enabled?this._updateTimestamp:void 0,this._updateTimestamp=e.o.now();const a=t.terrain&&t.terrain.scope,l=n.get("source"),c=o?this._mockSourceCache:t.getSourceCache(l,a);if(!c)return void e.w(`Couldn't find terrain source "${l}".`);if(this.sourceCache=c,this._attenuationRange=t.terrain.getAttenuationRange(),this._exaggeration=s?this.calculateExaggeration(i):n.get("exaggeration"),!i.projection.requiresDraping&&s&&0===this._exaggeration)return void this._disable();this.enabled=!0;const h=()=>{this.sourceCache.used&&e.w(`Raster DEM source '${this.sourceCache.id}' is used both for terrain and as layer source.\nThis leads to lower resolution of hillshade. For full hillshade resolution but higher memory consumption, define another raster DEM source.`);const t=this.getScaledDemTileSize();this.sourceCache.update(i,t,!0),this.resetTileLookupCache(this.sourceCache.id)};this.sourceCache.usedForTerrain||(this.resetTileLookupCache(this.sourceCache.id),this.sourceCache.usedForTerrain=!0,h(),this._initializing=!0),h(),i.updateElevation(!0,r),this.resetTileLookupCache(this.proxySourceCache.id),this.proxySourceCache.update(i),this._emptyDEMTextureDirty=!0,this._previousZoom=i.zoom}else this._disable()}calculateExaggeration(t){if(this._attenuationRange&&t.zoom>=Math.ceil(this._attenuationRange[1]))return this._style.terrain.getExaggeration(t.zoom);const i=this._previousCameraAltitude,r=t.getFreeCameraOptions().position.z/t.pixelsPerMeter*t.worldSize;this._previousCameraAltitude=r;const n=null!=i?r-i:Number.MAX_VALUE;if(Math.abs(n)<2)return this._exaggeration;const o=t.zoom,s=this._style.terrain;if(!this._previousUpdateTimestamp)return s.getExaggeration(o);let a=o-this._previousZoom;const l=this._previousUpdateTimestamp;let c=o;null!=this._evaluationZoom&&(c=this._evaluationZoom,Math.abs(o-c)>.5&&(a=.5*(o-c+a)),a*n<0&&(c+=a)),this._evaluationZoom=c;const h=s.getExaggeration(c),u=h===s.getExaggeration(Math.max(0,c-.1));if(u&&Math.abs(h-this._exaggeration)<.01)return h;let d=Math.min(.1,.00375*(this._updateTimestamp-l));return(u||h<.1||Math.abs(a)<1e-4)&&(d=Math.min(.2,4*d)),e.aj(this._exaggeration,h,d)}resetTileLookupCache(e){this._findCoveringTileCache[e]={}}attenuationRange(){return this._attenuationRange}getDemUpscale(){return this.proxySourceCache.getSource().tileSize/128}getScaledDemTileSize(){return this.sourceCache.getSource().tileSize/128*this.proxySourceCache.getSource().tileSize}_onStyleDataEvent(e){"source"===e.dataType&&e.coord?this._clearRenderCacheForTile(e.sourceCacheId,e.coord):"style"===e.dataType&&(this.invalidateRenderCache=!0,this._evaluationZoom=void 0,this._previousUpdateTimestamp=void 0,this._previousCameraAltitude=void 0)}_disable(){if(this.enabled&&(this.enabled=!1,this._emptyDEMTextureDirty=!0,this._sharedDepthStencil=void 0,this._evaluationZoom=void 0,this._previousUpdateTimestamp=void 0,this.proxySourceCache.deallocRenderCache(),this._style))for(const e in this._style._mergedSourceCaches)this._style._mergedSourceCaches[e].usedForTerrain=!1}destroy(){this._disable(),this._emptyDEMTexture&&this._emptyDEMTexture.destroy(),this.pool.forEach(e=>e.fb.destroy()),this.pool=[],this.framebufferCopyTexture&&this.framebufferCopyTexture.destroy()}_source(){return this.enabled?this.sourceCache:null}isUsingMockSource(){return this.sourceCache===this._mockSourceCache}exaggeration(){return this.enabled?this._exaggeration:0}get visibleDemTiles(){return this._visibleDemTiles}get drapeBufferSize(){const e=2*this.proxySourceCache.getSource().tileSize;return[e,e]}set useVertexMorphing(e){this._useVertexMorphing=e}updateTileBinding(t){if(!this.enabled)return;this.prevTerrainTileForTile=this.terrainTileForTile;const i=this.proxySourceCache,r=this.painter.transform;this._initializing&&(this._initializing=0===r._centerAltitude&&-1===this.getAtPointOrZero(e.ad.fromLngLat(r.center),-1),this._emptyDEMTextureDirty=!this._initializing);const n=this.proxyCoords=i.getIds().map(e=>{const t=i.getTileByID(e).tileID;return t.projMatrix=r.calculateProjMatrix(t.toUnwrapped()),t});!function(t,i){const r=i.transform.pointCoordinate(i.transform.getCameraPoint()),n=new e.P(r.x,r.y);t.sort((t,i)=>{if(i.overscaledZ-t.overscaledZ)return i.overscaledZ-t.overscaledZ;const r=new e.P(t.canonical.x+(1<<t.canonical.z)*t.wrap,t.canonical.y),o=new e.P(i.canonical.x+(1<<i.canonical.z)*i.wrap,i.canonical.y),s=n.mult(1<<t.canonical.z);return s.x-=.5,s.y-=.5,s.distSqr(r)-s.distSqr(o)})}(n,this.painter);const o=this.proxyToSource||{};this.proxyToSource={},n.forEach(e=>{this.proxyToSource[e.key]={}}),this.terrainTileForTile={};const s=this._style._mergedSourceCaches;for(const e in s){const i=s[e];if(!i.used)continue;if(i!==this.sourceCache&&this.resetTileLookupCache(i.id),this._setupProxiedCoordsForOrtho(i,t[e],o),i.usedForTerrain)continue;const r=t[e];(i.getSource().reparseOverscaled||i._isRasterElevatedOverTerrain)&&this._assignTerrainTiles(r)}this.proxiedCoords[i.id]=n.map(e=>new us(e,e.key,this.orthoMatrix)),this._assignTerrainTiles(n),this._prepareDEMTextures(),this._setupDrapedRenderBatches(),this._initFBOPool(),this._setupRenderCache(o),this.renderingToTexture=!1;const a={};this._visibleDemTiles=[];for(const e of this.proxyCoords){const t=this.terrainTileForTile[e.key];if(!t)continue;const i=t.tileID.key;i in a||(this._visibleDemTiles.push(t),a[i]=i)}}_assignTerrainTiles(e){this._initializing||e.forEach(e=>{if(this.terrainTileForTile[e.key])return;const t=this._findTileCoveringTileID(e,this.sourceCache);t&&(this.terrainTileForTile[e.key]=t)})}_prepareDEMTextures(){const e=this.painter.context,t=e.gl;for(const i in this.terrainTileForTile){const r=this.terrainTileForTile[i],n=r.dem;!n||r.demTexture&&!r.needsDEMTextureUpload||(e.activeTexture.set(t.TEXTURE1),mo(this.painter,r,n))}}_prepareDemTileUniforms(e,t,i,r){if(!t||null==t.demTexture)return!1;const n=e.tileID.canonical,o=Math.pow(2,t.tileID.canonical.z-n.z),s=r||"";return i[`u_dem_tl${s}`]=[n.x*o%1,n.y*o%1],i[`u_dem_scale${s}`]=o,!0}get emptyDEMTexture(){return!this._emptyDEMTextureDirty&&this._emptyDEMTexture?this._emptyDEMTexture:this._updateEmptyDEMTexture()}_getLoadedAreaMinimum(){if(!this.enabled)return 0;let e=0;const t=this._visibleDemTiles.reduce((t,i)=>{if(!i.dem)return t;const r=i.dem.tree.minimums[0];return r>0&&e++,t+r},0);return e?t/e:0}_updateEmptyDEMTexture(){const t=this.painter.context,i=t.gl;t.activeTexture.set(i.TEXTURE2);const r=this._getLoadedAreaMinimum(),n=new e.dC({width:1,height:1},new Float32Array([r]));this._emptyDEMTextureDirty=!1;let o=this._emptyDEMTexture;return o?o.update(n,{premultiply:!1}):o=this._emptyDEMTexture=new e.T(t,n,i.R32F,{premultiply:!1}),o}setupElevationDraw(t,i,r){const n=this.painter.context,o=n.gl,s={u_dem:2,u_dem_prev:4,u_dem_tl:[0,0],u_dem_tl_prev:[0,0],u_dem_scale:0,u_dem_scale_prev:0,u_dem_size:0,u_dem_lerp:1,u_depth:3,u_depth_size_inv:[0,0],u_depth_range_unpack:[0,1],u_occluder_half_size:16,u_occlusion_depth_offset:-1e-4,u_exaggeration:0};s.u_exaggeration=this.exaggeration();let a=null,l=null,c=1;if(r&&r.morphing&&this._useVertexMorphing){const e=r.morphing.srcDemTile,i=r.morphing.dstDemTile;c=r.morphing.phase,e&&i&&(this._prepareDemTileUniforms(t,e,s,"_prev")&&(l=e),this._prepareDemTileUniforms(t,i,s)&&(a=i))}const h=e=>e&&e.demTexture&&this.painter.linearFloatFilteringSupported()?o.LINEAR:o.NEAREST;let u=null;var d;if(this.enabled?l&&a?(u=a.demTexture,n.activeTexture.set(o.TEXTURE4),l.demTexture.bind(h(l),o.CLAMP_TO_EDGE),s.u_dem_lerp=c):(a=this.terrainTileForTile[t.tileID.key],u=this._prepareDemTileUniforms(t,a,s)?a.demTexture:this.emptyDEMTexture):u=this.emptyDEMTexture,n.activeTexture.set(o.TEXTURE2),u&&(s.u_dem_size=1===(d=u).size[0]?1:d.size[0]-2,u.bind(h(a),o.CLAMP_TO_EDGE)),this.painter.setupDepthForOcclusion(r&&r.useDepthForOcclusion,i,s),r&&r.useMeterToDem&&a&&(s.u_meter_to_dem=(1<<a.tileID.canonical.z)*e.bY(1,this.painter.transform.center.lat)*this.sourceCache.getSource().tileSize),r&&r.labelPlaneMatrixInv&&(s.u_label_plane_matrix_inv=r.labelPlaneMatrixInv),i.setTerrainUniformValues(n,s),"globe"===this.painter.transform.projection.name){const e=this.globeUniformValues(this.painter.transform,t.tileID.canonical,r&&r.useDenormalizedUpVectorScale);i.setGlobeUniformValues(n,e)}}globeUniformValues(t,i,r){const n=t.projection;return{u_tile_tl_up:n.upVector(i,0,0),u_tile_tr_up:n.upVector(i,e.ak,0),u_tile_br_up:n.upVector(i,e.ak,e.ak),u_tile_bl_up:n.upVector(i,0,e.ak),u_tile_up_scale:r?e.dD(1):n.upVectorScale(i,t.center.lat,t.worldSize).metersToTile}}renderToBackBuffer(t){const i=this.painter,r=this.painter.context;0!==t.length&&(r.bindFramebuffer.set(null),r.viewport.set([0,0,i.width,i.height]),i.gpuTimingDeferredRenderStart(),this.renderingToTexture=!1,function(t,i,r,n,o){if("globe"===t.transform.projection.name)!function(t,i,r,n,o){const s=t.context,a=s.gl;let l,c;const h=t.transform,u=e.ds(t,s,h),d=(e,i)=>{if(c===i)return;const r=[];1===i&&r.push("TERRAIN_VERTEX_MORPHING"),r.push("PROJECTION_GLOBE_VIEW"),u&&r.push("CUSTOM_ANTIALIASING");const n=t.isTileAffectedByFog(e);l=t.getOrCreateProgram("globeRaster",{defines:r,overrideFog:n}),c=i},p=t.colorModeForRenderPass(),f=new $r(a.LEQUAL,$r.ReadWrite,t.depthRangeFor3D);rs.update(o);const m=e.dt(h),_=[e.aG(h.center.lng),e.aJ(h.center.lat)],g=t.globeSharedBuffers,y=[h.width*e.o.devicePixelRatio,h.height*e.o.devicePixelRatio],x=Float32Array.from(h.globeMatrix),v={useDenormalizedUpVectorScale:!0};{const h=t.transform,u=ns(h.zoom,i.exaggeration(),i.sourceCache._source.tileSize);c=-1;const b=a.TRIANGLES;for(const c of n){const n=r.getTile(c),w=Zr.disabled,T=i.prevTerrainTileForTile[c.key],S=i.terrainTileForTile[c.key];is(T,S)&&rs.newMorphing(c.key,T,S,o,250),ss(t,n.emissiveTexture),s.activeTexture.set(a.TEXTURE0),n.texture&&n.texture.bind(a.LINEAR,a.CLAMP_TO_EDGE);const I=rs.getMorphValuesForProxy(c.key),E=I?1:0;I&&Object.assign(v,{morphing:{srcDemTile:I.from,dstDemTile:I.to,phase:e.dr(I.phase)}});const A=e.du(c.canonical),M=e.dv(A.getCenter().lat),C=e.dw(c.canonical,A,M,h.worldSize/h._pixelsPerMercatorPixel),P=e.dx(e.dy(c.canonical)),D="mrt-fallback"===t.emissiveMode?1:0,R=ts(h.expandedFarZProjMatrix,x,m,P,e.ai(h.zoom),_,h.frustumCorners.TL,h.frustumCorners.TR,h.frustumCorners.BR,h.frustumCorners.BL,h.globeCenterInViewSpace,h.globeRadius,y,u,h._farZ,D,C);if(d(c,E),l&&(i.setupElevationDraw(n,l,v),t.uploadCommonUniforms(s,l,c.toUnwrapped()),g)){const[e,i,r]=g.getGridBuffers(M,0!==u);l.draw(t,b,f,w,p,Yr.backCCW,R,"globe_raster",e,i,r)}}}if(g&&(t.renderDefaultNorthPole||t.renderDefaultSouthPole)){const o=["GLOBE_POLES","PROJECTION_GLOBE_VIEW"];u&&o.push("CUSTOM_ANTIALIASING"),l=t.getOrCreateProgram("globeRaster",{defines:o});for(const c of n){const{x:n,y:o,z:u}=c.canonical,d=0===o,m=o===(1<<u)-1,[x,b,w,T]=g.getPoleBuffers(u,!1);if(T&&(d||m)){const o=r.getTile(c);ss(t,o.emissiveTexture),s.activeTexture.set(a.TEXTURE0),o.texture&&o.texture.bind(a.LINEAR,a.CLAMP_TO_EDGE);let g=e.dz(u,n,h);const S=e.dx(e.dy(c.canonical)),I="mrt-fallback"===t.emissiveMode?1:0,E=(e,i)=>e.draw(t,a.TRIANGLES,f,Zr.disabled,p,Yr.disabled,ts(h.expandedFarZProjMatrix,g,g,S,0,_,h.frustumCorners.TL,h.frustumCorners.TR,h.frustumCorners.BR,h.frustumCorners.BL,h.globeCenterInViewSpace,h.globeRadius,y,0,h._farZ,I),"globe_pole_raster",i,w,T);i.setupElevationDraw(o,l,v),t.uploadCommonUniforms(s,l,c.toUnwrapped()),d&&t.renderDefaultNorthPole&&E(l,x),m&&t.renderDefaultSouthPole&&(g=e.cE(e.bd(),g,[1,-1,1]),E(l,b))}}}}(t,i,r,n,o);else{const s=t.context,a=s.gl;let l,c;const h=t.shadowRenderer,u=an(t,t.longestCutoffRange),d=e=>{if(c===e)return;const i=[];1===e&&i.push("TERRAIN_VERTEX_MORPHING"),u.shouldRenderCutoff&&i.push("RENDER_CUTOFF"),h&&(i.push("RENDER_SHADOWS"),h.useNormalOffset&&i.push("NORMAL_OFFSET")),l=t.getOrCreateProgram("terrainRaster",{defines:i}),c=e},p=t.colorModeForRenderPass(),f=new $r(a.LEQUAL,$r.ReadWrite,t.depthRangeFor3D);rs.update(o);const m=t.transform,_=ns(m.zoom,i.exaggeration(),i.sourceCache._source.tileSize);let g=[0,0,0];if(h){const e=t.style.directionalLight,i=t.style.ambientLight;e&&i&&(g=mn(t.style,e,i))}{c=-1;const y=a.TRIANGLES,[x,v]=[i.gridIndexBuffer,i.gridSegments];for(const c of n){const n=r.getTile(c),b=Zr.disabled,w=i.prevTerrainTileForTile[c.key],T=i.terrainTileForTile[c.key];is(w,T)&&rs.newMorphing(c.key,w,T,o,250),ss(t,n.emissiveTexture),s.activeTexture.set(a.TEXTURE0),n.texture&&n.texture.bind(a.LINEAR,a.CLAMP_TO_EDGE);const S=rs.getMorphValuesForProxy(c.key),I=S?1:0;let E;S&&(E={morphing:{srcDemTile:S.from,dstDemTile:S.to,phase:e.dr(S.phase)}});const A="mrt-fallback"===t.emissiveMode?1:0,M=es(c.projMatrix,os(c.canonical,m.renderWorldCopies)?_/10:_,g,A);if(d(I),!l)continue;i.setupElevationDraw(n,l,E);const C=c.toUnwrapped();h&&h.setupShadows(C,l),t.uploadCommonUniforms(s,l,C,null,u),l.draw(t,y,f,b,p,Yr.backCCW,M,"terrain_raster",i.gridBuffer,x,v)}}}}(i,this,this.proxySourceCache,t,this._updateTimestamp),this.renderingToTexture=!0,i.gpuTimingDeferredRenderEnd(),t.splice(0,t.length))}renderBatch(t){if(0===this._drapedRenderBatches.length)return t+1;this.renderingToTexture=!0;const i=this.painter,r=this.painter.context,n=this.proxySourceCache,o=this.proxiedCoords[n.id],s=this._drapedRenderBatches.shift(),a=i.style.order,l=[];this._updateFBOs("mrt-fallback"===i.emissiveMode);let c=0;for(const h of o){const o=n.getTileByID(h.proxyTileKey),u=n.proxyCachedFBO[h.key]?n.proxyCachedFBO[h.key][t]:void 0,d=void 0!==u?n.renderCache[u]:this.pool[c++],p=void 0!==u;if(o.texture=d.tex,o.emissiveTexture=d.emissiveTex,p&&!d.dirty){l.push(o.tileID);continue}r.bindFramebuffer.set(d.fb.framebuffer);const f=r.gl;let m;f.drawBuffers("mrt-fallback"===i.emissiveMode?[f.COLOR_ATTACHMENT0,f.COLOR_ATTACHMENT1]:[f.COLOR_ATTACHMENT0]),this.renderedToTile=!1,d.dirty&&(r.clear({color:e.C.transparent,stencil:0}),d.dirty=!1);for(let e=s.start;e<=s.end;++e){const t=i.style._mergedLayers[a[e]];if(t.isHidden(i.transform.zoom))continue;const n=i.style.getLayerSourceCache(t),o=n?this.proxyToSource[h.key][n.id]:[h];if(!o)continue;const s=o;r.viewport.set([0,0,d.fb.width,d.fb.height]),m!==(n?n.id:null)&&(this._setupStencil(d,o,t,n),m=n?n.id:null),i.renderLayer(i,n,t,s)}if(f.drawBuffers([f.COLOR_ATTACHMENT0]),0===this._drapedRenderBatches.length)for(const e of this._pendingGroundEffectLayers){const t=i.style._mergedLayers[a[e]];if(t.isHidden(i.transform.zoom))continue;const n=i.style.getLayerSourceCache(t),o=n?this.proxyToSource[h.key][n.id]:[h];if(!o)continue;const s=o;r.viewport.set([0,0,d.fb.width,d.fb.height]),m!==(n?n.id:null)&&(this._setupStencil(d,o,t,n),m=n?n.id:null),i.renderLayer(i,n,t,s)}this.renderedToTile?(d.dirty=!0,l.push(o.tileID)):p||--c,5===c&&(c=0,this.renderToBackBuffer(l))}return this.renderToBackBuffer(l),this.renderingToTexture=!1,r.bindFramebuffer.set(null),r.viewport.set([0,0,i.width,i.height]),s.end+1}postRender(){}isLayerOrderingCorrect(e){const t=e.order.length;let i=-1,r=t;for(let n=0;n<t;++n)this._style.isLayerDraped(e._mergedLayers[e.order[n]])?i=Math.max(i,n):r=Math.min(r,n);return r>i}getMinElevationBelowMSL(){let e=0;return this._visibleDemTiles.filter(e=>e.dem).forEach(t=>{e=Math.min(e,t.dem.tree.minimums[0])}),0===e?e:(e-30)*this._exaggeration}raycast(e,t,i){if(!this._visibleDemTiles)return null;const r=this._visibleDemTiles.filter(e=>e.dem).map(r=>{const n=r.tileID,o=1<<n.overscaledZ,{x:s,y:a}=n.canonical,l=s/o,c=(s+1)/o,h=a/o,u=(a+1)/o;return{minx:l,miny:h,maxx:c,maxy:u,t:r.dem.tree.raycastRoot(l,h,c,u,e,t,i),tile:r}});r.sort((e,t)=>(null!==e.t?e.t:Number.MAX_VALUE)-(null!==t.t?t.t:Number.MAX_VALUE));for(const n of r){if(null==n.t)return null;const r=n.tile.dem.tree.raycast(n.minx,n.miny,n.maxx,n.maxy,e,t,i);if(null!=r)return r}return null}_createFBO(){const t=this.painter.context,i=t.gl,r=this.drapeBufferSize;t.activeTexture.set(i.TEXTURE0);const n=new e.T(t,{width:r[0],height:r[1],data:null},i.RGBA8);n.bind(i.LINEAR,i.CLAMP_TO_EDGE);const o=t.createFramebuffer(r[0],r[1],1,null);let s;return o.colorAttachment0.set(n.texture),this._emissiveTexture&&(s=new e.T(t,{width:r[0],height:r[1],data:null},i.R8),s.bind(i.LINEAR,i.CLAMP_TO_EDGE),o.createColorAttachment(t,1),o.colorAttachment1.set(s.texture)),o.depthAttachment=new Qo(t,o.framebuffer),void 0===this._sharedDepthStencil?(this._sharedDepthStencil=t.createRenderbuffer(t.gl.DEPTH_STENCIL,r[0],r[1]),this._stencilRef=0,o.depthAttachment.set(this._sharedDepthStencil),t.clear({stencil:0})):o.depthAttachment.set(this._sharedDepthStencil),t.extTextureFilterAnisotropic&&i.texParameterf(i.TEXTURE_2D,t.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,t.extTextureFilterAnisotropicMax),{fb:o,tex:n,emissiveTex:s,dirty:!1}}_updateFBOs(e){if(this._emissiveTexture!==e){for(const t of this.pool)this._updateFBO(t,e);for(const t of this.proxySourceCache.renderCache)this._updateFBO(t,e);this._emissiveTexture=e}}_updateFBO(t,i){const r=t.fb,n=this.painter.context,o=n.gl,s=this.drapeBufferSize;if(i){const i=new e.T(n,{width:s[0],height:s[1],data:null},o.R8);i.bind(o.LINEAR,o.CLAMP_TO_EDGE),t.emissiveTex=i,r.createColorAttachment(n,1),r.colorAttachment1.set(i.texture)}else t.emissiveTex=void 0,r.removeColorAttachment(n,1);t.dirty=!0}_initFBOPool(){for(;this.pool.length<Math.min(5,this.proxyCoords.length);)this.pool.push(this._createFBO())}_shouldDisableRenderCache(){if(this._style.hasLightTransitions())return!0;for(const e in this._style._mergedSourceCaches)if(this._style._mergedSourceCaches[e].hasTransition())return!0;return this._style.order.some(e=>{const t=this._style._mergedLayers[e],i=t.isHidden(this.painter.transform.zoom);return"hillshade"===t.type||"custom"===t.type?!i&&t.shouldRedrape():!i&&t.hasTransition()})}_clearLineLayersFromRenderCache(){let t=!1;for(const e of this._style.getSources())if(e instanceof gi){t=!0;break}if(!t)return;const i={};for(let r=0;r<this._style.order.length;++r){const t=this._style._mergedLayers[this._style.order[r]],n=this._style.getLayerSourceCache(t);if(!n||i[n.id])continue;if(t.isHidden(this.painter.transform.zoom)||"line"!==t.type)continue;const o=t.widthExpression(),s=t.emissiveStrengthExpression();if(o instanceof e.ac||s instanceof e.ac){i[n.id]=!0;for(const e of this.proxyCoords){const t=this.proxyToSource[e.key][n.id];if(t)for(const e of t)this._clearRenderCacheForTile(n.id,e)}}}}_clearRasterLayersFromRenderCache(){let e=!1;for(const i in this._style._mergedSourceCaches)if(this._style._mergedSourceCaches[i]._source instanceof yi){e=!0;break}if(!e)return;const t={};for(let i=0;i<this._style.order.length;++i){const e=this._style._mergedLayers[this._style.order[i]],r=this._style.getLayerSourceCache(e);if(!r||t[r.id])continue;if(e.isHidden(this.painter.transform.zoom)||"raster"!==e.type)continue;const n=e.paint.get("raster-fade-duration");for(const t of this.proxyCoords){const e=this.proxyToSource[t.key][r.id];if(e)for(const t of e){const e=ls(r.getTile(t),r.findLoadedParent(t,0),r,this.painter.transform,n);(1!==e.opacity||0!==e.mix)&&this._clearRenderCacheForTile(r.id,t)}}}}_setupDrapedRenderBatches(){this._style.updateDrapeFirstLayers();const t=this._style.order,i=t.length;if(0===i)return;const r=[];this._pendingGroundEffectLayers=[];let n,o=0,s=this._style._mergedLayers[t[o]];for(;!this._style.isLayerDraped(s)&&s.isHidden(this.painter.transform.zoom)&&++o<i;)s=this._style._mergedLayers[t[o]];for(;o<i;++o){const e=this._style._mergedLayers[t[o]];e.isHidden(this.painter.transform.zoom)||(this._style.isLayerDraped(e)?void 0===n&&(n=o):("fill-extrusion"===e.type&&this._pendingGroundEffectLayers.push(o),void 0!==n&&(r.push({start:n,end:o-1}),n=void 0)))}if(void 0!==n&&r.push({start:n,end:o-1}),0!==r.length){const t=r.at(-1);this._pendingGroundEffectLayers.every(e=>e>t.end)||e.w("fill-extrusion with flood lighting and/or ground ambient occlusion should be moved to be on top of all draped layers.")}this._drapedRenderBatches=r}_setupRenderCache(e){const t=this.proxySourceCache;if(this._shouldDisableRenderCache()||this.invalidateRenderCache){if(this.invalidateRenderCache=!1,t.renderCache.length>t.renderCachePool.length){const e=Object.values(t.proxyCachedFBO);t.proxyCachedFBO={};for(let i=0;i<e.length;++i){const r=Object.values(e[i]);t.renderCachePool.push(...r)}}return}this._clearRasterLayersFromRenderCache();const i=this.proxyCoords,r=this._tilesDirty;for(let o=i.length-1;o>=0;o--){const n=i[o];if(t.getTileByID(n.key),void 0!==t.proxyCachedFBO[n.key]){const i=e[n.key],o=this.proxyToSource[n.key];let s=0;for(const e in o){const t=o[e],n=i[e];if(!n||n.length!==t.length||t.some((t,i)=>t!==n[i]||r[e]&&Object.hasOwn(r[e],t.key))){s=-1;break}++s}for(const e in t.proxyCachedFBO[n.key])t.renderCache[t.proxyCachedFBO[n.key][e]].dirty=s<0||s!==Object.values(i).length}}const n=[...this._drapedRenderBatches];n.sort((e,t)=>t.end-t.start-(e.end-e.start));for(const o of n)for(const e of i){if(t.proxyCachedFBO[e.key])continue;let i=t.renderCachePool.pop();void 0===i&&t.renderCache.length<50&&(i=t.renderCache.length,t.renderCache.push(this._createFBO())),void 0!==i&&(t.proxyCachedFBO[e.key]={},t.proxyCachedFBO[e.key][o.start]=i,t.renderCache[i].dirty=!0)}this._tilesDirty={}}_setupStencil(e,t,i,r){if(!r||!this._sourceTilesOverlap[r.id])return void(this._overlapStencilType&&(this._overlapStencilType=!1));const n=this.painter.context,o=n.gl;if(t.length<=1)return void(this._overlapStencilType=!1);let s;if(i.isTileClipped())s=t.length,this._overlapStencilMode.test={func:o.EQUAL,mask:255},this._overlapStencilType="Clip";else{if(!(t[0].overscaledZ>t.at(-1).overscaledZ))return void(this._overlapStencilType=!1);s=1,this._overlapStencilMode.test={func:o.GREATER,mask:255},this._overlapStencilType="Mask"}this._stencilRef+s>255&&(n.clear({stencil:0}),this._stencilRef=0),this._stencilRef+=s,this._overlapStencilMode.ref=this._stencilRef,i.isTileClipped()&&this._renderTileClippingMasks(t,this._overlapStencilMode.ref)}clipOrMaskOverlapStencilType(){return"Clip"===this._overlapStencilType||"Mask"===this._overlapStencilType}stencilModeForRTTOverlap(e){return this.renderingToTexture&&this._overlapStencilType?("Clip"===this._overlapStencilType&&(this._overlapStencilMode.ref=this.painter._tileClippingMaskIDs[e.key]),this._overlapStencilMode):Zr.disabled}_renderTileClippingMasks(e,t){const i=this.painter,r=this.painter.context,n=r.gl;i._tileClippingMaskIDs={},r.setColorMode(Hr.disabled),r.setDepthMode($r.disabled);const o=i.getOrCreateProgram("clippingMask");for(const s of e){const e=i._tileClippingMaskIDs[s.key]=--t;o.draw(i,n.TRIANGLES,$r.disabled,new Zr({func:n.ALWAYS,mask:0},e,255,n.KEEP,n.KEEP,n.REPLACE),Hr.disabled,Yr.disabled,as(s.projMatrix),"$clipping",i.tileExtentBuffer,i.quadTriangleIndexBuffer,i.tileExtentSegments)}}pointCoordinate(t){const i=this.painter.transform;if(t.x<0||t.x>i.width||t.y<0||t.y>i.height)return null;const r=[t.x,t.y,1,1];e.aD(r,r,i.pixelMatrixInverse),e.cw(r,r,1/r[3]),r[0]/=i.worldSize,r[1]/=i.worldSize;const n=i._camera.position,o=e.bY(1,i.center.lat),s=[n[0],n[1],n[2]/o,0],a=e.cZ([],r.slice(0,3),s);e.ax(a,a);const l=this.raycast(s,a,this._exaggeration);return null!==l&&l?(e.bi(s,s,a,l),s[3]=s[2],s[2]*=o,s):null}_setupProxiedCoordsForOrtho(t,i,r){if(t.getSource()instanceof e.aY)return this._setupProxiedCoordsForImageSource(t,i,r);this._findCoveringTileCache[t.id]=this._findCoveringTileCache[t.id]||{};const n=this.proxiedCoords[t.id]=[],o=this.proxyCoords;for(let e=0;e<o.length;e++){const i=o[e],s=this._findTileCoveringTileID(i,t);if(s){const e=this._createProxiedId(i,s,r[i.key]&&r[i.key][t.id]);n.push(e),this.proxyToSource[i.key][t.id]=[e]}}let s=!1;const a=/* @__PURE__ */new Set;for(let e=0;e<i.length;e++){const o=t.getTile(i[e]);if(!o||!o.hasData())continue;const l=this._findTileCoveringTileID(o.tileID,this.proxySourceCache);if(l&&l.tileID.canonical.z!==o.tileID.canonical.z){const e=this.proxyToSource[l.tileID.key][t.id],i=this._createProxiedId(l.tileID,o,r[l.tileID.key]&&r[l.tileID.key][t.id]);e?e.splice(e.length-1,0,i):this.proxyToSource[l.tileID.key][t.id]=[i];const c=this.proxyToSource[l.tileID.key][t.id];a.has(c)||a.add(c),n.push(i),s=!0}}if(this._sourceTilesOverlap[t.id]=s,s)for(const e of a)e.sort((e,t)=>t.overscaledZ-e.overscaledZ)}_setupProxiedCoordsForImageSource(t,i,r){if(!t.getSource().loaded())return;const n=this.proxiedCoords[t.id]=[],o=this.proxyCoords,s=t.getSource(),a=s.tileID;if(!a)return;const l=new e.P(a.x,a.y)._div(1<<a.z),c=s.coordinates.map(e.ad.fromLngLat).reduce((e,t)=>(e.min.x=Math.min(e.min.x,t.x-l.x),e.min.y=Math.min(e.min.y,t.y-l.y),e.max.x=Math.max(e.max.x,t.x-l.x),e.max.y=Math.max(e.max.y,t.y-l.y),e),{min:new e.P(Number.MAX_VALUE,Number.MAX_VALUE),max:new e.P(-Number.MAX_VALUE,-Number.MAX_VALUE)}),h=(t,i)=>{const r=t.wrap+t.canonical.x/(1<<t.canonical.z),n=t.canonical.y/(1<<t.canonical.z),o=e.ak/(1<<t.canonical.z),s=i.wrap+i.canonical.x/(1<<i.canonical.z),a=i.canonical.y/(1<<i.canonical.z);return r+o<s+c.min.x||r>s+c.max.x||n+o<a+c.min.y||n>a+c.max.y};for(let e=0;e<o.length;e++){const s=o[e];for(let e=0;e<i.length;e++){const o=t.getTile(i[e]);if(!o||!o.hasData())continue;if(h(s,o.tileID))continue;const a=this._createProxiedId(s,o,r[s.key]&&r[s.key][t.id]),l=this.proxyToSource[s.key][t.id];l?l.push(a):this.proxyToSource[s.key][t.id]=[a],n.push(a)}}}_createProxiedId(t,i,r){let n=this.orthoMatrix;if(r){const e=r.find(e=>e.key===i.tileID.key);if(e)return e}if(i.tileID.key!==t.key){const r=t.canonical.z-i.tileID.canonical.z;let o,s,a;n=e.bd();const l=i.tileID.wrap-t.wrap<<t.overscaledZ;r>0?(o=e.ak>>r,s=o*((i.tileID.canonical.x<<r)-t.canonical.x+l),a=o*((i.tileID.canonical.y<<r)-t.canonical.y)):(o=e.ak<<-r,s=e.ak*(i.tileID.canonical.x-(t.canonical.x+l<<-r)),a=e.ak*(i.tileID.canonical.y-(t.canonical.y<<-r))),e.bX(n,0,o,0,o,0,1),e.bB(n,n,[s,a,0])}return new us(i.tileID,t.key,n)}_findTileCoveringTileID(t,i){let r=i.getTile(t);if(r&&r.hasData())return r;const n=this._findCoveringTileCache[i.id],o=n[t.key];if(r=o?i.getTileByID(o):null,r&&r.hasData()||null===o)return r;let s=r?r.tileID:t,a=s.overscaledZ;const l=i.getSource().minzoom,c=[];if(!o){const n=i.getSource().maxzoom;if(t.canonical.z>=n){const r=t.canonical.z-n;i.getSource().reparseOverscaled?(a=Math.max(t.canonical.z+2,i.transform.tileZoom),s=new e.aU(a,t.wrap,n,t.canonical.x>>r,t.canonical.y>>r)):0!==r&&(a=n,s=new e.aU(a,t.wrap,n,t.canonical.x>>r,t.canonical.y>>r))}s.key!==t.key&&(c.push(s.key),r=i.getTile(s))}const h=e=>{c.forEach(t=>{n[t]=e}),c.length=0};for(a-=1;a>=l&&(!r||!r.hasData());a--){r&&h(r.tileID.key);const e=s.calculateScaledKey(a);if(r=i.getTileByID(e),r&&r.hasData())break;const t=n[e];if(null===t)break;void 0===t?c.push(e):r=i.getTileByID(t)}return h(r?r.tileID.key:null),r&&r.hasData()?r:null}findDEMTileFor(e){return this.enabled?this._findTileCoveringTileID(e,this.sourceCache):null}prepareDrawTile(){this.renderedToTile=!0}_clearRenderCacheForTile(e,t){let i=this._tilesDirty[e];i||(i=this._tilesDirty[e]={}),i[t.key]=!0}}function ps(t,i,r){const n=function(t,i,r){const n=e.bk(i,t),o=e.bk(r,[.2126,.7152,.0722]),s=(e,t,i)=>(1-i)*e+i*t,a=s(1-.3*Math.min(o,1),1,Math.min(n+1,1));return s(.92,1,Math.asin(e.aB(i[2],-1,1))/Math.PI+.5)*a}(t,[0,0,1],i),o=[0,0,0];e.bN(o,r.slice(0,3),n);const s=[0,0,0];e.bN(s,i.slice(0,3),t[2]);const a=[0,0,0];return e.cX(a,o,s),e.c_(a)}const fs=["fill","fillOutline","fillPattern","line","linePattern","background","backgroundPattern","hillshade","raster"],ms=["stars","rainParticle","snowParticle","fillExtrusion","fillExtrusionGroundEffect","building","buildingBloom","elevatedStructures","model","symbol"];class _s{static cacheKey(e,t,i,r){const n=[t];r&&n.push(r.cacheKey);for(const o of i)("string"==typeof o&&o.includes(" ")||e.usedDefines.has(o))&&n.push(o);return n.join("/")}constructor(e,t,i,r,n,o,s=!1){const a=e.gl;this.program=a.createProgram(),this._context=e,this._fixedUniformsFn=n,this._pending=!0,this._precompiled=s,this.attributes={},this.configuration=r,this.name=t,this.fixedDefines=[...o],s?e._compileStats.precompiled++:e._compileStats.onDemand++;const l=`#version 300 es\n${(r?r.defines():[]).concat(o.map(e=>`#define ${e}`)).join("\n")}`,c=[l,oo];for(const m of i.fragmentIncludes)c.push(Qn[m]);c.push(i.fragmentSource);const h=c.join("\n"),u=[l,so];for(const m of i.vertexIncludes)u.push(Qn[m]);this.forceManualRenderingForInstanceIDShaders=e.forceManualRenderingForInstanceIDShaders&&i.vertexSource.includes("gl_InstanceID"),this.forceManualRenderingForInstanceIDShaders&&u.push("uniform int u_instanceID;"),u.push(i.vertexSource);let d=u.join("\n");this.forceManualRenderingForInstanceIDShaders&&(d=d.replaceAll("gl_InstanceID","u_instanceID"));const p=a.createShader(a.FRAGMENT_SHADER);if(a.isContextLost())return this.failedToCreate=!0,void(this._pending=!1);a.shaderSource(p,h),a.compileShader(p),a.attachShader(this.program,p);const f=a.createShader(a.VERTEX_SHADER);if(a.isContextLost())return this.failedToCreate=!0,void(this._pending=!1);a.shaderSource(f,d),a.compileShader(f),a.attachShader(this.program,f),a.linkProgram(this.program),this._fragmentShader=p,this._vertexShader=f,e.extParallelShaderCompile?e._pendingPrograms.add(this):this._finalize()}_finalize(){if(!this._pending)return;this._pending=!1;const t=this._context,i=t.gl;t._pendingPrograms.delete(this);const r=e.o.now(),n=i.getProgramParameter(this.program,i.LINK_STATUS),o=e.o.now()-r,s=t._compileStats;if(s.totalStallMs+=o,o>s.maxStallMs&&(s.maxStallMs=o),o>1){s.framesMissed+=Math.floor(60*o/1e3);const e=this.fixedDefines.join(",");s.stalls.push({name:`${this.name}${e?"/":""}${e}`,ms:o,timestamp:r})}if(this._fragmentShader&&(n||e.w(`Fragment shader '${this.name}': ${i.getShaderInfoLog(this._fragmentShader)}`),i.deleteShader(this._fragmentShader),this._fragmentShader=null),this._vertexShader&&(n||e.w(`Vertex shader '${this.name}': ${i.getShaderInfoLog(this._vertexShader)}`),i.deleteShader(this._vertexShader),this._vertexShader=null),!n)return e.w(`Failed to link program '${this.name}': ${i.getProgramInfoLog(this.program)}`),void(this.failedToCreate=!0);this.fixedUniforms=this._fixedUniformsFn(t),this.fixedUniformsEntries=Object.entries(this.fixedUniforms),this.binderUniforms=this.configuration?this.configuration.getUniforms(t):[],this.forceManualRenderingForInstanceIDShaders&&(this.instancingUniforms=(t=>({u_instanceID:new e.b$(t)}))(t));const a=this.fixedDefines,l=this.name;(a.includes("TERRAIN")||a.includes("ELEVATED")||l.includes("symbol")||l.includes("circle"))&&(this.terrainUniforms=(t=>({u_dem:new e.b$(t),u_dem_prev:new e.b$(t),u_dem_tl:new e.c2(t),u_dem_scale:new e.c1(t),u_dem_tl_prev:new e.c2(t),u_dem_scale_prev:new e.c1(t),u_dem_size:new e.c1(t),u_dem_lerp:new e.c1(t),u_exaggeration:new e.c1(t),u_depth:new e.b$(t),u_depth_size_inv:new e.c2(t),u_depth_range_unpack:new e.c2(t),u_occluder_half_size:new e.c1(t),u_occlusion_depth_offset:new e.c1(t),u_meter_to_dem:new e.c1(t),u_label_plane_matrix_inv:new e.c3(t)}))(t)),a.includes("GLOBE")&&(this.globeUniforms=(t=>({u_tile_tl_up:new e.c0(t),u_tile_tr_up:new e.c0(t),u_tile_br_up:new e.c0(t),u_tile_bl_up:new e.c0(t),u_tile_up_scale:new e.c1(t)}))(t)),a.includes("FOG")&&(this.fogUniforms=(t=>({u_fog_matrix:new e.c3(t),u_fog_range:new e.c2(t),u_fog_color:new e.cS(t),u_fog_horizon_blend:new e.c1(t),u_fog_vertical_limit:new e.c2(t),u_fog_temporal_offset:new e.c1(t),u_frustum_tl:new e.c0(t),u_frustum_tr:new e.c0(t),u_frustum_br:new e.c0(t),u_frustum_bl:new e.c0(t),u_globe_pos:new e.c0(t),u_globe_radius:new e.c1(t),u_globe_transition:new e.c1(t),u_is_globe:new e.b$(t),u_viewport:new e.c2(t)}))(t)),a.includes("RENDER_CUTOFF")&&(this.cutoffUniforms=(t=>({u_cutoff_params:new e.cS(t)}))(t)),a.includes("LIGHTING_3D_MODE")&&(this.lightsUniforms=(t=>({u_lighting_ambient_color:new e.c0(t),u_lighting_directional_dir:new e.c0(t),u_lighting_directional_color:new e.c0(t),u_ground_radiance:new e.c0(t)}))(t)),a.includes("RENDER_SHADOWS")&&(this.shadowUniforms=(t=>({u_light_matrix_0:new e.c3(t),u_light_matrix_1:new e.c3(t),u_fade_range:new e.c2(t),u_shadow_normal_offset:new e.c0(t),u_shadow_intensity:new e.c1(t),u_shadow_texel_size:new e.c1(t),u_shadow_map_resolution:new e.c1(t),u_shadow_direction:new e.c0(t),u_shadow_bias:new e.c0(t),u_shadowmap_0:new e.b$(t),u_shadowmap_1:new e.b$(t)}))(t))}maybeFinalize(){if(!this._pending)return;const e=this._context.extParallelShaderCompile;e&&!this._context.gl.getProgramParameter(this.program,e.COMPLETION_STATUS_KHR)||this._finalize()}_ensureReady(){this._pending&&(this._finalize(),this._context.sweepPendingPrograms())}getAttributeLocation(e,t){this._ensureReady();let i=this.attributes[t];return void 0===i&&(i=this.attributes[t]=e.getAttribLocation(this.program,t)),i}setTerrainUniformValues(e,t){if(this._ensureReady(),!this.terrainUniforms)return;const i=this.terrainUniforms;if(!this.failedToCreate){e.program.set(this.program);for(const e in t)i[e]&&i[e].set(this.program,e,t[e])}}setGlobeUniformValues(e,t){if(this._ensureReady(),!this.globeUniforms)return;const i=this.globeUniforms;if(!this.failedToCreate){e.program.set(this.program);for(const e in t)i[e]&&i[e].set(this.program,e,t[e])}}setFogUniformValues(e,t){if(this._ensureReady(),!this.fogUniforms)return;const i=this.fogUniforms;if(!this.failedToCreate){e.program.set(this.program);for(const e in t)i[e].set(this.program,e,t[e])}}setCutoffUniformValues(e,t){if(this._ensureReady(),!this.cutoffUniforms)return;const i=this.cutoffUniforms;if(!this.failedToCreate){e.program.set(this.program);for(const e in t)i[e].set(this.program,e,t[e])}}setLightsUniformValues(e,t){if(this._ensureReady(),!this.lightsUniforms)return;const i=this.lightsUniforms;if(!this.failedToCreate){e.program.set(this.program);for(const e in t)i[e].set(this.program,e,t[e])}}setShadowUniformValues(e,t){if(this._ensureReady(),this.failedToCreate||!this.shadowUniforms)return;const i=this.shadowUniforms;e.program.set(this.program);for(const r in t)i[r].set(this.program,r,t[r])}_drawDebugWireframe(t,i,r,n,o,s,a,l,c,h){const u=t.options.wireframe;if(!1===u.terrain&&!1===u.layers2D&&!1===u.layers3D)return;const d=t.context;if(!(()=>!(!u.terrain||"terrainRaster"!==this.name&&"globeRaster"!==this.name)||!(!u.layers2D||t._terrain&&t._terrain.renderingToTexture||!fs.includes(this.name))||!(!u.layers3D||!ms.includes(this.name)))())return;const p=d.gl,f=t.wireframeDebugCache.getLinesFromTrianglesBuffer(t.frameCounter,o,d);if(!f)return;const m=[...this.fixedDefines,"DEBUG_WIREFRAME"],_=t.getOrCreateProgram(this.name,{config:this.configuration,defines:m});_._ensureReady(),d.program.set(_.program);const g=(e,t,i)=>{if(t[e]&&i[e])for(const r in t[e])i[e][r]&&i[e][r].set(i.program,r,t[e][r].current)};c&&c.setUniforms(_.program,d,_.binderUniforms,a,{zoom:l}),g("fixedUniforms",this,_),g("terrainUniforms",this,_),g("globeUniforms",this,_),g("fogUniforms",this,_),g("lightsUniforms",this,_),g("shadowUniforms",this,_),f.bind(),d.setColorMode(new Hr([p.ONE,p.ONE_MINUS_SRC_ALPHA,p.ZERO,p.ONE],e.C.transparent,[!0,!0,!0,!1])),d.setDepthMode(new $r(i.func===p.LESS?p.LEQUAL:i.func,$r.ReadOnly,i.range)),d.setStencilMode(Zr.disabled);const y=3*s.primitiveLength*2,x=3*s.primitiveOffset*2*2;if(this.forceManualRenderingForInstanceIDShaders){const e=h||1;for(let t=0;t<e;++t)_.instancingUniforms.u_instanceID.set(this.program,"u_instanceID",t),p.drawElements(p.LINES,y,p.UNSIGNED_SHORT,x)}else h&&h>1?p.drawElementsInstanced(p.LINES,y,p.UNSIGNED_SHORT,x,h):p.drawElements(p.LINES,y,p.UNSIGNED_SHORT,x);o.bind(),d.program.set(this.program),d.setDepthMode(i),d.setStencilMode(r),d.setColorMode(n)}checkUniforms(e,t,i){if(this.fixedDefines.includes(t))for(const r of Object.keys(i))if(!i[r].initialized)throw new Error(`Program '${this.name}', from draw '${e}': uniform ${r} not set but required by ${t} being defined`)}draw(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m){const _=e.context,g=_.gl;if(this._ensureReady(),this.failedToCreate)return;_.program.set(this.program),_.setDepthMode(i),_.setStencilMode(r),_.setColorMode(n),_.setCullFace(o);for(const[T,S]of this.fixedUniformsEntries)S.set(this.program,T,s[T]);p&&p.setUniforms(this.program,_,this.binderUniforms,u,{zoom:d});const y={[g.POINTS]:1,[g.LINES]:2,[g.TRIANGLES]:3,[g.LINE_STRIP]:1}[t];this.checkUniforms(a,"RENDER_SHADOWS",this.shadowUniforms);const x=f||[],v=p?p.getPaintVertexBuffers():[],b=t===g.TRIANGLES&&c,w=m&&m>0?1:void 0;for(const T of h.get()){const o=T.vaos||(T.vaos={});if((o[a]||(o[a]=new uo)).bind(_,this,l,v,c,T.vertexOffset,x,w),this.forceManualRenderingForInstanceIDShaders){const e=m||1;for(let i=0;i<e;++i)this.instancingUniforms.u_instanceID.set(this.program,"u_instanceID",i),c?g.drawElements(t,T.primitiveLength*y,g.UNSIGNED_SHORT,T.primitiveOffset*y*2):g.drawArrays(t,T.vertexOffset,T.vertexLength)}else m&&m>1?g.drawElementsInstanced(t,T.primitiveLength*y,g.UNSIGNED_SHORT,T.primitiveOffset*y*2,m):c?g.drawElements(t,T.primitiveLength*y,g.UNSIGNED_SHORT,T.primitiveOffset*y*2):g.drawArrays(t,T.vertexOffset,T.vertexLength);b&&this._drawDebugWireframe(e,i,r,n,c,T,u,d,p,m)}}}function gs(t,i,r=0){const n=Math.pow(2,i.tileID.overscaledZ),o=i.tileSize*Math.pow(2,t.transform.tileZoom)/n,s=o*(i.tileID.canonical.x+i.tileID.wrap*n),a=o*i.tileID.canonical.y;return{u_image:0,u_texsize:i.imageAtlasTexture?i.imageAtlasTexture.size:[0,0],u_tile_units_to_pixels:1/e.az(i,1,t.transform.tileZoom),u_pixel_coord_upper:[s>>16,a>>16],u_pixel_coord_lower:[65535&s,65535&a],u_pattern_transition:r}}const ys={terrain:0,flat:1},xs=e.bd(),vs=(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x=[0,0,1])=>{const v=i.style.light,b=v.properties.get("position"),w=[b.x,b.y,b.z],T=e.dH();"viewport"===v.properties.get("anchor")&&(e.dI(T,-i.transform.angle),e.dJ(w,w,T));const S=v.properties.get("color").toPremultipliedRenderColor(null),I=i.transform,E={u_matrix:t,u_lightpos:w,u_lightintensity:v.properties.get("intensity"),u_lightcolor:[S.r,S.g,S.b],u_vertical_gradient:+r,u_opacity:n,u_tile_id:[0,0,0],u_zoom_transition:0,u_inv_rot_matrix:xs,u_merc_center:[0,0],u_up_dir:[0,0,0],u_height_lift:0,u_height_type:ys[h],u_base_type:ys[u],u_ao:o,u_edge_radius:s,u_width_scale:a,u_flood_light_color:m,u_vertical_scale:_,u_flood_light_intensity:g,u_ground_shadow_factor:y,u_front_cutoff_params:x};return"globe"===I.projection.name&&(E.u_tile_id=[l.canonical.x,l.canonical.y,1<<l.canonical.z],E.u_zoom_transition=d,E.u_inv_rot_matrix=f,E.u_merc_center=p,E.u_up_dir=I.projection.upVector(new e.cp(0,0,0),p[0]*e.ak,p[1]*e.ak),E.u_height_lift=c),E},bs=(e,t,i,r,n,o)=>({u_matrix:e,u_edge_radius:t,u_width_scale:i,u_vertical_scale:r,u_height_type:ys[n],u_base_type:ys[o]}),ws=(e,t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g)=>{const y=vs(e,t,i,r,n,o,s,a,c,h,u,d,p,f,m,_,1,[0,0,0]),x={u_height_factor:-Math.pow(2,a.overscaledZ)/l.tileSize/8};return Object.assign(y,gs(t,l,g),x)},Ts=(e,t,i)=>({u_matrix:e,u_emissive_strength:t,u_ground_shadow_factor:i}),Ss=(e,t,i,r,n,o=0)=>Object.assign(Ts(e,t,n),gs(i,r,o)),Is=(e,t,i,r)=>({u_matrix:e,u_world:i,u_emissive_strength:t,u_ground_shadow_factor:r}),Es=(e,t,i,r,n,o,s=0)=>Object.assign(Ss(e,t,i,r,o,s),{u_world:n}),As=(e,t)=>({u_matrix:e,u_depth_bias:t}),Ms=(e,t)=>({u_matrix:e,u_ground_shadow_factor:t}),Cs=(e,t,i,r,n)=>({u_matrix:e,u_camera_pos:[t[0],t[1],t[2]],u_depth_bias:i,u_height_scale:r,u_reset_depth:n}),Ps=(e,t,i)=>({u_image:e,u_texel_size:t,u_first_pass:i?1:0}),Ds=(t,i,r,n,o,s,a,l)=>{const c=e.ak/s.tileSize;return{u_matrix:t,u_inv_rot_matrix:i,u_camera_to_center_distance:r.getCameraToCenterDistance(l),u_extrude_scale:[r.pixelsToGLUnits[0]/c,r.pixelsToGLUnits[1]/c],u_zoom_transition:n,u_tile_id:a,u_merc_center:o}},Rs=(e,t,i,r)=>({u_matrix:e,u_inv_matrix:t,u_camera_to_center_distance:i.getCameraToCenterDistance(r),u_viewport_size:[i.width,i.height]}),zs=(e,t,i=1)=>({u_matrix:e,u_color:t,u_overlay:0,u_overlay_scale:i}),Ls=e.bd(),Fs=(t,i,r,n,o,s,a)=>{const l=t.transform,c="globe"===l.projection.name,h=c?e.dK(l.zoom,i.canonical)*l._pixelsPerMercatorPixel:e.az(r,1,s),u={u_matrix:i.projMatrix,u_extrude_scale:h,u_intensity:a,u_inv_rot_matrix:Ls,u_merc_center:[0,0],u_tile_id:[0,0,0],u_zoom_transition:0,u_up_dir:[0,0,0]};if(c){u.u_inv_rot_matrix=n,u.u_merc_center=o,u.u_tile_id=[i.canonical.x,i.canonical.y,1<<i.canonical.z],u.u_zoom_transition=e.ai(l.zoom);const t=o[0]*e.ak,r=o[1]*e.ak;u.u_up_dir=l.projection.upVector(new e.cp(0,0,0),t,r)}return u};function Os(e,[t,i,r,n],[o,s]){if(o===s)return[0,0,0,0];const a=255*(e-1)/(e*(s-o));return[t*a,i*a,r*a,n*a]}function Bs(e,t,[i,r]){return i===r?0:.5/e+(t-i)*(e-1)/(e*(r-i))}function ks(t){const i=t.terrain?t.terrain.exaggeration():1;var r;return(t.transform.pitch<15?.07*(1-(r=e.aB((14-t.transform.zoom)/5,0,1)))+.7*r:.07)*i}const Ns=(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w)=>({u_matrix:i,u_normalize_matrix:r,u_globe_matrix:n,u_merc_matrix:o,u_grid_matrix:s,u_tl_parent:a,u_scale_parent:u,u_fade_t:d.mix,u_opacity:d.opacity*p.paint.get("raster-opacity"),u_image0:0,u_image1:1,u_brightness_low:p.paint.get("raster-brightness-min"),u_brightness_high:p.paint.get("raster-brightness-max"),u_saturation_factor:e.dM(p.paint.get("raster-saturation")),u_contrast_factor:e.dL(p.paint.get("raster-contrast")),u_spin_weights:Us(p.paint.get("raster-hue-rotate")),u_perspective_transform:f,u_raster_elevation:m,u_zoom_transition:l,u_merc_center:c,u_cutoff_params:h,u_colorization_mix:Os(e.dN,g,x),u_colorization_offset:Bs(e.dN,y,x),u_color_ramp:_,u_texture_offset:[b/(v+2*b),v/(v+2*b)],u_texture_res:[v+2*b,v+2*b],u_emissive_strength:w,u_zbias_factor:ks(t)});function Us(e){e*=Math.PI/180;const t=Math.sin(e),i=Math.cos(e);return[(2*i+1)/3,(-Math.sqrt(3)*t-i+1)/3,(Math.sqrt(3)*t-i+1)/3]}const Vs=e.bd(),js=(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b,w,T,S)=>{const I=o.transform,E={u_is_size_zoom_constant:+("constant"===t||"source"===t),u_is_size_feature_constant:+("constant"===t||"camera"===t),u_size_t:i?i.uSizeT:0,u_size:i?i.uSize:0,u_camera_to_center_distance:I.getCameraToCenterDistance(x),u_rotate_symbol:+r,u_aspect_ratio:I.width/I.height,u_fade_change:o.options.fadeDuration?o.symbolFadeChange:1,u_matrix:s,u_label_plane_matrix:a,u_coord_matrix:l,u_is_text:+h,u_elevation_from_sea:c?1:0,u_pitch_with_map:+n,u_texsize:u,u_texsize_icon:d,u_texture:0,u_texture_icon:1,u_tile_id:[0,0,0],u_zoom_transition:0,u_inv_rot_matrix:Vs,u_merc_center:[0,0],u_camera_forward:[0,0,0],u_ecef_origin:[0,0,0],u_tile_matrix:Vs,u_up_vector:[0,-1,0],u_color_adj_mat:w,u_icon_transition:T||0,u_gamma_scale:n?o.transform.getCameraToCenterDistance(x)*Math.cos(o.terrain?0:o.transform._pitch):1,u_device_pixel_ratio:e.o.devicePixelRatio,u_is_halo:1,u_scale_factor:S||1,u_ground_shadow_factor:v,u_inv_matrix:e.ba(e.bd(),a),u_normal_scale:b,u_lutTexture:10,u_zoom:I.zoom-Math.floor(I.zoom),u_spp_fill_np_color:[0,0,0,1],u_spp_halo_np_color:[0,0,0,0],u_spp_opacity:1,u_spp_halo_width:0,u_spp_halo_blur:0,u_spp_emissive_strength:0,u_spp_occlusion_opacity:1,u_spp_z_offset:0,u_spp_translate_rotation:[1,0]};return"globe"===x.name&&(E.u_tile_id=[f.canonical.x,f.canonical.y,1<<f.canonical.z],E.u_zoom_transition=m,E.u_inv_rot_matrix=g,E.u_merc_center=_,E.u_camera_forward=I._camera.forward(),E.u_ecef_origin=e.dO(I.globeMatrix,f.toUnwrapped()),E.u_tile_matrix=I.globeMatrix,E.u_up_vector=y),E},Gs=(e,t,i,r)=>({u_matrix:e,u_emissive_strength:t,u_opacity:i,u_color:r}),Hs=(t,i,r,n,o,s,a,l,c)=>Object.assign(function(t,i,r,n,o,s){const{width:a,height:l}=n.imageManager.getPixelSize(i),c=Math.pow(2,s.tileID.overscaledZ),h=s.tileSize*Math.pow(2,n.transform.tileZoom)/c,u=h*(s.tileID.canonical.x+s.tileID.wrap*c),d=h*s.tileID.canonical.y;return{u_image:0,u_pattern_tl:r.tl,u_pattern_br:r.br,u_texsize:[a,l],u_pattern_size:r.displaySize,u_pattern_units_to_pixels:o?[n.transform.width,-1*n.transform.height]:[1/e.az(s,1,n.transform.tileZoom),1/e.az(s,1,n.transform.tileZoom)],u_pixel_coord_upper:[u>>16,d>>16],u_pixel_coord_lower:[65535&u,65535&d]}}(0,s,a,n,l,c),{u_matrix:t,u_emissive_strength:i,u_opacity:r}),$s=new Float32Array(e.bA([])),qs=(t,i,r,n,o,s,a,l,c,h,u,d,p,f=[0,0,0],m,_,g,y=1)=>{const x=o.style.light,v=x.properties.get("position"),b=[-v.x,-v.y,v.z],w=e.dH();"viewport"===x.properties.get("anchor")&&(e.dI(w,-o.transform.angle),e.dJ(b,b,w));const T="MASK"===u.alphaMode,S=x.properties.get("color").toNonPremultipliedRenderColor(null),I=p.paint.get("model-ambient-occlusion-intensity"),E=p.paint.get("model-color").constantOr(e.C.white).toNonPremultipliedRenderColor(null);return E.a=p.paint.get("model-color-mix-intensity").constantOr(0),g&&(E.r=g[0],E.g=g[1],E.b=g[2],E.a=g[3]),_&&(E.r=_.color.r,E.g=_.color.g,E.b=_.color.b,E.a=_.colorMix,d=_.emissionStrength,s*=_.opacity),{u_matrix:t,u_lighting_matrix:i,u_normal_matrix:r,u_node_matrix:n||$s,u_lightpos:b,u_lightintensity:x.properties.get("intensity"),u_lightcolor:[S.r,S.g,S.b],u_camera_pos:f,u_opacity:s,u_baseTextureIsAlpha:0,u_alphaMask:+T,u_alphaCutoff:u.alphaCutoff,u_baseColorFactor:a.toNonPremultipliedRenderColor(null).toArray01(),u_emissiveFactor:l.toNonPremultipliedRenderColor(null).toArray01(),u_metallicFactor:c,u_roughnessFactor:h,u_baseColorTexture:5,u_metallicRoughnessTexture:6,u_normalTexture:7,u_occlusionTexture:8,u_emissionTexture:9,u_lutTexture:10,u_color_mix:E.toArray01(),u_aoIntensity:I,u_emissive_strength:d,u_occlusionTextureTransform:m||[0,0,0,0],u_dithered_discard_threshold:y}},Zs=(e,t=$s,i=$s)=>({u_matrix:e,u_instance:t,u_node_matrix:i}),Ws={fillExtrusion:t=>({u_matrix:new e.c3(t),u_lightpos:new e.c0(t),u_lightintensity:new e.c1(t),u_lightcolor:new e.c0(t),u_vertical_gradient:new e.c1(t),u_opacity:new e.c1(t),u_edge_radius:new e.c1(t),u_width_scale:new e.c1(t),u_ao:new e.c2(t),u_height_type:new e.b$(t),u_base_type:new e.b$(t),u_tile_id:new e.c0(t),u_zoom_transition:new e.c1(t),u_inv_rot_matrix:new e.c3(t),u_merc_center:new e.c2(t),u_up_dir:new e.c0(t),u_height_lift:new e.c1(t),u_flood_light_color:new e.c0(t),u_vertical_scale:new e.c1(t),u_flood_light_intensity:new e.c1(t),u_ground_shadow_factor:new e.c0(t),u_front_cutoff_params:new e.c0(t)}),fillExtrusionDepth:t=>({u_matrix:new e.c3(t),u_edge_radius:new e.c1(t),u_width_scale:new e.c1(t),u_vertical_scale:new e.c1(t),u_height_type:new e.b$(t),u_base_type:new e.b$(t)}),fillExtrusionPattern:t=>({u_matrix:new e.c3(t),u_lightpos:new e.c0(t),u_lightintensity:new e.c1(t),u_lightcolor:new e.c0(t),u_vertical_gradient:new e.c1(t),u_height_factor:new e.c1(t),u_edge_radius:new e.c1(t),u_width_scale:new e.c1(t),u_ao:new e.c2(t),u_height_type:new e.b$(t),u_base_type:new e.b$(t),u_tile_id:new e.c0(t),u_zoom_transition:new e.c1(t),u_inv_rot_matrix:new e.c3(t),u_merc_center:new e.c2(t),u_up_dir:new e.c0(t),u_height_lift:new e.c1(t),u_image:new e.b$(t),u_texsize:new e.c2(t),u_pixel_coord_upper:new e.c2(t),u_pixel_coord_lower:new e.c2(t),u_tile_units_to_pixels:new e.c1(t),u_opacity:new e.c1(t),u_pattern_transition:new e.c1(t)}),fillExtrusionGroundEffect:t=>({u_matrix:new e.c3(t),u_opacity:new e.c1(t),u_ao_pass:new e.c1(t),u_meter_to_tile:new e.c1(t),u_ao:new e.c2(t),u_flood_light_intensity:new e.c1(t),u_flood_light_color:new e.c0(t),u_attenuation:new e.c1(t),u_edge_radius:new e.c1(t),u_fb:new e.b$(t),u_fb_size:new e.c1(t),u_dynamic_offset:new e.c1(t)}),fill:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_ground_shadow_factor:new e.c0(t)}),fillPattern:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_image:new e.b$(t),u_texsize:new e.c2(t),u_pixel_coord_upper:new e.c2(t),u_pixel_coord_lower:new e.c2(t),u_tile_units_to_pixels:new e.c1(t),u_ground_shadow_factor:new e.c0(t),u_pattern_transition:new e.c1(t)}),fillOutline:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_world:new e.c2(t),u_ground_shadow_factor:new e.c0(t)}),fillOutlinePattern:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_world:new e.c2(t),u_image:new e.b$(t),u_texsize:new e.c2(t),u_pixel_coord_upper:new e.c2(t),u_pixel_coord_lower:new e.c2(t),u_tile_units_to_pixels:new e.c1(t),u_ground_shadow_factor:new e.c0(t),u_pattern_transition:new e.c1(t)}),lineBlendComposite:t=>({u_image:new e.b$(t),u_opacity:new e.c1(t),u_blend_mode:new e.b$(t),u_max_density:new e.c1(t)}),lineBlendReduce:t=>({u_image:new e.b$(t),u_texel_size:new e.c2(t),u_first_pass:new e.b$(t)}),elevatedStructuresDepth:t=>({u_matrix:new e.c3(t),u_depth_bias:new e.c1(t)}),elevatedStructures:t=>({u_matrix:new e.c3(t),u_ground_shadow_factor:new e.c0(t)}),elevatedStructuresDepthReconstruct:t=>({u_matrix:new e.c3(t),u_camera_pos:new e.c0(t),u_depth_bias:new e.c1(t),u_height_scale:new e.c1(t),u_reset_depth:new e.c1(t)}),circle:e.dR,collisionBox:t=>({u_matrix:new e.c3(t),u_inv_rot_matrix:new e.c3(t),u_camera_to_center_distance:new e.c1(t),u_extrude_scale:new e.c2(t),u_zoom_transition:new e.c1(t),u_merc_center:new e.c2(t),u_tile_id:new e.c0(t)}),collisionCircle:t=>({u_matrix:new e.c3(t),u_inv_matrix:new e.c3(t),u_camera_to_center_distance:new e.c1(t),u_viewport_size:new e.c2(t)}),debug:t=>({u_color:new e.dp(t),u_matrix:new e.c3(t),u_overlay:new e.b$(t),u_overlay_scale:new e.c1(t)}),clippingMask:t=>({u_matrix:new e.c3(t)}),heatmap:t=>({u_extrude_scale:new e.c1(t),u_intensity:new e.c1(t),u_matrix:new e.c3(t),u_inv_rot_matrix:new e.c3(t),u_merc_center:new e.c2(t),u_tile_id:new e.c0(t),u_zoom_transition:new e.c1(t),u_up_dir:new e.c0(t)}),heatmapTexture:t=>({u_image:new e.b$(t),u_color_ramp:new e.b$(t),u_opacity:new e.c1(t)}),hillshade:t=>({u_matrix:new e.c3(t),u_image:new e.b$(t),u_latrange:new e.c2(t),u_light:new e.c2(t),u_shadow:new e.dp(t),u_highlight:new e.dp(t),u_emissive_strength:new e.c1(t),u_accent:new e.dp(t)}),hillshadePrepare:t=>({u_matrix:new e.c3(t),u_image:new e.b$(t),u_dimension:new e.c2(t),u_zoom:new e.c1(t)}),line:e.dQ,linePattern:e.dP,raster:t=>({u_matrix:new e.c3(t),u_normalize_matrix:new e.c3(t),u_globe_matrix:new e.c3(t),u_merc_matrix:new e.c3(t),u_grid_matrix:new e.dq(t),u_tl_parent:new e.c2(t),u_scale_parent:new e.c1(t),u_fade_t:new e.c1(t),u_opacity:new e.c1(t),u_image0:new e.b$(t),u_image1:new e.b$(t),u_brightness_low:new e.c1(t),u_brightness_high:new e.c1(t),u_saturation_factor:new e.c1(t),u_contrast_factor:new e.c1(t),u_spin_weights:new e.c0(t),u_perspective_transform:new e.c2(t),u_raster_elevation:new e.c1(t),u_zoom_transition:new e.c1(t),u_merc_center:new e.c2(t),u_cutoff_params:new e.cS(t),u_colorization_mix:new e.cS(t),u_colorization_offset:new e.c1(t),u_color_ramp:new e.b$(t),u_texture_offset:new e.c2(t),u_texture_res:new e.c2(t),u_emissive_strength:new e.c1(t),u_zbias_factor:new e.c1(t)}),symbol:t=>({u_is_size_zoom_constant:new e.b$(t),u_is_size_feature_constant:new e.b$(t),u_size_t:new e.c1(t),u_size:new e.c1(t),u_camera_to_center_distance:new e.c1(t),u_rotate_symbol:new e.b$(t),u_aspect_ratio:new e.c1(t),u_fade_change:new e.c1(t),u_matrix:new e.c3(t),u_label_plane_matrix:new e.c3(t),u_coord_matrix:new e.c3(t),u_is_text:new e.b$(t),u_elevation_from_sea:new e.b$(t),u_pitch_with_map:new e.b$(t),u_texsize:new e.c2(t),u_texsize_icon:new e.c2(t),u_texture:new e.b$(t),u_texture_icon:new e.b$(t),u_gamma_scale:new e.c1(t),u_device_pixel_ratio:new e.c1(t),u_tile_id:new e.c0(t),u_zoom_transition:new e.c1(t),u_inv_rot_matrix:new e.c3(t),u_merc_center:new e.c2(t),u_camera_forward:new e.c0(t),u_tile_matrix:new e.c3(t),u_up_vector:new e.c0(t),u_ecef_origin:new e.c0(t),u_is_halo:new e.b$(t),u_icon_transition:new e.c1(t),u_color_adj_mat:new e.c3(t),u_scale_factor:new e.c1(t),u_ground_shadow_factor:new e.c0(t),u_inv_matrix:new e.c3(t),u_normal_scale:new e.c1(t),u_lutTexture:new e.b$(t),u_zoom:new e.c1(t),u_spp_fill_np_color:new e.cS(t),u_spp_halo_np_color:new e.cS(t),u_spp_opacity:new e.c1(t),u_spp_halo_width:new e.c1(t),u_spp_halo_blur:new e.c1(t),u_spp_emissive_strength:new e.c1(t),u_spp_occlusion_opacity:new e.c1(t),u_spp_z_offset:new e.c1(t),u_spp_translate_rotation:new e.c2(t)}),background:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_opacity:new e.c1(t),u_color:new e.dp(t)}),backgroundPattern:t=>({u_matrix:new e.c3(t),u_emissive_strength:new e.c1(t),u_opacity:new e.c1(t),u_image:new e.b$(t),u_pattern_tl:new e.c2(t),u_pattern_br:new e.c2(t),u_texsize:new e.c2(t),u_pattern_size:new e.c2(t),u_pixel_coord_upper:new e.c2(t),u_pixel_coord_lower:new e.c2(t),u_pattern_units_to_pixels:new e.c2(t)}),terrainRaster:t=>({u_matrix:new e.c3(t),u_image0:new e.b$(t),u_image1:new e.b$(t),u_skirt_height:new e.c1(t),u_ground_shadow_factor:new e.c0(t),u_emissive_texture_available:new e.c1(t)}),skybox:t=>({u_matrix:new e.c3(t),u_sun_direction:new e.c0(t),u_cubemap:new e.b$(t),u_opacity:new e.c1(t),u_temporal_offset:new e.c1(t)}),skyboxGradient:t=>({u_matrix:new e.c3(t),u_color_ramp:new e.b$(t),u_center_direction:new e.c0(t),u_radius:new e.c1(t),u_opacity:new e.c1(t),u_temporal_offset:new e.c1(t)}),skyboxCapture:t=>({u_matrix_3f:new e.dq(t),u_sun_direction:new e.c0(t),u_sun_intensity:new e.c1(t),u_color_tint_r:new e.cS(t),u_color_tint_m:new e.cS(t),u_luminance:new e.c1(t)}),globeRaster:t=>({u_proj_matrix:new e.c3(t),u_globe_matrix:new e.c3(t),u_normalize_matrix:new e.c3(t),u_merc_matrix:new e.c3(t),u_zoom_transition:new e.c1(t),u_merc_center:new e.c2(t),u_image0:new e.b$(t),u_image1:new e.b$(t),u_grid_matrix:new e.dq(t),u_skirt_height:new e.c1(t),u_far_z_cutoff:new e.c1(t),u_frustum_tl:new e.c0(t),u_frustum_tr:new e.c0(t),u_frustum_br:new e.c0(t),u_frustum_bl:new e.c0(t),u_globe_pos:new e.c0(t),u_globe_radius:new e.c1(t),u_viewport:new e.c2(t),u_emissive_texture_available:new e.c1(t)}),globeAtmosphere:t=>({u_frustum_tl:new e.c0(t),u_frustum_tr:new e.c0(t),u_frustum_br:new e.c0(t),u_frustum_bl:new e.c0(t),u_horizon:new e.c1(t),u_transition:new e.c1(t),u_fadeout_range:new e.c1(t),u_atmosphere_fog_color:new e.cS(t),u_high_color:new e.cS(t),u_space_color:new e.cS(t),u_temporal_offset:new e.c1(t),u_horizon_angle:new e.c1(t)}),model:t=>({u_matrix:new e.c3(t),u_lighting_matrix:new e.c3(t),u_normal_matrix:new e.c3(t),u_node_matrix:new e.c3(t),u_lightpos:new e.c0(t),u_lightintensity:new e.c1(t),u_lightcolor:new e.c0(t),u_camera_pos:new e.c0(t),u_opacity:new e.c1(t),u_baseColorFactor:new e.cS(t),u_emissiveFactor:new e.cS(t),u_metallicFactor:new e.c1(t),u_roughnessFactor:new e.c1(t),u_baseTextureIsAlpha:new e.b$(t),u_alphaMask:new e.b$(t),u_alphaCutoff:new e.c1(t),u_baseColorTexture:new e.b$(t),u_metallicRoughnessTexture:new e.b$(t),u_normalTexture:new e.b$(t),u_occlusionTexture:new e.b$(t),u_emissionTexture:new e.b$(t),u_lutTexture:new e.b$(t),u_color_mix:new e.cS(t),u_aoIntensity:new e.c1(t),u_emissive_strength:new e.c1(t),u_occlusionTextureTransform:new e.cS(t),u_dithered_discard_threshold:new e.c1(t)}),modelDepth:t=>({u_matrix:new e.c3(t),u_instance:new e.c3(t),u_node_matrix:new e.c3(t)}),groundShadow:t=>({u_matrix:new e.c3(t),u_ground_shadow_factor:new e.c0(t)}),stars:t=>({u_matrix:new e.c3(t),u_up:new e.c0(t),u_right:new e.c0(t),u_intensity_multiplier:new e.c1(t)}),occlusion:t=>({u_matrix:new e.c3(t),u_anchorPos:new e.c0(t),u_screenSizePx:new e.c2(t),u_occluderSizePx:new e.c2(t),u_color:new e.cS(t)})};class Xs{constructor(e,t,i,r){this.id=Xs.uniqueIdxCounter,Xs.uniqueIdxCounter++,this.context=e;const n=e.gl;this.buffer=n.createBuffer(),this.dynamicDraw=Boolean(i),this.context.unbindVAO(),e.bindElementBuffer.set(this.buffer),n.bufferData(n.ELEMENT_ARRAY_BUFFER,t.arrayBuffer,this.dynamicDraw?n.DYNAMIC_DRAW:n.STATIC_DRAW),this.dynamicDraw||r||t.destroy()}bind(){this.context.bindElementBuffer.set(this.buffer)}updateData(e){this.id=Xs.uniqueIdxCounter,Xs.uniqueIdxCounter++;const t=this.context.gl;this.context.unbindVAO(),this.bind(),t.bufferSubData(t.ELEMENT_ARRAY_BUFFER,0,e.arrayBuffer)}destroy(){this.buffer&&(this.context.gl.deleteBuffer(this.buffer),delete this.buffer)}}Xs.uniqueIdxCounter=0;const Ys={Int8:"BYTE",Uint8:"UNSIGNED_BYTE",Int16:"SHORT",Uint16:"UNSIGNED_SHORT",Int32:"INT",Uint32:"UNSIGNED_INT",Float32:"FLOAT"};class Js{constructor(e,t,i,r,n,o){this.length=t.length,this.attributes=i,this.itemSize=t.bytesPerElement,this.dynamicDraw=r,this.instanceCount=o,this.context=e;const s=e.gl;this.buffer=s.createBuffer(),e.bindVertexBuffer.set(this.buffer),s.bufferData(s.ARRAY_BUFFER,t.arrayBuffer,this.dynamicDraw?s.DYNAMIC_DRAW:s.STATIC_DRAW),this.dynamicDraw||n||t.destroy()}bind(){this.context.bindVertexBuffer.set(this.buffer)}updateData(e){const t=this.context.gl;this.bind(),t.bufferSubData(t.ARRAY_BUFFER,0,e.arrayBuffer)}enableAttributes(e,t){for(const i of this.attributes){const r=t.getAttributeLocation(e,i.name);-1!==r&&e.enableVertexAttribArray(r)}}setVertexAttribPointers(e,t,i){for(const r of this.attributes){const n=t.getAttributeLocation(e,r.name);if(-1!==n){const t=r.offset+this.itemSize*(i||0);"Float32"===r.type?e.vertexAttribPointer(n,r.components,e.FLOAT,!1,this.itemSize,t):e.vertexAttribIPointer(n,r.components,e[Ys[r.type]],this.itemSize,t)}}}setVertexAttribDivisor(e,t,i){for(let r=0;r<this.attributes.length;r++){const n=t.getAttributeLocation(e,this.attributes[r].name);-1!==n&&this.instanceCount&&this.instanceCount>0&&e.vertexAttribDivisor(n,i)}}destroy(){this.buffer&&(this.context.gl.deleteBuffer(this.buffer),delete this.buffer)}}class Ks{constructor(e,t,i,r,n){this.context=e,this.width=t,this.height=i;const o=this.framebuffer=e.gl.createFramebuffer();r>0&&(this.colorAttachment0=new Yo(e,o,0)),r>1&&(this.colorAttachment1=new Yo(e,o,1)),n&&(this.depthAttachmentType=n,this.depthAttachment="renderbuffer"===n?new Jo(e,o):new Ko(e,o))}static createWithTexture(t,i,r,n,o){const s=t.gl;if(t.activeTexture.set(s.TEXTURE1),t.viewport.set([0,0,r,n]),i&&i.width===r&&i.height===n)return s.bindTexture(s.TEXTURE_2D,i.colorAttachment0.get()),t.bindFramebuffer.set(i.framebuffer),i;i&&i.destroy();const a=t.extRenderToTextureHalfFloat||t.extColorBufferFloat?t.gl.RGBA16F:t.gl.RGBA8,l=new e.T(t,{width:r,height:n,data:null},a);l.bind(s.LINEAR,s.CLAMP_TO_EDGE);const c=t.createFramebuffer(r,n,1,null);if(c.format=a,c.colorAttachment0.set(l.texture),o){const e=t.createRenderbuffer(s.DEPTH24_STENCIL8,r,n);t.bindFramebuffer.set(c.framebuffer),s.framebufferRenderbuffer(s.FRAMEBUFFER,s.DEPTH_STENCIL_ATTACHMENT,s.RENDERBUFFER,e),c._stencilRbo=e}return c}createColorAttachment(e,t){0===t?this.colorAttachment0=new Yo(e,this.framebuffer,0):1===t&&(this.colorAttachment1=new Yo(e,this.framebuffer,1))}removeColorAttachment(e,t){const i=this.context.gl;let r;0===t?(r=this.colorAttachment0.get(),this.colorAttachment0=void 0):1===t&&(r=this.colorAttachment1.get(),this.colorAttachment1=void 0),r&&i.deleteTexture(r)}destroy(){const e=this.context.gl;if(this.colorAttachment0){const t=this.colorAttachment0.get();t&&e.deleteTexture(t)}if(this.colorAttachment1){const t=this.colorAttachment1.get();t&&e.deleteTexture(t)}if(this.depthAttachment&&this.depthAttachmentType)if("renderbuffer"===this.depthAttachmentType){const t=this.depthAttachment.get();t&&e.deleteRenderbuffer(t)}else{const t=this.depthAttachment.get();t&&e.deleteTexture(t)}this._stencilRbo&&(e.deleteRenderbuffer(this._stencilRbo),this._stencilRbo=null),e.deleteFramebuffer(this.framebuffer)}}class Qs{constructor(e,t){this.gl=e,this._pendingPrograms=/* @__PURE__ */new Set,this._compileStats={precompiled:0,onDemand:0,totalStallMs:0,maxStallMs:0,framesMissed:0,stalls:[]},this.clearColor=new yo(this),this.clearDepth=new xo(this),this.clearStencil=new vo(this),this.colorMask=new bo(this),this.depthMask=new wo(this),this.stencilMask=new To(this),this.stencilFunc=new So(this),this.stencilOp=new Io(this),this.stencilTest=new Eo(this),this.depthRange=new Ao(this),this.depthTest=new Mo(this),this.depthFunc=new Co(this),this.blend=new Po(this),this.blendFunc=new Do(this),this.blendColor=new Ro(this),this.blendEquation=new zo(this),this.cullFace=new Lo(this),this.cullFaceSide=new Fo(this),this.frontFace=new Oo(this),this.program=new Bo(this),this.activeTexture=new ko(this),this.viewport=new No(this),this.bindFramebuffer=new Uo(this),this.bindRenderbuffer=new Vo(this),this.bindTexture=new jo(this),this.bindVertexBuffer=new Go(this),this.bindElementBuffer=new Ho(this),this.bindVertexArrayOES=new $o(this),this.pixelStoreUnpack=new qo(this),this.pixelStoreUnpackPremultiplyAlpha=new Zo(this),this.pixelStoreUnpackFlipY=new Wo(this),this.options=t?Object.assign({},t):{},this.options.extTextureFilterAnisotropicForceOff||(this.extTextureFilterAnisotropic=e.getExtension("EXT_texture_filter_anisotropic")||e.getExtension("MOZ_EXT_texture_filter_anisotropic")||e.getExtension("WEBKIT_EXT_texture_filter_anisotropic"),this.extTextureFilterAnisotropic&&(this.extTextureFilterAnisotropicMax=e.getParameter(this.extTextureFilterAnisotropic.MAX_TEXTURE_MAX_ANISOTROPY_EXT))),this.extDebugRendererInfo=e.getExtension("WEBGL_debug_renderer_info"),this.extDebugRendererInfo&&(this.renderer=e.getParameter(this.extDebugRendererInfo.UNMASKED_RENDERER_WEBGL),this.vendor=e.getParameter(this.extDebugRendererInfo.UNMASKED_VENDOR_WEBGL)),this.forceManualRenderingForInstanceIDShaders=t&&!!t.forceManualRenderingForInstanceIDShaders||this.renderer&&this.renderer.includes("PowerVR"),this.disableSymbolUBO=t&&!!t.forceDisableSymbolUBO,this.options.extTextureFloatLinearForceOff||(this.extTextureFloatLinear=e.getExtension("OES_texture_float_linear")),this.extRenderToTextureHalfFloat=e.getExtension("EXT_color_buffer_half_float"),this.extColorBufferFloat=e.getExtension("EXT_color_buffer_float"),this.extTimerQuery=e.getExtension("EXT_disjoint_timer_query_webgl2"),this.maxTextureSize=e.getParameter(e.MAX_TEXTURE_SIZE),this.maxUniformBlockSize=Math.min(e.getParameter(e.MAX_UNIFORM_BLOCK_SIZE),32768),this.maxUniformBufferBindings=e.getParameter(e.MAX_UNIFORM_BUFFER_BINDINGS),this.extBlendFuncExtended=e.getExtension("WEBGL_blend_func_extended"),this.extParallelShaderCompile=e.getExtension("KHR_parallel_shader_compile")}sweepPendingPrograms(){if(0!==this._pendingPrograms.size)for(const e of this._pendingPrograms)e.maybeFinalize()}setDefault(){this.unbindVAO(),this.clearColor.setDefault(),this.clearDepth.setDefault(),this.clearStencil.setDefault(),this.colorMask.setDefault(),this.depthMask.setDefault(),this.stencilMask.setDefault(),this.stencilFunc.setDefault(),this.stencilOp.setDefault(),this.stencilTest.setDefault(),this.depthRange.setDefault(),this.depthTest.setDefault(),this.depthFunc.setDefault(),this.blend.setDefault(),this.blendFunc.setDefault(),this.blendColor.setDefault(),this.blendEquation.setDefault(),this.cullFace.setDefault(),this.cullFaceSide.setDefault(),this.frontFace.setDefault(),this.program.setDefault(),this.activeTexture.setDefault(),this.bindFramebuffer.setDefault(),this.pixelStoreUnpack.setDefault(),this.pixelStoreUnpackPremultiplyAlpha.setDefault(),this.pixelStoreUnpackFlipY.setDefault()}setDirty(){this.clearColor.dirty=!0,this.clearDepth.dirty=!0,this.clearStencil.dirty=!0,this.colorMask.dirty=!0,this.depthMask.dirty=!0,this.stencilMask.dirty=!0,this.stencilFunc.dirty=!0,this.stencilOp.dirty=!0,this.stencilTest.dirty=!0,this.depthRange.dirty=!0,this.depthTest.dirty=!0,this.depthFunc.dirty=!0,this.blend.dirty=!0,this.blendFunc.dirty=!0,this.blendColor.dirty=!0,this.blendEquation.dirty=!0,this.cullFace.dirty=!0,this.cullFaceSide.dirty=!0,this.frontFace.dirty=!0,this.program.dirty=!0,this.activeTexture.dirty=!0,this.viewport.dirty=!0,this.bindFramebuffer.dirty=!0,this.bindRenderbuffer.dirty=!0,this.bindTexture.dirty=!0,this.bindVertexBuffer.dirty=!0,this.bindElementBuffer.dirty=!0,this.bindVertexArrayOES.dirty=!0,this.pixelStoreUnpack.dirty=!0,this.pixelStoreUnpackPremultiplyAlpha.dirty=!0,this.pixelStoreUnpackFlipY.dirty=!0}createIndexBuffer(e,t,i){return new Xs(this,e,t,i)}createVertexBuffer(e,t,i,r,n){return new Js(this,e,t,i,r,n)}createRenderbuffer(e,t,i){const r=this.gl,n=r.createRenderbuffer();return this.bindRenderbuffer.set(n),r.renderbufferStorage(r.RENDERBUFFER,e,t,i),this.bindRenderbuffer.set(null),n}createFramebuffer(e,t,i,r){return new Ks(this,e,t,i,r)}clear({color:e,depth:t,stencil:i,colorMask:r}){const n=this.gl;let o=0;e&&(o|=n.COLOR_BUFFER_BIT,this.clearColor.set(e.toNonPremultipliedRenderColor(null)),this.colorMask.set(r||[!0,!0,!0,!0])),void 0!==t&&(o|=n.DEPTH_BUFFER_BIT,this.depthRange.set([0,1]),this.clearDepth.set(t),this.depthMask.set(!0)),void 0!==i&&(o|=n.STENCIL_BUFFER_BIT,this.clearStencil.set(i),this.stencilMask.set(255)),n.clear(o)}setCullFace(e){!1===e.enable?this.cullFace.set(!1):(this.cullFace.set(!0),this.cullFaceSide.set(e.mode),this.frontFace.set(e.frontFace))}setDepthMode(e){e.func!==this.gl.ALWAYS||e.mask?(this.depthTest.set(!0),this.depthFunc.set(e.func),this.depthMask.set(e.mask),this.depthRange.set(e.range)):this.depthTest.set(!1)}setStencilMode(e){e.test.func!==this.gl.ALWAYS||e.mask?(this.stencilTest.set(!0),this.stencilMask.set(e.mask),this.stencilOp.set([e.fail,e.depthFail,e.pass]),this.stencilFunc.set({func:e.test.func,ref:e.ref,mask:e.test.mask})):this.stencilTest.set(!1)}setColorMode(t){e.b9(t.blendFunction,Hr.Replace)?this.blend.set(!1):(this.blend.set(!0),this.blendFunc.set(t.blendFunction),this.blendColor.set(t.blendColor),t.blendEquation?this.blendEquation.set(t.blendEquation):this.blendEquation.setDefault()),this.colorMask.set(t.mask)}unbindVAO(){this.bindVertexArrayOES.set(null)}}let ea;function ta(t,i,r,n,o,s,a){const l=t.context,c=l.gl,h=t.transform,u=[e.aG(h.center.lng),e.aJ(h.center.lat)],d=r.layout.get("symbol-placement"),p=r.layout.get("text-variable-anchor"),f="map"===r.layout.get("icon-rotation-alignment"),m="map"===r.layout.get("text-rotation-alignment"),_="point"!==d,g=[];let y=0,x=0;for(let I=0;I<n.length;I++){const l=n[I],d=i.getTile(l),v=d.getBucket(r);if(!v)continue;const b=v.getProjection().createInversionMatrix(h,l.canonical),w=[],T=Xi(l,v,h),S=!a&&f&&_,E=a&&m&&_,A=p&&v.hasTextData(),M=v.hasIconTextFit()&&A&&v.hasIconData(),C=S||E||a&&A||M,P="globe"===v.projection.name,D=P?e.ai(h.zoom):0;P&&(w.push("PROJECTION_GLOBE_VIEW"),C&&w.push("PROJECTED_POS_ON_VIEWPORT"));const R=t.getOrCreateProgram("collisionBox",{defines:w});let z=T;0===o[0]&&0===o[1]||(z=t.translatePosMatrix(T,d,o,s));const L=a?v.textCollisionBox:v.iconCollisionBox,F=v.collisionCircleArray;if(F.length>0){const t=e.bd(),i=z;e.cB(t,v.placementInvProjMatrix,h.glCoordMatrix),e.cB(t,t,v.placementViewportMatrix),g.push({circleArray:F,circleOffset:x,transform:i,invTransform:t,projection:v.getProjection()}),y+=F.length/4,x=y}if(!L)continue;t.terrain&&t.terrain.setupElevationDraw(d,R);const O=P?[l.canonical.x,l.canonical.y,1<<l.canonical.z]:[0,0,0];R.draw(t,c.LINES,$r.disabled,Zr.disabled,t.colorModeForRenderPass(),Yr.disabled,Ds(z,b,h,D,u,d,O,v.getProjection()),r.id,L.layoutVertexBuffer,L.indexBuffer,L.segments,null,h.zoom,null,[L.collisionVertexBuffer,L.collisionVertexBufferExt])}if(!a||!g.length)return;const v=t.getOrCreateProgram("collisionCircle"),b=new e.dS;b.resize(4*y),b._trim();let w=0;for(const e of g)for(let t=0;t<e.circleArray.length/4;t++){const i=4*t,r=e.circleArray[i+0],n=e.circleArray[i+1],o=e.circleArray[i+2],s=e.circleArray[i+3];b.emplace(w++,r,n,o,s,0),b.emplace(w++,r,n,o,s,1),b.emplace(w++,r,n,o,s,2),b.emplace(w++,r,n,o,s,3)}(!ea||ea.length<2*y)&&(ea=function(t){const i=2*t,r=new e.dF;r.resize(i),r._trim();for(let e=0;e<i;e++){const t=6*e;r.uint16[t+0]=4*e+0,r.uint16[t+1]=4*e+1,r.uint16[t+2]=4*e+2,r.uint16[t+3]=4*e+2,r.uint16[t+4]=4*e+3,r.uint16[t+5]=4*e+0}return r}(y));const T=l.createIndexBuffer(ea,!0),S=l.createVertexBuffer(b,e.dT.members,!0);for(const I of g){const i=Rs(I.transform,I.invTransform,h,I.projection);v.draw(t,c.TRIANGLES,$r.disabled,Zr.disabled,t.colorModeForRenderPass(),Yr.disabled,i,r.id,S,T,e.dB.simpleSegment(0,2*I.circleOffset,I.circleArray.length,I.circleArray.length/2),null,h.zoom)}S.destroy(),T.destroy()}const ia=e.bd();function ra(t){const i=t._camera.getWorldToCamera(t.worldSize,1),r=e.aC([],i,t.globeMatrix);e.ba(r,r);const n=[0,0,0],o=[0,1,0,0];return e.aD(o,o,r),n[0]=o[0],n[1]=o[1],n[2]=o[2],e.ax(n,n),n}function na({width:t,height:i,anchor:r,textOffset:n,textScale:o},s){const{horizontalAlign:a,verticalAlign:l}=e.bJ(r),c=-(a-.5)*t,h=-(l-.5)*i,u=e.bK(r,n);return new e.P((c/o+u[0])*s,(h/o+u[1])*s)}function oa(t,i,r,n,o,s,a,l,c,h){const u=t.text.placedSymbolArray,d=t.text.dynamicLayoutVertexArray,p=t.icon.dynamicLayoutVertexArray,f={},m=t.getProjection(),_=Yi(a,m,o),g=o.elevation,y=m.upVectorScale(a.canonical,o.center.lat,o.worldSize).metersToTile;d.clear();for(let x=0;x<u.length;x++){const p=u.get(x),{tileAnchorX:v,tileAnchorY:b,numGlyphs:w}=p,T=p.hidden||!p.crossTileID||t.allowVerticalPlacement&&!p.placedOrientation?null:n[p.crossTileID];if(T){let n=0,u=0,S=0;const I="road"===t.elevationType;if(g||I){const i=I?t.getElevationFeatureForText(x):null,r=e.bx.getAtTileOffset(a,new e.P(v,b),g,i),[o,s,l]=m.upVector(a.canonical,v,b);n=r*o*y,u=r*s*y,S=r*l*y}let[E,A,M,C]=ir(p.projectedAnchorX+n,p.projectedAnchorY+u,p.projectedAnchorZ+S,r?_:s);const P=rr(o.getCameraToCenterDistance(m),C);let D=e.bn(t.textSizeData,c,p)*P/e.bC;r&&(D*=t.tilePixelRatio/l);const R=na(T,D);r?(({x:E,y:A,z:M}=m.projectTilePoint(v+R.x,b+R.y,a.canonical)),[E,A,M]=ir(E+n,A+u,M+S,s)):(i&&R._rotate(-o.angle),E+=R.x,A+=R.y,M=0);const z=t.allowVerticalPlacement&&p.placedOrientation===e.bm.vertical?Math.PI/2:0;for(let t=0;t<w;t++)e.bp(d,E,A,M,z);h&&p.associatedIconIndex>=0&&(f[p.associatedIconIndex]={x:E,y:A,z:M,angle:z})}else dr(w,d)}if(h){p.clear();const i=t.icon.placedSymbolArray;for(let t=0;t<i.length;t++){const r=i.get(t),{numGlyphs:n}=r,o=f[t];if(r.hidden||!o)dr(n,p);else{const{x:t,y:i,z:r,angle:s}=o;for(let o=0;o<n;o++)e.bp(p,t,i,r,s)}}t.icon.dynamicLayoutVertexBuffer.updateData(p)}t.text.dynamicLayoutVertexBuffer.updateData(d)}function sa(t,i,r,n,o,s,a={}){const l=r.paint.get("icon-translate"),c=r.paint.get("text-translate"),h=r.paint.get("icon-translate-anchor"),u=r.paint.get("text-translate-anchor"),d=r.layout.get("icon-rotation-alignment"),p=r.layout.get("text-rotation-alignment"),f=r.layout.get("icon-pitch-alignment"),m=r.layout.get("text-pitch-alignment"),_=r.layout.get("icon-keep-upright"),g=r.layout.get("text-keep-upright"),y=r.paint.get("icon-color-saturation"),x=r.paint.get("icon-color-contrast"),v=r.paint.get("icon-color-brightness-min"),b=r.paint.get("icon-color-brightness-max"),w="sea"===r.layout.get("symbol-elevation-reference"),T="none"===r.layout.get("icon-image-use-theme"),S=t.context,I=S.gl,E=t.transform,A="map"===d,M="map"===p,C="map"===f,P="map"===m,D=void 0!==r.layout.get("symbol-sort-key").constantOr(1);let R=!1;const z=t.depthModeForSublayer(0,$r.ReadOnly),L=new $r(t.context.gl.LEQUAL,$r.ReadOnly,t.depthRangeFor3D),F=[e.aG(E.center.lng),e.aJ(E.center.lat)],O=r.layout.get("text-variable-anchor"),B="globe"===E.projection.name,k=[],N=[0,-1,0];for(const U of n){const n=i.getTile(U),o=n.getBucket(r);if(!o)continue;if("mercator"===o.projection.name&&B)continue;if(o.fullyClipped)continue;const s="globe"===o.projection.name,d=s?e.ai(E.zoom):0,p=Yi(U,o.getProjection(),E),f=E.calculatePixelsToTileUnitsMatrix(n),m=O&&o.hasTextData(),V=o.hasIconTextFit()&&m&&o.hasIconData(),j=o.getProjection().createInversionMatrix(E,U.canonical),G=(1<<n.tileID.canonical.z)*e.ak/t.transform.worldSize,H=e=>{let i=[0,0,0];if(e){const e=t.style.directionalLight,r=t.style.ambientLight;e&&r&&(i=mn(t.style,e,r))}return i},$=e=>{if(t.context.disableSymbolUBO)return;e.push("USE_PAINT_PROPERTIES_UBO");const i=Math.floor(t.context.maxUniformBlockSize/4),r=Math.floor(i/4);e.push(`MAX_UBO_SIZE_VEC4 ${r}u`)},q=e=>{E.depthOcclusionForSymbolsAndCircles&&(r.hasOcclusionOpacityProperties||t.terrain)&&(e.push("DEPTH_D24"),e.push("DEPTH_OCCLUSION"))},Z=i=>{r.lut&&!T&&(r.lut.texture||(r.lut.texture=new e.dU(t.context,r.lut.image,[r.lut.image.height,r.lut.image.height,r.lut.image.height],S.gl.RGBA8)),S.activeTexture.set(S.gl.TEXTURE0+10),r.lut.texture&&r.lut.texture.bind(S.gl.LINEAR,S.gl.CLAMP_TO_EDGE),i.push("APPLY_LUT_ON_GPU"))},W=()=>{const i=A&&"point"!==r.layout.get("symbol-placement"),a=[];q(a),Z(a);const c=i||V,u="road"===o.elevationType,m=t.shadowRenderer,g=u&&C&&!!m&&m.enabled,T=H(g),M=u&&C&&!t.terrain?L:z,P=r.paint.get("icon-image-cross-fade");t.terrainRenderModeElevated()&&C&&a.push("PITCH_WITH_MAP_TERRAIN"),s&&(a.push("PROJECTION_GLOBE_VIEW"),c&&a.push("PROJECTED_POS_ON_VIEWPORT")),P>0&&o.hasAnySecondaryIcon&&a.push("ICON_TRANSITION"),!o.icon.zOffsetVertexBuffer||u&&t.terrain||a.push("Z_OFFSET"),0===y&&0===x&&0===v&&1===b||a.push("COLOR_ADJUSTMENT"),o.sdfIcons&&a.push("RENDER_SDF"),g&&a.push("RENDER_SHADOWS","NORMAL_OFFSET"),u&&C&&!t.terrain&&o.icon.orientationVertexBuffer&&a.push("ELEVATED_ROADS"),$(a);const D=S.disableSymbolUBO?o.icon.programConfigurations.get(r.id):null,R=t.getOrCreateProgram("symbol",{config:D,defines:a}),O=n.imageAtlasTexture?n.imageAtlasTexture.size:[0,0],k=o.iconSizeData,W=e.bl(k,E.zoom),X=C||!E.isOrthographic,Y=Qi(p,n.tileID.canonical,C,A,E,o.getProjection(),f),J=tr(p,n.tileID.canonical,C,A,E,o.getProjection(),f),K=o.icon.uboBinder&&o.icon.uboBinder.cachedHeader&&256&o.icon.uboBinder.cachedHeader.dataDrivenMask?[0,0]:l,Q=t.translatePosMatrix(J,n,K,h,!0),ee=t.translatePosMatrix(p,n,K,h),te=c?ia:Y,ie=A&&!C&&!i;let re=N;!B&&!E.mercatorFromTransition||A||(re=ra(E));const ne=s?re:N,oe=r.getColorAdjustmentMatrix(y,x,v,b),se=js(k.kind,W,ie,C,t,ee,te,Q,w,!1,O,[0,0],0,U,d,F,j,ne,o.getProjection(),T,G,oe,P,null),ae=n.imageAtlasTexture?n.imageAtlasTexture:null,le=1!==r.layout.get("icon-size").constantOr(0)||o.iconsNeedLinear,ce=o.sdfIcons||t.options.rotating||t.options.zooming||le||X?I.LINEAR:I.NEAREST,he=o.sdfIcons&&0!==r.paint.get("icon-halo-width").constantOr(1),ue=t.terrain&&C&&i?e.ba(e.bd(),Y):ia;if(i&&o.icon){const i=e.bx.getAtTileOffsetFunc(U,E.center.lat,E.worldSize,o.getProjection()),s=er(p,n.tileID.canonical,C,A,E,o.getProjection(),f),a=r.layout.get("icon-size-scale-range");or(o,p,t,!1,s,J,C,_,i,U,e.aB(t.scaleFactor,a[0],a[1]))}return{program:R,buffers:o.icon,uniformValues:se,atlasTexture:ae,atlasTextureIcon:null,atlasInterpolation:ce,atlasInterpolationIcon:null,isSDF:o.sdfIcons,hasHalo:he,depthMode:M,tile:n,renderWithShadows:g,labelPlaneMatrixInv:ue}},X=()=>{const i=M&&"point"!==r.layout.get("symbol-placement"),a=[],l=i||O||V,h="road"===o.elevationType,m=t.shadowRenderer,_=h&&P&&!!m&&m.enabled,y=H(_),x=h&&P&&!t.terrain?L:z;t.terrainRenderModeElevated()&&P&&a.push("PITCH_WITH_MAP_TERRAIN"),s&&(a.push("PROJECTION_GLOBE_VIEW"),l&&a.push("PROJECTED_POS_ON_VIEWPORT")),!o.text.zOffsetVertexBuffer||h&&t.terrain||a.push("Z_OFFSET"),o.iconsInText&&a.push("RENDER_TEXT_AND_SYMBOL"),a.push("RENDER_SDF"),_&&a.push("RENDER_SHADOWS","NORMAL_OFFSET"),h&&P&&!t.terrain&&o.text.orientationVertexBuffer&&a.push("ELEVATED_ROADS"),q(a),$(a);const v=S.disableSymbolUBO?o.text.programConfigurations.get(r.id):null,b=t.getOrCreateProgram("symbol",{config:v,defines:a});let T,A=[0,0],C=null;const D=o.textSizeData;o.iconsInText&&(A=n.imageAtlasTexture?n.imageAtlasTexture.size:[0,0],C=n.imageAtlasTexture?n.imageAtlasTexture:null,T=P||!E.isOrthographic||t.options.rotating||t.options.zooming||"composite"===D.kind||"camera"===D.kind?I.LINEAR:I.NEAREST);const R=n.glyphAtlasTexture?n.glyphAtlasTexture.size:[0,0],k=r.layout.get("text-size-scale-range"),Z=e.aB(t.scaleFactor,k[0],k[1]),W=e.bl(D,E.zoom,Z),X=Qi(p,n.tileID.canonical,P,M,E,o.getProjection(),f),Y=tr(p,n.tileID.canonical,P,M,E,o.getProjection(),f),J=o.text.uboBinder&&o.text.uboBinder.cachedHeader&&256&o.text.uboBinder.cachedHeader.dataDrivenMask?[0,0]:c,K=t.translatePosMatrix(Y,n,J,u,!0),Q=t.translatePosMatrix(p,n,J,u),ee=l?ia:X,te=M&&!P&&!i;let ie=N;!B&&!E.mercatorFromTransition||M||(ie=ra(E));const re=js(D.kind,W,te,P,t,Q,ee,K,w,!0,R,A,0,U,d,F,j,s?ie:N,o.getProjection(),y,G,null,null,Z),ne=n.glyphAtlasTexture?n.glyphAtlasTexture:null,oe=I.LINEAR,se=0!==r.paint.get("text-halo-width").constantOr(1),ae=t.terrain&&P&&i?e.ba(e.bd(),X):ia;if(i&&o.text){const i=e.bx.getAtTileOffsetFunc(U,E.center.lat,E.worldSize,o.getProjection());or(o,p,t,!0,er(p,n.tileID.canonical,P,M,E,o.getProjection(),f),Y,P,g,i,U,Z)}return{program:b,buffers:o.text,uniformValues:re,atlasTexture:ne,atlasTextureIcon:C,atlasInterpolation:oe,atlasInterpolationIcon:T,isSDF:!0,hasHalo:se,depthMode:x,tile:n,renderWithShadows:_,labelPlaneMatrixInv:ae}},Y=o.icon.segments.get().length,J=o.text.segments.get().length,K=Y&&!a.onlyText?W():null,Q=J&&!a.onlyIcons?X():null,ee=r.paint.get("icon-opacity").constantOr(1),te=r.paint.get("text-opacity").constantOr(1);if(D&&o.canOverlap){R=!0;const t=ee&&!a.onlyText?o.icon.segments.get():[],i=te&&!a.onlyIcons?o.text.segments.get():[];for(const r of t)k.push({segments:new e.dB([r]),sortKey:r.sortKey,state:K});for(const r of i)k.push({segments:new e.dB([r]),sortKey:r.sortKey,state:Q})}else a.onlyText||k.push({segments:ee?o.icon.segments:new e.dB([]),sortKey:0,state:K}),a.onlyIcons||k.push({segments:te?o.text.segments:new e.dB([]),sortKey:0,state:Q})}R&&k.sort((e,t)=>e.sortKey-t.sortKey);for(const e of k){const i=e.state;if(i)if(t.terrain?t.terrain.setupElevationDraw(i.tile,i.program,{useDepthForOcclusion:E.depthOcclusionForSymbolsAndCircles,labelPlaneMatrixInv:i.labelPlaneMatrixInv}):t.setupDepthForOcclusion(E.depthOcclusionForSymbolsAndCircles,i.program),S.activeTexture.set(I.TEXTURE0),i.atlasTexture&&i.atlasTexture.bind(i.atlasInterpolation,I.CLAMP_TO_EDGE,!0),i.atlasTextureIcon&&(S.activeTexture.set(I.TEXTURE1),i.atlasTextureIcon&&i.atlasTextureIcon.bind(i.atlasInterpolationIcon,I.CLAMP_TO_EDGE,!0)),i.renderWithShadows&&t.shadowRenderer.setupShadows(i.tile.tileID.toUnwrapped(),i.program,"vector-tile"),t.uploadCommonLightUniforms(t.context,i.program),i.hasHalo){const n=i.uniformValues;n.u_is_halo=1,aa(i.buffers,e.segments,r,t,i.program,i.depthMode,o,s,n,2),n.u_is_halo=0}else{if(i.isSDF){const n=i.uniformValues;i.hasHalo&&(n.u_is_halo=1,aa(i.buffers,e.segments,r,t,i.program,i.depthMode,o,s,n,1)),n.u_is_halo=0}aa(i.buffers,e.segments,r,t,i.program,i.depthMode,o,s,i.uniformValues,1)}}}function aa(e,t,i,r,n,o,s,a,l,c){const h=r.context,u=h.gl,d=[e.dynamicLayoutVertexBuffer,e.opacityVertexBuffer,e.iconTransitioningVertexBuffer,e.globeExtVertexBuffer,e.zOffsetVertexBuffer,e.orientationVertexBuffer];e.featureIdBuffer&&d.push(e.featureIdBuffer);const p=e.uboBinder?null:e.programConfigurations.get(i.id);if(e.uboBinder){e.uboBinder.layer=i;const t=r.transform.zoom,n=r.style.getBrightness?r.style.getBrightness():null,o=e.uboBinder.getConstantUniformValues(t,n);l.u_spp_fill_np_color=o.fill_np_color,l.u_spp_halo_np_color=o.halo_np_color,l.u_spp_opacity=o.opacity,l.u_spp_halo_width=o.halo_width,l.u_spp_halo_blur=o.halo_blur,l.u_spp_emissive_strength=o.emissive_strength,l.u_spp_occlusion_opacity=o.occlusion_opacity,l.u_spp_z_offset=o.z_offset;const s=i.paint.get(e.uboBinder.isText?"text-translate-anchor":"icon-translate-anchor"),a=e.uboBinder.cachedHeader&&256&e.uboBinder.cachedHeader.dataDrivenMask&&"map"===s?r.transform.angle:0;l.u_spp_translate_rotation=[Math.cos(a),Math.sin(a)]}const{batchIndices:f,batchSegments:m}=e.getBatchGrouping(t);for(const _ of f){const t=m.get(_);e.uboBinder&&e.uboBinder.bind(h,n.program,_),n.draw(r,u.TRIANGLES,o,s,a,Yr.disabled,l,i.id,e.layoutVertexBuffer,e.indexBuffer,t,i.paint,r.transform.zoom,p,d,c)}}function la(t,i,r,n,o,s){const a=r.paint.get("line-width"),l=r.paint.get("line-emissive-strength").isConstant(),c=r.paint.get("line-emissive-strength").constantOr(0),h=r.paint.get("line-occlusion-opacity"),u=r.layout.get("line-elevation-reference"),d="meters"===r.layout.get("line-width-unit"),p="sea"===u,f=!(!t.terrain||!t.terrain.enabled),m=t.context,_=m.gl;if(r.hasElevatedBuckets&&"globe"===t.transform.projection.name)return;const g=r.layout.get("line-cross-slope"),y=void 0!==g,x=g<1,v=o||t.colorModeForDrapableLayerRenderPass(l?c:null),b=t.terrain&&t.terrain.renderingToTexture||s,w=b?1:e.o.devicePixelRatio,T=r.paint.get("line-dasharray"),S=T.constantOr(1),I=r.layout.get("line-cap"),E=T.constantOr(null),A=I.constantOr(null),M=r.paint.get("line-pattern"),C=M.constantOr(1),P=r.paint.get("line-pattern-cross-fade"),D=M.constantOr(null),R=r.paint.get("line-opacity").constantOr(1);let z=!C&&1!==R||t.depthOcclusion&&h>0&&h<1;const L=r.paint.get("line-gradient"),F=C?"linePattern":"line",O=e.dX(r);let B;if(b&&t.terrain&&t.terrain.clipOrMaskOverlapStencilType()&&(z=!1),0!==h&&t.depthOcclusion){const t=r.paint._values["line-opacity"];t&&t.value&&"constant"===t.value.kind?B=t.value:e.w(`Occlusion opacity for layer ${r.id} is supported only when line-opacity isn't data-driven.`)}"constant"!==a.value.kind&&!1===a.value.isLineProgressConstant&&O.push("VARIABLE_LINE_WIDTH"),t._debugParams.showElevationIdDebug&&O.push("DEBUG_ELEVATION_ID"),b&&("dual-source-blending"!==t.emissiveMode||l?"mrt-fallback"===t.emissiveMode&&O.push("USE_MRT1"):O.push("DUAL_SOURCE_BLENDING"));const k={},N=(n,o,s,a,l,c)=>{for(const u of n){const n=i.getTile(u);if(C&&!n.patternsLoaded())continue;const p=n.getBucket(r);if(!p)continue;if("none"!==p.elevationType&&!l||"none"===p.elevationType&&l)continue;t.prepareDrawTile();const f=[...o],g=t.shadowRenderer,y="road"===p.elevationType&&!!g&&g.enabled;let x=[0,0,0];if(y){const e=t.style.directionalLight,i=t.style.ambientLight;e&&i&&(x=mn(t.style,e,i)),f.push("RENDER_SHADOWS","NORMAL_OFFSET")}const T=p.programConfigurations.get(r.id);let I=!1;if(D&&n.imageAtlas){const t=e.dY.from(D),i=t.getPrimary().scaleSelf(w).toString(),r=n.imageAtlas.patternPositions.get(i),o=t.getSecondary(),s=o?n.imageAtlas.patternPositions.get(o.scaleSelf(w).toString()):null;I=!!r&&!!s,r&&T.setConstantPatternPositions(r,s)}P>0&&(I||T.getPatternTransitionVertexBuffer("line-pattern"))&&f.push("LINE_PATTERN_TRANSITION"),p.elevationGroundScaleVertexBuffer&&f.push("ELEVATION_GROUND_SCALE");const M=t.isTileAffectedByFog(u),O=t.getOrCreateProgram(F,{config:T,defines:f,overrideFog:M});if(!C&&E&&A&&n.lineAtlas){const e=n.lineAtlas.getDash(E,A);e&&T.setConstantPatternPositions(e)}y&&g.setupShadows(n.tileID.toUnwrapped(),O,"vector-tile");let[N,U]=r.paint.get("line-trim-offset");if("round"===A||"square"===A){const e=1;N!==U&&(0===N&&(N-=e),1===U&&(U+=e))}const V=b?u.projMatrix:null,j=d?1/p.tileToMeter/e.az(n,1,t.transform.zoom):1,G=d?1/p.tileToMeter/e.az(n,1,Math.floor(t.transform.zoom)):1,H=S?r.paint._values["line-floorwidth"]:null;let $;if(H&&"constant"===H.value.kind){const e=p.zoom;e in k||(k[e]=Math.max(.01,r.widthExpression().evaluate({zoom:e}))),$=H.value.value;const i=Math.floor(t.transform.zoom);H.value.value=k[e]*Math.pow(2,i-n.tileID.overscaledZ)}const q=C?e.dZ(t,n,r,V,w,j,G,[N,U],x,P):e.d_(t,n,r,V,p.lineClipsArray.length,w,j,G,[N,U],x);if(L){const n=p.gradients[r.id];let o=n.texture;if(r.gradientVersion!==n.version){let s=256;if(r.stepInterpolant){const r=i.getSource().maxzoom,n=u.canonical.z===r?Math.ceil(1<<t.transform.maxZoom-u.canonical.z):1;s=e.aB(e.d$(p.maxLineLength/e.ak*1024*n),256,m.maxTextureSize)}n.gradient=e.e0({expression:r.gradientExpression(),evaluationKey:"lineProgress",resolution:s,image:n.gradient||void 0,clips:p.lineClipsArray}),n.texture?n.texture.update(n.gradient):n.texture=new e.T(m,n.gradient,_.RGBA8),n.version=r.gradientVersion,o=n.texture}m.activeTexture.set(_.TEXTURE1),o.bind(r.stepInterpolant?_.NEAREST:_.LINEAR,_.CLAMP_TO_EDGE)}S&&(m.activeTexture.set(_.TEXTURE0),n.lineAtlasTexture&&n.lineAtlasTexture.bind(_.LINEAR,_.REPEAT),T.updatePaintBuffers()),C&&(m.activeTexture.set(_.TEXTURE0),n.imageAtlasTexture&&n.imageAtlasTexture.bind(_.LINEAR,_.CLAMP_TO_EDGE),T.updatePaintBuffers()),l&&t.terrain.setupElevationDraw(n,O),t.uploadCommonUniforms(m,O,u.toUnwrapped());const Z=e=>{null!=B&&(B.value=R*h),O.draw(t,_.TRIANGLES,s,e,v,Yr.disabled,q,r.id,p.layoutVertexBuffer,p.indexBuffer,p.segments,r.paint,t.transform.zoom,T,[p.layoutVertexBuffer2,p.patternVertexBuffer,p.zOffsetVertexBuffer,p.elevationIdColVertexBuffer,p.elevationGroundScaleVertexBuffer]),null!=B&&(B.value=R)};if(z&&!l){const e=t.stencilModeForClipping(u).ref;0===e&&b&&m.clear({stencil:0});const i={func:_.EQUAL,mask:255};q.u_alpha_discard_threshold=.8,Z(new Zr(i,e,255,_.KEEP,_.KEEP,_.INVERT)),q.u_alpha_discard_threshold=0,Z(new Zr(i,e,255,_.KEEP,_.KEEP,_.KEEP))}else q.u_alpha_discard_threshold=z&&l&&c?.8:0,Z(l?a:t.stencilModeForClipping(u));void 0!==$&&(H.value.value=$)}};let U=t.depthModeForSublayer(0,$r.ReadOnly);const V=new $r(t.depthOcclusion?_.GREATER:_.LEQUAL,$r.ReadOnly,t.depthRangeFor3D);if(r.hasNonElevatedBuckets){const i=!b&&t.terrain;0!==h&&i?e.w(`Occlusion opacity for layer ${r.id} is supported on terrain only if the layer has line-z-offset enabled.`):i?e.w(`Cannot render non-elevated lines in immediate mode when terrain is enabled. Layer: ${r.id}.`):N(n,O,U,Zr.disabled,!1,!0)}if(r.hasElevatedBuckets){"hd-road-markup"===u?f||(U=V,O.push("ELEVATED_ROADS")):(O.push("ELEVATED"),U=V,y&&O.push(x?"CROSS_SLOPE_HORIZONTAL":"CROSS_SLOPE_VERTICAL"),p&&O.push("ELEVATION_REFERENCE_SEA"));const e=z?t.stencilModeFor3D():Zr.disabled;t.forceTerrainMode=!0,N(n,O,U,e,!0,!0),z&&N(n,O,U,e,!0,!1),t.forceTerrainMode=!1}z&&(t.resetStencilClippingMasks(),b&&m.clear({stencil:0})),0===h||t.depthOcclusion||b||t.layersWithOcclusionOpacity.push(t.currentLayer)}class ca{destroy(){this.fbo&&(this.fbo.destroy(),this.fbo=null),this.drapeFbo&&(this.drapeFbo.destroy(),this.drapeFbo=null)}}class ha{constructor(e){this.pbo=e.createBuffer(),this.sync=null,this.fboA=null,this.fboB=null,this.maxDensity=0}destroy(e){this.sync&&(e.deleteSync(this.sync),this.sync=null),e.deleteBuffer(this.pbo),this.fboA&&(this.fboA.destroy(),this.fboA=null),this.fboB&&(this.fboB.destroy(),this.fboB=null)}}const ua={additive:{clearColor:new e.C(0,0,0,0),colorMode:Hr.additiveAlphaWeighted,compositeUniformValue:1},multiply:{clearColor:new e.C(1,1,1,1),colorMode:Hr.multiply,compositeUniformValue:0}};function da(e){return!(!e.extRenderToTextureHalfFloat&&!e.extColorBufferFloat)}function pa(e,t){return"additive"===e&&da(t)?Hr.additiveAlphaWeightedUnboundedAlpha:ua[e].colorMode}function fa(e,t,i){const r=e.context,n=r.gl;let o=i.width,s=i.height,a=i.colorAttachment0.get();t.lineBlendDensityReadback||(t.lineBlendDensityReadback=new ha(n));const l=t.lineBlendDensityReadback;let c=0,h=!0;for(;o>1||s>1;){const i=Math.max(1,Math.floor(o/2)),u=Math.max(1,Math.floor(s/2)),d=0===c?"fboA":"fboB";l[d]=Ks.createWithTexture(r,l[d],i,u,!1);const p=l[d];r.bindFramebuffer.set(p.framebuffer),r.viewport.set([0,0,i,u]),r.activeTexture.set(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,a),e.getOrCreateProgram("lineBlendReduce").draw(e,n.TRIANGLES,$r.disabled,Zr.disabled,Hr.unblended,Yr.disabled,Ps(0,[1/o,1/s],h),t.id,e.viewportBuffer,e.quadTriangleIndexBuffer,e.viewportSegments,t.paint,e.transform.zoom),o=i,s=u,a=p.colorAttachment0.get(),c=1-c,h=!1}const u=da(r),d=u?16:4;l.sync&&(n.deleteSync(l.sync),l.sync=null),n.bindBuffer(n.PIXEL_PACK_BUFFER,l.pbo),n.bufferData(n.PIXEL_PACK_BUFFER,d,n.STREAM_READ),n.readPixels(0,0,1,1,n.RGBA,u?n.FLOAT:n.UNSIGNED_BYTE,0),n.bindBuffer(n.PIXEL_PACK_BUFFER,null),l.sync=n.fenceSync(n.SYNC_GPU_COMMANDS_COMPLETE,0),r.viewport.set([0,0,e.width,e.height])}function ma(e,t,i){if(!da(e.context))return;const r=t.lineBlendDensityReadback;r&&r.sync?(function(e,t,i){if(e.sync&&t.getSyncParameter(e.sync,t.SYNC_STATUS)===t.SIGNALED){if(t.deleteSync(e.sync),e.sync=null,t.bindBuffer(t.PIXEL_PACK_BUFFER,e.pbo),da(i)){const i=new Float32Array(4);t.getBufferSubData(t.PIXEL_PACK_BUFFER,0,i);const r=i[1];e.maxDensity=Math.max(2*(r>0?i[0]/r:0),1)}else e.maxDensity=1;t.bindBuffer(t.PIXEL_PACK_BUFFER,null)}}(r,e.context.gl,e.context),r.sync||(fa(e,t,i),e.style.map.triggerRepaint())):(fa(e,t,i),e.style.map.triggerRepaint())}function _a(e,t,i,r,n,o){const s=e.context,a=s.gl,l="additive"===i?1:t.paint.get("line-opacity").constantOr(1),c="additive"===i?function(e,t){const i=t.paint.get("line-blend-additive-clamp");if(i>0)return i;const r=t.lineBlendDensityReadback;return r&&0!==r.maxDensity?r.maxDensity:null}(0,t):1;if(null===c)return;s.bindFramebuffer.set(n),o&&s.viewport.set([0,0,o[0],o[1]]),s.activeTexture.set(a.TEXTURE0),a.bindTexture(a.TEXTURE_2D,r.colorAttachment0.get());const h=pa(i,e.context);e.getOrCreateProgram("lineBlendComposite").draw(e,a.TRIANGLES,$r.disabled,Zr.disabled,h,Yr.disabled,((e,t,i,r)=>({u_image:0,u_opacity:t,u_blend_mode:i,u_max_density:r}))(0,l,ua[i].compositeUniformValue,c),t.id,e.viewportBuffer,e.quadTriangleIndexBuffer,e.viewportSegments,t.paint,e.transform.zoom)}function ga(t,i){const r=1<<t.canonical.z,n=(i.x*r-t.canonical.x-t.wrap*r)*e.ak,o=(i.y*r-t.canonical.y)*e.ak,s=e.e1(i.z,i.y);return e.cU(n,o,s)}function ya(t,i,r,n,o){if(!r.layout||"none"===r.layout.get("fill-elevation-reference")||0===r.paint.get("fill-opacity").constantOr(1))return;const s=t.context.gl,a=new $r(t.context.gl.LEQUAL,$r.ReadWrite,t.depthRangeFor3D),l=new $r(t.context.gl.GREATER,$r.ReadWrite,t.depthRangeFor3D),c=function(t){let i=.01;return t.isOrthographic&&(i=e.aj(1e-4,i,e.cP(t.pitch>=on?1:t.pitch/on))),2*i}(t.transform),h=t.transform.getFreeCameraOptions().position,u="elevatedStructuresDepthReconstruct",d=t.getOrCreateProgram(u,{defines:["DEPTH_RECONSTRUCTION"]}),p=t.getOrCreateProgram(u);for(const e of n){const n=i.getTile(e),u=n.getBucket(r);if(!u)continue;const f=u.elevatedStructures;if(!f||!f.depthSegments)continue;const m=u.elevationBufferData.heightRange,_=ga(e.toUnwrapped(),h),g=t.translatePosMatrix(e.projMatrix,n,r.paint.get("fill-translate"),r.paint.get("fill-translate-anchor"));let y,x,v,b;if("initialize"===o){if(!m||m.min>=1||0===f.depthSegments.segments[0].primitiveLength)continue;y=Cs(g,_,c,1,0),x=a,v=f.depthSegments,b=d}else if("reset"===o){if(!m||m.min>=0||0===f.maskSegments.segments[0].primitiveLength)continue;y=Cs(g,_,0,0,1),x=l,v=f.maskSegments,b=d}else if("geometry"===o){if(0===f.depthSegments.segments[0].primitiveLength)continue;y=Cs(g,_,c,1,0),x=a,v=f.depthSegments,b=p}b.draw(t,s.TRIANGLES,x,Zr.disabled,Hr.disabled,Yr.disabled,y,r.id,f.vertexBuffer,f.indexBuffer,v,r.paint,t.transform.zoom)}}function xa(t,i,r,n){const{painter:o,sourceCache:s,layer:a,coords:l,colorMode:c,elevationType:h,terrainEnabled:u,pass:d}=t,p=o.context.gl,f=a.paint.get("fill-pattern"),m=a.paint.get("fill-pattern-cross-fade"),_=f.constantOr(null);let g=h;"road"!==h||i&&!u||(g="none");const y="road"===g,x=t.painter.shadowRenderer,v=y&&!!x&&x.enabled,b=new $r(o.context.gl.LEQUAL,$r.ReadOnly,o.depthRangeFor3D);let w=[0,0,0];if(v){const e=o.style.directionalLight,t=o.style.ambientLight;e&&t&&(w=mn(o.style,e,t))}const T=f&&f.constantOr(1),S=o.terrain&&o.terrain.renderingToTexture,I=(t,d)=>{let f,g,I,E,A;d?(f=T&&!a.getPaintProperty("fill-outline-color")?"fillOutlinePattern":"fillOutline",I=p.LINES):(f=T?"fillPattern":"fill",I=p.TRIANGLES);for(const M of l){const l=s.getTile(M);if(T&&!l.patternsLoaded())continue;const C=l.getBucket(a);if(!C)continue;const P=i?C.elevationBufferData:C.bufferData;if(P.isEmpty())continue;o.prepareDrawTile();const D=P.programConfigurations.get(a.id),R=o.isTileAffectedByFog(M),z=[],L=[];y&&(z.push("ELEVATED_ROADS"),L.push(P.elevatedLayoutVertexBuffer)),v&&z.push("RENDER_SHADOWS","NORMAL_OFFSET"),S&&r&&z.push("USE_MRT1"),T&&(o.context.activeTexture.set(p.TEXTURE0),l.imageAtlasTexture&&l.imageAtlasTexture.bind(p.LINEAR,p.CLAMP_TO_EDGE),D.updatePaintBuffers());let F=!1;if(_&&l.imageAtlas){const t=l.imageAtlas,i=e.dY.from(_),r=i.getPrimary().scaleSelf(e.o.devicePixelRatio).toString(),n=i.getSecondary(),o=t.patternPositions.get(r),s=n?t.patternPositions.get(n.scaleSelf(e.o.devicePixelRatio).toString()):null;F=!!o&&!!s,o&&D.setConstantPatternPositions(o,s)}m>0&&(F||D.getPatternTransitionVertexBuffer("fill-pattern"))&&z.push("FILL_PATTERN_TRANSITION");const O=o.getOrCreateProgram(f,{config:D,overrideFog:R,defines:z}),B=o.translatePosMatrix(M.projMatrix,l,a.paint.get("fill-translate"),a.paint.get("fill-translate-anchor"));v&&x.setupShadows(l.tileID.toUnwrapped(),O,"vector-tile");const k=a.paint.get("fill-emissive-strength");if(d){E=P.lineIndexBuffer,A=P.lineSegments;const e=o.terrain&&o.terrain.renderingToTexture?o.terrain.drapeBufferSize:[p.drawingBufferWidth,p.drawingBufferHeight];g="fillOutlinePattern"===f&&T?Es(B,k,o,l,e,w,m):Is(B,k,e,w)}else E=P.indexBuffer,A=P.triangleSegments,g=T?Ss(B,k,o,l,w,m):Ts(B,k,w);o.uploadCommonUniforms(o.context,O,M.toUnwrapped());let N=t;("road"===h&&!u||"offset"===h)&&(N=b),O.draw(o,I,N,n||o.stencilModeForClipping(M),c,Yr.disabled,g,a.id,P.layoutVertexBuffer,E,A,a.paint,o.transform.zoom,D,L)}};o.renderPass===d&&I(o.depthModeForSublayer(1,"opaque"===o.renderPass?$r.ReadWrite:$r.ReadOnly),!1),"none"===g&&"translucent"===o.renderPass&&a.paint.get("fill-antialias")&&I(o.depthModeForSublayer(a.getPaintProperty("fill-outline-color")?2:0,$r.ReadOnly),!0)}const va=new Float32Array(16);function ba(t,i,r,n,o,s,a,l){r.resetLayerRenderingStats(t);const c=t.context,h=c.gl,u=t.transform,d=r.paint.get("fill-extrusion-pattern"),p=r.paint.get("fill-extrusion-pattern-cross-fade"),f=d.constantOr(null),m=d.constantOr(1),_=r.paint.get("fill-extrusion-opacity"),g=t.style.enable3dLights(),y=r.paint.get(g&&!m?"fill-extrusion-ambient-occlusion-wall-radius":"fill-extrusion-ambient-occlusion-radius"),x=[r.paint.get("fill-extrusion-ambient-occlusion-intensity"),y],v=r.layout.get("fill-extrusion-edge-radius"),b=v>0&&!r.paint.get("fill-extrusion-rounded-roof"),w=b?0:v,T="globe"===u.projection.name?e.e4():0,S="globe"===u.projection.name,I=S?e.ai(u.zoom):0,E=[e.aG(u.center.lng),e.aJ(u.center.lat)],A="none"===r.paint.get("fill-extrusion-flood-light-color-use-theme").constantOr("default"),M=r.paint.get("fill-extrusion-flood-light-color").toNonPremultipliedRenderColor(A?null:r.lut).toArray01().slice(0,3),C=r.paint.get("fill-extrusion-flood-light-intensity"),P=r.paint.get("fill-extrusion-vertical-scale"),D=0!==r.paint.get("fill-extrusion-line-width").constantOr(1),R=r.paint.get("fill-extrusion-height-alignment"),z=r.paint.get("fill-extrusion-base-alignment"),L=an(t,r.paint.get("fill-extrusion-cutoff-fade-range")),F=r.paint.get("fill-extrusion-front-cutoff"),O=Ta(u.pitch,F,!!t.terrain),B=O[2]<1;B&&(t.maxFrontCutoffRawStart=Math.max(t.maxFrontCutoffRawStart,F[0]));const k=[];let N;S&&k.push("PROJECTION_GLOBE_VIEW"),x[0]>0&&k.push("FAUX_AO"),b&&k.push("ZERO_ROOF_RADIUS"),l&&k.push("HAS_CENTROID"),C>0&&k.push("FLOOD_LIGHT"),L.shouldRenderCutoff&&k.push("RENDER_CUTOFF"),B&&k.push("RENDER_FRONT_CUTOFF"),D&&k.push("RENDER_WALL_MODE");const U="shadow"===t.renderPass,V=t.shadowRenderer,j=U&&!!V,G=U?Yr.disabled:Yr.backCCW;t.shadowRenderer&&(t.shadowRenderer.useNormalOffset=!0);let H=[0,0,0];if(V){const e=t.style.directionalLight,i=t.style.ambientLight;e&&i&&(H=mn(t.style,e,i)),U||(k.push("RENDER_SHADOWS"),V.useNormalOffset&&k.push("NORMAL_OFFSET")),N=k.concat(["SHADOWS_SINGLE_CASCADE"])}const $=j?"fillExtrusionDepth":m?"fillExtrusionPattern":"fillExtrusion",q=r.getLayerRenderingStats();for(const Z of n){const n=i.getTile(Z),d=n.getBucket(r);if(!d||d.projection.name!==u.projection.name)continue;let g=!1;V&&(g=0===V.getMaxCascadeForTile(Z.toUnwrapped()));const y=t.isTileAffectedByFog(Z),v=d.programConfigurations.get(r.id);let b=!1;if(f&&n.imageAtlas){const t=n.imageAtlas,i=e.dY.from(f),r=i.getPrimary().scaleSelf(e.o.devicePixelRatio).toString(),o=i.getSecondary(),s=t.patternPositions.get(r),a=o?t.patternPositions.get(o.scaleSelf(e.o.devicePixelRatio).toString()):null;b=!!s&&!!a,s&&v.setConstantPatternPositions(s,a)}p>0&&(b||v.getPatternTransitionVertexBuffer("fill-extrusion-pattern"))&&k.push("FILL_EXTRUSION_PATTERN_TRANSITION");const A=t.getOrCreateProgram($,{config:v,defines:g?N:k,overrideFog:y});if(t.terrain&&t.terrain.setupElevationDraw(n,A,{useMeterToDem:!0}),!d.centroidVertexBuffer){const e=A.getAttributeLocation(h,"a_centroid_pos");-1!==e&&h.vertexAttribI4ui(e,0,0,0,0)}!U&&V&&V.setupShadows(n.tileID.toUnwrapped(),A,"vector-tile"),m&&(t.context.activeTexture.set(h.TEXTURE0),n.imageAtlasTexture&&n.imageAtlasTexture.bind(h.LINEAR,h.CLAMP_TO_EDGE),v.updatePaintBuffers());const F=r.paint.get("fill-extrusion-vertical-gradient"),B=1/d.tileToMeter;let j;if(U&&V){if(Ca(n.tileID,d.maxHeight,t))continue;j=bs(V.calculateShadowPassMatrixFromTile(n.tileID.toUnwrapped()),w,B,P,R,z)}else{const e=t.translatePosMatrix(Z.expandedProjMatrix,n,r.paint.get("fill-extrusion-translate"),r.paint.get("fill-extrusion-translate-anchor")),i=u.projection.createInversionMatrix(u,Z.canonical);j=m?ws(e,t,F,_,x,w,B,Z,n,T,R,z,I,E,i,M,P,p):vs(e,t,F,_,x,w,B,Z,T,R,z,I,E,i,M,P,C,H,O)}t.uploadCommonUniforms(c,A,Z.toUnwrapped(),null,L);let W=d.segments;if("mercator"===u.projection.name&&!U&&(W=d.getVisibleSegments(n.tileID,t.terrain,t.transform.getFrustum(0)),!W.get().length))continue;if(q)if(U)for(const e of W.get())q.numRenderedVerticesInShadowPass+=e.primitiveLength;else for(const e of W.get())q.numRenderedVerticesInTransparentPass+=e.primitiveLength;const X=[];(t.terrain||l)&&X.push(d.centroidVertexBuffer),S&&X.push(d.layoutVertexExtBuffer),D&&X.push(d.wallVertexBuffer),A.draw(t,c.gl.TRIANGLES,o,s,a,G,j,r.id,d.layoutVertexBuffer,d.indexBuffer,W,r.paint,t.transform.zoom,v,X)}t.shadowRenderer&&(t.shadowRenderer.useNormalOffset=!1)}class wa{constructor(){this.translate=[0,0],this.translateAnchor="map",this.edgeRadius=0,this.cutoffFadeRange=0}}function Ta(e,t,i){if(!(t[2]<1)||i)return[0,0,1];const r=180*e/Math.PI;if(r<15)return[-.5,t[1],t[2]];const n=Math.min(1,Math.max(0,(r-15)/5)),o=n*n*(3-2*n);return[-.5*(1-o)+t[0]*o,t[1],t[2]]}function Sa(t,i,r,n,o,s,a,l,c,h,u,d,p,f,m,_,g,y,x,v,b){const w=i.context,T=w.gl,S=i.transform,I=i.transform.zoom,E=[],A=t.translate,M=t.translateAnchor,C=t.edgeRadius,P=an(i,t.cutoffFadeRange);"clear"===u?(E.push("CLEAR_SUBPASS"),v&&(E.push("CLEAR_FROM_TEXTURE"),w.activeTexture.set(T.TEXTURE0),v.bind(T.LINEAR,T.CLAMP_TO_EDGE))):"sdf"===u?E.push("SDF_SUBPASS"):"emissive"===u&&(E.push("USE_MRT1"),w.activeTexture.set(T.TEXTURE0),v.bind(T.LINEAR,T.CLAMP_TO_EDGE)),y&&E.push("HAS_CENTROID"),P.shouldRenderCutoff&&E.push("RENDER_CUTOFF");const D=(e,t,r,o,u)=>{let x=E;null!=t.groundRadiusBuffer&&(x=E.concat("HAS_ATTRIBUTE_a_flood_light_ground_radius"));const b=t.programConfigurations.get(n.id),T=i.isTileAffectedByFog(e),S=i.getOrCreateProgram("fillExtrusionGroundEffect",{config:b,defines:x,overrideFog:T}),A=((e,t,i,r,n,o,s,a,l,c,h)=>({u_matrix:t,u_opacity:i,u_ao_pass:r?1:0,u_meter_to_tile:n,u_ao:o,u_flood_light_intensity:s,u_flood_light_color:a,u_attenuation:l,u_edge_radius:c,u_fb:0,u_fb_size:h,u_dynamic_offset:1}))(0,o,d,h,u,[p,f*u],m,_,g,I>=17?0:C*u,v?v.size[0]:0),M=[];y&&M.push(t.hiddenByLandmarkVertexBuffer),null!=t.groundRadiusBuffer&&M.push(t.groundRadiusBuffer),i.uploadCommonUniforms(w,S,e.toUnwrapped(),null,P),S.draw(i,w.gl.TRIANGLES,s,a,l,c,A,n.id,t.vertexBuffer,t.indexBuffer,r,n.paint,I,b,M)};for(const R of o){const t=r.getTile(R),o=t.getBucket(n);if(!o||o.projection.name!==S.projection.name||!o.groundEffect||o.groundEffect&&!o.groundEffect.hasData())continue;const s=o.groundEffect,a=1/o.tileToMeter;{const e=i.translatePosMatrix(R.projMatrix,t,A,M);D(R,s,s.getDefaultSegment(),e,a)}if(x)for(let l=0;l<4;l++){const o=e.e2[l](R),s=r.getTile(o);if(!s)continue;const c=s.getBucket(n);if(!c||c.projection.name!==S.projection.name||!c.groundEffect||c.groundEffect&&!c.groundEffect.hasData())continue;const h=c.groundEffect;let u,d;0===l?(u=[-e.ak,0,0],d=1):1===l?(u=[e.ak,0,0],d=0):2===l?(u=[0,-e.ak,0],d=3):(u=[0,e.ak,0],d=2);const p=h.regionSegments[d];p&&(e.bB(va,R.projMatrix,u),D(R,h,p,i.translatePosMatrix(va,t,A,M),a))}}}function Ia(t,i,r,n,o,s,a){0===n.centroidVertexArray.length&&n.createCentroidsBuffer();const l=s?s.findDEMTileFor(r):null;if(!(l&&l.dem||a))return;s&&l&&l.dem&&n.selfDEMTileTimestamp!==l.dem._timestamp&&(n.borderDoneWithNeighborZ=[-1,-1,-1,-1],n.selfDEMTileTimestamp=l.dem._timestamp);const c=(t,i)=>{(t.flags|i.flags)&e.e5?(t.flags|=e.e5,i.flags|=e.e5):(t.flags&=~e.e5,i.flags&=~e.e5)},h=t=>new e.P(Math.ceil((t+e.e6)*e.e7),0),u=(t,i,r)=>{const n=Math.ceil((t+e.e6)*e.e7),o=Math.floor(Math.max(0,Math.min(e.ak-1,r))/4);return new e.P(n,o<<5|(3&i)<<3|7)},d=e=>{const t=i.getSource().minzoom,r=e=>{const t=i.getTileByID(e);if(t&&t.hasData())return t.getBucket(o)};for(const i of[0,-1,1]){if(e.overscaledZ+i<t)continue;const n=r(e.calculateScaledKey(e.overscaledZ+i));if(n)return n}},p=[0,0,0],f=(t,i)=>(p[0]=Math.min(t.min.y,i.min.y),p[1]=Math.max(t.max.y,i.max.y),p[2]=e.ak-i.min.x>t.max.x?i.min.x-e.ak:t.max.x,p),m=(t,i)=>(p[0]=Math.min(t.min.x,i.min.x),p[1]=Math.max(t.max.x,i.max.x),p[2]=e.ak-i.min.y>t.max.y?i.min.y-e.ak:t.max.y,p),_=[(e,t)=>f(e,t),(e,t)=>f(t,e),(e,t)=>m(e,t),(e,t)=>m(t,e)],g=(t,i,n,o,a,c,h)=>{if(!s)return 0;const u=[[c?n:t,c?t:n,0],[c?n:i,c?i:n,0]],d=h<0?e.ak+h:h,p=[c?d:(t+i)/2,c?(t+i)/2:d,0];return 0===n&&h<0||0!==n&&h>0?s.getForTilePoints(a,[p],!0,o):u.push(p),s.getForTilePoints(r,u,!0,l),Math.max(u[0][2],u[1][2],p[2])/s.exaggeration()};for(let y=0;y<4;y++){const t=n.borderFeatureIndices[y];if(0===t.length)continue;const i=e.e2[y](r),o=d(i);if(!(o&&o instanceof e.e3))continue;const l=s?s.findDEMTileFor(i):null;if(!(l&&l.dem||a))continue;if(s&&l&&l.dem&&n.borderDEMTileTimestamp[y]!==l.dem._timestamp&&(n.borderDoneWithNeighborZ[y]=-1,n.borderDEMTileTimestamp[y]=l.dem._timestamp),n.borderDoneWithNeighborZ[y]===o.canonical.z)continue;0===o.centroidVertexArray.length&&o.createCentroidsBuffer();const p=(y<2?1:5)-y,f=o.borderDoneWithNeighborZ[p]!==n.canonical.z,m=o.borderFeatureIndices[p];let x=0;if(n.canonical.z!==o.canonical.z){for(const e of t)n.showCentroid(n.featuresOnBorder[e]);if(f)for(const e of m)o.showCentroid(o.featuresOnBorder[e]);n.borderDoneWithNeighborZ[y]=o.canonical.z,o.borderDoneWithNeighborZ[p]=n.canonical.z;continue}const v=/* @__PURE__ */new Map,b=/* @__PURE__ */new Set,w=/* @__PURE__ */new Set;for(let e=0;e<m.length;e++){const t=o.featuresOnBorder[m[e]];void 0!==t.buildingId&&v.set(t.buildingId,e)}for(const r of t){const t=n.featuresOnBorder[r],s=n.centroidData.get(t.centroidDataIndex);if(void 0===t.buildingId)continue;const h=v.get(t.buildingId);if(void 0===h)continue;const d=o.featuresOnBorder[m[h]],f=o.centroidData.get(d.centroidDataIndex);b.add(r),w.add(h),a&&c(s,f);const x=0!==s.groupCentroidPos.x||0!==s.groupCentroidPos.y?s.groupCentroidPos:t.centroid(),T=0!==f.groupCentroidPos.x||0!==f.groupCentroidPos.y?f.groupCentroidPos:d.centroid(),S=y<2?Math.round((x.y+T.y)/2):Math.round((x.x+T.x)/2),I=t.intersectsCount()>1||d.intersectsCount()>1;{let t=0;if(l&&l.dem&&!I){const r=_[y](s,f),n=y%2?e.ak-1:0;t=g(r[0],Math.min(e.ak-1,r[1]),n,l,i,y<2,r[2])}s.centroidXY=u(t,y,S),f.centroidXY=u(t,p,S)}if(n.writeCentroidToBuffer(s),o.writeCentroidToBuffer(f),void 0!==t.buildingId){for(const e of n.centroidData)e.buildingId===t.buildingId&&e!==s&&(e.centroidXY=s.centroidXY,n.writeCentroidToBuffer(e));for(const e of o.centroidData)e.buildingId===t.buildingId&&e!==f&&(e.centroidXY=f.centroidXY,o.writeCentroidToBuffer(e))}}for(const r of t){if(b.has(r))continue;const t=n.featuresOnBorder[r],s=n.centroidData.get(t.centroidDataIndex),u=t.borders[y];let d;for(;x<m.length;){if(w.has(x)){x++;continue}d=o.featuresOnBorder[m[x]];const e=d.borders[p];if(e[1]>u[0]+3||e[0]>u[0]-3)break;o.showCentroid(d),x++}if(d&&x<m.length){let r=x,f=0;for(;;)if(w.has(x)){if(++x===m.length)break;d=o.featuresOnBorder[m[x]]}else{if(d.borders[p][0]>u[1]-3)break;if(f++,++x===m.length)break;d=o.featuresOnBorder[m[x]]}for(;r<m.length&&w.has(r);)r++;if(r>=m.length){n.showCentroid(t);continue}d=o.featuresOnBorder[m[r]];let v=!1;if(f>=1){const e=d.borders[p];Math.abs(u[0]-e[0])<3&&Math.abs(u[1]-e[1])<3&&(f=1,v=!0,x=r+1)}else if(0===f){n.showCentroid(t);continue}const b=o.centroidData.get(d.centroidDataIndex);a&&v&&c(s,b);const T=t.intersectsCount()>1||d.intersectsCount()>1;if(f>1)x=r,s.centroidXY=b.centroidXY=new e.P(0,0);else if(l&&l.dem&&!T){const t=_[y](s,b),r=y%2?e.ak-1:0;s.centroidXY=b.centroidXY=h(g(t[0],Math.min(e.ak-1,t[1]),r,l,i,y<2,t[2]))}else T?s.centroidXY=b.centroidXY=new e.P(0,0):(s.centroidXY=n.encodeBorderCentroid(t),b.centroidXY=o.encodeBorderCentroid(d));n.writeCentroidToBuffer(s),o.writeCentroidToBuffer(b)}else n.showCentroid(t)}n.borderDoneWithNeighborZ[y]=o.canonical.z,o.borderDoneWithNeighborZ[p]=n.canonical.z}(n.needsCentroidUpdate||!n.centroidVertexBuffer&&0!==n.centroidVertexArray.length)&&n.uploadCentroid(t)}const Ea=[1,0,0],Aa=[0,1,0],Ma=[0,0,1];function Ca(t,i,r){const n=r.transform,o=r.shadowRenderer;if(!o)return!0;const s=r.frameCounter,a=r.currentShadowCascade;let l=r._shadowCullCache;if(!l||l.frame!==s||l.cascade!==a){const t=n.tileSize*o._cascades[a].scale,i=n.scaleZoom(t),c=o.shadowDirection,h=[c[0],c[1],-c[2]],u=[Ea,Aa,Ma,h,[h[0],0,h[2]],[0,h[1],h[2]]];l={frame:s,cascade:a,cameraFrustum:e.cn.fromInvProjectionMatrix(n.invProjMatrix,n.worldSize,i,!("globe"===n.projection.name)),edges:u,shadowDir:h,ws:t,zoom:i},r._shadowCullCache=l}const{cameraFrustum:c,edges:h,shadowDir:u,ws:d,zoom:p}=l;let f=i;if(n.elevation){const e=n.elevation.getMinMaxForTile(t);e&&(f+=e.max)}f/=e.e8(n.center.lat,p);const m=o.computeSimplifiedTileShadowVolume(t.toUnwrapped(),f,d,u);if(!m)return!1;const{vertices:_,planes:g}=m;return 0===c.intersectsPrecise(_,g,h)||0===o.getCurrentCascadeFrustum().intersectsPrecise(_,g,h)}const Pa=(e,t,i,r,n,o,s,a,l,c=[0,0,1])=>({u_matrix:e,u_normal_matrix:t,u_opacity:i,u_faux_facade_ao_intensity:r,u_camera_pos:n,u_tile_to_meter:o,u_facade_emissive_chance:s,u_flood_light_color:a,u_flood_light_intensity:l,u_front_cutoff_params:c}),Da=e=>({u_matrix:e}),Ra=e=>({u_matrix:e}),za=new Float32Array(16),La=new Float32Array(16);function Fa(t){const{painter:i,source:r,layer:n,coords:o}=t;let s=t.defines;const a=i.context,l="shadow"===i.renderPass,c="light-beam"===i.renderPass,h=i.shadowRenderer,u=e.e8(i.transform.center.lat,i.transform.zoom),d=an(i,n.paint.get("building-cutoff-fade-range"));d.shouldRenderCutoff&&(s=s.concat("RENDER_CUTOFF"));const p=n.paint.get("building-front-cutoff"),f=p[2]<1&&!i.terrain,m=Ta(i.transform.pitch,p,!!i.terrain);f&&(s=s.concat("RENDER_FRONT_CUTOFF"),i.maxFrontCutoffRawStart=Math.max(i.maxFrontCutoffRawStart,p[0])),t.floodLightIntensity>0&&(s=s.concat("FLOOD_LIGHT"));for(const _ of o){const o=r.getTile(_),p=o.getBucket(n);if(!p)continue;h&&0===h.getMaxCascadeForTile(_.toUnwrapped())&&(s=s.concat("SHADOWS_SINGLE_CASCADE"));const f=p.programConfigurations.get(n.id);let g,y;const x=i.translatePosMatrix(_.expandedProjMatrix,o,[0,0],"map");e.cE(za,x,[1,1,t.verticalScale]);const v=za;let b;if(l&&h){if(Ca(o.tileID,p.maxHeight*u,i))continue;const r=h.calculateShadowPassMatrixFromTile(o.tileID.toUnwrapped());e.cE(r,r,[1,1,t.verticalScale]),b=Ra(r),g=y=i.getOrCreateProgram("buildingDepth",{config:f,defines:s,overrideFog:!1})}else if(c)g=y=i.getOrCreateProgram("buildingBloom",{config:f,defines:s,overrideFog:!1}),b=Da(v);else{const r=i.transform.calculatePosMatrix(_.toUnwrapped(),i.transform.worldSize);e.cE(r,r,[1,1,t.verticalScale]),e.cE(La,r,[1,-1,1/u]),e.ba(La,La),e.e9(La,La);const n=La,o=i.transform.getFreeCameraOptions().position,a=1<<_.canonical.z;if(b=Pa(v,n,t.opacity,t.facadeAOIntensity,[((o.x-_.wrap)*a-_.canonical.x)*e.ak,(o.y*a-_.canonical.y)*e.ak,o.z*a*e.ak],p.tileToMeter,t.facadeEmissiveChance,t.floodLightColor,t.floodLightIntensity,m),y=i.getOrCreateProgram("building",{config:f,defines:s,overrideFog:!1}),!0===t.depthOnly)g=y;else{const e=s.concat(["BUILDING_FAUX_FACADE","HAS_ATTRIBUTE_a_faux_facade_color_emissive"]);g=i.getOrCreateProgram("building",{config:f,defines:e,overrideFog:!1})}h&&(h.setupShadowsFromMatrix(r,y,!0),g!==y&&h.setupShadowsFromMatrix(r,g,!0))}const w=(e,r)=>{if(c){const o=e.entranceBloom;r.draw(i,a.gl.TRIANGLES,t.depthMode,Zr.disabled,t.blendMode,Yr.disabled,b,n.id,o.layoutVertexBuffer,o.indexBuffer,o.segmentsBucket,n.paint,i.transform.zoom,f,[o.layoutAttenuationBuffer,o.layoutColorBuffer])}else{const o=e.segmentsBucket;let s=[e.layoutNormalBuffer,e.layoutCentroidBuffer,e.layoutColorBuffer,e.layoutFloodLightDataBuffer];e.layoutFacadePaintBuffer&&(s=s.concat([e.layoutFacadeDataBuffer,e.layoutFacadeVerticalRangeBuffer,e.layoutFacadePaintBuffer])),r.draw(i,a.gl.TRIANGLES,t.depthMode,Zr.disabled,t.blendMode,l?Yr.disabled:Yr.backCW,b,n.id,e.layoutVertexBuffer,e.indexBuffer,o,n.paint,i.transform.zoom,f,s)}};i.uploadCommonUniforms(a,y,_.toUnwrapped(),null,d),p.buildingWithoutFacade&&w(p.buildingWithoutFacade,y),p.buildingWithFacade&&(g!==y&&i.uploadCommonUniforms(a,g,_.toUnwrapped(),null,d),w(p.buildingWithFacade,g))}}function Oa(t,i,r,n,o,s,a,l,c,h,u,d,p,f){const m=t.context.gl,_=t.depthModeForSublayer(1,$r.ReadOnly,m.LEQUAL,!0),g=.1*(1-(y=u))+3*y;var y;const x=t._showOverdrawInspector,v=d,b=new wa;x||Sa(b,t,i,r,n,_,new Zr({func:m.ALWAYS,mask:255},255,255,m.KEEP,m.KEEP,m.REPLACE),new Hr([m.ONE,m.ONE,m.ONE,m.ONE],e.C.transparent,[!1,!1,!1,!0],m.MIN),Yr.disabled,o,"sdf",s,a,l,c,h,g,v,!1,void 0),Sa(b,t,i,r,n,_,x?Zr.disabled:new Zr({func:m.EQUAL,mask:255},255,255,m.KEEP,m.DECR,m.DECR),x?t.colorModeForRenderPass():new Hr([m.ONE_MINUS_DST_ALPHA,m.DST_ALPHA,m.ONE,m.ONE],e.C.transparent,[!0,!0,!0,!0]),Yr.disabled,o,"color",s,a,l,c,h,g,v,!1,void 0)}const Ba=.05,ka=(e,t,i,r,n,o,s,a,l,c,h,u)=>({u_matrix:e,u_normalize_matrix:t,u_globe_matrix:i,u_merc_matrix:r,u_grid_matrix:n,u_tl_parent:o,u_scale_parent:c,u_fade_t:h.mix,u_opacity:h.opacity,u_image0:0,u_image1:1,u_raster_elevation:u,u_zoom_transition:s,u_merc_center:a,u_cutoff_params:l}),Na=(e,t,i,r,n,o,s,a,l,c)=>({u_particle_texture:e,u_particle_texture_side_len:t,u_tile_offset:i,u_velocity:r,u_color_ramp:o,u_velocity_res:n,u_max_speed:s,u_uv_offset:a,u_data_scale:[255*l[0],255*l[1]],u_data_offset:c,u_particle_pos_scale:1.1,u_particle_pos_offset:[Ba,Ba]}),Ua=(e,t,i,r,n,o,s,a,l,c)=>({u_particle_texture:e,u_particle_texture_side_len:t,u_velocity:i,u_velocity_res:r,u_max_speed:n,u_speed_factor:o,u_reset_rate:s,u_rand_seed:Math.random(),u_uv_offset:a,u_data_scale:[255*l[0],255*l[1]],u_data_offset:c,u_particle_pos_scale:1.1,u_particle_pos_offset:[Ba,Ba]});var Va=e.ea([{name:"a_index",type:"Int16",components:1}]);class ja{constructor(t,i,r,n){const o={width:r[0],height:r[1],data:null},s=t.gl;this.targetColorTexture=new e.T(t,o,s.RGBA8,{useMipmap:!1}),this.backgroundColorTexture=new e.T(t,o,s.RGBA8,{useMipmap:!1}),this.context=t,this.updateParticleTexture(i,n),this.lastInvalidatedAt=0}updateParticleTexture(t,i){if(this.particleTextureDimension===i.width)return;(this.particleTexture0||this.particleTexture1||this.particleIndexBuffer||this.particleSegment)&&(this.particleTexture0.destroy(),this.particleTexture1.destroy(),this.particleIndexBuffer.destroy(),this.particleSegment.destroy());const r=this.context.gl,n=i.width*i.height;this.particleTexture0=new e.T(this.context,i,r.RGBA8,{premultiply:!1,useMipmap:!1}),this.particleTexture1=new e.T(this.context,i,r.RGBA8,{premultiply:!1,useMipmap:!1});const o=new e.eb;o.reserve(n);for(let e=0;e<n;e++)o.emplaceBack(e);this.particleIndexBuffer=this.context.createVertexBuffer(o,Va.members,!0),this.particleSegment=e.dB.simpleSegment(0,0,this.particleIndexBuffer.length,0),this.particleTextureDimension=i.width}update(t){return!(this.lastInvalidatedAt<t&&(this.lastInvalidatedAt=e.o.now(),1))}destroy(){this.targetColorTexture.destroy(),this.backgroundColorTexture.destroy(),this.particleIndexBuffer.destroy(),this.particleTexture0.destroy(),this.particleTexture1.destroy(),this.particleSegment.destroy()}}function Ga(t,i,r){if(!t)return null;const n=i.getTextureDescriptor(t,r,!0);if(!n)return null;let{texture:o,mix:s,offset:a,tileSize:l,buffer:c,format:h}=n;if(!o||!h)return null;let u=!1;return"uint32"===h&&(u=!0,s[3]=0,s=Os(e.ec,s,[0,r.paint.get("raster-particle-max-speed")]),a=Bs(e.ec,a,[0,r.paint.get("raster-particle-max-speed")])),{texture:o,textureOffset:[c/(l+2*c),l/(l+2*c)],tileSize:l,scalarData:u,scale:s,offset:a,defines:["RASTER_ARRAY",{uint8:"DATA_FORMAT_UINT8",uint16:"DATA_FORMAT_UINT16",uint32:"DATA_FORMAT_UINT32"}[h]]}}function Ha(e){const t=e._nearZ,i=e.projection.farthestPixelDistance(e),r=i-t,n=.2*e.height,o=t+n;return[t,i,(o-n-t)/r,(o-t)/r]}var $a="#ifdef RASTER_ARRAY\nuniform sampler2D u_velocity;uniform mediump vec2 u_velocity_res;uniform mediump float u_max_speed;const vec4 NO_DATA=vec4(1);const vec2 INVALID_VELOCITY=vec2(-1);uniform highp vec2 u_uv_offset;uniform highp float u_data_offset;uniform highp vec2 u_data_scale;ivec4 rasterArrayLinearCoord(highp vec2 texCoord,highp vec2 texResolution,out highp vec2 fxy) {texCoord=texCoord*texResolution-0.5;fxy=fract(texCoord);texCoord-=fxy;return ivec4(texCoord.xxyy+vec2(1.5,0.5).xyxy);}highp vec2 lookup_velocity(highp vec2 uv) {uv=u_uv_offset.x+u_uv_offset.y*uv;highp vec2 fxy;ivec4 c=rasterArrayLinearCoord(uv,u_velocity_res,fxy);highp vec4 tl=texelFetch(u_velocity,c.yz,0);highp vec4 tr=texelFetch(u_velocity,c.xz,0);highp vec4 bl=texelFetch(u_velocity,c.yw,0);highp vec4 br=texelFetch(u_velocity,c.xw,0);if (tl==NO_DATA) {return INVALID_VELOCITY;}if (tr==NO_DATA) {return INVALID_VELOCITY;}if (bl==NO_DATA) {return INVALID_VELOCITY;}if (br==NO_DATA) {return INVALID_VELOCITY;}highp vec4 t=mix(mix(bl,br,fxy.x),mix(tl,tr,fxy.x),fxy.y);highp vec2 velocity=u_data_offset+vec2(dot(t.rg,u_data_scale),dot(t.ba,u_data_scale));velocity.y=-velocity.y;velocity/=max(u_max_speed,length(velocity));return velocity;}\n#endif\nuniform highp float u_particle_pos_scale;uniform highp vec2 u_particle_pos_offset;highp vec4 pack_pos_to_rgba(highp vec2 p) {highp vec2 v=(p+u_particle_pos_offset)/u_particle_pos_scale;highp vec4 r=vec4(v.x,fract(v.x*255.0),v.y,fract(v.y*255.0));return vec4(r.x-r.y/255.0,r.y,r.z-r.w/255.0,r.w);}highp vec2 unpack_pos_from_rgba(highp vec4 v) {v=floor(v*255.0+0.5)/255.0;highp vec2 p=vec2(v.x+(v.y/255.0),v.z+(v.w/255.0));return u_particle_pos_scale*p-u_particle_pos_offset;}";Qn["_prelude_raster_particle.glsl"]||(Qn["_prelude_raster_particle.glsl"]=$a);var qa={building:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_shadow.fragment.glsl"\n#include "_prelude_lighting.glsl"\nconst float window_depth=0.5;const float ao_radius=0.2;in vec4 v_color;in highp vec3 v_normal;in highp vec3 v_pos;\n#ifdef RENDER_FRONT_CUTOFF\nin float v_front_cutoff_opacity;\n#endif\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nin vec4 v_ground_roof;\n#endif\n#endif\n#ifdef BUILDING_FAUX_FACADE\nin lowp float v_faux_facade;in highp float v_faux_facade_ed;in highp vec2 v_faux_facade_window;in highp vec2 v_faux_facade_floor;in highp vec2 v_faux_facade_range;in highp float v_aspect;in highp vec3 v_tbn_0;in highp vec3 v_tbn_1;in highp vec3 v_tbn_2;in highp vec4 v_faux_color_emissive;uniform float u_faux_facade_ao_intensity;\n#endif\n#ifdef RENDER_SHADOWS\nin highp vec4 v_pos_light_view_0;in highp vec4 v_pos_light_view_1;\n#endif\n#ifdef FLOOD_LIGHT\nin highp float v_flood_radius;in float v_has_flood_light;\n#endif\nuniform lowp float u_opacity;uniform vec3 u_camera_pos;uniform highp float u_tile_to_meter;uniform float u_facade_emissive_chance;uniform vec3 u_flood_light_color;uniform float u_flood_light_intensity;vec3 linearTosRGB(in vec3 color) {return pow(color,vec3(1./2.2));}\n#ifdef BUILDING_FAUX_FACADE\nhighp float hash12(in highp vec2 p) {highp vec3 p3 =fract(vec3(p.xyx)*0.1031);p3+=dot(p3,p3.yzx+33.33);return fract((p3.x+p3.y)*p3.z);}float min3(in vec3 v) {return min(min(v.x,v.y),v.z);}highp vec2 get_uv_mask_id(in highp vec2 q,out highp float mask,out highp vec2 id) {highp vec2 p=q;mask=step(v_faux_facade_range.x,p.y)*step(p.y,v_faux_facade_range.y);p.y=p.y-v_faux_facade_range.x;highp vec2 uv=modf(p/v_faux_facade_floor,id);highp vec4 d=(v_faux_facade_floor.xyxy+vec4(-v_faux_facade_window,v_faux_facade_window))*0.5;highp vec4 edge=d/v_faux_facade_floor.xyxy;highp vec2 m=step(edge.xy,uv)*step(uv,edge.zw);mask*=m.x*m.y;uv-=vec2(0.5);uv*=vec2(0.5)/(vec2(0.5)-edge.xy);uv+=vec2(0.5);return uv;}highp float ray_unit_box(in highp vec3 ray_o,in highp vec3 ray_d,in highp vec3 bmin,in highp vec3 bmax) {highp vec3 planes=mix(bmin,bmax,step(0.0,ray_d));highp vec3 t=(planes-ray_o)/ray_d;return min3(t);}float get_emissive(in vec2 id) {if (u_facade_emissive_chance > 0.0) {return (step(hash12(id),u_facade_emissive_chance)+0.05)*v_faux_color_emissive.a;}return 0.0;}vec3 get_shade_info(in highp vec3 v,in highp vec3 v_normalized,in vec3 color,in vec2 id,in mat3 tbn,inout vec3 out_normal,inout float out_emissive) {vec3 out_color=color;highp vec3 abs_v=abs(v_normalized);bool x_major=abs_v.x >=abs_v.y && abs_v.x >=abs_v.z;bool y_major=abs_v.y >=abs_v.x && abs_v.y >=abs_v.z;bool z_major=abs_v.z >=abs_v.x && abs_v.z >=abs_v.y;\n#if 0\nif (x_major) {out_color=v.x > 0.0 ? vec3(1.0,0.0,0.0) : vec3(0.0,1.0,1.0);} else if (y_major) {out_color=v.y > 0.0 ? vec3(0.0,1.0,0.0) : vec3(1.0,0.0,1.0);} else if (z_major) {out_color=v.z > 0.0 ? vec3(0.0,0.0,1.0) : vec3(1.0,1.0,0.0);}out_emissive=1.0;\n#else\nif (x_major) {out_normal=-sign(v.x)*tbn[0];} else if (y_major) {out_normal=vec3(0.0,0.0,-sign(v.y));} else if (z_major) {out_color=v_faux_color_emissive.rgb;out_emissive=v.z <=0.0 ? get_emissive(id) : out_emissive;}float ao=1.0;if (u_faux_facade_ao_intensity > 0.0) {vec4 ao_range=v_faux_facade_window.xxyy*0.5-vec4(0,ao_radius,0,ao_radius);vec2 ao_range_z=vec2(window_depth*0.5)-vec2(0.0,ao_radius);if (x_major || y_major) {ao*=smoothstep(-ao_range_z.x,-ao_range_z.y,v.z);} else if (z_major) {ao*=smoothstep(-ao_range.x,-ao_range.y,v.x)*(1.0-smoothstep(ao_range.y,ao_range.x,v.x));ao*=smoothstep(-ao_range.z,-ao_range.w,v.y)*(1.0-smoothstep(ao_range.w,ao_range.z,v.y));}ao=mix(1.0,min(1.0,ao+0.25),u_faux_facade_ao_intensity);}out_color*=ao;\n#endif\nreturn out_color;}\n#endif\nvec3 apply_lighting_linear(in vec3 color,in vec3 normal,in float dir_factor) {float ambient_directional_factor=calculate_ambient_directional_factor(normal);vec3 ambient_contrib=ambient_directional_factor*u_lighting_ambient_color;vec3 directional_contrib=u_lighting_directional_color*dir_factor;return color*(ambient_contrib+directional_contrib);}void main() {vec3 normal=normalize(v_normal);vec3 base_color=v_color.rgb;float emissive=v_color.a;\n#ifdef BUILDING_FAUX_FACADE\nif (v_faux_facade > 0.0) {highp mat3 tbn=mat3(v_tbn_0,v_tbn_1,v_tbn_2);highp vec3 v=vec3(v_pos.xy,v_pos.z/u_tile_to_meter)-u_camera_pos;highp vec3 view_tangent=transpose(tbn)*v;highp vec2 q=vec2(v_faux_facade_ed,v_pos.z);float mask=0.0;vec2 id=vec2(0.0);highp vec2 uv=get_uv_mask_id(q,mask,id);uv*=v_faux_facade_window;highp vec3 bmin=vec3(0.0,0.0,-window_depth);highp vec3 bmax=bmin+vec3(v_faux_facade_window,window_depth);highp vec3 ray_o=vec3(uv,0.0);highp vec3 ray_d=normalize(view_tangent);highp float t_min=ray_unit_box(ray_o,ray_d,bmin,bmax);highp vec3 hit=ray_o+t_min*ray_d;highp vec3 r=vec3(v_faux_facade_window,-window_depth);hit-=r*0.5;highp vec3 normalized=hit/r;vec3 out_normal=normal;float out_emissive=emissive;vec3 room_color=get_shade_info(hit,normalized,base_color,id,tbn,out_normal,out_emissive);base_color=mix(base_color,room_color,mask);normal=mix(normal,out_normal,mask);emissive=mix(emissive,out_emissive,mask);}\n#endif\nvec4 color=vec4(base_color,1.0);vec3 xy_flipped_normal=vec3(-normal.xy,normal.z);float shadowed_lighting_factor=0.0;\n#ifdef RENDER_SHADOWS\n#ifdef RENDER_CUTOFF\nshadowed_lighting_factor=shadowed_light_factor_normal_opacity(xy_flipped_normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w,v_cutoff_opacity);if (v_cutoff_opacity==0.0) {discard;}\n#else\nshadowed_lighting_factor=shadowed_light_factor_normal(xy_flipped_normal,v_pos_light_view_0,v_pos_light_view_1,1.0/gl_FragCoord.w);\n#endif\n#else\nshadowed_lighting_factor=max(0.0,dot(xy_flipped_normal,u_lighting_directional_dir));\n#endif\ncolor.rgb=apply_lighting_linear(color.rgb,xy_flipped_normal,shadowed_lighting_factor);color.rgb=linearTosRGB(color.rgb);\n#ifdef FLOOD_LIGHT\nfloat flood_radiance=(1.0-min(v_pos.z/v_flood_radius,1.0))*u_flood_light_intensity*v_has_flood_light;color.rgb=mix(color.rgb,u_flood_light_color,flood_radiance);\n#endif\ncolor.rgb=mix(color.rgb,linearTosRGB(base_color.rgb),emissive);\n#ifdef FOG\ncolor=fog_dither(fog_apply_premultiplied(color,v_fog_pos,v_pos.z));\n#endif\ncolor*=u_opacity;\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\n{float ditherOpacity=cutoutGroundRoofOpacity(v_ground_roof);if (ditherOpacity < 1.0) {int index=(int(gl_FragCoord.x) % 4)*4+(int(gl_FragCoord.y) % 4);if (ditherOpacity < DITHER_THRESHOLDS[index]) {discard;}}}\n#else\ncolor=applyCutout(color,v_pos.z);\n#endif\n#endif\n#ifdef RENDER_FRONT_CUTOFF\nif (v_front_cutoff_opacity < 1.0) {int index=(int(gl_FragCoord.x) % 4)*4+(int(gl_FragCoord.y) % 4);if (v_front_cutoff_opacity < DITHER_THRESHOLDS[index]) {discard;}}\n#endif\n#ifdef FEATURE_CUTOUT\ncolor=apply_feature_cutout(color,gl_FragCoord,get_cutout_factors(gl_FragCoord).x);\n#endif\nglFragColor=color;\n#ifdef DEBUG_SHOW_NORMALS\ncolor.rgb=xy_flipped_normal*0.5+vec3(0.5,0.5,0.5);color.a=1.0;glFragColor=color;\n#endif\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\n#include "_prelude_shadow.vertex.glsl"\nin vec3 a_pos_3f;in ivec4 a_normal_3;in ivec4 a_centroid_3;\n#ifdef FLOOD_LIGHT\nin int a_flood_light_wall_radius_1i16;\n#endif\n#ifdef BUILDING_FAUX_FACADE\nin uvec4 a_faux_facade_data;in uvec2 a_faux_facade_vertical_range;\n#endif\nuniform mat4 u_matrix;uniform mat4 u_normal_matrix;uniform highp float u_tile_to_meter;\n#ifdef RENDER_FRONT_CUTOFF\nuniform vec3 u_front_cutoff_params;out float v_front_cutoff_opacity;\n#endif\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nout vec4 v_ground_roof;\n#endif\n#endif\nout vec4 v_color;out vec3 v_normal;out highp vec3 v_pos;\n#ifdef BUILDING_FAUX_FACADE\nout lowp float v_faux_facade;out highp float v_faux_facade_ed;out highp vec2 v_faux_facade_window;out highp vec2 v_faux_facade_floor;out highp vec2 v_faux_facade_range;out highp float v_aspect;out highp vec3 v_tbn_0;out highp vec3 v_tbn_1;out highp vec3 v_tbn_2;out highp vec4 v_faux_color_emissive;\n#endif\n#ifdef RENDER_SHADOWS\nuniform mat4 u_light_matrix_0;uniform mat4 u_light_matrix_1;out highp vec4 v_pos_light_view_0;out highp vec4 v_pos_light_view_1;\n#endif\n#ifdef FLOOD_LIGHT\nout highp float v_flood_radius;out float v_has_flood_light;\n#endif\nconst float MAX_UINT_16=65535.0;const float MAX_INT_16=32767.0;const float MAX_UINT_8=255.0;const float TWO_POW_8=256.0;const float FLOOD_LIGHT_MAX_RADIUS_METER=2048.0;vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}\n#ifdef BUILDING_FAUX_FACADE\nmat3 get_tbn(in vec3 normal) {const vec3 bitangent=vec3(0.0,0.0,1.0);vec3 tangent=normalize(vec3(normal.y,-normal.x,0.0));return mat3(tangent,bitangent,normal);}\n#endif\n#pragma mapbox: define-attribute-vertex-shader-only highp uvec2 part_color_emissive\n#pragma mapbox: define-attribute-vertex-shader-only highp uvec2 faux_facade_color_emissive\nvoid main() {\n#pragma mapbox: initialize-attribute-custom highp uvec2 part_color_emissive\n#pragma mapbox: initialize-attribute-custom highp uvec2 faux_facade_color_emissive\n#ifdef FLOOD_LIGHT\nv_flood_radius=(float(a_flood_light_wall_radius_1i16)/MAX_INT_16*FLOOD_LIGHT_MAX_RADIUS_METER);v_has_flood_light=step(0.0,v_flood_radius);\n#endif\nvec4 color_emissive=decode_color(vec2(part_color_emissive));v_color=vec4(sRGBToLinear(color_emissive.rgb),color_emissive.a);vec3 a_normal_3f=vec3(a_normal_3)/MAX_INT_16;v_normal=vec3(u_normal_matrix*vec4(a_normal_3f,0.0));float hidden=0.0;float depth_offset=0.0;vec2 centroid_xy=vec2(a_centroid_3.xy >> 2);vec2 spanBits=vec2(a_centroid_3.xy & 3);\n#ifdef BUILDING_FAUX_FACADE\nvec4 faux_facade_data=vec4(a_faux_facade_data);v_faux_facade=faux_facade_data.x;if (v_faux_facade > 0.0) {v_faux_facade_ed=faux_facade_data.x *u_tile_to_meter;float window_x_perc=floor(faux_facade_data.y/TWO_POW_8);float window_y_perc=faux_facade_data.y-TWO_POW_8*window_x_perc;vec2 window_perc=vec2(window_x_perc,window_y_perc)/MAX_UINT_8;v_faux_facade_floor=(faux_facade_data.zw/MAX_UINT_16*EXTENT)*u_tile_to_meter;v_faux_facade_window=window_perc*v_faux_facade_floor;v_faux_facade_range=(vec2(a_faux_facade_vertical_range)/MAX_UINT_16*EXTENT)*u_tile_to_meter;v_aspect=v_faux_facade_window.x/v_faux_facade_window.y;mat3 tbn=get_tbn(normalize(v_normal));v_tbn_0=tbn[0];v_tbn_1=tbn[1];v_tbn_2=tbn[2];v_faux_color_emissive=decode_color(vec2(faux_facade_color_emissive));v_faux_color_emissive.rgb=sRGBToLinear(v_faux_color_emissive.rgb);depth_offset=min(1000.0,float(a_centroid_3.z))*0.0000002;}\n#endif\nv_pos=a_pos_3f;\n#if defined(RENDER_CUTOFF) || defined(RENDER_FRONT_CUTOFF)\nfloat halfSpanX=spanBits.x*10.0/u_tile_to_meter;float halfSpanY=spanBits.y*10.0/u_tile_to_meter;vec2 screenUpInTile=vec2(u_matrix[0][1],u_matrix[1][1]);vec2 spanOffset=vec2(halfSpanX,halfSpanY)*sign(screenUpInTile);vec2 cutoff_highestCorner=centroid_xy+spanOffset;vec2 cutoff_lowestCorner=centroid_xy-spanOffset;\n#endif\n#if defined(RENDER_CUTOFF) || defined(RENDER_FRONT_CUTOFF)\nvec4 ground=u_matrix*vec4(centroid_xy,0.0,1.0);\n#endif\n#ifdef RENDER_CUTOFF\nv_cutoff_opacity=cutoff_opacity(u_cutoff_params,ground.z);hidden=float(v_cutoff_opacity==0.0);v_pos.z*=v_cutoff_opacity;\n#endif\n#ifdef RENDER_SHADOWS\nvec3 shadow_pos=v_pos;\n#ifdef NORMAL_OFFSET\nvec3 offset=shadow_normal_offset_model(v_normal);shadow_pos+=offset*shadow_normal_offset_multiplier0();\n#endif\nv_pos_light_view_0=u_light_matrix_0*vec4(shadow_pos,1.0);v_pos_light_view_1=u_light_matrix_1*vec4(shadow_pos,1.0);\n#endif\n#ifdef FOG\nv_fog_pos=fog_position(v_pos);\n#endif\n#ifdef RENDER_FRONT_CUTOFF\nv_front_cutoff_opacity=1.0;{hidden=max(hidden,float(ground.w <=0.0));float ndc_y=ground.y/max(ground.w,0.001);float threshold=u_front_cutoff_params.x*2.0-1.0;float range_ndc=u_front_cutoff_params.y*2.0;hidden=max(hidden,float(ndc_y < threshold-range_ndc));float t=clamp((ndc_y-(threshold-range_ndc))/max(range_ndc,0.001),0.0,1.0);v_front_cutoff_opacity=mix(u_front_cutoff_params.z,1.0,t);}\n#endif\ngl_Position=mix(u_matrix*vec4(v_pos,1),AWAY,hidden);gl_Position.z-=depth_offset*gl_Position.w;\n#ifdef INDICATOR_CUTOUT\n#ifdef FEATURE_CUTOUT\nvec4 ic_ground=u_matrix*vec4(v_pos.xy,0.0,1.0);vec4 ic_roof=u_matrix*vec4(v_pos.xy,v_pos.z,1.0);v_ground_roof=vec4(ic_ground.xy/ic_ground.w,ic_roof.xy/ic_roof.w);\n#endif\n#endif\n}'),buildingBloom:ho("in vec4 v_color_emissive;\n#pragma mapbox: define-attribute highp vec4 bloom_attenuation\n#pragma mapbox: initialize-attribute highp vec4 bloom_attenuation\nfloat saturate(float val) {return clamp(val,0.0,1.0);}void main() {float emission=v_color_emissive.a;float opacity=1.0;\n#ifdef HAS_ATTRIBUTE_a_bloom_attenuation\nfloat distance=length(vec2(1.3*max(0.0,abs(bloom_attenuation.x)-bloom_attenuation.z),bloom_attenuation.y));distance+= mix(0.5,0.0,clamp(emission-1.0,0.0,1.0));opacity*=saturate(1.0-distance*distance);\n#endif\n#ifdef RENDER_CUTOFF\nopacity*=v_cutoff_opacity;\n#endif\nglFragColor=vec4(v_color_emissive.rgb,1.0)*opacity;}","in vec3 a_pos_3f;\n#pragma mapbox: define-attribute-vertex-shader-only highp uvec2 part_color_emissive\n#pragma mapbox: define-attribute highp vec4 bloom_attenuation\nout vec4 v_color_emissive;uniform mat4 u_matrix;vec3 sRGBToLinear(vec3 srgbIn) {return pow(srgbIn,vec3(2.2));}void main() {\n#pragma mapbox: initialize-attribute-custom highp uvec2 part_color_emissive\n#pragma mapbox: initialize-attribute highp vec4 bloom_attenuation\n#ifdef HAS_ATTRIBUTE_a_part_color_emissive\nvec4 color_emissive=decode_color(vec2(part_color_emissive));float part_emissive=color_emissive.a*5.0;v_color_emissive=vec4(sRGBToLinear(color_emissive.rgb),part_emissive);\n#else\nv_color_emissive=vec4(1.0);\n#endif\ngl_Position=u_matrix*vec4(a_pos_3f,1.0);\n#ifdef RENDER_CUTOFF\nv_cutoff_opacity=cutoff_opacity(u_cutoff_params,gl_Position.z);\n#endif\n}"),buildingDepth:ho("void main() {}","in vec3 a_pos_3f;uniform mat4 u_matrix;void main() {gl_Position=u_matrix*vec4(a_pos_3f,1.0);}"),rasterParticle:ho('#include "_prelude_fog.fragment.glsl"\n#include "_prelude_lighting.glsl"\nuniform float u_fade_t;uniform float u_opacity;uniform highp float u_raster_elevation;in vec2 v_pos0;in vec2 v_pos1;uniform sampler2D u_image0;uniform sampler2D u_image1;void main() {vec4 color0,color1,color;color0=texture(u_image0,v_pos0);color1=texture(u_image1,v_pos1);if (color0.a > 0.0) color0.rgb/=color0.a;if (color1.a > 0.0) color1.rgb/=color1.a;color=mix(color0,color1,u_fade_t);color.a*=u_opacity;vec3 out_color=color.rgb;\n#ifdef LIGHTING_3D_MODE\nout_color=apply_lighting_with_emission_ground(vec4(out_color,1.0),1.0).rgb;\n#endif\n#ifdef FOG\nhighp float fog_limit_high_meters=1000000.0;highp float fog_limit_low_meters=600000.0;float fog_limit=1.0-smoothstep(fog_limit_low_meters,fog_limit_high_meters,u_raster_elevation);out_color=fog_dither(fog_apply(out_color,v_fog_pos,fog_limit));\n#endif\nglFragColor=vec4(out_color*color.a,color.a);\n#ifdef OVERDRAW_INSPECTOR\nglFragColor=vec4(1.0);\n#endif\nHANDLE_WIREFRAME_DEBUG;}','#include "_prelude_fog.vertex.glsl"\nuniform mat4 u_matrix;uniform mat4 u_normalize_matrix;uniform mat4 u_globe_matrix;uniform mat4 u_merc_matrix;uniform mat3 u_grid_matrix;uniform vec2 u_tl_parent;uniform float u_scale_parent;uniform float u_raster_elevation;uniform float u_zoom_transition;uniform vec2 u_merc_center;\n#define GLOBE_UPSCALE GLOBE_RADIUS/6371008.8\nin ivec2 a_pos;in uvec2 a_texture_pos;out vec2 v_pos0;out vec2 v_pos1;void main() {float w=1.0;vec2 uv;\n#ifdef PROJECTION_GLOBE_VIEW\nvec3 decomposed_pos_and_skirt=decomposeToPosAndSkirt(a_pos);vec3 latLng=u_grid_matrix*vec3(decomposed_pos_and_skirt.xy,1.0);float mercatorY=mercatorYfromLat(latLng[0]);float mercatorX=mercatorXfromLng(latLng[1]);float tiles=u_grid_matrix[0][2];float idx=u_grid_matrix[1][2];float idy=u_grid_matrix[2][2];float uvX=mercatorX*tiles-idx;float uvY=mercatorY*tiles-idy;uv=vec2(uvX,uvY);vec3 globe_pos=latLngToECEF(latLng.xy);globe_pos+=normalize(globe_pos)*u_raster_elevation*GLOBE_UPSCALE;vec4 globe_world_pos=u_globe_matrix*vec4(globe_pos,1.0);vec4 merc_world_pos=vec4(0.0);if (u_zoom_transition > 0.0) {vec2 merc_pos=vec2(mercatorX,mercatorY);merc_world_pos=vec4(merc_pos,u_raster_elevation,1.0);merc_world_pos.xy-=u_merc_center;merc_world_pos.x=wrap(merc_world_pos.x,-0.5,0.5);merc_world_pos=u_merc_matrix*merc_world_pos;}vec4 interpolated_pos=vec4(mix(globe_world_pos.xyz,merc_world_pos.xyz,u_zoom_transition)*w,w);gl_Position=u_matrix*interpolated_pos;\n#ifdef FOG\nv_fog_pos=fog_position((u_normalize_matrix*vec4(globe_pos,1.0)).xyz);\n#endif\n#else\nuv=vec2(a_texture_pos)/8192.0;gl_Position=u_matrix*vec4(vec2(a_pos)*w,u_raster_elevation*w,w);\n#ifdef FOG\nv_fog_pos=fog_position(vec2(a_pos));\n#endif\n#endif\nv_pos0=uv;v_pos1=(v_pos0*u_scale_parent)+u_tl_parent;}'),rasterParticleDraw:ho("uniform sampler2D u_color_ramp;in float v_particle_speed;void main() {glFragColor=texture(u_color_ramp,vec2(v_particle_speed,0.5));}",'#include "_prelude_raster_particle.glsl"\nin int a_index;uniform sampler2D u_particle_texture;uniform float u_particle_texture_side_len;uniform vec2 u_tile_offset;out float v_particle_speed;void main() {ivec2 pixel_coord=ivec2(\nmod(float(a_index),u_particle_texture_side_len),float(a_index)/u_particle_texture_side_len);vec4 pixel=texelFetch(u_particle_texture,pixel_coord,0);vec2 pos=unpack_pos_from_rgba(pixel)+u_tile_offset;vec2 tex_coord=fract(pos);vec2 velocity=lookup_velocity(tex_coord);if (velocity==INVALID_VELOCITY) {gl_Position=AWAY;v_particle_speed=0.0;} else {gl_Position=vec4(2.0*pos-1.0,0,1);v_particle_speed=length(velocity);}gl_PointSize=1.0;}'),rasterParticleTexture:ho("uniform sampler2D u_texture;uniform float u_opacity;in vec2 v_tex_pos;void main() {vec4 color=texture(u_texture,v_tex_pos);glFragColor=vec4(floor(255.0*color*u_opacity)/255.0);}","in ivec2 a_pos;out vec2 v_tex_pos;void main() {vec2 uv=0.5*vec2(a_pos)+vec2(0.5);v_tex_pos=uv;gl_Position=vec4(a_pos,0.0,1.0);}"),rasterParticleUpdate:ho('#include "_prelude_raster_particle.glsl"\nuniform sampler2D u_particle_texture;uniform mediump float u_particle_texture_side_len;uniform mediump float u_speed_factor;uniform highp float u_reset_rate;uniform highp float u_rand_seed;in highp vec2 v_tex_coord;vec2 linearstep(vec2 edge0,vec2 edge1,vec2 x) {return clamp((x-edge0)/(edge1-edge0),vec2(0),vec2(1));}const highp vec3 rand_constants=vec3(12.9898,78.233,4375.85453);highp float rand(const highp vec2 co) {highp float t=dot(rand_constants.xy,co);return fract(sin(t)*(rand_constants.z+t));}void main() {ivec2 pixel_coord=ivec2(v_tex_coord*u_particle_texture_side_len);highp vec4 pixel=texelFetch(u_particle_texture,pixel_coord,0);highp vec2 pos=unpack_pos_from_rgba(pixel);highp vec2 velocity=lookup_velocity(clamp(pos,0.0,1.0));highp vec2 dp=velocity==INVALID_VELOCITY ? vec2(0) : velocity*u_speed_factor;pos=pos+dp;highp vec2 seed=(pos+v_tex_coord)*u_rand_seed;highp vec2 random_pos=vec2(rand(seed+1.3),rand(seed+2.1));highp vec2 persist_rate=pow(\nlinearstep(vec2(-u_particle_pos_offset),vec2(0),pos)*linearstep(vec2(1.0+u_particle_pos_offset),vec2(1),pos),vec2(4)\n);highp vec2 per_frame_persist=pow(persist_rate,abs(dp)/u_particle_pos_offset);highp float drop_rate=1.0-per_frame_persist.x*per_frame_persist.y;drop_rate=any(greaterThanEqual(abs(pos-0.5),vec2(0.5+u_particle_pos_offset))) ? 1.0 : drop_rate;highp float drop=step(1.0-drop_rate-u_reset_rate,rand(seed));highp vec2 next_pos=mix(pos,random_pos,drop);glFragColor=pack_pos_to_rgba(next_pos);}',"in ivec2 a_pos;out vec2 v_tex_coord;void main() {v_tex_coord=0.5*vec2(a_pos+ivec2(1));gl_Position=vec4(a_pos,0.0,1.0);}"),snowParticle:ho("in highp vec2 uv;in highp float alphaMultiplier;uniform vec4 u_particleColor;uniform vec2 u_simpleShapeParameters;void main() {float t=clamp((length(uv)-u_simpleShapeParameters.x)/(1.0-u_simpleShapeParameters.x),0.0,1.0);float alpha=1.0-pow(t,pow(10.0,u_simpleShapeParameters.y));alpha*=alphaMultiplier;alpha*=u_particleColor.a;vec3 color=u_particleColor.rgb*alpha;glFragColor=vec4(color,alpha) ;HANDLE_WIREFRAME_DEBUG;}","\nin highp vec3 a_pos_3f;in highp vec2 a_uv;in highp vec4 a_snowParticleData;in highp vec4 a_snowParticleDataHorizontalOscillation;uniform mat4 u_modelview;uniform mat4 u_projection;uniform vec3 u_cam_pos;uniform vec2 u_screenSize;uniform float u_time;uniform float u_boxSize;uniform float u_velocityConeAperture; \nuniform float u_velocity;uniform vec3 u_direction;uniform float u_horizontalOscillationRadius; \nuniform float u_horizontalOscillationRate; \nuniform float u_billboardSize;uniform vec2 u_thinningCenterPos;uniform vec3 u_thinningShape;uniform float u_thinningAffectedRatio;uniform float u_thinningParticleOffset;out highp vec2 uv;out highp float alphaMultiplier;void main() {vec3 pos=a_pos_3f;float halfBoxSize=0.5*u_boxSize;pos.xyz*=halfBoxSize;pos+=u_cam_pos;float velocityConeApertureRad=radians(u_velocityConeAperture*0.5);float coneAnglePichRad=velocityConeApertureRad*a_snowParticleData.z;float coneAngleHeadingRad=a_snowParticleData.w*radians(360.0);vec3 localZ=normalize(u_direction);vec3 localX=normalize(cross(localZ,vec3(1,0,0)));vec3 localY=normalize(cross(localZ,localX));vec3 direction;direction.x=cos(coneAngleHeadingRad)*sin(coneAnglePichRad);direction.y=sin(coneAngleHeadingRad)*sin(coneAnglePichRad);direction.z=cos(coneAnglePichRad);direction=normalize(direction);vec3 simPosLocal=vec3(0,0,0);float velocityScale=(1.0+3.0*a_snowParticleData.y)*u_velocity;simPosLocal+=direction*velocityScale*u_time;float horizontalOscillationRadius=u_horizontalOscillationRadius*a_snowParticleDataHorizontalOscillation.x;float horizontalOscillationAngle=u_horizontalOscillationRate*u_time*(-1.0+2.0*a_snowParticleDataHorizontalOscillation.y);simPosLocal.xy+=horizontalOscillationRadius*vec2(cos(horizontalOscillationAngle),sin(horizontalOscillationAngle));vec3 simPos=localX*simPosLocal.x+\nlocalY*simPosLocal.y+localZ*simPosLocal.z;pos+=simPos;pos=fract((pos+vec3(halfBoxSize))/vec3(u_boxSize))*u_boxSize-vec3(halfBoxSize);float clipZ=-u_cam_pos.z+pos.z;vec4 posView=u_modelview*vec4(pos,1.0);float size=u_billboardSize;alphaMultiplier=1.0;vec4 posScreen=u_projection*posView;posScreen/=posScreen.w;posScreen.xy=vec2(0.5)+posScreen.xy*0.5;posScreen.xy*=u_screenSize;vec2 thinningCenterPos=u_thinningCenterPos.xy;thinningCenterPos.y=u_screenSize.y-thinningCenterPos.y;float screenDist=length((thinningCenterPos-posScreen.xy)/(0.5*u_screenSize));screenDist+=a_snowParticleData.x*u_thinningParticleOffset;float scaleFactorMode=0.0;float thinningShapeDist=u_thinningShape.x+u_thinningShape.y;if (screenDist < thinningShapeDist) {float thinningFadeRatio=clamp((screenDist-u_thinningShape.x)/u_thinningShape.y,0.0,1.0);thinningFadeRatio=pow(thinningFadeRatio,u_thinningShape.z);if (a_snowParticleData.x < u_thinningAffectedRatio) {scaleFactorMode=1.0-thinningFadeRatio;alphaMultiplier=thinningFadeRatio;}}vec4 posScreen1=u_projection*vec4(posView.x-size,posView.yzw);posScreen1/=posScreen1.w;vec4 posScreen2=u_projection*vec4(posView.x+size,posView.yzw);posScreen2/=posScreen2.w;posScreen1.xy=vec2(0.5)+posScreen1.xy*0.5;posScreen1.xy*=u_screenSize;posScreen2.xy=vec2(0.5)+posScreen2.xy*0.5;posScreen2.xy*=u_screenSize;float screenLength=length(posScreen1.xy-posScreen2.xy);float screenEpsilon=3.0;float scaleFactor=1.0;if (screenLength < screenEpsilon) {scaleFactor=screenEpsilon/max(screenLength,0.01);scaleFactor=mix(scaleFactor,1.0,scaleFactorMode);}float screenEpsilon2=15.0;if (screenLength > screenEpsilon2) {scaleFactor=screenEpsilon2/max(screenLength,0.01);}size*=scaleFactor;vec2 right=size*vec2(1,0);vec2 up=size*vec2(0,1);posView.xy+=right*a_uv.x;posView.xy+=up*a_uv.y;uv=a_uv;gl_Position=u_projection*posView;}"),rainParticle:ho("in highp vec2 uv;in highp float particleRandomValue;uniform sampler2D u_texScreen;uniform float u_distortionStrength;uniform vec4 u_color;uniform vec2 u_thinningCenterPos;uniform vec3 u_thinningShape;uniform float u_thinningAffectedRatio;uniform float u_thinningParticleOffset;uniform float u_shapeDirectionalPower;uniform float u_mode;void main() {vec2 st=uv*0.5+vec2(0.5);vec2 uvm=uv;uvm.y=-1.0+2.0*pow(st.y,u_shapeDirectionalPower);float shape=clamp(1.0-length(uvm),0.0,1.0);float alpha=abs(shape)*u_color.a;vec2 screenSize=vec2(textureSize(u_texScreen,0));vec2 thinningCenterPos=u_thinningCenterPos.xy;thinningCenterPos.y=screenSize.y-thinningCenterPos.y;float screenDist=length((thinningCenterPos-gl_FragCoord.xy)/(0.5*screenSize));screenDist+=(0.5+0.5*particleRandomValue)*u_thinningParticleOffset;float thinningShapeDist=u_thinningShape.x+u_thinningShape.y;float thinningAlpha=1.0;if (screenDist < thinningShapeDist) {float thinningFadeRatio=clamp((screenDist-u_thinningShape.x)/u_thinningShape.y,0.0,1.0);thinningFadeRatio=pow(thinningFadeRatio,u_thinningShape.z);thinningAlpha*=thinningFadeRatio;}vec2 offsetXY=normalize(uvm)*abs(shape);vec2 stScreen=(gl_FragCoord.xy+offsetXY*u_distortionStrength*thinningAlpha)/screenSize;vec3 colorScreen=texture(u_texScreen,stScreen).rgb;alpha*=thinningAlpha;glFragColor=mix(vec4(colorScreen,1.0),vec4(u_color.rgb*alpha,alpha),u_mode);HANDLE_WIREFRAME_DEBUG;}","\nin highp vec3 a_pos_3f;in highp vec2 a_uv;in highp vec4 a_rainParticleData;uniform mat4 u_modelview;uniform mat4 u_projection;uniform vec3 u_cam_pos;uniform float u_time;uniform float u_boxSize;uniform float u_velocityConeAperture; \nuniform float u_velocity; \nuniform vec2 u_rainDropletSize;uniform vec3 u_rainDirection;out highp vec2 uv;out highp float particleRandomValue;void main() {vec3 pos=a_pos_3f;float halfBoxSize=0.5*u_boxSize;pos*=halfBoxSize; \npos+=u_cam_pos;float velocityConeApertureRad=radians(u_velocityConeAperture*0.5);float coneAnglePichRad=velocityConeApertureRad*a_rainParticleData.z;float coneAngleHeadingRad=a_rainParticleData.w*radians(360.0);vec3 localZ=normalize(u_rainDirection);vec3 localX=normalize(cross(localZ,vec3(1,0,0)));vec3 localY=normalize(cross(localZ,localX));vec3 directionLocal;directionLocal.x=cos(coneAngleHeadingRad)*sin(coneAnglePichRad);directionLocal.y=sin(coneAngleHeadingRad)*sin(coneAnglePichRad);directionLocal.z=cos(coneAnglePichRad);directionLocal=normalize(directionLocal);vec3 directionWorld=localX*directionLocal.x+localY*directionLocal.y+localZ*directionLocal.z;float velocityScale=(1.0+3.0*a_rainParticleData.y)*u_velocity;vec3 simPosLocal=vec3(0,0,0);simPosLocal+=directionLocal*velocityScale*u_time;vec3 simPos=localX*simPosLocal.x+\nlocalY*simPosLocal.y+localZ*simPosLocal.z;pos+=simPos;pos=fract((pos+vec3(halfBoxSize))/vec3(u_boxSize))*u_boxSize-vec3(halfBoxSize);vec4 posView=u_modelview*vec4(pos,1.0);vec3 directionView=normalize((u_modelview*vec4(directionWorld,0.0)).xyz);vec3 side=cross(directionView,normalize(posView.xyz));posView.xyz+=side*a_uv.x*u_rainDropletSize.x;posView.xyz+=directionView*a_uv.y*u_rainDropletSize.y;uv=a_uv;particleRandomValue=a_rainParticleData.x;gl_Position=u_projection*posView;}"),vignette:ho("uniform vec3 u_vignetteShape;uniform vec4 u_vignetteColor;in vec2 st;void main() {float screenDist=length(st);float alpha=clamp((screenDist-u_vignetteShape.x)/u_vignetteShape.y,0.0,1.0);alpha=pow(alpha,u_vignetteShape.z)*u_vignetteColor.a;vec3 color=u_vignetteColor.rgb;glFragColor=vec4(color*alpha,alpha) ;}","in vec2 a_pos_2f;out vec2 st;void main() {st=a_pos_2f;gl_Position=vec4(a_pos_2f,0,1);}")};ho($a,"");const Za=e.ea([{type:"Float32",name:"a_pos_3f",components:3},{type:"Float32",name:"a_uv",components:2},{type:"Float32",name:"a_rainParticleData",components:4}]),Wa=e.ea([{type:"Float32",name:"a_pos_2f",components:2}]);class Xa{destroy(){this.vignetteVx&&this.vignetteVx.destroy(),this.vignetteIdx&&this.vignetteIdx.destroy()}draw(t,i){const r=t.getOrCreateProgram("vignette");if(!this.vignetteVx||!this.vignetteIdx){const i=new e.ee,r=new e.dF;i.emplaceBack(-1,-1),i.emplaceBack(1,-1),i.emplaceBack(1,1),i.emplaceBack(-1,1),r.emplaceBack(0,1,2),r.emplaceBack(0,2,3),this.vignetteVx=t.context.createVertexBuffer(i,Wa.members),this.vignetteIdx=t.context.createIndexBuffer(r)}const n=e.dB.simpleSegment(0,0,4,6);if(this.vignetteVx&&this.vignetteIdx){t.uploadCommonUniforms(t.context,r);const e={u_vignetteShape:(o={vignetteShape:[i.start,i.range,Math.pow(10,i.fadePower)],vignetteColor:[i.color.r,i.color.g,i.color.b,i.color.a*i.strength]}).vignetteShape,u_vignetteColor:o.vignetteColor};r.draw(t,t.context.gl.TRIANGLES,$r.disabled,Zr.disabled,Hr.alphaBlended,Yr.disabled,e,"vignette",this.vignetteVx,this.vignetteIdx,n)}var o}}class Ya{constructor(){this._accumulatedOffsetX=0,this._accumulatedOffsetY=0,this._accumulatedElevation=0}update(t,i){const r=t.getFreeCameraOptions().position,n=r.toAltitude(),o=r.toLngLat(),s=e.am(o.lng),a=e.am(o.lat),l=t.pixelsPerMeter/i,c=s*e.eg,h=e.eg*Math.log(Math.tan(Math.PI/4+a/2));if(void 0===this._offsetXPrev)this._offsetXPrev=0,this._offsetYPrev=0,this._elevationPrev=0,this._accumulatedOffsetX=0,this._accumulatedOffsetY=0,this._accumulatedElevation=0;else{const e=-this._offsetYPrev+h,t=-this._elevationPrev+n;this._accumulatedOffsetX+=(-this._offsetXPrev+c)*l,this._accumulatedOffsetY+=e*l,this._accumulatedElevation+=t*l,this._offsetXPrev=c,this._offsetYPrev=h,this._elevationPrev=n}}getPosition(){return[this._accumulatedOffsetX,this._accumulatedOffsetY,this._accumulatedElevation]}}function Ja(e,t){return[-(e[0]-Math.floor(e[0]/t)*t),-(e[1]-Math.floor(e[1]/t)*t),-(e[2]-Math.floor(e[2]/t)*t)]}function Ka(t){const i=e.ef(1323123451230),r=[];for(let n=0;n<t;++n){const t=2*i()-1,n=2*i()-1,o=2*i()-1;r.push(e.cU(t,n,o))}return r}function Qa(t,i,r,n,o){const s=e.aB((o-r)/(n-r),0,1);return(1-s)*t+s*i}class el{constructor(e){this._movement=new Ya,this._accumulatedTimeFromStart=0,this._prevTime=Date.now()/1e3,this._vignette=new Xa,this._ppmScaleFactor=e}destroy(){this.particlesVx&&this.particlesVx.destroy(),this.particlesIdx&&this.particlesIdx.destroy(),this._vignette&&this._vignette.destroy()}updateOnRender(t,i){const r=t.transform;this._movement.update(r,this._ppmScaleFactor);const n=r.starsProjMatrix,o=e.bP([]);e.bR(o,o,e.am(90)-r._pitch),e.bQ(o,o,-r.angle);const s=e.bV(new Float32Array(16),o),a=new Float32Array([1,0,0,0,0,0,1,0,0,-1,0,0,0,0,0,1]),l=e.e9([],a),c=e.aC([],l,s),h=Date.now()/1e3;return this._accumulatedTimeFromStart+=(h-this._prevTime)*i,this._prevTime=h,{projectionMatrix:n,modelviewMatrix:c}}}const tl=e.ea([{type:"Float32",name:"a_pos_3f",components:3},{type:"Float32",name:"a_uv",components:2},{type:"Float32",name:"a_snowParticleData",components:4},{type:"Float32",name:"a_snowParticleDataHorizontalOscillation",components:2}]),il={drawBuilding:function(e,t,i,r){e.currentLayer<e.firstLightBeamLayer&&(e.firstLightBeamLayer=e.currentLayer);const n=i.paint.get("building-ambient-occlusion-ground-intensity"),o=i.paint.get("building-ambient-occlusion-ground-radius"),s=i.paint.get("building-ambient-occlusion-ground-attenuation"),a=i.paint.get("building-opacity");if(a<=0)return;let l=n>0&&o>0,c=!0;const h=i.paint.get("building-vertical-scale");if(h<=0)return;e.shadowRenderer||(c=!1);const u=e.conflationActive&&e.style.isLayerClipped(i,t.getSource());if(function(e,t,i,r,n,o){for(const s of o){const o=t.getTile(s).getBucket(i);o&&(n&&o.updateReplacement(s,e.replacementSource,r),o.uploadUpdatedIndexBuffer(e.context))}}(e,t,i,e.style.order.indexOf(i.fqid),u,r),function(e,t,i,r){for(const n of r){const r=t.getTile(n).getBucket(i);r&&r.needsEvaluation()&&r.uploadUpdatedColorBuffer(e.context)}}(e,t,i,r),i.resetLayerRenderingStats(e),e.shadowRenderer&&(e.shadowRenderer.useNormalOffset=!0),"shadow"===e.renderPass&&e.shadowRenderer){const n=[],o=e.shadowRenderer.getShadowPassDepthMode();Fa({painter:e,source:t,layer:i,coords:r,defines:n,blendMode:Hr.disabled,depthMode:o,opacity:a,verticalScale:h,facadeEmissiveChance:0,facadeAOIntensity:0,floodLightIntensity:0,floodLightColor:[0,0,0]})}else if("translucent"===e.renderPass){let d=["HAS_ATTRIBUTE_a_part_color_emissive","LIGHTING_3D_MODE"];c&&(d=d.concat("RENDER_SHADOWS")),e.shadowRenderer&&e.shadowRenderer.useNormalOffset&&(d=d.concat("NORMAL_OFFSET"));const p=i.paint.get("building-facade-emissive-chance"),f=i.paint.get("building-ambient-occlusion-intensity"),m=i.paint.get("building-flood-light-intensity"),_="none"===i.paint.get("building-flood-light-color-use-theme").constantOr("default"),g=i.paint.get("building-flood-light-color").toNonPremultipliedRenderColor(_?null:i.lut).toArray01().slice(0,3),y=i.paint.get("building-flood-light-ground-attenuation"),x=m>0,v=new $r(e.context.gl.LEQUAL,$r.ReadWrite,e.depthRangeFor3D);a<1&&Fa({painter:e,source:t,layer:i,coords:r,defines:d,blendMode:Hr.disabled,depthMode:v,opacity:a,verticalScale:h,facadeEmissiveChance:p,facadeAOIntensity:f,floodLightIntensity:m,floodLightColor:g,depthOnly:!0});const b=e.colorModeForRenderPass();Fa({painter:e,source:t,layer:i,coords:r,defines:d,blendMode:b,depthMode:v,opacity:a,verticalScale:h,facadeEmissiveChance:p,facadeAOIntensity:f,floodLightIntensity:m,floodLightColor:g});const w=i.paint.get("building-front-cutoff");Ta(e.transform.pitch,w,!!e.terrain),l&&Oa(e,t,i,r,!0,a,n,o,m,g,s,u),x&&Oa(e,t,i,r,!1,a,n,o,m,g,y,u)}else if("light-beam"===e.renderPass){const n=["HAS_ATTRIBUTE_a_part_color_emissive","HAS_ATTRIBUTE_a_bloom_attenuation"],o=new $r(e.context.gl.LEQUAL,$r.ReadOnly,e.depthRangeFor3D);Fa({painter:e,source:t,layer:i,coords:r,defines:n,blendMode:Hr.alphaBlended,depthMode:o,opacity:a,verticalScale:h,facadeEmissiveChance:0,facadeAOIntensity:0,floodLightIntensity:0,floodLightColor:[0,0,0]})}e.shadowRenderer&&(e.shadowRenderer.useNormalOffset=!1),e.resetStencilClippingMasks()},drawRasterParticle:function(t,i,r,n,o,s){"offscreen"===t.renderPass&&function(t,i,r,n){if(!n.length)return;const o=t.context,s=o.gl,a=i.getSource();if(!(a instanceof vi))return;const l=Math.ceil(Math.sqrt(r.paint.get("raster-particle-count")));let c=r.particlePositionRGBAImage;if(!c||c.width!==l){const t=function(t){const i=t*t,r=new Uint8Array(4*i),n=.9090909090909091;for(let o=0;o<i;o++){const t=n*(e.ed(2*o+0)+Ba),i=n*(e.ed(2*o+1)+Ba),s=255*t%1,a=255*i%1,l=s,c=i-a/255,h=a;r[4*o+0]=255*(t-s/255),r[4*o+1]=255*l,r[4*o+2]=255*c,r[4*o+3]=255*h}return r}(l);c=r.particlePositionRGBAImage=new e.q({width:l,height:l},t)}let h=r.particleFramebuffer;h?h.width!==l&&(h.destroy(),h=r.particleFramebuffer=o.createFramebuffer(l,l,1,null)):h=r.particleFramebuffer=o.createFramebuffer(l,l,1,null);const u=[];for(const e of n){const t=i.getTile(e);if(!(t instanceof Ci))continue;const n=Ga(t,a,r);if(!n)continue;const s=[t.tileSize,t.tileSize];let h=r.tileFramebuffer;h||(h=r.tileFramebuffer=o.createFramebuffer(s[0],s[1],1,null));let d=t.rasterParticleState;d||(d=t.rasterParticleState=new ja(o,e,s,c));const p=d.update(r.lastInvalidatedAt);d.particleTextureDimension!==l&&d.updateParticleTexture(e,c);const f=d.targetColorTexture;d.targetColorTexture=d.backgroundColorTexture,d.backgroundColorTexture=f;const m=d.particleTexture0;d.particleTexture0=d.particleTexture1,d.particleTexture1=m,u.push([e,n,d,p])}if(0===u.length)return;const d=e.o.now(),p=r.previousDrawTimestamp?.001*(d-r.previousDrawTimestamp):.0167;if(r.previousDrawTimestamp=d,r.hasColorMap()){o.activeTexture.set(s.TEXTURE0+2);let t=r.colorRampTexture;t||(t=r.colorRampTexture=new e.T(o,r.colorRamp,s.RGBA8)),t.bind(s.LINEAR,s.CLAMP_TO_EDGE)}o.bindFramebuffer.set(r.tileFramebuffer.framebuffer),function(t,i,r){const n=t.context,o=n.gl,s=i.tileFramebuffer;n.activeTexture.set(o.TEXTURE0);const a={u_texture:0,u_opacity:1.05*(c=i.paint.get("raster-particle-fade-opacity-factor"))/(c+.05)},l=t.getOrCreateProgram("rasterParticleTexture",{defines:[],overrideFog:!1});var c;for(const h of r){const[,,r,c]=h;s.colorAttachment0.set(r.targetColorTexture.texture),n.viewport.set([0,0,s.width,s.height]),n.clear({color:e.C.transparent}),c&&(r.backgroundColorTexture.bind(o.NEAREST,o.CLAMP_TO_EDGE),l.draw(t,o.TRIANGLES,$r.disabled,Zr.disabled,Hr.alphaBlended,Yr.disabled,a,i.id,t.viewportBuffer,t.quadTriangleIndexBuffer,t.viewportSegments))}}(t,r,u),function(t,i,r,n){const o=t.context,s=o.gl,a=r.tileFramebuffer,l="globe"===t.transform.projection.name,c=r.paint.get("raster-particle-max-speed");for(const h of n){const[n,u,d]=h;o.activeTexture.set(s.TEXTURE0+0),u.texture.bind(s.LINEAR,s.CLAMP_TO_EDGE),a.colorAttachment0.set(d.targetColorTexture.texture);const p=t.getOrCreateProgram("rasterParticleDraw",{defines:u.defines,overrideFog:!1});o.activeTexture.set(s.TEXTURE0+1);const f=u.scalarData?[]:[0,1,2,3].map(t=>e.e2[t](n));f.push(n);const m=n.canonical.x,_=n.canonical.y;for(const e of f){const o=i.getTile(l?e.wrapped():e);if(!o)continue;const a=o.rasterParticleState;if(!a)continue;const h=e.canonical.x+(1<<e.canonical.z)*(e.wrap-n.wrap),d=e.canonical.y;a.particleTexture0.bind(s.NEAREST,s.CLAMP_TO_EDGE);const f=Na(1,a.particleTexture0.size[0],[h-m,d-_],0,u.texture.size,2,c,u.textureOffset,u.scale,u.offset);p.draw(t,s.POINTS,$r.disabled,Zr.disabled,Hr.alphaBlended,Yr.disabled,f,r.id,a.particleIndexBuffer,void 0,a.particleSegment)}}}(t,i,r,u),o.bindFramebuffer.set(r.particleFramebuffer.framebuffer),function(t,i,r,n){const o=t.context,s=o.gl,a=i.paint.get("raster-particle-max-speed"),l=n*i.paint.get("raster-particle-speed-factor")*.15,c=function(e){return Math.pow(e,6)}(.01+1*i.paint.get("raster-particle-reset-rate-factor")),h=i.particleFramebuffer;o.viewport.set([0,0,h.width,h.height]);for(const u of r){const[,r,n]=u;o.activeTexture.set(s.TEXTURE0+0),r.texture.bind(s.LINEAR,s.CLAMP_TO_EDGE),o.activeTexture.set(s.TEXTURE0+1);const d=n.particleTexture0;d.bind(s.NEAREST,s.CLAMP_TO_EDGE);const p=Ua(1,d.size[0],0,r.texture.size,a,l,c,r.textureOffset,r.scale,r.offset);h.colorAttachment0.set(n.particleTexture1.texture),o.clear({color:e.C.transparent}),t.getOrCreateProgram("rasterParticleUpdate",{defines:r.defines}).draw(t,s.TRIANGLES,$r.disabled,Zr.disabled,Hr.unblended,Yr.disabled,p,i.id,t.viewportBuffer,t.quadTriangleIndexBuffer,t.viewportSegments)}}(t,r,u,p)}(t,i,r,n),"translucent"===t.renderPass&&(function(t,i,r,n){const o=t.context,s=o.gl,a=i.getSource().tileSize,l=5*(1-e.ag(e.cx,e.cx+1,t.transform.zoom))*a+r.paint.get("raster-particle-elevation"),c=!t.options.moving,h="globe"===t.transform.projection.name;if(!n.length)return;const[u,d]=t.stencilConfigForOverlap(n),p=[];h&&p.push("PROJECTION_GLOBE_VIEW");const f=t.stencilModeFor3D();for(const m of d){const n=m.toUnwrapped(),a=i.getTile(m);if(!a.rasterParticleState)continue;const d=a.rasterParticleState,_=100;a.registerFadeDuration(_);const g=i.findLoadedParent(m,0),y=ls(a,g,i,t.transform,_);let x,v;t.terrain&&t.terrain.prepareDrawTile(),o.activeTexture.set(s.TEXTURE0),d.targetColorTexture.bind(s.LINEAR,s.CLAMP_TO_EDGE),o.activeTexture.set(s.TEXTURE1),g&&g.rasterParticleState?(g.rasterParticleState.targetColorTexture.bind(s.LINEAR,s.CLAMP_TO_EDGE),x=Math.pow(2,g.tileID.overscaledZ-a.tileID.overscaledZ),v=[a.tileID.canonical.x*x%1,a.tileID.canonical.y*x%1]):d.targetColorTexture.bind(s.LINEAR,s.CLAMP_TO_EDGE);const b=h?t.transform.expandedFarZProjMatrix:t.transform.calculateProjMatrix(n,c),w=t.transform,T=Ha(w),S=e.du(m.canonical),I=e.dv(S.getCenter().lat);let E,A,M,C,P;h?(E=Float32Array.from(e.dx(e.dy(m.canonical))),A=Float32Array.from(w.globeMatrix),M=Float32Array.from(e.dt(w)),C=[e.aG(w.center.lng),e.aJ(w.center.lat)],P=Float32Array.from(e.dw(m.canonical,S,I,w.worldSize/w._pixelsPerMercatorPixel))):(E=new Float32Array(16),A=new Float32Array(9),M=new Float32Array(16),C=[0,0],P=new Float32Array(9));const D=ka(b,E,A,M,P,v||[0,0],e.ai(t.transform.zoom),C,T,x||1,y,l),R=t.isTileAffectedByFog(m),z=t.getOrCreateProgram("rasterParticle",{defines:p,overrideFog:R});if(t.uploadCommonUniforms(o,z,n),h){const e=new $r(s.LEQUAL,$r.ReadOnly,t.depthRangeFor3D),i=t.globeSharedBuffers;if(i){const[n,o,a]=i.getGridBuffers(I,!1);z.draw(t,s.TRIANGLES,e,f,Hr.alphaBlended,t.renderElevatedRasterBackface?Yr.frontCCW:Yr.backCCW,D,r.id,n,o,a)}}else{const e=t.depthModeForSublayer(0,$r.ReadOnly),i=u[m.overscaledZ],{tileBoundsBuffer:n,tileBoundsIndexBuffer:o,tileBoundsSegments:l}=t.getTileBoundsBuffers(a);z.draw(t,s.TRIANGLES,e,i,Hr.alphaBlended,Yr.disabled,D,r.id,n,o,l)}}t.resetStencilClippingMasks()}(t,i,r,n),t.style.map.triggerRepaint())},prepareRasterParticle:function(e,t,i){const r=t.getSource();if(!(r instanceof vi&&r.loaded()))return;const n=e.sourceLayer||r.rasterLayerIds&&r.rasterLayerIds[0];if(!n)return;const o=e.paint.get("raster-particle-array-band")||r.getInitialBand(n);if(null==o)return;const s=t.getIds().map(e=>t.getTileByID(e));for(const a of s)a.updateNeeded(e.id,o)&&r.prepareTile(a,n,e.id,o)},Rain:class extends el{constructor(){super(4.25),this._params={intensity:.5,timeFactor:1,velocityConeAperture:0,velocity:300,boxSize:2500,dropletSizeX:1,dropletSizeYScale:10,distortionStrength:70,screenThinning:{intensity:.57,start:.46,range:1.17,fadePower:.17,affectedRatio:1,particleOffset:-.2},color:{r:.66,g:.68,b:.74,a:.7},direction:{x:-50,y:-35},shapeDirPower:2,shapeNormalPower:1},this._vignetteParams={strength:1,start:.7,range:1,fadePower:.4,color:{r:.27,g:.27,b:.27,a:1}},this.particlesCount=16e3,this._devtoolsFolder=null,this._painter=null}destroy(){super.destroy()}update(t){const i=t.context;if(!this.particlesVx){const t=Ka(this.particlesCount),r=new e.eh,n=new e.dF;let o=0;const s=e.ef(1323123451230);for(let e=0;e<t.length;++e){const i=t[e],a=[2*s()-1,s(),s(),s()];r.emplaceBack(i[0],i[1],i[2],-1,-1,...a),r.emplaceBack(i[0],i[1],i[2],1,-1,...a),r.emplaceBack(i[0],i[1],i[2],1,1,...a),r.emplaceBack(i[0],i[1],i[2],-1,1,...a),n.emplaceBack(o+0,o+1,o+2),n.emplaceBack(o+0,o+2,o+3),o+=4}this.particlesVx=i.createVertexBuffer(r,Za.members),this.particlesIdx=i.createIndexBuffer(n)}}getDrawParams(e){if(!e.style.rain)return null;const t=e.style.rain.state,i=structuredClone(this._params);i.intensity=t.density,i.timeFactor=t.intensity,i.color=structuredClone(t.color),i.screenThinning.intensity=t.centerThinning,i.dropletSizeX=t.dropletSize[0],i.dropletSizeYScale=t.dropletSize[1]/t.dropletSize[0],i.distortionStrength=100*t.distortionStrength;const r=structuredClone(this._vignetteParams);return r.strength=1,r.color=structuredClone(t.vignetteColor),{params:i,vignetteParams:r,revealParams:{revealStart:0,revealRange:.01},direction:structuredClone(t.direction)}}draw(t){const i=this.getDrawParams(t);if(!i)return;const{params:r,revealParams:n,direction:o,vignetteParams:s}=i,a=t.transform.zoom;if(n.revealStart>a)return;const l=Qa(0,1,n.revealStart,n.revealStart+n.revealRange,a);if(!this.particlesVx||!this.particlesIdx)return;s.strength*=l;const c=this.updateOnRender(t,r.timeFactor),h=t.context,u=h.gl,d=t.transform;this.screenTexture&&this.screenTexture.size[0]===t.width&&this.screenTexture.size[1]===t.height||(this.screenTexture=new e.T(h,{width:t.width,height:t.height,data:null},u.RGBA8)),r.distortionStrength>0&&(h.activeTexture.set(u.TEXTURE0),this.screenTexture.bind(u.LINEAR,u.CLAMP_TO_EDGE),u.copyTexSubImage2D(u.TEXTURE_2D,0,0,0,0,0,t.width,t.height));const p=t.getOrCreateProgram("rainParticle");t.uploadCommonUniforms(h,p),h.activeTexture.set(u.TEXTURE0),this.screenTexture.bind(u.LINEAR,u.CLAMP_TO_EDGE);const f=[r.color.r,r.color.g,r.color.b,r.color.a],m=(i,n)=>{const s=Ja(this._movement.getPosition(),i),a=r.dropletSizeX,l=r.dropletSizeX*r.dropletSizeYScale,h=t.width/2,m=t.height/2,_=Qa(0,r.screenThinning.start,0,1,r.screenThinning.intensity),g=Qa(.001,r.screenThinning.range,0,1,r.screenThinning.intensity),y=Qa(0,r.screenThinning.particleOffset,0,1,r.screenThinning.intensity),x=(v={modelview:c.modelviewMatrix,projection:c.projectionMatrix,time:this._accumulatedTimeFromStart,camPos:s,velocityConeAperture:r.velocityConeAperture,velocity:r.velocity,boxSize:i,rainDropletSize:[a,l],distortionStrength:r.distortionStrength,rainDirection:o,color:f,screenSize:[d.width,d.height],thinningCenterPos:[h,m],thinningShape:[_,g,Math.pow(10,r.screenThinning.fadePower)],thinningAffectedRatio:r.screenThinning.affectedRatio,thinningParticleOffset:y,shapeDirectionalPower:r.shapeDirPower,shapeNormalPower:r.shapeNormalPower,mode:n?0:1},{u_modelview:Float32Array.from(v.modelview),u_projection:Float32Array.from(v.projection),u_time:v.time,u_cam_pos:v.camPos,u_texScreen:0,u_velocityConeAperture:v.velocityConeAperture,u_velocity:v.velocity,u_boxSize:v.boxSize,u_rainDropletSize:v.rainDropletSize,u_distortionStrength:v.distortionStrength,u_rainDirection:v.rainDirection,u_color:v.color,u_screenSize:v.screenSize,u_thinningCenterPos:v.thinningCenterPos,u_thinningShape:v.thinningShape,u_thinningAffectedRatio:v.thinningAffectedRatio,u_thinningParticleOffset:v.thinningParticleOffset,u_shapeDirectionalPower:v.shapeDirectionalPower,u_shapeNormalPower:v.shapeNormalPower,u_mode:v.mode});var v;const b=Math.round(r.intensity*this.particlesCount),w=e.dB.simpleSegment(0,0,4*b,2*b);p.draw(t,u.TRIANGLES,$r.disabled,Zr.disabled,Hr.alphaBlended,Yr.disabled,x,"rain_particles",this.particlesVx,this.particlesIdx,w)};r.distortionStrength>0&&m(r.boxSize,!0),m(r.boxSize,!1),this._vignette.draw(t,s)}},Snow:class extends el{constructor(){super(2.25),this._params={intensity:.85,timeFactor:.75,velocityConeAperture:70,velocity:40,horizontalOscillationRadius:4,horizontalOscillationRate:1.5,boxSize:2e3,billboardSize:2,shapeFadeStart:.27,shapeFadePower:.21,screenThinning:{intensity:.4,start:.15,range:1.4,fadePower:.24,affectedRatio:1,particleOffset:-.2},color:{r:1,g:1,b:1,a:1},direction:{x:-50,y:-35}},this._vignetteParams={strength:.3,start:.78,range:.46,fadePower:.2,color:{r:1,g:1,b:1,a:1}},this.particlesCount=16e3,this._devtoolsFolder=null,this._painter=null}destroy(){super.destroy()}update(t){const i=t.context;if(!this.particlesVx){const t=Ka(this.particlesCount),r=new e.ei,n=new e.dF;let o=0;const s=e.ef(1323123451230);for(let e=0;e<t.length;++e){const i=t[e],a=s(),l=s(),c=s(),h=[e/t.length,a,l,c],u=[s(),s()];r.emplaceBack(i[0],i[1],i[2],-1,-1,...h,...u),r.emplaceBack(i[0],i[1],i[2],1,-1,...h,...u),r.emplaceBack(i[0],i[1],i[2],1,1,...h,...u),r.emplaceBack(i[0],i[1],i[2],-1,1,...h,...u),n.emplaceBack(o+0,o+1,o+2),n.emplaceBack(o+0,o+2,o+3),o+=4}this.particlesVx=i.createVertexBuffer(r,tl.members),this.particlesIdx=i.createIndexBuffer(n)}}getDrawParams(e){if(!e.style.snow)return null;const t=e.style.snow.state,i=structuredClone(this._params);i.intensity=t.density,i.timeFactor=t.intensity,i.color=structuredClone(t.color),i.screenThinning.intensity=t.centerThinning,i.billboardSize=2.79*t.flakeSize;const r=structuredClone(this._vignetteParams);return r.strength=1,r.color=structuredClone(t.vignetteColor),{params:i,vignetteParams:r,revealParams:{revealStart:0,revealRange:.01},direction:structuredClone(t.direction)}}draw(t){const i=this.getDrawParams(t);if(!i)return;const{params:r,revealParams:n,direction:o,vignetteParams:s}=i,a=t.transform.zoom;if(n.revealStart>a)return;const l=Qa(0,1,n.revealStart,n.revealStart+n.revealRange,a);s.strength*=l;const c=this.updateOnRender(t,r.timeFactor);if(!this.particlesVx||!this.particlesIdx)return;const h=t.context,u=h.gl,d=t.transform,p=t.getOrCreateProgram("snowParticle");t.uploadCommonUniforms(h,p),((i,r,n)=>{const s=Ja(this._movement.getPosition(),i),a=d.width/2,l=d.height/2,h=Qa(0,n.screenThinning.start,0,1,n.screenThinning.intensity),f=Qa(.001,n.screenThinning.range,0,1,n.screenThinning.intensity),m=Qa(0,n.screenThinning.particleOffset,0,1,n.screenThinning.intensity),_=(g={modelview:c.modelviewMatrix,projection:c.projectionMatrix,time:this._accumulatedTimeFromStart,camPos:s,velocityConeAperture:n.velocityConeAperture,velocity:n.velocity,horizontalOscillationRadius:n.horizontalOscillationRadius,horizontalOscillationRate:n.horizontalOscillationRate,boxSize:i,billboardSize:1*n.billboardSize,simpleShapeParameters:[n.shapeFadeStart,n.shapeFadePower],screenSize:[d.width,d.height],thinningCenterPos:[a,l],thinningShape:[h,f,Math.pow(10,n.screenThinning.fadePower)],thinningAffectedRatio:n.screenThinning.affectedRatio,thinningParticleOffset:m,color:[n.color.r,n.color.g,n.color.b,n.color.a],direction:o},{u_modelview:Float32Array.from(g.modelview),u_projection:Float32Array.from(g.projection),u_time:g.time,u_cam_pos:g.camPos,u_velocityConeAperture:g.velocityConeAperture,u_velocity:g.velocity,u_horizontalOscillationRadius:g.horizontalOscillationRadius,u_horizontalOscillationRate:g.horizontalOscillationRate,u_boxSize:g.boxSize,u_billboardSize:g.billboardSize,u_simpleShapeParameters:g.simpleShapeParameters,u_screenSize:g.screenSize,u_thinningCenterPos:g.thinningCenterPos,u_thinningShape:g.thinningShape,u_thinningAffectedRatio:g.thinningAffectedRatio,u_thinningParticleOffset:g.thinningParticleOffset,u_particleColor:g.color,u_direction:g.direction});var g;const y=Math.round(n.intensity*this.particlesCount),x=e.dB.simpleSegment(0,0,4*y,2*y);this.particlesVx&&this.particlesIdx&&p.draw(t,u.TRIANGLES,$r.disabled,Zr.disabled,Hr.alphaBlended,Yr.disabled,_,"snow_particles",this.particlesVx,this.particlesIdx,x)})(r.boxSize,0,r),this._vignette.draw(t,s)}},shaders:qa,programUniforms:{building:t=>({u_matrix:new e.c3(t),u_normal_matrix:new e.c3(t),u_opacity:new e.c1(t),u_faux_facade_ao_intensity:new e.c1(t),u_camera_pos:new e.c0(t),u_tile_to_meter:new e.c1(t),u_facade_emissive_chance:new e.c1(t),u_flood_light_color:new e.c0(t),u_flood_light_intensity:new e.c1(t),u_front_cutoff_params:new e.c0(t)}),buildingBloom:t=>({u_matrix:new e.c3(t)}),buildingDepth:t=>({u_matrix:new e.c3(t)}),rasterParticle:t=>({u_matrix:new e.c3(t),u_normalize_matrix:new e.c3(t),u_globe_matrix:new e.c3(t),u_merc_matrix:new e.c3(t),u_grid_matrix:new e.dq(t),u_tl_parent:new e.c2(t),u_scale_parent:new e.c1(t),u_fade_t:new e.c1(t),u_opacity:new e.c1(t),u_image0:new e.b$(t),u_image1:new e.b$(t),u_raster_elevation:new e.c1(t),u_zoom_transition:new e.c1(t),u_merc_center:new e.c2(t),u_cutoff_params:new e.cS(t)}),rasterParticleTexture:t=>({u_texture:new e.b$(t),u_opacity:new e.c1(t)}),rasterParticleDraw:t=>({u_particle_texture:new e.b$(t),u_particle_texture_side_len:new e.c1(t),u_tile_offset:new e.c2(t),u_velocity:new e.b$(t),u_color_ramp:new e.b$(t),u_velocity_res:new e.c2(t),u_max_speed:new e.c1(t),u_uv_offset:new e.c2(t),u_data_scale:new e.c2(t),u_data_offset:new e.c1(t),u_particle_pos_scale:new e.c1(t),u_particle_pos_offset:new e.c2(t)}),rasterParticleUpdate:t=>({u_particle_texture:new e.b$(t),u_particle_texture_side_len:new e.c1(t),u_velocity:new e.b$(t),u_velocity_res:new e.c2(t),u_max_speed:new e.c1(t),u_speed_factor:new e.c1(t),u_reset_rate:new e.c1(t),u_rand_seed:new e.c1(t),u_uv_offset:new e.c2(t),u_data_scale:new e.c2(t),u_data_offset:new e.c1(t),u_particle_pos_scale:new e.c1(t),u_particle_pos_offset:new e.c2(t)}),snowParticle:t=>({u_modelview:new e.c3(t),u_projection:new e.c3(t),u_time:new e.c1(t),u_cam_pos:new e.c0(t),u_velocityConeAperture:new e.c1(t),u_velocity:new e.c1(t),u_horizontalOscillationRadius:new e.c1(t),u_horizontalOscillationRate:new e.c1(t),u_boxSize:new e.c1(t),u_billboardSize:new e.c1(t),u_simpleShapeParameters:new e.c2(t),u_screenSize:new e.c2(t),u_thinningCenterPos:new e.c2(t),u_thinningShape:new e.c0(t),u_thinningAffectedRatio:new e.c1(t),u_thinningParticleOffset:new e.c1(t),u_particleColor:new e.cS(t),u_direction:new e.c0(t)}),rainParticle:t=>({u_modelview:new e.c3(t),u_projection:new e.c3(t),u_time:new e.c1(t),u_cam_pos:new e.c0(t),u_texScreen:new e.b$(t),u_velocityConeAperture:new e.c1(t),u_velocity:new e.c1(t),u_boxSize:new e.c1(t),u_rainDropletSize:new e.c2(t),u_distortionStrength:new e.c1(t),u_rainDirection:new e.c0(t),u_color:new e.cS(t),u_screenSize:new e.c2(t),u_thinningCenterPos:new e.c2(t),u_thinningShape:new e.c0(t),u_thinningAffectedRatio:new e.c1(t),u_thinningParticleOffset:new e.c1(t),u_shapeDirectionalPower:new e.c1(t),u_shapeNormalPower:new e.c1(t),u_mode:new e.c1(t)}),vignette:t=>({u_vignetteShape:new e.c0(t),u_vignetteColor:new e.cS(t)})}};function rl(t){return[t[0]*e.ej,t[1]*e.ej,t[2]*e.ej,0]}function nl(t,i,r,n,o,s,a,l,c){const h=n.getSource(),u=r.globeSharedBuffers;if(!u)return;let d,p,f;if(i&&(d=n.getTile(i)),h instanceof e.aY?(p=h.texture,f=e.dz(0,0,r.transform)):d&&i&&(p=d.texture,f=e.dz(i.canonical.z,i.canonical.x,r.transform)),!p||!f)return;t||(f=e.cE(e.bd(),f,[1,-1,1]));const m=r.context,_=m.gl,g="nearest"===o.paint.get("raster-resampling")?_.NEAREST:_.LINEAR,y=r.colorModeForDrapableLayerRenderPass(s),x=a.defines;x.push("GLOBE_POLES");const v=new $r(_.LEQUAL,$r.ReadWrite,r.depthRangeFor3D),b=r.transform.expandedFarZProjMatrix,w=Float32Array.from(e.dx(e.dy(new e.cp(0,0,0))));r.terrain&&r.terrain.prepareDrawTile(),m.activeTexture.set(_.TEXTURE0),p.bind(g,_.CLAMP_TO_EDGE),m.activeTexture.set(_.TEXTURE1),p.bind(g,_.CLAMP_TO_EDGE),"useMipmap"in p&&m.extTextureFilterAnisotropic&&r.transform.pitch>20&&_.texParameterf(_.TEXTURE_2D,m.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,m.extTextureFilterAnisotropicMax);const[T,S,I,E]=i?u.getPoleBuffers(i.canonical.z,!1):u.getPoleBuffers(0,!0),A=o.paint.get("raster-elevation");let M;t?(M=T,r.renderDefaultNorthPole=0!==A):(M=S,r.renderDefaultSouthPole=0!==A);const C=rl(a.mix),P=((e,t,i,r,n,o,s,a,l,c,h,u,d,p)=>Ns(e,t,i,r,new Float32Array(16),new Float32Array(9),[0,0],n,[0,0],[0,0,0,0],1,{opacity:1,mix:0},s,[0,0],l,2,h,u,d,1,0,p))(r,b,w,f,e.ai(r.transform.zoom),0,o,0,A,0,C,a.offset,a.range,s),D=r.getOrCreateProgram("raster",{defines:x});r.uploadCommonUniforms(m,D,null),D.draw(r,_.TRIANGLES,v,c,y,l,P,o.id,M,I,E)}function ol(e){if(e.isOrthographic)return[0,0,0,0];const t=e._nearZ,i=e.projection.farthestPixelDistance(e),r=i-t,n=.2*e.height,o=t+n;return[t,i,(o-n-t)/r,(o-t)/r]}function sl(e,t,i,r){if(e)return t instanceof vi&&e instanceof Ci?t.getTextureDescriptor(e,i,!0):{texture:e.texture,mix:rl(r.mix),offset:r.offset,buffer:0,tileSize:1}}const al=e.bA(new Float32Array(16)),ll=new e.C(1,0,0,1),cl=new e.C(0,1,0,1),hl=new e.C(0,0,1,1),ul=new e.C(1,0,1,1),dl=new e.C(0,1,1,1);function pl(t,i,r,n,o,s,a){const l=t.context,c=t.transform,h=l.gl,u="globe"===c.projection.name,d=u?["PROJECTION_GLOBE_VIEW"]:[];let p=e.bb(r.projMatrix);if(u&&e.ai(c.zoom)>0){const t=e.ek(r.canonical,c),i=e.el(t);p=e.aC(new Float32Array(16),c.globeMatrix,i),e.aC(p,c.projMatrix,p)}const f=e.bd();f[12]+=2*o/(e.o.devicePixelRatio*c.width),f[13]+=2*s/(e.o.devicePixelRatio*c.height),e.aC(p,f,p);const m=t.getOrCreateProgram("debug",{defines:d}),_=i.getTileByID(r.key);t.terrain&&t.terrain.setupElevationDraw(_,m);const g=$r.disabled,y=Zr.disabled,x=t.colorModeForRenderPass(),v="$debug";l.activeTexture.set(h.TEXTURE0),t.emptyTexture.bind(h.LINEAR,h.CLAMP_TO_EDGE),u?_._makeGlobeTileDebugBuffers(t.context,c):_._makeDebugTileBoundsBuffers(t.context,c.projection);const b=_._tileDebugBuffer||t.debugBuffer,w=_._tileDebugIndexBuffer||t.debugIndexBuffer,T=_._tileDebugSegments||t.debugSegments;if(m.draw(t,h.LINE_STRIP,g,y,x,Yr.disabled,zs(p,n.toPremultipliedRenderColor(null)),v,b,w,T,null,null,null,[_._globeTileDebugBorderBuffer]),a){const e=_.latestRawTileData,i=Math.floor((e&&e.byteLength||0)/1024);let n=r.canonical.toString();r.overscaledZ!==r.canonical.z&&(n+=` => ${r.overscaledZ}`),n+=` ${_.state}`,n+=` ${i}kb`,function(e,t){e.initDebugOverlayCanvas();const i=e.debugOverlayCanvas,r=e.context.gl,n=e.debugOverlayCanvas.getContext("2d");n.clearRect(0,0,i.width,i.height),n.shadowColor="white",n.shadowBlur=2,n.lineWidth=1.5,n.strokeStyle="white",n.textBaseline="top",n.font="bold 36px Open Sans, sans-serif",n.fillText(t,5,5),n.strokeText(t,5,5),e.debugOverlayTexture.update(i),e.debugOverlayTexture.bind(r.LINEAR,r.CLAMP_TO_EDGE)}(t,n)}const S=i.getTile(r).tileSize,I=512/Math.min(S,512)*(r.overscaledZ/c.zoom)*.5,E=_._tileDebugTextBuffer||t.debugBuffer,A=_._tileDebugTextIndexBuffer||t.quadTriangleIndexBuffer,M=_._tileDebugTextSegments||t.debugSegments;m.draw(t,h.TRIANGLES,g,y,Hr.alphaBlended,Yr.disabled,zs(p,e.C.transparent.toPremultipliedRenderColor(null),I),v,E,A,M,null,null,null,[_._globeTileDebugTextBuffer])}function fl(e,t,i,r){_l(e,0,t+i/2,e.transform.width,i,r)}function ml(e,t,i,r){_l(e,t-i/2,0,i,e.transform.height,r)}function _l(t,i,r,n,o,s){const a=t.context,l=a.gl;l.enable(l.SCISSOR_TEST),l.scissor(i*e.o.devicePixelRatio,r*e.o.devicePixelRatio,n*e.o.devicePixelRatio,o*e.o.devicePixelRatio),a.clear({color:s}),l.disable(l.SCISSOR_TEST)}const{members:gl}=e.ea([{name:"a_pos_3f",components:3,type:"Float32"}]);function yl(e,t,i,r){e.emplaceBack(t,i,r)}class xl{constructor(t){this.vertexArray=new e.em,this.indices=new e.dF,yl(this.vertexArray,-1,-1,1),yl(this.vertexArray,1,-1,1),yl(this.vertexArray,-1,1,1),yl(this.vertexArray,1,1,1),yl(this.vertexArray,-1,-1,-1),yl(this.vertexArray,1,-1,-1),yl(this.vertexArray,-1,1,-1),yl(this.vertexArray,1,1,-1),this.indices.emplaceBack(5,1,3),this.indices.emplaceBack(3,7,5),this.indices.emplaceBack(6,2,0),this.indices.emplaceBack(0,4,6),this.indices.emplaceBack(2,6,7),this.indices.emplaceBack(7,3,2),this.indices.emplaceBack(5,4,0),this.indices.emplaceBack(0,1,5),this.indices.emplaceBack(0,2,3),this.indices.emplaceBack(3,1,0),this.indices.emplaceBack(7,6,4),this.indices.emplaceBack(4,5,7),this.vertexBuffer=t.createVertexBuffer(this.vertexArray,gl),this.indexBuffer=t.createIndexBuffer(this.indices),this.segment=e.dB.simpleSegment(0,0,36,12)}}function vl(t,i,r,n,o,s){const a=t.context.gl,l=i.paint.get("sky-atmosphere-color"),c=i.paint.get("sky-atmosphere-halo-color"),h=i.paint.get("sky-atmosphere-sun-intensity"),u=((e,t,i,r,n)=>({u_matrix_3f:e,u_sun_direction:t,u_sun_intensity:i,u_color_tint_r:[r.r,r.g,r.b,r.a],u_color_tint_m:[n.r,n.g,n.b,n.a],u_luminance:5e-5}))(e.ep(e.dH(),n),o,h,l.toPremultipliedRenderColor(null),c.toPremultipliedRenderColor(null));a.framebufferTexture2D(a.FRAMEBUFFER,a.COLOR_ATTACHMENT0,a.TEXTURE_CUBE_MAP_POSITIVE_X+s,i.skyboxTexture,0),r.draw(t,a.TRIANGLES,$r.disabled,Zr.disabled,Hr.unblended,Yr.frontCW,u,"skyboxCapture",i.skyboxGeometry.vertexBuffer,i.skyboxGeometry.indexBuffer,i.skyboxGeometry.segment)}const bl=e.ea([{type:"Float32",name:"a_pos",components:3},{type:"Float32",name:"a_uv",components:2}]);class wl{constructor(t){const i=new e.eq;i.emplaceBack(-1,1,1,0,0),i.emplaceBack(1,1,1,1,0),i.emplaceBack(1,-1,1,1,1),i.emplaceBack(-1,-1,1,0,1);const r=new e.dF;r.emplaceBack(0,1,2),r.emplaceBack(2,3,0),this.vertexBuffer=t.createVertexBuffer(i,bl.members),this.indexBuffer=t.createIndexBuffer(r),this.segments=e.dB.simpleSegment(0,0,4,2)}destroy(){this.vertexBuffer.destroy(),this.indexBuffer.destroy(),this.segments.destroy()}}const Tl=e.ea([{type:"Float32",name:"a_pos_3f",components:3},{type:"Float32",name:"a_uv",components:2},{type:"Float32",name:"a_size_scale",components:1},{type:"Float32",name:"a_opacity",components:1}]);class Sl{constructor(){this.colorModeAlphaBlendedWriteRGB=new Hr([1,Gr,1,Gr],e.C.transparent,[!0,!0,!0,!1]),this.colorModeWriteAlpha=new Hr([1,0,1,0],e.C.transparent,[!1,!1,!1,!0]),this.params={starsCount:16e3,sizeMultiplier:.15,sizeRange:100,intensityRange:200},this.updateNeeded=!0,this._painter=null,this._devtoolsFolder=null}update(t){this._painter=t;const i=t.context;if(!this.atmosphereBuffer||this.updateNeeded){this.updateNeeded=!1,this.atmosphereBuffer=new wl(i);let t=this.params;const r=t.sizeRange,n=t.intensityRange,o=function(t){const i=e.ef(30),r=[];for(let n=0;n<t;++n){const t=2*Math.PI*i(),n=Math.acos(1-2*i())-.5*Math.PI;r.push(e.cU(Math.cos(n)*Math.cos(t),Math.cos(n)*Math.sin(t),Math.sin(n)))}return r}(t.starsCount),s=e.ef(300),a=new e.er,l=new e.dF;let c=0;for(let i=0;i<o.length;++i){const t=e.bN([],o[i],200),h=Math.max(0,1+.01*r*(1*s()-.5)),u=Math.max(0,1+.01*n*(1*s()-.5));a.emplaceBack(t[0],t[1],t[2],-1,-1,h,u),a.emplaceBack(t[0],t[1],t[2],1,-1,h,u),a.emplaceBack(t[0],t[1],t[2],1,1,h,u),a.emplaceBack(t[0],t[1],t[2],-1,1,h,u),l.emplaceBack(c+0,c+1,c+2),l.emplaceBack(c+0,c+2,c+3),c+=4}this.starsVx=i.createVertexBuffer(a,Tl.members),this.starsIdx=i.createIndexBuffer(l),this.starsSegments=e.dB.simpleSegment(0,0,a.length,l.length)}}destroy(){this.atmosphereBuffer&&this.atmosphereBuffer.destroy(),this.starsVx&&this.starsVx.destroy(),this.starsIdx&&this.starsIdx.destroy(),this._painter=null}drawAtmosphereGlow(t,i){const r=t.context,n=r.gl,o=t.transform,s=new $r(n.LEQUAL,$r.ReadOnly,[0,1]),a=e.ai(o.zoom),l=t.style.getLut(i.scope),c="none"===i.properties.get("color-use-theme"),h=i.properties.get("color").toNonPremultipliedRenderColor(c?null:l),u="none"===i.properties.get("high-color-use-theme"),d=i.properties.get("high-color").toNonPremultipliedRenderColor(u?null:l),p="none"===i.properties.get("space-color-use-theme"),f=i.properties.get("space-color").toNonPremultipliedRenderColor(p?null:l),m=5e-4,_=e.es(i.properties.get("horizon-blend"),0,1,m,.25),g=e.ds(t,r,o)&&_===m?o.worldSize/(2*Math.PI*1.025)-1:o.globeRadius,y=t.frameCounter/1e3%1,x=e.af(o.globeCenterInViewSpace),v=Math.sqrt(Math.pow(x,2)-Math.pow(g,2)),b=Math.acos(v/x),w=e=>{const i="globe"===o.projection.name?["PROJECTION_GLOBE_VIEW","FOG"]:["FOG"];e&&i.push("ALPHA_PASS");const l=t.getOrCreateProgram("globeAtmosphere",{defines:i}),c=((e,t,i,r,n,o,s,a,l,c,h,u)=>({u_frustum_tl:e,u_frustum_tr:t,u_frustum_br:i,u_frustum_bl:r,u_horizon:n,u_transition:o,u_fadeout_range:s,u_atmosphere_fog_color:a.toArray01(),u_high_color:l.toArray01(),u_space_color:c.toArray01(),u_temporal_offset:h,u_horizon_angle:u}))(o.frustumCorners.TL,o.frustumCorners.TR,o.frustumCorners.BR,o.frustumCorners.BL,o.frustumCorners.horizon,a,_,h,d,f,y,b);t.uploadCommonUniforms(r,l);const u=this.atmosphereBuffer;u&&l.draw(t,n.TRIANGLES,s,Zr.disabled,e?this.colorModeWriteAlpha:this.colorModeAlphaBlendedWriteRGB,Yr.backCW,c,e?"atmosphere_glow_alpha":"atmosphere_glow",u.vertexBuffer,u.indexBuffer,u.segments)};w(!1),w(!0)}drawStars(t,i){const r=e.aB(i.properties.get("star-intensity"),0,1);if(0===r)return;const n=t.context,o=n.gl,s=t.transform,a=t.getOrCreateProgram("stars"),l=e.bP([]);e.bR(l,l,-s._pitch),e.bQ(l,l,-s.angle),e.bR(l,l,e.am(s._center.lat)),e.et(l,l,-e.am(s._center.lng));const c=e.bV(new Float32Array(16),l),h=e.aC([],s.starsProjMatrix,c),u=e.ep([],c),d=e.eu([],u);let p=this.params.sizeMultiplier;const f=[0,1,0];e.dJ(f,f,d),e.bN(f,f,p);const m=[1,0,0];e.dJ(m,m,d),e.bN(m,m,p);const _=(g=f,y=m,x=r,{u_matrix:Float32Array.from(h),u_up:g,u_right:y,u_intensity_multiplier:x});var g,y,x;t.uploadCommonUniforms(n,a),this.starsVx&&this.starsIdx&&a.draw(t,o.TRIANGLES,$r.disabled,Zr.disabled,this.colorModeAlphaBlendedWriteRGB,Yr.disabled,_,"atmosphere_stars",this.starsVx,this.starsIdx,this.starsSegments)}}class Il{constructor(){this.visibleTiles=[]}updateBorders(t,i){const r=[],n=[],o=t._getRenderableCoordinates(!1,!0);for(const e of o){const o=t.getTile(e);if(!o.hasData())continue;const s=o.getBucket(i);s&&(s.isEmpty()||(r.push(e.key),n.push({bucket:s,tileID:e.canonical})))}let s=r.length!==this.visibleTiles.length;if(!s){r.sort();for(let e=0;e<r.length;e++)if(r[e]!==this.visibleTiles[e]){s=!0;break}}if(!s)return;const a=/* @__PURE__ */new Set;this.visibleTiles=r,n.sort((e,t)=>e.tileID.z-t.tileID.z||e.tileID.x-t.tileID.x||e.tileID.y-t.tileID.y);for(const l of n){const t=new Array,i=new Array,r=l.bucket;for(const e of r.featuresOnBorder)a.has(e.featureId)?i.push(e.footprintIndex):(a.add(e.featureId),t.push(e.footprintIndex));r.updateFootprintHiddenFlags(t,e.ev,!1),r.updateFootprintHiddenFlags(i,e.ev,!0)}}}const El=new Float64Array(16),Al=new Float64Array(16),Ml=new Float64Array(16),Cl=new Float32Array(16),Pl=[0,0,0];function Dl(t,i,r){const n=r.cameraWorldSizeForFog/r.worldSize;return e.cE(t,r.worldToFogMatrix,[n,n,1]),e.aC(t,t,i),t}function Rl(t,i,r,n,o){const s=r.material,a=n.context,{baseColorTexture:l,metallicRoughnessTexture:c}=s.pbrMetallicRoughness,{normalTexture:h,occlusionTexture:u,emissionTexture:d}=s;function p(e,i,r){if(e&&(t.push(i),a.activeTexture.set(a.gl.TEXTURE0+r),e.gfxTexture)){const{minFilter:t,magFilter:i,wrapS:r,wrapT:n}=e.sampler;e.gfxTexture.bindExtraParam(t,i,r,n)}}p(l,"HAS_TEXTURE_u_baseColorTexture",5),p(c,"HAS_TEXTURE_u_metallicRoughnessTexture",6),p(h,"HAS_TEXTURE_u_normalTexture",7),p(u,"HAS_TEXTURE_u_occlusionTexture",8),p(d,"HAS_TEXTURE_u_emissionTexture",9),o&&(o.texture||(o.texture=new e.dU(n.context,o.image,[o.image.height,o.image.height,o.image.height],a.gl.RGBA8)),a.activeTexture.set(a.gl.TEXTURE0+10),o.texture&&o.texture.bind(a.gl.LINEAR,a.gl.CLAMP_TO_EDGE),t.push("APPLY_LUT_ON_GPU")),r.texcoordBuffer&&(t.push("HAS_ATTRIBUTE_a_uv_2f"),i.push(r.texcoordBuffer)),r.colorBuffer&&(t.push(12===r.colorBuffer.itemSize?"HAS_ATTRIBUTE_a_color_3f":"HAS_ATTRIBUTE_a_color_4f"),i.push(r.colorBuffer)),r.normalBuffer&&(t.push("HAS_ATTRIBUTE_a_normal_3f"),i.push(r.normalBuffer)),r.pbrBuffer&&(t.push("HAS_ATTRIBUTE_a_pbr"),t.push("HAS_ATTRIBUTE_a_heightBasedEmissiveStrength"),i.push(r.pbrBuffer)),"OPAQUE"!==s.alphaMode&&"MASK"!==s.alphaMode||t.push("UNPREMULT_TEXTURE_IN_SHADER"),s.defined||t.push("DIFFUSE_SHADED");const f=n.shadowRenderer;f&&(t.push("RENDER_SHADOWS"),f.useNormalOffset&&t.push("NORMAL_OFFSET"))}function zl(t,i,r,n,o,s){const a=t.modelOpacity,l=i.context,c=new $r(i.context.gl.LEQUAL,t.isLightMesh?$r.ReadOnly:$r.ReadWrite,i.depthRangeFor3D),h=i.transform,u=t.mesh,d=u.material,p=d.pbrMetallicRoughness,f=i.style.fog;"pixels"===i.transform.projection.zAxisUnit?El.set(t.nodeModelMatrix):e.aC(El,n.zScaleMatrix,t.nodeModelMatrix),e.aC(El,n.negCameraPosMatrix,El),e.ba(Al,El),e.e9(Al,Al);const m="none"===r.paint.get("model-color-use-theme").constantOr("default"),_=r.paint.get("model-emissive-strength").constantOr(0),g=qs(t.worldViewProjection,El,Al,null,i,a,p.baseColorFactor,d.emissiveFactor,p.metallicFactor,p.roughnessFactor,d,_,r,void 0,void 0,t.materialOverride,t.modelColor),y={defines:[]},x=[],v=i.shadowRenderer;v&&(v.useNormalOffset=!1),Rl(y.defines,x,u,i,m?null:r.lut);let b=null;if(f&&(b=Dl(Ml,t.nodeModelMatrix,i.transform),"globe"!==h.projection.name)){const e=u.aabb.min,t=u.aabb.max,[i,r]=f.getOpacityForBounds(b,e[0],e[1],t[0],t[1]);y.overrideFog=i>=$t||r>=$t}const w=an(i,r.paint.get("model-cutoff-fade-range"));w.shouldRenderCutoff&&y.defines.push("RENDER_CUTOFF");const T=i.getOrCreateProgram("model",y);i.uploadCommonUniforms(l,T,null,b,w),"shadow"!==i.renderPass&&v&&v.setupShadowsFromMatrix(t.nodeModelMatrix,T),T.draw(i,l.gl.TRIANGLES,c,o,s,u.material.doubleSided?Yr.disabled:Yr.backCCW,g,r.id,u.vertexBuffer,u.indexBuffer,u.segments,r.paint,i.transform.zoom,void 0,x)}function Ll(e,t){return e.style._importedAsBasemap?"basemap":t.scope}function Fl(t,i,r,n,o,s,a,l,c,h){const u=t.transform,d=!!i.isGeometryBloom&&i.isGeometryBloom;if(d&&"shadow"===t.renderPass)return;const p="globe"===u.projection.name?e.eD(r,u):[...r];e.aC(p,p,i.globalMatrix);const f=e.aC([],n,p);if(i.meshes)for(const m of i.meshes){const t=l.get(m.material.name);if(t&&t.opacity<=0)continue;if("BLEND"!==m.material.alphaMode){a.push({mesh:m,depth:0,modelIndex:o,worldViewProjection:f,nodeModelMatrix:p,isLightMesh:d,materialOverride:t,modelOpacity:c,modelColor:h,node:i,modelMatrix:r});continue}const n=e.ae([],m.centroid,f);!u.isOrthographic&&n[2]<=0||s.push({mesh:m,depth:n[2],modelIndex:o,worldViewProjection:f,nodeModelMatrix:p,isLightMesh:d,materialOverride:t,modelOpacity:c,modelColor:h,node:i,modelMatrix:r})}if(i.children)for(const e of i.children)Fl(t,e,r,n,o,s,a,l,c,h)}function Ol(e,t,i,r){const n=i.shadowRenderer;if(!n)return;const o=n.getShadowPassDepthMode(),s=Zs(n.calculateShadowPassMatrixFromMatrix(t));i.getOrCreateProgram("modelDepth").draw(i,i.context.gl.TRIANGLES,o,Zr.disabled,Hr.disabled,Yr.disabled,s,r.id,e.vertexBuffer,e.indexBuffer,e.segments,r.paint,i.transform.zoom,void 0,void 0)}function Bl(t,i,r,n){const o=function(t,i){if(i.footprintDebugMesh)return i.footprintDebugMesh;if(!i.footprint)return null;const r=t.context,n=i.footprint.vertices,o=i.footprint.indices,s=new e.dE;s.reserve(n.length);for(const e of n)s.emplaceBack(e.x,e.y);const a=new e.dF;a.reserve(o.length);for(let e=0;e<o.length;e+=3)a.emplaceBack(o[e],o[e+1],o[e+2]);const l=r.createVertexBuffer(s,e.dA.members),c=r.createIndexBuffer(a),h=e.dB.simpleSegment(0,0,n.length,o.length),u=i.id||i.name||"footprint";let d;const p=parseInt(u,10);d=isNaN(p)?function(e){let t=0;for(let i=0;i<e.length;i++)t=(t<<5)-t+e.charCodeAt(i)|0;return t}(u):p;const f=e.ed(d),m=e.ed(d+1),_=e.ed(d+2);return i.footprintDebugMesh={vertexBuffer:l,indexBuffer:c,segments:h,color:new e.C(f,m,_,.5)},i.footprintDebugMesh}(t,r);if(!o)return;const s=t.context,a=s.gl,l=t.getOrCreateProgram("debug"),c=o.color,h=$r.disabled;s.activeTexture.set(a.TEXTURE0),t.emptyTexture.bind(a.LINEAR,a.CLAMP_TO_EDGE),l.draw(t,a.TRIANGLES,h,Zr.disabled,Hr.alphaBlended,Yr.disabled,zs(n,c.toPremultipliedRenderColor(null)),"$debug",o.vertexBuffer,o.indexBuffer,o.segments)}function kl(e,t,i,r,n,o){for(const s of n){const n=Object.assign({},r);n.part=s;const a={type:"Unknown",id:t,properties:n},l={orientation:e.paint.get("model-rotation").evaluate(a,i)};o.set(s,l)}}function Nl(e,t,i,r,n,o){for(const s of n){const n=Object.assign({},r);n.part=s;const a={type:"Unknown",id:t,properties:n},l={color:e.paint.get("model-color").evaluate(a,i),colorMix:e.paint.get("model-color-mix-intensity").evaluate(a,i),opacity:e.paint.get("model-opacity").evaluate(a,i),emissionStrength:e.paint.get("model-emissive-strength").evaluate(a,i)};o.set(s,l)}}function Ul(e,t,i,r,n){let o=!1;for(const a of r)1!==a.modelOpacity&&(zl(a,e,t,n[a.modelIndex],Zr.disabled,Hr.disabled),o=!0);for(const a of r)zl(a,e,t,n[a.modelIndex],1!==a.modelOpacity?e.stencilModeFor3D():Zr.disabled,e.colorModeForRenderPass());o&&e.resetStencilClippingMasks();const s=Hr.additive;for(const a of i)zl(a,e,t,n[a.modelIndex],Zr.disabled,a.isLightMesh?s:e.colorModeForRenderPass())}function Vl(t,i,r){const n=i.updateZoomBasedPaintProperties(),o=function(t,i,r){let n,o,s,a=t.terrain?t.terrain.exaggeration():0;if(t.terrain&&a>0){const i=t.terrain,o=i.findDEMTileFor(r);o&&o.dem?n=e.eF.create(i,r,o):a=0}if(0===a&&(i.terrainElevationMin=0,i.terrainElevationMax=0),a===i.validForExaggeration&&(0===a||n&&n._demTile&&n._demTile.tileID===i.validForDEMTile.id&&n._dem._timestamp===i.validForDEMTile.timestamp))return!1;for(const e in i.instancesPerModel){const t=i.instancesPerModel[e];for(let e=0;e<t.instancedDataArray.length;++e){const r=(n?a*n.getElevationAt(0|t.instancedDataArray.float32[16*e],0|t.instancedDataArray.float32[16*e+1],!0,!0):0)+t.instancesEvaluatedElevation[e];t.instancedDataArray.float32[16*e+6]=r,o=o?Math.min(i.terrainElevationMin,r):r,s=s?Math.max(i.terrainElevationMax,r):r}}return i.terrainElevationMin=o||0,i.terrainElevationMax=s||0,i.validForExaggeration=a,i.validForDEMTile=n&&n._demTile?{id:n._demTile.tileID,timestamp:n._dem._timestamp}:{id:void 0,timestamp:0},!0}(t,i,r);(n||o)&&(i.uploaded=!1,i.upload(t.context))}const jl={shadowUniformsInitialized:!1,useSingleShadowCascade:!1,tileMatrix:new Float64Array(16),shadowTileMatrix:new Float32Array(16),aabb:new e.cY([0,0,0],[e.ak,e.ak,0])};function Gl(t,i){const r=1<<t.canonical.z,n=i.getFreeCameraOptions().position,o=i.elevation,s=t.canonical.x/r,a=(t.canonical.x+1)/r,l=t.canonical.y/r,c=(t.canonical.y+1)/r;let h=i._centerAltitude;if(o){const e=o.getMinMaxForTile(t);e&&e.max>h&&(h=e.max)}const u=e.aB(n.x,s,a)-n.x,d=e.aB(n.y,l,c)-n.y,p=e.bY(h,i.center.lat)-n.z;return i._zoomFromMercatorZ(Math.sqrt(u*u+d*d+p*p))}function Hl(e,t,i,r,n,o,s){const a=e.context,l="shadow"===e.renderPass,c=e.shadowRenderer,h=l&&c?c.getShadowPassDepthMode():new $r(a.gl.LEQUAL,$r.ReadWrite,e.depthRangeFor3D),u=e.isTileAffectedByFog(o),d="globe"===e.transform.projection.name;if(i.meshes)for(const p of i.meshes){const f=d?[]:["MODEL_POSITION_ON_GPU"],m=[];let _,g,y;const x=!d&&r.instancedDataArray.length>20;x&&f.push("INSTANCED_ARRAYS");const v=an(e,t.paint.get("model-cutoff-fade-range"));if(v.shouldRenderCutoff&&f.push("RENDER_CUTOFF"),l&&c)_=e.getOrCreateProgram("modelDepth",{defines:f}),g=Zs(s.shadowTileMatrix,s.shadowTileMatrix,i.globalMatrix),y=Hr.disabled;else{Rl(f,m,p,e,"none"===t.paint.get("model-color-use-theme").constantOr("default")?null:t.lut),_=e.getOrCreateProgram("model",{defines:f,overrideFog:u});const r=p.material,l=r.pbrMetallicRoughness,h=t.paint.get("model-opacity").constantOr(1),d=t.paint.get("model-emissive-strength").constantOr(0);g=qs(o.expandedProjMatrix,i.globalMatrix,Cl,null,e,h,l.baseColorFactor,r.emissiveFactor,l.metallicFactor,l.roughnessFactor,r,d,t,n),c&&(s.shadowUniformsInitialized?_.setShadowUniformValues(a,c.getShadowUniformValues()):(c.setupShadows(o.toUnwrapped(),_,"model-tile"),s.shadowUniformsInitialized=!0)),y=v.shouldRenderCutoff||h<1||"OPAQUE"!==r.alphaMode?Hr.alphaBlended:Hr.unblended}e.uploadCommonUniforms(a,_,o.toUnwrapped(),null,v);const b=p.material.doubleSided?Yr.disabled:Yr.backCCW;if(x)m.push(r.instancedDataBuffer),_.draw(e,a.gl.TRIANGLES,h,Zr.disabled,y,b,g,t.id,p.vertexBuffer,p.indexBuffer,p.segments,t.paint,e.transform.zoom,void 0,m,r.instancedDataArray.length);else{const i=l?"u_instance":"u_normal_matrix";for(let n=0;n<r.instancedDataArray.length;++n)g[i]=new Float32Array(r.instancedDataArray.arrayBuffer,64*n,16),_.draw(e,a.gl.TRIANGLES,h,Zr.disabled,y,b,g,t.id,p.vertexBuffer,p.indexBuffer,p.segments,t.paint,e.transform.zoom,void 0,m)}}if(i.children)for(const p of i.children)Hl(e,t,p,r,n,o,s)}const $l=[1,-1,1];function ql(e,t,i,r){const n=e.node;if(n.lodMeshes&&n.lodMeshes.length>0)if(e.targetLod<0)e.targetLod=t>r?1:0;else{const n=i/1e3;e.targetLod=t>r?Math.min(e.targetLod+n,1):Math.max(e.targetLod-n,0)}else e.targetLod=0}function Zl(t,i,r,n){if(!r.modelManager)return!0;const o=r.modelManager;if(!r.shadowRenderer)return!0;const s=r.shadowRenderer,a=i.aabb;let l=!0,c=t.maxHeight;if(0===c){let e=0;for(const i in t.instancesPerModel){const t=o.getModel(i,n);t?e=Math.max(e,Math.max(Math.max(t.aabb.max[0],t.aabb.max[1]),t.aabb.max[2])):l=!1}c=t.maxScale*e*1.41+t.maxVerticalOffset,l&&(t.maxHeight=c)}a.max[2]=c,a.min[2]+=t.terrainElevationMin,a.max[2]+=t.terrainElevationMax,e.ae(a.min,a.min,i.tileMatrix),e.ae(a.max,a.max,i.tileMatrix);const h=a.intersects(s.getCurrentCascadeFrustum());return 0===r.currentShadowCascade&&(t.isInsideFirstShadowMapFrustum=2===h),0===h}function Wl(t,i){const r=t.uniformValues.u_cutoff_params[0],n=t.uniformValues.u_cutoff_params[1],o=t.uniformValues.u_cutoff_params[2],s=t.uniformValues.u_cutoff_params[3];return n===r||s===o?1:e.aB(((i-r)/(n-r)-o)/(s-o),0,1)}function Xl(t,i,r,n){if(i.pitch<20)return 1;const o=i.getWorldToCameraMatrix();e.aC(o,o,t);const s=e.bw(r.min[0],r.min[1],r.min[2],1);let a=e.aD(e.bI(),s,o),l=a,c=a;s[1]=r.max[1],a=e.aD(e.bI(),s,o),l=a[1]<l[1]?a:l,c=a[1]>c[1]?a:c,s[0]=r.max[0],a=e.aD(e.bI(),s,o),l=a[1]<l[1]?a:l,c=a[1]>c[1]?a:c,s[1]=r.min[1],a=e.aD(e.bI(),s,o),l=a[1]<l[1]?a:l,c=a[1]>c[1]?a:c;const h=e.aB(n[0],0,1),u=100*i.pixelsPerMeter*e.aB(n[1],0,1),d=e.aB(n[2],0,1),p=e.eG(e.bI(),l,c,h),f=Math.tan(.5*i.fovX),m=-p[2]*f;if(0===u)return p[1]<-Math.abs(m)?d:1;const _=(-Math.abs(m)-p[1])/u,g=(e,t,i)=>(1-i)*e+i*t;return g(1,e.aB(g(1,d,_),d,1),e.aB((i.pitch-20)/20,0,1))}class Yl{}class Jl{constructor(){this._storage=/* @__PURE__ */new Map}getLinesFromTrianglesBuffer(t,i,r){{const e=this._storage.get(i.id);if(e)return e.lastUsedFrameIdx=t,e.buf}const n=r.gl,o=n.getBufferParameter(n.ELEMENT_ARRAY_BUFFER,n.BUFFER_SIZE),s=new ArrayBuffer(o),a=new Int16Array(s);n.getBufferSubData(n.ELEMENT_ARRAY_BUFFER,0,new Int16Array(s));const l=new e.eI;for(let e=0;e<o/2;e+=3){const t=a[e],i=a[e+1],r=a[e+2];l.emplaceBack(t,i),l.emplaceBack(i,r),l.emplaceBack(r,t)}const c=r.bindVertexArrayOES.current,h=new Yl;return h.buf=new Xs(r,l),h.lastUsedFrameIdx=t,this._storage.set(i.id,h),r.bindVertexArrayOES.set(c),h.buf}update(e){for(const[t,i]of this._storage)e-i.lastUsedFrameIdx>30&&(i.buf.destroy(),this._storage.delete(t))}destroy(){for(const[e,t]of this._storage)t.buf.destroy(),this._storage.delete(e)}}class Kl{constructor(){this.occluderSize=30,this.depthOffset=-1e-4}}const Ql={symbol:function(t,i,r,n,o){if("translucent"!==t.renderPass)return;const s=Zr.disabled,a=t.colorModeForRenderPass(),l=r.layout.get("text-variable-anchor"),c=r.layout.get("text-size-scale-range"),h=e.aB(t.scaleFactor,c[0],c[1]);l&&function(t,i,r,n,o,s,a,l){const c=i.transform,h="map"===o,u="map"===s;for(const d of t){const t=n.getTile(d),i=t.getBucket(r);if(!i||!i.text||!i.text.segments.get().length)continue;const o=e.bl(i.textSizeData,c.zoom,l),s=Yi(d,i.getProjection(),c),p=c.calculatePixelsToTileUnitsMatrix(t),f=Qi(s,t.tileID.canonical,u,h,c,i.getProjection(),p),m=i.hasIconTextFit()&&i.hasIconData();o&&oa(i,h,u,a,c,f,d,Math.pow(2,c.zoom-t.tileID.overscaledZ),o,m)}}(n,t,r,i,r.layout.get("text-rotation-alignment"),r.layout.get("text-pitch-alignment"),o,h);const u=0!==r.paint.get("icon-opacity").constantOr(1),d=0!==r.paint.get("text-opacity").constantOr(1);void 0!==r.layout.get("symbol-sort-key").constantOr(1)&&(u||d)?sa(t,i,r,n,s,a):(u&&sa(t,i,r,n,s,a,{onlyIcons:!0}),d&&sa(t,i,r,n,s,a,{onlyText:!0})),i.map.showCollisionBoxes&&(ta(t,i,r,n,r.paint.get("text-translate"),r.paint.get("text-translate-anchor"),!0),ta(t,i,r,n,r.paint.get("icon-translate"),r.paint.get("icon-translate-anchor"),!1))},circle:function(t,i,r,n){if("translucent"!==t.renderPass)return;const o=r.paint.get("circle-opacity"),s=r.paint.get("circle-stroke-width"),a=r.paint.get("circle-stroke-opacity"),l=void 0!==r.layout.get("circle-sort-key").constantOr(1),c=r.paint.get("circle-emissive-strength");if(0===o.constantOr(1)&&(0===s.constantOr(1)||0===a.constantOr(1)))return;const h=t.context,u=h.gl,d=t.transform,p=!(!t.terrain||!t.terrain.enabled),f=r.layout.get("circle-elevation-reference"),m=t.depthModeForSublayer(0,$r.ReadOnly),_=new $r(t.context.gl.LEQUAL,$r.ReadOnly,t.depthRangeFor3D),g="none"===f||p?m:_,y=Zr.disabled,x=t.colorModeForDrapableLayerRenderPass(c),v="globe"===d.projection.name,b=[e.aG(d.center.lng),e.aJ(d.center.lat)],w=[];for(let S=0;S<n.length;S++){const o=n[S],s=i.getTile(o),a=s.getBucket(r);if(!a||a.projection.name!==d.projection.name)continue;const c=a.programConfigurations.get(r.id),h=a.layoutVertexBuffer,u=a.globeExtVertexBuffer,p=a.indexBuffer,f=e.dV(r),m=[u],_=t.isTileAffectedByFog(o);v&&f.push("PROJECTION_GLOBE_VIEW"),f.push("DEPTH_D24"),t.terrain&&d.depthOcclusionForSymbolsAndCircles&&f.push("DEPTH_OCCLUSION"),a.hasElevation&&!t.terrain&&(f.push("ELEVATED_ROADS"),m.push(a.elevatedLayoutVertexBuffer));const g=t.getOrCreateProgram("circle",{config:c,defines:f,overrideFog:_}),y=d.projection.createInversionMatrix(d,o.canonical),x={programConfiguration:c,program:g,layoutVertexBuffer:h,dynamicBuffers:m,indexBuffer:p,uniformValues:e.dW(t,o,s,y,b,r),tile:s};if(l){const t=a.segments.get();for(const i of t)w.push({segments:new e.dB([i]),sortKey:i.sortKey,state:x})}else w.push({segments:a.segments,sortKey:0,state:x})}l&&w.sort((e,t)=>e.sortKey-t.sortKey);const T={useDepthForOcclusion:d.depthOcclusionForSymbolsAndCircles};for(const e of w){const{programConfiguration:i,program:n,layoutVertexBuffer:o,dynamicBuffers:s,indexBuffer:a,uniformValues:l,tile:c}=e.state,p=e.segments;t.terrain&&t.terrain.setupElevationDraw(c,n,T),t.uploadCommonUniforms(h,n,c.tileID.toUnwrapped()),n.draw(t,u.TRIANGLES,g,y,x,Yr.disabled,l,r.id,o,a,p,r.paint,d.zoom,i,s)}},heatmap:function(t,i,r,n){if(0!==r.paint.get("heatmap-opacity"))if("offscreen"===t.renderPass){const o=t.context,s=o.gl,a=Zr.disabled,l=new Hr([s.ONE,s.ONE,s.ONE,s.ONE],e.C.transparent,[!0,!0,!0,!0]),c="globe"===t.transform.projection.name?.5:.25;r.heatmapFbo=Ks.createWithTexture(o,r.heatmapFbo,t.width*c,t.height*c),o.clear({color:e.C.transparent});const h=t.transform,u="globe"===h.projection.name,d=u?["PROJECTION_GLOBE_VIEW"]:[],p=u?Yr.frontCCW:Yr.disabled,f=[e.aG(h.center.lng),e.aJ(h.center.lat)];for(let e=0;e<n.length;e++){const c=n[e];if(i.hasRenderableParent(c))continue;const m=i.getTile(c),_=m.getBucket(r);if(!_||_.projection.name!==h.projection.name)continue;const g=t.isTileAffectedByFog(c),y=_.programConfigurations.get(r.id),x=t.getOrCreateProgram("heatmap",{config:y,defines:d,overrideFog:g}),{zoom:v}=t.transform;t.terrain&&t.terrain.setupElevationDraw(m,x),t.uploadCommonUniforms(o,x,c.toUnwrapped());const b=h.projection.createInversionMatrix(h,c.canonical);x.draw(t,s.TRIANGLES,$r.disabled,a,l,p,Fs(t,c,m,b,f,v,r.paint.get("heatmap-intensity")),r.id,_.layoutVertexBuffer,_.indexBuffer,_.segments,r.paint,t.transform.zoom,y,u?[_.globeExtVertexBuffer]:null)}o.viewport.set([0,0,t.width,t.height])}else"translucent"===t.renderPass&&(t.context.setColorMode(t.colorModeForRenderPass()),function(t,i){const r=t.context,n=r.gl,o=i.heatmapFbo;if(!o)return;r.activeTexture.set(n.TEXTURE0),n.bindTexture(n.TEXTURE_2D,o.colorAttachment0.get()),r.activeTexture.set(n.TEXTURE1);let s=i.colorRampTexture;s||(s=i.colorRampTexture=new e.T(r,i.colorRamp,n.RGBA8)),s.bind(n.LINEAR,n.CLAMP_TO_EDGE),t.getOrCreateProgram("heatmapTexture").draw(t,n.TRIANGLES,$r.disabled,Zr.disabled,t.colorModeForRenderPass(),Yr.disabled,((e,t)=>({u_image:0,u_color_ramp:1,u_opacity:t.paint.get("heatmap-opacity")}))(0,i),i.id,t.viewportBuffer,t.quadTriangleIndexBuffer,t.viewportSegments,i.paint,t.transform.zoom)}(t,r))},line:function(e,t,i,r){const n=i.paint.get("line-opacity"),o=i.paint.get("line-width");if(0===n.constantOr(1)||0===o.constantOr(1))return;const s=i.paint.get("line-blend-mode"),a=e.terrain&&e.terrain.renderingToTexture;if("default"===s||"globe"===e.transform.projection.name)"translucent"===e.renderPass&&la(e,t,i,r);else{if(a)return void function(e,t,i,r,n){if("translucent"!==e.renderPass)return;const o=e.context,s=o.gl,a=e.terrain;if(!a)return;const l=o.bindFramebuffer.current,c="mrt-fallback"===e.emissiveMode,h=a.drapeBufferSize[0],u=a.drapeBufferSize[1];i.lineBlendFbos||(i.lineBlendFbos=new ca),i.lineBlendFbos.drapeFbo=Ks.createWithTexture(o,i.lineBlendFbos.drapeFbo,h,u,!0),c&&s.drawBuffers([s.COLOR_ATTACHMENT0]),o.clear({color:ua[n].clearColor,depth:1,stencil:0});const d=e.currentStencilSource,p=e._tileClippingMaskIDs,f=e.nextStencilID;e.currentStencilSource=void 0,e._tileClippingMaskIDs={},e.nextStencilID=1;const m=e._terrain;e._terrain=null,e._renderTileClippingMasks(i,t,r),la(e,t,i,r,pa(n,e.context),!0),e._terrain=m,e.currentStencilSource=d,e._tileClippingMaskIDs=p,e.nextStencilID=f,c&&s.drawBuffers([s.COLOR_ATTACHMENT0,s.COLOR_ATTACHMENT1]);const _=a.drapeBufferSize,g=i.lineBlendFbos&&i.lineBlendFbos.drapeFbo;g&&("additive"===n&&ma(e,i,g),_a(e,i,n,g,l,_))}(e,t,i,r,s);if("offscreen"===e.renderPass)return void function(e,t,i,r,n){const o=e.context,s=Math.ceil(e.width),a=Math.ceil(e.height);i.lineBlendFbos||(i.lineBlendFbos=new ca),i.lineBlendFbos.fbo=Ks.createWithTexture(o,i.lineBlendFbos.fbo,s,a,!0),o.clear({color:ua[n].clearColor,depth:1,stencil:0});const l=e.currentStencilSource,c=e._tileClippingMaskIDs,h=e.nextStencilID;e.currentStencilSource=void 0,e._tileClippingMaskIDs={},e.nextStencilID=1,e._renderTileClippingMasks(i,t,r);const u=e.renderPass;e.renderPass="translucent",la(e,t,i,r,pa(n,e.context)),e.renderPass=u,e.currentStencilSource=l,e._tileClippingMaskIDs=c,e.nextStencilID=h,o.viewport.set([0,0,e.width,e.height]),"additive"===n&&ma(e,i,i.lineBlendFbos.fbo)}(e,t,i,r,s);if("translucent"===e.renderPass){const t=i.lineBlendFbos&&i.lineBlendFbos.fbo;return void(t&&_a(e,i,s,t,null))}}},fill:function(t,i,r,n){const o=r.paint.get("fill-color"),s=r.paint.get("fill-opacity");if(0===s.constantOr(1))return;const a=r.paint.get("fill-emissive-strength"),l=t.colorModeForDrapableLayerRenderPass(a),c=r.paint.get("fill-pattern"),h=t.opaquePassEnabledForLayer()&&!c.constantOr(1)&&1===o.constantOr(e.C.transparent).a&&1===s.constantOr(0)?"opaque":"translucent";let u="none";"none"!==r.layout.get("fill-elevation-reference")?u="road":0!==r.paint.get("fill-z-offset").constantOr(1)&&(u="offset");const d=!(!t.terrain||!t.terrain.enabled),p={painter:t,sourceCache:i,layer:r,coords:n,colorMode:l,elevationType:u,terrainEnabled:d,pass:h};if("shadow"===t.renderPass)return void(t.shadowRenderer&&"road"===u&&!d&&function(e){const{painter:t,sourceCache:i,layer:r,coords:n}=e,o=t.context.gl,s=e.painter.shadowRenderer;for(const a of n){const e=i.getTile(a),n=e.getBucket(r);if(!n)continue;const l=n.elevatedStructures;if(!l)continue;if(!l.shadowCasterSegments||0===l.shadowCasterSegments.segments[0].primitiveLength)continue;t.prepareDrawTile();const c=n.bufferData.programConfigurations.get(r.id),h=t.isTileAffectedByFog(a),u=t.getOrCreateProgram("elevatedStructuresDepth",{config:c,overrideFog:h}),d=s.calculateShadowPassMatrixFromTile(e.tileID.toUnwrapped());t.uploadCommonUniforms(t.context,u,a.toUnwrapped());const p=As(d,0);u.draw(t,o.TRIANGLES,s.getShadowPassDepthMode(),Zr.disabled,Hr.disabled,Yr.disabled,p,r.id,l.vertexBuffer,l.indexBuffer,l.shadowCasterSegments,r.paint,t.transform.zoom,c)}}(p));const f="mrt-fallback"===t.emissiveMode;if("offset"!==u){if(xa(p,!1,f),"road"===u){const e=!d&&"translucent"===t.renderPass;e&&ya(t,i,r,n,"geometry"),xa(p,!0,f,Zr.disabled),e&&function(e){const{painter:t,sourceCache:i,layer:r,coords:n,colorMode:o}=e,s=t.context.gl,a=e.painter.shadowRenderer,l=!!a&&a.enabled,c=new $r(t.context.gl.LEQUAL,$r.ReadOnly,t.depthRangeFor3D);let h=[0,0,0];if(l){const e=t.style.directionalLight,i=t.style.ambientLight;e&&i&&(h=mn(t.style,e,i))}const u=e=>{for(const u of n){const n=i.getTile(u),d=n.getBucket(r);if(!d)continue;const p=d.elevatedStructures;if(!p)continue;let f,m;if(e?(f=p.renderableBridgeSegments,m=p.bridgeProgramConfigurations.get(r.id)):(f=p.renderableTunnelSegments,m=p.tunnelProgramConfigurations.get(r.id)),!f||0===f.segments[0].primitiveLength)continue;m.updatePaintBuffers(),t.prepareDrawTile();const _=t.isTileAffectedByFog(u),g=[];l&&g.push("RENDER_SHADOWS","NORMAL_OFFSET");const y=t.getOrCreateProgram("elevatedStructures",{config:m,overrideFog:_,defines:g}),x=t.translatePosMatrix(u.projMatrix,n,r.paint.get("fill-translate"),r.paint.get("fill-translate-anchor"));l&&a.setupShadows(n.tileID.toUnwrapped(),y,"vector-tile");const v=Ms(x,h);t.uploadCommonUniforms(t.context,y,u.toUnwrapped()),y.draw(t,s.TRIANGLES,c,Zr.disabled,o,Yr.backCCW,v,r.id,p.vertexBuffer,p.indexBuffer,f,r.paint,t.transform.zoom,m,[p.vertexBufferNormal])}};u(!0),u(!1)}(p)}}else xa(p,!1,f,t.stencilModeFor3D())},"fill-extrusion":function(t,i,r,n){const o=r.paint.get("fill-extrusion-opacity"),s=t.context,a=s.gl,l=t.terrain,c=l&&l.renderingToTexture;if(0===o)return;const h="mrt-fallback"===t.emissiveMode,u=t.conflationActive&&t.style.isLayerClipped(r,i.getSource()),d=t.style.order.indexOf(r.fqid);if(u&&function(e,t,i,r,n){for(const o of r){const r=t.getTile(o).getBucket(i);r&&(r.updateReplacement(o,e.replacementSource,n),r.uploadCentroid(e.context))}}(t,i,r,n,d),l||u)for(const e of n){const n=i.getTile(e).getBucket(r);n&&Ia(t.context,i,e,n,r,l,u)}if("shadow"===t.renderPass&&t.shadowRenderer){if(l&&o<.65&&r._transitionablePaint._values["fill-extrusion-opacity"].value.expression instanceof e.ac)return;ba(t,i,r,n,t.shadowRenderer.getShadowPassDepthMode(),Zr.disabled,Hr.disabled,u)}else if("translucent"===t.renderPass){const d=!r.paint.get("fill-extrusion-pattern").constantOr(1),p=r.paint.get("fill-extrusion-color").constantOr(e.C.white);if(!c&&0!==p.a){const e=new $r(t.context.gl.LEQUAL,$r.ReadWrite,t.depthRangeFor3D);1===o&&d?ba(t,i,r,n,e,Zr.disabled,Hr.unblended,u):(ba(t,i,r,n,e,Zr.disabled,Hr.disabled,u),ba(t,i,r,n,e,t.stencilModeFor3D(),t.colorModeForRenderPass(),u),t.resetStencilClippingMasks())}if(t.style.enable3dLights()&&d&&(!l&&"globe"!==t.transform.projection.name||c)){const o=r.paint.get("fill-extrusion-opacity"),d=r.paint.get("fill-extrusion-ambient-occlusion-intensity"),p=r.paint.get("fill-extrusion-ambient-occlusion-ground-radius"),f=r.paint.get("fill-extrusion-flood-light-intensity"),m="none"===r.paint.get("fill-extrusion-flood-light-color-use-theme").constantOr("default"),_=r.paint.get("fill-extrusion-flood-light-color").toNonPremultipliedRenderColor(m?null:r.lut).toArray01().slice(0,3),g=d>0&&p>0,y=f>0,x=(e,t,i)=>(1-i)*e+i*t,v=new wa;v.translate=r.paint.get("fill-extrusion-translate"),v.translateAnchor=r.paint.get("fill-extrusion-translate-anchor"),v.edgeRadius=r.layout.get("fill-extrusion-edge-radius"),v.cutoffFadeRange=r.paint.get("fill-extrusion-cutoff-fade-range");const b=s=>{const l=t.depthModeForSublayer(1,$r.ReadOnly,a.LEQUAL,!0),c=x(.1,3,r.paint.get(s?"fill-extrusion-ambient-occlusion-ground-attenuation":"fill-extrusion-flood-light-ground-attenuation")),h=t._showOverdrawInspector;h||Sa(v,t,i,r,n,l,new Zr({func:a.ALWAYS,mask:255},255,255,a.KEEP,a.KEEP,a.REPLACE),new Hr([a.ONE,a.ONE,a.ONE,a.ONE],e.C.transparent,[!1,!1,!1,!0],a.MIN),Yr.disabled,s,"sdf",o,d,p,f,_,c,u,!1),Sa(v,t,i,r,n,l,h?Zr.disabled:new Zr({func:a.EQUAL,mask:255},255,255,a.KEEP,a.DECR,a.DECR),h?t.colorModeForRenderPass():new Hr([a.ONE_MINUS_DST_ALPHA,a.DST_ALPHA,a.ONE,a.ONE],e.C.transparent,[!0,!0,!0,!0]),Yr.disabled,s,"color",o,d,p,f,_,c,u,!1)};if(c){const c=()=>{const t=l.drapeBufferSize[0],i=l.drapeBufferSize[1];let r=l.framebufferCopyTexture;return r&&(!r||r.size[0]===t&&r.size[1]===i)||(r&&r.destroy(),r=l.framebufferCopyTexture=new e.T(s,new e.q({width:t,height:i}),a.RGBA8)),r.bind(a.LINEAR,a.CLAMP_TO_EDGE),a.copyTexSubImage2D(a.TEXTURE_2D,0,0,0,0,0,t,i),r},m=(s,l,m)=>{const g=t.depthModeForSublayer(1,$r.ReadOnly,a.LEQUAL,!1),y=x(.1,3,r.paint.get(s?"fill-extrusion-ambient-occlusion-ground-attenuation":"fill-extrusion-flood-light-ground-attenuation"));{const c=new Hr([a.ONE,a.ONE,a.ONE,a.ONE],e.C.transparent,[!1,!1,!1,!0]);Sa(v,t,i,r,n,g,Zr.disabled,c,Yr.disabled,s,"clear",o,d,p,f,_,y,u,l)}Sa(v,t,i,r,n,g,new Zr({func:a.ALWAYS,mask:255},255,255,a.KEEP,a.KEEP,a.REPLACE),new Hr([a.ONE,a.ONE,a.ONE,a.ONE],e.C.transparent,[!1,!1,!1,!0],a.MIN),Yr.disabled,s,"sdf",o,d,p,f,_,y,u,l),h&&!s&&(m=c());{const c=s?a.ZERO:a.ONE_MINUS_DST_ALPHA;Sa(v,t,i,r,n,g,new Zr({func:a.EQUAL,mask:255},255,255,a.KEEP,a.DECR,a.DECR),new Hr([c,a.DST_ALPHA,a.ONE_MINUS_DST_ALPHA,a.ZERO],e.C.transparent,[!0,!0,!0,!0]),Yr.disabled,s,"color",o,d,p,f,_,y,u,l)}if(!h||s){const c=new Hr([a.ONE,a.ONE,a.ONE,s?a.ZERO:a.ONE],e.C.transparent,[!1,!1,!1,!0],s?a.FUNC_ADD:a.MAX);Sa(v,t,i,r,n,g,Zr.disabled,c,Yr.disabled,s,"clear",o,d,p,f,_,y,u,l,m)}else a.drawBuffers([a.NONE,a.COLOR_ATTACHMENT1]),Sa(v,t,i,r,n,g,new Zr({func:a.EQUAL,mask:255},254,255,a.KEEP,a.DECR,a.DECR),new Hr([a.ONE,a.ONE,a.ONE,a.ONE],e.C.transparent,[!0,!1,!1,!1],a.MAX),Yr.disabled,s,"emissive",o,d,p,f,_,y,u,l,m),a.drawBuffers([a.COLOR_ATTACHMENT0])};if(g||y){let e;t.prepareDrawTile(),h&&!g||(e=c()),g&&m(!0,!1,e),y&&m(!1,!0,e)}}else g&&b(!0),y&&b(!1),(g||y)&&t.resetStencilClippingMasks()}}},hillshade:function(e,t,i,r){if("offscreen"!==e.renderPass&&"translucent"!==e.renderPass)return;if(e.style.disableElevatedTerrain)return;const n=e.context,o=e.terrain&&e.terrain.renderingToTexture,[s,a]="translucent"!==e.renderPass||o?[{},r]:e.stencilConfigForOverlap(r);for(const l of a){const r=t.getTile(l);if(r.needsHillshadePrepare&&"offscreen"===e.renderPass)_o(e,r,i);else if("translucent"===e.renderPass){const t=e.depthModeForSublayer(0,$r.ReadOnly),n=i.paint.get("hillshade-emissive-strength"),a=e.colorModeForDrapableLayerRenderPass(n);fo(e,l,r,i,t,o&&e.terrain?e.terrain.stencilModeForRTTOverlap(l):s[l.overscaledZ],a)}}n.viewport.set([0,0,e.width,e.height]),e.resetStencilClippingMasks()},raster:function(t,i,r,n,o,s){if("translucent"!==t.renderPass)return;const a=r.paint.get("raster-opacity");if(0===a)return;const l="globe"===t.transform.projection.name,c=0!==r.paint.get("raster-elevation"),h=c&&l,u=t.terrain&&t.terrain.exaggeration()>0&&c&&"ground"===r.paint.get("raster-elevation-reference"),d=!l&&u;if(t.renderElevatedRasterBackface&&!h)return;const p=t.context,f=p.gl,m=i.getSource(),_=function(t,i,r,n,o){const s=i.paint.get("raster-color"),a="raster-array"===t.type,l=[],c=i.paint.get("raster-resampling"),h=i.paint.get("raster-color-mix");let u=i.paint.get("raster-color-range");const d=[h[0],h[1],h[2],0],p=h[3];let f="nearest"===c?n.NEAREST:n.LINEAR;if(a&&(l.push("RASTER_ARRAY"),s||l.push("RASTER_COLOR"),"linear"===c&&l.push("RASTER_ARRAY_LINEAR"),f=n.NEAREST,!u&&t.rasterLayers)){const e=t.rasterLayers.find(({id:e})=>e===i.sourceLayer);e&&e.fields&&e.fields.range&&(u=e.fields.range)}if(u=u||[0,1],s){l.push("RASTER_COLOR"),r.activeTexture.set(n.TEXTURE2),i.updateColorRamp(u);let t=i.colorRampTexture;t||(t=i.colorRampTexture=new e.T(r,i.colorRamp,n.RGBA8)),t.bind(f,n.CLAMP_TO_EDGE)}return o&&l.push("USE_MRT1"),{mix:d,range:u,offset:p,defines:l,resampling:f}}(m,r,p,f,t.terrain&&t.terrain.renderingToTexture&&"mrt-fallback"===t.emissiveMode);if(m instanceof e.aY&&!n.length&&!l)return;const g=r.paint.get("raster-emissive-strength"),y=t.colorModeForDrapableLayerRenderPass(g),x=t.terrain&&t.terrain.renderingToTexture,v=!t.options.moving,b="nearest"===r.paint.get("raster-resampling")?f.NEAREST:f.LINEAR;if(m instanceof e.aY&&!n.length&&(m.onNorthPole||m.onSouthPole)){const e=c?t.stencilModeFor3D():Zr.disabled;return void nl(!!m.onNorthPole,null,t,i,r,g,_,Yr.disabled,e)}if(!n.length)return;const[w,T]=m instanceof e.aY||x?[{},n]:t.stencilConfigForOverlap(n),S=T.at(-1).overscaledZ;h&&_.defines.push("PROJECTION_GLOBE_VIEW"),c&&_.defines.push("RENDER_CUTOFF","ELEVATED"),u&&_.defines.push("ELEVATION_REFERENCE_GROUND");const I=(n,o,T)=>{for(const I of n){const n=I.toUnwrapped(),E=i.getTile(I);if(x&&(!E||!E.hasData()))continue;p.activeTexture.set(f.TEXTURE0);const A=sl(E,m,r,_);if(!A||!A.texture)continue;const{texture:M,mix:C,offset:P,tileSize:D,buffer:R}=A;let z,L;x?(z=$r.disabled,L=I.projMatrix):c?(z=new $r(f.LEQUAL,$r.ReadWrite,t.depthRangeFor3D),L=l?t.transform.expandedFarZProjMatrix:t.transform.calculateProjMatrix(n,v)):(z=t.depthModeForSublayer(I.overscaledZ-S,1===a?$r.ReadWrite:$r.ReadOnly,f.LESS),L=t.transform.calculateProjMatrix(n,v));const F=t.terrain&&x?t.terrain.stencilModeForRTTOverlap(I):w[I.overscaledZ],O=s?0:r.paint.get("raster-fade-duration");E.registerFadeDuration(O);const B=i.findLoadedParent(I,0),k=ls(E,B,i,t.transform,O);let N,U;!k.isFading&&E.refreshedUponExpiration&&(E.refreshedUponExpiration=!1),t.terrain&&t.terrain.prepareDrawTile(),p.activeTexture.set(f.TEXTURE0),M.bind(b,f.CLAMP_TO_EDGE),p.activeTexture.set(f.TEXTURE1),B?(B.texture&&B.texture.bind(b,f.CLAMP_TO_EDGE),N=Math.pow(2,B.tileID.overscaledZ-E.tileID.overscaledZ),U=[E.tileID.canonical.x*N%1,E.tileID.canonical.y*N%1]):M.bind(b,f.CLAMP_TO_EDGE),"useMipmap"in M&&p.extTextureFilterAnisotropic&&t.transform.pitch>20&&f.texParameterf(f.TEXTURE_2D,p.extTextureFilterAnisotropic.TEXTURE_MAX_ANISOTROPY_EXT,p.extTextureFilterAnisotropicMax);const V=t.transform;let j;const G=c?ol(V):[0,0,0,0];let H,$,q,Z,W,X=0;if(h&&m instanceof e.aY&&m.coordinates.length>3)H=Float32Array.from(e.dx(e.dy(new e.cp(0,0,0)))),$=Float32Array.from(V.globeMatrix),q=Float32Array.from(e.dt(V)),Z=[e.aG(V.center.lng),e.aJ(V.center.lat)],j=m.elevatedGlobePerspectiveTransform,W=m.elevatedGlobeGridMatrix||new Float32Array(9);else if(h){const t=e.du(I.canonical);X=e.dv(t.getCenter().lat),H=Float32Array.from(e.dx(e.dy(I.canonical))),$=Float32Array.from(V.globeMatrix),q=Float32Array.from(e.dt(V)),Z=[e.aG(V.center.lng),e.aJ(V.center.lat)],j=[0,0],W=Float32Array.from(e.dw(I.canonical,t,X,V.worldSize/V._pixelsPerMercatorPixel))}else j=m instanceof e.aY?m.perspectiveTransform:[0,0],H=new Float32Array(16),$=new Float32Array(9),q=new Float32Array(16),Z=[0,0],W=new Float32Array(9);const Y=Ns(t,L,H,$,q,W,U||[0,0],e.ai(t.transform.zoom),Z,G,N||1,k,r,j,c?r.paint.get("raster-elevation"):0,2,C,P,_.range,D,R,g),J=t.isTileAffectedByFog(I),K=t.getOrCreateProgram("raster",{defines:_.defines,overrideFog:J});if(t.uploadCommonUniforms(p,K,n),m instanceof e.aY){const i=m.elevatedGlobeVertexBuffer,n=m.elevatedGlobeIndexBuffer;if(x||!l)m.boundsBuffer&&m.boundsSegments&&K.draw(t,f.TRIANGLES,z,Zr.disabled,y,Yr.disabled,Y,r.id,m.boundsBuffer,t.quadTriangleIndexBuffer,m.boundsSegments);else if(i&&n){const s=V.zoom<=e.cN?m.elevatedGlobeSegments:m.getSegmentsForLongitude(V.center.lng);s&&K.draw(t,f.TRIANGLES,z,Zr.disabled,y,o,Y,r.id,i,n,s)}}else if(h){z=new $r(f.LEQUAL,$r.ReadOnly,t.depthRangeFor3D);const e=t.globeSharedBuffers;if(e){u&&(t.terrain.setupElevationDraw(E,K),t.uploadCommonUniforms(p,K,E.tileID.toUnwrapped()));const[i,n,s]=e.getGridBuffers(X,!1),a=K.getAttributeLocation(f,"a_texture_pos");-1!==a&&f.vertexAttribI4ui(a,0,0,0,0),K.draw(t,f.TRIANGLES,z,T||F,t.colorModeForRenderPass(),o,Y,r.id,i,n,s)}}else if(d)z=new $r(f.LEQUAL,$r.ReadWrite,t.depthRangeFor3D),t.terrain.setupElevationDraw(E,K),t.uploadCommonUniforms(p,K,E.tileID.toUnwrapped()),V.pitch>20&&K.draw(t,f.TRIANGLES,z,Zr.disabled,Hr.disabled,Yr.frontCCW,Y,r.id,t.terrain.gridBuffer,t.terrain.gridIndexBuffer,t.terrain.gridSegments),K.draw(t,f.TRIANGLES,z,F,y,Yr.backCCW,Y,r.id,t.terrain.gridBuffer,t.terrain.gridIndexBuffer,t.terrain.gridSegments);else{const{tileBoundsBuffer:e,tileBoundsIndexBuffer:i,tileBoundsSegments:n}=t.getTileBoundsBuffers(E);K.draw(t,f.TRIANGLES,z,F,y,Yr.disabled,Y,r.id,e,i,n)}}if(!(m instanceof e.aY)&&h)for(const e of n){const n=e.canonical.y===(1<<e.canonical.z)-1;0===e.canonical.y&&nl(!0,e,t,i,r,g,_,o,T||Zr.disabled),n&&nl(!1,e,t,i,r,g,_,o===Yr.frontCW?Yr.backCW:Yr.frontCW,T||Zr.disabled)}};h?I(T,t.renderElevatedRasterBackface?Yr.backCW:Yr.frontCW,t.stencilModeFor3D()):I(T,Yr.disabled,void 0),t.resetStencilClippingMasks()},background:function(t,i,r,n){const o=r.paint.get("background-color"),s="none"===r.paint.get("background-color-use-theme").constantOr("default"),a=r.paint.get("background-opacity"),l=r.paint.get("background-emissive-strength"),c="viewport"===r.paint.get("background-pitch-alignment");if(0===a)return;const h=t.context,u=h.gl,d=t.transform,p=d.tileSize,f=r.paint.get("background-pattern");let m;if(void 0!==f){if(null===f)return;if(m=t.imageManager.getPattern(e.I.from(f.toString()),r.scope,t.style.getLut(r.scope)),!m)return}const _=!f&&1===o.a&&1===a&&t.opaquePassEnabledForLayer()?"opaque":"translucent";if(t.renderPass!==_)return;const g=Zr.disabled,y=t.depthModeForSublayer(0,"opaque"===_?$r.ReadWrite:$r.ReadOnly),x=t.colorModeForDrapableLayerRenderPass(l),v=f?"backgroundPattern":"background";let b,w=n;w||(b=t.getBackgroundTiles(),w=Object.values(b).map(e=>e.tileID)),f&&(h.activeTexture.set(u.TEXTURE0),t.imageManager.bind(t.context,r.scope));const T=[];if(t.terrain&&t.terrain.renderingToTexture&&"mrt-fallback"===t.emissiveMode&&T.push("USE_MRT1"),c){const i=t.getOrCreateProgram(v,{overrideFog:!1,overrideRtt:!0,defines:T}),n=al,h=new e.aU(0,0,0,0,0),d=f?Hs(n,l,a,t,0,r.scope,m,c,{tileID:h,tileSize:p}):Gs(n,l,a,o.toPremultipliedRenderColor(s?null:r.lut));return void i.draw(t,u.TRIANGLES,y,g,x,Yr.disabled,d,r.id,t.viewportBuffer,t.quadTriangleIndexBuffer,t.viewportSegments)}for(const S of w){const _=t.isTileAffectedByFog(S),w=t.getOrCreateProgram(v,{overrideFog:_,defines:T}),I=S.toUnwrapped(),E=n?S.projMatrix:t.transform.calculateProjMatrix(I);t.prepareDrawTile();const A=i?i.getTile(S):b?b[S.key]:new e.b3(S,p,d.zoom,t),M=f?Hs(E,l,a,t,0,r.scope,m,c,{tileID:S,tileSize:p}):Gs(E,l,a,o.toPremultipliedRenderColor(s?null:r.lut));t.uploadCommonUniforms(h,w,I);const{tileBoundsBuffer:C,tileBoundsIndexBuffer:P,tileBoundsSegments:D}=t.getTileBoundsBuffers(A);w.draw(t,u.TRIANGLES,y,g,x,Yr.disabled,M,r.id,C,P,D)}},sky:function(t,i,r){const n=t._atmosphere?e.ai(t.transform.zoom):1,o=r.paint.get("sky-opacity")*n;if(0===o)return;const s=t.context,a=r.paint.get("sky-type"),l=new $r(s.gl.LEQUAL,$r.ReadOnly,[0,1]),c=t.frameCounter/1e3%1;"atmosphere"===a?"offscreen"===t.renderPass?r.needsSkyboxCapture(t)&&(function(t,i){const r=t.context,n=r.gl;let o=i.skyboxFbo;if(!o){o=i.skyboxFbo=r.createFramebuffer(32,32,1,null),i.skyboxGeometry=new xl(r),i.skyboxTexture=r.gl.createTexture(),n.bindTexture(n.TEXTURE_CUBE_MAP,i.skyboxTexture),n.texParameteri(n.TEXTURE_CUBE_MAP,n.TEXTURE_WRAP_S,n.CLAMP_TO_EDGE),n.texParameteri(n.TEXTURE_CUBE_MAP,n.TEXTURE_WRAP_T,n.CLAMP_TO_EDGE),n.texParameteri(n.TEXTURE_CUBE_MAP,n.TEXTURE_MIN_FILTER,n.LINEAR),n.texParameteri(n.TEXTURE_CUBE_MAP,n.TEXTURE_MAG_FILTER,n.LINEAR);for(let e=0;e<6;++e)n.texImage2D(n.TEXTURE_CUBE_MAP_POSITIVE_X+e,0,n.RGBA,32,32,0,n.RGBA,n.UNSIGNED_BYTE,null)}r.bindFramebuffer.set(o.framebuffer),r.viewport.set([0,0,32,32]);const s=i.getCenter(t,!0),a=t.getOrCreateProgram("skyboxCapture"),l=new Float64Array(16);e.en(l,.5*-Math.PI),vl(t,i,a,l,s,0),e.en(l,.5*Math.PI),vl(t,i,a,l,s,1),e.eo(l,.5*-Math.PI),vl(t,i,a,l,s,2),e.eo(l,.5*Math.PI),vl(t,i,a,l,s,3),e.bA(l),vl(t,i,a,l,s,4),e.en(l,Math.PI),vl(t,i,a,l,s,5),r.viewport.set([0,0,t.width,t.height])}(t,r),r.markSkyboxValid(t)):"sky"===t.renderPass&&function(e,t,i,r,n){const o=e.context,s=o.gl,a=e.transform,l=e.getOrCreateProgram("skybox");o.activeTexture.set(s.TEXTURE0),s.bindTexture(s.TEXTURE_CUBE_MAP,t.skyboxTexture);const c=((e,t,i,r,n)=>({u_matrix:e,u_sun_direction:t,u_cubemap:0,u_opacity:r,u_temporal_offset:n}))(a.skyboxMatrix,t.getCenter(e,!1),0,r,n);e.uploadCommonUniforms(o,l),l.draw(e,s.TRIANGLES,i,Zr.disabled,e.colorModeForRenderPass(),Yr.backCW,c,"skybox",t.skyboxGeometry.vertexBuffer,t.skyboxGeometry.indexBuffer,t.skyboxGeometry.segment)}(t,r,l,o,c):"gradient"===a&&"sky"===t.renderPass&&function(t,i,r,n,o){const s=t.context,a=s.gl,l=t.transform,c=t.getOrCreateProgram("skyboxGradient");i.skyboxGeometry||(i.skyboxGeometry=new xl(s)),s.activeTexture.set(a.TEXTURE0);let h=i.colorRampTexture;h||(h=i.colorRampTexture=new e.T(s,i.colorRamp,a.RGBA8)),h.bind(a.LINEAR,a.CLAMP_TO_EDGE);const u=((t,i,r,n,o)=>({u_matrix:t,u_color_ramp:0,u_center_direction:i,u_radius:e.am(r),u_opacity:n,u_temporal_offset:o}))(l.skyboxMatrix,i.getCenter(t,!1),i.paint.get("sky-gradient-radius"),n,o);t.uploadCommonUniforms(s,c),c.draw(t,a.TRIANGLES,r,Zr.disabled,t.colorModeForRenderPass(),Yr.backCW,u,"skyboxGradient",i.skyboxGeometry.vertexBuffer,i.skyboxGeometry.indexBuffer,i.skyboxGeometry.segment)}(t,r,l,o,c)},custom:function(t,i,r,n){const o=t.context,s=r.implementation;if(!t.transform.projection.unsupportedLayers||!t.transform.projection.unsupportedLayers.includes("custom")||t.terrain&&(t.terrain.renderingToTexture||"offscreen"===t.renderPass)&&r.isDraped(i)){if("offscreen"===t.renderPass){const i=s.prerender;if(i){if(t.setCustomLayerDefaults(),o.setColorMode(t.colorModeForRenderPass()),"globe"===t.transform.projection.name){const r=t.transform.pointMerc;i.call(s,o.gl,t.transform.customLayerMatrix(),t.transform.getProjection(),t.transform.globeToMercatorMatrix(),e.ai(t.transform.zoom),[r.x,r.y],t.transform.pixelsPerMeterRatio)}else i.call(s,o.gl,t.transform.customLayerMatrix());o.setDirty(),t.setBaseState()}}else if("translucent"===t.renderPass){if(t.terrain&&t.terrain.renderingToTexture){const e=s.renderToTile;if(e){const i=n[0].canonical,r={x:i.x+n[0].wrap*(s.wrapTileId?0:1<<i.z),y:i.y,z:i.z};o.setDepthMode($r.disabled),o.setStencilMode(Zr.disabled),o.setColorMode(t.colorModeForRenderPass()),t.setCustomLayerDefaults(),e.call(s,o.gl,r),o.setDirty(),t.setBaseState()}return}t.setCustomLayerDefaults(),o.setColorMode(t.colorModeForRenderPass()),o.setStencilMode(Zr.disabled);const i="3d"===s.renderingMode?new $r(t.context.gl.LEQUAL,$r.ReadWrite,t.depthRangeFor3D):t.depthModeForSublayer(0,$r.ReadOnly);if(o.setDepthMode(i),"globe"===t.transform.projection.name){const i=t.transform.pointMerc;s.render(o.gl,t.transform.customLayerMatrix(),t.transform.getProjection(),t.transform.globeToMercatorMatrix(),e.ai(t.transform.zoom),[i.x,i.y],t.transform.pixelsPerMeterRatio)}else s.render(o.gl,t.transform.customLayerMatrix());o.setDirty(),t.setBaseState(),o.bindFramebuffer.set(null)}}else e.w("Custom layers are not yet supported with this projection. Use mercator or globe to enable usage of custom layers.")},model:function(t,i,r,n){if("opaque"===t.renderPass)return;const o=r.paint.get("model-opacity").constantOr(1),s=r.paint.get("model-elevation-reference"),a="ground"===s,l="ground"===s;if(0===o)return;const c=r.paint.get("model-cast-shadows");if("shadow"===t.renderPass){if(!c)return;if(t.terrain&&o<.65&&r._transitionablePaint._values["model-opacity"].value.expression instanceof e.ac)return}const h=t.shadowRenderer,u=r.paint.get("model-receive-shadows");h&&(h.useNormalOffset=!0,u||(h.enabled=!1));const d=()=>{h&&(h.useNormalOffset=!0,u||(h.enabled=!0))},p=i.getSource();if("light-beam"===t.renderPass&&"batched-model"!==p.type)return;if("vector"===p.type||"geojson"===p.type)return function(t,i,r,n,o){const s=t.transform,a="globe"===s.projection.name,l=s.getFreeCameraOptions().position;if(!t.modelManager)return;const c=t.modelManager;r.modelManager=c;const h=t.shadowRenderer;if(!Object.hasOwn(r._unevaluatedLayout._values,"model-id"))return;const u=r._unevaluatedLayout._values["model-id"],d=Object.assign({},r.layout.get("model-id").parameters),p=t.style.order.indexOf(r.fqid),f=r.paint.get("model-opacity").constantOr(1);for(const m of n){const n=i.getTile(m).getBucket(r);if(!n||n.projection.name!==s.projection.name)continue;const _=n.getModelUris();_&&!n.modelsRequested&&(c.addModelsFromBucket(_,o),n.modelsRequested=!0),d.zoom=a?m.overscaledZ:Gl(m,s);const g=u.possiblyEvaluate(d);if(Vl(t,n,m),jl.shadowUniformsInitialized=!1,jl.useSingleShadowCascade=!!h&&0===h.getMaxCascadeForTile(m.toUnwrapped()),"shadow"===t.renderPass&&h){if(1===t.currentShadowCascade&&n.isInsideFirstShadowMapFrustum)continue;const i=s.calculatePosMatrix(m.toUnwrapped(),s.worldSize);if(jl.tileMatrix.set(i),jl.shadowTileMatrix.set(h.calculateShadowPassMatrixFromMatrix(i)),jl.aabb.min=[0,0,0],jl.aabb.max[0]=jl.aabb.max[1]=e.ak,jl.aabb.max[2]=0,Zl(n,jl,t,r.scope))continue}const y=1<<m.canonical.z,x=[((l.x-m.wrap)*y-m.canonical.x)*e.ak,(l.y*y-m.canonical.y)*e.ak,l.z*y*e.ak];t.conflationActive&&Object.keys(n.instancesPerModel).length>0&&t.style.isLayerClipped(r,i.getSource())&&n.updateReplacement(m,t.replacementSource,p,r.scope)&&(n.uploaded=!1,n.upload(t.context));let v=0;const b=new Array,w=new Array,T=new Array;for(let i in n.instancesPerModel){const s=n.instancesPerModel[i];s.features.length>0&&!a&&(i=g.evaluate(s.features[0].feature,{}));const h=c.getModel(i,o);if(h||c.hasURLBeenRequested(i)||n.modelUris.includes(i)||(n.modelUris.push(i),n.modelsRequested=!1),h&&h.uploaded)if(a){const i=e.bN([],[l.x,l.y,l.z],t.transform.worldSize);e.ew(i,i);for(let r=0;r<s.instancedDataArray.length;++r){const o=[0,0,0],a=[1,1,1],l=e.ex(),c=s.tileCoordinatesForInstance(r),u=s.transformForInstance(r);e.ey(a,u),e.ez(l,u),e.eA(o,l);const d=s.translationForInstance(r),p=new e.aX(0,0);e.eB(n.canonical,p,c.x,c.y);const m=e.bd();e.eC(m,h,t.transform,p,o,a,d,!0,!1,!1);const _=s.colorForInstance(r),g=e.cK([],i),y=e.e8(p.lat,t.transform.zoom),x=e.bT([],[1,1,1/y]);T.push({zScaleMatrix:x,negCameraPosMatrix:g});for(const e of h.nodes)Fl(t,e,m,t.transform.expandedFarZProjMatrix,v,b,w,h.materialOverrides,f,_);++v}}else for(const e of h.nodes)Hl(t,r,e,s,x,m,jl)}if(a)if("shadow"===t.renderPass){for(const e of w)Ol(e.mesh,e.nodeModelMatrix,t,r);for(const e of b)Ol(e.mesh,e.nodeModelMatrix,t,r)}else Ul(t,r,b,w,T)}}(t,i,r,n,Ll(t,r)),void d();if(!p.loaded())return;if("batched-model"===p.type)return function(t,i,r,n){r.resetLayerRenderingStats(t);const o=t.context,s=t.transform,a=t.style.fog,l=t.shadowRenderer;if("mercator"!==s.projection.name)return void e.w(`Drawing 3D landmark models for ${s.projection.name} projection is not yet implemented`);const c=t.transform.getFreeCameraOptions().position,h=e.bN([],[c.x,c.y,c.z],t.transform.worldSize),u=e.ew([],h),d=e.cK([],u),p=e.e8(s.center.lat,s.zoom),f=e.bT([],[1,1,1/p]),m=r.paint.get("model-opacity").constantOr(1),_=new $r(o.gl.LEQUAL,$r.ReadWrite,t.depthRangeFor3D),g=new $r(o.gl.LEQUAL,$r.ReadOnly,t.depthRangeFor3D),y=new e.cY([1/0,1/0,1/0],[-1/0,-1/0,-1/0]),x="shadow"===t.renderPass,v=x&&l?l.getCurrentCascadeFrustum():s.getFrustum(s.scaleZoom(s.worldSize)),b=r.paint.get("model-front-cutoff"),w=b[2]<1,T=an(t,r.paint.get("model-cutoff-fade-range")),S=r.getLayerRenderingStats();(function(e,t,i,r){const n=e.terrain?e.terrain.exaggeration():0,o=e.transform.zoom;for(const s of r){const r=t.getTile(s).getBucket(i);r&&(r.setFilter(i.filter),e.conflationActive&&r.updateReplacement(s,e.replacementSource),r.evaluateTransform(e,i),e.terrain&&n>0&&r.elevationUpdate(e.terrain,n,s,i.source),r.needsReEvaluation(e,o,i)&&r.evaluate(i))}})(t,i,r,n),function(){const c=/* @__PURE__ */new Map;let u,I,E;w?(u=n.length-1,I=-1,E=-1):(u=0,I=n.length,E=1);const A=new Float64Array(16),M=e.cg(),C=new e.P(0,0);for(let P=u;P!==I;P+=E){const u=n[P],I=i.getTile(u).getBucket(r);if(!I||!I.uploaded)continue;let E=!1;l&&(E=0===l.getMaxCascadeForTile(u.toUnwrapped()));const D=s.calculatePosMatrix(u.toUnwrapped(),s.worldSize),R=I.modelTraits;!x&&w&&(e.ba(A,D),e.ae(M,h,A),C.x=M[0],C.y=M[1]);const z=[];I.setFilter(r.filter);for(const i of I.getNodesInfo()){if(i.hiddenByReplacement)continue;if(!i.node.meshes)continue;const r=i.node;let n=0;t.terrain&&r.elevation&&(n=r.elevation*t.terrain.exaggeration());const o=(()=>{const t=i.aabb;return y.min=[...t.min],y.max=[...t.max],y.min[2]+=n,y.max[2]+=n,e.ae(y.min,y.min,D),e.ae(y.max,y.max,D),y})(),a=i.evaluatedScale;if(a[0]<=1&&a[1]<=1&&a[2]<=1&&0===o.intersects(v))continue;if(!x){const r=o.min,n=o.max;Pl[0]=.5*(r[0]+n[0]),Pl[1]=.5*(r[1]+n[1]),Pl[2]=.5*(r[2]+n[2]),ql(i,e.bh(h,Pl)*p,Math.min(t._debugParams.dt,1e3/30),t._debugParams.lodSwitchDistance)}if(!x&&w){const t=1/6;i.cameraCollisionOpacity=h[0]>o.min[0]&&h[0]<o.max[0]&&h[1]>o.min[1]&&h[1]<o.max[1]&&h[2]*p<o.max[2]&&r.footprint&&e.bG(C,r.footprint)?Math.max(i.cameraCollisionOpacity-t,0):Math.min(1,i.cameraCollisionOpacity+t)}const l=[...D],c=1/e.cW(u.canonical),d=r.anchor?r.anchor[0]:0,f=r.anchor?r.anchor[1]:0;e.bB(l,l,[d*(a[0]-1)+i.evaluatedTranslation[0]*c,f*(a[1]-1)+i.evaluatedTranslation[1]*c,n+i.evaluatedTranslation[2]]),e.c6(a,e.eE)||e.cE(l,l,a);const _=e.aC([],l,r.globalMatrix),g=e.aC([],s.expandedFarZProjMatrix,_),S=e.aC([],s.expandedFarZProjMatrix,l),I=e.aD([],[d,f,n,1],g)[2];r.hidden=!1;let E=m;x||(w&&(E*=i.cameraCollisionOpacity,E*=Xl(l,s,i.aabb,b)),E*=Wl(T,I)),0!==E?z.push({nodeInfo:i,depth:I,opacity:E,wvpForNode:g,wvpForTile:S,nodeModelMatrix:_,tileModelMatrix:l}):r.hidden=!0}x||z.sort((e,t)=>!w||1===e.opacity&&1===t.opacity?e.depth<t.depth?-1:1:1===e.opacity?-1:1===t.opacity?1:e.depth>t.depth?-1:1);for(const i of z){const n=i.nodeInfo,h=n.node;if(t._debugParams.show3DModelFootprints&&h.footprint){const e=h.id||h.name||"footprint";c.has(e)||c.set(e,{node:h,mvp:i.wvpForTile})}e.aC(El,f,i.tileModelMatrix),e.aC(El,d,El),e.ba(Al,El),e.e9(Al,Al),e.cE(Al,Al,$l),e.aC(El,El,h.globalMatrix);const u="light-beam"===t.renderPass,p="none"===r.paint.get("model-color-use-theme").constantOr("default"),m=R&e.eH.HasMapboxMeshFeatures,y=m?0:n.evaluatedRMEA[0][2],v=n.targetLod,b=h.lodMeshes&&h.lodMeshes.length>0,w=b&&v>0&&v<1;if(x&&b&&1===Math.round(v))continue;const T=w?2:1,I=b&&1===Math.round(v);for(let e=0;e<T;++e){const c=w?1===e:I,d=c?h.lodMeshes:h.meshes,f=w?c?-v:1-v:1;for(let e=0;e<d.length;++e){const v=d[e],b=!c&&e===h.lightMeshIndex;let T=i.wvpForNode;if(b){if(!u&&!t.terrain&&t.shadowRenderer){t.currentLayer<t.firstLightBeamLayer&&(t.firstLightBeamLayer=t.currentLayer);continue}T=i.wvpForTile}else if(u)continue;const I={defines:[]},A=[];if(!x&&l&&(l.useNormalOffset=!!v.normalBuffer),Rl(I.defines,A,v,t,p?null:r.lut),m||I.defines.push("DIFFUSE_SHADED"),E&&I.defines.push("SHADOWS_SINGLE_CASCADE"),S&&(x?S.numRenderedVerticesInShadowPass+=v.vertexArray.length:S.numRenderedVerticesInTransparentPass+=v.vertexArray.length),x){Ol(v,i.nodeModelMatrix,t,r);continue}let M=null;if(a&&(M=Dl(Ml,i.nodeModelMatrix,t.transform),"globe"!==s.projection.name)){const e=v.aabb.min,t=v.aabb.max,[i,r]=a.getOpacityForBounds(M,e[0],e[1],t[0],t[1]);I.overrideFog=i>=$t||r>=$t}const C=v.material;let P;C.occlusionTexture&&C.occlusionTexture.offsetScale&&(P=C.occlusionTexture.offsetScale,I.defines.push("OCCLUSION_TEXTURE_TRANSFORM")),w&&I.defines.push("DITHERED_DISCARD");const D=t.getOrCreateProgram("model",I);!x&&l&&l.setupShadowsFromMatrix(i.tileModelMatrix,D,l.useNormalOffset),t.uploadCommonUniforms(o,D,null,M);const R=C.pbrMetallicRoughness;R.metallicFactor=.9,R.roughnessFactor=.5;const z=qs(T,El,Al,h.globalMatrix,t,i.opacity,R.baseColorFactor,C.emissiveFactor,R.metallicFactor,R.roughnessFactor,C,y,r,[0,0,0],P,void 0,void 0,f);!b&&(n.hasTranslucentParts||i.opacity<1)&&D.draw(t,o.gl.TRIANGLES,_,Zr.disabled,Hr.disabled,Yr.backCCW,z,r.id,v.vertexBuffer,v.indexBuffer,v.segments,r.paint,t.transform.zoom,void 0,A),D.draw(t,o.gl.TRIANGLES,b?g:_,Zr.disabled,b||i.opacity<1||n.hasTranslucentParts?Hr.alphaBlended:Hr.unblended,Yr.backCCW,z,r.id,v.vertexBuffer,v.indexBuffer,v.segments,r.paint,t.transform.zoom,void 0,A)}}}}if(t._debugParams.show3DModelFootprints&&c.size>0){const e=Array.from(c.keys()).sort();for(const i of e){const{node:e,mvp:r}=c.get(i);Bl(t,0,e,r)}}}()}(t,i,r,n),void d();if("model"!==p.type)return;const f=p.getModels(),m=[],_=t.transform.getFreeCameraOptions().position,g=e.bN([],[_.x,_.y,_.z],t.transform.worldSize);e.ew(g,g);const y=[],x=[];let v=0;for(const b of f){const n=i.getFeatureState("",b.id),o={type:"Unknown",id:b.id,properties:b.featureProperties},s=r.paint.get("model-rotation").evaluate(o,n),c=r.paint.get("model-scale").evaluate(o,n),h=r.paint.get("model-translation").evaluate(o,n),u=r.paint.get("model-opacity").evaluate(o,n);kl(r,b.id,n,b.featureProperties,b.nodeOverrideNames,b.nodeOverrides),Nl(r,b.id,n,b.featureProperties,b.materialOverrideNames,b.materialOverrides),b.nodeOverrides.size>0&&b.computeBoundsAndApplyParent(),b.computeModelMatrix(t,s,c,h,l,a,!1);const d=e.cK([],g),p=e.e8(b.position.lat,t.transform.zoom),f=e.bT([],[1,1,1/p]);m.push({zScaleMatrix:f,negCameraPosMatrix:d});for(const e of b.nodes)Fl(t,e,b.matrix,t.transform.expandedFarZProjMatrix,v,y,x,b.materialOverrides,u);v++}if(y.sort((e,t)=>t.depth-e.depth),"shadow"!==t.renderPass){if(t._debugParams.show3DModelFootprints){const i=t.transform.projMatrix,r=/* @__PURE__ */new Map,n=(t,n)=>{if(t.footprint){const o=t.id||t.name||"footprint";if(!r.has(o)){const s=e.aC([],i,n);r.set(o,{node:t,mvp:s})}}};for(const e of x)n(e.node,e.modelMatrix);for(const e of y)n(e.node,e.modelMatrix);const o=Array.from(r.keys()).sort();for(const e of o){const{node:i,mvp:n}=r.get(e);Bl(t,0,i,n)}}Ul(t,r,y,x,m),d()}else{for(const e of x)Ol(e.mesh,e.nodeModelMatrix,t,r);for(const e of y)Ol(e.mesh,e.nodeModelMatrix,t,r);d()}}},ec={line:function(e,t,i){if(e.hasElevatedBuckets=!1,e.hasNonElevatedBuckets=!1,void 0!==e._unevaluatedLayout.getValue("line-elevation-reference")||void 0!==e._unevaluatedLayout.getValue("line-z-offset")){if(t){const i=t.getVisibleCoordinates();for(const r of i){const i=t.getTile(r).getBucket(e);if(i&&("none"!==i.elevationType?e.hasElevatedBuckets=!0:e.hasNonElevatedBuckets=!0,e.hasElevatedBuckets&&e.hasNonElevatedBuckets))break}}}else e.hasNonElevatedBuckets=!0},model:function(e,t,i){const r=t.getSource();if(!r.loaded())return;if("vector"===r.type||"geojson"===r.type)return void(i.modelManager&&i.modelManager.upload(i,Ll(i,e)));if("batched-model"===r.type)return;if("model"!==r.type)return;const n=r.getModels();for(const o of n)o.upload(i.context)},raster:function(e,t,i){const r=t.getSource();if(!(r instanceof vi&&r.loaded()))return;const n=e.sourceLayer||r.rasterLayerIds&&r.rasterLayerIds[0];if(!n)return;const o=e.paint.get("raster-array-band")||r.getInitialBand(n);if(null==o)return;const s=t.getIds().map(e=>t.getTileByID(e));for(const a of s)a.updateNeeded(e.id,o)&&r.prepareTile(a,n,e.id,o)}},tc={fill:ya},ic={fill:function(e,t,i,r){if(!i.layout||"none"===i.layout.get("fill-elevation-reference")||0===i.paint.get("fill-opacity").constantOr(1))return;const n=e.context.gl,o=new $r(n.LEQUAL,$r.ReadOnly,e.depthRangeFor3D),s=new Zr({func:n.ALWAYS,mask:255},255,255,n.KEEP,n.KEEP,n.REPLACE),a=e.transform.getFreeCameraOptions().position,l=e.getOrCreateProgram("elevatedStructuresDepthReconstruct");for(const c of r){const r=t.getTile(c),h=r.getBucket(i);if(!h)continue;const u=h.elevatedStructures;if(!u||!u.depthSegments||0===u.depthSegments.segments[0].primitiveLength)continue;const d=ga(c.toUnwrapped(),a),p=Cs(e.translatePosMatrix(c.projMatrix,r,i.paint.get("fill-translate"),i.paint.get("fill-translate-anchor")),d,0,1,0);l.draw(e,n.TRIANGLES,o,s,Hr.disabled,Yr.disabled,p,i.id,u.vertexBuffer,u.indexBuffer,u.depthSegments,i.paint,e.transform.zoom)}}};class rc{constructor(t,i,r,n,o){this.context=new Qs(t,i),this.transform=r,this._tileTextures={},this.frameCopies=[],this.loadTimeStamps=[],this._debugParams={averageFPS:0,fpsHistory:[],fpsWindow:30,dt:0,timeStamp:e.o.now(),continousRedraw:!1,enabledLayers:{},buildingsShowNormals:!1,buildingsDrawGroundAO:!0,buildingsDrawShadowPass:!0,buildingsDrawTranslucentPass:!0,showTerrainProxyTiles:!1,terrainSortTilesHiZFirst:!0,terrainDisableRenderCache:!1,forceEnablePrecipitation:!1,overrideSnowParams:!1,snowParamsOverride:null,snowRevealParamsOverride:null,snowVignetteParamsOverride:null,overrideRainParams:!1,rainParamsOverride:null,rainRevealParamsOverride:null,rainVignetteParamsOverride:null,overrideStarsParams:!1,starsParamsOverride:null,show3DModelFootprints:!1,showElevationIdDebug:!1,lodSwitchDistance:3e3},this.occlusionParams=new Kl,this.setup(),this.numSublayers=Ri.maxUnderzooming+Ri.maxOverzooming+1,this.depthEpsilon=1/Math.pow(2,16),this.deferredRenderGpuTimeQueries=[],this.gpuTimers={},this.frameCounter=0,this._shadowCullCache=null,this._backgroundTiles={},this.conflationActive=!1,this.replacementSource=new e.eJ,this.longestCutoffRange=0,this.minCutoffZoom=0,this._fogVisible=!1,this._cachedTileFogOpacities={},this._shadowRenderer=new dn(this),this._wireframeDebugCache=new Jl,this.renderDefaultNorthPole=!0,this.renderDefaultSouthPole=!0,this.layersWithOcclusionOpacity=[];const s=new e.q({width:1,height:1},Uint8Array.of(0,0,0,0));this.emptyDepthTexture=new e.T(this.context,s,t.RGBA8),this._clippingActiveLastFrame=!1,this.scaleFactor=n,this.maxFrontCutoffRawStart=0,this.worldview=o,this._forceEmissiveMode=!1,this.emissiveMode="constant"}updateTerrain(e,t){const i=!!e&&!!e.terrain&&this.transform.projection.supportsTerrain;if(!(i||this._terrain&&this._terrain.enabled))return;this._terrain||(this._terrain=new ds(this,e));const r=this._terrain;this.transform.elevation=i?r:null,r.update(e,this.transform,t),this.transform.elevation&&!r.enabled&&(this.transform.elevation=null)}_updateFog(e){const t=e.fog;if(!t||"globe"===this.transform.projection.name||t.getOpacity(this.transform.pitch)<1||t.properties.get("horizon-blend")<.03)return void(this.transform.fogCullDistSq=null);const[i,r]=t.getRangeForProjection();if(i>r)return void(this.transform.fogCullDistSq=null);const n=i+.78*(r-i);this.transform.fogCullDistSq=n*n}get terrain(){return this.transform._terrainEnabled()&&this._terrain&&this._terrain.enabled||this._forceTerrainMode?this._terrain:null}get forceTerrainMode(){return this._forceTerrainMode}set forceTerrainMode(e){e&&!this._terrain&&(this._terrain=new ds(this,this.style)),this._forceTerrainMode=e}get shadowRenderer(){return this._shadowRenderer&&this._shadowRenderer.enabled?this._shadowRenderer:null}get wireframeDebugCache(){return this._wireframeDebugCache}resize(t,i){if(this.width=t*e.o.devicePixelRatio,this.height=i*e.o.devicePixelRatio,this.context.viewport.set([0,0,this.width,this.height]),this.style)for(const e of this.style.order)this.style._mergedLayers[e].resize()}setup(){const t=this.context,i=new e.dE;i.emplaceBack(0,0),i.emplaceBack(e.ak,0),i.emplaceBack(0,e.ak),i.emplaceBack(e.ak,e.ak),this.tileExtentBuffer=t.createVertexBuffer(i,e.dA.members),this.tileExtentSegments=e.dB.simpleSegment(0,0,4,2);const r=new e.dE;r.emplaceBack(0,0),r.emplaceBack(e.ak,0),r.emplaceBack(0,e.ak),r.emplaceBack(e.ak,e.ak),this.debugBuffer=t.createVertexBuffer(r,e.dA.members),this.debugSegments=e.dB.simpleSegment(0,0,4,5);const n=new e.dE;n.emplaceBack(-1,-1),n.emplaceBack(1,-1),n.emplaceBack(-1,1),n.emplaceBack(1,1),this.viewportBuffer=t.createVertexBuffer(n,e.dA.members),this.viewportSegments=e.dB.simpleSegment(0,0,4,2);const o=new e.eK;o.emplaceBack(0,0,0,0),o.emplaceBack(e.ak,0,e.ak,0),o.emplaceBack(0,e.ak,0,e.ak),o.emplaceBack(e.ak,e.ak,e.ak,e.ak),this.mercatorBoundsBuffer=t.createVertexBuffer(o,e.eL.members),this.mercatorBoundsSegments=e.dB.simpleSegment(0,0,4,2);const s=new e.dF;s.emplaceBack(0,1,2),s.emplaceBack(2,1,3),this.quadTriangleIndexBuffer=t.createIndexBuffer(s);const a=new e.eM;for(const e of[0,1,3,2,0])a.emplaceBack(e);this.debugIndexBuffer=t.createIndexBuffer(a),this.emptyTexture=new e.T(t,new e.q({width:1,height:1},Uint8Array.of(0,0,0,0)),t.gl.RGBA8),this.identityMat=e.bd();const l=this.context.gl;this.stencilClearMode=new Zr({func:l.ALWAYS,mask:0},0,255,l.ZERO,l.ZERO,l.ZERO),this.loadTimeStamps.push(performance.now())}getMercatorTileBoundsBuffers(){return{tileBoundsBuffer:this.mercatorBoundsBuffer,tileBoundsIndexBuffer:this.quadTriangleIndexBuffer,tileBoundsSegments:this.mercatorBoundsSegments}}getTileBoundsBuffers(e){return e._makeTileBoundsBuffers(this.context,this.transform.projection),e._tileBoundsBuffer?{tileBoundsBuffer:e._tileBoundsBuffer,tileBoundsIndexBuffer:e._tileBoundsIndexBuffer,tileBoundsSegments:e._tileBoundsSegments}:this.getMercatorTileBoundsBuffers()}clearStencil(){const e=this.context.gl;this.nextStencilID=1,this.currentStencilSource=void 0,this._tileClippingMaskIDs={},this.getOrCreateProgram("clippingMask").draw(this,e.TRIANGLES,$r.disabled,this.stencilClearMode,Hr.disabled,Yr.disabled,as(this.identityMat),"$clipping",this.viewportBuffer,this.quadTriangleIndexBuffer,this.viewportSegments)}resetStencilClippingMasks(){this.terrain||(this.currentStencilSource=void 0,this._tileClippingMaskIDs={})}_renderTileClippingMasks(e,t,i){if(!t||this.currentStencilSource===t.id||!e.isTileClipped()||!i||0===i.length)return;if(this._tileClippingMaskIDs&&!this.terrain){let e=!1;for(const t of i)if(void 0===this._tileClippingMaskIDs[t.key]){e=!0;break}if(!e)return}this.currentStencilSource=t.id;const r=this.context,n=r.gl;this.nextStencilID+i.length>256&&this.clearStencil(),r.setColorMode(Hr.disabled),r.setDepthMode($r.disabled);const o=this.getOrCreateProgram("clippingMask");this._tileClippingMaskIDs={};for(const s of i){const e=t.getTile(s),i=this._tileClippingMaskIDs[s.key]=this.nextStencilID++,{tileBoundsBuffer:r,tileBoundsIndexBuffer:a,tileBoundsSegments:l}=this.getTileBoundsBuffers(e);o.draw(this,n.TRIANGLES,$r.disabled,new Zr({func:n.ALWAYS,mask:0},i,255,n.KEEP,n.KEEP,n.REPLACE),Hr.disabled,Yr.disabled,as(s.projMatrix),"$clipping",r,a,l)}}stencilModeFor3D(){this.currentStencilSource=void 0,this.nextStencilID+1>256&&this.clearStencil();const e=this.nextStencilID++,t=this.context.gl;return new Zr({func:t.NOTEQUAL,mask:255},e,255,t.KEEP,t.KEEP,t.REPLACE)}stencilModeForClipping(e){if(this.terrain)return this.terrain.stencilModeForRTTOverlap(e);const t=this.context.gl;return new Zr({func:t.EQUAL,mask:255},this._tileClippingMaskIDs[e.key],0,t.KEEP,t.KEEP,t.REPLACE)}stencilConfigForOverlap(e){const t=this.context.gl,i=e.sort((e,t)=>t.overscaledZ-e.overscaledZ),r=i.at(-1).overscaledZ,n=i[0].overscaledZ-r+1;if(n>1){this.currentStencilSource=void 0,this.nextStencilID+n>256&&this.clearStencil();const e={};for(let i=0;i<n;i++)e[i+r]=new Zr({func:t.GEQUAL,mask:255},i+this.nextStencilID,255,t.KEEP,t.KEEP,t.REPLACE);return this.nextStencilID+=n,[e,i]}return[{[r]:Zr.disabled},i]}colorModeForRenderPass(){const t=this.context.gl;if(this._showOverdrawInspector){const i=1/8;return new Hr([t.CONSTANT_COLOR,t.ONE,t.CONSTANT_COLOR,t.ONE],new e.C(i,i,i,0),[!0,!0,!0,!0])}return"opaque"===this.renderPass?Hr.unblended:Hr.alphaBlended}colorModeForDrapableLayerRenderPass(t){const i=this.context.gl;return(()=>this.style&&this.style.enable3dLights()&&this.terrain&&this.terrain.renderingToTexture)()&&"translucent"===this.renderPass?null!=t&&"mrt-fallback"!==this.emissiveMode||"constant"===this.emissiveMode?new Hr([i.ONE,i.ONE_MINUS_SRC_ALPHA,i.CONSTANT_ALPHA,i.ONE_MINUS_SRC_ALPHA],new e.C(0,0,0,null!=t?t:0),[!0,!0,!0,!0]):"dual-source-blending"===this.emissiveMode?new Hr([i.ONE,i.ONE_MINUS_SRC_ALPHA,this.context.extBlendFuncExtended.SRC1_ALPHA_WEBGL,i.ONE_MINUS_SRC_ALPHA],e.C.transparent,[!0,!0,!0,!0]):this.colorModeForRenderPass():this.colorModeForRenderPass()}depthModeForSublayer(e,t,i,r=!1){if(this.depthOcclusion)return new $r(this.context.gl.GREATER,$r.ReadOnly,this.depthRangeFor3D);if(!this.opaquePassEnabledForLayer()&&!r)return $r.disabled;const n=1-((1+this.currentLayer)*this.numSublayers+e)*this.depthEpsilon;return new $r(i||this.context.gl.LEQUAL,t,[n,n])}opaquePassEnabledForLayer(){return this.currentLayer<this.opaquePassCutoff}blitDepth(){const t=this.context.gl,i=Math.ceil(this.width),r=Math.ceil(this.height),n=this.context.bindFramebuffer.get(),o=t.getParameter(t.TEXTURE_BINDING_2D);this.depthFBO&&this.depthFBO.width===i&&this.depthFBO.height===r||(this.depthFBO&&(this.depthFBO.destroy(),this.depthFBO=void 0,this.depthTexture=void 0),0!==i&&0!==r&&(this.depthFBO=new Ks(this.context,i,r,0,"texture"),this.depthTexture=new e.T(this.context,{width:i,height:r,data:null},t.DEPTH24_STENCIL8),this.depthFBO.depthAttachment.set(this.depthTexture.texture))),this.context.bindFramebuffer.set(n),t.bindTexture(t.TEXTURE_2D,o),this.depthFBO&&(t.bindFramebuffer(t.READ_FRAMEBUFFER,null),t.bindFramebuffer(t.DRAW_FRAMEBUFFER,this.depthFBO.framebuffer),t.blitFramebuffer(0,0,i,r,0,0,i,r,t.DEPTH_BUFFER_BIT,t.NEAREST),t.bindFramebuffer(t.FRAMEBUFFER,this.context.bindFramebuffer.current))}render(t,i){this.context.sweepPendingPrograms(),this._wireframeDebugCache.update(this.frameCounter),this.style=t,this.options=i;const r=this.style._mergedLayers,n=!(!this.terrain||!this.terrain.enabled),o=()=>this.style._getOrder(n);let s=o(),a=!1,l=!1,c=null,h=0,u=!1;for(const e of s){const t=r[e];"none"!==t.visibility&&("circle"===t.type?a=!0:"building"===t.type?(c=t,++h):"symbol"===t.type&&(t.hasOcclusionOpacityProperties?l=!0:a=!0))}this.updateEmissiveMode();let d=s.map(e=>r[e]);const p=this.style._mergedSourceCaches;this.imageManager=t.imageManager,this.modelManager=t.modelManager,this.symbolFadeChange=t.placement.symbolFadeChange(e.o.now()),this.imageManager.beginFrame();for(const e in p){const t=p[e];t.used&&(t.prepare(this.context),t.getSource().usedInConflation&&++h)}let f=!1;for(const e of d)e.isHidden(this.transform.zoom)||("clip"===e.type&&(f=!0),this.prepareLayer(e));const m={},_={},g={},y={},x={};for(const e in p){const t=p[e];m[e]=t.getVisibleCoordinates(),_[e]=m[e].slice().reverse(),g[e]=t.getVisibleCoordinates(!0).reverse(),y[e]=t.getShadowCasterCoordinates(),x[e]=t.sortCoordinatesByDistance(m[e])}const v=e=>{const t=this.style.getLayerSourceCache(e);return t&&t.used?t.getSource():null};if(h||f||this._clippingActiveLastFrame){const t=[],i=[];let r=0;for(const e of d)this.isSourceForClippingOrConflation(e,v(e))&&(t.push(e),i.push(r)),r++;if(t&&(f||t.length>1)||this._clippingActiveLastFrame){f=!1;const r=[];for(let n=0;n<t.length;n++){const o=t[n],s=i[n],a=this.style.getLayerSourceCache(o);if(!a||!a.used||!a.getSource().usedInConflation&&"clip"!==o.type&&"building"!==o.type)continue;let l=e.eN,c=e.bE.None;const h=[];let u=!0;if("building"===o.type)l=e.eP;else if("clip"===o.type)if(l=s,o.isHidden(this.transform.zoom))u=!1;else{if(!o.layout){u=!1;continue}for(const t of o.layout.get("clip-layer-types"))c|="model"===t?e.bE.Model:"symbol"===t?e.bE.Symbol:e.bE.FillExtrusion;for(const t of o.layout.get("clip-layer-scope"))h.push(e.t(t,o.scope));f=!0}u&&r.push({layer:o.fqid,cache:a,order:l,clipMask:c,clipScope:h})}this.replacementSource.setSources(r),u=!0}}this._clippingActiveLastFrame=f,u||this.replacementSource.clear(),this.conflationActive=u,this.minCutoffZoom=0,this.longestCutoffRange=0,this.maxFrontCutoffRawStart=0,this.opaquePassCutoff=1/0,this._lastOcclusionLayer=-1,this.layersWithOcclusionOpacity=[];for(let e=0;e<d.length;e++){const t=d[e];if("none"===t.visibility)continue;const i=t.cutoffRange();if(this.longestCutoffRange=Math.max(i,this.longestCutoffRange),i>0){const e=v(t);e&&(this.minCutoffZoom=Math.max(e.minzoom,this.minCutoffZoom)),t.minzoom&&(this.minCutoffZoom=Math.max(t.minzoom,this.minCutoffZoom))}t.is3D(n)&&(this.opaquePassCutoff===1/0&&(this.opaquePassCutoff=e),this._lastOcclusionLayer=e)}const b=this.style&&this.style.fog;b?(this._fogVisible=0!==b.getOpacity(this.transform.pitch),this._fogVisible&&"globe"!==this.transform.projection.name&&(this._fogVisible=b.isVisibleOnFrustum(this.transform.cameraFrustum))):this._fogVisible=!1,this._cachedTileFogOpacities={},this.terrain&&(this.terrain.updateTileBinding(g),this.opaquePassCutoff=0,s=o(),d=s.map(e=>r[e]));const w=this._shadowRenderer;if(w){w.updateShadowParameters(this.transform,this.style.directionalLight);for(const e in p)for(const t of m[e]){let e={min:0,max:0};this.terrain&&(e=this.terrain.getMinMaxForTile(t)||e),w.addShadowReceiver(t.toUnwrapped(),e.min,e.max)}}"globe"!==this.transform.projection.name||this.globeSharedBuffers||(this.globeSharedBuffers=new e.eO(this.context)),this.style.fog&&this.transform.projection.supportsFog?(this._atmosphere||(this._atmosphere=new Sl),this._atmosphere.update(this)):this._atmosphere&&(this._atmosphere.destroy(),this._atmosphere=void 0);let T=!(!this.style||!this.style.snow),S=!(!this.style||!this.style.rain);if(T&&!this._snow&&il.Snow&&(this._snow=new il.Snow),!T&&this._snow&&(this._snow.destroy(),delete this._snow),S&&!this._rain&&il.Rain&&(this._rain=new il.Rain),!S&&this._rain&&(this._rain.destroy(),delete this._rain),this._snow&&this._snow.update(this),this._rain&&this._rain.update(this),c){this.buildingTileBorderManager||(this.buildingTileBorderManager=new Il);const e=this.style.getLayerSourceCache(c);this.buildingTileBorderManager.updateBorders(e,c)}if(!Q.has(this.context.gl))return;this.renderPass="offscreen";for(const e of d){const i=t.getLayerSourceCache(e);if(!e.hasOffscreenPass()||e.isHidden(this.transform.zoom))continue;const r=i?_[i.id]:void 0;("custom"===e.type||"raster"===e.type||"raster-particle"===e.type||e.isSky()||r&&r.length)&&this.renderLayer(this,i,e,r)}this.depthRangeFor3D=[0,1-(d.length+2)*this.numSublayers*this.depthEpsilon],this._shadowRenderer&&(this.renderPass="shadow",this._shadowRenderer.drawShadowPass(this.style,y)),this.context.bindFramebuffer.set(null),this.context.viewport.set([0,0,this.width,this.height]);const I="globe"===this.transform.projection.name||this.transform.isHorizonVisible(),E=(()=>{if(i.showOverdrawInspector)return e.C.black;const t=this.style.fog;if(t&&this.transform.projection.supportsFog){const i=this.style.getLut(t.scope);if(!I){const r="none"===t.properties.get("color-use-theme"),n=t.properties.get("color").toNonPremultipliedRenderColor(r?null:i).toArray01();return new e.C(...n)}if(I){const r="none"===t.properties.get("space-color-use-theme"),n=t.properties.get("space-color").toNonPremultipliedRenderColor(r?null:i).toArray01();return new e.C(...n)}}return e.C.transparent})();if(this.context.clear({color:E,depth:1}),this.clearStencil(),this._showOverdrawInspector=i.showOverdrawInspector,this.renderPass="opaque",this.style.fog&&this.transform.projection.supportsFog&&this._atmosphere&&!this._showOverdrawInspector&&I&&this._atmosphere.drawStars(this,this.style.fog),!this.terrain)for(this.currentLayer=s.length-1;this.currentLayer>=0;this.currentLayer--){const e=d[this.currentLayer],i=t.getLayerSourceCache(e);if(e.isSky())continue;const r=i?(e.is3D(n)?x:_)[i.id]:void 0;this._renderTileClippingMasks(e,i,r),this.renderLayer(this,i,e,r)}if(this.style.fog&&this.transform.projection.supportsFog&&this._atmosphere&&!this._showOverdrawInspector&&I&&this._atmosphere.drawAtmosphereGlow(this,this.style.fog),this.renderPass="sky",(!this._atmosphere||e.ai(this.transform.zoom)>0)&&("globe"===this.transform.projection.name||this.transform.isHorizonVisible()))for(this.currentLayer=0;this.currentLayer<s.length;this.currentLayer++){const e=d[this.currentLayer],i=t.getLayerSourceCache(e);e.isSky()&&this.renderLayer(this,i,e,i?_[i.id]:void 0)}function A(e,t){let i;return t&&(i=("symbol"===e.type?g:e.is3D(n)?x:_)[t.id]),i}if(this.renderPass="translucent","globe"===this.transform.projection.name){for(this.renderElevatedRasterBackface=!0,this.currentLayer=0;this.currentLayer<s.length;){const e=d[this.currentLayer];if("raster"===e.type||"raster-particle"===e.type){const i=t.getLayerSourceCache(e);this.renderLayer(this,i,e,A(e,i))}++this.currentLayer}this.renderElevatedRasterBackface=!1}this.currentLayer=0,this.firstLightBeamLayer=Number.MAX_SAFE_INTEGER;const M=w?w.getGroundShadowLayerIndex():-1;let C=!1,P=-1;for(let e=0;e<s.length;++e){const t=d[e];t.isHidden(this.transform.zoom)||t.is3D(n)&&(P=e)}l&&-1===P&&(a=!0);let D=!1;for(;this.currentLayer<s.length;){const e=d[this.currentLayer],i=t.getLayerSourceCache(e);if(e.isSky())++this.currentLayer;else if(this.terrain&&this.style.isLayerDraped(e)){if(e.isHidden(this.transform.zoom)){++this.currentLayer;continue}this.currentLayer=this.terrain.renderBatch(this.currentLayer),this._lastOcclusionLayer=Math.max(this.currentLayer,this._lastOcclusionLayer)}else{if(!D&&e.is3D(n)&&!n){const e=this.currentLayer,t=e=>{for(this.currentLayer=0;this.currentLayer<d.length;this.currentLayer++){const t=d[this.currentLayer];if(tc[t.type]){const i=this.style.getLayerSourceCache(t);tc[t.type](this,i,t,A(t,i),e)}}};t("initialize"),t("reset"),this.currentLayer=e,D=!0}if(a&&!C&&this.terrain&&!this.transform.isOrthographic&&(C=!0,this.blitDepth()),l&&-1!==P&&this.currentLayer===P+1&&!this.transform.isOrthographic&&this.blitDepth(),this.terrain||this._renderTileClippingMasks(e,i,i?m[i.id]:void 0),this.renderLayer(this,i,e,A(e,i)),!this.terrain&&w&&this.currentLayer===M){{this.clearStencil(),this.resetStencilClippingMasks();const e=this.currentLayer;for(this.currentLayer=0;this.currentLayer<d.length;this.currentLayer++){const e=d[this.currentLayer];if(ic[e.type]){const t=this.style.getLayerSourceCache(e);ic[e.type](this,t,e,A(e,t))}}this.currentLayer=e}if(w.drawGroundShadows(),this.firstLightBeamLayer<=this.currentLayer){const e=this.currentLayer;for(this.renderPass="light-beam",this.currentLayer=this.firstLightBeamLayer;this.currentLayer<=e;this.currentLayer++){const e=d[this.currentLayer];if(!e.hasLightBeamPass())continue;const i=t.getLayerSourceCache(e);this.renderLayer(this,i,e,i?_[i.id]:void 0)}this.currentLayer=e,this.renderPass="translucent"}}if(this.currentLayer>=this._lastOcclusionLayer&&this.layersWithOcclusionOpacity.length>0){const e=this.currentLayer;this.depthOcclusion=!0;for(const i of this.layersWithOcclusionOpacity){this.currentLayer=i;const e=d[this.currentLayer],r=t.getLayerSourceCache(e),n=r?_[r.id]:void 0;this.terrain||this._renderTileClippingMasks(e,r,r?m[r.id]:void 0),this.renderLayer(this,r,e,n)}this.depthOcclusion=!1,this.currentLayer=e,this.renderPass="translucent",this.layersWithOcclusionOpacity=[]}++this.currentLayer}}if(this.terrain&&this.terrain.postRender(),this._snow&&this._snow.draw(this),this._rain&&this._rain.draw(this),this.options.showTileBoundaries||this.options.showQueryGeometry||this.options.showTileAABBs){let i=null;d.forEach(e=>{const r=t.getLayerSourceCache(e);r&&!e.isHidden(this.transform.zoom)&&r.getVisibleCoordinates().length&&(!i||i.getSource().maxzoom<r.getSource().maxzoom)&&(i=r)}),i&&this.options.showTileBoundaries&&function(e,t,i,r,n,o){for(let s=0;s<i.length;s++)pl(e,t,i[s],r,0,0,o)}(this,i,i.getVisibleCoordinates(),e.C.red,0,this.options.showParseStatus)}this.options.showPadding&&function(e){const t=e.transform.padding;fl(e,e.transform.height-(t.top||0),3,ll),fl(e,t.bottom||0,3,cl),ml(e,t.left||0,3,hl),ml(e,e.transform.width-(t.right||0),3,ul);const i=e.transform.centerPoint;!function(e,t,i,r){_l(e,t-1,i-10,2,20,r),_l(e,t-10,i-1,20,2,r)}(e,i.x,e.transform.height-i.y,dl)}(this),this.context.setDefault(),this.frameCounter=(this.frameCounter+1)%Number.MAX_SAFE_INTEGER,this.tileLoaded&&this.options.speedIndexTiming&&(this.loadTimeStamps.push(performance.now()),this.saveCanvasCopy()),u||(this.conflationActive=!1)}prepareLayer(e){this.gpuTimingStart(e);const{unsupportedLayers:t}=this.transform.projection,i=!t||!t.includes(e.type);if(ec[e.type]&&(i||this.terrain&&"custom"===e.type)){const t=this.style.getLayerSourceCache(e);ec[e.type](e,t,this)}this.gpuTimingEnd()}renderLayer(e,t,i,r){i.isHidden(this.transform.zoom)||("background"===i.type||"sky"===i.type||"custom"===i.type||"model"===i.type||"raster"===i.type||"raster-particle"===i.type||r&&r.length)&&(this.id=i.id,this.gpuTimingStart(i),(!e.transform.projection.unsupportedLayers||!e.transform.projection.unsupportedLayers.includes(i.type)||e.terrain&&"custom"===i.type)&&"clip"!==i.type&&"slot"!==i.type&&Ql[i.type]&&Ql[i.type](e,t,i,r,this.style.placement.variableOffsets,this.options.isInitialLoad),Ql[i.type]||async function(){await async function(){return Promise.resolve()}(),Object.assign(Ql,{building:il.drawBuilding,"raster-particle":il.drawRasterParticle}),Object.assign(ec,{"raster-particle":il.prepareRasterParticle})}(),this.gpuTimingEnd())}gpuTimingStart(e){if(!this.options.gpuTiming)return;const t=this.context.extTimerQuery,i=this.context.gl;let r=this.gpuTimers[e.id];r||(r=this.gpuTimers[e.id]={calls:0,cpuTime:0,query:i.createQuery()}),r.calls++,i.beginQuery(t.TIME_ELAPSED_EXT,r.query)}gpuTimingDeferredRenderStart(){if(this.options.gpuTimingDeferredRender){const e=this.context.extTimerQuery,t=this.context.gl,i=t.createQuery();this.deferredRenderGpuTimeQueries.push(i),t.beginQuery(e.TIME_ELAPSED_EXT,i)}}gpuTimingDeferredRenderEnd(){this.options.gpuTimingDeferredRender&&this.context.gl.endQuery(this.context.extTimerQuery.TIME_ELAPSED_EXT)}gpuTimingEnd(){this.options.gpuTiming&&this.context.gl.endQuery(this.context.extTimerQuery.TIME_ELAPSED_EXT)}collectGpuTimers(){const e=this.gpuTimers;return this.gpuTimers={},e}collectDeferredRenderGpuQueries(){const e=this.deferredRenderGpuTimeQueries;return this.deferredRenderGpuTimeQueries=[],e}queryGpuTimers(e){const t={};for(const i in e){const r=e[i],n=this.context.extTimerQuery,o=n.getQueryParameter(r.query,this.context.gl.QUERY_RESULT)/1e6;n.deleteQueryEXT(r.query),t[i]=o}return t}queryGpuTimeDeferredRender(e){if(!this.options.gpuTimingDeferredRender)return 0;const t=this.context.gl;let i=0;for(const r of e)i+=t.getQueryParameter(r,t.QUERY_RESULT)/1e6,t.deleteQuery(r);return i}translatePosMatrix(t,i,r,n,o){if(!r[0]&&!r[1])return t;const s=o?"map"===n?this.transform.angle:0:"viewport"===n?-this.transform.angle:0;if(s){const e=Math.sin(s),t=Math.cos(s);r=[r[0]*t-r[1]*e,r[0]*e+r[1]*t]}const a=[o?r[0]:e.az(i,r[0],this.transform.zoom),o?r[1]:e.az(i,r[1],this.transform.zoom),0],l=new Float32Array(16);return e.bB(l,t,a),l}saveTileTexture(e){if(e.context!==this.context)return;const t=e.size[0],i=this._tileTextures[t];i?i.push(e):this._tileTextures[t]=[e]}getTileTexture(e){const t=this._tileTextures[e];return t&&t.length>0?t.pop():null}terrainRenderModeElevated(){return this.style&&!!this.style.getTerrain()&&!!this.terrain&&!this.terrain.renderingToTexture||this.forceTerrainMode}linearFloatFilteringSupported(){return null!=this.context.extTextureFloatLinear}currentGlobalDefines(e,t,i,r,n){const o=void 0===i?this.terrain&&this.terrain.renderingToTexture:i,s=void 0===r?this.terrainRenderModeElevated():r,a=void 0===n?"globe"===this.transform.projection.name:n,l=[];return this.style&&this.style.enable3dLights()&&("globeRaster"===e||"terrainRaster"===e?(l.push("LIGHTING_3D_MODE"),l.push("LIGHTING_3D_ALPHA_EMISSIVENESS")):o||l.push("LIGHTING_3D_MODE")),s&&(l.push("TERRAIN"),this.linearFloatFilteringSupported()&&l.push("TERRAIN_DEM_FLOAT_FORMAT")),a&&l.push("GLOBE"),!this._fogVisible||o||void 0!==t&&!t||l.push("FOG"),o&&l.push("RENDER_TO_TEXTURE"),this._showOverdrawInspector&&l.push("OVERDRAW_INSPECTOR"),l}getOrCreateProgram(e,t){this.cache=this.cache||{};const{defines:i,config:r,overrideFog:n,overrideRtt:o,overrideTerrain:s,overrideGlobe:a,precompiled:l}=t||{},c=this.currentGlobalDefines(e,n,o,s,a).concat(i||[]),h=this.getShaderSource(e),u=Ws[e]||il.programUniforms[e],d=_s.cacheKey(h,e,c,r);return this.cache[d]||(this.cache[d]=new _s(this.context,e,h,r,u,c,l)),this.cache[d]}getShaderSource(e){return ao[e]||il.shaders&&il.shaders[e]}setCustomLayerDefaults(){this.context.unbindVAO(),this.context.cullFace.setDefault(),this.context.frontFace.setDefault(),this.context.cullFaceSide.setDefault(),this.context.activeTexture.setDefault(),this.context.pixelStoreUnpack.setDefault(),this.context.pixelStoreUnpackPremultiplyAlpha.setDefault(),this.context.pixelStoreUnpackFlipY.setDefault()}setBaseState(){const e=this.context.gl;this.context.cullFace.set(!1),this.context.viewport.set([0,0,this.width,this.height]),this.context.blendEquation.set(e.FUNC_ADD)}initDebugOverlayCanvas(){this.debugOverlayCanvas??(this.debugOverlayCanvas=document.createElement("canvas"),this.debugOverlayCanvas.width=512,this.debugOverlayCanvas.height=512,this.debugOverlayTexture=new e.T(this.context,this.debugOverlayCanvas,this.context.gl.RGBA8))}destroy(){this._terrain&&this._terrain.destroy(),this._atmosphere&&(this._atmosphere.destroy(),this._atmosphere=void 0),this.globeSharedBuffers&&this.globeSharedBuffers.destroy(),this.emptyTexture.destroy(),this.debugOverlayTexture&&this.debugOverlayTexture.destroy(),this._wireframeDebugCache.destroy(),this.depthFBO&&(this.depthFBO.destroy(),this.depthFBO=void 0,this.depthTexture=void 0),this.emptyDepthTexture&&this.emptyDepthTexture.destroy()}prepareDrawTile(){this.terrain&&this.terrain.prepareDrawTile()}uploadCommonLightUniforms(t,i){if(this.style.enable3dLights()){const r=this.style.directionalLight,n=this.style.ambientLight;if(r&&n){const o=((t,i,r)=>{const n=t.properties.get("direction"),o="none"===t.properties.get("color-use-theme"),s=t.properties.get("color").toNonPremultipliedRenderColor(o?null:r.getLut(t.scope)).toArray01(),a=t.properties.get("intensity"),l="none"===i.properties.get("color-use-theme"),c=i.properties.get("color").toNonPremultipliedRenderColor(l?null:r.getLut(i.scope)).toArray01(),h=i.properties.get("intensity"),u=[n.x,n.y,n.z],d=e.dG(c,h),p=e.dG(s,a);return{u_lighting_ambient_color:d,u_lighting_directional_dir:u,u_lighting_directional_color:p,u_ground_radiance:ps(u,p,d)}})(r,n,this.style);i.setLightsUniformValues(t,o)}}}uploadCommonUniforms(t,i,r,n,o){if(this.uploadCommonLightUniforms(t,i),this.terrain&&this.terrain.renderingToTexture)return;const s=this.style.fog;if(s){const o=s.getOpacity(this.transform.pitch),a=((t,i,r,n,o,s,a,l,c,h,u,d)=>{const p=t.transform,f="none"===i.properties.get("color-use-theme"),m=i.properties.get("color").toNonPremultipliedRenderColor(f?null:t.style.getLut(i.scope)).toArray01();m[3]=n;const _=t.frameCounter/1e3%1,[g,y]=i.properties.get("vertical-range");return{u_fog_matrix:r?p.calculateFogTileMatrix(r):d||t.identityMat,u_fog_range:i.getRangeForProjection(),u_fog_color:m,u_fog_horizon_blend:i.properties.get("horizon-blend"),u_fog_vertical_limit:[Math.min(g,y),y],u_fog_temporal_offset:_,u_frustum_tl:o,u_frustum_tr:s,u_frustum_br:a,u_frustum_bl:l,u_globe_pos:c,u_globe_radius:h,u_viewport:u,u_globe_transition:e.ai(p.zoom),u_is_globe:+("globe"===p.projection.name)}})(this,s,r,o,this.transform.frustumCorners.TL,this.transform.frustumCorners.TR,this.transform.frustumCorners.BR,this.transform.frustumCorners.BL,this.transform.globeCenterInViewSpace,this.transform.globeRadius,[this.transform.width*e.o.devicePixelRatio,this.transform.height*e.o.devicePixelRatio],n);i.setFogUniformValues(t,a)}o&&i.setCutoffUniformValues(t,o.uniformValues)}setTileLoadedFlag(e){this.tileLoaded=e}saveCanvasCopy(){const e=this.canvasCopy();e&&(this.frameCopies.push(e),this.tileLoaded=!1)}canvasCopy(){const e=this.context.gl,t=e.createTexture();return e.bindTexture(e.TEXTURE_2D,t),e.copyTexImage2D(e.TEXTURE_2D,0,e.RGBA,0,0,e.drawingBufferWidth,e.drawingBufferHeight,0),t}getCanvasCopiesAndTimestamps(){return{canvasCopies:this.frameCopies,timeStamps:this.loadTimeStamps}}averageElevationNeedsEasing(){if(!this.transform._elevation)return!1;const e=this.style&&this.style.fog;return!!e&&0!==e.getOpacity(this.transform.pitch)}getBackgroundTiles(){const t=this._backgroundTiles,i=this._backgroundTiles={},r=this.transform.coveringTiles({tileSize:512});for(const n of r)i[n.key]=t[n.key]||new e.b3(n,512,this.transform.tileZoom,this,void 0,this.worldview);return i}clearBackgroundTiles(){this._backgroundTiles={}}isSourceForClippingOrConflation(e,t){return!(!e.is3D(!(!this.terrain||!this.terrain.enabled))||"clip"!==e.type&&"building"!==e.type&&(e.minzoom&&e.minzoom>this.transform.zoom||(this.style._clipLayerPresent||"building"!==e.sourceLayer&&"procedural_buildings"!==e.sourceLayer)&&(!t||"batched-model"!==t.type)))}isTileAffectedByFog(e){if(!this.style||!this.style.fog)return!1;if("globe"===this.transform.projection.name)return!0;let t=this._cachedTileFogOpacities[e.key];return t||(this._cachedTileFogOpacities[e.key]=t=this.style.fog.getOpacityForTile(e)),t[0]>=$t||t[1]>=$t}setupDepthForOcclusion(e,t,i){const r=this.context,n=r.gl,o=!!i;var s;i||(i={u_dem:2,u_dem_prev:4,u_dem_tl:[0,0],u_dem_tl_prev:[0,0],u_dem_scale:0,u_dem_scale_prev:0,u_dem_size:0,u_dem_lerp:1,u_depth:3,u_depth_size_inv:[0,0],u_depth_range_unpack:[0,1],u_occluder_half_size:16,u_occlusion_depth_offset:-1e-4,u_exaggeration:0}),r.activeTexture.set(n.TEXTURE3),e&&this.depthFBO&&this.depthTexture?(this.depthTexture.bind(n.NEAREST,n.CLAMP_TO_EDGE),i.u_depth_size_inv=[1/this.depthFBO.width,1/this.depthFBO.height],i.u_depth_range_unpack=[2/((s=this.depthRangeFor3D)[1]-s[0]),-1-2*s[0]/(s[1]-s[0])],i.u_occluder_half_size=.5*this.occlusionParams.occluderSize,i.u_occlusion_depth_offset=this.occlusionParams.depthOffset):this.emptyDepthTexture.bind(n.NEAREST,n.CLAMP_TO_EDGE),r.activeTexture.set(n.TEXTURE0),o||t.setTerrainUniformValues(r,i)}updateEmissiveMode(){if(this._forceEmissiveMode)return;const e=this.style.hasDataDrivenEmissiveStrength();this.emissiveMode=e?this.context.extBlendFuncExtended?"dual-source-blending":"mrt-fallback":"constant"}}function nc(e,t){let i=!1,r=null;const n=()=>{r=null,i&&(e(),r=setTimeout(n,t),i=!1)};return()=>(i=!0,r||n(),r)}const oc=/(#.+)?$/;class sc{constructor(t){this._hashName=t&&encodeURIComponent(t),e.b0(["_getCurrentHash","_onHashChange","_updateHash"],this),this._updateHash=nc(this._updateHashUnthrottled.bind(this),300)}addTo(e){return this._map=e,window.addEventListener("hashchange",this._onHashChange,!1),e.on("moveend",this._updateHash),this}remove(){return this._map?(this._map.off("moveend",this._updateHash),window.removeEventListener("hashchange",this._onHashChange,!1),clearTimeout(this._updateHash()),this._map=void 0,this):this}getHashString(){const e=this._map;if(!e)return"";const t=ac(e);if(this._hashName){const e=this._hashName;let i=!1;const r=location.hash.slice(1).split("&").map(r=>{const n=r.split("=")[0];return n===e?(i=!0,`${n}=${t}`):r}).filter(e=>e);return i||r.push(`${e}=${t}`),`#${r.join("&")}`}return`#${t}`}_getCurrentHash(){const e=location.hash.replace("#","");if(this._hashName){let t;return e.split("&").map(e=>e.split("=")).forEach(e=>{e[0]===this._hashName&&(t=e)}),(t&&t[1]||"").split("/")}return e.split("/")}_onHashChange(){const e=this._map;if(!e)return!1;const t=this._getCurrentHash();if(t.length>=3&&!t.some(e=>isNaN(Number(e)))){const i=e.dragRotate.isEnabled()&&e.touchZoomRotate.isEnabled()?+(t[3]||0):e.getBearing();return e.jumpTo({center:[+t[2],+t[1]],zoom:+t[0],bearing:i,pitch:+(t[4]||0)}),!0}return!1}_updateHashUnthrottled(){history.replaceState(history.state,"",location.href.replace(oc,this.getHashString()))}}function ac(e,t){const i=e.getCenter(),r=Math.round(100*e.getZoom())/100,n=Math.ceil((r*Math.LN2+Math.log(512/360/.5))/Math.LN10),o=Math.pow(10,n),s=Math.round(i.lng*o)/o,a=Math.round(i.lat*o)/o,l=e.getBearing(),c=e.getPitch();let h=t?`/${s}/${a}/${r}`:`${r}/${a}/${s}`;return(l||c)&&(h+="/"+Math.round(10*l)/10),c&&(h+=`/${Math.round(c)}`),h}const lc={linearity:.3,easing:e.eQ(0,0,.3,1)},cc=Object.assign({deceleration:2500,maxSpeed:1400},lc),hc=Object.assign({deceleration:20,maxSpeed:1400},lc),uc=Object.assign({deceleration:1e3,maxSpeed:360},lc),dc=Object.assign({deceleration:1e3,maxSpeed:90},lc);class pc{constructor(e){this._map=e,this.clear()}clear(){this._inertiaBuffer=[]}record(t){this._drainInertiaBuffer(),this._inertiaBuffer.push({time:e.o.now(),settings:t})}_drainInertiaBuffer(){const t=this._inertiaBuffer,i=e.o.now();for(;t.length>0&&i-t[0].time>160;)t.shift()}_onMoveEnd(t){if(this._map._prefersReducedMotion())return;if(this._drainInertiaBuffer(),this._inertiaBuffer.length<2)return;const i={zoom:0,bearing:0,pitch:0,pan:new e.P(0,0),pinchAround:void 0,around:void 0};for(const{settings:e}of this._inertiaBuffer)i.zoom+=e.zoomDelta||0,i.bearing+=e.bearingDelta||0,i.pitch+=e.pitchDelta||0,e.panDelta&&i.pan._add(e.panDelta),e.around&&(i.around=e.around),e.pinchAround&&(i.pinchAround=e.pinchAround);const r=this._inertiaBuffer.at(-1).time-this._inertiaBuffer[0].time,n={};if(i.pan.mag()){const e=mc(i.pan.mag(),r,Object.assign({},cc,t||{}));n.offset=i.pan.mult(e.amount/i.pan.mag()),n.center=this._map.transform.center,fc(n,e)}if(i.zoom){const e=mc(i.zoom,r,hc);n.zoom=this._map.transform.zoom+e.amount,fc(n,e)}if(i.bearing){const t=mc(i.bearing,r,uc);n.bearing=this._map.transform.bearing+e.aB(t.amount,-179,179),fc(n,t)}if(i.pitch){const e=mc(i.pitch,r,dc);n.pitch=this._map.transform.pitch+e.amount,fc(n,e)}if(n.zoom||n.bearing){const e=void 0===i.pinchAround?i.around:i.pinchAround;n.around=e?this._map.unproject(e):this._map.getCenter()}return this.clear(),n.noMoveStart=!0,n}}function fc(e,t){(!e.duration||e.duration<t.duration)&&(e.duration=t.duration,e.easing=t.easing)}function mc(t,i,r){const{maxSpeed:n,linearity:o,deceleration:s}=r,a=e.aB(t*o/(i/1e3),-n,n),l=Math.abs(a)/(s*o);return{easing:r.easing,duration:1e3*l,amount:a*(l/2)}}class _c extends e.z{preventDefault(){this._defaultPrevented=!0}get defaultPrevented(){return this._defaultPrevented}constructor(e,t,i,r={}){const n=x(t.getCanvasContainer(),i),o=t.unproject(n);super(e,Object.assign({point:n,lngLat:o,originalEvent:i},r)),this._defaultPrevented=!1,this.target=t}}class gc extends e.z{preventDefault(){this._defaultPrevented=!0}get defaultPrevented(){return this._defaultPrevented}constructor(t,i,r){const n="touchend"===t?r.changedTouches:r.touches,o=v(i.getCanvasContainer(),n),s=o.map(e=>i.unproject(e)),a=o.reduce((e,t,i,r)=>e.add(t.div(r.length)),new e.P(0,0));super(t,{points:o,point:a,lngLats:s,lngLat:i.unproject(a),originalEvent:r}),this._defaultPrevented=!1}}class yc extends e.z{preventDefault(){this._defaultPrevented=!0}get defaultPrevented(){return this._defaultPrevented}constructor(e,t){super("wheel",{originalEvent:t}),this._defaultPrevented=!1}}class xc{constructor(e,t){this._map=e,this._clickTolerance=t.clickTolerance}reset(){this._mousedownPos=void 0}wheel(e){return this._firePreventable(new yc(this._map,e))}mousedown(e,t){return this._mousedownPos=t,this._firePreventable(new _c(e.type,this._map,e))}mouseup(e){this._map.fire(new _c(e.type,this._map,e))}preclick(e){const t=new MouseEvent("preclick",e);this._map.fire(new _c(t.type,this._map,t))}click(e,t){this._mousedownPos&&this._mousedownPos.dist(t)>=this._clickTolerance||(this.preclick(e),this._map.fire(new _c(e.type,this._map,e)))}dblclick(e){return this._firePreventable(new _c(e.type,this._map,e))}mouseover(e){this._map.fire(new _c(e.type,this._map,e))}mouseout(e){this._map.fire(new _c(e.type,this._map,e))}touchstart(e){return this._firePreventable(new gc(e.type,this._map,e))}touchmove(e){this._map.fire(new gc(e.type,this._map,e))}touchend(e){this._map.fire(new gc(e.type,this._map,e))}touchcancel(e){this._map.fire(new gc(e.type,this._map,e))}_firePreventable(e){if(this._map.fire(e),e.defaultPrevented)return{}}isEnabled(){return!0}isActive(){return!1}enable(){}disable(){}}class vc{constructor(e){this._map=e}reset(){this._delayContextMenu=!1,this._contextMenuEvent=void 0}mousemove(e){this._map.fire(new _c(e.type,this._map,e))}mousedown(){this._delayContextMenu=!0}mouseup(){this._delayContextMenu=!1,this._contextMenuEvent&&(this._map.fire(new _c("contextmenu",this._map,this._contextMenuEvent)),delete this._contextMenuEvent)}contextmenu(e){this._delayContextMenu?this._contextMenuEvent=e:this._map.fire(new _c(e.type,this._map,e)),this._map.listens("contextmenu")&&e.preventDefault()}isEnabled(){return!0}isActive(){return!1}enable(){}disable(){}}class bc{constructor(e,t){this._map=e,this._el=e.getCanvasContainer(),this._container=e.getContainer(),this._clickTolerance=t.clickTolerance||1}isEnabled(){return!!this._enabled}isActive(){return!!this._active}enable(){this.isEnabled()||(this._enabled=!0)}disable(){this.isEnabled()&&(this._enabled=!1)}mousedown(e,t){this.isEnabled()&&e.shiftKey&&0===e.button&&(m(),this._startPos=this._lastPos=t,this._active=!0)}mousemoveWindow(e,t){if(!this._active)return;const i=t,r=this._startPos,n=this._lastPos;if(!r||!n||n.equals(i)||!this._box&&i.dist(r)<this._clickTolerance)return;this._lastPos=i,this._box||(this._box=h("div","mapboxgl-boxzoom",this._container),this._container.classList.add("mapboxgl-crosshair"),this._fireEvent("boxzoomstart",e));const o=Math.min(r.x,i.x),s=Math.max(r.x,i.x),a=Math.min(r.y,i.y),l=Math.max(r.y,i.y);this._map._requestDomTask(()=>{this._box&&(this._box.style.transform=`translate(${o}px,${a}px)`,this._box.style.width=s-o+"px",this._box.style.height=l-a+"px")})}mouseupWindow(t,i){if(!this._active)return;const r=this._startPos,n=i;if(r&&0===t.button){if(this.reset(),y(),r.x!==n.x||r.y!==n.y)return this._map.fire(new e.z("boxzoomend",{originalEvent:t})),{cameraAnimation:e=>e.fitScreenCoordinates(r,n,this._map.getBearing(),{linear:!1})};this._fireEvent("boxzoomcancel",t)}}keydown(e){this._active&&27===e.keyCode&&(this.reset(),this._fireEvent("boxzoomcancel",e))}blur(){this.reset()}reset(){this._active=!1,this._container.classList.remove("mapboxgl-crosshair"),this._box&&(this._box.remove(),this._box=null),_(),delete this._startPos,delete this._lastPos}_fireEvent(t,i){return this._map.fire(new e.z(t,{originalEvent:i}))}}function wc(e,t){const i={};for(let r=0;r<e.length;r++)i[e[r].identifier]=t[r];return i}class Tc{constructor(e){this.reset(),this.numTouches=e.numTouches}reset(){this.centroid=void 0,this.startTime=0,this.touches={},this.aborted=!1}touchstart(t,i,r){(this.centroid||r.length>this.numTouches)&&(this.aborted=!0),this.aborted||(0===this.startTime&&(this.startTime=t.timeStamp),r.length===this.numTouches&&(this.centroid=function(t){const i=new e.P(0,0);for(const e of t)i._add(e);return i.div(t.length)}(i),this.touches=wc(r,i)))}touchmove(e,t,i){if(this.aborted||!this.centroid)return;const r=wc(i,t);for(const n in this.touches){const e=r[n];(!e||e.dist(this.touches[n])>30)&&(this.aborted=!0)}}touchend(e,t,i){if((!this.centroid||e.timeStamp-this.startTime>500)&&(this.aborted=!0),0===i.length){const e=!this.aborted&&this.centroid;if(this.reset(),e)return e}}}class Sc{constructor(e){this.singleTap=new Tc(e),this.numTaps=e.numTaps,this.reset()}reset(){this.lastTime=1/0,this.lastTap=void 0,this.count=0,this.singleTap.reset()}touchstart(e,t,i){this.singleTap.touchstart(e,t,i)}touchmove(e,t,i){this.singleTap.touchmove(e,t,i)}touchend(e,t,i){const r=this.singleTap.touchend(e,t,i);if(r){const t=e.timeStamp-this.lastTime<500,i=!this.lastTap||this.lastTap.dist(r)<30;if(t&&i||this.reset(),this.count++,this.lastTime=e.timeStamp,this.lastTap=r,this.count===this.numTaps)return this.reset(),r}}}class Ic{constructor(){this._zoomIn=new Sc({numTouches:1,numTaps:2}),this._zoomOut=new Sc({numTouches:2,numTaps:1}),this.reset()}reset(){this._active=!1,this._zoomIn.reset(),this._zoomOut.reset()}touchstart(e,t,i){this._zoomIn.touchstart(e,t,i),this._zoomOut.touchstart(e,t,i)}touchmove(e,t,i){this._zoomIn.touchmove(e,t,i),this._zoomOut.touchmove(e,t,i)}touchend(e,t,i){const r=this._zoomIn.touchend(e,t,i),n=this._zoomOut.touchend(e,t,i);return r?(this._active=!0,e.preventDefault(),setTimeout(()=>this.reset(),0),{cameraAnimation:t=>t.easeTo({duration:300,zoom:t.getZoom()+1,around:t.unproject(r)},{originalEvent:e})}):n?(this._active=!0,e.preventDefault(),setTimeout(()=>this.reset(),0),{cameraAnimation:t=>t.easeTo({duration:300,zoom:t.getZoom()-1,around:t.unproject(n)},{originalEvent:e})}):void 0}touchcancel(){this.reset()}enable(){this._enabled=!0}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}}const Ec=0,Ac=2,Mc={[Ec]:1,[Ac]:2},Cc={Control:"ctrlKey",Alt:"altKey",Shift:"shiftKey",Meta:"metaKey"};class Pc{constructor(e){this.reset(),this._clickTolerance=e.clickTolerance||1}blur(){this.reset()}reset(){this._active=!1,this._moved=!1,this._lastPoint=void 0,this._eventButton=void 0}_correctButton(e,t){return!1}_move(e,t){return{}}mousedown(e,t){if(this._lastPoint)return;const i=b(e);this._correctButton(e,i)&&(this._lastPoint=t,this._eventButton=i)}mousemoveWindow(e,t){const i=this._lastPoint;if(i)if(e.preventDefault(),null!=this._eventButton&&function(e,t){const i=Mc[t];return void 0===e.buttons||(e.buttons&i)!==i}(e,this._eventButton))this.reset();else if(this._moved||!(t.dist(i)<this._clickTolerance))return this._moved=!0,this._lastPoint=t,this._move(i,t)}mouseupWindow(e){this._lastPoint&&b(e)===this._eventButton&&(this._moved&&y(),this.reset())}enable(){this._enabled=!0}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}}class Dc extends Pc{mousedown(e,t){super.mousedown(e,t),this._lastPoint&&(this._active=!0)}_correctButton(e,t){return 0===t&&!e.ctrlKey}_move(e,t){return{around:t,panDelta:t.sub(e)}}}class Rc extends Pc{constructor(e){super(e),this._pitchRotateKey=e.pitchRotateKey?Cc[e.pitchRotateKey]:void 0}_correctButton(e,t){return this._pitchRotateKey?0===t&&e[this._pitchRotateKey]:0===t&&e.ctrlKey||2===t}_move(e,t){const i=.8*(t.x-e.x);if(i)return this._active=!0,{bearingDelta:i}}contextmenu(e){this._pitchRotateKey||e.preventDefault()}}class zc extends Pc{constructor(e){super(e),this._pitchRotateKey=e.pitchRotateKey?Cc[e.pitchRotateKey]:void 0}_correctButton(e,t){return this._pitchRotateKey?0===t&&e[this._pitchRotateKey]:0===t&&e.ctrlKey||2===t}_move(e,t){const i=-.5*(t.y-e.y);if(i)return this._active=!0,{pitchDelta:i}}contextmenu(e){this._pitchRotateKey||e.preventDefault()}}class Lc{constructor(t,i){this._map=t,this._el=t.getCanvasContainer(),this._minTouches=1,this._clickTolerance=i.clickTolerance||1,this.reset(),e.b0(["_addTouchPanBlocker","_showTouchPanBlockerAlert"],this)}reset(){this._active=!1,this._touches={},this._sum=new e.P(0,0)}touchstart(e,t,i){return this._calculateTransform(e,t,i)}touchmove(t,i,r){if(this._active&&!(r.length<this._minTouches)){if(this._map._cooperativeGestures&&!this._map.isMoving()){if(1===r.length&&!e.eR())return void this._showTouchPanBlockerAlert();"hidden"!==this._alertContainer.style.visibility&&(this._alertContainer.style.visibility="hidden",clearTimeout(this._alertTimer))}return t.cancelable&&t.preventDefault(),this._calculateTransform(t,i,r)}}touchend(e,t,i){this._calculateTransform(e,t,i),this._active&&i.length<this._minTouches&&this.reset()}touchcancel(){this.reset()}_calculateTransform(t,i,r){r.length>0&&(this._active=!0);const n=wc(r,i),o=new e.P(0,0),s=new e.P(0,0);let a=0;for(const e in n){const t=n[e],i=this._touches[e];i&&(o._add(t),s._add(t.sub(i)),a++,n[e]=t)}if(this._touches=n,a<this._minTouches||!s.mag())return;const l=s.div(a);return this._sum._add(l),this._sum.mag()<this._clickTolerance?void 0:{around:o.div(a),panDelta:l}}enable(){this._enabled=!0,this._map._cooperativeGestures&&(this._addTouchPanBlocker(),this._el.classList.add("mapboxgl-touch-pan-blocker-override","mapboxgl-scrollable-page"))}disable(){this._enabled=!1,this._map._cooperativeGestures&&(clearTimeout(this._alertTimer),this._alertContainer.remove(),this._el.classList.remove("mapboxgl-touch-pan-blocker-override","mapboxgl-scrollable-page")),this.reset()}isEnabled(){return!!this._enabled}isActive(){return!!this._active}_addTouchPanBlocker(){this._map&&!this._alertContainer&&(this._alertContainer=h("div","mapboxgl-touch-pan-blocker",this._map._container),this._alertContainer.textContent=this._map._getUIString("TouchPanBlocker.Message"),this._alertContainer.style.fontSize=`${Math.max(10,Math.min(24,Math.floor(.05*this._el.clientWidth)))}px`)}_showTouchPanBlockerAlert(){this._alertContainer.style.visibility="visible",this._alertContainer.classList.add("mapboxgl-touch-pan-blocker-show"),this._alertContainer.setAttribute("role","alert"),clearTimeout(this._alertTimer),this._alertTimer=window.setTimeout(()=>{this._alertContainer.classList.remove("mapboxgl-touch-pan-blocker-show"),this._alertContainer.removeAttribute("role")},500)}}class Fc{constructor(){this.reset()}reset(){this._active=!1,this._firstTwoTouches=void 0}_start(e){}_move(e,t,i){return{}}touchstart(e,t,i){this._firstTwoTouches||i.length<2||(this._firstTwoTouches=[i[0].identifier,i[1].identifier],this._start([t[0],t[1]]))}touchmove(e,t,i){const r=this._firstTwoTouches;if(!r)return;e.preventDefault();const[n,o]=r,s=Oc(i,t,n),a=Oc(i,t,o);if(!s||!a)return;const l=this._aroundCenter?null:s.add(a).div(2);return this._move([s,a],l,e)}touchend(e,t,i){if(!this._firstTwoTouches)return;const[r,n]=this._firstTwoTouches,o=Oc(i,t,r),s=Oc(i,t,n);o&&s||(this._active&&y(),this.reset())}touchcancel(){this.reset()}enable(e){this._enabled=!0,this._aroundCenter=!!e&&"center"===e.around}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}}function Oc(e,t,i){for(let r=0;r<e.length;r++)if(e[r].identifier===i)return t[r]}function Bc(e,t){return Math.log2(e/t)}class kc extends Fc{reset(){super.reset(),this._distance=0,this._startDistance=0}_start(e){this._startDistance=this._distance=e[0].dist(e[1])}_move(e,t){const i=this._distance;if(this._distance=e[0].dist(e[1]),this._active||!(Math.abs(Bc(this._distance,this._startDistance))<.1))return this._active=!0,{zoomDelta:Bc(this._distance,i),pinchAround:t}}}function Nc(e,t){return 180*e.angleWith(t)/Math.PI}class Uc extends Fc{reset(){super.reset(),this._minDiameter=0,this._startVector=void 0,this._vector=void 0}_start(e){this._startVector=this._vector=e[0].sub(e[1]),this._minDiameter=e[0].dist(e[1])}_move(e,t){const i=this._vector;if(this._vector=e[0].sub(e[1]),i&&(this._active||!this._isBelowThreshold(this._vector)))return this._active=!0,{bearingDelta:Nc(this._vector,i),pinchAround:t}}_isBelowThreshold(e){this._minDiameter=Math.min(this._minDiameter,e.mag());const t=25/(Math.PI*this._minDiameter)*360,i=this._startVector;if(!i)return!1;const r=Nc(e,i);return Math.abs(r)<t}}function Vc(e){return Math.abs(e.y)>Math.abs(e.x)}class jc extends Fc{constructor(e){super(),this._map=e}reset(){super.reset(),this._valid=void 0,this._firstMove=void 0,this._lastPoints=void 0}_start(e){this._lastPoints=e,Vc(e[0].sub(e[1]))&&(this._valid=!1)}_move(t,i,r){const n=this._lastPoints;if(!n)return;const o=t[0].sub(n[0]),s=t[1].sub(n[1]);return this._map._cooperativeGestures&&!e.eR()&&r.touches.length<3||(this._valid=this.gestureBeginsVertically(o,s,r.timeStamp),!this._valid)?void 0:(this._lastPoints=t,this._active=!0,{pitchDelta:(o.y+s.y)/2*-.5})}gestureBeginsVertically(e,t,i){if(void 0!==this._valid)return this._valid;const r=e.mag()>=2,n=t.mag()>=2;if(!r&&!n)return;if(!r||!n)return this._firstMove??=i,i-this._firstMove<100&&void 0;const o=e.y>0==t.y>0;return Vc(e)&&Vc(t)&&o}}const Gc={panStep:100,bearingStep:15,pitchStep:10};class Hc{constructor(){const e=Gc;this._panStep=e.panStep,this._bearingStep=e.bearingStep,this._pitchStep=e.pitchStep,this._rotationDisabled=!1}blur(){this.reset()}reset(){this._active=!1}keydown(e){if(e.altKey||e.ctrlKey||e.metaKey)return;let t=0,i=0,r=0,n=0,o=0;switch(e.keyCode){case 61:case 107:case 171:case 187:t=1;break;case 189:case 109:case 173:t=-1;break;case 37:e.shiftKey?i=-1:(e.preventDefault(),n=-1);break;case 39:e.shiftKey?i=1:(e.preventDefault(),n=1);break;case 38:e.shiftKey?r=1:(e.preventDefault(),o=-1);break;case 40:e.shiftKey?r=-1:(e.preventDefault(),o=1);break;default:return}return this._rotationDisabled&&(i=0,r=0),{cameraAnimation:s=>{const a=s.getZoom();s.easeTo({duration:300,easeId:"keyboardHandler",easing:$c,zoom:t?Math.round(a)+t*(e.shiftKey?2:1):a,bearing:s.getBearing()+i*this._bearingStep,pitch:s.getPitch()+r*this._pitchStep,offset:[-n*this._panStep,-o*this._panStep],center:s.getCenter()},{originalEvent:e})}}}enable(){this._enabled=!0}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}disableRotation(){this._rotationDisabled=!0}enableRotation(){this._rotationDisabled=!1}}function $c(e){return e*(2-e)}const qc=4.000244140625,Zc=1/450,Wc=/(Mac|iPad)/i;class Xc{constructor(t,i){this._map=t,this._el=t.getCanvasContainer(),this._handler=i,this._delta=0,this._lastDelta=0,this._defaultZoomRate=.01,this._wheelZoomRate=Zc,e.b0(["_onTimeout","_addScrollZoomBlocker","_showBlockerAlert"],this)}setZoomRate(e){this._defaultZoomRate=e}setWheelZoomRate(e){this._wheelZoomRate=e}isEnabled(){return!!this._enabled}isActive(){return this._active||void 0!==this._finishTimeout}isZooming(){return!!this._zooming}enable(e){this.isEnabled()||(this._enabled=!0,this._aroundCenter=!!e&&"center"===e.around,this._map._cooperativeGestures&&this._addScrollZoomBlocker())}disable(){this.isEnabled()&&(this._enabled=!1,this._map._cooperativeGestures&&(clearTimeout(this._alertTimer),this._alertContainer.remove()))}wheel(t){if(!this.isEnabled())return;if(this._map._cooperativeGestures){if(!(t.ctrlKey||t.metaKey||this.isZooming()||e.eR()))return void this._showBlockerAlert();"hidden"!==this._alertContainer.style.visibility&&(this._alertContainer.style.visibility="hidden",clearTimeout(this._alertTimer))}let i=t.deltaMode===WheelEvent.DOM_DELTA_LINE?40*t.deltaY:t.deltaY;const r=e.o.now(),n=r-(this._lastWheelEventTime||0);this._lastWheelEventTime=r,0!==i&&i%qc===0?this._type="wheel":0!==i&&Math.abs(i)<4?this._type="trackpad":n>400?(this._type=null,this._lastValue=i,this._timeout=window.setTimeout(this._onTimeout,40,t)):this._type||(this._type=Math.abs(n*i)<200?"trackpad":"wheel",this._timeout&&(clearTimeout(this._timeout),this._timeout=null,i+=this._lastValue)),t.shiftKey&&i&&(i/=4),this._type&&(this._lastWheelEvent=t,this._delta-=i,this._active||this._start(t)),t.preventDefault()}_onTimeout(e){this._type="wheel",this._delta-=this._lastValue,this._active||this._start(e)}_start(e){if(!this._delta)return;this._frameId&&(this._frameId=null),this._active=!0,this.isZooming()||(this._zooming=!0),this._finishTimeout&&(clearTimeout(this._finishTimeout),delete this._finishTimeout);const t=x(this._el,e);this._aroundPoint=this._aroundCenter?this._map.transform.centerPoint:t,this._aroundCoord=this._map.transform.pointCoordinate3D(this._aroundPoint),this._targetZoom=void 0,this._frameId||(this._frameId=!0,this._handler._triggerRenderFrame())}renderFrame(){if(!this._frameId)return;if(this._frameId=null,!this.isActive())return;const t=this._map.transform;"wheel"===this._type&&t.projection.wrap&&(t._center.lng>=180||t._center.lng<=-180)&&(this._prevEase=null,this._easing=null,this._lastWheelEvent=null,this._lastWheelEventTime=0);const i=()=>t._terrainEnabled()&&this._aroundCoord?t.computeZoomRelativeTo(this._aroundCoord):t.zoom;if(0!==this._delta){const e="wheel"===this._type&&Math.abs(this._delta)>qc?this._wheelZoomRate:this._defaultZoomRate;let r=2/(1+Math.exp(-Math.abs(this._delta*e)));this._delta<0&&0!==r&&(r=1/r);const n=i(),o=Math.pow(2,n),s="number"==typeof this._targetZoom?t.zoomScale(this._targetZoom):o;this._targetZoom=Math.min(t.maxZoom,Math.max(t.minZoom,t.scaleZoom(s*r))),"wheel"===this._type&&(this._startZoom=n,this._easing=this._smoothOutEasing(200)),this._lastDelta=this._delta,this._delta=0}const r="number"==typeof this._targetZoom?this._targetZoom:i(),n=this._startZoom,o=this._easing;let s,a=!1;if("wheel"===this._type&&n&&o){const t=Math.min((e.o.now()-this._lastWheelEventTime)/200,1),i=o(t);s=e.aj(n,r,i),t<1?this._frameId||(this._frameId=!0):a=!0}else s=r,a=!0;this._active=!0,a&&(this._active=!1,this._finishTimeout=window.setTimeout(()=>{this._zooming=!1,this._handler._triggerRenderFrame(),delete this._targetZoom,delete this._finishTimeout},200));let l=s-i();return l*this._lastDelta<0&&(l=0),{noInertia:!0,needsRenderFrame:!a,zoomDelta:l,around:this._aroundPoint,aroundCoord:this._aroundCoord,originalEvent:this._lastWheelEvent}}_smoothOutEasing(t){let i=e.eS;if(this._prevEase){const t=this._prevEase,r=(e.o.now()-t.start)/t.duration,n=t.easing(r+.01)-t.easing(r),o=.27/Math.sqrt(n*n+1e-4)*.01,s=Math.sqrt(.0729-o*o);i=e.eQ(o,s,.25,1)}return this._prevEase={start:e.o.now(),duration:t,easing:i},i}blur(){this.reset()}reset(){this._active=!1}_addScrollZoomBlocker(){this._map&&!this._alertContainer&&(this._alertContainer=h("div","mapboxgl-scroll-zoom-blocker",this._map._container),this._alertContainer.textContent=Wc.test(navigator.userAgent)?this._map._getUIString("ScrollZoomBlocker.CmdMessage"):this._map._getUIString("ScrollZoomBlocker.CtrlMessage"),this._alertContainer.style.fontSize=`${Math.max(10,Math.min(24,Math.floor(.05*this._el.clientWidth)))}px`)}_showBlockerAlert(){this._alertContainer.style.visibility="visible",this._alertContainer.classList.add("mapboxgl-scroll-zoom-blocker-show"),this._alertContainer.setAttribute("role","alert"),clearTimeout(this._alertTimer),this._alertTimer=window.setTimeout(()=>{this._alertContainer.classList.remove("mapboxgl-scroll-zoom-blocker-show"),this._alertContainer.removeAttribute("role")},200)}}class Yc{constructor(e,t){this._clickZoom=e,this._tapZoom=t}enable(){this._clickZoom.enable(),this._tapZoom.enable()}disable(){this._clickZoom.disable(),this._tapZoom.disable()}isEnabled(){return this._clickZoom.isEnabled()&&this._tapZoom.isEnabled()}isActive(){return this._clickZoom.isActive()||this._tapZoom.isActive()}}class Jc{constructor(){this.reset()}reset(){this._active=!1}blur(){this.reset()}dblclick(e,t){return e.preventDefault(),{cameraAnimation:i=>{i.easeTo({duration:300,zoom:i.getZoom()+(e.shiftKey?-1:1),around:i.unproject(t)},{originalEvent:e})}}}enable(){this._enabled=!0}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}}class Kc{constructor(){this._tap=new Sc({numTouches:1,numTaps:1}),this.reset()}reset(){this._active=!1,this._swipePoint=void 0,this._swipeTouch=0,this._tapTime=0,this._tap.reset()}touchstart(e,t,i){this._swipePoint||(this._tapTime&&e.timeStamp-this._tapTime>500&&this.reset(),this._tapTime?i.length>0&&(this._swipePoint=t[0],this._swipeTouch=i[0].identifier):this._tap.touchstart(e,t,i))}touchmove(e,t,i){if(this._tapTime){if(this._swipePoint){if(i[0].identifier!==this._swipeTouch)return;const r=t[0],n=r.y-this._swipePoint.y;return this._swipePoint=r,e.preventDefault(),this._active=!0,{zoomDelta:n/128}}}else this._tap.touchmove(e,t,i)}touchend(e,t,i){this._tapTime?this._swipePoint&&0===i.length&&this.reset():this._tap.touchend(e,t,i)&&(this._tapTime=e.timeStamp)}touchcancel(){this.reset()}enable(){this._enabled=!0}disable(){this._enabled=!1,this.reset()}isEnabled(){return this._enabled}isActive(){return this._active}}class Qc{constructor(e,t,i){this._el=e,this._mousePan=t,this._touchPan=i}enable(e){this._inertiaOptions=e||{},this._mousePan.enable(),this._touchPan.enable(),this._el.classList.add("mapboxgl-touch-drag-pan")}disable(){this._mousePan.disable(),this._touchPan.disable(),this._el.classList.remove("mapboxgl-touch-drag-pan")}isEnabled(){return this._mousePan.isEnabled()&&this._touchPan.isEnabled()}isActive(){return this._mousePan.isActive()||this._touchPan.isActive()}}class eh{constructor(e,t,i){this._pitchWithRotate=e.pitchWithRotate,this._mouseRotate=t,this._mousePitch=i}enable(){this._mouseRotate.enable(),this._pitchWithRotate&&this._mousePitch.enable()}disable(){this._mouseRotate.disable(),this._mousePitch.disable()}isEnabled(){return this._mouseRotate.isEnabled()&&(!this._pitchWithRotate||this._mousePitch.isEnabled())}isActive(){return this._mouseRotate.isActive()||this._mousePitch.isActive()}}class th{constructor(e,t,i,r){this._el=e,this._touchZoom=t,this._touchRotate=i,this._tapDragZoom=r,this._rotationDisabled=!1,this._enabled=!0}enable(e){this._touchZoom.enable(e),this._rotationDisabled||this._touchRotate.enable(e),this._tapDragZoom.enable(),this._el.classList.add("mapboxgl-touch-zoom-rotate")}disable(){this._touchZoom.disable(),this._touchRotate.disable(),this._tapDragZoom.disable(),this._el.classList.remove("mapboxgl-touch-zoom-rotate")}isEnabled(){return this._touchZoom.isEnabled()&&(this._rotationDisabled||this._touchRotate.isEnabled())&&this._tapDragZoom.isEnabled()}isActive(){return this._touchZoom.isActive()||this._touchRotate.isActive()||this._tapDragZoom.isActive()}disableRotation(){this._rotationDisabled=!0,this._touchRotate.disable()}enableRotation(){this._rotationDisabled=!1,this._touchZoom.isEnabled()&&this._touchRotate.enable()}}const ih=e=>e.zoom||e.drag||e.pitch||e.rotate;class rh extends e.z{}class nh{constructor(){this.constants=[1,1,.01],this.radius=0}setup(t,i){const r=e.aw([],i,t);this.radius=e.af(r[2]<0?e.eU([],r,this.constants):[r[0],r[1],0])}projectRay(t){e.eU(t,t,this.constants),e.ax(t,t),e.eV(t,t,this.constants);const i=e.bN([],t,this.radius);if(i[2]>0){const t=e.bN([],[0,0,1],e.bk(i,[0,0,1])),r=e.bN([],e.ax([],[i[0],i[1],0]),this.radius),n=e.cX([],i,e.bN([],e.aw([],e.cX([],r,t),i),2));i[0]=n[0],i[1]=n[1]}return i}}function oh(e){return e.panDelta&&e.panDelta.mag()||e.zoomDelta||e.bearingDelta||e.pitchDelta}class sh{constructor(t,i){this._map=t,this._el=this._map.getCanvasContainer(),this._handlers=[],this._handlersById={},this._changes=[],this._inertia=new pc(t),this._bearingSnap=i.bearingSnap,this._previousActiveHandlers={},this._trackingEllipsoid=new nh,this._dragOrigin=null,this._eventsInProgress={},this._addDefaultHandlers(i),e.b0(["handleEvent","handleWindowEvent"],this);const r=this._el;this._listeners=[[r,"touchstart",{passive:!0}],[r,"touchmove",{passive:!1}],[r,"touchend",void 0],[r,"touchcancel",void 0],[r,"mousedown",void 0],[r,"mousemove",void 0],[r,"mouseup",void 0],[document,"mousemove",{capture:!0}],[document,"mouseup",void 0],[r,"mouseover",void 0],[r,"mouseout",void 0],[r,"dblclick",void 0],[r,"click",void 0],[r,"keydown",{capture:!1}],[r,"keyup",void 0],[r,"wheel",{passive:!1}],[r,"contextmenu",void 0],[window,"blur",void 0]];for(const[e,n,o]of this._listeners){const t=e===document?this.handleWindowEvent:this.handleEvent;e.addEventListener(n,t,o)}}destroy(){for(const[e,t,i]of this._listeners){const r=e===document?this.handleWindowEvent:this.handleEvent;e.removeEventListener(t,r,i)}}_addDefaultHandlers(e){const t=this._map,i=t.getCanvasContainer();this._add("mapEvent",new xc(t,e));const r=t.boxZoom=new bc(t,e);this._add("boxZoom",r);const n=new Ic,o=new Jc;t.doubleClickZoom=new Yc(o,n),this._add("tapZoom",n),this._add("clickZoom",o);const s=new Kc;this._add("tapDragZoom",s);const a=t.touchPitch=new jc(t);this._add("touchPitch",a);const l=new Rc(e),c=new zc(e);t.dragRotate=new eh(e,l,c),this._add("mouseRotate",l,["mousePitch"]),this._add("mousePitch",c,["mouseRotate"]);const h=new Dc(e),u=new Lc(t,e);t.dragPan=new Qc(i,h,u),this._add("mousePan",h),this._add("touchPan",u,["touchZoom","touchRotate"]);const d=new Uc,p=new kc;t.touchZoomRotate=new th(i,p,d,s),this._add("touchRotate",d,["touchPan","touchZoom"]),this._add("touchZoom",p,["touchPan","touchRotate"]),this._add("blockableMapEvent",new vc(t));const f=t.scrollZoom=new Xc(t,this);this._add("scrollZoom",f,["mousePan"]);const m=t.keyboard=new Hc;this._add("keyboard",m);for(const _ of["boxZoom","doubleClickZoom","tapDragZoom","touchPitch","dragRotate","dragPan","touchZoomRotate","scrollZoom","keyboard"])e.interactive&&e[_]&&t[_].enable(e[_])}_add(e,t,i){this._handlers.push({handlerName:e,handler:t,allowed:i}),this._handlersById[e]=t}stop(e){if(!this._updatingCamera){for(const{handler:e}of this._handlers)e.reset();this._inertia.clear(),this._fireEvents({},{},e),this._changes=[],this._originalZoom=void 0}}isActive(){for(const{handler:e}of this._handlers)if(e.isActive())return!0;return!1}isZooming(){return!!this._eventsInProgress.zoom||this._map.scrollZoom.isZooming()}isRotating(){return!!this._eventsInProgress.rotate}isMoving(){return!!ih(this._eventsInProgress)||this.isZooming()}_isDragging(){return!!this._eventsInProgress.drag}_blockedByActive(e,t,i){for(const r in e)if(!(r===i||t&&t.includes(r)))return!0;return!1}handleWindowEvent(e){this.handleEvent(e,`${e.type}Window`)}_getMapTouches(e){const t=[];for(const i of e)this._el.contains(i.target)&&t.push(i);return t}handleEvent(e,t){this._updatingCamera=!0;const i="renderFrame"===e.type,r=i?void 0:e,n={needsRenderFrame:!1},o={},s={},a=e.touches?this._getMapTouches(e.touches):void 0,l=a?v(this._el,a):i?void 0:x(this._el,e);for(const{handlerName:u,handler:d,allowed:p}of this._handlers){if(!d.isEnabled())continue;let i;this._blockedByActive(s,p,u)?d.reset():d[t||e.type]&&(i=d[t||e.type](e,l,a),this.mergeHandlerResult(n,o,i,u,r),i&&i.needsRenderFrame&&this._triggerRenderFrame()),(i||d.isActive())&&(s[u]=d)}const c={};for(const u in this._previousActiveHandlers)s[u]||(c[u]=r);this._previousActiveHandlers=s,(Object.keys(c).length||oh(n))&&(this._changes.push([n,o,c]),this._triggerRenderFrame()),(Object.keys(s).length||oh(n))&&this._map._stop(!0),this._updatingCamera=!1;const{cameraAnimation:h}=n;h&&(this._inertia.clear(),this._fireEvents({},{},!0),this._changes=[],h(this._map))}mergeHandlerResult(e,t,i,r,n){if(!i)return;Object.assign(e,i);const o={handlerName:r,originalEvent:i.originalEvent||n};void 0!==i.zoomDelta&&(t.zoom=o),void 0!==i.panDelta&&(t.drag=o),void 0!==i.pitchDelta&&(t.pitch=o),void 0!==i.bearingDelta&&(t.rotate=o)}_applyChanges(){const t={},i={},r={};for(const[n,o,s]of this._changes)n.panDelta&&(t.panDelta=(t.panDelta||new e.P(0,0))._add(n.panDelta)),n.zoomDelta&&(t.zoomDelta=(t.zoomDelta||0)+n.zoomDelta),n.bearingDelta&&(t.bearingDelta=(t.bearingDelta||0)+n.bearingDelta),n.pitchDelta&&(t.pitchDelta=(t.pitchDelta||0)+n.pitchDelta),void 0!==n.around&&(t.around=n.around),void 0!==n.aroundCoord&&(t.aroundCoord=n.aroundCoord),void 0!==n.pinchAround&&(t.pinchAround=n.pinchAround),n.noInertia&&(t.noInertia=n.noInertia),Object.assign(i,o),Object.assign(r,s);this._updateMapTransform(t,i,r),this._changes=[]}_updateMapTransform(t,i,r){const n=this._map,o=n.transform,s=e=>[e.x,e.y,e.z];if((()=>{const e=this._eventsInProgress.drag;return e&&!this._handlersById[e.handlerName].isActive()})()&&!oh(t)){const e=o.zoom;o.cameraElevationReference="sea",null!=this._originalZoom&&o._orthographicProjectionAtLowPitch&&"globe"!==o.projection.name&&0===o.pitch?(o.cameraElevationReference="ground",o.zoom=this._originalZoom):(o.recenterOnTerrain(),o.cameraElevationReference="ground"),e!==o.zoom&&this._map._update(!0)}if(o._isCameraConstrained&&n._stop(!0),!oh(t))return void this._fireEvents(i,r,!0);let{panDelta:a,zoomDelta:l,bearingDelta:c,pitchDelta:h,around:u,aroundCoord:d,pinchAround:p}=t;o._isCameraConstrained&&(l>0&&(l=0),o._isCameraConstrained=!1),void 0!==p&&(u=p),(l||(e=>i[e]&&!this._eventsInProgress[e])("drag"))&&u&&(this._dragOrigin=s(o.pointCoordinate3D(u)),this._originalZoom=o.zoom,this._trackingEllipsoid.setup(o._camera.position,this._dragOrigin)),o.cameraElevationReference="sea",n._stop(!0),u=u||n.transform.centerPoint,c&&(o.bearing+=c),h&&(o.pitch+=h),o._updateCameraState();const f=[0,0,0];if(a)if("mercator"===o.projection.name){const e=this._trackingEllipsoid.projectRay(o.screenPointToMercatorRay(u).dir),t=this._trackingEllipsoid.projectRay(o.screenPointToMercatorRay(u.sub(a)).dir);f[0]=t[0]-e[0],f[1]=t[1]-e[1]}else{const t=o.pointCoordinate(u);if("globe"===o.projection.name){a=a.rotate(-o.angle);const i=o._pixelsPerMercatorPixel/o.worldSize;f[0]=-a.x*e.eT(e.bZ(t.y))*i,f[1]=-a.y*e.eT(o.center.lat)*i}else{const e=o.pointCoordinate(u.sub(a));t&&e&&(f[0]=e.x-t.x,f[1]=e.y-t.y)}}const m=o.zoom,_=[0,0,0];if(l){const t=s(d||o.pointCoordinate3D(u)),i={dir:e.ax([],e.aw([],t,o._camera.position))};if(i.dir[2]<0){const r=o.zoomDeltaToMovement(t,l);e.bN(_,i.dir,r)}}const g=e.cX(f,f,_);o._translateCameraConstrained(g),l&&Math.abs(o.zoom-m)>1e-4&&o.recenterOnTerrain(),o.cameraElevationReference="ground",this._map._update(),t.noInertia||this._inertia.record(t),this._fireEvents(i,r,!0)}_fireEvents(t,i,r){const n=ih(this._eventsInProgress),o=ih(t),s={};for(const e in t){const{originalEvent:i}=t[e];this._eventsInProgress[e]||(s[`${e}start`]=i),this._eventsInProgress[e]=t[e]}!n&&o&&this._fireEvent("movestart",o.originalEvent);for(const e in s)this._fireEvent(e,s[e]);o&&this._fireEvent("move",o.originalEvent);for(const e in t){const{originalEvent:i}=t[e];this._fireEvent(e,i)}const a={};let l;for(const e in this._eventsInProgress){const{handlerName:t,originalEvent:r}=this._eventsInProgress[e];this._handlersById[t].isActive()||(delete this._eventsInProgress[e],l=i[t]||r,a[`${e}end`]=l)}for(const e in a)this._fireEvent(e,a[e]);const c=ih(this._eventsInProgress);if(r&&(n||o)&&!c){this._updatingCamera=!0;const t=this._inertia._onMoveEnd(this._map.dragPan._inertiaOptions),i=e=>0!==e&&-this._bearingSnap<e&&e<this._bearingSnap;t?(i(t.bearing||this._map.getBearing())&&(t.bearing=0),this._map.easeTo(t,{originalEvent:l})):(this._map.fire(new e.z("moveend",{originalEvent:l})),i(this._map.getBearing())&&this._map.resetNorth()),this._updatingCamera=!1}}_fireEvent(t,i){this._map.fire(new e.z(t,i?{originalEvent:i}:{}))}_requestFrame(){return this._map.triggerRepaint(),this._map._renderTaskQueue.add(e=>{this._frameId=void 0,this.handleEvent(new rh("renderFrame",{timeStamp:e})),this._applyChanges()})}_triggerRenderFrame(){void 0===this._frameId&&(this._frameId=this._requestFrame())}}const ah="map.setFreeCameraOptions(...) and map.getFreeCameraOptions() are not yet supported for non-mercator projections.";class lh extends e.E{constructor(t,i){super(),this._moving=!1,this._zooming=!1,this.transform=t,this._bearingSnap=i.bearingSnap,this._respectPrefersReducedMotion=!1!==i.respectPrefersReducedMotion,e.b0(["_renderFrameCallback"],this)}getCenter(){return new e.aX(this.transform.center.lng,this.transform.center.lat)}setCenter(e,t){return this.jumpTo({center:e},t)}panBy(t,i,r){return t=e.P.convert(t).mult(-1),this.panTo(this.transform.center,Object.assign({offset:t},i),r)}panTo(e,t,i){return this.easeTo(Object.assign({center:e},t),i)}getZoom(){return this.transform.zoom}setZoom(e,t){return this.jumpTo({zoom:e},t),this}zoomTo(e,t,i){return this.easeTo(Object.assign({zoom:e},t),i)}zoomIn(e,t){return this.zoomTo(this.getZoom()+1,e,t),this}zoomOut(e,t){return this.zoomTo(this.getZoom()-1,e,t),this}getBearing(){return this.transform.bearing}setBearing(e,t){return this.jumpTo({bearing:e},t),this}getPadding(){return this.transform.padding}setPadding(e,t){return this.jumpTo({padding:e},t),this}rotateTo(e,t,i){return this.easeTo(Object.assign({bearing:e},t),i)}resetNorth(e,t){return this.rotateTo(0,Object.assign({duration:1e3},e),t),this}resetNorthPitch(e,t){return this.easeTo(Object.assign({bearing:0,pitch:0,duration:1e3},e),t),this}snapToNorth(e,t){return Math.abs(this.getBearing())<this._bearingSnap?this.resetNorth(e,t):this}getPitch(){return this.transform.pitch}setPitch(e,t){return this.jumpTo({pitch:e},t),this}cameraForBounds(t,i){t=e.aI.convert(t);const r=i&&i.bearing||0,n=i&&i.pitch||0,o=t.getNorthWest(),s=t.getSouthEast();return this._cameraForBounds(this.transform,o,s,r,n,i)}_extendPadding(e){const t={top:0,right:0,bottom:0,left:0};return null==e?Object.assign({},t,this.transform.padding):"number"==typeof e?{top:e,bottom:e,right:e,left:e}:Object.assign({},t,e)}_extendCameraOptions(e){return(e=Object.assign({offset:[0,0],maxZoom:this.transform.maxZoom},e)).padding=this._extendPadding(e.padding),e}_minimumAABBFrustumDistance(e,t){const i=t.max[0]-t.min[0],r=t.max[1]-t.min[1];return i/r>e.aspect?i/(2*Math.tan(.5*e.fovX)*e.aspect):r/(2*Math.tan(.5*e.fovY)*e.aspect)}_cameraForBoundsOnGlobe(t,i,r,n,o,s){const a=t.clone(),l=this._extendCameraOptions(s);a.bearing=n,a.pitch=o;const c=e.aX.convert(i),h=e.aX.convert(r),u=.5*(c.lat+h.lat),d=.5*(c.lng+h.lng),p=e.eW(u,d),f=e.ax([],p),m=e.ax([],e.bj([],f,[0,1,0])),_=e.bj([],m,f),g=[m[0],m[1],m[2],0,_[0],_[1],_[2],0,f[0],f[1],f[2],0,0,0,0,1],y=[p,e.eW(c.lat,c.lng),e.eW(h.lat,c.lng),e.eW(h.lat,h.lng),e.eW(c.lat,h.lng),e.eW(u,c.lng),e.eW(u,h.lng),e.eW(c.lat,d),e.eW(h.lat,d)];let x=e.cY.fromPoints(y.map(t=>[e.bk(m,t),e.bk(_,t),e.bk(f,t)]));const v=e.ae([],x.center,g);0===e.eX(v)&&e.eY(v,0,0,1),e.ax(v,v),e.bN(v,v,e.aE),a.center=e.eZ(v);const b=a.getWorldToCameraMatrix(),w=e.ba(new Float64Array(16),b);x=e.cY.applyTransform(x,e.aC([],b,g));const T=this._extendAABB(x,a,l,n);if(!T)return void e.w("Map cannot fit within canvas with the given bounds, padding, and/or offset.");x=T,e.ae(v,v,b);const S=.5*(x.max[2]-x.min[2]),I=this._minimumAABBFrustumDistance(a,x),E=e.bN([],[0,0,1],S),A=e.cX(E,v,E),M=I+(0===a.pitch?0:e.bh(v,A)),C=a.globeCenterInViewSpace,P=e.aw([],v,[C[0],C[1],C[2]]);e.ax(P,P),e.bN(P,P,M);const D=e.cX([],v,P);e.ae(D,D,w);const R=e.eg/e.aE,z=e.af(D),L=e.bY(Math.max(z*R-e.eg,Number.EPSILON),0),F=Math.min(a.zoomFromMercatorZAdjusted(L),l.maxZoom);return F>.5*(e.cN+e.cx)?(a.setProjection({name:"mercator"}),a.zoom=F,this._cameraForBounds(a,i,r,n,o,s)):{center:a.center,zoom:F,bearing:n,pitch:o}}_extendAABB(t,i,r,n){const o=.5*((r.padding.left||0)+(r.padding.right||0)),s=.5*((r.padding.top||0)+(r.padding.bottom||0)),a=s,l=o,c=o,h=s,u=i.width-(l+c),d=i.height-(a+h),p=e.aw([],t.max,t.min),f=Math.min(u/p[0],d/p[1]),m=Math.min(i.scaleZoom(i.scale*f),r.maxZoom);if(isNaN(m))return null;const _=i.scale/i.zoomScale(m),g=new e.cY([t.min[0]-l*_,t.min[1]-h*_,t.min[2]],[t.max[0]+c*_,t.max[1]+a*_,t.max[2]]),y=("number"==typeof r.offset.x&&"number"==typeof r.offset.y?new e.P(r.offset.x,r.offset.y):e.P.convert(r.offset)).rotate(-e.am(n));return g.center[0]-=y.x*_,g.center[1]+=y.y*_,g}queryTerrainElevation(t,i){const r=this.transform.elevation;return r?(i=Object.assign({},{exaggerated:!0},i),r.getAtPoint(e.ad.fromLngLat(t),null,i.exaggerated)):null}_cameraForBounds(t,i,r,n,o,s){if("globe"===t.projection.name)return this._cameraForBoundsOnGlobe(t,i,r,n,o,s);const a=t.clone(),l=this._extendCameraOptions(s);a.bearing=n,a.pitch=o;const c=e.aX.convert(i),h=e.aX.convert(r),u=new e.aX(c.lng,h.lat),d=new e.aX(h.lng,c.lat),p=a.project(c),f=a.project(h),m=this.queryTerrainElevation(c),_=this.queryTerrainElevation(h),g=this.queryTerrainElevation(u),y=this.queryTerrainElevation(d),x=[[p.x,p.y,Math.min(m||0,_||0,g||0,y||0)],[f.x,f.y,Math.max(m||0,_||0,g||0,y||0)]];let v=e.cY.fromPoints(x);const b=a.getWorldToCameraMatrix(),w=e.ba(new Float64Array(16),b);v=e.cY.applyTransform(v,b);const T=this._extendAABB(v,a,l,n);if(!T)return void e.w("Map cannot fit within canvas with the given bounds, padding, and/or offset.");v=T;const S=.5*e.aw([],v.max,v.min)[2],I=this._minimumAABBFrustumDistance(a,v),E=[0,0,1,0];e.aD(E,E,b),e.e_(E,E);const A=e.bN([],E,I+S),M=e.cX([],v.center,A);e.ae(v.center,v.center,w),e.ae(M,M,w);const C=a.unproject(new e.P(v.center[0],v.center[1])),P=e.e$(a.projection,C),D=Math.pow(2,P),R=Math.min(a._zoomFromMercatorZ(M[2]*a.pixelsPerMeter*D/a.worldSize),l.maxZoom);return a.mercatorFromTransition&&R<.5*(e.cN+e.cx)?(a.setProjection({name:"globe"}),a.zoom=R,this._cameraForBounds(a,i,r,n,o,s)):{center:C,zoom:R,bearing:n,pitch:o}}fitBounds(e,t,i){const r=this.cameraForBounds(e,t);return this._fitInternal(r,t,i)}fitScreenCoordinates(t,i,r,n,o){const s=e.P.convert(t),a=e.P.convert(i),l=new e.P(Math.min(s.x,a.x),Math.min(s.y,a.y)),c=new e.P(Math.max(s.x,a.x),Math.max(s.y,a.y));if("mercator"===this.transform.projection.name&&this.transform.anyCornerOffEdge(s,a))return this;const h=this.transform.pointLocation3D(l),u=this.transform.pointLocation3D(c),d=this.transform.pointLocation3D(new e.P(l.x,c.y)),p=this.transform.pointLocation3D(new e.P(c.x,l.y)),f=[Math.min(h.lng,u.lng,d.lng,p.lng),Math.min(h.lat,u.lat,d.lat,p.lat)],m=[Math.max(h.lng,u.lng,d.lng,p.lng),Math.max(h.lat,u.lat,d.lat,p.lat)],_=n&&n.pitch?n.pitch:this.getPitch(),g=this._cameraForBounds(this.transform,f,m,r,_,n);return this._fitInternal(g,n,o)}_fitInternal(e,t,i){return e?(t=Object.assign(e,t)).linear?this.easeTo(t,i):this.flyTo(t,i):this}jumpTo(t,i){this.stop();const r=t.preloadOnly?this.transform.clone():this.transform;let n=!1,o=!1,s=!1;"zoom"in t&&r.zoom!==+t.zoom&&(n=!0,r.zoom=+t.zoom),void 0!==t.center&&(r.center=e.aX.convert(t.center)),"bearing"in t&&r.bearing!==+t.bearing&&(o=!0,r.bearing=+t.bearing),"pitch"in t&&r.pitch!==+t.pitch&&(s=!0,r.pitch=+t.pitch);const a="number"==typeof t.padding?this._extendPadding(t.padding):t.padding;if(null!=t.padding&&!r.isPaddingEqual(a))if(!1===t.retainPadding){const e=r.clone();e.padding=a,r.setLocationAtPoint(r.center,e.centerPoint)}else r.padding=a;return t.preloadOnly?(this._preloadTiles(r),this):(this.fire(new e.z("movestart",i)).fire(new e.z("move",i)),n&&this.fire(new e.z("zoomstart",i)).fire(new e.z("zoom",i)).fire(new e.z("zoomend",i)),o&&this.fire(new e.z("rotatestart",i)).fire(new e.z("rotate",i)).fire(new e.z("rotateend",i)),s&&this.fire(new e.z("pitchstart",i)).fire(new e.z("pitch",i)).fire(new e.z("pitchend",i)),this.fire(new e.z("moveend",i)))}getFreeCameraOptions(){return this.transform.projection.supportsFreeCamera||e.w(ah),this.transform.getFreeCameraOptions()}setFreeCameraOptions(t,i){const r=this.transform;if(!r.projection.supportsFreeCamera)return e.w(ah),this;this.stop();const n=r.zoom,o=r.pitch,s=r.bearing;r.setFreeCameraOptions(t);const a=n!==r.zoom,l=o!==r.pitch,c=s!==r.bearing;return this.fire(new e.z("movestart",i)).fire(new e.z("move",i)),a&&this.fire(new e.z("zoomstart",i)).fire(new e.z("zoom",i)).fire(new e.z("zoomend",i)),c&&this.fire(new e.z("rotatestart",i)).fire(new e.z("rotate",i)).fire(new e.z("rotateend",i)),l&&this.fire(new e.z("pitchstart",i)).fire(new e.z("pitch",i)).fire(new e.z("pitchend",i)),this.fire(new e.z("moveend",i)),this}easeTo(t,i){this._stop(!1,t.easeId),(!1===(t=Object.assign({offset:[0,0],duration:500,easing:e.eS},t)).animate||this._prefersReducedMotion(t))&&(t.duration=0);const r=this.transform,n=this.getZoom(),o=this.getBearing(),s=this.getPitch(),a=this.getPadding(),l="zoom"in t?+t.zoom:n,c="bearing"in t?this._normalizeBearing(t.bearing,o):o,h="pitch"in t?+t.pitch:s,u=this._extendPadding(t.padding),d=e.P.convert(t.offset);let p,f,m;if("globe"===r.projection.name){const i=e.ad.fromLngLat(r.center),n=d.rotate(-r.angle);i.x+=n.x/r.worldSize,i.y+=n.y/r.worldSize;const o=i.toLngLat(),s=e.aX.convert(t.center||o);this._normalizeCenter(s),p=r.centerPoint.add(n),f=new e.P(i.x,i.y).mult(r.worldSize),m=new e.P(e.aG(s.lng),e.aJ(s.lat)).mult(r.worldSize).sub(f)}else{p=r.centerPoint.add(d);const i=r.pointLocation(p),n=e.aX.convert(t.center||i);this._normalizeCenter(n),f=r.project(i),m=r.project(n).sub(f)}const _=r.zoomScale(l-n);let g,y;t.around&&(g=e.aX.convert(t.around),y=r.locationPoint(g));const x=this._zooming||l!==n,v=this._rotating||o!==c,b=this._pitching||h!==s,w=!r.isPaddingEqual(u),T=!1===t.retainPadding?r.clone():r,S=r=>S=>{if(x&&(r.zoom=e.aj(n,l,S)),v&&(r.bearing=e.aj(o,c,S)),b&&(r.pitch=e.aj(s,h,S)),w&&(T.interpolatePadding(a,u,S),p=T.centerPoint.add(d)),g)r.setLocationAtPoint(g,y);else{const e=r.zoomScale(r.zoom-n),t=Math.pow(l>n?Math.min(2,_):Math.max(.5,_),1-S),i=r.unproject(f.add(m.mult(S*t)).mult(e));r.setLocationAtPoint(r.renderWorldCopies?i.wrap():i,p)}return t.preloadOnly||this._fireMoveEvents(i),r};if(t.preloadOnly){const e=this._emulate(S,t.duration,r);return this._preloadTiles(e),this}const I={moving:this._moving,zooming:this._zooming,rotating:this._rotating,pitching:this._pitching};return this._zooming=x,this._rotating=v,this._pitching=b,this._padding=w,this._easeId=t.easeId,this._prepareEase(i,t.noMoveStart,I),this._ease(S(r),e=>{"sea"===r.cameraElevationReference&&r.recenterOnTerrain(),this._afterEase(i,e)},t),this}_prepareEase(t,i,r={}){this._moving=!0,this.transform.cameraElevationReference="sea",this.transform._orthographicProjectionAtLowPitch&&0===this.transform.pitch&&"globe"!==this.transform.projection.name&&(this.transform.cameraElevationReference="ground"),i||r.moving||this.fire(new e.z("movestart",t)),this._zooming&&!r.zooming&&this.fire(new e.z("zoomstart",t)),this._rotating&&!r.rotating&&this.fire(new e.z("rotatestart",t)),this._pitching&&!r.pitching&&this.fire(new e.z("pitchstart",t))}_fireMoveEvents(t){this.fire(new e.z("move",t)),this._zooming&&this.fire(new e.z("zoom",t)),this._rotating&&this.fire(new e.z("rotate",t)),this._pitching&&this.fire(new e.z("pitch",t))}_afterEase(t,i){if(this._easeId&&i&&this._easeId===i)return;this._easeId=void 0,this.transform.cameraElevationReference="ground";const r=this._zooming,n=this._rotating,o=this._pitching;this._moving=!1,this._zooming=!1,this._rotating=!1,this._pitching=!1,this._padding=!1,r&&this.fire(new e.z("zoomend",t)),n&&this.fire(new e.z("rotateend",t)),o&&this.fire(new e.z("pitchend",t)),this.fire(new e.z("moveend",t))}flyTo(t,i){if(this._prefersReducedMotion(t)){const r=e.aK(t,["center","zoom","bearing","pitch","around","padding","retainPadding"]);return this.jumpTo(r,i)}this.stop(),t=Object.assign({offset:[0,0],speed:1.2,curve:1.42,easing:e.eS},t);const r=this.transform,n=this.getZoom(),o=this.getBearing(),s=this.getPitch(),a=this.getPadding(),l="zoom"in t?e.aB(+t.zoom,r.minZoom,r.maxZoom):n,c="bearing"in t?this._normalizeBearing(t.bearing,o):o,h="pitch"in t?+t.pitch:s,u=this._extendPadding(t.padding),d=r.zoomScale(l-n),p=e.P.convert(t.offset);let f=r.centerPoint.add(p);const m=r.pointLocation(f),_=e.aX.convert(t.center||m);this._normalizeCenter(_);const g=r.project(m),y=r.project(_).sub(g);let x=t.curve;const v=Math.max(r.width,r.height),b=v/d,w=y.mag();if("minZoom"in t){const i=e.aB(Math.min(t.minZoom,n,l),r.minZoom,r.maxZoom),o=v/r.zoomScale(i-n);x=Math.sqrt(o/w*2)}const T=x*x;function S(e){const t=(b*b-v*v+(e?-1:1)*T*T*w*w)/(2*(e?b:v)*T*w);return Math.log(Math.sqrt(t*t+1)-t)}function I(e){return(Math.exp(e)-Math.exp(-e))/2}function E(e){return(Math.exp(e)+Math.exp(-e))/2}const A=S(0);let M=function(e){return E(A)/E(A+x*e)},C=function(e){return v*((E(A)*(I(t=A+x*e)/E(t))-I(A))/T)/w;var t},P=(S(1)-A)/x;if(Math.abs(w)<1e-6||!isFinite(P)){if(Math.abs(v-b)<1e-6)return this.easeTo(t,i);const e=b<v?-1:1;P=Math.abs(Math.log(b/v))/x,C=function(){return 0},M=function(t){return Math.exp(e*x*t)}}t.duration="duration"in t?+t.duration:1e3*P/("screenSpeed"in t?+t.screenSpeed/x:+t.speed),t.maxDuration&&t.duration>t.maxDuration&&(t.duration=0);const D=o!==c,R=h!==s,z=!r.isPaddingEqual(u),L=!1===t.retainPadding?r.clone():r,F=r=>d=>{const m=d*P,x=1/M(m);r.zoom=1===d?l:n+r.scaleZoom(x),D&&(r.bearing=e.aj(o,c,d)),R&&(r.pitch=e.aj(s,h,d)),z&&(L.interpolatePadding(a,u,d),f=L.centerPoint.add(p));const v=1===d?_:r.unproject(g.add(y.mult(C(m))).mult(x));return r.setLocationAtPoint(r.renderWorldCopies?v.wrap():v,f),r._updateCameraOnTerrain(),t.preloadOnly||this._fireMoveEvents(i),r};if(t.preloadOnly){const e=this._emulate(F,t.duration,r);return this._preloadTiles(e),this}return this._zooming=!0,this._rotating=D,this._pitching=R,this._padding=z,this._prepareEase(i,!1),this._ease(F(r),()=>this._afterEase(i),t),this}isEasing(){return!!this._easeFrameId}stop(){return this._stop()}_requestRenderFrame(e){}_cancelRenderFrame(e){}_stop(e,t){if(this._easeFrameId&&(this._cancelRenderFrame(this._easeFrameId),this._easeFrameId=void 0,this._onEaseFrame=void 0),this._onEaseEnd){const e=this._onEaseEnd;this._onEaseEnd=void 0,e.call(this,t)}if(!e){const e=this.handlers;e&&e.stop(!1)}return this}_ease(t,i,r){!1===r.animate||0===r.duration?(t(1),i()):(this._easeStart=e.o.now(),this._easeOptions=r,this._onEaseFrame=t,this._onEaseEnd=i,this._easeFrameId=this._requestRenderFrame(this._renderFrameCallback))}_renderFrameCallback(){const t=Math.min((e.o.now()-this._easeStart)/this._easeOptions.duration,1),i=this._onEaseFrame;i&&i(this._easeOptions.easing(t)),t<1?this._easeFrameId=this._requestRenderFrame(this._renderFrameCallback):this.stop()}_normalizeBearing(t,i){t=e.bv(t,-180,180);const r=Math.abs(t-i);return Math.abs(t-360-i)<r&&(t-=360),Math.abs(t+360-i)<r&&(t+=360),t}_normalizeCenter(e){const t=this.transform;if(t.maxBounds)return;if("globe"!==t.projection.name&&!t.renderWorldCopies)return;const i=e.lng-t.center.lng;e.lng+=i>180?-360:i<-180?360:0}_prefersReducedMotion(t){return this._respectPrefersReducedMotion&&e.o.prefersReducedMotion&&!(t&&t.essential)}_emulate(e,t,i){const r=Math.ceil(15*t/1e3),n=[],o=e(i.clone());for(let s=0;s<=r;s++){const e=o(s/r);n.push(e.clone())}return n}_preloadTiles(e,t){}}const ch=/^(https?:|mailto:)/i;class hh{constructor(t={}){this.options=t,e.b0(["_toggleAttribution","_updateEditLink","_updateData","_updateCompact"],this)}getDefaultPosition(){return"bottom-right"}onAdd(e){const t=this.options&&this.options.compact,i=e._getUIString("AttributionControl.ToggleAttribution");this._map=e,this._container=h("div","mapboxgl-ctrl mapboxgl-ctrl-attrib"),this._compactButton=h("button","mapboxgl-ctrl-attrib-button",this._container),this._compactButton.type="button",this._compactButton.addEventListener("click",this._toggleAttribution),this._compactButton.setAttribute("aria-label",i);const r=h("span","mapboxgl-ctrl-icon",this._compactButton);return r.setAttribute("aria-hidden","true"),r.setAttribute("title",i),this._innerContainer=h("div","mapboxgl-ctrl-attrib-inner",this._container),t&&this._container.classList.add("mapboxgl-compact"),this._updateAttributions(),this._updateEditLink(),this._map.on("styledata",this._updateData),this._map.on("sourcedata",this._updateData),this._map.on("moveend",this._updateEditLink),void 0===t&&(this._map.on("resize",this._updateCompact),this._updateCompact()),this._container}onRemove(){this._container.remove(),this._map.off("styledata",this._updateData),this._map.off("sourcedata",this._updateData),this._map.off("moveend",this._updateEditLink),this._map.off("resize",this._updateCompact),this._map=void 0,this._attribHTML=void 0}_toggleAttribution(){this._container.classList.contains("mapboxgl-compact-show")?(this._container.classList.remove("mapboxgl-compact-show"),this._compactButton.setAttribute("aria-expanded","false")):(this._container.classList.add("mapboxgl-compact-show"),this._compactButton.setAttribute("aria-expanded","true"))}_updateEditLink(){let t=this._editLink;t||(t=this._editLink=this._container.querySelector(".mapbox-improve-map"));const i=[{key:"owner",value:this.styleOwner},{key:"id",value:this.styleId},{key:"access_token",value:this._map._requestManager._customAccessToken||e.g.ACCESS_TOKEN}];if(t){const r=i.reduce((e,t,r)=>(t.value&&(e+=`${t.key}=${t.value}${r<i.length-1?"&":""}`),e),"?");t.href=`${e.g.FEEDBACK_URL}/${r}#${ac(this._map,!0)}`,t.rel="noopener nofollow"}}_updateData(e){!e||("source"!==e.dataType||"metadata"!==e.sourceDataType&&"visibility"!==e.sourceDataType)&&"style"!==e.dataType||(this._updateAttributions(),this._updateEditLink())}_updateAttributions(){if(!this._map.style)return;let e=[];if(this._map.style.stylesheet){const e=this._map.style.stylesheet;this.styleOwner=e.owner,this.styleId=e.id}const t=this._map.style._mergedSourceCaches;for(const r in t){const i=t[r];if(i.used){const t=i.getSource();t.attribution&&!e.includes(t.attribution)&&e.push(t.attribution)}}e.sort((e,t)=>e.length-t.length),e=e.filter((t,i)=>{for(let r=i+1;r<e.length;r++)if(e[r].includes(t))return!1;return!0}),this.options.customAttribution&&(Array.isArray(this.options.customAttribution)?e=[...this.options.customAttribution,...e]:e.unshift(this.options.customAttribution));const i=e.map(e=>function(e){const t=(new DOMParser).parseFromString(e,"text/html");return Array.from(t.body.querySelectorAll("*")).reverse().forEach(e=>{const i=e.textContent||"";if("A"!==e.tagName)return void e.replaceWith(...e.childNodes);const r=e.getAttribute("href");if(!r||!ch.test(r))return void e.replaceWith(t.createTextNode(i));const n=t.createElement("a");n.href=r,n.textContent=i,n.rel="noopener nofollow";const o=e.getAttribute("class");o&&(n.className=o),e.replaceWith(n)}),t.body.innerHTML}(e)).join(" | ");i!==this._attribHTML&&(this._attribHTML=i,e.length?(this._innerContainer.innerHTML=i,this._container.classList.remove("mapboxgl-attrib-empty")):this._container.classList.add("mapboxgl-attrib-empty"),this._editLink=null)}_updateCompact(){this._map.getCanvasContainer().offsetWidth<=640?this._container.classList.add("mapboxgl-compact"):this._container.classList.remove("mapboxgl-compact","mapboxgl-compact-show")}}class uh{constructor(){e.b0(["_updateLogo","_updateCompact"],this)}onAdd(e){this._map=e,this._container=h("div","mapboxgl-ctrl");const t=h("a","mapboxgl-ctrl-logo");return t.target="_blank",t.rel="noopener nofollow",t.href="https://www.mapbox.com/",t.setAttribute("aria-label",this._map._getUIString("LogoControl.Title")),t.setAttribute("rel","noopener nofollow"),this._container.appendChild(t),this._container.style.display="none",this._map.on("sourcedata",this._updateLogo),this._updateLogo(),this._map.on("resize",this._updateCompact),this._updateCompact(),this._container}onRemove(){this._container.remove(),this._map.off("sourcedata",this._updateLogo),this._map.off("resize",this._updateCompact)}getDefaultPosition(){return"bottom-left"}_updateLogo(e){e&&"metadata"!==e.sourceDataType||(this._container.style.display=this._logoRequired()?"block":"none")}_logoRequired(){if(!this._map.style)return!0;const e=this._map.style._sourceCaches;if(0===Object.entries(e).length)return!0;for(const t in e){const i=e[t].getSource();if(Object.hasOwn(i,"mapbox_logo")&&!i.mapbox_logo)return!1}return!0}_updateCompact(){const e=this._container.children;if(e.length){const t=e[0];this._map.getCanvasContainer().offsetWidth<250?t.classList.add("mapboxgl-compact"):t.classList.remove("mapboxgl-compact")}}}class dh{constructor(){this._queue=[],this._id=0,this._cleared=!1,this._currentlyRunning=!1}add(e){const t=++this._id;return this._queue.push({callback:e,id:t,cancelled:!1}),t}remove(e){const t=this._currentlyRunning,i=t?this._queue.concat(t):this._queue;for(const r of i)if(r.id===e)return void(r.cancelled=!0)}run(e=0){const t=this._currentlyRunning=this._queue;this._queue=[];for(const i of t)if(!i.cancelled&&(i.callback(e),this._cleared))break;this._cleared=!1,this._currentlyRunning=!1}clear(){this._currentlyRunning&&(this._cleared=!0),this._queue=[]}}class ph{constructor(e){this.jumpTo(e)}getValue(t){if(t<=this._startTime)return this._start;if(t>=this._endTime)return this._end;const i=e.dr((t-this._startTime)/(this._endTime-this._startTime));return this._start*(1-i)+this._end*i}isEasing(e){return e>=this._startTime&&e<=this._endTime}jumpTo(e){this._startTime=-1/0,this._endTime=-1/0,this._start=e,this._end=e}easeTo(e,t,i){this._start=this.getValue(t),this._end=e,this._startTime=t,this._endTime=t+i}}const fh={"AttributionControl.ToggleAttribution":"Toggle attribution","FullscreenControl.Enter":"Enter fullscreen","FullscreenControl.Exit":"Exit fullscreen","GeolocateControl.FindMyLocation":"Find my location","GeolocateControl.LocationNotAvailable":"Location not available","LogoControl.Title":"Mapbox homepage","Map.Title":"Map","NavigationControl.ResetBearing":"Reset bearing to north","NavigationControl.ZoomIn":"Zoom in","NavigationControl.ZoomOut":"Zoom out","ScrollZoomBlocker.CtrlMessage":"Use ctrl + scroll to zoom the map","ScrollZoomBlocker.CmdMessage":"Use ⌘ + scroll to zoom the map","TouchPanBlocker.Message":"Use two fingers to move the map"};class mh extends e.z{constructor(e,t,i,r){const{point:n,lngLat:o,originalEvent:s,target:a}=e;super(e.type,{point:n,lngLat:o,originalEvent:s,target:a}),this.preventDefault=()=>{e.preventDefault()},this.id=t,this.interaction=i,this.feature=r}}class _h{constructor(e){this.map=e,this.interactionsByType=/* @__PURE__ */new Map,this.delegatedInteractions=/* @__PURE__ */new Map,this.typeById=/* @__PURE__ */new Map,this.filters=/* @__PURE__ */new Map,this.handleType=this.handleType.bind(this),this.handleMove=this.handleMove.bind(this),this.handleOut=this.handleOut.bind(this),this.hoveredFeatures=/* @__PURE__ */new Map,this.prevHoveredFeatures=/* @__PURE__ */new Map}add(t,i){if(this.typeById.has(t))throw new Error(`Interaction id "${t}" already exists.`);const r=i.filter;let n=i.type;r&&this.filters.set(t,e.dj(r)),"mouseover"===n&&(n="mouseenter"),"mouseout"===n&&(n="mouseleave");const o=this.interactionsByType.get(n)||/* @__PURE__ */new Map;"mouseenter"===n||"mouseleave"===n?(0===this.delegatedInteractions.size&&(this.map.on("mousemove",this.handleMove),this.map.on("mouseout",this.handleOut)),this.delegatedInteractions.set(t,i)):0===o.size&&this.map.on(n,this.handleType),0===o.size&&this.interactionsByType.set(n,o),o.set(t,i),this.typeById.set(t,n)}get(e){const t=this.typeById.get(e);if(!t)return;const i=this.interactionsByType.get(t);return i?i.get(e):void 0}remove(e){const t=this.typeById.get(e);if(!t)return;this.typeById.delete(e),this.filters.delete(e);const i=this.interactionsByType.get(t);i&&(i.delete(e),"mouseenter"===t||"mouseleave"===t?(this.delegatedInteractions.delete(e),0===this.delegatedInteractions.size&&(this.map.off("mousemove",this.handleMove),this.map.off("mouseout",this.handleOut))):0===i.size&&this.map.off(t,this.handleType))}queryTargets(e,t){const i=[];for(const[r,n]of t)n.target&&i.push({targetId:r,target:n.target,filter:this.filters.get(r)});return this.map.style.queryRenderedTargets(e,i,this.map.transform)}handleMove(e){this.prevHoveredFeatures=this.hoveredFeatures,this.hoveredFeatures=/* @__PURE__ */new Map;const t=this.queryTargets(e.point,Array.from(this.delegatedInteractions).reverse());t.length&&(e.type="mouseenter",this.handleType(e,t));const i=/* @__PURE__ */new Map;for(const[r,{feature:n}]of this.prevHoveredFeatures)this.hoveredFeatures.has(r)||i.set(n.id,n);i.size&&(e.type="mouseleave",this.handleType(e,Array.from(i.values())))}handleOut(e){const t=Array.from(this.hoveredFeatures.values()).map(({feature:e})=>e);t.length&&(e.type="mouseleave",this.handleType(e,t)),this.hoveredFeatures.clear()}handleType(t,i){const r="mouseenter"===t.type;if(r&&!this.interactionsByType.has(t.type))return void e.w("mouseenter interaction required for mouseleave to work.");const n=Array.from(this.interactionsByType.get(t.type)).reverse(),o=!!i;i=i||this.queryTargets(t.point,n);let s=!1;const a=/* @__PURE__ */new Set;for(const l of i){for(const[i,c]of n){if(!c.target)continue;const n=l.variants?l.variants[i]:null;if(n){for(const h of n){if(Si(h,l,a,i))continue;const n=new e.dl(l,h),u=Ti(h,l,i);o&&void 0!==n.id&&(n.state=this.map.getFeatureState(n));const d=r?this.prevHoveredFeatures.get(u):null,p=new mh(t,i,c,n),f=d?d.stop:c.handler(p);if(r&&this.hoveredFeatures.set(u,{feature:l,stop:f}),!1!==f){s=!0;break}}if(s)break}}if(s)break}if(!s)for(const[e,l]of n){const{handler:i,target:r}=l;if(!r&&!1!==i(new mh(t,e,l,null)))break}}}function gh(t,i){if(Array.isArray(t)&&Array.isArray(i)){const e=new Set(t),r=new Set(i);return e.size===r.size&&t.every(e=>r.has(e))}return e.b9(t,i)}const yh=/matrix.*\((.+)\)/,xh={center:[0,0],zoom:0,bearing:0,pitch:0,minZoom:-2,maxZoom:22,minPitch:0,maxPitch:85,interactive:!0,scrollZoom:!0,boxZoom:!0,dragRotate:!0,dragPan:!0,keyboard:!0,doubleClickZoom:!0,touchZoomRotate:!0,touchPitch:!0,cooperativeGestures:!1,performanceMetricsCollection:!0,bearingSnap:7,clickTolerance:3,pitchWithRotate:!0,hash:!1,attributionControl:!0,antialias:!1,failIfMajorPerformanceCaveat:!1,preserveDrawingBuffer:!1,trackResize:!0,renderWorldCopies:!0,refreshExpiredTiles:!0,minTileCacheSize:null,maxTileCacheSize:null,localIdeographFontFamily:"sans-serif",localFontFamily:null,fontstackCompositing:"client",transformRequest:null,accessToken:null,fadeDuration:300,respectPrefersReducedMotion:!0,crossSourceCollisions:!0,collectResourceTiming:!1,testMode:!1,precompilePrograms:!0,scaleFactor:1},vh={showCompass:!0,showZoom:!0,visualizePitch:!1};class bh{constructor(t,i,r=!1){this._clickTolerance=10,this.element=i,this.mouseRotate=new Rc({clickTolerance:t.dragRotate._mouseRotate._clickTolerance}),this.map=t,r&&(this.mousePitch=new zc({clickTolerance:t.dragRotate._mousePitch._clickTolerance})),e.b0(["mousedown","mousemove","mouseup","touchstart","touchmove","touchend","reset"],this),i.addEventListener("mousedown",this.mousedown),i.addEventListener("touchstart",this.touchstart,{passive:!1}),i.addEventListener("touchmove",this.touchmove),i.addEventListener("touchend",this.touchend),i.addEventListener("touchcancel",this.reset)}down(e,t){this.mouseRotate.mousedown(e,t),this.mousePitch&&this.mousePitch.mousedown(e,t),m()}move(e,t){const i=this.map,r=this.mouseRotate.mousemoveWindow(e,t),n=r&&r.bearingDelta;if(n&&i.setBearing(i.getBearing()+n),this.mousePitch){const r=this.mousePitch.mousemoveWindow(e,t),n=r&&r.pitchDelta;n&&i.setPitch(i.getPitch()+n)}}off(){const e=this.element;e.removeEventListener("mousedown",this.mousedown),e.removeEventListener("touchstart",this.touchstart),e.removeEventListener("touchmove",this.touchmove),e.removeEventListener("touchend",this.touchend),e.removeEventListener("touchcancel",this.reset),this.offTemp()}offTemp(){_(),window.removeEventListener("mousemove",this.mousemove),window.removeEventListener("mouseup",this.mouseup)}mousedown(e){this.down(Object.assign({},e,{button:e.button,type:e.type,ctrlKey:!0,preventDefault:()=>e.preventDefault()}),x(this.element,e)),window.addEventListener("mousemove",this.mousemove),window.addEventListener("mouseup",this.mouseup)}mousemove(e){this.move(e,x(this.element,e))}mouseup(e){this.mouseRotate.mouseupWindow(e),this.mousePitch&&this.mousePitch.mouseupWindow(e),this.offTemp()}touchstart(e){1!==e.targetTouches.length?this.reset():(this._startPos=this._lastPos=v(this.element,e.targetTouches)[0],this.down({type:"mousedown",button:0,ctrlKey:!0,preventDefault:()=>e.preventDefault()},this._startPos))}touchmove(e){1!==e.targetTouches.length?this.reset():(this._lastPos=v(this.element,e.targetTouches)[0],this.move({buttons:1,preventDefault:()=>e.preventDefault()},this._lastPos))}touchend(e){0===e.targetTouches.length&&this._startPos&&this._lastPos&&this._startPos.dist(this._lastPos)<this._clickTolerance&&this.element.click(),this.reset()}reset(){this.mouseRotate.reset(),this.mousePitch&&this.mousePitch.reset(),delete this._startPos,delete this._lastPos,this.offTemp()}}function wh(t,i,r){if(t=new e.aX(t.lng,t.lat),i){const n=new e.aX(t.lng-360,t.lat),o=new e.aX(t.lng+360,t.lat),s=360*Math.ceil(Math.abs(t.lng-r.center.lng)/360),a=r.locationPoint3D(t).distSqr(i),l=i.x<0||i.y<0||i.x>r.width||i.y>r.height;r.locationPoint3D(n).distSqr(i)<a&&(l||Math.abs(n.lng-r.center.lng)<s)?t=n:r.locationPoint3D(o).distSqr(i)<a&&(l||Math.abs(o.lng-r.center.lng)<s)&&(t=o)}for(;Math.abs(t.lng-r.center.lng)>180;){const e=r.locationPoint3D(t);if(e.x>=0&&e.y>=0&&e.x<=r.width&&e.y<=r.height)break;t.lng>r.center.lng?t.lng-=360:t.lng+=360}return t}const Th={center:"translate(-50%,-50%)",top:"translate(-50%,0)","top-left":"translate(0,0)","top-right":"translate(-100%,0)",bottom:"translate(-50%,-100%)","bottom-left":"translate(0,-100%)","bottom-right":"translate(-100%,-100%)",left:"translate(0,-50%)",right:"translate(-100%,-50%)"},Sh=/\s+/,Ih={rotation:0,rotationAlignment:"auto",pitchAlignment:"auto",occludedOpacity:.2,altitude:0};class Eh extends e.E{constructor(t,i){super(),(t instanceof HTMLElement||i)&&(t=Object.assign({element:t},i)),e.b0(["_update","_onMove","_onUp","_addDragHandler","_onMapClick","_onKeyPress","_clearFadeTimer"],this);const{anchor:r="center",color:n="#3FB1CE",scale:o=1,draggable:s=!1,clickTolerance:a=0,rotation:l=Ih.rotation,rotationAlignment:c=Ih.rotationAlignment,pitchAlignment:h=Ih.pitchAlignment,occludedOpacity:u=Ih.occludedOpacity,altitude:d=Ih.altitude}=t||{};this._anchor=r,this._color=n,this._scale=o,this._draggable=s,this._clickTolerance=a,this._rotation=l,this._rotationAlignment=c,this._pitchAlignment=h,this._occludedOpacity=u,this._altitude=d,this._state="inactive",this._isDragging=!1,this._updateMoving=()=>this._update(!0),t&&t.element?(this._element=t.element,this._offset=e.P.convert(t&&t.offset||[0,0])):(this._defaultMarker=!0,this._element=this._createDefaultMarker(),this._offset=e.P.convert(t&&t.offset||[0,-14])),this._element.hasAttribute("aria-label")||this._element.setAttribute("aria-label","Map marker"),this._element.hasAttribute("role")||this._element.setAttribute("role","img"),this._element.classList.add("mapboxgl-marker"),this._element.addEventListener("dragstart",e=>{e.preventDefault()}),this._element.addEventListener("mousedown",e=>{e.preventDefault()});const p=this._element.classList;for(const e in Th)p.remove(`mapboxgl-marker-anchor-${e}`);p.add(`mapboxgl-marker-anchor-${this._anchor}`);const f=t&&t.className?t.className.trim().split(Sh):[];p.add(...f),this._popup=null}_createDefaultMarker(){const e=h("div"),t=u("svg",{display:"block",height:41*this._scale+"px",width:27*this._scale+"px",viewBox:"0 0 27 41"},e);if(0===this._altitude){const e=u("radialGradient",{id:"shadowGradient"},u("defs",{},t));u("stop",{offset:"10%","stop-opacity":.4},e),u("stop",{offset:"100%","stop-opacity":.05},e),u("ellipse",{cx:13.5,cy:34.8,rx:10.5,ry:5.25,fill:"url(#shadowGradient)"},t)}return u("path",{fill:this._color,d:"M27,13.5C27,19.07 20.25,27 14.75,34.5C14.02,35.5 12.98,35.5 12.25,34.5C6.75,27 0,19.22 0,13.5C0,6.04 6.04,0 13.5,0C20.96,0 27,6.04 27,13.5Z"},t),u("path",{opacity:.25,d:"M13.5,0C6.04,0 0,6.04 0,13.5C0,19.22 6.75,27 12.25,34.5C13,35.52 14.02,35.5 14.75,34.5C20.25,27 27,19.07 27,13.5C27,6.04 20.96,0 13.5,0ZM13.5,1C20.42,1 26,6.58 26,13.5C26,15.9 24.5,19.18 22.22,22.74C19.95,26.3 16.71,30.14 13.94,33.91C13.74,34.18 13.61,34.32 13.5,34.44C13.39,34.32 13.26,34.18 13.06,33.91C10.28,30.13 7.41,26.31 5.02,22.77C2.62,19.23 1,15.95 1,13.5C1,6.58 6.58,1 13.5,1Z"},t),u("circle",{fill:"white",cx:13.5,cy:13.5,r:5.5},t),e}addTo(e){return e===this._map||(this.remove(),this._map=e,e.getCanvasContainer().appendChild(this._element),e.on("move",this._updateMoving),e.on("moveend",this._update),e.on("remove",this._clearFadeTimer),e._addMarker(this),this.setDraggable(this._draggable),this._update(),e.on("click",this._onMapClick)),this}remove(){const e=this._map;return e&&(e.off("click",this._onMapClick),e.off("move",this._updateMoving),e.off("moveend",this._update),e.off("mousedown",this._addDragHandler),e.off("touchstart",this._addDragHandler),e.off("mouseup",this._onUp),e.off("touchend",this._onUp),e.off("mousemove",this._onMove),e.off("touchmove",this._onMove),e.off("remove",this._clearFadeTimer),e._removeMarker(this),this._map=void 0),this._clearFadeTimer(),this._element.remove(),this._popup&&this._popup.remove(),this}getLngLat(){return this._lngLat}setLngLat(t){return this._lngLat=e.aX.convert(t),this._pos=null,this._popup&&this._popup.setLngLat(this._lngLat),this._update(!0),this}setAltitude(e){return e===this._altitude||(this._defaultMarker&&(0===this._altitude&&0!==e||0!==this._altitude&&0===e)&&(this._element=this._createDefaultMarker()),this._altitude=e||Ih.altitude,this._update()),this}getAltitude(){return this._altitude}getElement(){return this._element}setPopup(e){if(this._popup&&(this._popup.remove(),this._popup=null,this._element.removeAttribute("role"),this._element.removeEventListener("keypress",this._onKeyPress),this._originalTabIndex||this._element.removeAttribute("tabindex")),e){if(!("offset"in e.options)){const t=38.1,i=13.5,r=Math.sqrt(Math.pow(i,2)/2);e.options.offset=this._defaultMarker?{top:[0,0],"top-left":[0,0],"top-right":[0,0],bottom:[0,-38.1],"bottom-left":[r,-1*(t-i+r)],"bottom-right":[-r,-1*(t-i+r)],left:[i,-1*(t-i)],right:[-13.5,-1*(t-i)]}:this._offset}this._popup=e,e._marker=this,e._altitude=this._altitude,this._lngLat&&this._popup.setLngLat(this._lngLat),this._element.setAttribute("role","button"),this._originalTabIndex=this._element.getAttribute("tabindex"),this._originalTabIndex||this._element.setAttribute("tabindex","0"),this._element.addEventListener("keypress",this._onKeyPress),this._element.setAttribute("aria-expanded","false")}return this}_onKeyPress(e){const t=e.code,i=e.charCode||e.keyCode;"Space"!==t&&"Enter"!==t&&32!==i&&13!==i||this.togglePopup()}_onMapClick(e){const t=e.originalEvent.target,i=this._element;this._popup&&(t===i||i.contains(t))&&this.togglePopup()}getPopup(){return this._popup}togglePopup(){const e=this._popup;return e?(e.isOpen()?(e.remove(),this._element.setAttribute("aria-expanded","false")):this._map&&(e.addTo(this._map),this._element.setAttribute("aria-expanded","true")),this):this}_behindTerrain(){const e=this._map,t=this._pos;if(!e||!t)return!1;const i=e.unproject(t,this._altitude),r=e.getFreeCameraOptions();if(!r.position)return!1;const n=r.position.toLngLat();return n.distanceTo(i)<.9*n.distanceTo(this._lngLat)}_evaluateOpacity(){const t=this._map;if(!t)return;const i=this._pos;if(!i||i.x<0||i.x>t.transform.width||i.y<0||i.y>t.transform.height)return void this._clearFadeTimer();const r=t.unproject(i,this._altitude);let n;t._showingGlobe()&&e.f2(t.transform,this._lngLat)?n=0:(n=1-t._queryFogOpacity(r),t.transform._terrainEnabled()&&t.getTerrain()&&this._behindTerrain()&&(n*=this._occludedOpacity)),this._element.style.opacity=`${n}`,this._element.style.pointerEvents=n>0?"auto":"none",this._popup&&this._popup._setOpacity(n),this._fadeTimer=null}_clearFadeTimer(){this._fadeTimer&&(clearTimeout(this._fadeTimer),this._fadeTimer=null)}_updateDOM(){const e=this._pos;if(!e||!this._map)return;const t=this._offset.mult(this._scale);this._element.style.transform=`\n translate(${e.x}px,${e.y}px)\n ${Th[this._anchor]}\n ${this._calculateXYTransform()} ${this._calculateZTransform()}\n translate(${t.x}px,${t.y}px)\n `}_calculateXYTransform(){const t=this._pos,i=this._map,r=this.getPitchAlignment();if(!i||!t||"map"!==r)return"";if(!i._showingGlobe()){const e=i.getPitch();return e?`rotateX(${e}deg)`:""}const n=e.cL(e.f3(i.transform,this._lngLat)),o=t.sub(e.f4(i.transform)),s=Math.abs(o.x)+Math.abs(o.y);if(0===s)return"";const a=n/s;return`rotateX(${-o.y*a}deg) rotateY(${o.x*a}deg)`}_calculateZTransform(){const t=this._pos,i=this._map;if(!i||!t)return"";let r=0;const n=this.getRotationAlignment();if("map"===n)if(i._showingGlobe()){const t=i.project(new e.aX(this._lngLat.lng,this._lngLat.lat+.001),this._altitude),n=i.project(new e.aX(this._lngLat.lng,this._lngLat.lat-.001),this._altitude).sub(t);r=e.cL(Math.atan2(n.y,n.x))-90}else r=-i.getBearing();else if("horizon"===n){const n=e.ag(4,6,i.getZoom()),o=e.f4(i.transform);o.y+=n*i.transform.height;const s=t.sub(o),a=e.cL(Math.atan2(s.y,s.x));r=(a>90?a-270:a+90)*(1-n)}return r+=this._rotation,r?`rotateZ(${r}deg)`:""}_update(e){cancelAnimationFrame(this._updateFrameId);const t=this._map;t&&(t.transform.renderWorldCopies&&(this._lngLat=wh(this._lngLat,this._pos,t.transform)),this._pos=t.project(this._lngLat,this._altitude),!0===e?this._updateFrameId=requestAnimationFrame(()=>{this._element&&this._pos&&this._anchor&&(this._pos=this._pos.round(),this._updateDOM())}):this._pos=this._pos.round(),t._requestDomTask(()=>{this._map&&(this._element&&this._pos&&this._anchor&&this._updateDOM(),(t._showingGlobe()||t.getTerrain()||t.getFog())&&!this._fadeTimer&&(this._fadeTimer=window.setTimeout(this._evaluateOpacity.bind(this),60)))}))}getOffset(){return this._offset}setOffset(t){return this._offset=e.P.convert(t),this._update(),this}addClassName(e){return this._element.classList.add(e),this}removeClassName(e){return this._element.classList.remove(e),this}toggleClassName(e){return this._element.classList.toggle(e)}_onMove(t){const i=this._map;if(!i)return;const r=this._pointerdownPos,n=this._positionDelta;if(r&&n){if(!this._isDragging){const e=this._clickTolerance||i._clickTolerance;if(t.point.dist(r)<e)return;this._isDragging=!0}this._pos=t.point.sub(n),this._lngLat=i.unproject(this._pos,this._altitude),this.setLngLat(this._lngLat),this._element.style.pointerEvents="none","pending"===this._state&&(this._state="active",this.fire(new e.z("dragstart"))),this.fire(new e.z("drag"))}}_onUp(){this._element.style.pointerEvents="auto",this._positionDelta=null,this._pointerdownPos=null,this._isDragging=!1;const t=this._map;t&&(t.off("mousemove",this._onMove),t.off("touchmove",this._onMove)),"active"===this._state&&this.fire(new e.z("dragend")),this._state="inactive"}_addDragHandler(e){const t=this._map,i=this._pos;t&&i&&this._element.contains(e.originalEvent.target)&&(e.preventDefault(),this._positionDelta=e.point.sub(i),this._pointerdownPos=e.point,this._state="pending",t.on("mousemove",this._onMove),t.on("touchmove",this._onMove),t.once("mouseup",this._onUp),t.once("touchend",this._onUp))}setDraggable(e){this._draggable=!!e;const t=this._map;return t&&(e?(t.on("mousedown",this._addDragHandler),t.on("touchstart",this._addDragHandler)):(t.off("mousedown",this._addDragHandler),t.off("touchstart",this._addDragHandler))),this}isDraggable(){return this._draggable}setRotation(e){return this._rotation=e||Ih.rotation,this._update(),this}getRotation(){return this._rotation}setRotationAlignment(e){return this._rotationAlignment=e||Ih.rotationAlignment,this._update(),this}getRotationAlignment(){return"auto"===this._rotationAlignment||"horizon"===this._rotationAlignment&&this._map&&!this._map._showingGlobe()?"viewport":this._rotationAlignment}setPitchAlignment(e){return this._pitchAlignment=e||Ih.pitchAlignment,this._update(),this}getPitchAlignment(){return"auto"===this._pitchAlignment?this.getRotationAlignment():this._pitchAlignment}setOccludedOpacity(e){return this._occludedOpacity=e||Ih.occludedOpacity,this._update(),this}getOccludedOpacity(){return this._occludedOpacity}}const Ah={positionOptions:{enableHighAccuracy:!1,maximumAge:0,timeout:6e3},fitBoundsOptions:{maxZoom:15},trackUserLocation:!1,showAccuracyCircle:!0,showUserLocation:!0,showUserHeading:!1,showButton:!0,followUserLocation:!0},Mh={maxWidth:100,unit:"metric"},Ch={kilometer:"km",meter:"m",mile:"mi",foot:"ft","nautical-mile":"nm"},Ph=/\s+/,Dh={closeButton:!0,closeOnClick:!0,focusAfterOpen:!0,className:"",maxWidth:"240px",altitude:0},Rh=["a[href]","[tabindex]:not([tabindex='-1'])","[contenteditable]:not([contenteditable='false'])","button:not([disabled])","input:not([disabled])","select:not([disabled])","textarea:not([disabled])"].join(", ");function zh(t=new e.P(0,0),i="bottom"){if("number"==typeof t){const r=Math.round(Math.sqrt(.5*Math.pow(t,2)));switch(i){case"top":return new e.P(0,t);case"top-left":return new e.P(r,r);case"top-right":return new e.P(-r,r);case"bottom":return new e.P(0,-t);case"bottom-left":return new e.P(r,-r);case"bottom-right":return new e.P(-r,-r);case"left":return new e.P(t,0);case"right":return new e.P(-t,0)}return new e.P(0,0)}return t instanceof e.P||Array.isArray(t)?e.P.convert(t):e.P.convert(t[i]||[0,0])}return{version:t,supported:a.supported,setRTLTextPlugin:e.f7,getRTLTextPluginStatus:e.f6,addTileProvider:e.f5,Map:class extends lh{constructor(t){r.mark(i.create);const n=t;if(null!=(t=Object.assign({},xh,t)).minZoom&&null!=t.maxZoom&&t.minZoom>t.maxZoom)throw new Error("maxZoom must be greater than or equal to minZoom");if(null!=t.minPitch&&null!=t.maxPitch&&t.minPitch>t.maxPitch)throw new Error("maxPitch must be greater than or equal to minPitch");if(null!=t.minPitch&&t.minPitch<0)throw new Error("minPitch must be greater than or equal to 0");if(null!=t.maxPitch&&t.maxPitch>85)throw new Error("maxPitch must be less than or equal to 85");t.antialias&&e.f0(window)&&(t.antialias=!1,e.w("Antialiasing is disabled for this WebGL context to avoid browser bug: https://github.com/mapbox/mapbox-gl-js/issues/11609")),super(new sn(t.minZoom,t.maxZoom,t.minPitch,t.maxPitch,t.renderWorldCopies,null,null),t),this._repaint=!!t.repaint,this._interactive=t.interactive,this._minTileCacheSize=t.minTileCacheSize,this._maxTileCacheSize=t.maxTileCacheSize,this._failIfMajorPerformanceCaveat=t.failIfMajorPerformanceCaveat,this._preserveDrawingBuffer=t.preserveDrawingBuffer,this._antialias=t.antialias,this._trackResize=t.trackResize,this._bearingSnap=t.bearingSnap,this._refreshExpiredTiles=t.refreshExpiredTiles,this._fadeDuration=t.fadeDuration,this._isInitialLoad=!0,this._crossSourceCollisions=t.crossSourceCollisions,this._collectResourceTiming=t.collectResourceTiming,this._language=this._parseLanguage(t.language),this._worldview=t.worldview,this._renderTaskQueue=new dh,this._domRenderTaskQueue=new dh,this._controls=[],this._markers=[],this._popups=[],this._mapId=e.an(),this._locale=Object.assign({},fh,t.locale),this._clickTolerance=t.clickTolerance,this._cooperativeGestures=t.cooperativeGestures,this._performanceMetricsCollection=t.performanceMetricsCollection,this._tessellationStep=t.tessellationStep,this._containerWidth=0,this._containerHeight=0,this._showParseStatus=!0,this._precompilePrograms=t.precompilePrograms,this._averageElevationLastSampledAt=-1/0,this._averageElevationExaggeration=0,this._averageElevation=new ph(0),this._interactionRange=[1/0,-1/0],this._visibilityHidden=0,this._useExplicitProjection=!1,this._frameId=0,this._scaleFactor=t.scaleFactor,this._requestManager=new P(t.transformRequest,t.accessToken,t.testMode);const o=F(t.accessToken||e.g.ACCESS_TOKEN);if(o&&"atlas"in o&&"number"==typeof o.atlas&&(this._tokenExpiration=o.atlas),this._silenceAuthErrors=!!t.testMode,this._contextCreateOptions=t.contextCreateOptions?Object.assign({},t.contextCreateOptions):{},"string"==typeof t.container){const e=document.getElementById(t.container);if(!e)throw new Error(`Container '${t.container.toString()}' not found.`);this._container=e}else{if(!(t.container instanceof HTMLElement))throw new Error("Invalid type: 'container' must be a String or HTMLElement.");this._container=t.container}if(this._container.childNodes.length>0&&e.w("The map container element should be empty, otherwise the map's interactivity will be negatively impacted. If you want to display a message when WebGL is not supported, use the Mapbox GL Supported plugin instead."),t.maxBounds&&this.setMaxBounds(t.maxBounds),this._spriteFormat="auto",e.b0(["_onWindowOnline","_onWindowResize","_onVisibilityChange","_onMapScroll","_contextLost","_contextRestored"],this),this._setupContainer(),this._setupPainter(),void 0===this.painter)throw new Error("Failed to initialize WebGL.");if(this.on("move",()=>this._update(!1)),this.on("moveend",()=>this._update(!1)),this.on("zoom",()=>this._update(!0)),this._fullscreenchangeEvent="onfullscreenchange"in document?"fullscreenchange":"webkitfullscreenchange",window.addEventListener("online",this._onWindowOnline,!1),window.addEventListener("resize",this._onWindowResize,!1),window.addEventListener("orientationchange",this._onWindowResize,!1),window.addEventListener(this._fullscreenchangeEvent,this._onWindowResize,!1),window.addEventListener("visibilitychange",this._onVisibilityChange,!1),this.handlers=new sh(this,t),this._localFontFamily=t.localFontFamily,this._localIdeographFontFamily=t.localIdeographFontFamily,this._fontstackCompositing=t.fontstackCompositing,(t.style||!t.testMode)&&this.setStyle(t.style||e.g.DEFAULT_STYLE,{config:t.config,localFontFamily:this._localFontFamily,localIdeographFontFamily:this._localIdeographFontFamily,fontstackCompositing:this._fontstackCompositing}),t.projection&&this.setProjection(t.projection),t.hash&&(this._hash=new sc("string"==typeof t.hash&&t.hash||void 0).addTo(this)),!this._hash||!this._hash._onHashChange()){null==n.center&&null==n.zoom||(this.transform._unmodified=!1),this.jumpTo({center:t.center,zoom:t.zoom,bearing:t.bearing,pitch:t.pitch});const e=t.bounds;e&&(this.resize(),this.fitBounds(e,Object.assign({},t.fitBoundsOptions,{duration:0})))}this.resize(),t.attributionControl&&this.addControl(new hh({customAttribution:t.customAttribution})),this._logoControl=new uh,this.addControl(this._logoControl,t.logoPosition),this.on("style.load",()=>{this.transform.unmodified&&this.jumpTo(this.style.stylesheet),this._postStyleLoadEvent(),this._postStyleWithAppearanceEvent()}),this.on("data",t=>{this._update("style"===t.dataType),this.fire(new e.z(`${t.dataType}data`,t))}),this.on("dataloading",t=>{this.fire(new e.z(`${t.dataType}dataloading`,t))}),this._interactions=new _h(this)}_getMapId(){return this._mapId}addControl(t,i){if(void 0===i&&(i=t.getDefaultPosition?t.getDefaultPosition():"top-right"),!t||!t.onAdd)return this.fire(new e.y(/* @__PURE__ */new Error("Invalid argument to map.addControl(). Argument must be a control with onAdd and onRemove methods.")));const r=t.onAdd(this);this._controls.push(t);const n=this._controlPositions[i];return i.includes("bottom")?n.insertBefore(r,n.firstChild):n.appendChild(r),this}removeControl(t){if(!t||!t.onRemove)return this.fire(new e.y(/* @__PURE__ */new Error("Invalid argument to map.removeControl(). Argument must be a control with onAdd and onRemove methods.")));const i=this._controls.indexOf(t);return i>-1&&this._controls.splice(i,1),t.onRemove(this),this}hasControl(e){return this._controls.includes(e)}getContainer(){return this._container}getCanvasContainer(){return this._canvasContainer}getCanvas(){return this._canvas}resize(t){if(this._updateContainerDimensions(),this._containerWidth===this.transform.width&&this._containerHeight===this.transform.height)return this;this._resizeCanvas(this._containerWidth,this._containerHeight),this.transform.resize(this._containerWidth,this._containerHeight),this.painter.resize(Math.ceil(this._containerWidth),Math.ceil(this._containerHeight));const i=!this._moving;return i&&this.fire(new e.z("movestart",t)).fire(new e.z("move",t)),this.fire(new e.z("resize",t)),i&&this.fire(new e.z("moveend",t)),this}getBounds(){return this.transform.getBounds()}getMaxBounds(){return this.transform.getMaxBounds()||null}setMaxBounds(t){return this.transform.setMaxBounds(e.aI.convert(t)),this._update()}setMinZoom(t){if((t=t??-2)>=-2&&t<=this.transform.maxZoom)return this.transform.minZoom=t,this._update(),this.getZoom()<t?this.setZoom(t):this.fire(new e.z("zoomstart")).fire(new e.z("zoom")).fire(new e.z("zoomend")),this;throw new Error("minZoom must be between -2 and the current maxZoom, inclusive")}getMinZoom(){return this.transform.minZoom}setMaxZoom(t){if((t=t??22)>=this.transform.minZoom)return this.transform.maxZoom=t,this._update(),this.getZoom()>t?this.setZoom(t):this.fire(new e.z("zoomstart")).fire(new e.z("zoom")).fire(new e.z("zoomend")),this;throw new Error("maxZoom must be greater than the current minZoom")}getMaxZoom(){return this.transform.maxZoom}setMinPitch(t){if((t=t??0)<0)throw new Error("minPitch must be greater than or equal to 0");if(t>=0&&t<=this.transform.maxPitch)return this.transform.minPitch=t,this._update(),this.getPitch()<t?this.setPitch(t):this.fire(new e.z("pitchstart")).fire(new e.z("pitch")).fire(new e.z("pitchend")),this;throw new Error("minPitch must be between 0 and the current maxPitch, inclusive")}getMinPitch(){return this.transform.minPitch}setMaxPitch(t){if((t=t??85)>85)throw new Error("maxPitch must be less than or equal to 85");if(t>=this.transform.minPitch)return this.transform.maxPitch=t,this._update(),this.getPitch()>t?this.setPitch(t):this.fire(new e.z("pitchstart")).fire(new e.z("pitch")).fire(new e.z("pitchend")),this;throw new Error("maxPitch must be greater than or equal to minPitch")}getMaxPitch(){return this.transform.maxPitch}getScaleFactor(){return this._scaleFactor}setScaleFactor(e){return this._scaleFactor=e,this.painter.scaleFactor=e,this.style&&this.style._setLabelPlacementStale(),this.style._updateFilteredLayers(e=>"symbol"===e.type),this._update(!0),this}getRenderWorldCopies(){return this.transform.renderWorldCopies}setRenderWorldCopies(e){return this.transform.renderWorldCopies=e,this.transform.renderWorldCopies||this._forceMarkerAndPopupUpdate(!0),this._update()}getLanguage(){return this._language}_parseLanguage(e){return"auto"===e?navigator.language:Array.isArray(e)?0===e.length?void 0:e.map(e=>"auto"===e?navigator.language:e):e}setLanguage(e){const t=this._parseLanguage(e);if(!this.style||t===this._language)return this;this._language=t,this.style.reloadSources();for(const i of this._controls)i._setLanguage&&i._setLanguage(this._language);return this}getWorldview(){return this._worldview}setWorldview(e){return this.style&&e!==this._worldview?(this._worldview=e,this._styleDirty=!0,this.style.setWorldview(e),this):this}getProjection(){return this.transform.mercatorFromTransition?{name:"globe",center:[0,0]}:this.transform.getProjection()}_showingGlobe(){return"globe"===this.transform.projection.name}setProjection(e){return this._lazyInitEmptyStyle(),e?"string"==typeof e&&(e={name:e}):e=null,this._useExplicitProjection=!!e,this._prioritizeAndUpdateProjection(e,this.style.projection)}_updateProjectionTransition(){if("globe"!==this.getProjection().name)return;const t=this.transform,i=t.projection.name;let r;"globe"===i&&t.zoom>=e.cx?(t.setMercatorFromTransition(),r=!0):"mercator"===i&&t.zoom<e.cx&&(t.setProjection({name:"globe"}),r=!0),r&&(this.style.applyProjectionUpdate(),this.style._forceSymbolLayerUpdate(),this._update(!0))}_prioritizeAndUpdateProjection(e,t){return this._updateProjection(e||t||{name:"mercator"})}_updateProjection(t){let i;const r=this.transform.mercatorFromTransition;i="globe"===t.name&&this.transform.zoom>=e.cx?this.transform.setMercatorFromTransition():this.transform.setProjection(t),this.style.applyProjectionUpdate();const n="mercator"===this.transform.getProjection().name&&r!==this.transform.mercatorFromTransition;return(i||n)&&(this.painter.clearBackgroundTiles(),this.style.clearSources(),this._update(!0),this._forceMarkerAndPopupUpdate(!0)),this}project(t,i){return this.transform.locationPoint3D(e.aX.convert(t),i)}unproject(t,i){return this.transform.pointLocation3D(e.P.convert(t),i)}isMoving(){return this._moving||this.handlers&&this.handlers.isMoving()||!1}isZooming(){return this._zooming||this.handlers&&this.handlers.isZooming()||!1}isRotating(){return this._rotating||this.handlers&&this.handlers.isRotating()||!1}_isDragging(){return this.handlers&&this.handlers._isDragging()||!1}_createDelegatedListener(e,t,i){const r=e=>{let i=[];if(Array.isArray(t)){const r=t.filter(e=>this.getLayer(e));i=r.length?this.queryRenderedFeatures(e,{layers:r}):[]}else i=this.queryRenderedFeatures(e,{target:t});return i};if("mouseenter"===e||"mouseover"===e){let n=!1;const o=t=>{const o=r(t.point);o.length?n||(n=!0,i.call(this,new _c(e,this,t.originalEvent,{features:o}))):n=!1};return{listener:i,targets:t,delegates:{mousemove:o,mouseout:()=>{n=!1}}}}if("mouseleave"===e||"mouseout"===e){let n=!1;const o=t=>{r(t.point).length?n=!0:n&&(n=!1,i.call(this,new _c(e,this,t.originalEvent)))},s=t=>{n&&(n=!1,i.call(this,new _c(e,this,t.originalEvent)))};return{listener:i,targets:t,delegates:{mousemove:o,mouseout:s}}}{const n=e=>{const t=r(e.point);t.length&&(e.features=t,i.call(this,e),delete e.features)};return{listener:i,targets:t,delegates:{[e]:n}}}}on(e,t,i){if("function"==typeof t||void 0===i)return super.on(e,t);if("string"==typeof t&&(t=[t]),!this._areTargetsValid(t))return this;const r=this._createDelegatedListener(e,t,i);this._delegatedListeners=this._delegatedListeners||{},this._delegatedListeners[e]=this._delegatedListeners[e]||[],this._delegatedListeners[e].push(r);for(const n in r.delegates)this.on(n,r.delegates[n]);return this}once(e,t,i){if("function"==typeof t||void 0===i)return super.once(e,t);if("string"==typeof t&&(t=[t]),!this._areTargetsValid(t))return this;const r=this._createDelegatedListener(e,t,i);for(const n in r.delegates)this.once(n,r.delegates[n]);return this}off(e,t,i){if("function"==typeof t||void 0===i)return super.off(e,t);if("string"==typeof t&&(t=[t]),!this._areTargetsValid(t))return this;const r=this._delegatedListeners?this._delegatedListeners[e]:void 0;return r&&(e=>{for(let r=0;r<e.length;r++){const n=e[r];if(n.listener===i&&gh(n.targets,t)){for(const e in n.delegates)this.off(e,n.delegates[e]);return e.splice(r,1),this}}})(r),this}queryRenderedFeatures(t,i){if(!this.style)return[];if(void 0===t||t instanceof e.P||Array.isArray(t)||void 0!==i||(i=t,t=void 0),t=t||[[0,0],[this.transform.width,this.transform.height]],!i){const e=this.style.queryRenderedFeatures(t,void 0,this.transform),i=this.style.queryRenderedFeatureset(t,void 0,this.transform);return e.concat(i)}let r=!0;if(i.target&&(r=this._isTargetValid(i.target),r&&!i.layers))return this.style.queryRenderedFeatureset(t,i,this.transform);let n=!0;if(i.layers&&Array.isArray(i.layers)){for(const e of i.layers)if(!this._isValidId(e)){n=!1;break}if(n&&!i.target)return this.style.queryRenderedFeatures(t,i,this.transform)}let o=[];return n&&(o=o.concat(this.style.queryRenderedFeatures(t,i,this.transform))),r&&(o=o.concat(this.style.queryRenderedFeatureset(t,i,this.transform))),o}querySourceFeatures(e,t){return!e||"string"==typeof e&&!this._isValidId(e)?[]:this.style.querySourceFeatures(e,t)}queryRasterValue(e,t,i){return this._isValidId(e)?this.style.queryRasterValue(e,t,i):Promise.resolve(null)}isPointOnSurface(t){const{name:i}=this.transform.projection;return"globe"!==i&&"mercator"!==i&&e.w(`${i} projection does not support isPointOnSurface, this API may behave unexpectedly.`),this.transform.isPointOnSurface(e.P.convert(t))}addInteraction(e,t){return this._interactions.add(e,t),this}removeInteraction(e){return this._interactions.remove(e),this}getCooperativeGestures(){return this._cooperativeGestures}setCooperativeGestures(e){return this._cooperativeGestures=e,this}setStyle(t,i){return i=Object.assign({},{localIdeographFontFamily:this._localIdeographFontFamily,localFontFamily:this._localFontFamily,fontstackCompositing:this._fontstackCompositing},i),this.style&&t&&!1!==i.diff&&i.localFontFamily===this._localFontFamily&&i.localIdeographFontFamily===this._localIdeographFontFamily&&i.fontstackCompositing===this._fontstackCompositing&&!i.config?(this.style._diffStyle(t,(r,n)=>{if(r){const n="string"==typeof r?r:r instanceof Error?r.message:r.error;e.w(`Unable to perform style diff: ${n}. Rebuilding the style from scratch.`),this._updateStyle(t,i)}else n&&this._update(!0)},()=>this._postStyleLoadEvent()),this):(this._localIdeographFontFamily=i.localIdeographFontFamily,this._localFontFamily=i.localFontFamily,this._fontstackCompositing=i.fontstackCompositing,this._updateStyle(t,i))}_getUIString(e){const t=this._locale[e];if(null==t)throw new Error(`Missing UI string '${e}'`);return t}_updateStyle(e,t){if(this.style&&(this.style.setEventedParent(null),this.style._remove(),this.style=void 0),e){const i=Object.assign({},t);t&&t.config&&(i.initialConfig=t.config,delete i.config),this.style=new On(this,i).load(e),this.style.setEventedParent(this,{style:this.style})}return this._updateTerrain(),this}_lazyInitEmptyStyle(){this.style||(this.style=new On(this,{}),this.style.setEventedParent(this,{style:this.style}),this.style.loadEmpty())}getStyle(){if(this.style)return this.style.serialize()}isStyleLoaded(){return this.style?this.style.loaded():(e.w("There is no style added to the map."),!1)}_isValidId(t){return null==t?(this.fire(new e.y(/* @__PURE__ */new Error("IDs can't be empty."))),!1):!e.de(t)||(this.fire(new e.y(/* @__PURE__ */new Error(`IDs can't contain special symbols: "${t}".`))),!1)}_isTargetValid(e){return"featuresetId"in e?this._isValidId("importId"in e?e.importId:e.featuresetId):"layerId"in e&&this._isValidId(e.layerId)}_areTargetsValid(e){if(Array.isArray(e)){for(const t of e)if(!this._isValidId(t))return!1;return!0}return this._isTargetValid(e)}addSource(e,t){return this._isValidId(e)?(this._lazyInitEmptyStyle(),this.style.addSource(e,t),this._update(!0)):this}isSourceLoaded(e){return!!this._isValidId(e)&&!!this.style&&this.style._isSourceCacheLoaded(e)}areTilesLoaded(){return this.style.areTilesLoaded()}addSourceType(e,t,i){this._lazyInitEmptyStyle(),this.style.addSourceType(e,t,i)}removeSource(e){return this._isValidId(e)?(this.style.removeSource(e),this._updateTerrain(),this._update(!0)):this}getSource(e){return this._isValidId(e)?this.style.getOwnSource(e):null}addImage(t,i,{pixelRatio:r=1,sdf:n=!1,stretchX:o,stretchY:s,content:a}={}){this._lazyInitEmptyStyle();const l=e.I.from(t);if(i instanceof HTMLImageElement||ImageBitmap&&i instanceof ImageBitmap){const{width:t,height:c,data:h}=e.o.getImageData(i);this.style.addImage(l,{data:new e.q({width:t,height:c},h),pixelRatio:r,stretchX:o,stretchY:s,content:a,sdf:n,version:0,usvg:!1})}else if(void 0===i.width||void 0===i.height)this.fire(new e.y(/* @__PURE__ */new Error("Invalid arguments to map.addImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));else{const{width:c,height:h}=i,u=i;this.style.addImage(l,{data:new e.q({width:c,height:h},new Uint8Array(u.data)),pixelRatio:r,stretchX:o,stretchY:s,content:a,sdf:n,usvg:!1,version:0,userImage:u}),u.onAdd&&u.onAdd(this,t)}}updateImage(t,i){this._lazyInitEmptyStyle();const r=e.I.from(t),n=this.style.getImage(r);if(!n)return void this.fire(new e.y(/* @__PURE__ */new Error("The map has no image with that id. If you are adding a new image use `map.addImage(...)` instead.")));const{width:o,height:s,data:a}=i instanceof HTMLImageElement||ImageBitmap&&i instanceof ImageBitmap?e.o.getImageData(i):i;if(void 0===o||void 0===s)return void this.fire(new e.y(/* @__PURE__ */new Error("Invalid arguments to map.updateImage(). The second argument must be an `HTMLImageElement`, `ImageData`, `ImageBitmap`, or object with `width`, `height`, and `data` properties with the same format as `ImageData`")));if(o!==(n.usvg?n.icon.usvg_tree.width:n.data.width)||s!==(n.usvg?n.icon.usvg_tree.height:n.data.height))return void this.fire(new e.y(/* @__PURE__ */new Error(`The width and height of the updated image (${o}, ${s})\n must be that same as the previous version of the image\n (${n.data.width}, ${n.data.height})`)));const l=!(i instanceof HTMLImageElement||ImageBitmap&&i instanceof ImageBitmap);let c=!1;n.usvg?(n.data=new e.q({width:o,height:s},new Uint8Array(a)),n.usvg=!1,n.icon=void 0,c=!0):n.data.replace(a,l),this.style.updateImage(r,n,c)}hasImage(t){return t?!!this.style&&!!this.style.getImage(e.I.from(t)):(this.fire(new e.y(/* @__PURE__ */new Error("Missing required image id"))),!1)}removeImage(t){this.style.removeImage(e.I.from(t))}loadImage(t,i){e.n(this._requestManager.transformRequest(t,e.R.Image),(e,t)=>{i(e,t)})}listImages(){return this.style.listImages().map(e=>e.name)}addModel(e,t){this._lazyInitEmptyStyle(),this.style.addModel(e,t)}hasModel(t){return t?this.style.hasModel(t):(this.fire(new e.y(/* @__PURE__ */new Error("Missing required model id"))),!1)}removeModel(e){this.style.removeModel(e)}listModels(){return this.style.listModels()}addLayer(e,t){return this._isValidId(e.id)?(this._lazyInitEmptyStyle(),this.style.addLayer(e,t),this._update(!0)):this}getSlot(e){const t=this.getLayer(e);return t&&t.slot||null}setSlot(e,t){return this.style.setSlot(e,t),this.style.mergeLayers(),this._update(!0)}addImport(t,i){return this.style.addImport(t,i).catch(t=>this.fire(new e.y(new Error("Failed to add import",t)))),this}updateImport(e,t){return"string"!=typeof t&&t.id!==e?(this.removeImport(e),this.addImport(t)):(this.style.updateImport(e,t),this._update(!0))}removeImport(e){return this.style.removeImport(e),this}moveImport(e,t){return this.style.moveImport(e,t),this._update(!0)}moveLayer(e,t){return this._isValidId(e)?(this.style.moveLayer(e,t),this._update(!0)):this}removeLayer(e){return this._isValidId(e)?(this.style.removeLayer(e),this._update(!0)):this}getLayer(e){if(!this._isValidId(e))return null;const t=this.style.getOwnLayer(e);return t?"custom"===t.type?t.implementation:t.serialize():void 0}getSlots(){return this.style.getSlots()}setLayerZoomRange(e,t,i){return this._isValidId(e)?(this.style.setLayerZoomRange(e,t,i),this._update(!0)):this}setFilter(e,t,i={}){return this._isValidId(e)?(this.style.setFilter(e,t,i),this._update(!0)):this}getFilter(e){return this._isValidId(e)?this.style.getFilter(e):null}setPaintProperty(e,t,i,r={}){return this._isValidId(e)?(this.style.setPaintProperty(e,t,i,r),this._update(!0)):this}getPaintProperty(e,t){return this._isValidId(e)?this.style.getPaintProperty(e,t):null}setLayoutProperty(e,t,i,r={}){return this._isValidId(e)?(this.style.setLayoutProperty(e,t,i,r),this._update(!0)):this}getLayoutProperty(e,t){return this._isValidId(e)?this.style.getLayoutProperty(e,t):null}setLayerProperty(e,t,i,r={}){return this._isValidId(e)?("appearances"===t&&this._postAddingAppearancesToStyleEvent(),this.style.setLayerProperty(e,t,i,r),this._update(!0)):this}getGlyphsUrl(){return this.style.getGlyphsUrl()}setGlyphsUrl(e){return this.style.setGlyphsUrl(e),this._update(!0)}getSchema(e){return this.style.getSchema(e)}setSchema(e,t){return this.style.setSchema(e,t),this._update(!0)}getConfig(e){return this.style.getConfig(e)}setConfig(e,t){return this.style.setConfig(e,t),this._update(!0)}getConfigProperty(e,t){return this.style.getConfigProperty(e,t)}setConfigProperty(e,t,i){return this.style.setConfigProperty(e,t,i),this._update(!0)}getFeaturesetDescriptors(e){return this.style.getFeaturesetDescriptors(e)}setLights(e){if(this._lazyInitEmptyStyle(),e&&1===e.length&&"flat"===e[0].type){const t=e[0];t.properties?this.style.setFlatLight(t.properties,t.id,{}):this.style.setFlatLight({},"flat")}else this.style.setLights(e),this.painter.terrain&&(this.painter.terrain.invalidateRenderCache=!0);return this._update(!0)}getLights(){const e=this.style.getLights()||[];return 0===e.length&&e.push({id:this.style.light.id,type:"flat",properties:this.style.getFlatLight()}),e}setLight(e,t={}){return console.log("The `map.setLight` function is deprecated, prefer using `map.setLights` with `flat` light type instead."),this.setLights([{id:"flat",type:"flat",properties:e}])}getLight(){return console.log("The `map.getLight` function is deprecated, prefer using `map.getLights` instead."),this.style.getFlatLight()}setTerrain(e){return this._lazyInitEmptyStyle(),!e&&this.transform.projection.requiresDraping?this.style.setTerrainForDraping():this.style.setTerrain(e),this._averageElevationLastSampledAt=-1/0,this._update(!0)}getTerrain(){return this.style?this.style.getTerrain():null}setFog(e){return this._lazyInitEmptyStyle(),this.style.setFog(e),this._update(!0)}getFog(){return this.style?this.style.getFog():null}setSnow(e){return this._lazyInitEmptyStyle(),this.style.setSnow(e),this._update(!0)}getSnow(){return this.style?this.style.getSnow():null}setRain(e){return this._lazyInitEmptyStyle(),this.style.setRain(e),this._update(!0)}getRain(){return this.style?this.style.getRain():null}setColorTheme(e){return this._lazyInitEmptyStyle(),this.style.setColorTheme(e),this._update(!0)}setImportColorTheme(e,t){return this._lazyInitEmptyStyle(),this.style.setImportColorTheme(e,t),this._update(!0)}setCamera(e){return this.style.setCamera(e),this._triggerCameraUpdate(e)}getNearClipOffset(){return this.transform.nearClipOffset}setNearClipOffset(e){const t=this.transform.nearClipOffset!==e;return this.transform.nearClipOffset=e,this._update(t)}_triggerCameraUpdate(e){return this._update(this.transform.setOrthographicProjectionAtLowPitch("orthographic"===e["camera-projection"]))}getCamera(){return this.style.camera}_queryFogOpacity(t){return this.style&&this.style.fog?this.style.fog.getOpacityAtLatLng(e.aX.convert(t),this.transform):0}setFeatureState(e,t){return e.source&&!this._isValidId(e.source)?this:(this.style.setFeatureState(e,t),this._update())}removeFeatureState(e,t){return e.source&&!this._isValidId(e.source)?this:(this.style.removeFeatureState(e,t),this._update())}getFeatureState(e){return e.source&&!this._isValidId(e.source)?null:this.style.getFeatureState(e)}_selectIndoorFloor(e){this.style.indoorManager.selectFloor(e)}_setIndoorActiveFloorsVisibility(e){this.style.indoorManager.setActiveFloorsVisibility(e)}getIndoorTileOptions(e,t){return this.style&&this.style.isIndoorEnabled()?this.style.indoorManager.getIndoorTileOptions(e,t):null}_updateContainerDimensions(){if(!this._container)return;const e=this._container.getBoundingClientRect().width||400,t=this._container.getBoundingClientRect().height||300;let i,r,n,o=this._container;for(;o&&(!r||!n);){const e=window.getComputedStyle(o).transform;e&&"none"!==e&&(i=e.match(yh)[1].split(", "),i[0]&&"0"!==i[0]&&"1"!==i[0]&&(r=i[0]),i[3]&&"0"!==i[3]&&"1"!==i[3]&&(n=i[3])),o=o.parentElement}this._containerWidth=r?Math.abs(e/r):e,this._containerHeight=n?Math.abs(t/n):t}_detectMissingCSS(){"rgb(250, 128, 114)"!==window.getComputedStyle(this._missingCSSCanary).getPropertyValue("background-color")&&e.w("This page appears to be missing CSS declarations for Mapbox GL JS, which may cause the map to display incorrectly. Please ensure your page includes mapbox-gl.css, as described in https://www.mapbox.com/mapbox-gl-js/api/.")}_setupContainer(){const e=this._container;e.classList.add("mapboxgl-map"),(this._missingCSSCanary=h("div","mapboxgl-canary",e)).style.visibility="hidden",this._detectMissingCSS();const t=this._canvasContainer=h("div","mapboxgl-canvas-container",e);this._canvas=h("canvas","mapboxgl-canvas",t),this._interactive&&(t.classList.add("mapboxgl-interactive"),this._canvas.setAttribute("tabindex","0")),this._canvas.addEventListener("webglcontextlost",this._contextLost,!1),this._canvas.addEventListener("webglcontextrestored",this._contextRestored,!1),this._canvas.setAttribute("aria-label",this._getUIString("Map.Title")),this._canvas.setAttribute("role","region"),this._updateContainerDimensions(),this._resizeCanvas(this._containerWidth,this._containerHeight);const i=this._controlContainer=h("div","mapboxgl-control-container",e),r=this._controlPositions={};["top-left","top","top-right","right","bottom-right","bottom","bottom-left","left"].forEach(e=>{r[e]=h("div",`mapboxgl-ctrl-${e}`,i)}),this._container.addEventListener("scroll",this._onMapScroll,!1)}_resizeCanvas(t,i){const r=e.o.devicePixelRatio||1;this._canvas.width=r*Math.ceil(t),this._canvas.height=r*Math.ceil(i),this._canvas.style.width=`${t}px`,this._canvas.style.height=`${i}px`}_addMarker(e){this._markers.push(e)}_removeMarker(e){const t=this._markers.indexOf(e);-1!==t&&this._markers.splice(t,1)}_addPopup(e){this._popups.push(e)}_removePopup(e){const t=this._popups.indexOf(e);-1!==t&&this._popups.splice(t,1)}_setupPainter(){const t=Object.assign({},a.supported.webGLContextAttributes,{failIfMajorPerformanceCaveat:this._failIfMajorPerformanceCaveat,preserveDrawingBuffer:this._preserveDrawingBuffer,antialias:this._antialias||!1}),i=this._canvas.getContext("webgl2",t);i?(ee(i,!0),this.painter=new rc(i,this._contextCreateOptions,this.transform,this._scaleFactor,this._worldview),this.on("data",e=>{if("source"===e.dataType){const t=this.transform.elevation?this.transform.elevation._source():null;t&&e.sourceCacheId===t.id&&this.style&&this.style._setLabelPlacementStale(),this.painter.setTileLoadedFlag(!0)}}),e.k.testSupport(i)):this.fire(new e.y(/* @__PURE__ */new Error("Failed to initialize WebGL")))}_contextLost(t){t.preventDefault(),this._frame&&(this._frame.cancel(),this._frame=null),this.style&&this.style.handleContextLost(),this.fire(new e.z("webglcontextlost",{originalEvent:t}))}_contextRestored(t){this._setupPainter(),this.painter.resize(Math.ceil(this._containerWidth),Math.ceil(this._containerHeight)),this._updateTerrain(),this.style&&(this.style.clearLayers(),this.style.imageManager.destroyAtlasTextures(),this.style.imageManager.imageAtlasCache.destroyTextures(),this.style.reloadModels(),this.style.clearSources()),this._update(),this.fire(new e.z("webglcontextrestored",{originalEvent:t}))}_onMapScroll(e){if(e.target===this._container)return this._container.scrollTop=0,this._container.scrollLeft=0,!1}idle(){return!this.isMoving()&&this.loaded()}loaded(){return!this._styleDirty&&!this._sourcesDirty&&!!this.style&&this.style.loaded()}frameReady(){return this.loaded()&&!this._placementDirty}_update(e){return this.style?(this._styleDirty=this._styleDirty||e,this._sourcesDirty=!0,this.triggerRepaint(),this):this}_requestRenderFrame(e){return this._update(),this._renderTaskQueue.add(e)}_cancelRenderFrame(e){this._renderTaskQueue.remove(e)}_requestDomTask(e){!this.loaded()||this.loaded()&&!this.isMoving()?e():this._domRenderTaskQueue.add(e)}_render(t){let n;this.fire(new e.z("renderstart")),++this._frameId;const o=this.painter.context.extTimerQuery,s=e.o.now(),a=this.painter.context.gl;if(this.listens("gpu-timing-frame")&&(n=a.createQuery(),a.beginQuery(o.TIME_ELAPSED_EXT,n)),this.painter.context.setDirty(),this.painter.setBaseState(),(this.isMoving()||this.isRotating()||this.isZooming())&&(this._interactionRange[0]=Math.min(this._interactionRange[0],performance.now()),this._interactionRange[1]=Math.max(this._interactionRange[1],performance.now())),this._renderTaskQueue.run(t),this._domRenderTaskQueue.run(t),this._removed)return;this._updateProjectionTransition();const l=this._isInitialLoad?0:this._fadeDuration;if(this.style&&this._styleDirty){this._styleDirty=!1;const t=this.transform.zoom,i=this.transform.pitch,r=e.o.now(),n=new e.ab(t,{now:r,fadeDuration:l,pitch:i,transition:this.style.transition,worldview:this._worldview});this.style.update(n)}this.style&&this.style.hasFogTransition()&&(this.style._markersNeedUpdate=!0,this._sourcesDirty=!0);let c=!1;if(this.style&&this._sourcesDirty?(this._sourcesDirty=!1,this.painter._updateFog(this.style),this._updateTerrain(),c=this._updateAverageElevation(s),this.style.updateSources(this.transform),this.style.updateImageProviders(),this.isMoving()||this._forceMarkerAndPopupUpdate()):c=this._updateAverageElevation(s),this.style&&(this._placementDirty=this.style._updatePlacement(this.painter.transform,this.showCollisionBoxes,l,this._crossSourceCollisions,this.painter.replacementSource)),this.style&&this.painter.render(this.style,{showTileBoundaries:this.showTileBoundaries,showParseStatus:this.showParseStatus,wireframe:{terrain:this.showTerrainWireframe,layers2D:this.showLayers2DWireframe,layers3D:this.showLayers3DWireframe},showOverdrawInspector:this._showOverdrawInspector,showQueryGeometry:!!this._showQueryGeometry,showTileAABBs:this.showTileAABBs,rotating:this.isRotating(),zooming:this.isZooming(),moving:this.isMoving(),fadeDuration:l,isInitialLoad:this._isInitialLoad,showPadding:this.showPadding,gpuTiming:!!this.listens("gpu-timing-layer"),gpuTimingDeferredRender:!!this.listens("gpu-timing-deferred-render"),speedIndexTiming:this.speedIndexTiming}),this.fire(new e.z("render")),this.loaded()&&!this._loaded&&(this._loaded=!0,r.mark(i.load),this.fire(new e.z("load"))),this.style&&this.style.hasTransitions()&&(this._styleDirty=!0),this.style&&(this.style.snow||this.style.rain)&&(this._styleDirty=!0),this.style&&this.style.imageManager.hasPatternsInFlight()&&(this._styleDirty=!0),this.style&&!this.style.modelManager.isLoaded()&&(this._styleDirty=!0),this.style&&!this._placementDirty&&this.style._releaseSymbolFadeTiles(),n){const t=e.o.now()-s;a.endQuery(o.TIME_ELAPSED_EXT),setTimeout(()=>{const i=a.getQueryParameter(n,a.QUERY_RESULT)/1e6;a.deleteQuery(n),this.fire(new e.z("gpu-timing-frame",{cpuTime:t,gpuTime:i}))},50)}if(this.listens("gpu-timing-layer")){const t=this.painter.collectGpuTimers();setTimeout(()=>{const i=this.painter.queryGpuTimers(t);this.fire(new e.z("gpu-timing-layer",{layerTimes:i}))},50)}if(this.listens("gpu-timing-deferred-render")){const t=this.painter.collectDeferredRenderGpuQueries();setTimeout(()=>{const i=this.painter.queryGpuTimeDeferredRender(t);this.fire(new e.z("gpu-timing-deferred-render",{gpuTime:i}))},50)}const h=this._sourcesDirty||this._styleDirty||this._placementDirty||c;if(h||this._repaint)this.triggerRepaint();else{const t=this.idle();if(t&&(c=this._updateAverageElevation(s,!0)),c)this.triggerRepaint();else{if(this._triggerFrame(!1),t&&(this.fire(new e.z("idle")),this._isInitialLoad=!1,this.speedIndexTiming)){const t=this._calculateSpeedIndex();this.fire(new e.z("speedindexcompleted",{speedIndex:t})),this.speedIndexTiming=!1}t&&this.style&&this.style.handleIdle()}}!this._loaded||this._fullyLoaded||h||(this._fullyLoaded=!0,r.mark(i.fullLoad),this._performanceMetricsCollection&&Y(this._requestManager._customAccessToken,{width:this.painter.width,height:this.painter.height,interactionRange:this._interactionRange,visibilityHidden:this._visibilityHidden,terrainEnabled:!!this.painter.style.getTerrain(),fogEnabled:!!this.painter.style.getFog(),projection:this.getProjection().name,zoom:this.transform.zoom,renderer:this.painter.context.renderer,vendor:this.painter.context.vendor}),this._authenticate())}_forceMarkerAndPopupUpdate(e){for(const t of this._markers)e&&!this.getRenderWorldCopies()&&(t._lngLat=t._lngLat.wrap()),t._update();for(const t of this._popups)!e||this.getRenderWorldCopies()||t._trackPointer||(t._lngLat=t._lngLat.wrap()),t._update()}_updateAverageElevation(e,t=!1){const i=e=>(this.transform.averageElevation=e,this._update(!1),!0);if(!this.painter.averageElevationNeedsEasing())return 0!==this.transform.averageElevation&&i(0);const r=this.transform.elevation&&this.transform.elevation.exaggeration()!==this._averageElevationExaggeration;if(r||(t||e-this._averageElevationLastSampledAt>500)&&!this._averageElevation.isEasing(e)){const t=this.transform.averageElevation;let n=this.transform.sampleAverageElevation();null!=this.transform.elevation&&(this._averageElevationExaggeration=this.transform.elevation.exaggeration()),isNaN(n)?n=0:this._averageElevationLastSampledAt=e;const o=Math.abs(t-n);if(o>1){if(this._isInitialLoad||r)return this._averageElevation.jumpTo(n),i(n);this._averageElevation.easeTo(n,e,300)}else if(o>1e-4)return this._averageElevation.jumpTo(n),i(n)}return!!this._averageElevation.isEasing(e)&&i(this._averageElevation.getValue(e))}_isTokenExpired(){return null!=this._tokenExpiration&&Date.now()>this._tokenExpiration}_revokeAuth(){const t=this.painter.context.gl;ee(t,!1),this._logoControl instanceof uh&&this._logoControl._updateLogo(),t&&t.clear(t.DEPTH_BUFFER_BIT|t.COLOR_BUFFER_BIT|t.STENCIL_BUFFER_BIT),this._silenceAuthErrors||this.fire(new e.y(/* @__PURE__ */new Error("A valid Mapbox access token is required to use Mapbox GL JS. To create an account or a new access token, visit https://account.mapbox.com/")))}_authenticate(){K(this._getMapId(),this._requestManager._skuToken,this._requestManager._customAccessToken,e=>{e&&(e.message!==C&&401!==e.status||this._revokeAuth())}),this._isTokenExpired()&&this._revokeAuth(),j(this._getMapId(),this._requestManager._skuToken,this._requestManager._customAccessToken,()=>{})}_postStyleLoadEvent(){this.style.globalId&&H(this._requestManager._customAccessToken,{map:this,style:this.style.globalId,importedStyles:this.style.getImportGlobalIds()})}_postStyleWithAppearanceEvent(){this.style.globalId&&this.style.hasAppearances()&&q(this._requestManager._customAccessToken)}_postAddingAppearancesToStyleEvent(){W(this._requestManager._customAccessToken)}_updateTerrain(){const e=this._isDragging();this.painter.updateTerrain(this.style,e)}_calculateSpeedIndex(){const e=this.painter.canvasCopy(),t=this.painter.getCanvasCopiesAndTimestamps();t.timeStamps.push(performance.now());const i=this.painter.context.gl,r=i.createFramebuffer();function n(e){i.framebufferTexture2D(i.FRAMEBUFFER,i.COLOR_ATTACHMENT0,i.TEXTURE_2D,e,0);const t=new Uint8Array(i.drawingBufferWidth*i.drawingBufferHeight*4);return i.readPixels(0,0,i.drawingBufferWidth,i.drawingBufferHeight,i.RGBA,i.UNSIGNED_BYTE,t),t}return i.bindFramebuffer(i.FRAMEBUFFER,r),this._canvasPixelComparison(n(e),t.canvasCopies.map(n),t.timeStamps)}_canvasPixelComparison(e,t,i){let r=i[1]-i[0];const n=e.length/4;for(let o=0;o<t.length;o++){const s=t[o];let a=0;for(let t=0;t<s.length;t+=4)s[t]===e[t]&&s[t+1]===e[t+1]&&s[t+2]===e[t+2]&&s[t+3]===e[t+3]&&(a+=1);r+=(i[o+2]-i[o+1])*(1-a/n)}return r}remove(){if(this._removed)return;this._hash&&this._hash.remove();for(const e of this._controls)e.onRemove(this);this._controls=[],this._frame&&(this._frame.cancel(),this._frame=null),this._renderTaskQueue.clear(),this._domRenderTaskQueue.clear(),this.style&&this.style.destroy(),this.painter.destroy(),this.handlers&&this.handlers.destroy(),this.handlers=void 0,this.setStyle(null),window.removeEventListener("resize",this._onWindowResize,!1),window.removeEventListener("orientationchange",this._onWindowResize,!1),window.removeEventListener(this._fullscreenchangeEvent,this._onWindowResize,!1),window.removeEventListener("online",this._onWindowOnline,!1),window.removeEventListener("visibilitychange",this._onVisibilityChange,!1);const t=this.painter.context.gl.getExtension("WEBGL_lose_context");t&&t.loseContext(),this._canvas.removeEventListener("webglcontextlost",this._contextLost,!1),this._canvas.removeEventListener("webglcontextrestored",this._contextRestored,!1),this._canvasContainer.remove(),this._controlContainer.remove(),this._missingCSSCanary.remove(),this._canvas=void 0,this._canvasContainer=void 0,this._controlContainer=void 0,this._missingCSSCanary=void 0,this._container.classList.remove("mapboxgl-map"),this._container.removeEventListener("scroll",this._onMapScroll,!1),Q.delete(this.painter.context.gl),J.remove(),V.remove(),this._removed=!0,this.fire(new e.z("remove"))}triggerRepaint(){this._triggerFrame(!0)}_triggerFrame(t){this._renderNextFrame=this._renderNextFrame||t,this.style&&!this._frame&&(this._frame=e.o.frame(e=>{const t=!!this._renderNextFrame;this._frame=null,this._renderNextFrame=null,t&&this._render(e)}))}_preloadTiles(t){const i=this.style?this.style.getSourceCaches():[];return e.ao(i,(e,i)=>e._preloadTiles(t,i),()=>{this.triggerRepaint()}),this}_onWindowOnline(){this._update()}_onWindowResize(e){this._trackResize&&this.resize({originalEvent:e})._update()}_onVisibilityChange(){"hidden"===document.visibilityState&&this._visibilityHidden++}get showTileBoundaries(){return!!this._showTileBoundaries}set showTileBoundaries(e){this._showTileBoundaries!==e&&(this._showTileBoundaries=e,this._update())}get showParseStatus(){return!!this._showParseStatus}set showParseStatus(e){this._showParseStatus!==e&&(this._showParseStatus=e,this._update())}get showTerrainWireframe(){return!!this._showTerrainWireframe}set showTerrainWireframe(e){this._showTerrainWireframe!==e&&(this._showTerrainWireframe=e,this._update())}get showLayers2DWireframe(){return!!this._showLayers2DWireframe}set showLayers2DWireframe(e){this._showLayers2DWireframe!==e&&(this._showLayers2DWireframe=e,this._update())}get showLayers3DWireframe(){return!!this._showLayers3DWireframe}set showLayers3DWireframe(e){this._showLayers3DWireframe!==e&&(this._showLayers3DWireframe=e,this._update())}get showElevationIdDebug(){return!!this.painter&&this.painter._debugParams.showElevationIdDebug}set showElevationIdDebug(e){this.painter&&this.painter._debugParams.showElevationIdDebug!==e&&(this.painter._debugParams.showElevationIdDebug=e,this.style&&e?this.style._reloadSources():this._update())}get speedIndexTiming(){return!!this._speedIndexTiming}set speedIndexTiming(e){this._speedIndexTiming!==e&&(this._speedIndexTiming=e,this._update())}get showPadding(){return!!this._showPadding}set showPadding(e){this._showPadding!==e&&(this._showPadding=e,this._update())}get showCollisionBoxes(){return!!this._showCollisionBoxes}set showCollisionBoxes(e){this._showCollisionBoxes!==e&&(this._showCollisionBoxes=e,this.style&&e?this.style._reloadSources():this._update())}get showOverdrawInspector(){return!!this._showOverdrawInspector}set showOverdrawInspector(e){this._showOverdrawInspector!==e&&(this._showOverdrawInspector=e,this._update())}get repaint(){return!!this._repaint}set repaint(e){this._repaint!==e&&(this._repaint=e,this.triggerRepaint())}get vertices(){return!!this._vertices}set vertices(e){this._vertices=e,this._update()}get showTileAABBs(){return!!this._showTileAABBs}set showTileAABBs(e){this._showTileAABBs!==e&&(this._showTileAABBs=e,e&&this._update())}_setCacheLimits(t,i){e.f1(t,i)}get version(){return t}},NavigationControl:class{constructor(t={}){this.options=Object.assign({},vh,t),this._container=h("div","mapboxgl-ctrl mapboxgl-ctrl-group"),this._container.addEventListener("contextmenu",e=>e.preventDefault()),this.options.showZoom&&(e.b0(["_setButtonTitle","_updateZoomButtons"],this),this._zoomInButton=this._createButton("mapboxgl-ctrl-zoom-in",e=>{this._map&&this._map.zoomIn({},{originalEvent:e})}),h("span","mapboxgl-ctrl-icon",this._zoomInButton).setAttribute("aria-hidden","true"),this._zoomOutButton=this._createButton("mapboxgl-ctrl-zoom-out",e=>{this._map&&this._map.zoomOut({},{originalEvent:e})}),h("span","mapboxgl-ctrl-icon",this._zoomOutButton).setAttribute("aria-hidden","true")),this.options.showCompass&&(e.b0(["_rotateCompassArrow"],this),this._compass=this._createButton("mapboxgl-ctrl-compass",e=>{const t=this._map;t&&(this.options.visualizePitch?t.resetNorthPitch({},{originalEvent:e}):t.resetNorth({},{originalEvent:e}))}),this._compassIcon=h("span","mapboxgl-ctrl-icon",this._compass),this._compassIcon.setAttribute("aria-hidden","true"))}_updateZoomButtons(){const e=this._map;if(!e)return;const t=e.getZoom(),i=t===e.getMaxZoom(),r=t===e.getMinZoom();this._zoomInButton.disabled=i,this._zoomOutButton.disabled=r,this._zoomInButton.setAttribute("aria-disabled",i.toString()),this._zoomOutButton.setAttribute("aria-disabled",r.toString())}_rotateCompassArrow(){const e=this._map;if(!e)return;const t=this.options.visualizePitch?`scale(${1/Math.pow(Math.cos(e.transform.pitch*(Math.PI/180)),.5)}) rotateX(${e.transform.pitch}deg) rotateZ(${e.transform.angle*(180/Math.PI)}deg)`:`rotate(${e.transform.angle*(180/Math.PI)}deg)`;e._requestDomTask(()=>{this._compassIcon&&(this._compassIcon.style.transform=t)})}onAdd(e){return this._map=e,this.options.showZoom&&(this._setButtonTitle(this._zoomInButton,"ZoomIn"),this._setButtonTitle(this._zoomOutButton,"ZoomOut"),e.on("zoom",this._updateZoomButtons),this._updateZoomButtons()),this.options.showCompass&&(this._setButtonTitle(this._compass,"ResetBearing"),this.options.visualizePitch&&e.on("pitch",this._rotateCompassArrow),e.on("rotate",this._rotateCompassArrow),this._rotateCompassArrow(),this._handler=new bh(e,this._compass,this.options.visualizePitch)),this._container}onRemove(){const e=this._map;e&&(this._container.remove(),this.options.showZoom&&e.off("zoom",this._updateZoomButtons),this.options.showCompass&&(this.options.visualizePitch&&e.off("pitch",this._rotateCompassArrow),e.off("rotate",this._rotateCompassArrow),this._handler&&this._handler.off(),this._handler=void 0),this._map=void 0)}_createButton(e,t){const i=h("button",e,this._container);return i.type="button",i.addEventListener("click",t),i}_setButtonTitle(e,t){if(!this._map)return;const i=this._map._getUIString(`NavigationControl.${t}`);e.setAttribute("aria-label",i),e.firstElementChild&&e.firstElementChild.setAttribute("title",i)}},GeolocateControl:class extends e.E{constructor(t={}){super();const i=navigator.geolocation;this.options=Object.assign({geolocation:i},Ah,t),e.b0(["_onSuccess","_onError","_onZoom","_finish","_setupUI","_updateCamera","_updateMarker","_updateMarkerRotation","_onDeviceOrientation"],this),this._updateMarkerRotationThrottled=nc(this._updateMarkerRotation,20),this._numberOfWatches=0}onAdd(e){return this._map=e,this._container=h("div","mapboxgl-ctrl mapboxgl-ctrl-group"),this._checkGeolocationSupport(this._setupUI),this._container}onRemove(){this._clearRequestTimeout(),void 0!==this._geolocationWatchID&&(this.options.geolocation.clearWatch(this._geolocationWatchID),this._geolocationWatchID=void 0),this.options.showUserLocation&&this._userLocationDotMarker&&this._userLocationDotMarker.remove(),this.options.showAccuracyCircle&&this._accuracyCircleMarker&&this._accuracyCircleMarker.remove(),this._container.remove(),this._map.off("zoom",this._onZoom),this._map=void 0,this._numberOfWatches=0,this._noTimeout=!1}_checkGeolocationSupport(e){const t=(t=!!this.options.geolocation)=>{this._supportsGeolocation=t,e(t)};void 0!==this._supportsGeolocation?e(this._supportsGeolocation):void 0!==navigator.permissions?navigator.permissions.query({name:"geolocation"}).then(e=>t("denied"!==e.state)).catch(()=>t()):t()}_isOutOfMapMaxBounds(e){const t=this._map.getMaxBounds(),i=e.coords;return!!t&&(i.longitude<t.getWest()||i.longitude>t.getEast()||i.latitude<t.getSouth()||i.latitude>t.getNorth())}_setErrorState(){switch(this._watchState){case"WAITING_ACTIVE":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error");break;case"ACTIVE_LOCK":this._watchState="ACTIVE_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting");break;case"BACKGROUND":this._watchState="BACKGROUND_ERROR",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting")}}_onSuccess(t){if(this._map){if(this._clearRequestTimeout(),this._isOutOfMapMaxBounds(t))return this._setErrorState(),this.fire(new e.z("outofmaxbounds",t)),this._updateMarker(),void this._finish();if(this.options.trackUserLocation)switch(this._lastKnownPosition=t,this._watchState){case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this.options.followUserLocation?(this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active")):(this._watchState="BACKGROUND",this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"));break;case"BACKGROUND":case"BACKGROUND_ERROR":this._watchState="BACKGROUND",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background")}this.options.showUserLocation&&"OFF"!==this._watchState&&this._updateMarker(t),this.options.followUserLocation&&(!this.options.trackUserLocation||"ACTIVE_LOCK"===this._watchState)&&this._updateCamera(t),this.options.showUserLocation&&this._userLocationDotMarker.removeClassName("mapboxgl-user-location-dot-stale"),this.fire(new e.z("geolocate",Object.assign({coords:t.coords,timestamp:t.timestamp},t.toJSON?{toJSON:t.toJSON.bind(t)}:{}))),this._finish()}}_updateCamera(t){const i=new e.aX(t.coords.longitude,t.coords.latitude),r=t.coords.accuracy,n=this._map.getBearing(),o=Object.assign({bearing:n},this.options.fitBoundsOptions);this._map.fitBounds(i.toBounds(r),o,{geolocateSource:!0})}_updateMarker(t){if(t){const i=new e.aX(t.coords.longitude,t.coords.latitude);this._accuracyCircleMarker.setLngLat(i).addTo(this._map),this._userLocationDotMarker.setLngLat(i).addTo(this._map),this._accuracy=t.coords.accuracy,this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()}else this._userLocationDotMarker.remove(),this._accuracyCircleMarker.remove()}_updateCircleRadius(){const t=this._map.transform,i=e.bY(1,t._center.lat)*t.worldSize,r=Math.ceil(2*this._accuracy*i);this._circleElement.style.width=`${r}px`,this._circleElement.style.height=`${r}px`}_onZoom(){this.options.showUserLocation&&this.options.showAccuracyCircle&&this._updateCircleRadius()}_updateMarkerRotation(){this._userLocationDotMarker&&"number"==typeof this._heading?(this._userLocationDotMarker.setRotation(this._heading),this._userLocationDotMarker.addClassName("mapboxgl-user-location-show-heading")):(this._userLocationDotMarker.removeClassName("mapboxgl-user-location-show-heading"),this._userLocationDotMarker.setRotation(0))}_onError(t){if(this._map){if(this._clearRequestTimeout(),this.options.trackUserLocation)if(1===t.code){this._watchState="OFF",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.disabled=!0;const e=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.setAttribute("aria-label",e),this._geolocateButton.firstElementChild&&this._geolocateButton.firstElementChild.setAttribute("title",e),void 0!==this._geolocationWatchID&&this._clearWatch()}else{if(3===t.code&&this._noTimeout)return;this._setErrorState()}"OFF"!==this._watchState&&this.options.showUserLocation&&this._userLocationDotMarker.addClassName("mapboxgl-user-location-dot-stale"),this.fire(new e.z("error",{code:t.code,message:t.message,PERMISSION_DENIED:t.PERMISSION_DENIED,POSITION_UNAVAILABLE:t.POSITION_UNAVAILABLE,TIMEOUT:t.TIMEOUT})),this._finish()}}_finish(){this._timeoutId&&clearTimeout(this._timeoutId),this._timeoutId=void 0}_startRequestTimeout(){this._clearRequestTimeout();const e=this.options.positionOptions.timeout;e&&(this._requestTimeoutId=window.setTimeout(()=>{this._onError({code:3,message:"Geolocation request timed out"})},e))}_clearRequestTimeout(){void 0!==this._requestTimeoutId&&(clearTimeout(this._requestTimeoutId),this._requestTimeoutId=void 0)}_setupUI(t){if(void 0!==this._map){if(this._container.addEventListener("contextmenu",e=>e.preventDefault()),this._geolocateButton=h("button","mapboxgl-ctrl-geolocate",this._container),h("span","mapboxgl-ctrl-icon",this._geolocateButton).setAttribute("aria-hidden","true"),this._geolocateButton.type="button",!1===t){e.w("Geolocation support is not available so the GeolocateControl will be disabled.");const t=this._map._getUIString("GeolocateControl.LocationNotAvailable");this._geolocateButton.disabled=!0,this._geolocateButton.setAttribute("aria-label",t),this._geolocateButton.firstElementChild&&this._geolocateButton.firstElementChild.setAttribute("title",t)}else{const e=this._map._getUIString("GeolocateControl.FindMyLocation");this._geolocateButton.setAttribute("aria-label",e),this._geolocateButton.firstElementChild&&this._geolocateButton.firstElementChild.setAttribute("title",e)}this.options.trackUserLocation&&(this._geolocateButton.setAttribute("aria-pressed","false"),this._watchState="OFF"),this.options.showUserLocation&&(this._dotElement=h("div","mapboxgl-user-location"),this._dotElement.appendChild(h("div","mapboxgl-user-location-dot")),this._dotElement.appendChild(h("div","mapboxgl-user-location-heading")),this._userLocationDotMarker=new Eh({element:this._dotElement,rotationAlignment:"map",pitchAlignment:"map"}),this._circleElement=h("div","mapboxgl-user-location-accuracy-circle"),this._accuracyCircleMarker=new Eh({element:this._circleElement,pitchAlignment:"map"}),this.options.trackUserLocation&&(this._watchState="OFF"),this._map.on("zoom",this._onZoom)),this._geolocateButton.addEventListener("click",this.trigger.bind(this)),this._setup=!0,this.options.showButton||(this._container.style.display="none"),this.options.trackUserLocation&&this._map.on("movestart",t=>{t.geolocateSource||"ACTIVE_LOCK"!==this._watchState||t.originalEvent&&"resize"===t.originalEvent.type||(this._watchState="BACKGROUND",this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this.fire(new e.z("trackuserlocationend")))})}}_onDeviceOrientation(e){this._userLocationDotMarker&&(e.webkitCompassHeading?this._heading=e.webkitCompassHeading:!0===e.absolute&&(this._heading=-1*e.alpha),this._updateMarkerRotationThrottled())}trigger(){if(!this._setup)return e.w("Geolocate control triggered before added to a map"),!1;if(this.options.trackUserLocation){switch(this._watchState){case"OFF":this._watchState="WAITING_ACTIVE",this.fire(new e.z("trackuserlocationstart"));break;case"WAITING_ACTIVE":case"ACTIVE_LOCK":case"ACTIVE_ERROR":case"BACKGROUND_ERROR":this._numberOfWatches--,this._noTimeout=!1,this._watchState="OFF",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this.fire(new e.z("trackuserlocationend"));break;case"BACKGROUND":this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._lastKnownPosition&&this._updateCamera(this._lastKnownPosition),this.fire(new e.z("trackuserlocationstart"))}switch(this._watchState){case"WAITING_ACTIVE":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active");break;case"ACTIVE_LOCK":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active");break;case"ACTIVE_ERROR":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active-error");break;case"BACKGROUND":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background");break;case"BACKGROUND_ERROR":this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background-error")}if("OFF"===this._watchState&&void 0!==this._geolocationWatchID)this._clearWatch();else if(void 0===this._geolocationWatchID){let e;this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","true"),this._numberOfWatches++,this._numberOfWatches>1?(e={maximumAge:6e5,timeout:0},this._noTimeout=!0):(e=this.options.positionOptions,this._noTimeout=!1),this._geolocationWatchID=this.options.geolocation.watchPosition(this._onSuccess,this._onError,e),this._startRequestTimeout(),this.options.showUserHeading&&this._addDeviceOrientationListener()}}else this.options.geolocation.getCurrentPosition(this._onSuccess,this._onError,this.options.positionOptions),this._startRequestTimeout(),this._timeoutId=window.setTimeout(this._finish,1e4);return!0}setFollowUserLocation(t){return this.options.followUserLocation=null!=t?t:Ah.followUserLocation,this.options.trackUserLocation&&"OFF"!==this._watchState&&(this.options.followUserLocation?"BACKGROUND"!==this._watchState&&"BACKGROUND_ERROR"!==this._watchState||(this._watchState="ACTIVE_LOCK",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-background-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-active"),this._lastKnownPosition&&this._updateCamera(this._lastKnownPosition),this.fire(new e.z("trackuserlocationstart"))):"ACTIVE_LOCK"!==this._watchState&&"ACTIVE_ERROR"!==this._watchState||(this._watchState="BACKGROUND",this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active"),this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-active-error"),this._geolocateButton.classList.add("mapboxgl-ctrl-geolocate-background"),this.fire(new e.z("trackuserlocationend")))),this}_addDeviceOrientationListener(){const e=()=>{const e="ondeviceorientationabsolute"in window?"deviceorientationabsolute":"deviceorientation";window.addEventListener(e,this._onDeviceOrientation)};"function"==typeof DeviceOrientationEvent.requestPermission?DeviceOrientationEvent.requestPermission().then(t=>{"granted"===t&&e()}).catch(console.error):e()}_clearWatch(){this._clearRequestTimeout(),this.options.geolocation.clearWatch(this._geolocationWatchID),window.removeEventListener("deviceorientation",this._onDeviceOrientation),window.removeEventListener("deviceorientationabsolute",this._onDeviceOrientation),this._geolocationWatchID=void 0,this._geolocateButton.classList.remove("mapboxgl-ctrl-geolocate-waiting"),this._geolocateButton.setAttribute("aria-pressed","false"),this.options.showUserLocation&&this._updateMarker(null)}},AttributionControl:hh,ScaleControl:class{constructor(t={}){this.options=Object.assign({},Mh,t),e.b0(["_update","_setScale","setUnit"],this)}getDefaultPosition(){return"bottom-left"}_update(){const e=this.options.maxWidth||100,t=this._map,i=t._containerHeight/2,r=t._containerWidth/2-e/2,n=t.unproject([r,i]),o=t.unproject([r+e,i]),s=n.distanceTo(o);if("imperial"===this.options.unit){const t=3.2808*s;t>5280?this._setScale(e,t/5280,"mile"):this._setScale(e,t,"foot")}else"nautical"===this.options.unit?this._setScale(e,s/1852,"nautical-mile"):s>=1e3?this._setScale(e,s/1e3,"kilometer"):this._setScale(e,s,"meter")}_setScale(e,t,i){this._map._requestDomTask(()=>{const r=function(e){const t=Math.pow(10,`${Math.floor(e)}`.length-1);let i=e/t;return i=i>=10?10:i>=5?5:i>=3?3:i>=2?2:i>=1?1:function(e){const t=Math.pow(10,Math.ceil(-Math.log(e)/Math.LN10));return Math.round(e*t)/t}(i),t*i}(t),n=r/t;this._container.innerHTML="nautical-mile"!==i?new Intl.NumberFormat(this._language,{style:"unit",unitDisplay:"short",unit:i}).format(r):`${r} ${Ch[i]}`,this._container.style.width=e*n+"px"})}onAdd(e){return this._map=e,this._language=e.getLanguage(),this._container=h("div","mapboxgl-ctrl mapboxgl-ctrl-scale",e.getContainer()),this._container.dir="auto",this._map.on("move",this._update),this._update(),this._container}onRemove(){this._container.remove(),this._map.off("move",this._update),this._map=void 0}_setLanguage(e){this._language=e,this._update()}setUnit(e){this.options.unit=e,this._update()}},FullscreenControl:class{constructor(t={}){this._fullscreen=!1,t&&t.container&&(t.container instanceof HTMLElement?this._container=t.container:e.w("Full screen control 'container' must be a DOM element.")),e.b0(["_onClickFullscreen","_changeIcon"],this),"onfullscreenchange"in document?this._fullscreenchange="fullscreenchange":"onwebkitfullscreenchange"in document&&(this._fullscreenchange="webkitfullscreenchange")}onAdd(t){return this._map=t,this._container||(this._container=this._map.getContainer()),this._controlContainer=h("div","mapboxgl-ctrl mapboxgl-ctrl-group"),this._checkFullscreenSupport()?this._setupUI():(this._controlContainer.style.display="none",e.w("This device does not support fullscreen mode.")),this._controlContainer}onRemove(){this._controlContainer.remove(),this._map=null,document.removeEventListener(this._fullscreenchange,this._changeIcon)}_checkFullscreenSupport(){return!(!document.fullscreenEnabled&&!document.webkitFullscreenEnabled)}_setupUI(){const e=this._fullscreenButton=h("button","mapboxgl-ctrl-fullscreen",this._controlContainer);h("span","mapboxgl-ctrl-icon",e).setAttribute("aria-hidden","true"),e.type="button",this._updateTitle(),this._fullscreenButton.addEventListener("click",this._onClickFullscreen),document.addEventListener(this._fullscreenchange,this._changeIcon)}_updateTitle(){const e=this._getTitle();this._fullscreenButton.setAttribute("aria-label",e),this._fullscreenButton.firstElementChild&&this._fullscreenButton.firstElementChild.setAttribute("title",e)}_getTitle(){return this._map._getUIString(this._isFullscreen()?"FullscreenControl.Exit":"FullscreenControl.Enter")}_isFullscreen(){return this._fullscreen}_changeIcon(){(document.fullscreenElement||document.webkitFullscreenElement)===this._container!==this._fullscreen&&(this._fullscreen=!this._fullscreen,this._fullscreenButton.classList.toggle("mapboxgl-ctrl-shrink"),this._fullscreenButton.classList.toggle("mapboxgl-ctrl-fullscreen"),this._updateTitle())}_onClickFullscreen(){this._isFullscreen()?document.exitFullscreen?document.exitFullscreen():document.webkitCancelFullScreen&&document.webkitCancelFullScreen():this._container.requestFullscreen?this._container.requestFullscreen():this._container.webkitRequestFullscreen&&this._container.webkitRequestFullscreen()}},IndoorControl:class{constructor(){e.b0(["_onIndoorUpdate","_onStyleData","_scrollUp","_scrollDown","_toggleIndoor"],this),this._visibleFloorStart=0,this._lastSelectedFloorId=null}onAdd(e){return this._map=e,this._container=h("div","mapboxgl-ctrl mapboxgl-ctrl-group"),this._container.style.display="none",this._map.on("styledata",this._onStyleData),this._updateConnection(),this._container}_onStyleData(){this._updateConnection()}_updateConnection(){if(this._map&&this._map.style&&this._map.style.indoorManager){const e=this._map.style.indoorManager;e.off("selector-update",this._onIndoorUpdate),e.on("selector-update",this._onIndoorUpdate),this._onIndoorUpdate(e.getControlState())}}_createButton(e,t){const i=h("button",e,this._container);return i.type="button",i.addEventListener("click",t),i}_setButtonTitle(e,t){e.setAttribute("aria-label",t),e.textContent=t}onRemove(){this._container&&this._container.remove(),this._map&&(this._map.off("styledata",this._onStyleData),this._map.style&&this._map.style.indoorManager.off("selector-update",this._onIndoorUpdate),this._map=null)}getDefaultPosition(){return"top-right"}_onIndoorUpdate(e){if(!e||!e.floors||0===e.floors.length)return this._model=e,void(this._container.style.display="none");const t=this._model;this._model=e,this._container.style.display="inline-block";const i=!t||t.floors.length!==e.floors.length||t.floors.some((t,i)=>t.id!==e.floors[i].id);if(i&&(this._visibleFloorStart=0,this._lastSelectedFloorId=null),e.selectedFloorId){if(e.selectedFloorId!==this._lastSelectedFloorId||i){const t=e.floors.findIndex(t=>t.id===e.selectedFloorId);if(-1!==t){const i=e.floors.length;let r,n;i<=5?(r=0,n=i-1):0===this._visibleFloorStart?(r=0,n=3):this._visibleFloorStart>=i-3?(r=i-3-1,n=i-1):(r=this._visibleFloorStart,n=this._visibleFloorStart+3-1),t<r?this._visibleFloorStart=t:t>n&&(this._visibleFloorStart=t-2)}}this._lastSelectedFloorId=e.selectedFloorId}this._render()}_render(){if(!this._container||!this._model||!this._model.floors)return;this._container.innerHTML="";const e=this._createButton("mapboxgl-ctrl-indoor-toggle",this._toggleIndoor);h("span","mapboxgl-ctrl-icon",e).setAttribute("aria-hidden","true"),this._model.activeFloorsVisible||e.classList.add("mapboxgl-ctrl-level-button-selected"),this._container.appendChild(e);const t=this._model.floors,i=t.length;if(i<=5)return void t.forEach(e=>this._createFloorButton(e));const r=0===this._visibleFloorStart,n=this._visibleFloorStart>=i-3;if(r)this._createFloorButton(t[0]);else{const e=this._createButton("mapboxgl-ctrl-arrow-up",this._scrollUp);h("span","mapboxgl-ctrl-icon",e).setAttribute("aria-hidden","true"),this._container.appendChild(e)}let o=[];if(o=r?t.slice(1,4):n?t.slice(this._visibleFloorStart-1,this._visibleFloorStart+3-1):t.slice(this._visibleFloorStart,this._visibleFloorStart+3),o.forEach(e=>this._createFloorButton(e)),n)this._createFloorButton(t[i-1]);else{const e=this._createButton("mapboxgl-ctrl-arrow-down",this._scrollDown);h("span","mapboxgl-ctrl-icon",e).setAttribute("aria-hidden","true"),this._container.appendChild(e)}}_createFloorButton(e){const t=this._createButton("mapboxgl-ctrl-level-button",()=>{const t=e.id;this._model&&this._model.selectedFloorId===t&&this._model.activeFloorsVisible||this._map&&(this._model&&!this._model.activeFloorsVisible&&this._map.style&&this._map.style.indoorManager&&this._map.style.indoorManager.setActiveFloorsVisibility(!0),this._map._selectIndoorFloor(t))}),i=(e.name||"").trim(),r=e.zIndex.toString(),n=i?Array.from(i).slice(0,3).join(""):r;this._setButtonTitle(t,n),this._model&&this._model.activeFloorsVisible&&e.id===this._model.selectedFloorId&&t.classList.add("mapboxgl-ctrl-level-button-selected"),this._container&&this._container.appendChild(t)}_toggleIndoor(){this._map&&this._map.style&&this._map.style.indoorManager&&this._model&&this._model.activeFloorsVisible&&this._map.style.indoorManager.setActiveFloorsVisibility(!1)}_scrollUp(){if(this._visibleFloorStart>0){this._visibleFloorStart--,1===this._visibleFloorStart&&(this._visibleFloorStart=0);const e=this._model&&this._model.floors||[];if(e.length>3){const t=e.length-3;this._visibleFloorStart===t-1&&(this._visibleFloorStart=t-2)}this._render()}}_scrollDown(){if(this._model&&this._model.floors){const e=this._model.floors.length-3;this._visibleFloorStart<e&&(this._visibleFloorStart++,1===this._visibleFloorStart&&(this._visibleFloorStart=2),this._visibleFloorStart===e-1&&(this._visibleFloorStart=e),this._visibleFloorStart>e&&(this._visibleFloorStart=e),this._render())}}},Popup:class extends e.E{constructor(t){super(),this.options=Object.assign(Object.create(Dh),t),this._altitude=this.options.altitude,e.b0(["_update","_onClose","remove","_onMouseEvent"],this),this._classList=new Set(t&&t.className?t.className.trim().split(Ph):[])}addTo(t){return this._map&&this.remove(),this._map=t,this.options.closeOnClick&&t.on("preclick",this._onClose),this.options.closeOnMove&&t.on("move",this._onClose),t.on("remove",this.remove),this._update(),t._addPopup(this),this._focusFirstElement(),this._trackPointer?(t.on("mousemove",this._onMouseEvent),t.on("mouseup",this._onMouseEvent),t._canvasContainer.classList.add("mapboxgl-track-pointer")):t.on("move",this._update),this.fire(new e.z("open")),this}isOpen(){return!!this._map}remove(){this._content&&this._content.remove(),this._container&&(this._container.remove(),this._container=void 0);const t=this._map;return t&&(t.off("move",this._update),t.off("move",this._onClose),t.off("preclick",this._onClose),t.off("click",this._onClose),t.off("remove",this.remove),t.off("mousemove",this._onMouseEvent),t.off("mouseup",this._onMouseEvent),t.off("drag",this._onMouseEvent),t._canvasContainer&&t._canvasContainer.classList.remove("mapboxgl-track-pointer"),t._removePopup(this),this._map=void 0),this.fire(new e.z("close")),this}getLngLat(){return this._lngLat}setLngLat(t){this._lngLat=e.aX.convert(t),this._pos=null,this._trackPointer=!1,this._update();const i=this._map;return i&&(i.on("move",this._update),i.off("mousemove",this._onMouseEvent),i._canvasContainer.classList.remove("mapboxgl-track-pointer")),this}getAltitude(){return this._altitude}setAltitude(e){return this._altitude=e,this._update(),this}trackPointer(){this._trackPointer=!0,this._pos=null,this._update();const e=this._map;return e&&(e.off("move",this._update),e.on("mousemove",this._onMouseEvent),e.on("drag",this._onMouseEvent),e._canvasContainer.classList.add("mapboxgl-track-pointer")),this}getElement(){return this._container}setText(e){return this.setDOMContent(document.createTextNode(e))}setHTML(e){const t=document.createDocumentFragment(),i=document.createElement("body");let r;for(i.innerHTML=e;r=i.firstChild,r;)t.appendChild(r);return this.setDOMContent(t)}getMaxWidth(){return this._container&&this._container.style.maxWidth}setMaxWidth(e){return this.options.maxWidth=e,this._update(),this}setDOMContent(e){let t=this._content;if(t)for(;t.hasChildNodes();)t.firstChild&&t.removeChild(t.firstChild);else t=this._content=h("div","mapboxgl-popup-content",this._container||void 0);if(t.appendChild(e),this.options.closeButton){const e=this._closeButton=h("button","mapboxgl-popup-close-button",t);e.type="button",e.setAttribute("aria-label","Close popup"),e.innerHTML='<span aria-hidden="true">×</span>',e.addEventListener("click",this._onClose)}return this._update(),this._focusFirstElement(),this}addClassName(e){return this._classList.add(e),this._updateClassList(),this}removeClassName(e){return this._classList.delete(e),this._updateClassList(),this}setOffset(e){return this.options.offset=e,this._update(),this}toggleClassName(e){let t;return this._classList.delete(e)?t=!1:(this._classList.add(e),t=!0),this._updateClassList(),t}_onMouseEvent(e){this._update(e.point)}_getAnchor(e){if(this.options.anchor)return this.options.anchor;const t=this._map,i=this._container,r=this._pos;if(!t||!i||!r)return"bottom";const n=i.offsetWidth,o=i.offsetHeight,s=r.x<n/2,a=r.x>t.transform.width-n/2;if(r.y+e<o)return s?"top-left":a?"top-right":"top";if(r.y>t.transform.height-o){if(s)return"bottom-left";if(a)return"bottom-right"}return s?"left":a?"right":"bottom"}_updateClassList(){const e=this._container;if(!e)return;const t=[...this._classList];t.push("mapboxgl-popup"),this._anchor&&t.push(`mapboxgl-popup-anchor-${this._anchor}`),this._trackPointer&&t.push("mapboxgl-popup-track-pointer"),e.className=t.join(" ")}_update(t){const i=this._map,r=this._content;if(!i||!this._lngLat&&!this._trackPointer||!r)return;let n=this._container;if(n||(n=this._container=h("div","mapboxgl-popup",i.getContainer()),this._tip=h("div","mapboxgl-popup-tip",n),n.appendChild(r)),this.options.maxWidth&&n.style.maxWidth!==this.options.maxWidth&&(n.style.maxWidth=this.options.maxWidth),i.transform.renderWorldCopies&&!this._trackPointer&&(this._lngLat=wh(this._lngLat,this._pos,i.transform)),!this._trackPointer||t){const r=this._pos=this._trackPointer&&t instanceof e.P?t:i.project(this._lngLat,this._altitude),n=zh(this.options.offset),o=this._anchor=this._getAnchor(n.y),s=zh(this.options.offset,o),a=r.add(s).round();i._requestDomTask(()=>{this._container&&o&&(this._container.style.transform=`${Th[o]} translate(${a.x}px,${a.y}px)`)})}if(!this._marker&&i._showingGlobe()){const t=e.f2(i.transform,this._lngLat)?0:1;this._setOpacity(t)}this._updateClassList()}_focusFirstElement(){if(!this.options.focusAfterOpen||!this._container)return;const e=this._container.querySelector(Rh);e&&e.focus()}_onClose(){this.remove()}_setOpacity(e){this._container&&(this._container.style.opacity=`${e}`),this._content&&(this._content.style.pointerEvents=e?"auto":"none")}},Marker:Eh,Style:On,LngLat:e.aX,LngLatBounds:e.aI,Point:e.P,MercatorCoordinate:e.ad,FreeCameraOptions:en,Evented:e.E,config:e.g,prewarm:function(){Bi().acquire(ri)},clearPrewarmedResources:function(){const e=Oi;e&&(e.isPreloaded()&&1===e.numActive()?(e.release(ri),Oi=null):console.warn("Could not clear WebWorkers since there are active Map instances that still reference it. The pre-warmed WebWorker pool can only be cleared when all map instances have been removed with map.remove()"))},get accessToken(){return e.g.ACCESS_TOKEN},set accessToken(t){e.g.ACCESS_TOKEN=t},get baseApiUrl(){return e.g.API_URL},set baseApiUrl(t){e.g.API_URL=t},get workerCount(){return ni.workerCount},set workerCount(e){ni.workerCount=e},get maxParallelImageRequests(){return e.g.MAX_PARALLEL_IMAGE_REQUESTS},set maxParallelImageRequests(t){e.g.MAX_PARALLEL_IMAGE_REQUESTS=t},clearStorage(t){e.fb(t)},get workerUrl(){return ti.workerUrl},set workerUrl(e){ti.workerUrl=e},get workerClass(){return ti.workerClass},set workerClass(e){ti.workerClass=e},get workerParams(){return ti.workerParams},set workerParams(e){ti.workerParams=e},get dracoUrl(){return e.fa()},set dracoUrl(t){e.g.DRACO_URL=e.o.resolveURL(t)},get meshoptUrl(){return e.f9()},set meshoptUrl(t){const i=e.o.resolveURL(t);e.g.MESHOPT_URL=i,e.g.MESHOPT_SIMD_URL=i},get buildingGenUrl(){return e.f8()},set buildingGenUrl(t){e.g.BUILDING_GEN_URL=e.o.resolveURL(t)},setNow:e.o.setNow,restoreNow:e.o.restoreNow}}),i},"object"==typeof e&&void 0!==t?t.exports=r():"function"==typeof define&&define.amd?define(r):(i="undefined"!=typeof globalThis?globalThis:i||self).mapboxgl=r()});export default t();
|