@htmlbricks/hb-map 0.65.18 → 0.65.20
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/main.iife.js +9 -9
- package/main.iife.js.map +1 -1
- package/manifest.json +60 -1
- package/package.json +1 -1
- package/types/webcomponent.type.d.json +8 -0
- package/types/webcomponent.type.d.ts +1 -1
package/main.iife.js
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
(function(ba){"use strict";typeof window<"u"&&((window.__svelte??={}).v??=new Set).add("5");const fu=1,gu=4,_u=8,mu=16,pu=2,La="[",Aa="[!",Ma="]",Rn={},Tt=Symbol(),kr=!1;var yu=Array.isArray,xu=Array.prototype.indexOf,Eu=Array.from,xs=Object.keys,Es=Object.defineProperty,_i=Object.getOwnPropertyDescriptor,vu=Object.prototype,wu=Array.prototype,Cu=Object.getPrototypeOf,Pa=Object.isExtensible;function Ru(n){for(var t=0;t<n.length;t++)n[t]()}function Tu(){var n,t,e=new Promise((i,s)=>{n=i,t=s});return{promise:e,resolve:n,reject:t}}const pt=2,Nr=4,Oa=8,Te=16,Be=32,Ze=64,vs=128,he=512,It=1024,Yt=2048,Ie=4096,Ue=8192,Ve=16384,ws=32768,Cs=65536,Da=1<<17,Fa=1<<18,Xi=1<<19,Iu=1<<20,mi=32768,Gr=1<<21,ka=1<<22,Tn=1<<23,Rs=Symbol("$state"),Na=Symbol("legacy props"),Ga=new class extends Error{name="StaleReactionError";message="The reaction that called `getAbortSignal()` was re-run or destroyed"},za=3,Ts=8;function Su(n){throw new Error("https://svelte.dev/e/lifecycle_outside_component")}function bu(n){throw new Error("https://svelte.dev/e/effect_in_teardown")}function Lu(){throw new Error("https://svelte.dev/e/effect_in_unowned_derived")}function Au(n){throw new Error("https://svelte.dev/e/effect_orphan")}function Mu(){throw new Error("https://svelte.dev/e/effect_update_depth_exceeded")}function Pu(){throw new Error("https://svelte.dev/e/hydration_failed")}function Ou(n){throw new Error("https://svelte.dev/e/props_invalid_value")}function Du(){throw new Error("https://svelte.dev/e/state_descriptors_fixed")}function Fu(){throw new Error("https://svelte.dev/e/state_prototype_fixed")}function ku(){throw new Error("https://svelte.dev/e/state_unsafe_mutation")}function Nu(){throw new Error("https://svelte.dev/e/svelte_boundary_reset_onerror")}function zr(n){console.warn("https://svelte.dev/e/hydration_mismatch")}function Gu(){console.warn("https://svelte.dev/e/svelte_boundary_reset_noop")}let Et=!1;function Is(n){Et=n}let rt;function Se(n){if(n===null)throw zr(),Rn;return rt=n}function Xa(){return Se(Le(rt))}function zu(n){if(Et){if(Le(rt)!==null)throw zr(),Rn;rt=n}}function Wa(n=1){if(Et){for(var t=n,e=rt;t--;)e=Le(e);rt=e}}function Xu(n=!0){for(var t=0,e=rt;;){if(e.nodeType===Ts){var i=e.data;if(i===Ma){if(t===0)return e;t-=1}else(i===La||i===Aa)&&(t+=1)}var s=Le(e);n&&e.remove(),e=s}}function Ya(n){return n===this.v}function Wu(n,t){return n!=n?t==t:n!==t||n!==null&&typeof n=="object"||typeof n=="function"}function $a(n){return!Wu(n,this.v)}let Yu=!1,Ut=null;function Ss(n){Ut=n}function Ka(n,t=!1,e){Ut={p:Ut,i:!1,c:null,e:null,s:n,x:null,l:null}}function Ba(n){var t=Ut,e=t.e;if(e!==null){t.e=null;for(var i of e)al(i)}return n!==void 0&&(t.x=n),t.i=!0,Ut=t.p,n??{}}function Za(){return!0}let pi=[];function Ua(){var n=pi;pi=[],Ru(n)}function bs(n){if(pi.length===0&&!In){var t=pi;queueMicrotask(()=>{t===pi&&Ua()})}pi.push(n)}function $u(){for(;pi.length>0;)Ua()}function Va(n){var t=it;if(t===null)return H.f|=Tn,n;if((t.f&ws)===0){if((t.f&vs)===0)throw n;t.b.error(n)}else Ls(n,t)}function Ls(n,t){for(;t!==null;){if((t.f&vs)!==0)try{t.b.error(n);return}catch(e){n=e}t=t.parent}throw n}const As=new Set;let St=null,Vt=null,jt=[],Ms=null,Xr=!1,In=!1;class ce{committed=!1;current=new Map;previous=new Map;#e=new Set;#t=new Set;#l=0;#r=0;#h=null;#o=[];#s=[];skipped_effects=new Set;is_fork=!1;is_deferred(){return this.is_fork||this.#r>0}process(t){jt=[],this.apply();var e={parent:null,effect:null,effects:[],render_effects:[],block_effects:[]};for(const i of t)this.#i(i,e);this.is_fork||this.#c(),this.is_deferred()?(this.#n(e.effects),this.#n(e.render_effects),this.#n(e.block_effects)):(St=null,Ha(e.render_effects),Ha(e.effects),this.#h?.resolve()),Vt=null}#i(t,e){t.f^=It;for(var i=t.first;i!==null;){var s=i.f,r=(s&(Be|Ze))!==0,o=r&&(s&It)!==0,a=o||(s&Ue)!==0||this.skipped_effects.has(i);if((i.f&vs)!==0&&i.b?.is_pending()&&(e={parent:e,effect:i,effects:[],render_effects:[],block_effects:[]}),!a&&i.fn!==null){r?i.f^=It:(s&Nr)!==0?e.effects.push(i):Mn(i)&&((i.f&Te)!==0&&e.block_effects.push(i),Pn(i));var l=i.first;if(l!==null){i=l;continue}}var h=i.parent;for(i=i.next;i===null&&h!==null;)h===e.effect&&(this.#n(e.effects),this.#n(e.render_effects),this.#n(e.block_effects),e=e.parent),i=h.next,h=h.parent}}#n(t){for(const e of t)((e.f&Yt)!==0?this.#o:this.#s).push(e),this.#a(e.deps),Lt(e,It)}#a(t){if(t!==null)for(const e of t)(e.f&pt)===0||(e.f&mi)===0||(e.f^=mi,this.#a(e.deps))}capture(t,e){this.previous.has(t)||this.previous.set(t,e),(t.f&Tn)===0&&(this.current.set(t,t.v),Vt?.set(t,t.v))}activate(){St=this,this.apply()}deactivate(){St===this&&(St=null,Vt=null)}flush(){if(this.activate(),jt.length>0){if(ja(),St!==null&&St!==this)return}else this.#l===0&&this.process([]);this.deactivate()}discard(){for(const t of this.#t)t(this);this.#t.clear()}#c(){if(this.#r===0){for(const t of this.#e)t();this.#e.clear()}this.#l===0&&this.#u()}#u(){if(As.size>1){this.previous.clear();var t=Vt,e=!0,i={parent:null,effect:null,effects:[],render_effects:[],block_effects:[]};for(const r of As){if(r===this){e=!1;continue}const o=[];for(const[l,h]of this.current){if(r.current.has(l))if(e&&h!==r.current.get(l))r.current.set(l,h);else continue;o.push(l)}if(o.length===0)continue;const a=[...r.current.keys()].filter(l=>!this.current.has(l));if(a.length>0){var s=jt;jt=[];const l=new Set,h=new Map;for(const c of o)qa(c,a,l,h);if(jt.length>0){St=r,r.apply();for(const c of jt)r.#i(c,i);r.deactivate()}jt=s}}St=null,Vt=t}this.committed=!0,As.delete(this)}increment(t){this.#l+=1,t&&(this.#r+=1)}decrement(t){this.#l-=1,t&&(this.#r-=1),this.revive()}revive(){for(const t of this.#o)Lt(t,Yt),Wi(t);for(const t of this.#s)Lt(t,Ie),Wi(t);this.#o=[],this.#s=[],this.flush()}oncommit(t){this.#e.add(t)}ondiscard(t){this.#t.add(t)}settled(){return(this.#h??=Tu()).promise}static ensure(){if(St===null){const t=St=new ce;As.add(St),In||ce.enqueue(()=>{St===t&&t.flush()})}return St}static enqueue(t){bs(t)}apply(){}}function je(n){var t=In;In=!0;try{for(var e;;){if($u(),jt.length===0&&(St?.flush(),jt.length===0))return Ms=null,e;ja()}}finally{In=t}}function ja(){var n=Je;Xr=!0;var t=null;try{var e=0;for(Fs(!0);jt.length>0;){var i=ce.ensure();if(e++>1e3){var s,r;Ku()}i.process(jt),He.clear()}}finally{Xr=!1,Fs(n),Ms=null}}function Ku(){try{Mu()}catch(n){Ls(n,Ms)}}let be=null;function Ha(n){var t=n.length;if(t!==0){for(var e=0;e<t;){var i=n[e++];if((i.f&(Ve|Ue))===0&&Mn(i)&&(be=new Set,Pn(i),i.deps===null&&i.first===null&&i.nodes_start===null&&(i.teardown===null&&i.ac===null?ul(i):i.fn=null),be?.size>0)){He.clear();for(const s of be){if((s.f&(Ve|Ue))!==0)continue;const r=[s];let o=s.parent;for(;o!==null;)be.has(o)&&(be.delete(o),r.push(o)),o=o.parent;for(let a=r.length-1;a>=0;a--){const l=r[a];(l.f&(Ve|Ue))===0&&Pn(l)}}be.clear()}}be=null}}function qa(n,t,e,i){if(!e.has(n)&&(e.add(n),n.reactions!==null))for(const s of n.reactions){const r=s.f;(r&pt)!==0?qa(s,t,e,i):(r&(ka|Te))!==0&&(r&Yt)===0&&Ja(s,t,i)&&(Lt(s,Yt),Wi(s))}}function Ja(n,t,e){const i=e.get(n);if(i!==void 0)return i;if(n.deps!==null)for(const s of n.deps){if(t.includes(s))return!0;if((s.f&pt)!==0&&Ja(s,t,e))return e.set(s,!0),!0}return e.set(n,!1),!1}function Wi(n){for(var t=Ms=n;t.parent!==null;){t=t.parent;var e=t.f;if(Xr&&t===it&&(e&Te)!==0&&(e&Fa)===0)return;if((e&(Ze|Be))!==0){if((e&It)===0)return;t.f^=It}}jt.push(t)}function Bu(n){let t=0,e=Ps(0),i;return()=>{Os()&&(Z(e),ll(()=>(t===0&&(i=Vr(()=>n(()=>Sn(e)))),t+=1,()=>{bs(()=>{t-=1,t===0&&(i?.(),i=void 0,Sn(e))})})))}}var Zu=Cs|Xi|vs;function Uu(n,t,e){new Vu(n,t,e)}class Vu{parent;#e=!1;#t;#l=Et?rt:null;#r;#h;#o;#s=null;#i=null;#n=null;#a=null;#c=null;#u=0;#d=0;#g=!1;#f=null;#x=Bu(()=>(this.#f=Ps(this.#u),()=>{this.#f=null}));constructor(t,e,i){this.#t=t,this.#r=e,this.#h=i,this.parent=it.b,this.#e=!!this.#r.pending,this.#o=cd(()=>{if(it.b=this,Et){const r=this.#l;Xa(),r.nodeType===Ts&&r.data===Aa?this.#v():this.#E()}else{var s=this.#p();try{this.#s=yi(()=>i(s))}catch(r){this.error(r)}this.#d>0?this.#m():this.#e=!1}return()=>{this.#c?.remove()}},Zu),Et&&(this.#t=rt)}#E(){try{this.#s=yi(()=>this.#h(this.#t))}catch(t){this.error(t)}this.#e=!1}#v(){const t=this.#r.pending;t&&(this.#i=yi(()=>t(this.#t)),ce.enqueue(()=>{var e=this.#p();this.#s=this.#_(()=>(ce.ensure(),yi(()=>this.#h(e)))),this.#d>0?this.#m():(Ds(this.#i,()=>{this.#i=null}),this.#e=!1)}))}#p(){var t=this.#t;return this.#e&&(this.#c=bn(),this.#t.before(this.#c),t=this.#c),t}is_pending(){return this.#e||!!this.parent&&this.parent.is_pending()}has_pending_snippet(){return!!this.#r.pending}#_(t){var e=it,i=H,s=Ut;Qe(this.#o),qt(this.#o),Ss(this.#o.ctx);try{return t()}catch(r){return Va(r),null}finally{Qe(e),qt(i),Ss(s)}}#m(){const t=this.#r.pending;this.#s!==null&&(this.#a=document.createDocumentFragment(),this.#a.append(this.#c),gd(this.#s,this.#a)),this.#i===null&&(this.#i=yi(()=>t(this.#t)))}#y(t){if(!this.has_pending_snippet()){this.parent&&this.parent.#y(t);return}this.#d+=t,this.#d===0&&(this.#e=!1,this.#i&&Ds(this.#i,()=>{this.#i=null}),this.#a&&(this.#t.before(this.#a),this.#a=null))}update_pending_count(t){this.#y(t),this.#u+=t,this.#f&&il(this.#f,this.#u)}get_effect_pending(){return this.#x(),Z(this.#f)}error(t){var e=this.#r.onerror;let i=this.#r.failed;if(this.#g||!e&&!i)throw t;this.#s&&(ue(this.#s),this.#s=null),this.#i&&(ue(this.#i),this.#i=null),this.#n&&(ue(this.#n),this.#n=null),Et&&(Se(this.#l),Wa(),Se(Xu()));var s=!1,r=!1;const o=()=>{if(s){Gu();return}s=!0,r&&Nu(),ce.ensure(),this.#u=0,this.#n!==null&&Ds(this.#n,()=>{this.#n=null}),this.#e=this.has_pending_snippet(),this.#s=this.#_(()=>(this.#g=!1,yi(()=>this.#h(this.#t)))),this.#d>0?this.#m():this.#e=!1};var a=H;try{qt(null),r=!0,e?.(t,o),r=!1}catch(l){Ls(l,this.#o&&this.#o.parent)}finally{qt(a)}i&&bs(()=>{this.#n=this.#_(()=>{ce.ensure(),this.#g=!0;try{return yi(()=>{i(this.#t,()=>t,()=>o)})}catch(l){return Ls(l,this.#o.parent),null}finally{this.#g=!1}})})}}function Wr(n){var t=pt|Yt,e=H!==null&&(H.f&pt)!==0?H:null;return it!==null&&(it.f|=Xi),{ctx:Ut,deps:null,effects:null,equals:Ya,f:t,fn:n,reactions:null,rv:0,v:Tt,wv:0,parent:e??it,ac:null}}function ju(n){const t=Wr(n);return gl(t),t}function Hu(n){const t=Wr(n);return t.equals=$a,t}function Qa(n){var t=n.effects;if(t!==null){n.effects=null;for(var e=0;e<t.length;e+=1)ue(t[e])}}function qu(n){for(var t=n.parent;t!==null;){if((t.f&pt)===0)return(t.f&Ve)===0?t:null;t=t.parent}return null}function Yr(n){var t,e=it;Qe(qu(n));try{n.f&=~mi,Qa(n),t=xl(n)}finally{Qe(e)}return t}function tl(n){var t=Yr(n);if(n.equals(t)||(St?.is_fork||(n.v=t),n.wv=pl()),!xi)if(Vt!==null)Os()&&Vt.set(n,t);else{var e=(n.f&he)===0?Ie:It;Lt(n,e)}}let $r=new Set;const He=new Map;let el=!1;function Ps(n,t){var e={f:0,v:n,reactions:null,equals:Ya,rv:0,wv:0};return e}function Ht(n,t){const e=Ps(n);return gl(e),e}function Ju(n,t=!1,e=!0){const i=Ps(n);return t||(i.equals=$a),i}function Dt(n,t,e=!1){H!==null&&(!ye||(H.f&Da)!==0)&&Za()&&(H.f&(pt|Te|ka|Da))!==0&&!Ae?.includes(n)&&ku();let i=e?Yi(t):t;return il(n,i)}function il(n,t){if(!n.equals(t)){var e=n.v;xi?He.set(n,t):He.set(n,e),n.v=t;var i=ce.ensure();i.capture(n,e),(n.f&pt)!==0&&((n.f&Yt)!==0&&Yr(n),Lt(n,(n.f&he)!==0?It:Ie)),n.wv=pl(),nl(n,Yt),it!==null&&(it.f&It)!==0&&(it.f&(Be|Ze))===0&&(Jt===null?_d([n]):Jt.push(n)),!i.is_fork&&$r.size>0&&!el&&Qu()}return t}function Qu(){el=!1;var n=Je;Fs(!0);const t=Array.from($r);try{for(const e of t)(e.f&It)!==0&&Lt(e,Ie),Mn(e)&&Pn(e)}finally{Fs(n)}$r.clear()}function Sn(n){Dt(n,n.v+1)}function nl(n,t){var e=n.reactions;if(e!==null)for(var i=e.length,s=0;s<i;s++){var r=e[s],o=r.f,a=(o&Yt)===0;if(a&&Lt(r,t),(o&pt)!==0){var l=r;Vt?.delete(l),(o&mi)===0&&(o&he&&(r.f|=mi),nl(l,Ie))}else a&&((o&Te)!==0&&be!==null&&be.add(r),Wi(r))}}function Yi(n){if(typeof n!="object"||n===null||Rs in n)return n;const t=Cu(n);if(t!==vu&&t!==wu)return n;var e=new Map,i=yu(n),s=Ht(0),r=Ei,o=a=>{if(Ei===r)return a();var l=H,h=Ei;qt(null),ml(r);var c=a();return qt(l),ml(h),c};return i&&e.set("length",Ht(n.length)),new Proxy(n,{defineProperty(a,l,h){(!("value"in h)||h.configurable===!1||h.enumerable===!1||h.writable===!1)&&Du();var c=e.get(l);return c===void 0?c=o(()=>{var u=Ht(h.value);return e.set(l,u),u}):Dt(c,h.value,!0),!0},deleteProperty(a,l){var h=e.get(l);if(h===void 0){if(l in a){const c=o(()=>Ht(Tt));e.set(l,c),Sn(s)}}else Dt(h,Tt),Sn(s);return!0},get(a,l,h){if(l===Rs)return n;var c=e.get(l),u=l in a;if(c===void 0&&(!u||_i(a,l)?.writable)&&(c=o(()=>{var f=Yi(u?a[l]:Tt),g=Ht(f);return g}),e.set(l,c)),c!==void 0){var d=Z(c);return d===Tt?void 0:d}return Reflect.get(a,l,h)},getOwnPropertyDescriptor(a,l){var h=Reflect.getOwnPropertyDescriptor(a,l);if(h&&"value"in h){var c=e.get(l);c&&(h.value=Z(c))}else if(h===void 0){var u=e.get(l),d=u?.v;if(u!==void 0&&d!==Tt)return{enumerable:!0,configurable:!0,value:d,writable:!0}}return h},has(a,l){if(l===Rs)return!0;var h=e.get(l),c=h!==void 0&&h.v!==Tt||Reflect.has(a,l);if(h!==void 0||it!==null&&(!c||_i(a,l)?.writable)){h===void 0&&(h=o(()=>{var d=c?Yi(a[l]):Tt,f=Ht(d);return f}),e.set(l,h));var u=Z(h);if(u===Tt)return!1}return c},set(a,l,h,c){var u=e.get(l),d=l in a;if(i&&l==="length")for(var f=h;f<u.v;f+=1){var g=e.get(f+"");g!==void 0?Dt(g,Tt):f in a&&(g=o(()=>Ht(Tt)),e.set(f+"",g))}if(u===void 0)(!d||_i(a,l)?.writable)&&(u=o(()=>Ht(void 0)),Dt(u,Yi(h)),e.set(l,u));else{d=u.v!==Tt;var m=o(()=>Yi(h));Dt(u,m)}var _=Reflect.getOwnPropertyDescriptor(a,l);if(_?.set&&_.set.call(c,h),!d){if(i&&typeof l=="string"){var p=e.get("length"),y=Number(l);Number.isInteger(y)&&y>=p.v&&Dt(p,y+1)}Sn(s)}return!0},ownKeys(a){Z(s);var l=Reflect.ownKeys(a).filter(u=>{var d=e.get(u);return d===void 0||d.v!==Tt});for(var[h,c]of e)c.v!==Tt&&!(h in a)&&l.push(h);return l},setPrototypeOf(){Fu()}})}var Kr,sl,rl,ol;function Br(){if(Kr===void 0){Kr=window,sl=/Firefox/.test(navigator.userAgent);var n=Element.prototype,t=Node.prototype,e=Text.prototype;rl=_i(t,"firstChild").get,ol=_i(t,"nextSibling").get,Pa(n)&&(n.__click=void 0,n.__className=void 0,n.__attributes=null,n.__style=void 0,n.__e=void 0),Pa(e)&&(e.__t=void 0)}}function bn(n=""){return document.createTextNode(n)}function Ln(n){return rl.call(n)}function Le(n){return ol.call(n)}function td(n,t){if(!Et)return Ln(n);var e=Ln(rt);return e===null&&(e=rt.appendChild(bn())),Se(e),e}function ed(n,t=!1){if(!Et){var e=Ln(n);return e instanceof Comment&&e.data===""?Le(e):e}if(t&&rt?.nodeType!==za){var i=bn();return rt?.before(i),Se(i),i}return rt}function id(n,t=1,e=!1){let i=Et?rt:n;for(var s;t--;)s=i,i=Le(i);if(!Et)return i;if(e&&i?.nodeType!==za){var r=bn();return i===null?s?.after(r):i.before(r),Se(r),r}return Se(i),i}function nd(n){n.textContent=""}function Zr(n){var t=H,e=it;qt(null),Qe(null);try{return n()}finally{qt(t),Qe(e)}}function sd(n){it===null&&(H===null&&Au(),Lu()),xi&&bu()}function rd(n,t){var e=t.last;e===null?t.last=t.first=n:(e.next=n,n.prev=e,t.last=n)}function qe(n,t,e){var i=it;i!==null&&(i.f&Ue)!==0&&(n|=Ue);var s={ctx:Ut,deps:null,nodes_start:null,nodes_end:null,f:n|Yt|he,first:null,fn:t,last:null,next:null,parent:i,b:i&&i.b,prev:null,teardown:null,transitions:null,wv:0,ac:null};if(e)try{Pn(s),s.f|=ws}catch(a){throw ue(s),a}else t!==null&&Wi(s);var r=s;if(e&&r.deps===null&&r.teardown===null&&r.nodes_start===null&&r.first===r.last&&(r.f&Xi)===0&&(r=r.first,(n&Te)!==0&&(n&Cs)!==0&&r!==null&&(r.f|=Cs)),r!==null&&(r.parent=i,i!==null&&rd(r,i),H!==null&&(H.f&pt)!==0&&(n&Ze)===0)){var o=H;(o.effects??=[]).push(r)}return s}function Os(){return H!==null&&!ye}function od(n){const t=qe(Oa,null,!1);return Lt(t,It),t.teardown=n,t}function Ur(n){sd();var t=it.f,e=!H&&(t&Be)!==0&&(t&ws)===0;if(e){var i=Ut;(i.e??=[]).push(n)}else return al(n)}function al(n){return qe(Nr|Iu,n,!1)}function ad(n){ce.ensure();const t=qe(Ze|Xi,n,!0);return()=>{ue(t)}}function ld(n){ce.ensure();const t=qe(Ze|Xi,n,!0);return(e={})=>new Promise(i=>{e.outro?Ds(t,()=>{ue(t),i(void 0)}):(ue(t),i(void 0))})}function hd(n){return qe(Nr,n,!1)}function ll(n,t=0){return qe(Oa|t,n,!0)}function cd(n,t=0){var e=qe(Te|t,n,!0);return e}function yi(n){return qe(Be|Xi,n,!0)}function hl(n){var t=n.teardown;if(t!==null){const e=xi,i=H;fl(!0),qt(null);try{t.call(null)}finally{fl(e),qt(i)}}}function cl(n,t=!1){var e=n.first;for(n.first=n.last=null;e!==null;){const s=e.ac;s!==null&&Zr(()=>{s.abort(Ga)});var i=e.next;(e.f&Ze)!==0?e.parent=null:ue(e,t),e=i}}function ud(n){for(var t=n.first;t!==null;){var e=t.next;(t.f&Be)===0&&ue(t),t=e}}function ue(n,t=!0){var e=!1;(t||(n.f&Fa)!==0)&&n.nodes_start!==null&&n.nodes_end!==null&&(dd(n.nodes_start,n.nodes_end),e=!0),cl(n,t&&!e),ks(n,0),Lt(n,Ve);var i=n.transitions;if(i!==null)for(const r of i)r.stop();hl(n);var s=n.parent;s!==null&&s.first!==null&&ul(n),n.next=n.prev=n.teardown=n.ctx=n.deps=n.fn=n.nodes_start=n.nodes_end=n.ac=null}function dd(n,t){for(;n!==null;){var e=n===t?null:Le(n);n.remove(),n=e}}function ul(n){var t=n.parent,e=n.prev,i=n.next;e!==null&&(e.next=i),i!==null&&(i.prev=e),t!==null&&(t.first===n&&(t.first=i),t.last===n&&(t.last=e))}function Ds(n,t,e=!0){var i=[];dl(n,i,!0),fd(i,()=>{e&&ue(n),t&&t()})}function fd(n,t){var e=n.length;if(e>0){var i=()=>--e||t();for(var s of n)s.out(i)}else t()}function dl(n,t,e){if((n.f&Ue)===0){if(n.f^=Ue,n.transitions!==null)for(const o of n.transitions)(o.is_global||e)&&t.push(o);for(var i=n.first;i!==null;){var s=i.next,r=(i.f&Cs)!==0||(i.f&Be)!==0&&(n.f&Te)!==0;dl(i,t,r?e:!1),i=s}}}function gd(n,t){for(var e=n.nodes_start,i=n.nodes_end;e!==null;){var s=e===i?null:Le(e);t.append(e),e=s}}let Je=!1;function Fs(n){Je=n}let xi=!1;function fl(n){xi=n}let H=null,ye=!1;function qt(n){H=n}let it=null;function Qe(n){it=n}let Ae=null;function gl(n){H!==null&&(Ae===null?Ae=[n]:Ae.push(n))}let bt=null,$t=0,Jt=null;function _d(n){Jt=n}let _l=1,An=0,Ei=An;function ml(n){Ei=n}function pl(){return++_l}function Mn(n){var t=n.f;if((t&Yt)!==0)return!0;if(t&pt&&(n.f&=~mi),(t&Ie)!==0){var e=n.deps;if(e!==null)for(var i=e.length,s=0;s<i;s++){var r=e[s];if(Mn(r)&&tl(r),r.wv>n.wv)return!0}(t&he)!==0&&Vt===null&&Lt(n,It)}return!1}function yl(n,t,e=!0){var i=n.reactions;if(i!==null&&!Ae?.includes(n))for(var s=0;s<i.length;s++){var r=i[s];(r.f&pt)!==0?yl(r,t,!1):t===r&&(e?Lt(r,Yt):(r.f&It)!==0&&Lt(r,Ie),Wi(r))}}function xl(n){var t=bt,e=$t,i=Jt,s=H,r=Ae,o=Ut,a=ye,l=Ei,h=n.f;bt=null,$t=0,Jt=null,H=(h&(Be|Ze))===0?n:null,Ae=null,Ss(n.ctx),ye=!1,Ei=++An,n.ac!==null&&(Zr(()=>{n.ac.abort(Ga)}),n.ac=null);try{n.f|=Gr;var c=n.fn,u=c(),d=n.deps;if(bt!==null){var f;if(ks(n,$t),d!==null&&$t>0)for(d.length=$t+bt.length,f=0;f<bt.length;f++)d[$t+f]=bt[f];else n.deps=d=bt;if(Je&&Os()&&(n.f&he)!==0)for(f=$t;f<d.length;f++)(d[f].reactions??=[]).push(n)}else d!==null&&$t<d.length&&(ks(n,$t),d.length=$t);if(Za()&&Jt!==null&&!ye&&d!==null&&(n.f&(pt|Ie|Yt))===0)for(f=0;f<Jt.length;f++)yl(Jt[f],n);return s!==null&&s!==n&&(An++,Jt!==null&&(i===null?i=Jt:i.push(...Jt))),(n.f&Tn)!==0&&(n.f^=Tn),u}catch(g){return Va(g)}finally{n.f^=Gr,bt=t,$t=e,Jt=i,H=s,Ae=r,Ss(o),ye=a,Ei=l}}function md(n,t){let e=t.reactions;if(e!==null){var i=xu.call(e,n);if(i!==-1){var s=e.length-1;s===0?e=t.reactions=null:(e[i]=e[s],e.pop())}}e===null&&(t.f&pt)!==0&&(bt===null||!bt.includes(t))&&(Lt(t,Ie),(t.f&he)!==0&&(t.f^=he,t.f&=~mi),Qa(t),ks(t,0))}function ks(n,t){var e=n.deps;if(e!==null)for(var i=t;i<e.length;i++)md(n,e[i])}function Pn(n){var t=n.f;if((t&Ve)===0){Lt(n,It);var e=it,i=Je;it=n,Je=!0;try{(t&Te)!==0?ud(n):cl(n),hl(n);var s=xl(n);n.teardown=typeof s=="function"?s:null,n.wv=_l;var r;kr&&Yu&&(n.f&Yt)!==0&&n.deps}finally{Je=i,it=e}}}function Z(n){var t=n.f,e=(t&pt)!==0;if(H!==null&&!ye){var i=it!==null&&(it.f&Ve)!==0;if(!i&&!Ae?.includes(n)){var s=H.deps;if((H.f&Gr)!==0)n.rv<An&&(n.rv=An,bt===null&&s!==null&&s[$t]===n?$t++:bt===null?bt=[n]:bt.includes(n)||bt.push(n));else{(H.deps??=[]).push(n);var r=n.reactions;r===null?n.reactions=[H]:r.includes(H)||r.push(H)}}}if(xi){if(He.has(n))return He.get(n);if(e){var o=n,a=o.v;return((o.f&It)===0&&o.reactions!==null||vl(o))&&(a=Yr(o)),He.set(o,a),a}}else e&&!Vt?.has(n)&&(o=n,Mn(o)&&tl(o),Je&&Os()&&(o.f&he)===0&&El(o));if(Vt?.has(n))return Vt.get(n);if((n.f&Tn)!==0)throw n.v;return n.v}function El(n){if(n.deps!==null){n.f^=he;for(const t of n.deps)(t.reactions??=[]).push(n),(t.f&pt)!==0&&(t.f&he)===0&&El(t)}}function vl(n){if(n.v===Tt)return!0;if(n.deps===null)return!1;for(const t of n.deps)if(He.has(t)||(t.f&pt)!==0&&vl(t))return!0;return!1}function Vr(n){var t=ye;try{return ye=!0,n()}finally{ye=t}}const pd=-7169;function Lt(n,t){n.f=n.f&pd|t}const wl=new Set,jr=new Set;function yd(n,t,e,i={}){function s(r){if(i.capture||On.call(t,r),!r.cancelBubble)return Zr(()=>e?.call(this,r))}return n.startsWith("pointer")||n.startsWith("touch")||n==="wheel"?bs(()=>{t.addEventListener(n,s,i)}):t.addEventListener(n,s,i),s}function xd(n,t,e,i,s){var r={capture:i,passive:s},o=yd(n,t,e,r);(t===document.body||t===window||t===document||t instanceof HTMLMediaElement)&&od(()=>{t.removeEventListener(n,o,r)})}function Ed(n){for(var t=0;t<n.length;t++)wl.add(n[t]);for(var e of jr)e(n)}let Cl=null;function On(n){var t=this,e=t.ownerDocument,i=n.type,s=n.composedPath?.()||[],r=s[0]||n.target;Cl=n;var o=0,a=Cl===n&&n.__root;if(a){var l=s.indexOf(a);if(l!==-1&&(t===document||t===window)){n.__root=t;return}var h=s.indexOf(t);if(h===-1)return;l<=h&&(o=l)}if(r=s[o]||n.target,r!==t){Es(n,"currentTarget",{configurable:!0,get(){return r||e}});var c=H,u=it;qt(null),Qe(null);try{for(var d,f=[];r!==null;){var g=r.assignedSlot||r.parentNode||r.host||null;try{var m=r["__"+i];m!=null&&(!r.disabled||n.target===r)&&m.call(r,n)}catch(_){d?f.push(_):d=_}if(n.cancelBubble||g===t||g===null)break;r=g}if(d){for(let _ of f)queueMicrotask(()=>{throw _});throw d}}finally{n.__root=t,delete n.currentTarget,qt(c),Qe(u)}}}function vd(n){var t=document.createElement("template");return t.innerHTML=n.replaceAll("<!>","<!---->"),t.content}function Hr(n,t){var e=it;e.nodes_start===null&&(e.nodes_start=n,e.nodes_end=t)}function wd(n,t){var e=(t&pu)!==0,i,s=!n.startsWith("<!>");return()=>{if(Et)return Hr(rt,null),rt;i===void 0&&(i=vd(s?n:"<!>"+n));var r=e||sl?document.importNode(i,!0):i.cloneNode(!0);{var o=Ln(r),a=r.lastChild;Hr(o,a)}return r}}function Rl(n,t){if(Et){var e=it;((e.f&ws)===0||e.nodes_end===null)&&(e.nodes_end=rt),Xa();return}n!==null&&n.before(t)}const Cd=["touchstart","touchmove"];function Rd(n){return Cd.includes(n)}function Tl(n,t){return Il(n,t)}function Td(n,t){Br(),t.intro=t.intro??!1;const e=t.target,i=Et,s=rt;try{for(var r=Ln(e);r&&(r.nodeType!==Ts||r.data!==La);)r=Le(r);if(!r)throw Rn;Is(!0),Se(r);const o=Il(n,{...t,anchor:r});return Is(!1),o}catch(o){if(o instanceof Error&&o.message.split(`
|
|
2
|
-
`).some(a=>a.startsWith("https://svelte.dev/e/")))throw o;return o!==Rn&&console.warn("Failed to hydrate: ",o),t.recover===!1&&Pu(),Br(),nd(e),Is(!1),Tl(n,t)}finally{Is(i),Se(s)}}const $i=new Map;function Il(n,{target:t,anchor:e,props:i={},events:s,context:r,intro:o=!0}){Br();var a=new Set,l=u=>{for(var d=0;d<u.length;d++){var f=u[d];if(!a.has(f)){a.add(f);var g=Rd(f);t.addEventListener(f,On,{passive:g});var m=$i.get(f);m===void 0?(document.addEventListener(f,On,{passive:g}),$i.set(f,1)):$i.set(f,m+1)}}};l(Eu(wl)),jr.add(l);var h=void 0,c=ld(()=>{var u=e??t.appendChild(bn());return Uu(u,{pending:()=>{}},d=>{if(r){Ka({});var f=Ut;f.c=r}if(s&&(i.$$events=s),Et&&Hr(d,null),h=n(d,i)||{},Et&&(it.nodes_end=rt,rt===null||rt.nodeType!==Ts||rt.data!==Ma))throw zr(),Rn;r&&Ba()}),()=>{for(var d of a){t.removeEventListener(d,On);var f=$i.get(d);--f===0?(document.removeEventListener(d,On),$i.delete(d)):$i.set(d,f)}jr.delete(l),u!==e&&u.parentNode?.removeChild(u)}});return qr.set(h,c),h}let qr=new WeakMap;function Id(n,t){const e=qr.get(n);return e?(qr.delete(n),e(t)):Promise.resolve()}function Sd(n){Ut===null&&Su(),Ur(()=>{const t=Vr(n);if(typeof t=="function")return t})}function bd(n,t){hd(()=>{var e=n.getRootNode(),i=e.host?e:e.head??e.ownerDocument.head;if(!i.querySelector("#"+t.hash)){const s=document.createElement("style");s.id=t.hash,s.textContent=t.code,i.appendChild(s)}})}let Ns=!1;function Ld(n){var t=Ns;try{return Ns=!1,[n(),Ns]}finally{Ns=t}}function vi(n,t,e,i){var s=(e&_u)!==0,r=(e&mu)!==0,o=i,a=!0,l=()=>(a&&(a=!1,o=r?Vr(i):i),o),h;if(s){var c=Rs in n||Na in n;h=_i(n,t)?.set??(c&&t in n?y=>n[t]=y:void 0)}var u,d=!1;s?[u,d]=Ld(()=>n[t]):u=n[t],u===void 0&&i!==void 0&&(u=l(),h&&(Ou(),h(u)));var f;if(f=()=>{var y=n[t];return y===void 0?l():(a=!0,y)},(e&gu)===0)return f;if(h){var g=n.$$legacy;return(function(y,w){return arguments.length>0?((!w||g||d)&&h(w?f():y),y):f()})}var m=!1,_=((e&fu)!==0?Wr:Hu)(()=>(m=!1,f()));s&&Z(_);var p=it;return(function(y,w){if(arguments.length>0){const x=w?Z(_):s?Yi(y):y;return Dt(_,x),m=!0,o!==void 0&&(o=x),y}return xi&&m||(p.f&Ve)!==0?_.v:Z(_)})}function Ad(n){return new Md(n)}class Md{#e;#t;constructor(t){var e=new Map,i=(r,o)=>{var a=Ju(o,!1,!1);return e.set(r,a),a};const s=new Proxy({...t.props||{},$$events:{}},{get(r,o){return Z(e.get(o)??i(o,Reflect.get(r,o)))},has(r,o){return o===Na?!0:(Z(e.get(o)??i(o,Reflect.get(r,o))),Reflect.has(r,o))},set(r,o,a){return Dt(e.get(o)??i(o,a),a),Reflect.set(r,o,a)}});this.#t=(t.hydrate?Td:Tl)(t.component,{target:t.target,anchor:t.anchor,props:s,context:t.context,intro:t.intro??!1,recover:t.recover}),(!t?.props?.$$host||t.sync===!1)&&je(),this.#e=s.$$events;for(const r of Object.keys(this.#t))r==="$set"||r==="$destroy"||r==="$on"||Es(this,r,{get(){return this.#t[r]},set(o){this.#t[r]=o},enumerable:!0});this.#t.$set=r=>{Object.assign(s,r)},this.#t.$destroy=()=>{Id(this.#t)}}$set(t){this.#t.$set(t)}$on(t,e){this.#e[t]=this.#e[t]||[];const i=(...s)=>e.call(this,...s);return this.#e[t].push(i),()=>{this.#e[t]=this.#e[t].filter(s=>s!==i)}}$destroy(){this.#t.$destroy()}}let Sl;typeof HTMLElement=="function"&&(Sl=class extends HTMLElement{$$ctor;$$s;$$c;$$cn=!1;$$d={};$$r=!1;$$p_d={};$$l={};$$l_u=new Map;$$me;constructor(n,t,e){super(),this.$$ctor=n,this.$$s=t,e&&this.attachShadow({mode:"open"})}addEventListener(n,t,e){if(this.$$l[n]=this.$$l[n]||[],this.$$l[n].push(t),this.$$c){const i=this.$$c.$on(n,t);this.$$l_u.set(t,i)}super.addEventListener(n,t,e)}removeEventListener(n,t,e){if(super.removeEventListener(n,t,e),this.$$c){const i=this.$$l_u.get(t);i&&(i(),this.$$l_u.delete(t))}}async connectedCallback(){if(this.$$cn=!0,!this.$$c){let n=function(i){return s=>{const r=document.createElement("slot");i!=="default"&&(r.name=i),Rl(s,r)}};if(await Promise.resolve(),!this.$$cn||this.$$c)return;const t={},e=Pd(this);for(const i of this.$$s)i in e&&(i==="default"&&!this.$$d.children?(this.$$d.children=n(i),t.default=!0):t[i]=n(i));for(const i of this.attributes){const s=this.$$g_p(i.name);s in this.$$d||(this.$$d[s]=Gs(s,i.value,this.$$p_d,"toProp"))}for(const i in this.$$p_d)!(i in this.$$d)&&this[i]!==void 0&&(this.$$d[i]=this[i],delete this[i]);this.$$c=Ad({component:this.$$ctor,target:this.shadowRoot||this,props:{...this.$$d,$$slots:t,$$host:this}}),this.$$me=ad(()=>{ll(()=>{this.$$r=!0;for(const i of xs(this.$$c)){if(!this.$$p_d[i]?.reflect)continue;this.$$d[i]=this.$$c[i];const s=Gs(i,this.$$d[i],this.$$p_d,"toAttribute");s==null?this.removeAttribute(this.$$p_d[i].attribute||i):this.setAttribute(this.$$p_d[i].attribute||i,s)}this.$$r=!1})});for(const i in this.$$l)for(const s of this.$$l[i]){const r=this.$$c.$on(i,s);this.$$l_u.set(s,r)}this.$$l={}}}attributeChangedCallback(n,t,e){this.$$r||(n=this.$$g_p(n),this.$$d[n]=Gs(n,e,this.$$p_d,"toProp"),this.$$c?.$set({[n]:this.$$d[n]}))}disconnectedCallback(){this.$$cn=!1,Promise.resolve().then(()=>{!this.$$cn&&this.$$c&&(this.$$c.$destroy(),this.$$me(),this.$$c=void 0)})}$$g_p(n){return xs(this.$$p_d).find(t=>this.$$p_d[t].attribute===n||!this.$$p_d[t].attribute&&t.toLowerCase()===n)||n}});function Gs(n,t,e,i){const s=e[n]?.type;if(t=s==="Boolean"&&typeof t!="boolean"?t!=null:t,!i||!e[n])return t;if(i==="toAttribute")switch(s){case"Object":case"Array":return t==null?null:JSON.stringify(t);case"Boolean":return t?"":null;case"Number":return t??null;default:return t}else switch(s){case"Object":case"Array":return t&&JSON.parse(t);case"Boolean":return t;case"Number":return t!=null?+t:t;default:return t}}function Pd(n){const t={};return n.childNodes.forEach(e=>{t[e.slot||"default"]=!0}),t}function Od(n,t,e,i,s,r){let o=class extends Sl{constructor(){super(n,e,s),this.$$p_d=t}static get observedAttributes(){return xs(t).map(a=>(t[a].attribute||a).toLowerCase())}};return xs(t).forEach(a=>{Es(o.prototype,a,{get(){return this.$$c&&a in this.$$c?this.$$c[a]:this.$$d[a]},set(l){l=Gs(a,l,t),this.$$d[a]=l;var h=this.$$c;if(h){var c=_i(h,a)?.get;c?h[a]=l:h.$set({[a]:l})}}})}),i.forEach(a=>{Es(o.prototype,a,{get(){return this.$$c?.[a]}})}),n.element=o,o}const Ft={ADD:"add",REMOVE:"remove"},Ki={PROPERTYCHANGE:"propertychange"},W={CHANGE:"change",ERROR:"error",CONTEXTMENU:"contextmenu",CLICK:"click",DBLCLICK:"dblclick",KEYDOWN:"keydown",KEYPRESS:"keypress",LOAD:"load",TOUCHMOVE:"touchmove",WHEEL:"wheel"};class zs{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}}function Dd(n,t,e){let i,s;e=e||Me;let r=0,o=n.length,a=!1;for(;r<o;)i=r+(o-r>>1),s=+e(n[i],t),s<0?r=i+1:(o=i,a=!s);return a?r:~r}function Me(n,t){return n>t?1:n<t?-1:0}function Fd(n,t){return n<t?1:n>t?-1:0}function Jr(n,t,e){if(n[0]<=t)return 0;const i=n.length;if(t<=n[i-1])return i-1;if(typeof e=="function"){for(let s=1;s<i;++s){const r=n[s];if(r===t)return s;if(r<t)return e(t,n[s-1],r)>0?s-1:s}return i-1}if(e>0){for(let s=1;s<i;++s)if(n[s]<t)return s-1;return i-1}if(e<0){for(let s=1;s<i;++s)if(n[s]<=t)return s;return i-1}for(let s=1;s<i;++s){if(n[s]==t)return s;if(n[s]<t)return n[s-1]-t<t-n[s]?s-1:s}return i-1}function kd(n,t,e){for(;t<e;){const i=n[t];n[t]=n[e],n[e]=i,++t,--e}}function Qr(n,t){const e=Array.isArray(t)?t:[t],i=e.length;for(let s=0;s<i;s++)n[n.length]=e[s]}function ti(n,t){const e=n.length;if(e!==t.length)return!1;for(let i=0;i<e;i++)if(n[i]!==t[i])return!1;return!0}function Nd(n,t,e){const i=t||Me;return n.every(function(s,r){if(r===0)return!0;const o=i(n[r-1],s);return!(o>0||o===0)})}function Dn(){return!0}function Xs(){return!1}function Fn(){}function bl(n){let t,e,i;return function(){const s=Array.prototype.slice.call(arguments);return(!e||this!==i||!ti(s,e))&&(i=this,e=s,t=n.apply(this,arguments)),t}}function Gd(n){function t(){let e;try{e=n()}catch(i){return Promise.reject(i)}return e instanceof Promise?e:Promise.resolve(e)}return t()}function kn(n){for(const t in n)delete n[t]}function Bi(n){let t;for(t in n)return!1;return!t}class Pe{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}}class Ws extends zs{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;const i=this.listeners_||(this.listeners_={}),s=i[t]||(i[t]=[]);s.includes(e)||s.push(e)}dispatchEvent(t){const e=typeof t=="string",i=e?t:t.type,s=this.listeners_&&this.listeners_[i];if(!s)return;const r=e?new Pe(t):t;r.target||(r.target=this.eventTarget_||this);const o=this.dispatching_||(this.dispatching_={}),a=this.pendingRemovals_||(this.pendingRemovals_={});i in o||(o[i]=0,a[i]=0),++o[i];let l;for(let h=0,c=s.length;h<c;++h)if("handleEvent"in s[h]?l=s[h].handleEvent(r):l=s[h].call(this,r),l===!1||r.propagationStopped){l=!1;break}if(--o[i]===0){let h=a[i];for(delete a[i];h--;)this.removeEventListener(i,Fn);delete o[i]}return l}disposeInternal(){this.listeners_&&kn(this.listeners_)}getListeners(t){return this.listeners_&&this.listeners_[t]||void 0}hasListener(t){return this.listeners_?t?t in this.listeners_:Object.keys(this.listeners_).length>0:!1}removeEventListener(t,e){if(!this.listeners_)return;const i=this.listeners_[t];if(!i)return;const s=i.indexOf(e);s!==-1&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[s]=Fn,++this.pendingRemovals_[t]):(i.splice(s,1),i.length===0&&delete this.listeners_[t]))}}function U(n,t,e,i,s){if(s){const o=e;e=function(a){return n.removeEventListener(t,e),o.call(i??this,a)}}else i&&i!==n&&(e=e.bind(i));const r={target:n,type:t,listener:e};return n.addEventListener(t,e),r}function Ys(n,t,e,i){return U(n,t,e,i,!0)}function nt(n){n&&n.target&&(n.target.removeEventListener(n.type,n.listener),kn(n))}class Nn extends Ws{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(W.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){const i=t.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=U(this,t[r],e);return s}return U(this,t,e)}onceInternal(t,e){let i;if(Array.isArray(t)){const s=t.length;i=new Array(s);for(let r=0;r<s;++r)i[r]=Ys(this,t[r],e)}else i=Ys(this,t,e);return e.ol_key=i,i}unInternal(t,e){const i=e.ol_key;if(i)zd(i);else if(Array.isArray(t))for(let s=0,r=t.length;s<r;++s)this.removeEventListener(t[s],e);else this.removeEventListener(t,e)}}Nn.prototype.on,Nn.prototype.once,Nn.prototype.un;function zd(n){if(Array.isArray(n))for(let t=0,e=n.length;t<e;++t)nt(n[t]);else nt(n)}function V(){throw new Error("Unimplemented abstract method.")}let Xd=0;function j(n){return n.ol_uid||(n.ol_uid=String(++Xd))}class Ll extends Pe{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}}class de extends Nn{constructor(t){super(),this.on,this.once,this.un,j(this),this.values_=null,t!==void 0&&this.setProperties(t)}get(t){let e;return this.values_&&this.values_.hasOwnProperty(t)&&(e=this.values_[t]),e}getKeys(){return this.values_&&Object.keys(this.values_)||[]}getProperties(){return this.values_&&Object.assign({},this.values_)||{}}getPropertiesInternal(){return this.values_}hasProperties(){return!!this.values_}notify(t,e){let i;i=`change:${t}`,this.hasListener(i)&&this.dispatchEvent(new Ll(i,t,e)),i=Ki.PROPERTYCHANGE,this.hasListener(i)&&this.dispatchEvent(new Ll(i,t,e))}addChangeListener(t,e){this.addEventListener(`change:${t}`,e)}removeChangeListener(t,e){this.removeEventListener(`change:${t}`,e)}set(t,e,i){const s=this.values_||(this.values_={});if(i)s[t]=e;else{const r=s[t];s[t]=e,r!==e&&this.notify(t,r)}}setProperties(t,e){for(const i in t)this.set(i,t[i],e)}applyProperties(t){t.values_&&Object.assign(this.values_||(this.values_={}),t.values_)}unset(t,e){if(this.values_&&t in this.values_){const i=this.values_[t];delete this.values_[t],Bi(this.values_)&&(this.values_=null),e||this.notify(t,i)}}}const Al={LENGTH:"length"};class $s extends Pe{constructor(t,e,i){super(t),this.element=e,this.index=i}}class Qt extends de{constructor(t,e){if(super(),this.on,this.once,this.un,e=e||{},this.unique_=!!e.unique,this.array_=t??[],this.unique_)for(let i=1,s=this.array_.length;i<s;++i)this.assertUnique_(this.array_[i],i);this.updateLength_()}clear(){for(;this.getLength()>0;)this.pop()}extend(t){for(let e=0,i=t.length;e<i;++e)this.push(t[e]);return this}forEach(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)t(e[i],i,e)}getArray(){return this.array_}item(t){return this.array_[t]}getLength(){return this.get(Al.LENGTH)}insertAt(t,e){if(t<0||t>this.getLength())throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e),this.array_.splice(t,0,e),this.updateLength_(),this.dispatchEvent(new $s(Ft.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){const e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)if(e[i]===t)return this.removeAt(i)}removeAt(t){if(t<0||t>=this.getLength())return;const e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new $s(Ft.REMOVE,e,t)),e}setAt(t,e){const i=this.getLength();if(t>=i){this.insertAt(t,e);return}if(t<0)throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e,t);const s=this.array_[t];this.array_[t]=e,this.dispatchEvent(new $s(Ft.REMOVE,s,t)),this.dispatchEvent(new $s(Ft.ADD,e,t))}updateLength_(){this.set(Al.LENGTH,this.array_.length)}assertUnique_(t,e){const i=this.array_;for(let s=0,r=i.length;s<r;++s)if(i[s]===t&&s!==e)throw new Error("Duplicate item added to a unique collection")}}function Q(n,t){if(!n)throw new Error(t)}class to extends de{constructor(t){if(super(),this.on,this.once,this.un,this.id_=void 0,this.geometryName_="geometry",this.style_=null,this.styleFunction_=void 0,this.geometryChangeKey_=null,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),t)if(typeof t.getSimplifiedGeometry=="function"){const e=t;this.setGeometry(e)}else{const e=t;this.setProperties(e)}}clone(){const t=new to(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());const e=this.getGeometry();e&&t.setGeometry(e.clone());const i=this.getStyle();return i&&t.setStyle(i),t}getGeometry(){return this.get(this.geometryName_)}getId(){return this.id_}getGeometryName(){return this.geometryName_}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}handleGeometryChange_(){this.changed()}handleGeometryChanged_(){this.geometryChangeKey_&&(nt(this.geometryChangeKey_),this.geometryChangeKey_=null);const t=this.getGeometry();t&&(this.geometryChangeKey_=U(t,W.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?Wd(t):void 0,this.changed()}setId(t){this.id_=t,this.changed()}setGeometryName(t){this.removeChangeListener(this.geometryName_,this.handleGeometryChanged_),this.geometryName_=t,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),this.handleGeometryChanged_()}}function Wd(n){if(typeof n=="function")return n;let t;return Array.isArray(n)?t=n:(Q(typeof n.getZIndex=="function","Expected an `ol/style/Style` or an array of `ol/style/Style.js`"),t=[n]),function(){return t}}const dt={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16};function Ml(n){const t=Kt();for(let e=0,i=n.length;e<i;++e)zn(t,n[e]);return t}function eo(n,t,e){return e?(e[0]=n[0]-t,e[1]=n[1]-t,e[2]=n[2]+t,e[3]=n[3]+t,e):[n[0]-t,n[1]-t,n[2]+t,n[3]+t]}function Pl(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n.slice()}function Ol(n,t,e){let i,s;return t<n[0]?i=n[0]-t:n[2]<t?i=t-n[2]:i=0,e<n[1]?s=n[1]-e:n[3]<e?s=e-n[3]:s=0,i*i+s*s}function Zi(n,t){return Dl(n,t[0],t[1])}function Ui(n,t){return n[0]<=t[0]&&t[2]<=n[2]&&n[1]<=t[1]&&t[3]<=n[3]}function Dl(n,t,e){return n[0]<=t&&t<=n[2]&&n[1]<=e&&e<=n[3]}function io(n,t){const e=n[0],i=n[1],s=n[2],r=n[3],o=t[0],a=t[1];let l=dt.UNKNOWN;return o<e?l=l|dt.LEFT:o>s&&(l=l|dt.RIGHT),a<i?l=l|dt.BELOW:a>r&&(l=l|dt.ABOVE),l===dt.UNKNOWN&&(l=dt.INTERSECTING),l}function Kt(){return[1/0,1/0,-1/0,-1/0]}function ei(n,t,e,i,s){return s?(s[0]=n,s[1]=t,s[2]=e,s[3]=i,s):[n,t,e,i]}function Ks(n){return ei(1/0,1/0,-1/0,-1/0,n)}function Fl(n,t){const e=n[0],i=n[1];return ei(e,i,e,i,t)}function no(n,t,e,i,s){const r=Ks(s);return Nl(r,n,t,e,i)}function Gn(n,t){return n[0]==t[0]&&n[2]==t[2]&&n[1]==t[1]&&n[3]==t[3]}function kl(n,t){return t[0]<n[0]&&(n[0]=t[0]),t[2]>n[2]&&(n[2]=t[2]),t[1]<n[1]&&(n[1]=t[1]),t[3]>n[3]&&(n[3]=t[3]),n}function zn(n,t){t[0]<n[0]&&(n[0]=t[0]),t[0]>n[2]&&(n[2]=t[0]),t[1]<n[1]&&(n[1]=t[1]),t[1]>n[3]&&(n[3]=t[1])}function Nl(n,t,e,i,s){for(;e<i;e+=s)Yd(n,t[e],t[e+1]);return n}function Yd(n,t,e){n[0]=Math.min(n[0],t),n[1]=Math.min(n[1],e),n[2]=Math.max(n[2],t),n[3]=Math.max(n[3],e)}function Gl(n,t){let e;return e=t(Bs(n)),e||(e=t(Zs(n)),e)||(e=t(Us(n)),e)||(e=t(Ri(n)),e)?e:!1}function so(n){let t=0;return Vs(n)||(t=tt(n)*At(n)),t}function Bs(n){return[n[0],n[1]]}function Zs(n){return[n[2],n[1]]}function wi(n){return[(n[0]+n[2])/2,(n[1]+n[3])/2]}function $d(n,t){let e;if(t==="bottom-left")e=Bs(n);else if(t==="bottom-right")e=Zs(n);else if(t==="top-left")e=Ri(n);else if(t==="top-right")e=Us(n);else throw new Error("Invalid corner");return e}function ro(n,t,e,i,s){const[r,o,a,l,h,c,u,d]=zl(n,t,e,i);return ei(Math.min(r,a,h,u),Math.min(o,l,c,d),Math.max(r,a,h,u),Math.max(o,l,c,d),s)}function zl(n,t,e,i){const s=t*i[0]/2,r=t*i[1]/2,o=Math.cos(e),a=Math.sin(e),l=s*o,h=s*a,c=r*o,u=r*a,d=n[0],f=n[1];return[d-l+u,f-h-c,d-l-u,f-h+c,d+l-u,f+h+c,d+l+u,f+h-c,d-l+u,f-h-c]}function At(n){return n[3]-n[1]}function Ci(n,t,e){const i=e||Kt();return kt(n,t)?(n[0]>t[0]?i[0]=n[0]:i[0]=t[0],n[1]>t[1]?i[1]=n[1]:i[1]=t[1],n[2]<t[2]?i[2]=n[2]:i[2]=t[2],n[3]<t[3]?i[3]=n[3]:i[3]=t[3]):Ks(i),i}function Ri(n){return[n[0],n[3]]}function Us(n){return[n[2],n[3]]}function tt(n){return n[2]-n[0]}function kt(n,t){return n[0]<=t[2]&&n[2]>=t[0]&&n[1]<=t[3]&&n[3]>=t[1]}function Vs(n){return n[2]<n[0]||n[3]<n[1]}function Kd(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n}function Bd(n,t,e){let i=!1;const s=io(n,t),r=io(n,e);if(s===dt.INTERSECTING||r===dt.INTERSECTING)i=!0;else{const o=n[0],a=n[1],l=n[2],h=n[3],c=t[0],u=t[1],d=e[0],f=e[1],g=(f-u)/(d-c);let m,_;r&dt.ABOVE&&!(s&dt.ABOVE)&&(m=d-(f-h)/g,i=m>=o&&m<=l),!i&&r&dt.RIGHT&&!(s&dt.RIGHT)&&(_=f-(d-l)*g,i=_>=a&&_<=h),!i&&r&dt.BELOW&&!(s&dt.BELOW)&&(m=d-(f-a)/g,i=m>=o&&m<=l),!i&&r&dt.LEFT&&!(s&dt.LEFT)&&(_=f-(d-o)*g,i=_>=a&&_<=h)}return i}function Xl(n,t){const e=t.getExtent(),i=wi(n);if(t.canWrapX()&&(i[0]<e[0]||i[0]>=e[2])){const s=tt(e),o=Math.floor((i[0]-e[0])/s)*s;n[0]-=o,n[2]-=o}return n}function Wl(n,t,e){if(t.canWrapX()){const i=t.getExtent();if(!isFinite(n[0])||!isFinite(n[2]))return[[i[0],n[1],i[2],n[3]]];Xl(n,t);const s=tt(i);if(tt(n)>s&&!e)return[[i[0],n[1],i[2],n[3]]];if(n[0]<i[0])return[[n[0]+s,n[1],i[2],n[3]],[i[0],n[1],n[2],n[3]]];if(n[2]>i[2])return[[n[0],n[1],i[2],n[3]],[i[0],n[1],n[2]-s,n[3]]]}return[n]}function ot(n,t,e){return Math.min(Math.max(n,t),e)}function Zd(n,t,e,i,s,r){const o=s-e,a=r-i;if(o!==0||a!==0){const l=((n-e)*o+(t-i)*a)/(o*o+a*a);l>1?(e=s,i=r):l>0&&(e+=o*l,i+=a*l)}return Vi(n,t,e,i)}function Vi(n,t,e,i){const s=e-n,r=i-t;return s*s+r*r}function Ud(n){const t=n.length;for(let i=0;i<t;i++){let s=i,r=Math.abs(n[i][i]);for(let a=i+1;a<t;a++){const l=Math.abs(n[a][i]);l>r&&(r=l,s=a)}if(r===0)return null;const o=n[s];n[s]=n[i],n[i]=o;for(let a=i+1;a<t;a++){const l=-n[a][i]/n[i][i];for(let h=i;h<t+1;h++)i==h?n[a][h]=0:n[a][h]+=l*n[i][h]}}const e=new Array(t);for(let i=t-1;i>=0;i--){e[i]=n[i][t]/n[i][i];for(let s=i-1;s>=0;s--)n[s][t]-=n[s][i]*e[i]}return e}function Yl(n){return n*180/Math.PI}function ii(n){return n*Math.PI/180}function ji(n,t){const e=n%t;return e*t<0?e+t:e}function te(n,t,e){return n+e*(t-n)}function js(n,t){const e=Math.pow(10,t);return Math.round(n*e)/e}function Hs(n,t){return Math.floor(js(n,t))}function qs(n,t){return Math.ceil(js(n,t))}function oo(n,t,e){if(n>=t&&n<e)return n;const i=e-t;return((n-t)%i+i)%i+t}const Vd=63710088e-1;function $l(n,t,e){e=e||Vd;const i=ii(n[1]),s=ii(t[1]),r=(s-i)/2,o=ii(t[0]-n[0])/2,a=Math.sin(r)*Math.sin(r)+Math.sin(o)*Math.sin(o)*Math.cos(i)*Math.cos(s);return 2*e*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}function Kl(...n){console.warn(...n)}function jd(n,t){return n[0]+=+t[0],n[1]+=+t[1],n}function Js(n,t){let e=!0;for(let i=n.length-1;i>=0;--i)if(n[i]!=t[i]){e=!1;break}return e}function ao(n,t){const e=Math.cos(t),i=Math.sin(t),s=n[0]*e-n[1]*i,r=n[1]*e+n[0]*i;return n[0]=s,n[1]=r,n}function Hd(n,t){return n[0]*=t,n[1]*=t,n}function Bl(n,t){if(t.canWrapX()){const e=tt(t.getExtent()),i=qd(n,t,e);i&&(n[0]-=i*e)}return n}function qd(n,t,e){const i=t.getExtent();let s=0;return t.canWrapX()&&(n[0]<i[0]||n[0]>i[2])&&(e=e||tt(i),s=Math.floor((n[0]-i[0])/e)),s}const lo={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937};class ho{constructor(t){this.code_=t.code,this.units_=t.units,this.extent_=t.extent!==void 0?t.extent:null,this.worldExtent_=t.worldExtent!==void 0?t.worldExtent:null,this.axisOrientation_=t.axisOrientation!==void 0?t.axisOrientation:"enu",this.global_=t.global!==void 0?t.global:!1,this.canWrapX_=!!(this.global_&&this.extent_),this.getPointResolutionFunc_=t.getPointResolution,this.defaultTileGrid_=null,this.metersPerUnit_=t.metersPerUnit}canWrapX(){return this.canWrapX_}getCode(){return this.code_}getExtent(){return this.extent_}getUnits(){return this.units_}getMetersPerUnit(){return this.metersPerUnit_||lo[this.units_]}getWorldExtent(){return this.worldExtent_}getAxisOrientation(){return this.axisOrientation_}isGlobal(){return this.global_}setGlobal(t){this.global_=t,this.canWrapX_=!!(t&&this.extent_)}getDefaultTileGrid(){return this.defaultTileGrid_}setDefaultTileGrid(t){this.defaultTileGrid_=t}setExtent(t){this.extent_=t,this.canWrapX_=!!(this.global_&&t)}setWorldExtent(t){this.worldExtent_=t}setGetPointResolution(t){this.getPointResolutionFunc_=t}getPointResolutionFunc(){return this.getPointResolutionFunc_}}const Xn=6378137,Hi=Math.PI*Xn,Jd=[-Hi,-Hi,Hi,Hi],Qd=[-180,-85,180,85],Qs=Xn*Math.log(Math.tan(Math.PI/2));class qi extends ho{constructor(t){super({code:t,units:"m",extent:Jd,global:!0,worldExtent:Qd,getPointResolution:function(e,i){return e/Math.cosh(i[1]/Xn)}})}}const Zl=[new qi("EPSG:3857"),new qi("EPSG:102100"),new qi("EPSG:102113"),new qi("EPSG:900913"),new qi("http://www.opengis.net/def/crs/EPSG/0/3857"),new qi("http://www.opengis.net/gml/srs/epsg.xml#3857")];function tf(n,t,e,i){const s=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(s));for(let r=0;r<s;r+=i){t[r]=Hi*n[r]/180;let o=Xn*Math.log(Math.tan(Math.PI*(+n[r+1]+90)/360));o>Qs?o=Qs:o<-Qs&&(o=-Qs),t[r+1]=o}return t}function ef(n,t,e,i){const s=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(s));for(let r=0;r<s;r+=i)t[r]=180*n[r]/Hi,t[r+1]=360*Math.atan(Math.exp(n[r+1]/Xn))/Math.PI-90;return t}const nf=6378137,Ul=[-180,-90,180,90],sf=Math.PI*nf/180;class Ti extends ho{constructor(t,e){super({code:t,units:"degrees",extent:Ul,axisOrientation:e,global:!0,metersPerUnit:sf,worldExtent:Ul})}}const Vl=[new Ti("CRS:84"),new Ti("EPSG:4326","neu"),new Ti("urn:ogc:def:crs:OGC:1.3:CRS84"),new Ti("urn:ogc:def:crs:OGC:2:84"),new Ti("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new Ti("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new Ti("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];let co={};function rf(n){return co[n]||co[n.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/,"EPSG:$3")]||null}function of(n,t){co[n]=t}let Ji={};function Wn(n,t,e){const i=n.getCode(),s=t.getCode();i in Ji||(Ji[i]={}),Ji[i][s]=e}function uo(n,t){return n in Ji&&t in Ji[n]?Ji[n][t]:null}const tr=.9996,ee=.00669438,er=ee*ee,ir=er*ee,Ii=ee/(1-ee),jl=Math.sqrt(1-ee),Qi=(1-jl)/(1+jl),Hl=Qi*Qi,fo=Hl*Qi,go=fo*Qi,ql=go*Qi,Jl=1-ee/4-3*er/64-5*ir/256,af=3*ee/8+3*er/32+45*ir/1024,lf=15*er/256+45*ir/1024,hf=35*ir/3072,cf=3/2*Qi-27/32*fo+269/512*ql,uf=21/16*Hl-55/32*go,df=151/96*fo-417/128*ql,ff=1097/512*go,nr=6378137;function gf(n,t,e){const i=n-5e5,o=(e.north?t:t-1e7)/tr/(nr*Jl),a=o+cf*Math.sin(2*o)+uf*Math.sin(4*o)+df*Math.sin(6*o)+ff*Math.sin(8*o),l=Math.sin(a),h=l*l,c=Math.cos(a),u=l/c,d=u*u,f=d*d,g=1-ee*h,m=Math.sqrt(1-ee*h),_=nr/m,p=(1-ee)/g,y=Ii*c**2,w=y*y,x=i/(_*tr),E=x*x,T=E*x,I=T*x,v=I*x,R=v*x,b=a-u/p*(E/2-I/24*(5+3*d+10*y-4*w-9*Ii))+R/720*(61+90*d+298*y+45*f-252*Ii-3*w);let O=(x-T/6*(1+2*d+y)+v/120*(5-2*y+28*d-3*w+8*Ii+24*f))/c;return O=oo(O+ii(eh(e.number)),-Math.PI,Math.PI),[Yl(O),Yl(b)]}const Ql=-80,th=84,_f=-180,mf=180;function pf(n,t,e){n=oo(n,_f,mf),t<Ql?t=Ql:t>th&&(t=th);const i=ii(t),s=Math.sin(i),r=Math.cos(i),o=s/r,a=o*o,l=a*a,h=ii(n),c=eh(e.number),u=ii(c),d=nr/Math.sqrt(1-ee*s**2),f=Ii*r**2,g=r*oo(h-u,-Math.PI,Math.PI),m=g*g,_=m*g,p=_*g,y=p*g,w=y*g,x=nr*(Jl*i-af*Math.sin(2*i)+lf*Math.sin(4*i)-hf*Math.sin(6*i)),E=tr*d*(g+_/6*(1-a+f)+y/120*(5-18*a+l+72*f-58*Ii))+5e5;let T=tr*(x+d*o*(m/2+p/24*(5-a+9*f+4*f**2)+w/720*(61-58*a+l+600*f-330*Ii)));return e.north||(T+=1e7),[E,T]}function eh(n){return(n-1)*6-180+3}const yf=[/^EPSG:(\d+)$/,/^urn:ogc:def:crs:EPSG::(\d+)$/,/^http:\/\/www\.opengis\.net\/def\/crs\/EPSG\/0\/(\d+)$/];function ih(n){let t=0;for(const s of yf){const r=n.match(s);if(r){t=parseInt(r[1]);break}}if(!t)return null;let e=0,i=!1;return t>32700&&t<32761?e=t-32700:t>32600&&t<32661&&(i=!0,e=t-32600),e?{number:e,north:i}:null}function nh(n,t){return function(e,i,s,r){const o=e.length;s=s>1?s:2,r=r??s,i||(s>2?i=e.slice():i=new Array(o));for(let a=0;a<o;a+=r){const l=e[a],h=e[a+1],c=n(l,h,t);i[a]=c[0],i[a+1]=c[1]}return i}}function xf(n){return ih(n)?new ho({code:n,units:"m"}):null}function Ef(n){const t=ih(n.getCode());return t?{forward:nh(pf,t),inverse:nh(gf,t)}:null}const vf=[Ef],wf=[xf];let _o=!0;function sh(n){_o=!1}function mo(n,t){if(t!==void 0){for(let e=0,i=n.length;e<i;++e)t[e]=n[e];t=t}else t=n.slice();return t}function po(n){of(n.getCode(),n),Wn(n,n,mo)}function Cf(n){n.forEach(po)}function Nt(n){if(typeof n!="string")return n;const t=rf(n);if(t)return t;for(const e of wf){const i=e(n);if(i)return i}return null}function rh(n,t,e,i){n=Nt(n);let s;const r=n.getPointResolutionFunc();if(r)s=r(t,e);else{const o=n.getUnits();if(o=="degrees"&&!i||i=="degrees")s=t;else{const a=Eo(n,Nt("EPSG:4326"));if(!a&&o!=="degrees")s=t*n.getMetersPerUnit();else{let h=[e[0]-t/2,e[1],e[0]+t/2,e[1],e[0],e[1]-t/2,e[0],e[1]+t/2];h=a(h,h,2);const c=$l(h.slice(0,2),h.slice(2,4)),u=$l(h.slice(4,6),h.slice(6,8));s=(c+u)/2}const l=n.getMetersPerUnit();l!==void 0&&(s/=l)}}return s}function oh(n){Cf(n),n.forEach(function(t){n.forEach(function(e){t!==e&&Wn(t,e,mo)})})}function Rf(n,t,e,i){n.forEach(function(s){t.forEach(function(r){Wn(s,r,e),Wn(r,s,i)})})}function yo(n,t){return n?typeof n=="string"?Nt(n):n:Nt(t)}function Tf(n){return(function(t,e,i,s){const r=t.length;i=i!==void 0?i:2,s=s??i,e=e!==void 0?e:new Array(r);for(let o=0;o<r;o+=s){const a=n(t.slice(o,o+i)),l=a.length;for(let h=0,c=s;h<c;++h)e[o+h]=h>=l?t[o+h]:a[h]}return e})}function xo(n,t){return sh(),Yn(n,"EPSG:4326","EPSG:3857")}function sr(n,t){if(n===t)return!0;const e=n.getUnits()===t.getUnits();return(n.getCode()===t.getCode()||Eo(n,t)===mo)&&e}function Eo(n,t){const e=n.getCode(),i=t.getCode();let s=uo(e,i);if(s)return s;let r=null,o=null;for(const l of vf)r||(r=l(n)),o||(o=l(t));if(!r&&!o)return null;const a="EPSG:4326";if(o)if(r)s=vo(r.inverse,o.forward);else{const l=uo(e,a);l&&(s=vo(l,o.forward))}else{const l=uo(a,i);l&&(s=vo(r.inverse,l))}return s&&(po(n),po(t),Wn(n,t,s)),s}function vo(n,t){return function(e,i,s,r){return i=n(e,i,s,r),t(i,i,s,r)}}function rr(n,t){const e=Nt(n),i=Nt(t);return Eo(e,i)}function Yn(n,t,e){const i=rr(t,e);if(!i){const s=Nt(t).getCode(),r=Nt(e).getCode();throw new Error(`No transform available between ${s} and ${r}`)}return i(n,void 0,n.length)}function wo(n,t){return n}function Oe(n,t){return _o&&!Js(n,[0,0])&&n[0]>=-180&&n[0]<=180&&n[1]>=-90&&n[1]<=90&&(_o=!1,Kl("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),n}function ah(n,t){return n}function ni(n,t){return n}function If(){oh(Zl),oh(Vl),Rf(Vl,Zl,tf,ef)}If(),new Array(6);function fe(){return[1,0,0,1,0,0]}function Sf(n,t){return n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=t[3],n[4]=t[4],n[5]=t[5],n}function ft(n,t){const e=t[0],i=t[1];return t[0]=n[0]*e+n[2]*i+n[4],t[1]=n[1]*e+n[3]*i+n[5],t}function De(n,t,e,i,s,r,o,a){const l=Math.sin(r),h=Math.cos(r);return n[0]=i*h,n[1]=s*l,n[2]=-i*l,n[3]=s*h,n[4]=o*i*h-a*i*l+t,n[5]=o*s*l+a*s*h+e,n}function lh(n,t){const e=bf(t);Q(e!==0,"Transformation matrix cannot be inverted");const i=t[0],s=t[1],r=t[2],o=t[3],a=t[4],l=t[5];return n[0]=o/e,n[1]=-s/e,n[2]=-r/e,n[3]=i/e,n[4]=(r*l-o*a)/e,n[5]=-(i*l-s*a)/e,n}function bf(n){return n[0]*n[3]-n[1]*n[2]}const Lf=[1e5,1e5,1e5,1e5,2,2];function Af(n){return"matrix("+n.join(", ")+")"}function Co(n){return n.substring(7,n.length-1).split(",").map(parseFloat)}function Mf(n,t){const e=Co(n),i=Co(t);for(let s=0;s<6;++s)if(Math.round((e[s]-i[s])*Lf[s])!==0)return!1;return!0}function si(n,t,e,i,s,r,o){r=r||[],o=o||2;let a=0;for(let l=t;l<e;l+=i){const h=n[l],c=n[l+1];r[a++]=s[0]*h+s[2]*c+s[4],r[a++]=s[1]*h+s[3]*c+s[5];for(let u=2;u<o;u++)r[a++]=n[l+u]}return r&&r.length!=a&&(r.length=a),r}function hh(n,t,e,i,s,r,o){o=o||[];const a=Math.cos(s),l=Math.sin(s),h=r[0],c=r[1];let u=0;for(let d=t;d<e;d+=i){const f=n[d]-h,g=n[d+1]-c;o[u++]=h+f*a-g*l,o[u++]=c+f*l+g*a;for(let m=d+2;m<d+i;++m)o[u++]=n[m]}return o&&o.length!=u&&(o.length=u),o}function Pf(n,t,e,i,s,r,o,a){a=a||[];const l=o[0],h=o[1];let c=0;for(let u=t;u<e;u+=i){const d=n[u]-l,f=n[u+1]-h;a[c++]=l+s*d,a[c++]=h+r*f;for(let g=u+2;g<u+i;++g)a[c++]=n[g]}return a&&a.length!=c&&(a.length=c),a}function Of(n,t,e,i,s,r,o){o=o||[];let a=0;for(let l=t;l<e;l+=i){o[a++]=n[l]+s,o[a++]=n[l+1]+r;for(let h=l+2;h<l+i;++h)o[a++]=n[h]}return o&&o.length!=a&&(o.length=a),o}const ch=fe(),Df=[NaN,NaN];class Ff extends de{constructor(){super(),this.extent_=Kt(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=bl((t,e,i)=>{if(!i)return this.getSimplifiedGeometry(e);const s=this.clone();return s.applyTransform(i),s.getSimplifiedGeometry(e)})}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return V()}closestPointXY(t,e,i,s){return V()}containsXY(t,e){return this.closestPointXY(t,e,Df,Number.MIN_VALUE)===0}getClosestPoint(t,e){return e=e||[NaN,NaN],this.closestPointXY(t[0],t[1],e,1/0),e}intersectsCoordinate(t){return this.containsXY(t[0],t[1])}computeExtent(t){return V()}getExtent(t){if(this.extentRevision_!=this.getRevision()){const e=this.computeExtent(this.extent_);(isNaN(e[0])||isNaN(e[1]))&&Ks(e),this.extentRevision_=this.getRevision()}return Kd(this.extent_,t)}rotate(t,e){V()}scale(t,e,i){V()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return V()}getType(){return V()}applyTransform(t){V()}intersectsExtent(t){return V()}translate(t,e){V()}transform(t,e){const i=Nt(t),s=i.getUnits()=="tile-pixels"?function(r,o,a){const l=i.getExtent(),h=i.getWorldExtent(),c=At(h)/At(l);De(ch,h[0],h[3],c,-c,0,0,0);const u=si(r,0,r.length,a,ch,o),d=rr(i,e);return d?d(u,u,a):u}:rr(i,e);return this.applyTransform(s),this}}class Ro extends Ff{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates}computeExtent(t){return no(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return V()}getFirstCoordinate(){return this.flatCoordinates.slice(0,this.stride)}getFlatCoordinates(){return this.flatCoordinates}getLastCoordinate(){return this.flatCoordinates.slice(this.flatCoordinates.length-this.stride)}getLayout(){return this.layout}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||this.simplifiedGeometryMaxMinSquaredTolerance!==0&&t<=this.simplifiedGeometryMaxMinSquaredTolerance)return this;const e=this.getSimplifiedGeometryInternal(t);return e.getFlatCoordinates().length<this.flatCoordinates.length?e:(this.simplifiedGeometryMaxMinSquaredTolerance=t,this)}getSimplifiedGeometryInternal(t){return this}getStride(){return this.stride}setFlatCoordinates(t,e){this.stride=uh(t),this.layout=t,this.flatCoordinates=e}setCoordinates(t,e){V()}setLayout(t,e,i){let s;if(t)s=uh(t);else{for(let r=0;r<i;++r){if(e.length===0){this.layout="XY",this.stride=2;return}e=e[0]}s=e.length,t=kf(s)}this.layout=t,this.stride=s}applyTransform(t){this.flatCoordinates&&(t(this.flatCoordinates,this.flatCoordinates,this.layout.startsWith("XYZ")?3:2,this.stride),this.changed())}rotate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();hh(i,0,i.length,s,t,e,i),this.changed()}}scale(t,e,i){e===void 0&&(e=t),i||(i=wi(this.getExtent()));const s=this.getFlatCoordinates();if(s){const r=this.getStride();Pf(s,0,s.length,r,t,e,i,s),this.changed()}}translate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();Of(i,0,i.length,s,t,e,i),this.changed()}}}function kf(n){let t;return n==2?t="XY":n==3?t="XYZ":n==4&&(t="XYZM"),t}function uh(n){let t;return n=="XY"?t=2:n=="XYZ"||n=="XYM"?t=3:n=="XYZM"&&(t=4),t}function Nf(n,t,e){const i=n.getFlatCoordinates();if(!i)return null;const s=n.getStride();return si(i,0,i.length,s,t,e)}function dh(n,t,e,i){let s=0;const r=n[e-i],o=n[e-i+1];let a=0,l=0;for(;t<e;t+=i){const h=n[t]-r,c=n[t+1]-o;s+=l*h-a*c,a=h,l=c}return s/2}function Gf(n,t,e,i){let s=0;for(let r=0,o=e.length;r<o;++r){const a=e[r];s+=dh(n,t,a,i),t=a}return s}function fh(n,t,e,i,s,r,o){const a=n[t],l=n[t+1],h=n[e]-a,c=n[e+1]-l;let u;if(h===0&&c===0)u=t;else{const d=((s-a)*h+(r-l)*c)/(h*h+c*c);if(d>1)u=e;else if(d>0){for(let f=0;f<i;++f)o[f]=te(n[t+f],n[e+f],d);o.length=i;return}else u=t}for(let d=0;d<i;++d)o[d]=n[u+d];o.length=i}function gh(n,t,e,i,s){let r=n[t],o=n[t+1];for(t+=i;t<e;t+=i){const a=n[t],l=n[t+1],h=Vi(r,o,a,l);h>s&&(s=h),r=a,o=l}return s}function zf(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];s=gh(n,t,a,i,s),t=a}return s}function _h(n,t,e,i,s,r,o,a,l,h,c){if(t==e)return h;let u,d;if(s===0){if(d=Vi(o,a,n[t],n[t+1]),d<h){for(u=0;u<i;++u)l[u]=n[t+u];return l.length=i,d}return h}c=c||[NaN,NaN];let f=t+i;for(;f<e;)if(fh(n,f-i,f,i,o,a,c),d=Vi(o,a,c[0],c[1]),d<h){for(h=d,u=0;u<i;++u)l[u]=c[u];l.length=i,f+=i}else f+=i*Math.max((Math.sqrt(d)-Math.sqrt(h))/s|0,1);if(fh(n,e-i,t,i,o,a,c),d=Vi(o,a,c[0],c[1]),d<h){for(h=d,u=0;u<i;++u)l[u]=c[u];l.length=i}return h}function Xf(n,t,e,i,s,r,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){const f=e[u];h=_h(n,t,f,i,s,r,o,a,l,h,c),t=f}return h}function Wf(n,t,e,i){for(let s=0,r=e.length;s<r;++s)n[t++]=e[s];return t}function mh(n,t,e,i){for(let s=0,r=e.length;s<r;++s){const o=e[s];for(let a=0;a<i;++a)n[t++]=o[a]}return t}function Yf(n,t,e,i,s){s=s||[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=mh(n,t,e[o],i);s[r++]=l,t=l}return s.length=r,s}function tn(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=t;o<e;o+=i)s[r++]=n.slice(o,o+i);return s.length=r,s}function or(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=tn(n,t,l,i,s[r]),t=l}return s.length=r,s}function ph(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=l.length===1&&l[0]===t?[]:or(n,t,l,i,s[r]),t=l[l.length-1]}return s.length=r,s}function To(n,t,e,i,s,r,o){const a=(e-t)/i;if(a<3){for(;t<e;t+=i)r[o++]=n[t],r[o++]=n[t+1];return o}const l=new Array(a);l[0]=1,l[a-1]=1;const h=[t,e-i];let c=0;for(;h.length>0;){const u=h.pop(),d=h.pop();let f=0;const g=n[d],m=n[d+1],_=n[u],p=n[u+1];for(let y=d+i;y<u;y+=i){const w=n[y],x=n[y+1],E=Zd(w,x,g,m,_,p);E>f&&(c=y,f=E)}f>s&&(l[(c-t)/i]=1,d+i<c&&h.push(d,c),c+i<u&&h.push(c,u))}for(let u=0;u<a;++u)l[u]&&(r[o++]=n[t+u*i],r[o++]=n[t+u*i+1]);return o}function $f(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l];o=To(n,t,c,i,s,r,o),a.push(o),t=c}return o}function Si(n,t){return t*Math.round(n/t)}function Kf(n,t,e,i,s,r,o){if(t==e)return o;let a=Si(n[t],s),l=Si(n[t+1],s);t+=i,r[o++]=a,r[o++]=l;let h,c;do if(h=Si(n[t],s),c=Si(n[t+1],s),t+=i,t==e)return r[o++]=h,r[o++]=c,o;while(h==a&&c==l);for(;t<e;){const u=Si(n[t],s),d=Si(n[t+1],s);if(t+=i,u==h&&d==c)continue;const f=h-a,g=c-l,m=u-a,_=d-l;if(f*_==g*m&&(f<0&&m<f||f==m||f>0&&m>f)&&(g<0&&_<g||g==_||g>0&&_>g)){h=u,c=d;continue}r[o++]=h,r[o++]=c,a=h,l=c,h=u,c=d}return r[o++]=h,r[o++]=c,o}function yh(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l];o=Kf(n,t,c,i,s,r,o),a.push(o),t=c}return o}class $n extends Ro{constructor(t,e){super(),this.maxDelta_=-1,this.maxDeltaRevision_=-1,e!==void 0&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}clone(){return new $n(this.flatCoordinates.slice(),this.layout)}closestPointXY(t,e,i,s){return s<Ol(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(gh(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),_h(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,s))}getArea(){return dh(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return tn(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){const e=[];return e.length=To(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new $n(e,"XY")}getType(){return"LinearRing"}intersectsExtent(t){return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=mh(this.flatCoordinates,0,t,this.stride),this.changed()}}class ar extends Ro{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){const t=new ar(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){const r=this.flatCoordinates,o=Vi(t,e,r[0],r[1]);if(o<s){const a=this.stride;for(let l=0;l<a;++l)i[l]=r[l];return i.length=a,o}return s}getCoordinates(){return this.flatCoordinates.slice()}computeExtent(t){return Fl(this.flatCoordinates,t)}getType(){return"Point"}intersectsExtent(t){return Dl(t,this.flatCoordinates[0],this.flatCoordinates[1])}setCoordinates(t,e){this.setLayout(e,t,0),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=Wf(this.flatCoordinates,0,t,this.stride),this.changed()}}function Bf(n,t,e,i,s){return!Gl(s,function(o){return!bi(n,t,e,i,o[0],o[1])})}function bi(n,t,e,i,s,r){let o=0,a=n[e-i],l=n[e-i+1];for(;t<e;t+=i){const h=n[t],c=n[t+1];l<=r?c>r&&(h-a)*(r-l)-(s-a)*(c-l)>0&&o++:c<=r&&(h-a)*(r-l)-(s-a)*(c-l)<0&&o--,a=h,l=c}return o!==0}function xh(n,t,e,i,s,r){if(e.length===0||!bi(n,t,e[0],i,s,r))return!1;for(let o=1,a=e.length;o<a;++o)if(bi(n,e[o-1],e[o],i,s,r))return!1;return!0}function Io(n,t,e,i,s,r,o){let a,l,h,c,u,d,f;const g=s[r+1],m=[];for(let y=0,w=e.length;y<w;++y){const x=e[y];for(c=n[x-i],d=n[x-i+1],a=t;a<x;a+=i)u=n[a],f=n[a+1],(g<=d&&f<=g||d<=g&&g<=f)&&(h=(g-d)/(f-d)*(u-c)+c,m.push(h)),c=u,d=f}let _=NaN,p=-1/0;for(m.sort(Me),c=m[0],a=1,l=m.length;a<l;++a){u=m[a];const y=Math.abs(u-c);y>p&&(h=(c+u)/2,xh(n,t,e,i,h,g)&&(_=h,p=y)),c=u}return isNaN(_)&&(_=s[r]),o?(o.push(_,g,p),o):[_,g,p]}function Zf(n,t,e,i,s){let r=[];for(let o=0,a=e.length;o<a;++o){const l=e[o];r=Io(n,t,l,i,s,2*o,r),t=l[l.length-1]}return r}function Uf(n,t,e,i,s){let r;for(t+=i;t<e;t+=i)if(r=s(n.slice(t-i,t),n.slice(t,t+i)),r)return r;return!1}function Eh(n,t,e,i,s,r){return r=r??Nl(Kt(),n,t,e,i),kt(s,r)?r[0]>=s[0]&&r[2]<=s[2]||r[1]>=s[1]&&r[3]<=s[3]?!0:Uf(n,t,e,i,function(o,a){return Bd(s,o,a)}):!1}function vh(n,t,e,i,s){return!!(Eh(n,t,e,i,s)||bi(n,t,e,i,s[0],s[1])||bi(n,t,e,i,s[0],s[3])||bi(n,t,e,i,s[2],s[1])||bi(n,t,e,i,s[2],s[3]))}function Vf(n,t,e,i,s){if(!vh(n,t,e[0],i,s))return!1;if(e.length===1)return!0;for(let r=1,o=e.length;r<o;++r)if(Bf(n,e[r-1],e[r],i,s)&&!Eh(n,e[r-1],e[r],i,s))return!1;return!0}function jf(n,t,e,i){for(;t<e-i;){for(let s=0;s<i;++s){const r=n[t+s];n[t+s]=n[e-i+s],n[e-i+s]=r}t+=i,e-=i}}function So(n,t,e,i){let s=0,r=n[e-i],o=n[e-i+1];for(;t<e;t+=i){const a=n[t],l=n[t+1];s+=(a-r)*(l+o),r=a,o=l}return s===0?void 0:s>0}function Hf(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=So(n,t,a,i);if(r===0){if(s&&l||!s&&!l)return!1}else if(s&&!l||!s&&l)return!1;t=a}return!0}function wh(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=So(n,t,a,i);(r===0?s&&l||!s&&!l:s&&!l||!s&&l)&&jf(n,t,a,i),t=a}return t}function qf(n,t){const e=[];let i=0,s=0,r;for(let o=0,a=t.length;o<a;++o){const l=t[o],h=So(n,i,l,2);if(r===void 0&&(r=h),h===r)e.push(t.slice(s,o+1));else{if(e.length===0)continue;e[e.length-1].push(t[s])}s=o+1,i=l}return e}class Kn extends Ro{constructor(t,e,i){super(),this.ends_=[],this.flatInteriorPointRevision_=-1,this.flatInteriorPoint_=null,this.maxDelta_=-1,this.maxDeltaRevision_=-1,this.orientedRevision_=-1,this.orientedFlatCoordinates_=null,e!==void 0&&i?(this.setFlatCoordinates(e,t),this.ends_=i):this.setCoordinates(t,e)}appendLinearRing(t){this.flatCoordinates?Qr(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){const t=new Kn(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<Ol(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(zf(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),Xf(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,s))}containsXY(t,e){return xh(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return Gf(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),wh(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,or(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){const t=wi(this.getExtent());this.flatInteriorPoint_=Io(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new ar(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new $n(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){const t=this.layout,e=this.flatCoordinates,i=this.ends_,s=[];let r=0;for(let o=0,a=i.length;o<a;++o){const l=i[o],h=new $n(e.slice(r,l),t);s.push(h),r=l}return s}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){const t=this.flatCoordinates;Hf(t,0,this.ends_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=wh(this.orientedFlatCoordinates_,0,this.ends_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){const e=[],i=[];return e.length=yh(this.flatCoordinates,0,this.ends_,this.stride,Math.sqrt(t),e,0,i),new Kn(e,"XY",i)}getType(){return"Polygon"}intersectsExtent(t){return Vf(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);const i=Yf(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}}function Ch(n){if(Vs(n))throw new Error("Cannot create polygon from empty extent");const t=n[0],e=n[1],i=n[2],s=n[3],r=[t,e,t,s,i,s,i,e,t,e];return new Kn(r,"XY",[r.length])}function Rh(n,t,e,i,s,r,o){let a,l;const h=(e-t)/i;if(h===1)a=t;else if(h===2)a=t,l=s;else if(h!==0){let c=n[t],u=n[t+1],d=0;const f=[0];for(let _=t+i;_<e;_+=i){const p=n[_],y=n[_+1];d+=Math.sqrt((p-c)*(p-c)+(y-u)*(y-u)),f.push(d),c=p,u=y}const g=s*d,m=Dd(f,g);m<0?(l=(g-f[-m-2])/(f[-m-1]-f[-m-2]),a=t+(-m-2)*i):a=t+m*i}o=o>1?o:2,r=r||new Array(o);for(let c=0;c<o;++c)r[c]=a===void 0?NaN:l===void 0?n[a+c]:te(n[a+c],n[a+i+c],l);return r}function Jf(n,t,e,i){let s=n[t],r=n[t+1],o=0;for(let a=t+i;a<e;a+=i){const l=n[a],h=n[a+1];o+=Math.sqrt((l-s)*(l-s)+(h-r)*(h-r)),s=l,r=h}return o}const ie={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"},Li=typeof navigator<"u"&&typeof navigator.userAgent<"u"?navigator.userAgent.toLowerCase():"";Li.includes("safari")&&!Li.includes("chrom")&&(Li.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(Li));const Qf=Li.includes("webkit")&&!Li.includes("edge"),Th=Li.includes("macintosh"),tg=typeof devicePixelRatio<"u"?devicePixelRatio:1,Bt=typeof WorkerGlobalScope<"u"&&typeof OffscreenCanvas<"u"&&self instanceof WorkerGlobalScope,Ih=typeof Image<"u"&&Image.prototype.decode,Sh=(function(){let n=!1;try{const t=Object.defineProperty({},"passive",{get:function(){n=!0}});window.addEventListener("_",null,t),window.removeEventListener("_",null,t)}catch{}return n})(),Y={IDLE:0,LOADING:1,LOADED:2,ERROR:3};function ct(n,t,e,i){let s;return e&&e.length?s=e.shift():Bt?s=new class extends OffscreenCanvas{style={}}(n??300,t??150):s=document.createElement("canvas"),n&&(s.width=n),t&&(s.height=t),s.getContext("2d",i)}let bo;function lr(){return bo||(bo=ct(1,1)),bo}function hr(n){const t=n.canvas;t.width=1,t.height=1,n.clearRect(0,0,1,1)}function eg(n){let t=n.offsetWidth;const e=getComputedStyle(n);return t+=parseInt(e.marginLeft,10)+parseInt(e.marginRight,10),t}function ig(n){let t=n.offsetHeight;const e=getComputedStyle(n);return t+=parseInt(e.marginTop,10)+parseInt(e.marginBottom,10),t}function bh(n,t){const e=t.parentNode;e&&e.replaceChild(n,t)}function Lh(n){for(;n.lastChild;)n.lastChild.remove()}function ng(n,t){const e=n.childNodes;for(let i=0;;++i){const s=e[i],r=t[i];if(!s&&!r)break;if(s!==r){if(!s){n.appendChild(r);continue}if(!r){n.removeChild(s),--i;continue}n.insertBefore(r,s)}}}function Ah(){return new Proxy({childNodes:[],appendChild:function(t){return this.childNodes.push(t),t},remove:function(){},removeChild:function(t){const e=this.childNodes.indexOf(t);if(e===-1)throw new Error("Node to remove was not found");return this.childNodes.splice(e,1),t},insertBefore:function(t,e){const i=this.childNodes.indexOf(e);if(i===-1)throw new Error("Reference node not found");return this.childNodes.splice(i,0,t),t},style:{}},{get(t,e,i){return e==="firstElementChild"?t.childNodes.length>0?t.childNodes[0]:null:Reflect.get(t,e,i)}})}function ri(n){return typeof HTMLCanvasElement<"u"&&n instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&n instanceof OffscreenCanvas}const Lo=[NaN,NaN,NaN,0];let Ao;function sg(){return Ao||(Ao=ct(1,1,void 0,{willReadFrequently:!0,desynchronized:!0})),Ao}const rg=/^rgba?\(\s*(\d+%?)\s+(\d+%?)\s+(\d+%?)(?:\s*\/\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,og=/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,ag=/^rgba?\(\s*(\d+%)\s*,\s*(\d+%)\s*,\s*(\d+%)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,lg=/^#([\da-f]{3,4}|[\da-f]{6}|[\da-f]{8})$/i;function cr(n,t){return n.endsWith("%")?Number(n.substring(0,n.length-1))/t:Number(n)}function Bn(n){throw new Error('failed to parse "'+n+'" as color')}function Mh(n){if(n.toLowerCase().startsWith("rgb")){const r=n.match(og)||n.match(rg)||n.match(ag);if(r){const o=r[4],a=100/255;return[ot(cr(r[1],a)+.5|0,0,255),ot(cr(r[2],a)+.5|0,0,255),ot(cr(r[3],a)+.5|0,0,255),o!==void 0?ot(cr(o,100),0,1):1]}Bn(n)}if(n.startsWith("#")){if(lg.test(n)){const r=n.substring(1),o=r.length<=4?1:2,a=[0,0,0,255];for(let l=0,h=r.length;l<h;l+=o){let c=parseInt(r.substring(l,l+o),16);o===1&&(c+=c<<4),a[l/o]=c}return a[3]=a[3]/255,a}Bn(n)}const t=sg();t.fillStyle="#abcdef";let e=t.fillStyle;t.fillStyle=n,t.fillStyle===e&&(t.fillStyle="#fedcba",e=t.fillStyle,t.fillStyle=n,t.fillStyle===e&&Bn(n));const i=t.fillStyle;if(i.startsWith("#")||i.startsWith("rgba"))return Mh(i);t.clearRect(0,0,1,1),t.fillRect(0,0,1,1);const s=Array.from(t.getImageData(0,0,1,1).data);return s[3]=js(s[3]/255,3),s}function hg(n){return typeof n=="string"?n:No(n)}const cg=1024,Zn={};let Mo=0;function ug(n){if(n.length===4)return n;const t=n.slice();return t[3]=1,t}function Po(n){return n>.0031308?Math.pow(n,1/2.4)*269.025-14.025:n*3294.6}function Oo(n){return n>.2068965?Math.pow(n,3):(n-4/29)*(108/841)}function Do(n){return n>10.314724?Math.pow((n+14.025)/269.025,2.4):n/3294.6}function Fo(n){return n>.0088564?Math.pow(n,1/3):n/(108/841)+4/29}function Ph(n){const t=Do(n[0]),e=Do(n[1]),i=Do(n[2]),s=Fo(t*.222488403+e*.716873169+i*.06060791),r=500*(Fo(t*.452247074+e*.399439023+i*.148375274)-s),o=200*(s-Fo(t*.016863605+e*.117638439+i*.865350722)),a=Math.atan2(o,r)*(180/Math.PI);return[116*s-16,Math.sqrt(r*r+o*o),a<0?a+360:a,n[3]]}function dg(n){const t=(n[0]+16)/116,e=n[1],i=n[2]*Math.PI/180,s=Oo(t),r=Oo(t+e/500*Math.cos(i)),o=Oo(t-e/200*Math.sin(i)),a=Po(r*3.021973625-s*1.617392459-o*.404875592),l=Po(r*-.943766287+s*1.916279586+o*.027607165),h=Po(r*.069407491-s*.22898585+o*1.159737864);return[ot(a+.5|0,0,255),ot(l+.5|0,0,255),ot(h+.5|0,0,255),n[3]]}function ko(n){if(n==="none")return Lo;if(Zn.hasOwnProperty(n))return Zn[n];if(Mo>=cg){let e=0;for(const i in Zn)(e++&3)===0&&(delete Zn[i],--Mo)}const t=Mh(n);t.length!==4&&Bn(n);for(const e of t)isNaN(e)&&Bn(n);return Zn[n]=t,++Mo,t}function en(n){return Array.isArray(n)?n:ko(n)}function No(n){let t=n[0];t!=(t|0)&&(t=t+.5|0);let e=n[1];e!=(e|0)&&(e=e+.5|0);let i=n[2];i!=(i|0)&&(i=i+.5|0);const s=n[3]===void 0?1:Math.round(n[3]*1e3)/1e3;return"rgba("+t+","+e+","+i+","+s+")"}function fg(n,t,e){const i=n;let s=!0,r=!1,o=!1;const a=[Ys(i,W.LOAD,function(){o=!0,r||t()})];return i.src&&Ih?(r=!0,i.decode().then(function(){s&&t()}).catch(function(l){s&&(o?t():e())})):a.push(Ys(i,W.ERROR,e)),function(){s=!1,a.forEach(nt)}}function gg(n,t){return new Promise((e,i)=>{function s(){o(),e(n)}function r(){o(),i(new Error("Image load error"))}function o(){n.removeEventListener("load",s),n.removeEventListener("error",r)}n.addEventListener("load",s),n.addEventListener("error",r)})}function _g(n,t){return t&&(n.src=t),n.src&&Ih?new Promise((e,i)=>n.decode().then(()=>e(n)).catch(s=>n.complete&&n.width?e(n):i(s))):gg(n)}class mg{constructor(){this.cache_={},this.patternCache_={},this.cacheSize_=0,this.maxCacheSize_=1024}clear(){this.cache_={},this.patternCache_={},this.cacheSize_=0}canExpireCache(){return this.cacheSize_>this.maxCacheSize_}expire(){if(this.canExpireCache()){let t=0;for(const e in this.cache_){const i=this.cache_[e];(t++&3)===0&&!i.hasListener()&&(delete this.cache_[e],delete this.patternCache_[e],--this.cacheSize_)}}}get(t,e,i){const s=Go(t,e,i);return s in this.cache_?this.cache_[s]:null}getPattern(t,e,i){const s=Go(t,e,i);return s in this.patternCache_?this.patternCache_[s]:null}set(t,e,i,s,r){const o=Go(t,e,i),a=o in this.cache_;this.cache_[o]=s,r&&(s.getImageState()===Y.IDLE&&s.load(),s.getImageState()===Y.LOADING?s.ready().then(()=>{this.patternCache_[o]=lr().createPattern(s.getImage(1),"repeat")}):this.patternCache_[o]=lr().createPattern(s.getImage(1),"repeat")),a||++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}}function Go(n,t,e){const i=e?en(e):"null";return t+":"+n+":"+i}const ne=new mg;let Un=null;class Oh extends Ws{constructor(t,e,i,s,r){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=i,this.canvas_={},this.color_=r,this.imageState_=s===void 0?Y.IDLE:s,this.size_=t&&t.width&&t.height?[t.width,t.height]:null,this.src_=e,this.tainted_,this.ready_=null}initializeImage_(){this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_)}isTainted_(){if(this.tainted_===void 0&&this.imageState_===Y.LOADED){Un||(Un=ct(1,1,void 0,{willReadFrequently:!0})),Un.drawImage(this.image_,0,0);try{Un.getImageData(0,0,1,1),this.tainted_=!1}catch{Un=null,this.tainted_=!0}}return this.tainted_===!0}dispatchChangeEvent_(){this.dispatchEvent(W.CHANGE)}handleImageError_(){this.imageState_=Y.ERROR,this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=Y.LOADED,this.size_=[this.image_.width,this.image_.height],this.dispatchChangeEvent_()}getImage(t){return this.image_||this.initializeImage_(),this.replaceColor_(t),this.canvas_[t]?this.canvas_[t]:this.image_}getPixelRatio(t){return this.replaceColor_(t),this.canvas_[t]?t:1}getImageState(){return this.imageState_}getHitDetectionImage(){if(this.image_||this.initializeImage_(),!this.hitDetectionImage_)if(this.isTainted_()){const t=this.size_[0],e=this.size_[1],i=ct(t,e);i.fillRect(0,0,t,e),this.hitDetectionImage_=i.canvas}else this.hitDetectionImage_=this.image_;return this.hitDetectionImage_}getSize(){return this.size_}getSrc(){return this.src_}load(){if(this.imageState_===Y.IDLE){this.image_||this.initializeImage_(),this.imageState_=Y.LOADING;try{this.src_!==void 0&&(this.image_.src=this.src_)}catch{this.handleImageError_()}this.image_ instanceof HTMLImageElement&&_g(this.image_,this.src_).then(t=>{this.image_=t,this.handleImageLoad_()}).catch(this.handleImageError_.bind(this))}}replaceColor_(t){if(!this.color_||this.canvas_[t]||this.imageState_!==Y.LOADED)return;const e=this.image_,i=ct(Math.ceil(e.width*t),Math.ceil(e.height*t)),s=i.canvas;i.scale(t,t),i.drawImage(e,0,0),i.globalCompositeOperation="multiply",i.fillStyle=hg(this.color_),i.fillRect(0,0,s.width/t,s.height/t),i.globalCompositeOperation="destination-in",i.drawImage(e,0,0),this.canvas_[t]=s}ready(){return this.ready_||(this.ready_=new Promise(t=>{if(this.imageState_===Y.LOADED||this.imageState_===Y.ERROR)t();else{const e=()=>{(this.imageState_===Y.LOADED||this.imageState_===Y.ERROR)&&(this.removeEventListener(W.CHANGE,e),t())};this.addEventListener(W.CHANGE,e)}})),this.ready_}}function ur(n,t,e,i,s,r){let o=t===void 0?void 0:ne.get(t,e,s);return o||(o=new Oh(n,n&&"src"in n?n.src||void 0:t,e,i,s),ne.set(t,e,s,o,r)),r&&o&&!ne.getPattern(t,e,s)&&ne.set(t,e,s,o,r),o}function xe(n){return n?Array.isArray(n)?No(n):typeof n=="object"&&"src"in n?pg(n):n:null}function pg(n){if(!n.offset||!n.size)return ne.getPattern(n.src,"anonymous",n.color);const t=n.src+":"+n.offset,e=ne.getPattern(t,void 0,n.color);if(e)return e;const i=ne.get(n.src,"anonymous",null);if(i.getImageState()!==Y.LOADED)return null;const s=ct(n.size[0],n.size[1]);return s.drawImage(i.getImage(1),n.offset[0],n.offset[1],n.size[0],n.size[1],0,0,n.size[0],n.size[1]),ur(s.canvas,t,void 0,Y.LOADED,n.color,!0),ne.getPattern(t,void 0,n.color)}class Dh{drawCustom(t,e,i,s,r){}drawGeometry(t){}setStyle(t){}drawCircle(t,e,i){}drawFeature(t,e,i){}drawGeometryCollection(t,e,i){}drawLineString(t,e,i){}drawMultiLineString(t,e,i){}drawMultiPoint(t,e,i){}drawMultiPolygon(t,e,i){}drawPoint(t,e,i){}drawPolygon(t,e,i){}drawText(t,e,i){}setFillStrokeStyle(t,e){}setImageStyle(t,e){}setTextStyle(t,e){}}const dr="ol-hidden",yg="ol-selectable",fr="ol-unselectable",zo="ol-control",Fh="ol-collapsed",xg=new RegExp(["^\\s*(?=(?:(?:[-a-z]+\\s*){0,2}(italic|oblique))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(small-caps))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(bold(?:er)?|lighter|[1-9]00 ))?)","(?:(?:normal|\\1|\\2|\\3)\\s*){0,3}((?:xx?-)?","(?:small|large)|medium|smaller|larger|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx]))","(?:\\s*\\/\\s*(normal|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx])?))",`?\\s*([-,\\"\\'\\sa-z0-9]+?)\\s*$`].join(""),"i"),kh=["style","variant","weight","size","lineHeight","family"],Xo={normal:400,bold:700},Wo=function(n){const t=n.match(xg);if(!t)return null;const e={lineHeight:"normal",size:"1.2em",style:"normal",weight:"400",variant:"normal"};for(let i=0,s=kh.length;i<s;++i){const r=t[i+1];r!==void 0&&(e[kh[i]]=typeof r=="string"?r.trim():r)}return isNaN(Number(e.weight))&&e.weight in Xo&&(e.weight=Xo[e.weight]),e.families=e.family.split(/,\s?/).map(i=>i.trim().replace(/^['"]|['"]$/g,"")),e},Nh="10px sans-serif",Gt="#000",nn="round",Fe=[],ke=0,sn="round",Vn=10,jn="#000",Hn="center",gr="middle",Ai=[0,0,0,0],qn=1,rn=new de;let Jn=null,Gh;const Yo={},Eg=new Set(["serif","sans-serif","monospace","cursive","fantasy","system-ui","ui-serif","ui-sans-serif","ui-monospace","ui-rounded","emoji","math","fangsong"]);function vg(n,t,e){return`${n} ${t} 16px "${e}"`}const wg=(function(){let t,e;async function i(r){await e.ready;const o=await e.load(r);if(o.length===0)return!1;const a=Wo(r),l=a.families[0].toLowerCase(),h=a.weight;return o.some(c=>{const u=c.family.replace(/^['"]|['"]$/g,"").toLowerCase(),d=Xo[c.weight]||c.weight;return u===l&&c.style===a.style&&d==h})}async function s(){await e.ready;let r=!0;const o=rn.getProperties(),a=Object.keys(o).filter(l=>o[l]<100);for(let l=a.length-1;l>=0;--l){const h=a[l];let c=o[h];c<100&&(await i(h)?(kn(Yo),rn.set(h,100)):(c+=10,rn.set(h,c,!0),c<100&&(r=!1)))}t=void 0,r||(t=setTimeout(s,100))}return async function(r){e||(e=Bt?self.fonts:document.fonts);const o=Wo(r);if(!o)return;const a=o.families;let l=!1;for(const h of a){if(Eg.has(h))continue;const c=vg(o.style,o.weight,h);rn.get(c)===void 0&&(rn.set(c,0,!0),l=!0)}l&&(clearTimeout(t),t=setTimeout(s,100))}})(),Cg=(function(){let n;return function(t){let e=Yo[t];if(e==null){if(Bt){const i=Wo(t),s=zh(t,"Žg");e=(isNaN(Number(i.lineHeight))?1.2:Number(i.lineHeight))*(s.actualBoundingBoxAscent+s.actualBoundingBoxDescent)}else n||(n=document.createElement("div"),n.innerHTML="M",n.style.minHeight="0",n.style.maxHeight="none",n.style.height="auto",n.style.padding="0",n.style.border="none",n.style.position="absolute",n.style.display="block",n.style.left="-99999px"),n.style.font=t,document.body.appendChild(n),e=n.offsetHeight,document.body.removeChild(n);Yo[t]=e}return e}})();function zh(n,t){return Jn||(Jn=ct(1,1)),n!=Gh&&(Jn.font=n,Gh=Jn.font),Jn.measureText(t)}function Xh(n,t){return zh(n,t).width}function Wh(n,t,e){if(t in e)return e[t];const i=t.split(`
|
|
3
|
-
`).reduce((s,r)=>Math.max(s,
|
|
4
|
-
`||h===c){r=Math.max(r,o),s.push(o),o=0,a+=l,l=0;continue}const d=t[h+1]||n.font,f=Xh(d,u);e.push(f),o+=f;const g=Cg(d);i.push(g),l=Math.max(l,g)}return{width:r,height:a,widths:e,heights:i,lineWidths:s}}function Tg(n,t,e,i,s,r,o,a,l,h,c){n.save(),e!==1&&(n.globalAlpha===void 0?n.globalAlpha=u=>u.globalAlpha*=e:n.globalAlpha*=e),t&&n.transform.apply(n,t),i.contextInstructions?(n.translate(l,h),n.scale(c[0],c[1]),Ig(i,n)):c[0]<0||c[1]<0?(n.translate(l,h),n.scale(c[0],c[1]),n.drawImage(i,s,r,o,a,0,0,o,a)):n.drawImage(i,s,r,o,a,l,h,o*c[0],a*c[1]),n.restore()}function Ig(n,t){const e=n.contextInstructions;for(let i=0,s=e.length;i<s;i+=2)Array.isArray(e[i+1])?t[e[i]].apply(t,e[i+1]):t[e[i]]=e[i+1]}class Sg extends Dh{constructor(t,e,i,s,r,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=s,this.transformRotation_=s?js(Math.atan2(s[1],s[0]),10):0,this.viewRotation_=r,this.squaredTolerance_=o,this.userTransform_=a,this.contextFillState_=null,this.contextStrokeState_=null,this.contextTextState_=null,this.fillState_=null,this.strokeState_=null,this.image_=null,this.imageAnchorX_=0,this.imageAnchorY_=0,this.imageHeight_=0,this.imageOpacity_=0,this.imageOriginX_=0,this.imageOriginY_=0,this.imageRotateWithView_=!1,this.imageRotation_=0,this.imageScale_=[0,0],this.imageWidth_=0,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=!1,this.textRotation_=0,this.textScale_=[0,0],this.textFillState_=null,this.textStrokeState_=null,this.textState_=null,this.pixelCoordinates_=[],this.tmpLocalTransform_=fe()}drawImages_(t,e,i,s){if(!this.image_)return;const r=si(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.tmpLocalTransform_,l=o.globalAlpha;this.imageOpacity_!=1&&(o.globalAlpha=l*this.imageOpacity_);let h=this.imageRotation_;this.transformRotation_===0&&(h-=this.viewRotation_),this.imageRotateWithView_&&(h+=this.viewRotation_);for(let c=0,u=r.length;c<u;c+=2){const d=r[c]-this.imageAnchorX_,f=r[c+1]-this.imageAnchorY_;if(h!==0||this.imageScale_[0]!=1||this.imageScale_[1]!=1){const g=d+this.imageAnchorX_,m=f+this.imageAnchorY_;De(a,g,m,1,1,h,-g,-m),o.save(),o.transform.apply(o,a),o.translate(g,m),o.scale(this.imageScale_[0],this.imageScale_[1]),o.drawImage(this.image_,this.imageOriginX_,this.imageOriginY_,this.imageWidth_,this.imageHeight_,-this.imageAnchorX_,-this.imageAnchorY_,this.imageWidth_,this.imageHeight_),o.restore()}else o.drawImage(this.image_,this.imageOriginX_,this.imageOriginY_,this.imageWidth_,this.imageHeight_,d,f,this.imageWidth_,this.imageHeight_)}this.imageOpacity_!=1&&(o.globalAlpha=l)}drawText_(t,e,i,s){if(!this.textState_||this.text_==="")return;this.textFillState_&&this.setContextFillState_(this.textFillState_),this.textStrokeState_&&this.setContextStrokeState_(this.textStrokeState_),this.setContextTextState_(this.textState_);const r=si(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_;let a=this.textRotation_;for(this.transformRotation_===0&&(a-=this.viewRotation_),this.textRotateWithView_&&(a+=this.viewRotation_);e<i;e+=s){const l=r[e]+this.textOffsetX_,h=r[e+1]+this.textOffsetY_;a!==0||this.textScale_[0]!=1||this.textScale_[1]!=1?(o.save(),o.translate(l-this.textOffsetX_,h-this.textOffsetY_),o.rotate(a),o.translate(this.textOffsetX_,this.textOffsetY_),o.scale(this.textScale_[0],this.textScale_[1]),this.textStrokeState_&&o.strokeText(this.text_,0,0),this.textFillState_&&o.fillText(this.text_,0,0),o.restore()):(this.textStrokeState_&&o.strokeText(this.text_,l,h),this.textFillState_&&o.fillText(this.text_,l,h))}}moveToLineTo_(t,e,i,s,r){const o=this.context_,a=si(t,e,i,s,this.transform_,this.pixelCoordinates_);o.moveTo(a[0],a[1]);let l=a.length;r&&(l-=2);for(let h=2;h<l;h+=2)o.lineTo(a[h],a[h+1]);return r&&o.closePath(),i}drawRings_(t,e,i,s){for(let r=0,o=i.length;r<o;++r)e=this.moveToLineTo_(t,e,i[r],s,!0);return e}drawCircle(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!kt(this.extent_,t.getExtent())){if(this.fillState_||this.strokeState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=Nf(t,this.transform_,this.pixelCoordinates_),i=e[2]-e[0],s=e[3]-e[1],r=Math.sqrt(i*i+s*s),o=this.context_;o.beginPath(),o.arc(e[0],e[1],r,0,2*Math.PI),this.fillState_&&o.fill(),this.strokeState_&&o.stroke()}this.text_!==""&&this.drawText_(t.getCenter(),0,2,2)}}setStyle(t){this.setFillStrokeStyle(t.getFill(),t.getStroke()),this.setImageStyle(t.getImage()),this.setTextStyle(t.getText())}setTransform(t){this.transform_=t}drawGeometry(t){switch(t.getType()){case"Point":this.drawPoint(t);break;case"LineString":this.drawLineString(t);break;case"Polygon":this.drawPolygon(t);break;case"MultiPoint":this.drawMultiPoint(t);break;case"MultiLineString":this.drawMultiLineString(t);break;case"MultiPolygon":this.drawMultiPolygon(t);break;case"GeometryCollection":this.drawGeometryCollection(t);break;case"Circle":this.drawCircle(t);break}}drawFeature(t,e){const i=e.getGeometryFunction()(t);i&&(this.setStyle(e),this.drawGeometry(i))}drawGeometryCollection(t){const e=t.getGeometriesArray();for(let i=0,s=e.length;i<s;++i)this.drawGeometry(e[i])}drawPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawMultiPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawLineString(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!kt(this.extent_,t.getExtent())){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getFlatCoordinates();e.beginPath(),this.moveToLineTo_(i,0,i.length,t.getStride(),!1),e.stroke()}if(this.text_!==""){const e=t.getFlatMidpoint();this.drawText_(e,0,2,2)}}}drawMultiLineString(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getExtent();if(kt(this.extent_,e)){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const i=this.context_,s=t.getFlatCoordinates();let r=0;const o=t.getEnds(),a=t.getStride();i.beginPath();for(let l=0,h=o.length;l<h;++l)r=this.moveToLineTo_(s,r,o[l],a,!1);i.stroke()}if(this.text_!==""){const i=t.getFlatMidpoints();this.drawText_(i,0,i.length,2)}}}drawPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!kt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_;e.beginPath(),this.drawRings_(t.getOrientedFlatCoordinates(),0,t.getEnds(),t.getStride()),this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoint();this.drawText_(e,0,2,2)}}}drawMultiPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!kt(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getOrientedFlatCoordinates();let s=0;const r=t.getEndss(),o=t.getStride();e.beginPath();for(let a=0,l=r.length;a<l;++a){const h=r[a];s=this.drawRings_(i,s,h,o)}this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoints();this.drawText_(e,0,e.length,2)}}}setContextFillState_(t){const e=this.context_,i=this.contextFillState_;i?i.fillStyle!=t.fillStyle&&(i.fillStyle=t.fillStyle,e.fillStyle=t.fillStyle):(e.fillStyle=t.fillStyle,this.contextFillState_={fillStyle:t.fillStyle})}setContextStrokeState_(t){const e=this.context_,i=this.contextStrokeState_;i?(i.lineCap!=t.lineCap&&(i.lineCap=t.lineCap,e.lineCap=t.lineCap),ti(i.lineDash,t.lineDash)||e.setLineDash(i.lineDash=t.lineDash),i.lineDashOffset!=t.lineDashOffset&&(i.lineDashOffset=t.lineDashOffset,e.lineDashOffset=t.lineDashOffset),i.lineJoin!=t.lineJoin&&(i.lineJoin=t.lineJoin,e.lineJoin=t.lineJoin),i.lineWidth!=t.lineWidth&&(i.lineWidth=t.lineWidth,e.lineWidth=t.lineWidth),i.miterLimit!=t.miterLimit&&(i.miterLimit=t.miterLimit,e.miterLimit=t.miterLimit),i.strokeStyle!=t.strokeStyle&&(i.strokeStyle=t.strokeStyle,e.strokeStyle=t.strokeStyle)):(e.lineCap=t.lineCap,e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset,e.lineJoin=t.lineJoin,e.lineWidth=t.lineWidth,e.miterLimit=t.miterLimit,e.strokeStyle=t.strokeStyle,this.contextStrokeState_={lineCap:t.lineCap,lineDash:t.lineDash,lineDashOffset:t.lineDashOffset,lineJoin:t.lineJoin,lineWidth:t.lineWidth,miterLimit:t.miterLimit,strokeStyle:t.strokeStyle})}setContextTextState_(t){const e=this.context_,i=this.contextTextState_,s=t.textAlign?t.textAlign:Hn;i?(i.font!=t.font&&(i.font=t.font,e.font=t.font),i.textAlign!=s&&(i.textAlign=s,e.textAlign=s),i.textBaseline!=t.textBaseline&&(i.textBaseline=t.textBaseline,e.textBaseline=t.textBaseline)):(e.font=t.font,e.textAlign=s,e.textBaseline=t.textBaseline,this.contextTextState_={font:t.font,textAlign:s,textBaseline:t.textBaseline})}setFillStrokeStyle(t,e){if(!t)this.fillState_=null;else{const i=t.getColor();this.fillState_={fillStyle:xe(i||Gt)}}if(!e)this.strokeState_=null;else{const i=e.getColor(),s=e.getLineCap(),r=e.getLineDash(),o=e.getLineDashOffset(),a=e.getLineJoin(),l=e.getWidth(),h=e.getMiterLimit(),c=r||Fe;this.strokeState_={lineCap:s!==void 0?s:nn,lineDash:this.pixelRatio_===1?c:c.map(u=>u*this.pixelRatio_),lineDashOffset:(o||ke)*this.pixelRatio_,lineJoin:a!==void 0?a:sn,lineWidth:(l!==void 0?l:qn)*this.pixelRatio_,miterLimit:h!==void 0?h:Vn,strokeStyle:xe(i||jn)}}}setImageStyle(t){let e;if(!t||!(e=t.getSize())){this.image_=null;return}const i=t.getPixelRatio(this.pixelRatio_),s=t.getAnchor(),r=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=s[0]*i,this.imageAnchorY_=s[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=r[0],this.imageOriginY_=r[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();const o=t.getScaleArray();this.imageScale_=[o[0]*this.pixelRatio_/i,o[1]*this.pixelRatio_/i],this.imageWidth_=e[0]*i}setTextStyle(t){if(!t)this.text_="";else{const e=t.getFill();if(!e)this.textFillState_=null;else{const f=e.getColor();this.textFillState_={fillStyle:xe(f||Gt)}}const i=t.getStroke();if(!i)this.textStrokeState_=null;else{const f=i.getColor(),g=i.getLineCap(),m=i.getLineDash(),_=i.getLineDashOffset(),p=i.getLineJoin(),y=i.getWidth(),w=i.getMiterLimit();this.textStrokeState_={lineCap:g!==void 0?g:nn,lineDash:m||Fe,lineDashOffset:_||ke,lineJoin:p!==void 0?p:sn,lineWidth:y!==void 0?y:qn,miterLimit:w!==void 0?w:Vn,strokeStyle:xe(f||jn)}}const s=t.getFont(),r=t.getOffsetX(),o=t.getOffsetY(),a=t.getRotateWithView(),l=t.getRotation(),h=t.getScaleArray(),c=t.getText(),u=t.getTextAlign(),d=t.getTextBaseline();this.textState_={font:s!==void 0?s:Nh,textAlign:u!==void 0?u:Hn,textBaseline:d!==void 0?d:gr},this.text_=c!==void 0?Array.isArray(c)?c.reduce((f,g,m)=>f+=m%2?" ":g,""):c:"",this.textOffsetX_=r!==void 0?this.pixelRatio_*r:0,this.textOffsetY_=o!==void 0?this.pixelRatio_*o:0,this.textRotateWithView_=a!==void 0?a:!1,this.textRotation_=l!==void 0?l:0,this.textScale_=[this.pixelRatio_*h[0],this.pixelRatio_*h[1]]}}}const bg=.5,Yh={Point:kg,LineString:Og,Polygon:Gg,MultiPoint:Ng,MultiLineString:Dg,MultiPolygon:Fg,GeometryCollection:Pg,Circle:Ag};function Lg(n,t){return parseInt(j(n),10)-parseInt(j(t),10)}function $h(n,t){const e=Kh(n,t);return e*e}function Kh(n,t){return bg*n/t}function Ag(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Circle");l.setFillStrokeStyle(r,o),l.drawCircle(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function Bh(n,t,e,i,s,r,o,a){const l=[],h=e.getImage();if(h){let d=!0;const f=h.getImageState();f==Y.LOADED||f==Y.ERROR?d=!1:f==Y.IDLE&&h.load(),d&&l.push(h.ready())}const c=e.getFill();c&&c.loading()&&l.push(c.ready());const u=l.length>0;return u&&Promise.all(l).then(()=>s(null)),Mg(n,t,e,i,r,o,a),u}function Mg(n,t,e,i,s,r,o){const a=e.getGeometryFunction()(t);if(!a)return;const l=a.simplifyTransformed(i,s);if(e.getRenderer())Zh(n,l,e,t,o);else{const c=Yh[l.getType()];c(n,l,e,t,o,r)}}function Zh(n,t,e,i,s){if(t.getType()=="GeometryCollection"){const o=t.getGeometries();for(let a=0,l=o.length;a<l;++a)Zh(n,o[a],e,i,s);return}n.getBuilder(e.getZIndex(),"Default").drawCustom(t,i,e.getRenderer(),e.getHitDetectionRenderer(),s)}function Pg(n,t,e,i,s,r){const o=t.getGeometriesArray();let a,l;for(a=0,l=o.length;a<l;++a){const h=Yh[o[a].getType()];h(n,o[a],e,i,s,r)}}function Og(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawLineString(t,i,s)}const o=e.getText();if(o&&o.getText()){const a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,s)}}function Dg(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawMultiLineString(t,i,s)}const o=e.getText();if(o&&o.getText()){const a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,s)}}function Fg(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(o||r){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawMultiPolygon(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,s)}}function kg(n,t,e,i,s,r){const o=e.getImage(),a=e.getText(),l=a&&a.getText(),h=r&&o&&l?{}:void 0;if(o){if(o.getImageState()!=Y.LOADED)return;const c=n.getBuilder(e.getZIndex(),"Image");c.setImageStyle(o,h),c.drawPoint(t,i,s)}if(l){const c=n.getBuilder(e.getZIndex(),"Text");c.setTextStyle(a,h),c.drawText(t,i,s)}}function Ng(n,t,e,i,s,r){const o=e.getImage(),a=o&&o.getOpacity()!==0,l=e.getText(),h=l&&l.getText(),c=r&&a&&h?{}:void 0;if(a){if(o.getImageState()!=Y.LOADED)return;const u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(o,c),u.drawMultiPoint(t,i,s)}if(h){const u=n.getBuilder(e.getZIndex(),"Text");u.setTextStyle(l,c),u.drawText(t,i,s)}}function Gg(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawPolygon(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,s)}}let zg=!1;function Xg(n,t,e,i,s,r,o){const a=new XMLHttpRequest;a.open("GET",typeof n=="function"?n(e,i,s):n,!0),t.getType()=="arraybuffer"&&(a.responseType="arraybuffer"),a.withCredentials=zg,a.onload=function(l){if(!a.status||a.status>=200&&a.status<300){const h=t.getType();try{let c;h=="text"||h=="json"?c=a.responseText:h=="xml"?c=a.responseXML||a.responseText:h=="arraybuffer"&&(c=a.response),c?r(t.readFeatures(c,{extent:e,featureProjection:s}),t.readProjection(c)):o()}catch{o()}}else o()},a.onerror=o,a.send()}function Uh(n,t){return function(e,i,s,r,o){Xg(n,t,e,i,s,(a,l)=>{this.addFeatures(a),r!==void 0&&r(a)},()=>{this.changed(),o!==void 0&&o()})}}function Wg(n,t){return[[-1/0,-1/0,1/0,1/0]]}function Yg(n,t,e,i){const s=[];let r=Kt();for(let o=0,a=e.length;o<a;++o){const l=e[o];r=no(n,t,l[0],i),s.push((r[0]+r[2])/2,(r[1]+r[3])/2),t=l[l.length-1]}return s}const Vh=fe();class ge{constructor(t,e,i,s,r,o){this.styleFunction,this.extent_,this.id_=o,this.type_=t,this.flatCoordinates_=e,this.flatInteriorPoints_=null,this.flatMidpoints_=null,this.ends_=i||null,this.properties_=r,this.squaredTolerance_,this.stride_=s,this.simplifiedGeometry_}get(t){return this.properties_[t]}getExtent(){return this.extent_||(this.extent_=this.type_==="Point"?Fl(this.flatCoordinates_):no(this.flatCoordinates_,0,this.flatCoordinates_.length,2)),this.extent_}getFlatInteriorPoint(){if(!this.flatInteriorPoints_){const t=wi(this.getExtent());this.flatInteriorPoints_=Io(this.flatCoordinates_,0,this.ends_,2,t,0)}return this.flatInteriorPoints_}getFlatInteriorPoints(){if(!this.flatInteriorPoints_){const t=qf(this.flatCoordinates_,this.ends_),e=Yg(this.flatCoordinates_,0,t,2);this.flatInteriorPoints_=Zf(this.flatCoordinates_,0,t,2,e)}return this.flatInteriorPoints_}getFlatMidpoint(){return this.flatMidpoints_||(this.flatMidpoints_=Rh(this.flatCoordinates_,0,this.flatCoordinates_.length,2,.5)),this.flatMidpoints_}getFlatMidpoints(){if(!this.flatMidpoints_){this.flatMidpoints_=[];const t=this.flatCoordinates_;let e=0;const i=this.ends_;for(let s=0,r=i.length;s<r;++s){const o=i[s],a=Rh(t,e,o,2,.5);Qr(this.flatMidpoints_,a),e=o}}return this.flatMidpoints_}getId(){return this.id_}getOrientedFlatCoordinates(){return this.flatCoordinates_}getGeometry(){return this}getSimplifiedGeometry(t){return this}simplifyTransformed(t,e){return this}getProperties(){return this.properties_}getPropertiesInternal(){return this.properties_}getStride(){return this.stride_}getStyleFunction(){return this.styleFunction}getType(){return this.type_}transform(t){t=Nt(t);const e=t.getExtent(),i=t.getWorldExtent();if(e&&i){const s=At(i)/At(e);De(Vh,i[0],i[3],s,-s,0,0,0),si(this.flatCoordinates_,0,this.flatCoordinates_.length,2,Vh,this.flatCoordinates_)}}applyTransform(t){t(this.flatCoordinates_,this.flatCoordinates_,this.stride_)}clone(){return new ge(this.type_,this.flatCoordinates_.slice(),this.ends_?.slice(),this.stride_,Object.assign({},this.properties_),this.id_)}getEnds(){return this.ends_}enableSimplifyTransformed(){return this.simplifyTransformed=bl((t,e)=>{if(t===this.squaredTolerance_)return this.simplifiedGeometry_;this.simplifiedGeometry_=this.clone(),e&&this.simplifiedGeometry_.applyTransform(e);const i=this.simplifiedGeometry_.getFlatCoordinates();let s;switch(this.type_){case"LineString":i.length=To(i,0,this.simplifiedGeometry_.flatCoordinates_.length,this.simplifiedGeometry_.stride_,t,i,0),s=[i.length];break;case"MultiLineString":s=[],i.length=$f(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,t,i,0,s);break;case"Polygon":s=[],i.length=yh(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,Math.sqrt(t),i,0,s);break}return s&&(this.simplifiedGeometry_=new ge(this.type_,i,s,2,this.properties_,this.id_)),this.squaredTolerance_=t,this.simplifiedGeometry_}),this}}ge.prototype.getFlatCoordinates=ge.prototype.getOrientedFlatCoordinates;function jh(n,t,e=0,i=n.length-1,s=$g){for(;i>e;){if(i-e>600){const l=i-e+1,h=t-e+1,c=Math.log(l),u=.5*Math.exp(2*c/3),d=.5*Math.sqrt(c*u*(l-u)/l)*(h-l/2<0?-1:1),f=Math.max(e,Math.floor(t-h*u/l+d)),g=Math.min(i,Math.floor(t+(l-h)*u/l+d));jh(n,t,f,g,s)}const r=n[t];let o=e,a=i;for(Qn(n,e,t),s(n[i],r)>0&&Qn(n,e,i);o<a;){for(Qn(n,o,a),o++,a--;s(n[o],r)<0;)o++;for(;s(n[a],r)>0;)a--}s(n[e],r)===0?Qn(n,e,a):(a++,Qn(n,a,i)),a<=t&&(e=a+1),t<=a&&(i=a-1)}}function Qn(n,t,e){const i=n[t];n[t]=n[e],n[e]=i}function $g(n,t){return n<t?-1:n>t?1:0}let Hh=class{constructor(t=9){this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(this._maxEntries*.4)),this.clear()}all(){return this._all(this.data,[])}search(t){let e=this.data;const i=[];if(!mr(t,e))return i;const s=this.toBBox,r=[];for(;e;){for(let o=0;o<e.children.length;o++){const a=e.children[o],l=e.leaf?s(a):a;mr(t,l)&&(e.leaf?i.push(a):Ko(t,l)?this._all(a,i):r.push(a))}e=r.pop()}return i}collides(t){let e=this.data;if(!mr(t,e))return!1;const i=[];for(;e;){for(let s=0;s<e.children.length;s++){const r=e.children[s],o=e.leaf?this.toBBox(r):r;if(mr(t,o)){if(e.leaf||Ko(t,o))return!0;i.push(r)}}e=i.pop()}return!1}load(t){if(!(t&&t.length))return this;if(t.length<this._minEntries){for(let i=0;i<t.length;i++)this.insert(t[i]);return this}let e=this._build(t.slice(),0,t.length-1,0);if(!this.data.children.length)this.data=e;else if(this.data.height===e.height)this._splitRoot(this.data,e);else{if(this.data.height<e.height){const i=this.data;this.data=e,e=i}this._insert(e,this.data.height-e.height-1,!0)}return this}insert(t){return t&&this._insert(t,this.data.height-1),this}clear(){return this.data=an([]),this}remove(t,e){if(!t)return this;let i=this.data;const s=this.toBBox(t),r=[],o=[];let a,l,h;for(;i||r.length;){if(i||(i=r.pop(),l=r[r.length-1],a=o.pop(),h=!0),i.leaf){const c=Kg(t,i.children,e);if(c!==-1)return i.children.splice(c,1),r.push(i),this._condense(r),this}!h&&!i.leaf&&Ko(i,s)?(r.push(i),o.push(a),a=0,l=i,i=i.children[0]):l?(a++,i=l.children[a],h=!1):i=null}return this}toBBox(t){return t}compareMinX(t,e){return t.minX-e.minX}compareMinY(t,e){return t.minY-e.minY}toJSON(){return this.data}fromJSON(t){return this.data=t,this}_all(t,e){const i=[];for(;t;)t.leaf?e.push(...t.children):i.push(...t.children),t=i.pop();return e}_build(t,e,i,s){const r=i-e+1;let o=this._maxEntries,a;if(r<=o)return a=an(t.slice(e,i+1)),on(a,this.toBBox),a;s||(s=Math.ceil(Math.log(r)/Math.log(o)),o=Math.ceil(r/Math.pow(o,s-1))),a=an([]),a.leaf=!1,a.height=s;const l=Math.ceil(r/o),h=l*Math.ceil(Math.sqrt(o));qh(t,e,i,h,this.compareMinX);for(let c=e;c<=i;c+=h){const u=Math.min(c+h-1,i);qh(t,c,u,l,this.compareMinY);for(let d=c;d<=u;d+=l){const f=Math.min(d+l-1,u);a.children.push(this._build(t,d,f,s-1))}}return on(a,this.toBBox),a}_chooseSubtree(t,e,i,s){for(;s.push(e),!(e.leaf||s.length-1===i);){let r=1/0,o=1/0,a;for(let l=0;l<e.children.length;l++){const h=e.children[l],c=$o(h),u=Ug(t,h)-c;u<o?(o=u,r=c<r?c:r,a=h):u===o&&c<r&&(r=c,a=h)}e=a||e.children[0]}return e}_insert(t,e,i){const s=i?t:this.toBBox(t),r=[],o=this._chooseSubtree(s,this.data,e,r);for(o.children.push(t),es(o,s);e>=0&&r[e].children.length>this._maxEntries;)this._split(r,e),e--;this._adjustParentBBoxes(s,r,e)}_split(t,e){const i=t[e],s=i.children.length,r=this._minEntries;this._chooseSplitAxis(i,r,s);const o=this._chooseSplitIndex(i,r,s),a=an(i.children.splice(o,i.children.length-o));a.height=i.height,a.leaf=i.leaf,on(i,this.toBBox),on(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(i,a)}_splitRoot(t,e){this.data=an([t,e]),this.data.height=t.height+1,this.data.leaf=!1,on(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let s,r=1/0,o=1/0;for(let a=e;a<=i-e;a++){const l=ts(t,0,a,this.toBBox),h=ts(t,a,i,this.toBBox),c=Vg(l,h),u=$o(l)+$o(h);c<r?(r=c,s=a,o=u<o?u:o):c===r&&u<o&&(o=u,s=a)}return s||i-e}_chooseSplitAxis(t,e,i){const s=t.leaf?this.compareMinX:Bg,r=t.leaf?this.compareMinY:Zg,o=this._allDistMargin(t,e,i,s),a=this._allDistMargin(t,e,i,r);o<a&&t.children.sort(s)}_allDistMargin(t,e,i,s){t.children.sort(s);const r=this.toBBox,o=ts(t,0,e,r),a=ts(t,i-e,i,r);let l=_r(o)+_r(a);for(let h=e;h<i-e;h++){const c=t.children[h];es(o,t.leaf?r(c):c),l+=_r(o)}for(let h=i-e-1;h>=e;h--){const c=t.children[h];es(a,t.leaf?r(c):c),l+=_r(a)}return l}_adjustParentBBoxes(t,e,i){for(let s=i;s>=0;s--)es(e[s],t)}_condense(t){for(let e=t.length-1,i;e>=0;e--)t[e].children.length===0?e>0?(i=t[e-1].children,i.splice(i.indexOf(t[e]),1)):this.clear():on(t[e],this.toBBox)}};function Kg(n,t,e){if(!e)return t.indexOf(n);for(let i=0;i<t.length;i++)if(e(n,t[i]))return i;return-1}function on(n,t){ts(n,0,n.children.length,t,n)}function ts(n,t,e,i,s){s||(s=an(null)),s.minX=1/0,s.minY=1/0,s.maxX=-1/0,s.maxY=-1/0;for(let r=t;r<e;r++){const o=n.children[r];es(s,n.leaf?i(o):o)}return s}function es(n,t){return n.minX=Math.min(n.minX,t.minX),n.minY=Math.min(n.minY,t.minY),n.maxX=Math.max(n.maxX,t.maxX),n.maxY=Math.max(n.maxY,t.maxY),n}function Bg(n,t){return n.minX-t.minX}function Zg(n,t){return n.minY-t.minY}function $o(n){return(n.maxX-n.minX)*(n.maxY-n.minY)}function _r(n){return n.maxX-n.minX+(n.maxY-n.minY)}function Ug(n,t){return(Math.max(t.maxX,n.maxX)-Math.min(t.minX,n.minX))*(Math.max(t.maxY,n.maxY)-Math.min(t.minY,n.minY))}function Vg(n,t){const e=Math.max(n.minX,t.minX),i=Math.max(n.minY,t.minY),s=Math.min(n.maxX,t.maxX),r=Math.min(n.maxY,t.maxY);return Math.max(0,s-e)*Math.max(0,r-i)}function Ko(n,t){return n.minX<=t.minX&&n.minY<=t.minY&&t.maxX<=n.maxX&&t.maxY<=n.maxY}function mr(n,t){return t.minX<=n.maxX&&t.minY<=n.maxY&&t.maxX>=n.minX&&t.maxY>=n.minY}function an(n){return{children:n,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function qh(n,t,e,i,s){const r=[t,e];for(;r.length;){if(e=r.pop(),t=r.pop(),e-t<=i)continue;const o=t+Math.ceil((e-t)/i/2)*i;jh(n,o,t,e,s),r.push(t,o,o,e)}}class Jh{constructor(t){this.rbush_=new Hh(t),this.items_={}}insert(t,e){const i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[j(e)]=i}load(t,e){const i=new Array(e.length);for(let s=0,r=e.length;s<r;s++){const o=t[s],a=e[s],l={minX:o[0],minY:o[1],maxX:o[2],maxY:o[3],value:a};i[s]=l,this.items_[j(a)]=l}this.rbush_.load(i)}remove(t){const e=j(t),i=this.items_[e];return delete this.items_[e],this.rbush_.remove(i)!==null}update(t,e){const i=this.items_[j(e)],s=[i.minX,i.minY,i.maxX,i.maxY];Gn(s,t)||(this.remove(e),this.insert(t,e))}getAll(){return this.rbush_.all().map(function(e){return e.value})}getInExtent(t){const e={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3]};return this.rbush_.search(e).map(function(s){return s.value})}forEach(t){return this.forEach_(this.getAll(),t)}forEachInExtent(t,e){return this.forEach_(this.getInExtent(t),e)}forEach_(t,e){let i;for(let s=0,r=t.length;s<r;s++)if(i=e(t[s]),i)return i;return i}isEmpty(){return Bi(this.items_)}clear(){this.rbush_.clear(),this.items_={}}getExtent(t){const e=this.rbush_.toJSON();return ei(e.minX,e.minY,e.maxX,e.maxY,t)}concat(t){this.rbush_.load(t.rbush_.all());for(const e in t.items_)this.items_[e]=t.items_[e]}}class Qh extends de{constructor(t){super(),this.projection=Nt(t.projection),this.attributions_=tc(t.attributions),this.attributionsCollapsible_=t.attributionsCollapsible??!0,this.loading=!1,this.state_=t.state!==void 0?t.state:"ready",this.wrapX_=t.wrapX!==void 0?t.wrapX:!1,this.interpolate_=!!t.interpolate,this.viewResolver=null,this.viewRejector=null;const e=this;this.viewPromise_=new Promise(function(i,s){e.viewResolver=i,e.viewRejector=s})}getAttributions(){return this.attributions_}getAttributionsCollapsible(){return this.attributionsCollapsible_}getProjection(){return this.projection}getResolutions(t){return null}getView(){return this.viewPromise_}getState(){return this.state_}getWrapX(){return this.wrapX_}getInterpolate(){return this.interpolate_}refresh(){this.changed()}setAttributions(t){this.attributions_=tc(t),this.changed()}setState(t){this.state_=t,this.changed()}}function tc(n){return n?typeof n=="function"?n:(Array.isArray(n)||(n=[n]),t=>n):null}const se={ADDFEATURE:"addfeature",CHANGEFEATURE:"changefeature",CLEAR:"clear",REMOVEFEATURE:"removefeature",FEATURESLOADSTART:"featuresloadstart",FEATURESLOADEND:"featuresloadend",FEATURESLOADERROR:"featuresloaderror"};class oi extends Pe{constructor(t,e,i){super(t),this.feature=e,this.features=i}}class jg extends Qh{constructor(t){t=t||{},super({attributions:t.attributions,interpolate:!0,projection:void 0,state:"ready",wrapX:t.wrapX!==void 0?t.wrapX:!0}),this.on,this.once,this.un,this.loader_=Fn,this.format_=t.format||null,this.overlaps_=t.overlaps===void 0?!0:t.overlaps,this.url_=t.url,t.loader!==void 0?this.loader_=t.loader:this.url_!==void 0&&(Q(this.format_,"`format` must be set when `url` is set"),this.loader_=Uh(this.url_,this.format_)),this.strategy_=t.strategy!==void 0?t.strategy:Wg;const e=t.useSpatialIndex!==void 0?t.useSpatialIndex:!0;this.featuresRtree_=e?new Jh:null,this.loadedExtentsRtree_=new Jh,this.loadingExtentsCount_=0,this.nullGeometryFeatures_={},this.idIndex_={},this.uidIndex_={},this.featureChangeKeys_={},this.featuresCollection_=null;let i,s;Array.isArray(t.features)?s=t.features:t.features&&(i=t.features,s=i.getArray()),!e&&i===void 0&&(i=new Qt(s)),s!==void 0&&this.addFeaturesInternal(s),i!==void 0&&this.bindFeaturesCollection_(i)}addFeature(t){this.addFeatureInternal(t),this.changed()}addFeatureInternal(t){const e=j(t);if(!this.addToIndex_(e,t)){this.featuresCollection_&&this.featuresCollection_.remove(t);return}this.setupChangeEvents_(e,t);const i=t.getGeometry();if(i){const s=i.getExtent();this.featuresRtree_&&this.featuresRtree_.insert(s,t)}else this.nullGeometryFeatures_[e]=t;this.dispatchEvent(new oi(se.ADDFEATURE,t))}setupChangeEvents_(t,e){e instanceof ge||(this.featureChangeKeys_[t]=[U(e,W.CHANGE,this.handleFeatureChange_,this),U(e,Ki.PROPERTYCHANGE,this.handleFeatureChange_,this)])}addToIndex_(t,e){let i=!0;if(e.getId()!==void 0){const s=String(e.getId());if(!(s in this.idIndex_))this.idIndex_[s]=e;else if(e instanceof ge){const r=this.idIndex_[s];r instanceof ge?Array.isArray(r)?r.push(e):this.idIndex_[s]=[r,e]:i=!1}else i=!1}return i&&(Q(!(t in this.uidIndex_),"The passed `feature` was already added to the source"),this.uidIndex_[t]=e),i}addFeatures(t){this.addFeaturesInternal(t),this.changed()}addFeaturesInternal(t){const e=[],i=[],s=[];for(let r=0,o=t.length;r<o;r++){const a=t[r],l=j(a);this.addToIndex_(l,a)&&i.push(a)}for(let r=0,o=i.length;r<o;r++){const a=i[r],l=j(a);this.setupChangeEvents_(l,a);const h=a.getGeometry();if(h){const c=h.getExtent();e.push(c),s.push(a)}else this.nullGeometryFeatures_[l]=a}if(this.featuresRtree_&&this.featuresRtree_.load(e,s),this.hasListener(se.ADDFEATURE))for(let r=0,o=i.length;r<o;r++)this.dispatchEvent(new oi(se.ADDFEATURE,i[r]))}bindFeaturesCollection_(t){let e=!1;this.addEventListener(se.ADDFEATURE,function(i){e||(e=!0,t.push(i.feature),e=!1)}),this.addEventListener(se.REMOVEFEATURE,function(i){e||(e=!0,t.remove(i.feature),e=!1)}),t.addEventListener(Ft.ADD,i=>{e||(e=!0,this.addFeature(i.element),e=!1)}),t.addEventListener(Ft.REMOVE,i=>{e||(e=!0,this.removeFeature(i.element),e=!1)}),this.featuresCollection_=t}clear(t){if(t){for(const i in this.featureChangeKeys_)this.featureChangeKeys_[i].forEach(nt);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){this.featuresRtree_.forEach(i=>{this.removeFeatureInternal(i)});for(const i in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[i])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};const e=new oi(se.CLEAR);this.dispatchEvent(e),this.changed()}forEachFeature(t){if(this.featuresRtree_)return this.featuresRtree_.forEach(t);this.featuresCollection_&&this.featuresCollection_.forEach(t)}forEachFeatureAtCoordinateDirect(t,e){const i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,function(s){const r=s.getGeometry();if(r instanceof ge||r.intersectsCoordinate(t))return e(s)})}forEachFeatureInExtent(t,e){if(this.featuresRtree_)return this.featuresRtree_.forEachInExtent(t,e);this.featuresCollection_&&this.featuresCollection_.forEach(e)}forEachFeatureIntersectingExtent(t,e){return this.forEachFeatureInExtent(t,function(i){const s=i.getGeometry();if(s instanceof ge||s.intersectsExtent(t)){const r=e(i);if(r)return r}})}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),Bi(this.nullGeometryFeatures_)||Qr(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){const e=[];return this.forEachFeatureAtCoordinateDirect(t,function(i){e.push(i)}),e}getFeaturesInExtent(t,e){if(this.featuresRtree_){if(!(e&&e.canWrapX()&&this.getWrapX()))return this.featuresRtree_.getInExtent(t);const s=Wl(t,e);return[].concat(...s.map(r=>this.featuresRtree_.getInExtent(r)))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){const i=t[0],s=t[1];let r=null;const o=[NaN,NaN];let a=1/0;const l=[-1/0,-1/0,1/0,1/0];return e=e||Dn,this.featuresRtree_.forEachInExtent(l,function(h){if(e(h)){const c=h.getGeometry(),u=a;if(a=c instanceof ge?0:c.closestPointXY(i,s,o,a),a<u){r=h;const d=Math.sqrt(a);l[0]=i-d,l[1]=s-d,l[2]=i+d,l[3]=s+d}}}),r}getExtent(t){return this.featuresRtree_.getExtent(t)}getFeatureById(t){const e=this.idIndex_[t.toString()];return e!==void 0?e:null}getFeatureByUid(t){const e=this.uidIndex_[t];return e!==void 0?e:null}getFormat(){return this.format_}getOverlaps(){return this.overlaps_}getUrl(){return this.url_}handleFeatureChange_(t){const e=t.target,i=j(e),s=e.getGeometry();if(!s)i in this.nullGeometryFeatures_||(this.featuresRtree_&&this.featuresRtree_.remove(e),this.nullGeometryFeatures_[i]=e);else{const o=s.getExtent();i in this.nullGeometryFeatures_?(delete this.nullGeometryFeatures_[i],this.featuresRtree_&&this.featuresRtree_.insert(o,e)):this.featuresRtree_&&this.featuresRtree_.update(o,e)}const r=e.getId();if(r!==void 0){const o=r.toString();this.idIndex_[o]!==e&&(this.removeFromIdIndex_(e),this.idIndex_[o]=e)}else this.removeFromIdIndex_(e),this.uidIndex_[i]=e;this.changed(),this.dispatchEvent(new oi(se.CHANGEFEATURE,e))}hasFeature(t){const e=t.getId();return e!==void 0?e in this.idIndex_:j(t)in this.uidIndex_}isEmpty(){return this.featuresRtree_?this.featuresRtree_.isEmpty()&&Bi(this.nullGeometryFeatures_):this.featuresCollection_?this.featuresCollection_.getLength()===0:!0}loadFeatures(t,e,i){const s=this.loadedExtentsRtree_,r=this.strategy_(t,e,i);for(let o=0,a=r.length;o<a;++o){const l=r[o];s.forEachInExtent(l,function(c){return Ui(c.extent,l)})||(++this.loadingExtentsCount_,this.dispatchEvent(new oi(se.FEATURESLOADSTART)),this.loader_.call(this,l,e,i,c=>{--this.loadingExtentsCount_,this.dispatchEvent(new oi(se.FEATURESLOADEND,void 0,c))},()=>{--this.loadingExtentsCount_,this.dispatchEvent(new oi(se.FEATURESLOADERROR))}),s.insert(l,{extent:l.slice()}))}this.loading=this.loader_.length<4?!1:this.loadingExtentsCount_>0}refresh(){this.clear(!0),this.loadedExtentsRtree_.clear(),super.refresh()}removeLoadedExtent(t){const e=this.loadedExtentsRtree_,i=e.forEachInExtent(t,function(s){if(Gn(s.extent,t))return s});i&&e.remove(i)}removeFeatures(t){let e=!1;for(let i=0,s=t.length;i<s;++i)e=this.removeFeatureInternal(t[i])||e;e&&this.changed()}removeFeature(t){if(!t)return;this.removeFeatureInternal(t)&&this.changed()}removeFeatureInternal(t){const e=j(t);if(!(e in this.uidIndex_))return!1;e in this.nullGeometryFeatures_?delete this.nullGeometryFeatures_[e]:this.featuresRtree_&&this.featuresRtree_.remove(t),this.featureChangeKeys_[e]?.forEach(nt),delete this.featureChangeKeys_[e];const s=t.getId();if(s!==void 0){const r=s.toString(),o=this.idIndex_[r];o===t?delete this.idIndex_[r]:Array.isArray(o)&&(o.splice(o.indexOf(t),1),o.length===1&&(this.idIndex_[r]=o[0]))}return delete this.uidIndex_[e],this.hasListener(se.REMOVEFEATURE)&&this.dispatchEvent(new oi(se.REMOVEFEATURE,t)),!0}removeFromIdIndex_(t){for(const e in this.idIndex_)if(this.idIndex_[e]===t){delete this.idIndex_[e];break}}setLoader(t){this.loader_=t}setUrl(t){Q(this.format_,"`format` must be set when `url` is set"),this.url_=t,this.setLoader(Uh(t,this.format_))}setOverlaps(t){this.overlaps_=t,this.changed()}}class Mi{constructor(t){t=t||{},this.patternImage_=null,this.color_=null,t.color!==void 0&&this.setColor(t.color)}clone(){const t=this.getColor();return new Mi({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){if(t!==null&&typeof t=="object"&&"src"in t){const e=ur(null,t.src,"anonymous",void 0,t.offset?null:t.color?t.color:null,!(t.offset&&t.size));e.ready().then(()=>{this.patternImage_=null}),e.getImageState()===Y.IDLE&&e.load(),e.getImageState()===Y.LOADING&&(this.patternImage_=e)}this.color_=t}getKey(){const t=this.getColor();return t?t instanceof CanvasPattern||t instanceof CanvasGradient?j(t):typeof t=="object"&&"src"in t?t.src+":"+t.offset:en(t).toString():""}loading(){return!!this.patternImage_}ready(){return this.patternImage_?this.patternImage_.ready():Promise.resolve()}}class is{constructor(t){t=t||{},this.color_=t.color!==void 0?t.color:null,this.lineCap_=t.lineCap,this.lineDash_=t.lineDash!==void 0?t.lineDash:null,this.lineDashOffset_=t.lineDashOffset,this.lineJoin_=t.lineJoin,this.miterLimit_=t.miterLimit,this.width_=t.width}clone(){const t=this.getColor();return new is({color:Array.isArray(t)?t.slice():t||void 0,lineCap:this.getLineCap(),lineDash:this.getLineDash()?this.getLineDash().slice():void 0,lineDashOffset:this.getLineDashOffset(),lineJoin:this.getLineJoin(),miterLimit:this.getMiterLimit(),width:this.getWidth()})}getColor(){return this.color_}getLineCap(){return this.lineCap_}getLineDash(){return this.lineDash_}getLineDashOffset(){return this.lineDashOffset_}getLineJoin(){return this.lineJoin_}getMiterLimit(){return this.miterLimit_}getWidth(){return this.width_}setColor(t){this.color_=t}setLineCap(t){this.lineCap_=t}setLineDash(t){this.lineDash_=t}setLineDashOffset(t){this.lineDashOffset_=t}setLineJoin(t){this.lineJoin_=t}setMiterLimit(t){this.miterLimit_=t}setWidth(t){this.width_=t}}function ec(n){return n[0]>0&&n[1]>0}function Hg(n,t,e){return e===void 0&&(e=[0,0]),e[0]=n[0]*t+.5|0,e[1]=n[1]*t+.5|0,e}function zt(n,t){return Array.isArray(n)?n:(t===void 0?t=[n,n]:(t[0]=n,t[1]=n),t)}class pr{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=zt(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new pr({opacity:this.getOpacity(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getOpacity(){return this.opacity_}getRotateWithView(){return this.rotateWithView_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getDisplacement(){return this.displacement_}getDeclutterMode(){return this.declutterMode_}getAnchor(){return V()}getImage(t){return V()}getHitDetectionImage(){return V()}getPixelRatio(t){return 1}getImageState(){return V()}getImageSize(){return V()}getOrigin(){return V()}getSize(){return V()}setDisplacement(t){this.displacement_=t}setOpacity(t){this.opacity_=t}setRotateWithView(t){this.rotateWithView_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=zt(t)}listenImageChange(t){V()}load(){V()}unlistenImageChange(t){V()}ready(){return Promise.resolve()}}class yr extends pr{constructor(t){super({opacity:1,rotateWithView:t.rotateWithView!==void 0?t.rotateWithView:!1,rotation:t.rotation!==void 0?t.rotation:0,scale:t.scale!==void 0?t.scale:1,displacement:t.displacement!==void 0?t.displacement:[0,0],declutterMode:t.declutterMode}),this.hitDetectionCanvas_=null,this.fill_=t.fill!==void 0?t.fill:null,this.origin_=[0,0],this.points_=t.points,this.radius=t.radius,this.radius2_=t.radius2,this.angle_=t.angle!==void 0?t.angle:0,this.stroke_=t.stroke!==void 0?t.stroke:null,this.size_,this.renderOptions_,this.imageState_=this.fill_&&this.fill_.loading()?Y.LOADING:Y.LOADED,this.imageState_===Y.LOADING&&this.ready().then(()=>this.imageState_=Y.LOADED),this.render()}clone(){const t=this.getScale(),e=new yr({fill:this.getFill()?this.getFill().clone():void 0,points:this.getPoints(),radius:this.getRadius(),radius2:this.getRadius2(),angle:this.getAngle(),stroke:this.getStroke()?this.getStroke().clone():void 0,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),scale:Array.isArray(t)?t.slice():t,displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}getAnchor(){const t=this.size_,e=this.getDisplacement(),i=this.getScaleArray();return[t[0]/2-e[0]/i[0],t[1]/2+e[1]/i[1]]}getAngle(){return this.angle_}getFill(){return this.fill_}setFill(t){this.fill_=t,this.render()}getHitDetectionImage(){return this.hitDetectionCanvas_||(this.hitDetectionCanvas_=this.createHitDetectionCanvas_(this.renderOptions_)),this.hitDetectionCanvas_}getImage(t){const e=this.fill_?.getKey(),i=`${t},${this.angle_},${this.radius},${this.radius2_},${this.points_},${e}`+Object.values(this.renderOptions_).join(",");let s=ne.get(i,null,null)?.getImage(1);if(!s){const r=this.renderOptions_,o=Math.ceil(r.size*t),a=ct(o,o);this.draw_(r,a,t),s=a.canvas,ne.set(i,null,null,new Oh(s,void 0,null,Y.LOADED,null))}return s}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return this.imageState_}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius}getRadius2(){return this.radius2_}getSize(){return this.size_}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t,this.render()}listenImageChange(t){}load(){}unlistenImageChange(t){}calculateLineJoinSize_(t,e,i){if(e===0||this.points_===1/0||t!=="bevel"&&t!=="miter")return e;let s=this.radius,r=this.radius2_===void 0?s:this.radius2_;if(s<r){const T=s;s=r,r=T}const o=this.radius2_===void 0?this.points_:this.points_*2,a=2*Math.PI/o,l=r*Math.sin(a),h=Math.sqrt(r*r-l*l),c=s-h,u=Math.sqrt(l*l+c*c),d=u/l;if(t==="miter"&&d<=i)return d*e;const f=e/2/d,g=e/2*(c/u),_=Math.sqrt((s+f)*(s+f)+g*g)-s;if(this.radius2_===void 0||t==="bevel")return _*2;const p=s*Math.sin(a),y=Math.sqrt(s*s-p*p),w=r-y,E=Math.sqrt(p*p+w*w)/p;if(E<=i){const T=E*e/2-r-s;return 2*Math.max(_,T)}return _*2}createRenderOptions(){let t=nn,e=sn,i=0,s=null,r=0,o,a=0;this.stroke_&&(o=xe(this.stroke_.getColor()??jn),a=this.stroke_.getWidth()??qn,s=this.stroke_.getLineDash(),r=this.stroke_.getLineDashOffset()??0,e=this.stroke_.getLineJoin()??sn,t=this.stroke_.getLineCap()??nn,i=this.stroke_.getMiterLimit()??Vn);const l=this.calculateLineJoinSize_(e,a,i),h=Math.max(this.radius,this.radius2_||0),c=Math.ceil(2*h+l);return{strokeStyle:o,strokeWidth:a,size:c,lineCap:t,lineDash:s,lineDashOffset:r,lineJoin:e,miterLimit:i}}render(){this.renderOptions_=this.createRenderOptions();const t=this.renderOptions_.size;this.hitDetectionCanvas_=null,this.size_=[t,t]}draw_(t,e,i){if(e.scale(i,i),e.translate(t.size/2,t.size/2),this.createPath_(e),this.fill_){let s=this.fill_.getColor();s===null&&(s=Gt),e.fillStyle=xe(s),e.fill()}t.strokeStyle&&(e.strokeStyle=t.strokeStyle,e.lineWidth=t.strokeWidth,t.lineDash&&(e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset),e.lineCap=t.lineCap,e.lineJoin=t.lineJoin,e.miterLimit=t.miterLimit,e.stroke())}createHitDetectionCanvas_(t){let e;if(this.fill_){let i=this.fill_.getColor(),s=0;typeof i=="string"&&(i=en(i)),i===null?s=1:Array.isArray(i)&&(s=i.length===4?i[3]:1),s===0&&(e=ct(t.size,t.size),this.drawHitDetectionCanvas_(t,e))}return e?e.canvas:this.getImage(1)}createPath_(t){let e=this.points_;const i=this.radius;if(e===1/0)t.arc(0,0,i,0,2*Math.PI);else{const s=this.radius2_===void 0?i:this.radius2_;this.radius2_!==void 0&&(e*=2);const r=this.angle_-Math.PI/2,o=2*Math.PI/e;for(let a=0;a<e;a++){const l=r+a*o,h=a%2===0?i:s;t.lineTo(h*Math.cos(l),h*Math.sin(l))}t.closePath()}}drawHitDetectionCanvas_(t,e){e.translate(t.size/2,t.size/2),this.createPath_(e),e.fillStyle=Gt,e.fill(),t.strokeStyle&&(e.strokeStyle=t.strokeStyle,e.lineWidth=t.strokeWidth,t.lineDash&&(e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset),e.lineJoin=t.lineJoin,e.miterLimit=t.miterLimit,e.stroke())}ready(){return this.fill_?this.fill_.ready():Promise.resolve()}}class xr extends yr{constructor(t){t=t||{radius:5},super({points:1/0,fill:t.fill,radius:t.radius,stroke:t.stroke,scale:t.scale!==void 0?t.scale:1,rotation:t.rotation!==void 0?t.rotation:0,rotateWithView:t.rotateWithView!==void 0?t.rotateWithView:!1,displacement:t.displacement!==void 0?t.displacement:[0,0],declutterMode:t.declutterMode})}clone(){const t=this.getScale(),e=new xr({fill:this.getFill()?this.getFill().clone():void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,radius:this.getRadius(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}setRadius(t){this.radius=t,this.render()}}class Ee{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=nc,t.geometry!==void 0&&this.setGeometry(t.geometry),this.fill_=t.fill!==void 0?t.fill:null,this.image_=t.image!==void 0?t.image:null,this.renderer_=t.renderer!==void 0?t.renderer:null,this.hitDetectionRenderer_=t.hitDetectionRenderer!==void 0?t.hitDetectionRenderer:null,this.stroke_=t.stroke!==void 0?t.stroke:null,this.text_=t.text!==void 0?t.text:null,this.zIndex_=t.zIndex}clone(){let t=this.getGeometry();return t&&typeof t=="object"&&(t=t.clone()),new Ee({geometry:t??void 0,fill:this.getFill()?this.getFill().clone():void 0,image:this.getImage()?this.getImage().clone():void 0,renderer:this.getRenderer()??void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,text:this.getText()?this.getText().clone():void 0,zIndex:this.getZIndex()})}getRenderer(){return this.renderer_}setRenderer(t){this.renderer_=t}setHitDetectionRenderer(t){this.hitDetectionRenderer_=t}getHitDetectionRenderer(){return this.hitDetectionRenderer_}getGeometry(){return this.geometry_}getGeometryFunction(){return this.geometryFunction_}getFill(){return this.fill_}setFill(t){this.fill_=t}getImage(){return this.image_}setImage(t){this.image_=t}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t}getText(){return this.text_}setText(t){this.text_=t}getZIndex(){return this.zIndex_}setGeometry(t){typeof t=="function"?this.geometryFunction_=t:typeof t=="string"?this.geometryFunction_=function(e){return e.get(t)}:t?t!==void 0&&(this.geometryFunction_=function(){return t}):this.geometryFunction_=nc,this.geometry_=t}setZIndex(t){this.zIndex_=t}}function qg(n){let t;if(typeof n=="function")t=n;else{let e;Array.isArray(n)?e=n:(Q(typeof n.getZIndex=="function","Expected an `Style` or an array of `Style`"),e=[n]),t=function(){return e}}return t}let Bo=null;function ic(n,t){if(!Bo){const e=new Mi({color:"rgba(255,255,255,0.4)"}),i=new is({color:"#3399CC",width:1.25});Bo=[new Ee({image:new xr({fill:e,stroke:i,radius:5}),fill:e,stroke:i})]}return Bo}function nc(n){return n.getGeometry()}const Jg="#333";let sc=class du{constructor(t){t=t||{},this.font_=t.font,this.rotation_=t.rotation,this.rotateWithView_=t.rotateWithView,this.keepUpright_=t.keepUpright,this.scale_=t.scale,this.scaleArray_=zt(t.scale!==void 0?t.scale:1),this.text_=t.text,this.textAlign_=t.textAlign,this.justify_=t.justify,this.repeat_=t.repeat,this.textBaseline_=t.textBaseline,this.fill_=t.fill!==void 0?t.fill:new Mi({color:Jg}),this.maxAngle_=t.maxAngle!==void 0?t.maxAngle:Math.PI/4,this.placement_=t.placement!==void 0?t.placement:"point",this.overflow_=!!t.overflow,this.stroke_=t.stroke!==void 0?t.stroke:null,this.offsetX_=t.offsetX!==void 0?t.offsetX:0,this.offsetY_=t.offsetY!==void 0?t.offsetY:0,this.backgroundFill_=t.backgroundFill?t.backgroundFill:null,this.backgroundStroke_=t.backgroundStroke?t.backgroundStroke:null,this.padding_=t.padding===void 0?null:t.padding,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new du({font:this.getFont(),placement:this.getPlacement(),repeat:this.getRepeat(),maxAngle:this.getMaxAngle(),overflow:this.getOverflow(),rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),keepUpright:this.getKeepUpright(),scale:Array.isArray(t)?t.slice():t,text:this.getText(),textAlign:this.getTextAlign(),justify:this.getJustify(),textBaseline:this.getTextBaseline(),fill:this.getFill()instanceof Mi?this.getFill().clone():this.getFill(),stroke:this.getStroke()?this.getStroke().clone():void 0,offsetX:this.getOffsetX(),offsetY:this.getOffsetY(),backgroundFill:this.getBackgroundFill()?this.getBackgroundFill().clone():void 0,backgroundStroke:this.getBackgroundStroke()?this.getBackgroundStroke().clone():void 0,padding:this.getPadding()||void 0,declutterMode:this.getDeclutterMode()})}getOverflow(){return this.overflow_}getFont(){return this.font_}getMaxAngle(){return this.maxAngle_}getPlacement(){return this.placement_}getRepeat(){return this.repeat_}getOffsetX(){return this.offsetX_}getOffsetY(){return this.offsetY_}getFill(){return this.fill_}getRotateWithView(){return this.rotateWithView_}getKeepUpright(){return this.keepUpright_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getStroke(){return this.stroke_}getText(){return this.text_}getTextAlign(){return this.textAlign_}getJustify(){return this.justify_}getTextBaseline(){return this.textBaseline_}getBackgroundFill(){return this.backgroundFill_}getBackgroundStroke(){return this.backgroundStroke_}getPadding(){return this.padding_}getDeclutterMode(){return this.declutterMode_}setOverflow(t){this.overflow_=t}setFont(t){this.font_=t}setMaxAngle(t){this.maxAngle_=t}setOffsetX(t){this.offsetX_=t}setOffsetY(t){this.offsetY_=t}setPlacement(t){this.placement_=t}setRepeat(t){this.repeat_=t}setRotateWithView(t){this.rotateWithView_=t}setKeepUpright(t){this.keepUpright_=t}setFill(t){this.fill_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=zt(t!==void 0?t:1)}setStroke(t){this.stroke_=t}setText(t){this.text_=t}setTextAlign(t){this.textAlign_=t}setJustify(t){this.justify_=t}setTextBaseline(t){this.textBaseline_=t}setBackgroundFill(t){this.backgroundFill_=t}setBackgroundStroke(t){this.backgroundStroke_=t}setPadding(t){this.padding_=t}};const vt={ANIMATING:0,INTERACTING:1},N={BEGIN_GEOMETRY:0,BEGIN_PATH:1,CIRCLE:2,CLOSE_PATH:3,CUSTOM:4,DRAW_CHARS:5,DRAW_IMAGE:6,END_GEOMETRY:7,FILL:8,MOVE_TO_LINE_TO:9,SET_FILL_STYLE:10,SET_STROKE_STYLE:11,STROKE:12},Er=[N.FILL],ai=[N.STROKE],Pi=[N.BEGIN_PATH],rc=[N.CLOSE_PATH];class ns extends Dh{constructor(t,e,i,s){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=s,this.maxLineWidth=0,this.resolution=i,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_=null,this.bufferedMaxExtent_=null,this.instructions=[],this.coordinates=[],this.tmpCoordinate_=[],this.hitDetectionInstructions=[],this.state={}}applyPixelRatio(t){const e=this.pixelRatio;return e==1?t:t.map(function(i){return i*e})}appendFlatPointCoordinates(t,e){const i=this.getBufferedMaxExtent(),s=this.tmpCoordinate_,r=this.coordinates;let o=r.length;for(let a=0,l=t.length;a<l;a+=e)s[0]=t[a],s[1]=t[a+1],Zi(i,s)&&(r[o++]=s[0],r[o++]=s[1]);return o}appendFlatLineCoordinates(t,e,i,s,r,o){const a=this.coordinates;let l=a.length;const h=this.getBufferedMaxExtent();o&&(e+=s);let c=t[e],u=t[e+1];const d=this.tmpCoordinate_;let f=!0,g,m,_;for(g=e+s;g<i;g+=s)d[0]=t[g],d[1]=t[g+1],_=io(h,d),_!==m?(f&&(a[l++]=c,a[l++]=u,f=!1),a[l++]=d[0],a[l++]=d[1]):_===dt.INTERSECTING?(a[l++]=d[0],a[l++]=d[1],f=!1):f=!0,c=d[0],u=d[1],m=_;return(r&&f||g===e+s)&&(a[l++]=c,a[l++]=u),l}drawCustomCoordinates_(t,e,i,s,r){for(let o=0,a=i.length;o<a;++o){const l=i[o],h=this.appendFlatLineCoordinates(t,e,l,s,!1,!1);r.push(h),e=l}return e}drawCustom(t,e,i,s,r){this.beginGeometry(t,e,r);const o=t.getType(),a=t.getStride(),l=this.coordinates.length;let h,c,u,d,f;switch(o){case"MultiPolygon":h=t.getOrientedFlatCoordinates(),d=[];const g=t.getEndss();f=0;for(let m=0,_=g.length;m<_;++m){const p=[];f=this.drawCustomCoordinates_(h,f,g[m],a,p),d.push(p)}this.instructions.push([N.CUSTOM,l,d,t,i,ph,r]),this.hitDetectionInstructions.push([N.CUSTOM,l,d,t,s||i,ph,r]);break;case"Polygon":case"MultiLineString":u=[],h=o=="Polygon"?t.getOrientedFlatCoordinates():t.getFlatCoordinates(),f=this.drawCustomCoordinates_(h,0,t.getEnds(),a,u),this.instructions.push([N.CUSTOM,l,u,t,i,or,r]),this.hitDetectionInstructions.push([N.CUSTOM,l,u,t,s||i,or,r]);break;case"LineString":case"Circle":h=t.getFlatCoordinates(),c=this.appendFlatLineCoordinates(h,0,h.length,a,!1,!1),this.instructions.push([N.CUSTOM,l,c,t,i,tn,r]),this.hitDetectionInstructions.push([N.CUSTOM,l,c,t,s||i,tn,r]);break;case"MultiPoint":h=t.getFlatCoordinates(),c=this.appendFlatPointCoordinates(h,a),c>l&&(this.instructions.push([N.CUSTOM,l,c,t,i,tn,r]),this.hitDetectionInstructions.push([N.CUSTOM,l,c,t,s||i,tn,r]));break;case"Point":h=t.getFlatCoordinates(),this.coordinates.push(h[0],h[1]),c=this.coordinates.length,this.instructions.push([N.CUSTOM,l,c,t,i,void 0,r]),this.hitDetectionInstructions.push([N.CUSTOM,l,c,t,s||i,void 0,r]);break}this.endGeometry(e)}beginGeometry(t,e,i){this.beginGeometryInstruction1_=[N.BEGIN_GEOMETRY,e,0,t,i],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[N.BEGIN_GEOMETRY,e,0,t,i],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){const t=this.hitDetectionInstructions;t.reverse();let e;const i=t.length;let s,r,o=-1;for(e=0;e<i;++e)s=t[e],r=s[0],r==N.END_GEOMETRY?o=e:r==N.BEGIN_GEOMETRY&&(s[2]=e,kd(this.hitDetectionInstructions,o,e),o=-1)}fillStyleToState(t,e={}){if(t){const i=t.getColor();e.fillPatternScale=i&&typeof i=="object"&&"src"in i?this.pixelRatio:1,e.fillStyle=xe(i||Gt)}else e.fillStyle=void 0;return e}strokeStyleToState(t,e={}){if(t){const i=t.getColor();e.strokeStyle=xe(i||jn);const s=t.getLineCap();e.lineCap=s!==void 0?s:nn;const r=t.getLineDash();e.lineDash=r?r.slice():Fe;const o=t.getLineDashOffset();e.lineDashOffset=o||ke;const a=t.getLineJoin();e.lineJoin=a!==void 0?a:sn;const l=t.getWidth();e.lineWidth=l!==void 0?l:qn;const h=t.getMiterLimit();e.miterLimit=h!==void 0?h:Vn,e.lineWidth>this.maxLineWidth&&(this.maxLineWidth=e.lineWidth,this.bufferedMaxExtent_=null)}else e.strokeStyle=void 0,e.lineCap=void 0,e.lineDash=null,e.lineDashOffset=void 0,e.lineJoin=void 0,e.lineWidth=void 0,e.miterLimit=void 0;return e}setFillStrokeStyle(t,e){const i=this.state;this.fillStyleToState(t,i),this.strokeStyleToState(e,i)}createFill(t){const e=t.fillStyle,i=[N.SET_FILL_STYLE,e];return typeof e!="string"&&i.push(t.fillPatternScale),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[N.SET_STROKE_STYLE,t.strokeStyle,t.lineWidth*this.pixelRatio,t.lineCap,t.lineJoin,t.miterLimit,t.lineDash?this.applyPixelRatio(t.lineDash):null,t.lineDashOffset*this.pixelRatio]}updateFillStyle(t,e){const i=t.fillStyle;(typeof i!="string"||t.currentFillStyle!=i)&&(this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){const i=t.strokeStyle,s=t.lineCap,r=t.lineDash,o=t.lineDashOffset,a=t.lineJoin,l=t.lineWidth,h=t.miterLimit;(t.currentStrokeStyle!=i||t.currentLineCap!=s||r!=t.currentLineDash&&!ti(t.currentLineDash,r)||t.currentLineDashOffset!=o||t.currentLineJoin!=a||t.currentLineWidth!=l||t.currentMiterLimit!=h)&&(e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=s,t.currentLineDash=r,t.currentLineDashOffset=o,t.currentLineJoin=a,t.currentLineWidth=l,t.currentMiterLimit=h)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;const e=[N.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=Pl(this.maxExtent),this.maxLineWidth>0)){const t=this.resolution*(this.maxLineWidth+1)/2;eo(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}}class Qg extends ns{constructor(t,e,i,s){super(t,e,i,s),this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.anchorX_=void 0,this.anchorY_=void 0,this.height_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.scale_=void 0,this.width_=void 0,this.declutterMode_=void 0,this.declutterImageWithText_=void 0}drawPoint(t,e,i){if(!this.image_||this.maxExtent&&!Zi(this.maxExtent,t.getFlatCoordinates()))return;this.beginGeometry(t,e,i);const s=t.getFlatCoordinates(),r=t.getStride(),o=this.coordinates.length,a=this.appendFlatPointCoordinates(s,r);this.instructions.push([N.DRAW_IMAGE,o,a,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([N.DRAW_IMAGE,o,a,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,1,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}drawMultiPoint(t,e,i){if(!this.image_)return;this.beginGeometry(t,e,i);const s=t.getFlatCoordinates(),r=[];for(let l=0,h=s.length;l<h;l+=t.getStride())(!this.maxExtent||Zi(this.maxExtent,s.slice(l,l+2)))&&r.push(s[l],s[l+1]);const o=this.coordinates.length,a=this.appendFlatPointCoordinates(r,2);this.instructions.push([N.DRAW_IMAGE,o,a,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([N.DRAW_IMAGE,o,a,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,1,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}finish(){return this.reverseHitDetectionInstructions(),this.anchorX_=void 0,this.anchorY_=void 0,this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.height_=void 0,this.scale_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.width_=void 0,super.finish()}setImageStyle(t,e){const i=t.getAnchor(),s=t.getSize(),r=t.getOrigin();this.imagePixelRatio_=t.getPixelRatio(this.pixelRatio),this.anchorX_=i[0],this.anchorY_=i[1],this.hitDetectionImage_=t.getHitDetectionImage(),this.image_=t.getImage(this.pixelRatio),this.height_=s[1],this.opacity_=t.getOpacity(),this.originX_=r[0],this.originY_=r[1],this.rotateWithView_=t.getRotateWithView(),this.rotation_=t.getRotation(),this.scale_=t.getScaleArray(),this.width_=s[0],this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}}class t_ extends ns{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinates_(t,e,i,s){const r=this.coordinates.length,o=this.appendFlatLineCoordinates(t,e,i,s,!1,!1),a=[N.MOVE_TO_LINE_TO,r,o];return this.instructions.push(a),this.hitDetectionInstructions.push(a),i}drawLineString(t,e,i){const s=this.state,r=s.strokeStyle,o=s.lineWidth;if(r===void 0||o===void 0)return;this.updateStrokeStyle(s,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([N.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Fe,ke],Pi);const a=t.getFlatCoordinates(),l=t.getStride();this.drawFlatCoordinates_(a,0,a.length,l),this.hitDetectionInstructions.push(ai),this.endGeometry(e)}drawMultiLineString(t,e,i){const s=this.state,r=s.strokeStyle,o=s.lineWidth;if(r===void 0||o===void 0)return;this.updateStrokeStyle(s,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([N.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Fe,ke],Pi);const a=t.getEnds(),l=t.getFlatCoordinates(),h=t.getStride();let c=0;for(let u=0,d=a.length;u<d;++u)c=this.drawFlatCoordinates_(l,c,a[u],h);this.hitDetectionInstructions.push(ai),this.endGeometry(e)}finish(){const t=this.state;return t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&this.instructions.push(ai),this.reverseHitDetectionInstructions(),this.state=null,super.finish()}applyStroke(t){t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&(this.instructions.push(ai),t.lastStroke=this.coordinates.length),t.lastStroke=0,super.applyStroke(t),this.instructions.push(Pi)}}class oc extends ns{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinatess_(t,e,i,s){const r=this.state,o=r.fillStyle!==void 0,a=r.strokeStyle!==void 0,l=i.length;this.instructions.push(Pi),this.hitDetectionInstructions.push(Pi);for(let h=0;h<l;++h){const c=i[h],u=this.coordinates.length,d=this.appendFlatLineCoordinates(t,e,c,s,!0,!a),f=[N.MOVE_TO_LINE_TO,u,d];this.instructions.push(f),this.hitDetectionInstructions.push(f),a&&(this.instructions.push(rc),this.hitDetectionInstructions.push(rc)),e=c}return o&&(this.instructions.push(Er),this.hitDetectionInstructions.push(Er)),a&&(this.instructions.push(ai),this.hitDetectionInstructions.push(ai)),e}drawCircle(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_FILL_STYLE,Gt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Fe,ke]);const a=t.getFlatCoordinates(),l=t.getStride(),h=this.coordinates.length;this.appendFlatLineCoordinates(a,0,a.length,l,!1,!1);const c=[N.CIRCLE,h];this.instructions.push(Pi,c),this.hitDetectionInstructions.push(Pi,c),s.fillStyle!==void 0&&(this.instructions.push(Er),this.hitDetectionInstructions.push(Er)),s.strokeStyle!==void 0&&(this.instructions.push(ai),this.hitDetectionInstructions.push(ai)),this.endGeometry(e)}drawPolygon(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_FILL_STYLE,Gt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Fe,ke]);const a=t.getEnds(),l=t.getOrientedFlatCoordinates(),h=t.getStride();this.drawFlatCoordinatess_(l,0,a,h),this.endGeometry(e)}drawMultiPolygon(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_FILL_STYLE,Gt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([N.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Fe,ke]);const a=t.getEndss(),l=t.getOrientedFlatCoordinates(),h=t.getStride();let c=0;for(let u=0,d=a.length;u<d;++u)c=this.drawFlatCoordinatess_(l,c,a[u],h);this.endGeometry(e)}finish(){this.reverseHitDetectionInstructions(),this.state=null;const t=this.tolerance;if(t!==0){const e=this.coordinates;for(let i=0,s=e.length;i<s;++i)e[i]=Si(e[i],t)}return super.finish()}setFillStrokeStyles_(){const t=this.state;this.updateFillStyle(t,this.createFill),this.updateStrokeStyle(t,this.applyStroke)}}function e_(n,t,e,i,s){const r=[];let o=e,a=0,l=t.slice(e,2);for(;a<n&&o+s<i;){const[h,c]=l.slice(-2),u=t[o+s],d=t[o+s+1],f=Math.sqrt((u-h)*(u-h)+(d-c)*(d-c));if(a+=f,a>=n){const g=(n-a+f)/f,m=te(h,u,g),_=te(c,d,g);l.push(m,_),r.push(l),l=[m,_],a==n&&(o+=s),a=0}else if(a<n)l.push(t[o+s],t[o+s+1]),o+=s;else{const g=f-a,m=te(h,u,g/f),_=te(c,d,g/f);l.push(m,_),r.push(l),l=[m,_],a=0,o+=s}}return a>0&&r.push(l),r}function i_(n,t,e,i,s){let r=e,o=e,a=0,l=0,h=e,c,u,d,f,g,m,_,p,y,w;for(u=e;u<i;u+=s){const x=t[u],E=t[u+1];g!==void 0&&(y=x-g,w=E-m,f=Math.sqrt(y*y+w*w),_!==void 0&&(l+=d,c=Math.acos((_*y+p*w)/(d*f)),c>n&&(l>a&&(a=l,r=h,o=u),l=0,h=u-s)),d=f,_=y,p=w),g=x,m=E}return l+=f,l>a?[h,u]:[r,o]}const vr={left:0,center:.5,right:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1};class n_ extends ns{constructor(t,e,i,s){super(t,e,i,s),this.labels_=null,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=void 0,this.textKeepUpright_=void 0,this.textRotation_=0,this.textFillState_=null,this.fillStates={},this.fillStates[Gt]={fillStyle:Gt},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterMode_=void 0,this.declutterImageWithText_=void 0}finish(){const t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e,i){const s=this.textFillState_,r=this.textStrokeState_,o=this.textState_;if(this.text_===""||!o||!s&&!r)return;const a=this.coordinates;let l=a.length;const h=t.getType();let c=null,u=t.getStride();if(o.placement==="line"&&(h=="LineString"||h=="MultiLineString"||h=="Polygon"||h=="MultiPolygon")){if(!kt(this.maxExtent,t.getExtent()))return;let d;if(c=t.getFlatCoordinates(),h=="LineString")d=[c.length];else if(h=="MultiLineString")d=t.getEnds();else if(h=="Polygon")d=t.getEnds().slice(0,1);else if(h=="MultiPolygon"){const _=t.getEndss();d=[];for(let p=0,y=_.length;p<y;++p)d.push(_[p][0])}this.beginGeometry(t,e,i);const f=o.repeat,g=f?void 0:o.textAlign;let m=0;for(let _=0,p=d.length;_<p;++_){let y;f?y=e_(f*this.resolution,c,m,d[_],u):y=[c.slice(m,d[_])];for(let w=0,x=y.length;w<x;++w){const E=y[w];let T=0,I=E.length;if(g==null){const R=i_(o.maxAngle,E,0,E.length,2);T=R[0],I=R[1]}for(let R=T;R<I;R+=u)a.push(E[R],E[R+1]);const v=a.length;m=d[_],this.drawChars_(l,v),l=v}}this.endGeometry(e)}else{let d=o.overflow?null:[];switch(h){case"Point":case"MultiPoint":c=t.getFlatCoordinates();break;case"LineString":c=t.getFlatMidpoint();break;case"Circle":c=t.getCenter();break;case"MultiLineString":c=t.getFlatMidpoints(),u=2;break;case"Polygon":c=t.getFlatInteriorPoint(),o.overflow||d.push(c[2]/this.resolution),u=3;break;case"MultiPolygon":const x=t.getFlatInteriorPoints();c=[];for(let E=0,T=x.length;E<T;E+=3)o.overflow||d.push(x[E+2]/this.resolution),c.push(x[E],x[E+1]);if(c.length===0)return;u=2;break}const f=this.appendFlatPointCoordinates(c,u);if(f===l)return;if(d&&(f-l)/2!==c.length/u){let x=l/2;d=d.filter((E,T)=>{const I=a[(x+T)*2]===c[T*u]&&a[(x+T)*2+1]===c[T*u+1];return I||--x,I})}this.saveTextStates_();const g=o.backgroundFill?this.createFill(this.fillStyleToState(o.backgroundFill)):null,m=o.backgroundStroke?this.createStroke(this.strokeStyleToState(o.backgroundStroke)):null;this.beginGeometry(t,e,i);let _=o.padding;if(_!=Ai&&(o.scale[0]<0||o.scale[1]<0)){let x=o.padding[0],E=o.padding[1],T=o.padding[2],I=o.padding[3];o.scale[0]<0&&(E=-E,I=-I),o.scale[1]<0&&(x=-x,T=-T),_=[x,E,T,I]}const p=this.pixelRatio;this.instructions.push([N.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,this.declutterMode_,this.declutterImageWithText_,_==Ai?Ai:_.map(function(x){return x*p}),g,m,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]);const y=1/p,w=g?g.slice(0):null;w&&(w[1]=Gt),this.hitDetectionInstructions.push([N.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[y,y],NaN,this.declutterMode_,this.declutterImageWithText_,_,w,m,this.text_,this.textKey_,this.strokeKey_,this.fillKey_?Gt:this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]),this.endGeometry(e)}}saveTextStates_(){const t=this.textStrokeState_,e=this.textState_,i=this.textFillState_,s=this.strokeKey_;t&&(s in this.strokeStates||(this.strokeStates[s]={strokeStyle:t.strokeStyle,lineCap:t.lineCap,lineDashOffset:t.lineDashOffset,lineWidth:t.lineWidth,lineJoin:t.lineJoin,miterLimit:t.miterLimit,lineDash:t.lineDash}));const r=this.textKey_;r in this.textStates||(this.textStates[r]={font:e.font,textAlign:e.textAlign||Hn,justify:e.justify,textBaseline:e.textBaseline||gr,scale:e.scale});const o=this.fillKey_;i&&(o in this.fillStates||(this.fillStates[o]={fillStyle:i.fillStyle}))}drawChars_(t,e){const i=this.textStrokeState_,s=this.textState_,r=this.strokeKey_,o=this.textKey_,a=this.fillKey_;this.saveTextStates_();const l=this.pixelRatio,h=vr[s.textBaseline],c=this.textOffsetY_*l,u=this.text_,d=i?i.lineWidth*Math.abs(s.scale[0])/2:0;this.instructions.push([N.DRAW_CHARS,t,e,h,s.overflow,a,s.maxAngle,l,c,r,d*l,u,o,1,this.declutterMode_,this.textKeepUpright_]),this.hitDetectionInstructions.push([N.DRAW_CHARS,t,e,h,s.overflow,a&&Gt,s.maxAngle,l,c,r,d*l,u,o,1/l,this.declutterMode_,this.textKeepUpright_])}setTextStyle(t,e){let i,s,r;if(!t)this.text_="";else{const o=t.getFill();o?(s=this.textFillState_,s||(s={},this.textFillState_=s),s.fillStyle=xe(o.getColor()||Gt)):(s=null,this.textFillState_=s);const a=t.getStroke();if(!a)r=null,this.textStrokeState_=r;else{r=this.textStrokeState_,r||(r={},this.textStrokeState_=r);const m=a.getLineDash(),_=a.getLineDashOffset(),p=a.getWidth(),y=a.getMiterLimit();r.lineCap=a.getLineCap()||nn,r.lineDash=m?m.slice():Fe,r.lineDashOffset=_===void 0?ke:_,r.lineJoin=a.getLineJoin()||sn,r.lineWidth=p===void 0?qn:p,r.miterLimit=y===void 0?Vn:y,r.strokeStyle=xe(a.getColor()||jn)}i=this.textState_;const l=t.getFont()||Nh;wg(l);const h=t.getScaleArray();i.overflow=t.getOverflow(),i.font=l,i.maxAngle=t.getMaxAngle(),i.placement=t.getPlacement(),i.textAlign=t.getTextAlign(),i.repeat=t.getRepeat(),i.justify=t.getJustify(),i.textBaseline=t.getTextBaseline()||gr,i.backgroundFill=t.getBackgroundFill(),i.backgroundStroke=t.getBackgroundStroke(),i.padding=t.getPadding()||Ai,i.scale=h===void 0?[1,1]:h;const c=t.getOffsetX(),u=t.getOffsetY(),d=t.getRotateWithView(),f=t.getKeepUpright(),g=t.getRotation();this.text_=t.getText()||"",this.textOffsetX_=c===void 0?0:c,this.textOffsetY_=u===void 0?0:u,this.textRotateWithView_=d===void 0?!1:d,this.textKeepUpright_=f===void 0?!0:f,this.textRotation_=g===void 0?0:g,this.strokeKey_=r?(typeof r.strokeStyle=="string"?r.strokeStyle:j(r.strokeStyle))+r.lineCap+r.lineDashOffset+"|"+r.lineWidth+r.lineJoin+r.miterLimit+"["+r.lineDash.join()+"]":"",this.textKey_=i.font+i.scale+(i.textAlign||"?")+(i.repeat||"?")+(i.justify||"?")+(i.textBaseline||"?"),this.fillKey_=s&&s.fillStyle?typeof s.fillStyle=="string"?s.fillStyle:"|"+j(s.fillStyle):""}this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}}const s_={Circle:oc,Default:ns,Image:Qg,LineString:t_,Polygon:oc,Text:n_};class r_{constructor(t,e,i,s){this.tolerance_=t,this.maxExtent_=e,this.pixelRatio_=s,this.resolution_=i,this.buildersByZIndex_={}}finish(){const t={};for(const e in this.buildersByZIndex_){t[e]=t[e]||{};const i=this.buildersByZIndex_[e];for(const s in i){const r=i[s].finish();t[e][s]=r}}return t}getBuilder(t,e){const i=t!==void 0?t.toString():"0";let s=this.buildersByZIndex_[i];s===void 0&&(s={},this.buildersByZIndex_[i]=s);let r=s[e];if(r===void 0){const o=s_[e];r=new o(this.tolerance_,this.maxExtent_,this.resolution_,this.pixelRatio_),s[e]=r}return r}}function o_(n,t,e,i,s,r,o,a,l,h,c,u,d=!0){let f=n[t],g=n[t+1],m=0,_=0,p=0,y=0;function w(){m=f,_=g,t+=i,f=n[t],g=n[t+1],y+=p,p=Math.sqrt((f-m)*(f-m)+(g-_)*(g-_))}do w();while(t<e-i&&y+p<r);let x=p===0?0:(r-y)/p;const E=te(m,f,x),T=te(_,g,x),I=t-i,v=y,R=r+a*l(h,s,c);for(;t<e-i&&y+p<R;)w();x=p===0?0:(R-y)/p;const b=te(m,f,x),O=te(_,g,x);let F=!1;if(d)if(u){const X=[E,T,b,O];hh(X,0,4,2,u,X,X),F=X[0]>X[2]}else F=E>b;const A=Math.PI,L=[],M=I+i===t;t=I,p=0,y=v,f=n[t],g=n[t+1];let P;if(M){w(),P=Math.atan2(g-_,f-m),F&&(P+=P>0?-A:A);const X=(b+E)/2,D=(O+T)/2;return L[0]=[X,D,(R-r)/2,P,s],L}s=s.replace(/\n/g," ");for(let X=0,D=s.length;X<D;){w();let k=Math.atan2(g-_,f-m);if(F&&(k+=k>0?-A:A),P!==void 0){let st=k-P;if(st+=st>A?-2*A:st<-A?2*A:0,Math.abs(st)>o)return null}P=k;const K=X;let J=0;for(;X<D;++X){const st=F?D-X-1:X,_t=a*l(h,s[st],c);if(t+i<e&&y+p<r+J+_t/2)break;J+=_t}if(X===K)continue;const S=F?s.substring(D-K,D-X):s.substring(K,X);x=p===0?0:(r+J/2-y)/p;const gt=te(m,f,x),xt=te(_,g,x);L.push([gt,xt,J/2,k,S]),r+=J}return L}class ac{constructor(){this.instructions_=[],this.zIndex=0,this.offset_=0,this.context_=new Proxy(lr(),{get:(t,e)=>{if(typeof lr()[e]=="function")return this.push_(e),this.pushMethodArgs_},set:(t,e,i)=>(this.push_(e,i),!0)})}push_(...t){const e=this.instructions_,i=this.zIndex+this.offset_;e[i]||(e[i]=[]),e[i].push(...t)}pushMethodArgs_=(...t)=>(this.push_(t),this);pushFunction(t){this.push_(t)}getContext(){return this.context_}draw(t){this.instructions_.forEach(e=>{for(let i=0,s=e.length;i<s;++i){const r=e[i];if(typeof r=="function"){r(t);continue}const o=e[++i];if(typeof t[r]=="function")t[r](...o);else{if(typeof o=="function"){t[r]=o(t);continue}t[r]=o}}})}clear(){this.instructions_.length=0,this.zIndex=0,this.offset_=0}offset(){this.offset_=this.instructions_.length,this.zIndex=0}}const ln=Kt(),li=[],Ne=[],Ge=[],hi=[];function lc(n){return n[3].declutterBox}const hc=new RegExp("[֑-ࣿיִ-﷿ﹰ-ﻼࠀ--]");function Zo(n,t){return t==="start"?t=hc.test(n)?"right":"left":t==="end"&&(t=hc.test(n)?"left":"right"),vr[t]}function a_(n,t,e){return e>0&&n.push(`
|
|
5
|
-
`,""),n.push(t,""),n}function
|
|
6
|
-
`).reduce(
|
|
7
|
-
`){A+=F,F=0,R=u*w+v*d,++M;continue}const K=f[X+1]||l.font;K!==P&&(s&&b.push("font",K),i&&O.push("font",K),P=K),F=Math.max(F,p[L]);const J=[k,R+v*_[L]+u*(_[L]-y[M]),.5*(d+F)+A];R+=_[L],s&&b.push("strokeText",J),i&&O.push("fillText",J),++L}return Array.prototype.push.apply(x,b),Array.prototype.push.apply(x,O),this.labels_[r]=I,I}replayTextBackground_(t,e,i,s,r,o,a){t.beginPath(),t.moveTo.apply(t,e),t.lineTo.apply(t,i),t.lineTo.apply(t,s),t.lineTo.apply(t,r),t.lineTo.apply(t,e),o&&(this.alignAndScaleFill_=o[2],t.fillStyle=o[1],this.fill_(t)),a&&(this.setStrokeStyle_(t,a),t.stroke())}calculateImageOrLabelDimensions_(t,e,i,s,r,o,a,l,h,c,u,d,f,g,m,_){a*=d[0],l*=d[1];let p=i-a,y=s-l;const w=r+h>t?t-h:r,x=o+c>e?e-c:o,E=g[3]+w*d[0]+g[1],T=g[0]+x*d[1]+g[2],I=p-g[3],v=y-g[0];(m||u!==0)&&(li[0]=I,hi[0]=I,li[1]=v,Ne[1]=v,Ne[0]=I+E,Ge[0]=Ne[0],Ge[1]=v+T,hi[1]=Ge[1]);let R;return u!==0?(R=De(fe(),i,s,1,1,u,-i,-s),ft(R,li),ft(R,Ne),ft(R,Ge),ft(R,hi),ei(Math.min(li[0],Ne[0],Ge[0],hi[0]),Math.min(li[1],Ne[1],Ge[1],hi[1]),Math.max(li[0],Ne[0],Ge[0],hi[0]),Math.max(li[1],Ne[1],Ge[1],hi[1]),ln)):ei(Math.min(I,I+E),Math.min(v,v+T),Math.max(I,I+E),Math.max(v,v+T),ln),f&&(p=Math.round(p),y=Math.round(y)),{drawImageX:p,drawImageY:y,drawImageW:w,drawImageH:x,originX:h,originY:c,declutterBox:{minX:ln[0],minY:ln[1],maxX:ln[2],maxY:ln[3],value:_},canvasTransform:R,scale:d}}replayImageOrLabel_(t,e,i,s,r,o,a){const l=!!(o||a),h=s.declutterBox,c=a?a[2]*s.scale[0]/2:0;return h.minX-c<=e[0]&&h.maxX+c>=0&&h.minY-c<=e[1]&&h.maxY+c>=0&&(l&&this.replayTextBackground_(t,li,Ne,Ge,hi,o,a),Tg(t,s.canvasTransform,r,i,s.originX,s.originY,s.drawImageW,s.drawImageH,s.drawImageX,s.drawImageY,s.scale)),!0}fill_(t){const e=this.alignAndScaleFill_;if(e){const i=ft(this.renderedTransform_,[0,0]),s=512*this.pixelRatio;t.save(),t.translate(i[0]%s,i[1]%s),e!==1&&t.scale(e,e),t.rotate(this.viewRotation_)}t.fill(),e&&t.restore()}setStrokeStyle_(t,e){t.strokeStyle=e[1],e[1]&&(t.lineWidth=e[2],t.lineCap=e[3],t.lineJoin=e[4],t.miterLimit=e[5],t.lineDashOffset=e[7],t.setLineDash(e[6]))}drawLabelWithPointPlacement_(t,e,i,s){const r=this.textStates[e],o=this.createLabel(t,e,s,i),a=this.strokeStates[i],l=this.pixelRatio,h=Zo(Array.isArray(t)?t[0]:t,r.textAlign||Hn),c=vr[r.textBaseline||gr],u=a&&a.lineWidth?a.lineWidth:0,d=o.width/l-2*r.scale[0],f=h*d+2*(.5-h)*u,g=c*o.height/l+2*(.5-c)*u;return{label:o,anchorX:f,anchorY:g}}execute_(t,e,i,s,r,o,a,l){const h=this.zIndexContext_;let c;this.pixelCoordinates_&&ti(i,this.renderedTransform_)?c=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),c=si(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),Sf(this.renderedTransform_,i));let u=0;const d=s.length;let f=0,g,m,_,p,y,w,x,E,T,I,v,R,b,O=0,F=0;const A=this.coordinateCache_,L=this.viewRotation_,M=Math.round(Math.atan2(-i[1],i[0])*1e12)/1e12,P={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:L},X=this.instructions!=s||this.overlaps?0:200;let D,k,K,J;for(;u<d;){const S=s[u];switch(S[0]){case N.BEGIN_GEOMETRY:D=S[1],J=S[3],D.getGeometry()?a!==void 0&&!kt(a,J.getExtent())?u=S[2]+1:++u:u=S[2],h&&(h.zIndex=S[4]);break;case N.BEGIN_PATH:O>X&&(this.fill_(t),O=0),F>X&&(t.stroke(),F=0),!O&&!F&&(t.beginPath(),y=NaN,w=NaN),++u;break;case N.CIRCLE:f=S[1];const xt=c[f],st=c[f+1],_t=c[f+2],ht=c[f+3],Pt=_t-xt,Rt=ht-st,Zt=Math.sqrt(Pt*Pt+Rt*Rt);t.moveTo(xt+Zt,st),t.arc(xt,st,Zt,0,2*Math.PI,!0),++u;break;case N.CLOSE_PATH:t.closePath(),++u;break;case N.CUSTOM:f=S[1],g=S[2];const Or=S[3],wa=S[4],gs=S[5];P.geometry=Or,P.feature=D,u in A||(A[u]=[]);const Ni=A[u];gs?gs(c,f,g,2,Ni):(Ni[0]=c[f],Ni[1]=c[f+1],Ni.length=2),h&&(h.zIndex=S[6]),wa(Ni,P),++u;break;case N.DRAW_IMAGE:f=S[1],g=S[2],T=S[3],m=S[4],_=S[5];let re=S[6];const Ce=S[7],En=S[8],vn=S[9],_s=S[10];let Gi=S[11];const wn=S[12];let Cn=S[13];p=S[14]||"declutter";const mt=S[15];if(!T&&S.length>=20){I=S[19],v=S[20],R=S[21],b=S[22];const oe=this.drawLabelWithPointPlacement_(I,v,R,b);T=oe.label,S[3]=T;const zi=S[23];m=(oe.anchorX-zi)*this.pixelRatio,S[4]=m;const ae=S[24];_=(oe.anchorY-ae)*this.pixelRatio,S[5]=_,re=T.height,S[6]=re,Cn=T.width,S[13]=Cn}let Ca;S.length>25&&(Ca=S[25]);let Ra,Dr,Fr;S.length>17?(Ra=S[16],Dr=S[17],Fr=S[18]):(Ra=Ai,Dr=null,Fr=null),_s&&M?Gi+=L:!_s&&!M&&(Gi-=L);let kp=0;for(;f<g;f+=2){if(Ca&&Ca[kp++]<Cn/this.pixelRatio)continue;const oe=this.calculateImageOrLabelDimensions_(T.width,T.height,c[f],c[f+1],Cn,re,m,_,En,vn,Gi,wn,r,Ra,!!Dr||!!Fr,D),zi=[t,e,T,oe,Ce,Dr,Fr];if(l){let ae,Re,le;if(mt){const lt=g-f;if(!mt[lt]){mt[lt]={args:zi,declutterMode:p};continue}const Ot=mt[lt];ae=Ot.args,Re=Ot.declutterMode,delete mt[lt],le=lc(ae)}let Ye,$e;if(ae&&(Re!=="declutter"||!l.collides(le))&&(Ye=!0),(p!=="declutter"||!l.collides(oe.declutterBox))&&($e=!0),Re==="declutter"&&p==="declutter"){const lt=Ye&&$e;Ye=lt,$e=lt}Ye&&(Re!=="none"&&l.insert(le),this.replayImageOrLabel_.apply(this,ae)),$e&&(p!=="none"&&l.insert(oe.declutterBox),this.replayImageOrLabel_.apply(this,zi))}else this.replayImageOrLabel_.apply(this,zi)}++u;break;case N.DRAW_CHARS:const ru=S[1],ou=S[2],Ta=S[3],Np=S[4];b=S[5];const Gp=S[6],au=S[7],lu=S[8];R=S[9];const Ia=S[10];I=S[11],Array.isArray(I)&&(I=I.reduce(l_,"")),v=S[12];const hu=[S[13],S[13]];p=S[14]||"declutter";const zp=S[15],Sa=this.textStates[v],ms=Sa.font,ps=[Sa.scale[0]*au,Sa.scale[1]*au];let ys;ms in this.widths_?ys=this.widths_[ms]:(ys={},this.widths_[ms]=ys);const cu=Jf(c,ru,ou,2),uu=Math.abs(ps[0])*Wh(ms,I,ys);if(Np||uu<=cu){const oe=this.textStates[v].textAlign,zi=(cu-uu)*Zo(I,oe),ae=o_(c,ru,ou,2,I,zi,Gp,Math.abs(ps[0]),Wh,ms,ys,M?0:this.viewRotation_,zp);t:if(ae){const Re=[];let le,Ye,$e,lt,Ot;if(R)for(le=0,Ye=ae.length;le<Ye;++le){Ot=ae[le],$e=Ot[4],lt=this.createLabel($e,v,"",R),m=Ot[2]+(ps[0]<0?-Ia:Ia),_=Ta*lt.height+(.5-Ta)*2*Ia*ps[1]/ps[0]-lu;const Ke=this.calculateImageOrLabelDimensions_(lt.width,lt.height,Ot[0],Ot[1],lt.width,lt.height,m,_,0,0,Ot[3],hu,!1,Ai,!1,D);if(l&&p==="declutter"&&l.collides(Ke.declutterBox))break t;Re.push([t,e,lt,Ke,1,null,null])}if(b)for(le=0,Ye=ae.length;le<Ye;++le){Ot=ae[le],$e=Ot[4],lt=this.createLabel($e,v,b,""),m=Ot[2],_=Ta*lt.height-lu;const Ke=this.calculateImageOrLabelDimensions_(lt.width,lt.height,Ot[0],Ot[1],lt.width,lt.height,m,_,0,0,Ot[3],hu,!1,Ai,!1,D);if(l&&p==="declutter"&&l.collides(Ke.declutterBox))break t;Re.push([t,e,lt,Ke,1,null,null])}l&&p!=="none"&&l.load(Re.map(lc));for(let Ke=0,Xp=Re.length;Ke<Xp;++Ke)this.replayImageOrLabel_.apply(this,Re[Ke])}}++u;break;case N.END_GEOMETRY:if(o!==void 0){D=S[1];const oe=o(D,J,p);if(oe)return oe}++u;break;case N.FILL:X?O++:this.fill_(t),++u;break;case N.MOVE_TO_LINE_TO:for(f=S[1],g=S[2],k=c[f],K=c[f+1],t.moveTo(k,K),y=k+.5|0,w=K+.5|0,f+=2;f<g;f+=2)k=c[f],K=c[f+1],x=k+.5|0,E=K+.5|0,(f==g-2||x!==y||E!==w)&&(t.lineTo(k,K),y=x,w=E);++u;break;case N.SET_FILL_STYLE:this.alignAndScaleFill_=S[2],O&&(this.fill_(t),O=0,F&&(t.stroke(),F=0)),t.fillStyle=S[1],++u;break;case N.SET_STROKE_STYLE:F&&(t.stroke(),F=0),this.setStrokeStyle_(t,S),++u;break;case N.STROKE:X?F++:t.stroke(),++u;break;default:++u;break}}O&&this.fill_(t),F&&t.stroke()}execute(t,e,i,s,r,o){this.viewRotation_=s,this.execute_(t,e,i,this.instructions,r,void 0,void 0,o)}executeHitDetection(t,e,i,s,r){return this.viewRotation_=i,this.execute_(t,[t.canvas.width,t.canvas.height],e,this.hitDetectionInstructions,!0,s,r)}}const Oi=["Polygon","Circle","LineString","Image","Text","Default"],cc=["Image","Text"],c_=Oi.filter(n=>!cc.includes(n));class u_{constructor(t,e,i,s,r,o,a){this.maxExtent_=t,this.overlaps_=s,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=o,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=fe(),this.renderedContext_=null,this.deferredZIndexContexts_={},this.createExecutors_(r,a)}clip(t,e){const i=this.getClipCoords(e);t.beginPath(),t.moveTo(i[0],i[1]),t.lineTo(i[2],i[3]),t.lineTo(i[4],i[5]),t.lineTo(i[6],i[7]),t.clip()}createExecutors_(t,e){for(const i in t){let s=this.executorsByZIndex_[i];s===void 0&&(s={},this.executorsByZIndex_[i]=s);const r=t[i];for(const o in r){const a=r[o];s[o]=new h_(this.resolution_,this.pixelRatio_,this.overlaps_,a,e)}}}hasExecutors(t){for(const e in this.executorsByZIndex_){const i=this.executorsByZIndex_[e];for(let s=0,r=t.length;s<r;++s)if(t[s]in i)return!0}return!1}forEachFeatureAtCoordinate(t,e,i,s,r,o){s=Math.round(s);const a=s*2+1,l=De(this.hitDetectionTransform_,s+.5,s+.5,1/e,-1/e,-i,-t[0],-t[1]),h=!this.hitDetectionContext_;h&&(this.hitDetectionContext_=ct(a,a));const c=this.hitDetectionContext_;c.canvas.width!==a||c.canvas.height!==a?(c.canvas.width=a,c.canvas.height=a):h||c.clearRect(0,0,a,a);let u;this.renderBuffer_!==void 0&&(u=Kt(),zn(u,t),eo(u,e*(this.renderBuffer_+s),u));const d=d_(s);let f;function g(E,T,I){const v=c.getImageData(0,0,a,a).data;for(let R=0,b=d.length;R<b;R++)if(v[d[R]]>0){if(!o||I==="none"||f!=="Image"&&f!=="Text"||o.includes(E)){const O=(d[R]-3)/4,F=s-O%a,A=s-(O/a|0),L=r(E,T,F*F+A*A);if(L)return L}c.clearRect(0,0,a,a);break}}const m=Object.keys(this.executorsByZIndex_).map(Number);m.sort(Me);let _,p,y,w,x;for(_=m.length-1;_>=0;--_){const E=m[_].toString();for(y=this.executorsByZIndex_[E],p=Oi.length-1;p>=0;--p)if(f=Oi[p],w=y[f],w!==void 0&&(x=w.executeHitDetection(c,l,i,g,u),x))return x}}getClipCoords(t){const e=this.maxExtent_;if(!e)return null;const i=e[0],s=e[1],r=e[2],o=e[3],a=[i,s,i,o,r,o,r,s];return si(a,0,8,2,t,a),a}isEmpty(){return Bi(this.executorsByZIndex_)}execute(t,e,i,s,r,o,a){const l=Object.keys(this.executorsByZIndex_).map(Number);l.sort(a?Fd:Me),o=o||Oi;const h=Oi.length;for(let c=0,u=l.length;c<u;++c){const d=l[c].toString(),f=this.executorsByZIndex_[d];for(let g=0,m=o.length;g<m;++g){const _=o[g],p=f[_];if(p!==void 0){const y=a===null?void 0:p.getZIndexContext(),w=y?y.getContext():t,x=this.maxExtent_&&_!=="Image"&&_!=="Text";if(x&&(w.save(),this.clip(w,i)),!y||_==="Text"||_==="Image"?p.execute(w,e,i,s,r,a):y.pushFunction(E=>p.execute(E,e,i,s,r,a)),x&&w.restore(),y){y.offset();const E=l[c]*h+Oi.indexOf(_);this.deferredZIndexContexts_[E]||(this.deferredZIndexContexts_[E]=[]),this.deferredZIndexContexts_[E].push(y)}}}}this.renderedContext_=t}getDeferredZIndexContexts(){return this.deferredZIndexContexts_}getRenderedContext(){return this.renderedContext_}renderDeferred(){const t=this.deferredZIndexContexts_,e=Object.keys(t).map(Number).sort(Me);for(let i=0,s=e.length;i<s;++i)t[e[i]].forEach(r=>{r.draw(this.renderedContext_),r.clear()}),t[e[i]].length=0}}const Uo={};function d_(n){if(Uo[n]!==void 0)return Uo[n];const t=n*2+1,e=n*n,i=new Array(e+1);for(let r=0;r<=n;++r)for(let o=0;o<=n;++o){const a=r*r+o*o;if(a>e)break;let l=i[a];l||(l=[],i[a]=l),l.push(((n+r)*t+(n+o))*4+3),r>0&&l.push(((n-r)*t+(n+o))*4+3),o>0&&(l.push(((n+r)*t+(n-o))*4+3),r>0&&l.push(((n-r)*t+(n-o))*4+3))}const s=[];for(let r=0,o=i.length;r<o;++r)i[r]&&s.push(...i[r]);return Uo[n]=s,s}function uc(n,t,e,i){return e!==void 0&&i!==void 0?[e/n,i/t]:e!==void 0?e/n:i!==void 0?i/t:1}class hn extends pr{constructor(t){t=t||{};const e=t.opacity!==void 0?t.opacity:1,i=t.rotation!==void 0?t.rotation:0,s=t.scale!==void 0?t.scale:1,r=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:e,rotation:i,scale:s,displacement:t.displacement!==void 0?t.displacement:[0,0],rotateWithView:r,declutterMode:t.declutterMode}),this.anchor_=t.anchor!==void 0?t.anchor:[.5,.5],this.normalizedAnchor_=null,this.anchorOrigin_=t.anchorOrigin!==void 0?t.anchorOrigin:"top-left",this.anchorXUnits_=t.anchorXUnits!==void 0?t.anchorXUnits:"fraction",this.anchorYUnits_=t.anchorYUnits!==void 0?t.anchorYUnits:"fraction",this.crossOrigin_=t.crossOrigin!==void 0?t.crossOrigin:null;const o=t.img!==void 0?t.img:null;let a=t.src;Q(!(a!==void 0&&o),"`image` and `src` cannot be provided at the same time"),(a===void 0||a.length===0)&&o&&(a=o.src||j(o)),Q(a!==void 0&&a.length>0,"A defined and non-empty `src` or `image` must be provided"),Q(!((t.width!==void 0||t.height!==void 0)&&t.scale!==void 0),"`width` or `height` cannot be provided together with `scale`");let l;if(t.src!==void 0?l=Y.IDLE:o!==void 0&&("complete"in o?o.complete?l=o.src?Y.LOADED:Y.IDLE:l=Y.LOADING:l=Y.LOADED),this.color_=t.color!==void 0?en(t.color):null,this.iconImage_=ur(o,a,this.crossOrigin_,l,this.color_),this.offset_=t.offset!==void 0?t.offset:[0,0],this.offsetOrigin_=t.offsetOrigin!==void 0?t.offsetOrigin:"top-left",this.origin_=null,this.size_=t.size!==void 0?t.size:null,this.initialOptions_,t.width!==void 0||t.height!==void 0){let h,c;if(t.size)[h,c]=t.size;else{const u=this.getImage(1);if(u.width&&u.height)h=u.width,c=u.height;else if(u instanceof HTMLImageElement){this.initialOptions_=t;const d=()=>{if(this.unlistenImageChange(d),!this.initialOptions_)return;const f=this.iconImage_.getSize();this.setScale(uc(f[0],f[1],t.width,t.height))};this.listenImageChange(d);return}}h!==void 0&&this.setScale(uc(h,c,t.width,t.height))}}clone(){let t,e,i;return this.initialOptions_?(e=this.initialOptions_.width,i=this.initialOptions_.height):(t=this.getScale(),t=Array.isArray(t)?t.slice():t),new hn({anchor:this.anchor_.slice(),anchorOrigin:this.anchorOrigin_,anchorXUnits:this.anchorXUnits_,anchorYUnits:this.anchorYUnits_,color:this.color_&&this.color_.slice?this.color_.slice():this.color_||void 0,crossOrigin:this.crossOrigin_,offset:this.offset_.slice(),offsetOrigin:this.offsetOrigin_,opacity:this.getOpacity(),rotateWithView:this.getRotateWithView(),rotation:this.getRotation(),scale:t,width:e,height:i,size:this.size_!==null?this.size_.slice():void 0,src:this.getSrc(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getAnchor(){let t=this.normalizedAnchor_;if(!t){t=this.anchor_;const s=this.getSize();if(this.anchorXUnits_=="fraction"||this.anchorYUnits_=="fraction"){if(!s)return null;t=this.anchor_.slice(),this.anchorXUnits_=="fraction"&&(t[0]*=s[0]),this.anchorYUnits_=="fraction"&&(t[1]*=s[1])}if(this.anchorOrigin_!="top-left"){if(!s)return null;t===this.anchor_&&(t=this.anchor_.slice()),(this.anchorOrigin_=="top-right"||this.anchorOrigin_=="bottom-right")&&(t[0]=-t[0]+s[0]),(this.anchorOrigin_=="bottom-left"||this.anchorOrigin_=="bottom-right")&&(t[1]=-t[1]+s[1])}this.normalizedAnchor_=t}const e=this.getDisplacement(),i=this.getScaleArray();return[t[0]-e[0]/i[0],t[1]+e[1]/i[1]]}setAnchor(t){this.anchor_=t,this.normalizedAnchor_=null}getColor(){return this.color_}getImage(t){return this.iconImage_.getImage(t)}getPixelRatio(t){return this.iconImage_.getPixelRatio(t)}getImageSize(){return this.iconImage_.getSize()}getImageState(){return this.iconImage_.getImageState()}getHitDetectionImage(){return this.iconImage_.getHitDetectionImage()}getOrigin(){if(this.origin_)return this.origin_;let t=this.offset_;if(this.offsetOrigin_!="top-left"){const e=this.getSize(),i=this.iconImage_.getSize();if(!e||!i)return null;t=t.slice(),(this.offsetOrigin_=="top-right"||this.offsetOrigin_=="bottom-right")&&(t[0]=i[0]-e[0]-t[0]),(this.offsetOrigin_=="bottom-left"||this.offsetOrigin_=="bottom-right")&&(t[1]=i[1]-e[1]-t[1])}return this.origin_=t,this.origin_}getSrc(){return this.iconImage_.getSrc()}setSrc(t){this.iconImage_=ur(null,t,this.crossOrigin_,Y.IDLE,this.color_)}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){const t=this.getScaleArray();if(this.size_)return this.size_[0]*t[0];if(this.iconImage_.getImageState()==Y.LOADED)return this.iconImage_.getSize()[0]*t[0]}getHeight(){const t=this.getScaleArray();if(this.size_)return this.size_[1]*t[1];if(this.iconImage_.getImageState()==Y.LOADED)return this.iconImage_.getSize()[1]*t[1]}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(W.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(W.CHANGE,t)}ready(){return this.iconImage_.ready()}}const ve=.5;function f_(n,t,e,i,s,r,o,a,l){const h=s,c=n[0]*ve,u=n[1]*ve,d=ct(c,u);d.imageSmoothingEnabled=!1;const f=d.canvas,g=new Sg(d,ve,s,null,o,a,null),m=e.length,_=Math.floor((256*256*256-1)/m),p={};for(let w=1;w<=m;++w){const x=e[w-1],E=x.getStyleFunction()||i;if(!E)continue;let T=E(x,r);if(!T)continue;Array.isArray(T)||(T=[T]);const v=(w*_).toString(16).padStart(7,"#00000");for(let R=0,b=T.length;R<b;++R){const O=T[R],F=O.getGeometryFunction()(x);if(!F||!kt(h,F.getExtent()))continue;const A=O.clone(),L=A.getFill();L&&L.setColor(v);const M=A.getStroke();M&&(M.setColor(v),M.setLineDash(null)),A.setText(void 0);const P=O.getImage();if(P){const K=P.getImageSize();if(!K)continue;const J=ct(K[0],K[1],void 0,{alpha:!1}),S=J.canvas;J.fillStyle=v,J.fillRect(0,0,S.width,S.height),A.setImage(new hn({img:S,anchor:P.getAnchor(),anchorXUnits:"pixels",anchorYUnits:"pixels",offset:P.getOrigin(),opacity:1,size:P.getSize(),scale:P.getScale(),rotation:P.getRotation(),rotateWithView:P.getRotateWithView()}))}const X=A.getZIndex()||0;let D=p[X];D||(D={},p[X]=D,D.Polygon=[],D.Circle=[],D.LineString=[],D.Point=[]);const k=F.getType();if(k==="GeometryCollection"){const K=F.getGeometriesArrayRecursive();for(let J=0,S=K.length;J<S;++J){const gt=K[J];D[gt.getType().replace("Multi","")].push(gt,A)}}else D[k.replace("Multi","")].push(F,A)}}const y=Object.keys(p).map(Number).sort(Me);for(let w=0,x=y.length;w<x;++w){const E=p[y[w]];for(const T in E){const I=E[T];for(let v=0,R=I.length;v<R;v+=2){g.setStyle(I[v+1]);for(let b=0,O=t.length;b<O;++b)g.setTransform(t[b]),g.drawGeometry(I[v])}}}return d.getImageData(0,0,f.width,f.height)}function g_(n,t,e){const i=[];if(e){const s=Math.floor(Math.round(n[0])*ve),r=Math.floor(Math.round(n[1])*ve),o=(ot(s,0,e.width-1)+ot(r,0,e.height-1)*e.width)*4,a=e.data[o],l=e.data[o+1],c=e.data[o+2]+256*(l+256*a),u=Math.floor((256*256*256-1)/t.length);c&&c%u===0&&i.push(t[c/u-1])}return i}class dc extends Pe{constructor(t,e,i,s){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=s}}const __=5;class m_ extends Nn{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.staleKeys_=new Array,this.maxStaleKeys=__}getStaleKeys(){return this.staleKeys_}prependStaleKey(t){this.staleKeys_.unshift(t),this.staleKeys_.length>this.maxStaleKeys&&(this.staleKeys_.length=this.maxStaleKeys)}getFeatures(t){return V()}getData(t){return null}prepareFrame(t){return V()}renderFrame(t,e){return V()}forEachFeatureAtCoordinate(t,e,i,s,r){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){const e=t.target;(e.getState()===Y.LOADED||e.getState()===Y.ERROR)&&this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=Y.LOADED&&e!=Y.ERROR&&t.addEventListener(W.CHANGE,this.boundHandleImageChange_),e==Y.IDLE&&(t.load(),e=t.getState()),e==Y.LOADED}renderIfReadyAndVisible(){const t=this.getLayer();t&&t.getVisible()&&t.getSourceState()==="ready"&&t.changed()}renderDeferred(t){}disposeInternal(){delete this.layer_,super.disposeInternal()}}const fc=[];let cn=null;function p_(){cn=ct(1,1,void 0,{willReadFrequently:!0})}class gc extends m_{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=fe(),this.pixelTransform=fe(),this.inversePixelTransform=fe(),this.context=null,this.deferredContext_=null,this.containerReused=!1,this.frameState=null}getImageData(t,e,i){cn||p_(),cn.clearRect(0,0,1,1);let s;try{cn.drawImage(t,e,i,1,1,0,0,1,1),s=cn.getImageData(0,0,1,1).data}catch{return cn=null,null}return s}getBackground(t){let i=this.getLayer().getBackground();return typeof i=="function"&&(i=i(t.viewState.resolution)),i||void 0}useContainer(t,e,i){const s=this.getLayer().getClassName();let r,o;if(t&&t.className===s&&(!i||t&&t.style.backgroundColor&&ti(en(t.style.backgroundColor),en(i)))){const a=t.firstElementChild;ri(a)&&(o=a.getContext("2d"))}if(o&&Mf(o.canvas.style.transform,e)?(this.container=t,this.context=o,this.containerReused=!0):this.containerReused?(this.container=null,this.context=null,this.containerReused=!1):this.container&&(this.container.style.backgroundColor=null),!this.container){r=Bt?Ah():document.createElement("div"),r.className=s;let a=r.style;a.position="absolute",a.width="100%",a.height="100%",o=ct();const l=o.canvas;r.appendChild(l),a=l.style,a.position="absolute",a.left="0",a.transformOrigin="top left",this.container=r,this.context=o}!this.containerReused&&i&&!this.container.style.backgroundColor&&(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){const s=Ri(i),r=Us(i),o=Zs(i),a=Bs(i);ft(e.coordinateToPixelTransform,s),ft(e.coordinateToPixelTransform,r),ft(e.coordinateToPixelTransform,o),ft(e.coordinateToPixelTransform,a);const l=this.inversePixelTransform;ft(l,s),ft(l,r),ft(l,o),ft(l,a),t.save(),t.beginPath(),t.moveTo(Math.round(s[0]),Math.round(s[1])),t.lineTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(o[0]),Math.round(o[1])),t.lineTo(Math.round(a[0]),Math.round(a[1])),t.clip()}prepareContainer(t,e){const i=t.extent,s=t.viewState.resolution,r=t.viewState.rotation,o=t.pixelRatio,a=Math.round(tt(i)/s*o),l=Math.round(At(i)/s*o);De(this.pixelTransform,t.size[0]/2,t.size[1]/2,1/o,1/o,r,-a/2,-l/2),lh(this.inversePixelTransform,this.pixelTransform);const h=Af(this.pixelTransform);if(this.useContainer(e,h,this.getBackground(t)),!this.containerReused){const c=this.context.canvas;c.width!=a||c.height!=l?(c.width=a,c.height=l):this.context.clearRect(0,0,a,l),h!==c.style.transform&&(c.style.transform=h)}}dispatchRenderEvent_(t,e,i){const s=this.getLayer();if(s.hasListener(t)){const r=new dc(t,this.inversePixelTransform,i,e);s.dispatchEvent(r)}}preRender(t,e){this.frameState=e,!e.declutter&&this.dispatchRenderEvent_(ie.PRERENDER,t,e)}postRender(t,e){e.declutter||this.dispatchRenderEvent_(ie.POSTRENDER,t,e)}renderDeferredInternal(t){}getRenderContext(t){return t.declutter&&!this.deferredContext_&&(this.deferredContext_=new ac),t.declutter?this.deferredContext_.getContext():this.context}renderDeferred(t){t.declutter&&(this.dispatchRenderEvent_(ie.PRERENDER,this.context,t),t.declutter&&this.deferredContext_&&(this.deferredContext_.draw(this.context),this.deferredContext_.clear()),this.renderDeferredInternal(t),this.dispatchRenderEvent_(ie.POSTRENDER,this.context,t))}getRenderTransform(t,e,i,s,r,o,a){const l=r/2,h=o/2,c=s/e,u=-c,d=-t[0]+a,f=-t[1];return De(this.tempTransform,l,h,c,u,-i,d,f)}disposeInternal(){delete this.frameState,super.disposeInternal()}}class y_ extends gc{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.clipped_=!1,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=Kt(),this.wrappedRenderedExtent_=Kt(),this.renderedRotation_,this.renderedCenter_=null,this.renderedProjection_=null,this.renderedPixelRatio_=1,this.renderedRenderOrder_=null,this.renderedFrameDeclutter_,this.replayGroup_=null,this.replayGroupChanged=!0,this.clipping=!0,this.targetContext_=null,this.opacity_=1}renderWorlds(t,e,i){const s=e.extent,r=e.viewState,o=r.center,a=r.resolution,l=r.projection,h=r.rotation,c=l.getExtent(),u=this.getLayer().getSource(),d=this.getLayer().getDeclutter(),f=e.pixelRatio,g=e.viewHints,m=!(g[vt.ANIMATING]||g[vt.INTERACTING]),_=this.context,p=Math.round(tt(s)/a*f),y=Math.round(At(s)/a*f),w=u.getWrapX()&&l.canWrapX(),x=w?tt(c):null,E=w?Math.ceil((s[2]-c[2])/x)+1:1;let T=w?Math.floor((s[0]-c[0])/x):0;do{let I=this.getRenderTransform(o,a,0,f,p,y,T*x);e.declutter&&(I=I.slice(0)),t.execute(_,[_.canvas.width,_.canvas.height],I,h,m,i===void 0?Oi:i?cc:c_,i?d&&e.declutter[d]:void 0)}while(++T<E)}setDrawContext_(){this.opacity_!==1&&(this.targetContext_=this.context,this.context=ct(this.context.canvas.width,this.context.canvas.height,fc))}resetDrawContext_(){if(this.opacity_!==1&&this.targetContext_){const t=this.targetContext_.globalAlpha;this.targetContext_.globalAlpha=this.opacity_,this.targetContext_.drawImage(this.context.canvas,0,0),this.targetContext_.globalAlpha=t,hr(this.context),fc.push(this.context.canvas),this.context=this.targetContext_,this.targetContext_=null}}renderDeclutter(t){!this.replayGroup_||!this.getLayer().getDeclutter()||this.renderWorlds(this.replayGroup_,t,!0)}renderDeferredInternal(t){this.replayGroup_&&(this.replayGroup_.renderDeferred(),this.clipped_&&this.context.restore(),this.resetDrawContext_())}renderFrame(t,e){const i=t.layerStatesArray[t.layerIndex];this.opacity_=i.opacity;const s=t.viewState;this.prepareContainer(t,e);const r=this.context,o=this.replayGroup_;let a=o&&!o.isEmpty();if(!a&&!(this.getLayer().hasListener(ie.PRERENDER)||this.getLayer().hasListener(ie.POSTRENDER)))return this.container;if(this.setDrawContext_(),this.preRender(r,t),s.projection,this.clipped_=!1,a&&i.extent&&this.clipping){const l=ni(i.extent);a=kt(l,t.extent),this.clipped_=a&&!Ui(l,t.extent),this.clipped_&&this.clipUnrotated(r,t,l)}return a&&this.renderWorlds(o,t,this.getLayer().getDeclutter()?!1:void 0),!t.declutter&&this.clipped_&&r.restore(),this.postRender(r,t),this.renderedRotation_!==s.rotation&&(this.renderedRotation_=s.rotation,this.hitDetectionImageData_=null),t.declutter||this.resetDrawContext_(),this.container}getFeatures(t){return new Promise(e=>{if(this.frameState&&!this.hitDetectionImageData_&&!this.animatingOrInteracting_){const i=this.frameState.size.slice(),s=this.renderedCenter_,r=this.renderedResolution_,o=this.renderedRotation_,a=this.renderedProjection_,l=this.wrappedRenderedExtent_,h=this.getLayer(),c=[],u=i[0]*ve,d=i[1]*ve;c.push(this.getRenderTransform(s,r,o,ve,u,d,0).slice());const f=h.getSource(),g=a.getExtent();if(f.getWrapX()&&a.canWrapX()&&!Ui(g,l)){let m=l[0];const _=tt(g);let p=0,y;for(;m<g[0];)--p,y=_*p,c.push(this.getRenderTransform(s,r,o,ve,u,d,y).slice()),m+=_;for(p=0,m=l[2];m>g[2];)++p,y=_*p,c.push(this.getRenderTransform(s,r,o,ve,u,d,y).slice()),m-=_}this.hitDetectionImageData_=f_(i,c,this.renderedFeatures_,h.getStyleFunction(),l,r,o,$h(r,this.renderedPixelRatio_))}e(g_(t,this.renderedFeatures_,this.hitDetectionImageData_))})}forEachFeatureAtCoordinate(t,e,i,s,r){if(!this.replayGroup_)return;const o=e.viewState.resolution,a=e.viewState.rotation,l=this.getLayer(),h={},c=function(d,f,g){const m=j(d),_=h[m];if(_){if(_!==!0&&g<_.distanceSq){if(g===0)return h[m]=!0,r.splice(r.lastIndexOf(_),1),s(d,l,f);_.geometry=f,_.distanceSq=g}}else{if(g===0)return h[m]=!0,s(d,l,f);r.push(h[m]={feature:d,layer:l,geometry:f,distanceSq:g,callback:s})}},u=this.getLayer().getDeclutter();return this.replayGroup_.forEachFeatureAtCoordinate(t,o,a,i,c,u?e.declutter?.[u]?.all().map(d=>d.value):null)}handleFontsChanged(){const t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){const e=this.getLayer(),i=e.getSource();if(!i)return!1;const s=t.viewHints[vt.ANIMATING],r=t.viewHints[vt.INTERACTING],o=e.getUpdateWhileAnimating(),a=e.getUpdateWhileInteracting();if(this.ready&&!o&&s||!a&&r)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;const l=t.extent,h=t.viewState,c=h.projection,u=h.resolution,d=t.pixelRatio,f=e.getRevision(),g=e.getRenderBuffer();let m=e.getRenderOrder();m===void 0&&(m=Lg);const _=h.center.slice(),p=eo(l,g*u),y=p.slice(),w=[p.slice()],x=c.getExtent();if(i.getWrapX()&&c.canWrapX()&&!Ui(x,t.extent)){const L=tt(x),M=Math.max(tt(p)/2,L);p[0]=x[0]-M,p[2]=x[2]+M,Bl(_,c);const P=Xl(w[0],c);P[0]<x[0]&&P[2]<x[2]?w.push([P[0]+L,P[1],P[2]+L,P[3]]):P[0]>x[0]&&P[2]>x[2]&&w.push([P[0]-L,P[1],P[2]-L,P[3]])}if(this.ready&&this.renderedResolution_==u&&this.renderedRevision_==f&&this.renderedRenderOrder_==m&&this.renderedFrameDeclutter_===!!t.declutter&&Ui(this.wrappedRenderedExtent_,p))return ti(this.renderedExtent_,y)||(this.hitDetectionImageData_=null,this.renderedExtent_=y),this.renderedCenter_=_,this.replayGroupChanged=!1,!0;this.replayGroup_=null;const E=new r_(Kh(u,d),p,u,d);let T;for(let L=0,M=w.length;L<M;++L)i.loadFeatures(w[L],u,c);const I=$h(u,d);let v=!0;const R=(L,M)=>{let P;const X=L.getStyleFunction()||e.getStyleFunction();if(X&&(P=X(L,u)),P){const D=this.renderFeature(L,I,P,E,T,this.getLayer().getDeclutter(),M);v=v&&!D}},b=ah(p),O=i.getFeaturesInExtent(b);m&&O.sort(m);for(let L=0,M=O.length;L<M;++L)R(O[L],L);this.renderedFeatures_=O,this.ready=v;const F=E.finish(),A=new u_(p,u,d,i.getOverlaps(),F,e.getRenderBuffer(),!!t.declutter);return this.renderedResolution_=u,this.renderedRevision_=f,this.renderedRenderOrder_=m,this.renderedFrameDeclutter_=!!t.declutter,this.renderedExtent_=y,this.wrappedRenderedExtent_=p,this.renderedCenter_=_,this.renderedProjection_=c,this.renderedPixelRatio_=d,this.replayGroup_=A,this.hitDetectionImageData_=null,this.replayGroupChanged=!0,!0}renderFeature(t,e,i,s,r,o,a){if(!i)return!1;let l=!1;if(Array.isArray(i))for(let h=0,c=i.length;h<c;++h)l=Bh(s,t,i[h],e,this.boundHandleStyleImageChange_,r,o,a)||l;else l=Bh(s,t,i,e,this.boundHandleStyleImageChange_,r,o,a);return l}}let Di=0;const Mt=1<<Di++,B=1<<Di++,Xt=1<<Di++,_e=1<<Di++,Fi=1<<Di++,ss=1<<Di++,wr=Math.pow(2,Di)-1,Vo={[Mt]:"boolean",[B]:"number",[Xt]:"string",[_e]:"color",[Fi]:"number[]",[ss]:"size"},x_=Object.keys(Vo).map(Number).sort(Me);function E_(n){return n in Vo}function rs(n){const t=[];for(const e of x_)os(n,e)&&t.push(Vo[e]);return t.length===0?"untyped":t.length<3?t.join(" or "):t.slice(0,-1).join(", ")+", or "+t[t.length-1]}function os(n,t){return(n&t)===t}function ci(n,t){return n===t}class ut{constructor(t,e){if(!E_(t))throw new Error(`literal expressions must have a specific type, got ${rs(t)}`);this.type=t,this.value=e}}class v_{constructor(t,e,...i){this.type=t,this.operator=e,this.args=i}}function _c(){return{variables:new Set,properties:new Set,featureId:!1,geometryType:!1,mapState:!1}}function yt(n,t,e){switch(typeof n){case"boolean":{if(ci(t,Xt))return new ut(Xt,n?"true":"false");if(!os(t,Mt))throw new Error(`got a boolean, but expected ${rs(t)}`);return new ut(Mt,n)}case"number":{if(ci(t,ss))return new ut(ss,zt(n));if(ci(t,Mt))return new ut(Mt,!!n);if(ci(t,Xt))return new ut(Xt,n.toString());if(!os(t,B))throw new Error(`got a number, but expected ${rs(t)}`);return new ut(B,n)}case"string":{if(ci(t,_e))return new ut(_e,ko(n));if(ci(t,Mt))return new ut(Mt,!!n);if(!os(t,Xt))throw new Error(`got a string, but expected ${rs(t)}`);return new ut(Xt,n)}}if(!Array.isArray(n))throw new Error("expression must be an array or a primitive value");if(n.length===0)throw new Error("empty expression");if(typeof n[0]=="string")return P_(n,t,e);for(const i of n)if(typeof i!="number")throw new Error("expected an array of numbers");if(ci(t,ss)){if(n.length!==2)throw new Error(`expected an array of two values for a size, got ${n.length}`);return new ut(ss,n)}if(ci(t,_e)){if(n.length===3)return new ut(_e,[...n,1]);if(n.length===4)return new ut(_e,n);throw new Error(`expected an array of 3 or 4 values for a color, got ${n.length}`)}if(!os(t,Fi))throw new Error(`got an array of numbers, but expected ${rs(t)}`);return new ut(Fi,n)}const C={Get:"get",Var:"var",Concat:"concat",GeometryType:"geometry-type",LineMetric:"line-metric",Any:"any",All:"all",Not:"!",Resolution:"resolution",Zoom:"zoom",Time:"time",Equal:"==",NotEqual:"!=",GreaterThan:">",GreaterThanOrEqualTo:">=",LessThan:"<",LessThanOrEqualTo:"<=",Multiply:"*",Divide:"/",Add:"+",Subtract:"-",Clamp:"clamp",Mod:"%",Pow:"^",Abs:"abs",Floor:"floor",Ceil:"ceil",Round:"round",Sin:"sin",Cos:"cos",Atan:"atan",Sqrt:"sqrt",Match:"match",Between:"between",Interpolate:"interpolate",Coalesce:"coalesce",Case:"case",In:"in",Number:"number",String:"string",Array:"array",Color:"color",Id:"id",Band:"band",Palette:"palette",ToString:"to-string",Has:"has"},w_={[C.Get]:z($(1,1/0),mc),[C.Var]:z($(1,1),C_),[C.Has]:z($(1,1/0),mc),[C.Id]:z(R_,un),[C.Concat]:z($(2,1/0),q(Xt)),[C.GeometryType]:z(T_,un),[C.LineMetric]:z(un),[C.Resolution]:z(jo,un),[C.Zoom]:z(jo,un),[C.Time]:z(jo,un),[C.Any]:z($(2,1/0),q(Mt)),[C.All]:z($(2,1/0),q(Mt)),[C.Not]:z($(1,1),q(Mt)),[C.Equal]:z($(2,2),q(wr)),[C.NotEqual]:z($(2,2),q(wr)),[C.GreaterThan]:z($(2,2),q(B)),[C.GreaterThanOrEqualTo]:z($(2,2),q(B)),[C.LessThan]:z($(2,2),q(B)),[C.LessThanOrEqualTo]:z($(2,2),q(B)),[C.Multiply]:z($(2,1/0),pc),[C.Coalesce]:z($(2,1/0),pc),[C.Divide]:z($(2,2),q(B)),[C.Add]:z($(2,1/0),q(B)),[C.Subtract]:z($(2,2),q(B)),[C.Clamp]:z($(3,3),q(B)),[C.Mod]:z($(2,2),q(B)),[C.Pow]:z($(2,2),q(B)),[C.Abs]:z($(1,1),q(B)),[C.Floor]:z($(1,1),q(B)),[C.Ceil]:z($(1,1),q(B)),[C.Round]:z($(1,1),q(B)),[C.Sin]:z($(1,1),q(B)),[C.Cos]:z($(1,1),q(B)),[C.Atan]:z($(1,2),q(B)),[C.Sqrt]:z($(1,1),q(B)),[C.Match]:z($(4,1/0),yc,S_),[C.Between]:z($(3,3),q(B)),[C.Interpolate]:z($(6,1/0),yc,b_),[C.Case]:z($(3,1/0),I_,L_),[C.In]:z($(2,2),A_),[C.Number]:z($(1,1/0),q(wr)),[C.String]:z($(1,1/0),q(wr)),[C.Array]:z($(1,1/0),q(B)),[C.Color]:z($(1,4),q(B)),[C.Band]:z($(1,3),q(B)),[C.Palette]:z($(2,2),M_),[C.ToString]:z($(1,1),q(Mt|B|Xt|_e))};function mc(n,t,e){const i=n.length-1,s=new Array(i);for(let r=0;r<i;++r){const o=n[r+1];switch(typeof o){case"number":{s[r]=new ut(B,o);break}case"string":{s[r]=new ut(Xt,o);break}default:throw new Error(`expected a string key or numeric array index for a get operation, got ${o}`)}r===0&&e.properties.add(String(o))}return s}function C_(n,t,e){const i=n[1];if(typeof i!="string")throw new Error("expected a string argument for var operation");return e.variables.add(i),[new ut(Xt,i)]}function R_(n,t,e){e.featureId=!0}function T_(n,t,e){e.geometryType=!0}function jo(n,t,e){e.mapState=!0}function un(n,t,e){const i=n[0];if(n.length!==1)throw new Error(`expected no arguments for ${i} operation`);return[]}function $(n,t){return function(e,i,s){const r=e[0],o=e.length-1;if(n===t){if(o!==n){const a=n===1?"":"s";throw new Error(`expected ${n} argument${a} for ${r}, got ${o}`)}}else if(o<n||o>t){const a=t===1/0?`${n} or more`:`${n} to ${t}`;throw new Error(`expected ${a} arguments for ${r}, got ${o}`)}}}function pc(n,t,e){const i=n.length-1,s=new Array(i);for(let r=0;r<i;++r){const o=yt(n[r+1],t,e);s[r]=o}return s}function q(n){return function(t,e,i){const s=t.length-1,r=new Array(s);for(let o=0;o<s;++o){const a=yt(t[o+1],n,i);r[o]=a}return r}}function I_(n,t,e){const i=n[0],s=n.length-1;if(s%2===0)throw new Error(`expected an odd number of arguments for ${i}, got ${s} instead`)}function yc(n,t,e){const i=n[0],s=n.length-1;if(s%2===1)throw new Error(`expected an even number of arguments for operation ${i}, got ${s} instead`)}function S_(n,t,e){const i=n.length-1,s=Xt|B|Mt,r=yt(n[1],s,e),o=yt(n[n.length-1],t,e),a=new Array(i-2);for(let l=0;l<i-2;l+=2){try{const h=yt(n[l+2],r.type,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+1} of match expression: ${h.message}`)}try{const h=yt(n[l+3],o.type,e);a[l+1]=h}catch(h){throw new Error(`failed to parse argument ${l+2} of match expression: ${h.message}`)}}return[r,...a,o]}function b_(n,t,e){const i=n[1];let s;switch(i[0]){case"linear":s=1;break;case"exponential":const l=i[1];if(typeof l!="number"||l<=0)throw new Error(`expected a number base for exponential interpolation, got ${JSON.stringify(l)} instead`);s=l;break;default:throw new Error(`invalid interpolation type: ${JSON.stringify(i)}`)}const r=new ut(B,s);let o;try{o=yt(n[2],B,e)}catch(l){throw new Error(`failed to parse argument 1 in interpolate expression: ${l.message}`)}const a=new Array(n.length-3);for(let l=0;l<a.length;l+=2){try{const h=yt(n[l+3],B,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+2} for interpolate expression: ${h.message}`)}try{const h=yt(n[l+4],t,e);a[l+1]=h}catch(h){throw new Error(`failed to parse argument ${l+3} for interpolate expression: ${h.message}`)}}return[r,o,...a]}function L_(n,t,e){const i=yt(n[n.length-1],t,e),s=new Array(n.length-1);for(let r=0;r<s.length-1;r+=2){try{const o=yt(n[r+1],Mt,e);s[r]=o}catch(o){throw new Error(`failed to parse argument ${r} of case expression: ${o.message}`)}try{const o=yt(n[r+2],i.type,e);s[r+1]=o}catch(o){throw new Error(`failed to parse argument ${r+1} of case expression: ${o.message}`)}}return s[s.length-1]=i,s}function A_(n,t,e){let i=n[2];if(!Array.isArray(i))throw new Error('the second argument for the "in" operator must be an array');let s;if(typeof i[0]=="string"){if(i[0]!=="literal")throw new Error('for the "in" operator, a string array should be wrapped in a "literal" operator to disambiguate from expressions');if(!Array.isArray(i[1]))throw new Error('failed to parse "in" expression: the literal operator must be followed by an array');i=i[1],s=Xt}else s=B;const r=new Array(i.length);for(let a=0;a<r.length;a++)try{const l=yt(i[a],s,e);r[a]=l}catch(l){throw new Error(`failed to parse haystack item ${a} for "in" expression: ${l.message}`)}return[yt(n[1],s,e),...r]}function M_(n,t,e){let i;try{i=yt(n[1],B,e)}catch(o){throw new Error(`failed to parse first argument in palette expression: ${o.message}`)}const s=n[2];if(!Array.isArray(s))throw new Error("the second argument of palette must be an array");const r=new Array(s.length);for(let o=0;o<r.length;o++){let a;try{a=yt(s[o],_e,e)}catch(l){throw new Error(`failed to parse color at index ${o} in palette expression: ${l.message}`)}if(!(a instanceof ut))throw new Error(`the palette color at index ${o} must be a literal value`);r[o]=a}return[i,...r]}function z(...n){return function(t,e,i){const s=t[0];let r;for(let o=0;o<n.length;o++){const a=n[o](t,e,i);if(o==n.length-1){if(!a)throw new Error("expected last argument validator to return the parsed args");r=a}}return new v_(e,s,...r)}}function P_(n,t,e){const i=n[0],s=w_[i];if(!s)throw new Error(`unknown operator: ${i}`);return s(n,t,e)}function xc(n){if(!n)return"";const t=n.getType();switch(t){case"Point":case"LineString":case"Polygon":return t;case"MultiPoint":case"MultiLineString":case"MultiPolygon":return t.substring(5);case"Circle":return"Polygon";case"GeometryCollection":return xc(n.getGeometries()[0]);default:return""}}function Ec(){return{variables:{},properties:{},resolution:NaN,featureId:null,geometryType:""}}function ze(n,t,e){const i=yt(n,t,e);return me(i)}function me(n,t){if(n instanceof ut){if(n.type===_e&&typeof n.value=="string"){const i=ko(n.value);return function(){return i}}return function(){return n.value}}const e=n.operator;switch(e){case C.Number:case C.String:case C.Coalesce:return O_(n);case C.Get:case C.Var:case C.Has:return D_(n);case C.Id:return i=>i.featureId;case C.GeometryType:return i=>i.geometryType;case C.Concat:{const i=n.args.map(s=>me(s));return s=>"".concat(...i.map(r=>r(s).toString()))}case C.Resolution:return i=>i.resolution;case C.Any:case C.All:case C.Between:case C.In:case C.Not:return k_(n);case C.Equal:case C.NotEqual:case C.LessThan:case C.LessThanOrEqualTo:case C.GreaterThan:case C.GreaterThanOrEqualTo:return F_(n);case C.Multiply:case C.Divide:case C.Add:case C.Subtract:case C.Clamp:case C.Mod:case C.Pow:case C.Abs:case C.Floor:case C.Ceil:case C.Round:case C.Sin:case C.Cos:case C.Atan:case C.Sqrt:return N_(n);case C.Case:return G_(n);case C.Match:return z_(n);case C.Interpolate:return X_(n);case C.ToString:return W_(n);default:throw new Error(`Unsupported operator ${e}`)}}function O_(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=me(n.args[r]);switch(e){case C.Coalesce:return r=>{for(let o=0;o<i;++o){const a=s[o](r);if(typeof a<"u"&&a!==null)return a}throw new Error("Expected one of the values to be non-null")};case C.Number:case C.String:return r=>{for(let o=0;o<i;++o){const a=s[o](r);if(typeof a===e)return a}throw new Error(`Expected one of the values to be a ${e}`)};default:throw new Error(`Unsupported assertion operator ${e}`)}}function D_(n,t){const i=n.args[0].value;switch(n.operator){case C.Get:return s=>{const r=n.args;let o=s.properties[i];for(let a=1,l=r.length;a<l;++a){const c=r[a].value;o=o[c]}return o};case C.Var:return s=>s.variables[i];case C.Has:return s=>{const r=n.args;if(!(i in s.properties))return!1;let o=s.properties[i];for(let a=1,l=r.length;a<l;++a){const c=r[a].value;if(!o||!Object.hasOwn(o,c))return!1;o=o[c]}return!0};default:throw new Error(`Unsupported accessor operator ${n.operator}`)}}function F_(n,t){const e=n.operator,i=me(n.args[0]),s=me(n.args[1]);switch(e){case C.Equal:return r=>i(r)===s(r);case C.NotEqual:return r=>i(r)!==s(r);case C.LessThan:return r=>i(r)<s(r);case C.LessThanOrEqualTo:return r=>i(r)<=s(r);case C.GreaterThan:return r=>i(r)>s(r);case C.GreaterThanOrEqualTo:return r=>i(r)>=s(r);default:throw new Error(`Unsupported comparison operator ${e}`)}}function k_(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=me(n.args[r]);switch(e){case C.Any:return r=>{for(let o=0;o<i;++o)if(s[o](r))return!0;return!1};case C.All:return r=>{for(let o=0;o<i;++o)if(!s[o](r))return!1;return!0};case C.Between:return r=>{const o=s[0](r),a=s[1](r),l=s[2](r);return o>=a&&o<=l};case C.In:return r=>{const o=s[0](r);for(let a=1;a<i;++a)if(o===s[a](r))return!0;return!1};case C.Not:return r=>!s[0](r);default:throw new Error(`Unsupported logical operator ${e}`)}}function N_(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=me(n.args[r]);switch(e){case C.Multiply:return r=>{let o=1;for(let a=0;a<i;++a)o*=s[a](r);return o};case C.Divide:return r=>s[0](r)/s[1](r);case C.Add:return r=>{let o=0;for(let a=0;a<i;++a)o+=s[a](r);return o};case C.Subtract:return r=>s[0](r)-s[1](r);case C.Clamp:return r=>{const o=s[0](r),a=s[1](r);if(o<a)return a;const l=s[2](r);return o>l?l:o};case C.Mod:return r=>s[0](r)%s[1](r);case C.Pow:return r=>Math.pow(s[0](r),s[1](r));case C.Abs:return r=>Math.abs(s[0](r));case C.Floor:return r=>Math.floor(s[0](r));case C.Ceil:return r=>Math.ceil(s[0](r));case C.Round:return r=>Math.round(s[0](r));case C.Sin:return r=>Math.sin(s[0](r));case C.Cos:return r=>Math.cos(s[0](r));case C.Atan:return i===2?r=>Math.atan2(s[0](r),s[1](r)):r=>Math.atan(s[0](r));case C.Sqrt:return r=>Math.sqrt(s[0](r));default:throw new Error(`Unsupported numeric operator ${e}`)}}function G_(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=me(n.args[s]);return s=>{for(let r=0;r<e-1;r+=2)if(i[r](s))return i[r+1](s);return i[e-1](s)}}function z_(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=me(n.args[s]);return s=>{const r=i[0](s);for(let o=1;o<e-1;o+=2)if(r===i[o](s))return i[o+1](s);return i[e-1](s)}}function X_(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=me(n.args[s]);return s=>{const r=i[0](s),o=i[1](s);let a,l;for(let h=2;h<e;h+=2){const c=i[h](s);let u=i[h+1](s);const d=Array.isArray(u);if(d&&(u=ug(u)),c>=o)return h===2?u:d?Y_(r,o,a,l,c,u):as(r,o,a,l,c,u);a=c,l=u}return l}}function W_(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=me(n.args[r]);switch(e){case C.ToString:return r=>{const o=s[0](r);return n.args[0].type===_e?No(o):o.toString()};default:throw new Error(`Unsupported convert operator ${e}`)}}function as(n,t,e,i,s,r){const o=s-e;if(o===0)return i;const a=t-e,l=n===1?a/o:(Math.pow(n,a)-1)/(Math.pow(n,o)-1);return i+l*(r-i)}function Y_(n,t,e,i,s,r){if(s-e===0)return i;const a=Ph(i),l=Ph(r);let h=l[2]-a[2];h>180?h-=360:h<-180&&(h+=360);const c=[as(n,t,e,a[0],s,l[0]),as(n,t,e,a[1],s,l[1]),a[2]+as(n,t,e,0,s,h),as(n,t,e,i[3],s,r[3])];return dg(c)}function $_(n){return!0}function K_(n){const t=_c(),e=B_(n,t),i=Ec();return function(s,r){if(i.properties=s.getPropertiesInternal(),i.resolution=r,t.featureId){const o=s.getId();o!==void 0?i.featureId=o:i.featureId=null}return t.geometryType&&(i.geometryType=xc(s.getGeometry())),e(i)}}function vc(n){const t=_c(),e=n.length,i=new Array(e);for(let o=0;o<e;++o)i[o]=Ho(n[o],t);const s=Ec(),r=new Array(e);return function(o,a){if(s.properties=o.getPropertiesInternal(),s.resolution=a,t.featureId){const h=o.getId();h!==void 0?s.featureId=h:s.featureId=null}let l=0;for(let h=0;h<e;++h){const c=i[h](s);c&&(r[l]=c,l+=1)}return r.length=l,r}}function B_(n,t){const e=n.length,i=new Array(e);for(let s=0;s<e;++s){const r=n[s],o="filter"in r?ze(r.filter,Mt,t):$_;let a;if(Array.isArray(r.style)){const l=r.style.length;a=new Array(l);for(let h=0;h<l;++h)a[h]=Ho(r.style[h],t)}else a=[Ho(r.style,t)];i[s]={filter:o,styles:a}}return function(s){const r=[];let o=!1;for(let a=0;a<e;++a){const l=i[a].filter;if(l(s)&&!(n[a].else&&o)){o=!0;for(const h of i[a].styles){const c=h(s);c&&r.push(c)}}}return r}}function Ho(n,t){const e=ls(n,"",t),i=hs(n,"",t),s=Z_(n,t),r=U_(n,t),o=Wt(n,"z-index",t);if(!e&&!i&&!s&&!r&&!Bi(n))throw new Error("No fill, stroke, point, or text symbolizer properties in style: "+JSON.stringify(n));const a=new Ee;return function(l){let h=!0;if(e){const c=e(l);c&&(h=!1),a.setFill(c)}if(i){const c=i(l);c&&(h=!1),a.setStroke(c)}if(s){const c=s(l);c&&(h=!1),a.setText(c)}if(r){const c=r(l);c&&(h=!1),a.setImage(c)}return o&&a.setZIndex(o(l)),h?null:a}}function ls(n,t,e){let i;if(t+"fill-pattern-src"in n)i=q_(n,t+"fill-",e);else{if(n[t+"fill-color"]==="none")return r=>null;i=qo(n,t+"fill-color",e)}if(!i)return null;const s=new Mi;return function(r){const o=i(r);return o===Lo?null:(s.setColor(o),s)}}function hs(n,t,e){const i=Wt(n,t+"stroke-width",e),s=qo(n,t+"stroke-color",e);if(!i&&!s)return null;const r=Xe(n,t+"stroke-line-cap",e),o=Xe(n,t+"stroke-line-join",e),a=wc(n,t+"stroke-line-dash",e),l=Wt(n,t+"stroke-line-dash-offset",e),h=Wt(n,t+"stroke-miter-limit",e),c=new is;return function(u){if(s){const d=s(u);if(d===Lo)return null;c.setColor(d)}if(i&&c.setWidth(i(u)),r){const d=r(u);if(d!=="butt"&&d!=="round"&&d!=="square")throw new Error("Expected butt, round, or square line cap");c.setLineCap(d)}if(o){const d=o(u);if(d!=="bevel"&&d!=="round"&&d!=="miter")throw new Error("Expected bevel, round, or miter line join");c.setLineJoin(d)}return a&&c.setLineDash(a(u)),l&&c.setLineDashOffset(l(u)),h&&c.setMiterLimit(h(u)),c}}function Z_(n,t){const e="text-",i=Xe(n,e+"value",t);if(!i)return null;const s=ls(n,e,t),r=ls(n,e+"background-",t),o=hs(n,e,t),a=hs(n,e+"background-",t),l=Xe(n,e+"font",t),h=Wt(n,e+"max-angle",t),c=Wt(n,e+"offset-x",t),u=Wt(n,e+"offset-y",t),d=dn(n,e+"overflow",t),f=Xe(n,e+"placement",t),g=Wt(n,e+"repeat",t),m=Rr(n,e+"scale",t),_=dn(n,e+"rotate-with-view",t),p=Wt(n,e+"rotation",t),y=Xe(n,e+"align",t),w=Xe(n,e+"justify",t),x=Xe(n,e+"baseline",t),E=dn(n,e+"keep-upright",t),T=wc(n,e+"padding",t),I=Ir(n,e+"declutter-mode"),v=new sc({declutterMode:I});return function(R){if(v.setText(i(R)),s&&v.setFill(s(R)),r&&v.setBackgroundFill(r(R)),o&&v.setStroke(o(R)),a&&v.setBackgroundStroke(a(R)),l&&v.setFont(l(R)),h&&v.setMaxAngle(h(R)),c&&v.setOffsetX(c(R)),u&&v.setOffsetY(u(R)),d&&v.setOverflow(d(R)),f){const b=f(R);if(b!=="point"&&b!=="line")throw new Error("Expected point or line for text-placement");v.setPlacement(b)}if(g&&v.setRepeat(g(R)),m&&v.setScale(m(R)),_&&v.setRotateWithView(_(R)),p&&v.setRotation(p(R)),y){const b=y(R);if(b!=="left"&&b!=="center"&&b!=="right"&&b!=="end"&&b!=="start")throw new Error("Expected left, right, center, start, or end for text-align");v.setTextAlign(b)}if(w){const b=w(R);if(b!=="left"&&b!=="right"&&b!=="center")throw new Error("Expected left, right, or center for text-justify");v.setJustify(b)}if(x){const b=x(R);if(b!=="bottom"&&b!=="top"&&b!=="middle"&&b!=="alphabetic"&&b!=="hanging")throw new Error("Expected bottom, top, middle, alphabetic, or hanging for text-baseline");v.setTextBaseline(b)}return T&&v.setPadding(T(R)),E&&v.setKeepUpright(E(R)),v}}function U_(n,t){return"icon-src"in n?V_(n,t):"shape-points"in n?j_(n,t):"circle-radius"in n?H_(n,t):null}function V_(n,t){const e="icon-",i=e+"src",s=Ic(n[i],i),r=Cr(n,e+"anchor",t),o=Rr(n,e+"scale",t),a=Wt(n,e+"opacity",t),l=Cr(n,e+"displacement",t),h=Wt(n,e+"rotation",t),c=dn(n,e+"rotate-with-view",t),u=Rc(n,e+"anchor-origin"),d=Tc(n,e+"anchor-x-units"),f=Tc(n,e+"anchor-y-units"),g=em(n,e+"color"),m=Q_(n,e+"cross-origin"),_=tm(n,e+"offset"),p=Rc(n,e+"offset-origin"),y=Tr(n,e+"width"),w=Tr(n,e+"height"),x=J_(n,e+"size"),E=Ir(n,e+"declutter-mode"),T=new hn({src:s,anchorOrigin:u,anchorXUnits:d,anchorYUnits:f,color:g,crossOrigin:m,offset:_,offsetOrigin:p,height:w,width:y,size:x,declutterMode:E});return function(I){return a&&T.setOpacity(a(I)),l&&T.setDisplacement(l(I)),h&&T.setRotation(h(I)),c&&T.setRotateWithView(c(I)),o&&T.setScale(o(I)),r&&T.setAnchor(r(I)),T}}function j_(n,t){const e="shape-",i=e+"points",s=e+"radius",r=Jo(n[i],i),o=Jo(n[s],s),a=ls(n,e,t),l=hs(n,e,t),h=Rr(n,e+"scale",t),c=Cr(n,e+"displacement",t),u=Wt(n,e+"rotation",t),d=dn(n,e+"rotate-with-view",t),f=Tr(n,e+"radius2"),g=Tr(n,e+"angle"),m=Ir(n,e+"declutter-mode"),_=new yr({points:r,radius:o,radius2:f,angle:g,declutterMode:m});return function(p){return a&&_.setFill(a(p)),l&&_.setStroke(l(p)),c&&_.setDisplacement(c(p)),u&&_.setRotation(u(p)),d&&_.setRotateWithView(d(p)),h&&_.setScale(h(p)),_}}function H_(n,t){const e="circle-",i=ls(n,e,t),s=hs(n,e,t),r=Wt(n,e+"radius",t),o=Rr(n,e+"scale",t),a=Cr(n,e+"displacement",t),l=Wt(n,e+"rotation",t),h=dn(n,e+"rotate-with-view",t),c=Ir(n,e+"declutter-mode"),u=new xr({radius:5,declutterMode:c});return function(d){return r&&u.setRadius(r(d)),i&&u.setFill(i(d)),s&&u.setStroke(s(d)),a&&u.setDisplacement(a(d)),l&&u.setRotation(l(d)),h&&u.setRotateWithView(h(d)),o&&u.setScale(o(d)),u}}function Wt(n,t,e){if(!(t in n))return;const i=ze(n[t],B,e);return function(s){return Jo(i(s),t)}}function Xe(n,t,e){if(!(t in n))return null;const i=ze(n[t],Xt,e);return function(s){return Ic(i(s),t)}}function q_(n,t,e){const i=Xe(n,t+"pattern-src",e),s=Cc(n,t+"pattern-offset",e),r=Cc(n,t+"pattern-size",e),o=qo(n,t+"color",e);return function(a){return{src:i(a),offset:s&&s(a),size:r&&r(a),color:o&&o(a)}}}function dn(n,t,e){if(!(t in n))return null;const i=ze(n[t],Mt,e);return function(s){const r=i(s);if(typeof r!="boolean")throw new Error(`Expected a boolean for ${t}`);return r}}function qo(n,t,e){if(!(t in n))return null;const i=ze(n[t],_e,e);return function(s){return Sc(i(s),t)}}function wc(n,t,e){if(!(t in n))return null;const i=ze(n[t],Fi,e);return function(s){return cs(i(s),t)}}function Cr(n,t,e){if(!(t in n))return null;const i=ze(n[t],Fi,e);return function(s){const r=cs(i(s),t);if(r.length!==2)throw new Error(`Expected two numbers for ${t}`);return r}}function Cc(n,t,e){if(!(t in n))return null;const i=ze(n[t],Fi,e);return function(s){return bc(i(s),t)}}function Rr(n,t,e){if(!(t in n))return null;const i=ze(n[t],Fi|B,e);return function(s){return im(i(s),t)}}function Tr(n,t){const e=n[t];if(e!==void 0){if(typeof e!="number")throw new Error(`Expected a number for ${t}`);return e}}function J_(n,t){const e=n[t];if(e!==void 0){if(typeof e=="number")return zt(e);if(!Array.isArray(e))throw new Error(`Expected a number or size array for ${t}`);if(e.length!==2||typeof e[0]!="number"||typeof e[1]!="number")throw new Error(`Expected a number or size array for ${t}`);return e}}function Q_(n,t){const e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);return e}}function Rc(n,t){const e=n[t];if(e!==void 0){if(e!=="bottom-left"&&e!=="bottom-right"&&e!=="top-left"&&e!=="top-right")throw new Error(`Expected bottom-left, bottom-right, top-left, or top-right for ${t}`);return e}}function Tc(n,t){const e=n[t];if(e!==void 0){if(e!=="pixels"&&e!=="fraction")throw new Error(`Expected pixels or fraction for ${t}`);return e}}function tm(n,t){const e=n[t];if(e!==void 0)return cs(e,t)}function Ir(n,t){const e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);if(e!=="declutter"&&e!=="obstacle"&&e!=="none")throw new Error(`Expected declutter, obstacle, or none for ${t}`);return e}}function em(n,t){const e=n[t];if(e!==void 0)return Sc(e,t)}function cs(n,t){if(!Array.isArray(n))throw new Error(`Expected an array for ${t}`);const e=n.length;for(let i=0;i<e;++i)if(typeof n[i]!="number")throw new Error(`Expected an array of numbers for ${t}`);return n}function Ic(n,t){if(typeof n!="string")throw new Error(`Expected a string for ${t}`);return n}function Jo(n,t){if(typeof n!="number")throw new Error(`Expected a number for ${t}`);return n}function Sc(n,t){if(typeof n=="string")return n;const e=cs(n,t),i=e.length;if(i<3||i>4)throw new Error(`Expected a color with 3 or 4 values for ${t}`);return e}function bc(n,t){const e=cs(n,t);if(e.length!==2)throw new Error(`Expected an array of two numbers for ${t}`);return e}function im(n,t){return typeof n=="number"?n:bc(n,t)}const pe={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};function Lc(n,t,e){return(function(i,s,r,o,a){if(!i)return;if(!s&&!t)return i;const l=t?0:r[0]*s,h=t?0:r[1]*s,c=a?a[0]:0,u=a?a[1]:0;let d=n[0]+l/2+c,f=n[2]-l/2+c,g=n[1]+h/2+u,m=n[3]-h/2+u;d>f&&(d=(f+d)/2,f=d),g>m&&(g=(m+g)/2,m=g);let _=ot(i[0],d,f),p=ot(i[1],g,m);if(o&&e&&s){const y=30*s;_+=-y*Math.log(1+Math.max(0,d-i[0])/y)+y*Math.log(1+Math.max(0,i[0]-f)/y),p+=-y*Math.log(1+Math.max(0,g-i[1])/y)+y*Math.log(1+Math.max(0,i[1]-m)/y)}return[_,p]})}function nm(n){return n}function Ac(n){return Math.pow(n,3)}function fn(n){return 1-Ac(1-n)}function sm(n){return 3*n*n-2*n*n*n}function rm(n){return n}function Qo(n,t,e,i){const s=tt(t)/e[0],r=At(t)/e[1];return i?Math.min(n,Math.max(s,r)):Math.min(n,Math.min(s,r))}function ta(n,t,e){let i=Math.min(n,t);const s=50;return i*=Math.log(1+s*Math.max(0,n/t-1))/s+1,e&&(i=Math.max(i,e),i/=Math.log(1+s*Math.max(0,e/n-1))/s+1),ot(i,e/2,t*2)}function om(n,t,e,i){return t=t!==void 0?t:!0,(function(s,r,o,a){if(s!==void 0){const l=n[0],h=n[n.length-1],c=e?Qo(l,e,o,i):l;if(a)return t?ta(s,c,h):ot(s,h,c);const u=Math.min(c,s),d=Math.floor(Jr(n,u,r));return n[d]>c&&d<n.length-1?n[d+1]:n[d]}})}function am(n,t,e,i,s,r){return i=i!==void 0?i:!0,e=e!==void 0?e:0,(function(o,a,l,h){if(o!==void 0){const c=s?Qo(t,s,l,r):t;if(h)return i?ta(o,c,e):ot(o,e,c);const u=1e-9,d=Math.ceil(Math.log(t/c)/Math.log(n)-u),f=-a*(.5-u)+.5,g=Math.min(c,o),m=Math.floor(Math.log(t/g)/Math.log(n)+f),_=Math.max(d,m),p=t/Math.pow(n,_);return ot(p,e,c)}})}function Mc(n,t,e,i,s){return e=e!==void 0?e:!0,(function(r,o,a,l){if(r!==void 0){const h=i?Qo(n,i,a,s):n;return!e||!l?ot(r,t,h):ta(r,h,t)}})}function ea(n){if(n!==void 0)return 0}function Pc(n){if(n!==void 0)return n}function lm(n){const t=2*Math.PI/n;return(function(e,i){if(i)return e;if(e!==void 0)return e=Math.floor(e/t+.5)*t,e})}function hm(n){const t=ii(5);return(function(e,i){return i||e===void 0?e:Math.abs(e)<=t?0:e})}const cm=42,ia=256,na=0;class we extends de{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=yo(t.projection,"EPSG:3857"),this.viewportSize_=[100,100],this.targetCenter_=null,this.targetResolution_,this.targetRotation_,this.nextCenter_=null,this.nextResolution_,this.nextRotation_,this.cancelAnchor_=void 0,t.projection&&sh(),t.center&&(t.center=Oe(t.center,this.projection_)),t.extent&&(t.extent=ni(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){const e=Object.assign({},t);for(const a in pe)delete e[a];this.setProperties(e,!0);const i=dm(t);this.maxResolution_=i.maxResolution,this.minResolution_=i.minResolution,this.zoomFactor_=i.zoomFactor,this.resolutions_=t.resolutions,this.padding_=t.padding,this.minZoom_=i.minZoom;const s=um(t),r=i.constraint,o=fm(t);this.constraints_={center:s,resolution:r,rotation:o},this.setRotation(t.rotation!==void 0?t.rotation:0),this.setCenterInternal(t.center!==void 0?t.center:null),t.resolution!==void 0?this.setResolution(t.resolution):t.zoom!==void 0&&this.setZoom(t.zoom)}get padding(){return this.padding_}set padding(t){let e=this.padding_;this.padding_=t;const i=this.getCenterInternal();if(i){const s=t||[0,0,0,0];e=e||[0,0,0,0];const r=this.getResolution(),o=r/2*(s[3]-e[3]+e[1]-s[1]),a=r/2*(s[0]-e[0]+e[2]-s[2]);this.setCenterInternal([i[0]+o,i[1]-a])}}getUpdatedOptions_(t){const e=this.getProperties();return e.resolution!==void 0?e.resolution=this.getResolution():e.zoom=this.getZoom(),e.center=this.getCenterInternal(),e.rotation=this.getRotation(),Object.assign({},e,t)}animate(t){this.isDef()&&!this.getAnimating()&&this.resolveConstraints(0);const e=new Array(arguments.length);for(let i=0;i<e.length;++i){let s=arguments[i];s.center&&(s=Object.assign({},s),s.center=Oe(s.center,this.getProjection())),s.anchor&&(s=Object.assign({},s),s.anchor=Oe(s.anchor,this.getProjection())),e[i]=s}this.animateInternal.apply(this,e)}animateInternal(t){let e=arguments.length,i;e>1&&typeof arguments[e-1]=="function"&&(i=arguments[e-1],--e);let s=0;for(;s<e&&!this.isDef();++s){const c=arguments[s];c.center&&this.setCenterInternal(c.center),c.zoom!==void 0?this.setZoom(c.zoom):c.resolution&&this.setResolution(c.resolution),c.rotation!==void 0&&this.setRotation(c.rotation)}if(s===e){i&&Sr(i,!0);return}let r=Date.now(),o=this.targetCenter_.slice(),a=this.targetResolution_,l=this.targetRotation_;const h=[];for(;s<e;++s){const c=arguments[s],u={start:r,complete:!1,anchor:c.anchor,duration:c.duration!==void 0?c.duration:1e3,easing:c.easing||sm,callback:i};if(c.center&&(u.sourceCenter=o,u.targetCenter=c.center.slice(),o=u.targetCenter),c.zoom!==void 0?(u.sourceResolution=a,u.targetResolution=this.getResolutionForZoom(c.zoom),a=u.targetResolution):c.resolution&&(u.sourceResolution=a,u.targetResolution=c.resolution,a=u.targetResolution),c.rotation!==void 0){u.sourceRotation=l;const d=ji(c.rotation-l+Math.PI,2*Math.PI)-Math.PI;u.targetRotation=l+d,l=u.targetRotation}gm(u)?u.complete=!0:r+=u.duration,h.push(u)}this.animations_.push(h),this.setHint(vt.ANIMATING,1),this.updateAnimations_()}getAnimating(){return this.hints_[vt.ANIMATING]>0}getInteracting(){return this.hints_[vt.INTERACTING]>0}cancelAnimations(){this.setHint(vt.ANIMATING,-this.hints_[vt.ANIMATING]);let t;for(let e=0,i=this.animations_.length;e<i;++e){const s=this.animations_[e];if(s[0].callback&&Sr(s[0].callback,!1),!t)for(let r=0,o=s.length;r<o;++r){const a=s[r];if(!a.complete){t=a.anchor;break}}}this.animations_.length=0,this.cancelAnchor_=t,this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN}updateAnimations_(){if(this.updateAnimationKey_!==void 0&&(cancelAnimationFrame(this.updateAnimationKey_),this.updateAnimationKey_=void 0),!this.getAnimating())return;const t=Date.now();let e=!1;for(let i=this.animations_.length-1;i>=0;--i){const s=this.animations_[i];let r=!0;for(let o=0,a=s.length;o<a;++o){const l=s[o];if(l.complete)continue;const h=t-l.start;let c=l.duration>0?h/l.duration:1;c>=1?(l.complete=!0,c=1):r=!1;const u=l.easing(c);if(l.sourceCenter){const d=l.sourceCenter[0],f=l.sourceCenter[1],g=l.targetCenter[0],m=l.targetCenter[1];this.nextCenter_=l.targetCenter;const _=d+u*(g-d),p=f+u*(m-f);this.targetCenter_=[_,p]}if(l.sourceResolution&&l.targetResolution){const d=u===1?l.targetResolution:l.sourceResolution+u*(l.targetResolution-l.sourceResolution);if(l.anchor){const f=this.getViewportSize_(this.getRotation()),g=this.constraints_.resolution(d,0,f,!0);this.targetCenter_=this.calculateCenterZoom(g,l.anchor)}this.nextResolution_=l.targetResolution,this.targetResolution_=d,this.applyTargetState_(!0)}if(l.sourceRotation!==void 0&&l.targetRotation!==void 0){const d=u===1?ji(l.targetRotation+Math.PI,2*Math.PI)-Math.PI:l.sourceRotation+u*(l.targetRotation-l.sourceRotation);if(l.anchor){const f=this.constraints_.rotation(d,!0);this.targetCenter_=this.calculateCenterRotate(f,l.anchor)}this.nextRotation_=l.targetRotation,this.targetRotation_=d}if(this.applyTargetState_(!0),e=!0,!l.complete)break}if(r){this.animations_[i]=null,this.setHint(vt.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;const o=s[0].callback;o&&Sr(o,!0)}}this.animations_=this.animations_.filter(Boolean),e&&this.updateAnimationKey_===void 0&&(this.updateAnimationKey_=requestAnimationFrame(this.updateAnimations_.bind(this)))}calculateCenterRotate(t,e){let i;const s=this.getCenterInternal();return s!==void 0&&(i=[s[0]-e[0],s[1]-e[1]],ao(i,t-this.getRotation()),jd(i,e)),i}calculateCenterZoom(t,e){let i;const s=this.getCenterInternal(),r=this.getResolution();if(s!==void 0&&r!==void 0){const o=e[0]-t*(e[0]-s[0])/r,a=e[1]-t*(e[1]-s[1])/r;i=[o,a]}return i}getViewportSize_(t){const e=this.viewportSize_;if(t){const i=e[0],s=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(s*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(s*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){const t=this.getCenterInternal();return t&&wo(t,this.getProjection())}getCenterInternal(){return this.get(pe.CENTER)}getConstraints(){return this.constraints_}getConstrainResolution(){return this.get("constrainResolution")}getHints(t){return t!==void 0?(t[0]=this.hints_[0],t[1]=this.hints_[1],t):this.hints_.slice()}calculateExtent(t){const e=this.calculateExtentInternal(t);return ah(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();const e=this.getCenterInternal();Q(e,"The view center is not defined");const i=this.getResolution();Q(i!==void 0,"The view resolution is not defined");const s=this.getRotation();return Q(s!==void 0,"The view rotation is not defined"),ro(e,i,s,t)}getMaxResolution(){return this.maxResolution_}getMinResolution(){return this.minResolution_}getMaxZoom(){return this.getZoomForResolution(this.minResolution_)}setMaxZoom(t){this.applyOptions_(this.getUpdatedOptions_({maxZoom:t}))}getMinZoom(){return this.getZoomForResolution(this.maxResolution_)}setMinZoom(t){this.applyOptions_(this.getUpdatedOptions_({minZoom:t}))}setConstrainResolution(t){this.applyOptions_(this.getUpdatedOptions_({constrainResolution:t}))}getProjection(){return this.projection_}getResolution(){return this.get(pe.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal(ni(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();const i=tt(t)/e[0],s=At(t)/e[1];return Math.max(i,s)}getResolutionForValueFunction(t){t=t||2;const e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,s=Math.log(e/i)/Math.log(t);return(function(r){return e/Math.pow(t,r*s)})}getRotation(){return this.get(pe.ROTATION)}getValueForResolutionFunction(t){const e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),s=this.minResolution_,r=Math.log(i/s)/e;return(function(o){return Math.log(i/o)/e/r})}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t);const i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){const t=this.getProjection(),e=this.getResolution(),i=this.getRotation();let s=this.getCenterInternal();const r=this.padding_;if(r){const o=this.getViewportSizeMinusPadding_();s=sa(s,this.getViewportSize_(),[o[0]/2+r[3],o[1]/2+r[0]],e,i)}return{center:s.slice(0),projection:t!==void 0?t:null,resolution:e,nextCenter:this.nextCenter_,nextResolution:this.nextResolution_,nextRotation:this.nextRotation_,rotation:i,zoom:this.getZoom()}}getViewStateAndExtent(){return{viewState:this.getState(),extent:this.calculateExtent()}}getZoom(){let t;const e=this.getResolution();return e!==void 0&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e=this.minZoom_||0,i,s;if(this.resolutions_){const r=Jr(this.resolutions_,t,1);e=r,i=this.resolutions_[r],r==this.resolutions_.length-1?s=2:s=i/this.resolutions_[r+1]}else i=this.maxResolution_,s=this.zoomFactor_;return e+Math.log(i/t)/Math.log(s)}getResolutionForZoom(t){if(this.resolutions_?.length){if(this.resolutions_.length===1)return this.resolutions_[0];const e=ot(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,ot(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if(Q(Array.isArray(t)||typeof t.getSimplifiedGeometry=="function","Invalid extent or geometry provided as `geometry`"),Array.isArray(t)){Q(!Vs(t),"Cannot fit empty extent provided as `geometry`");const s=ni(t,this.getProjection());i=Ch(s)}else if(t.getType()==="Circle"){const s=ni(t.getExtent(),this.getProjection());i=Ch(s),i.rotate(this.getRotation(),wi(s))}else i=t;this.fitInternal(i,e)}rotatedExtentForGeometry(t){const e=this.getRotation(),i=Math.cos(e),s=Math.sin(-e),r=t.getFlatCoordinates(),o=t.getStride();let a=1/0,l=1/0,h=-1/0,c=-1/0;for(let u=0,d=r.length;u<d;u+=o){const f=r[u]*i-r[u+1]*s,g=r[u]*s+r[u+1]*i;a=Math.min(a,f),l=Math.min(l,g),h=Math.max(h,f),c=Math.max(c,g)}return[a,l,h,c]}fitInternal(t,e){e=e||{};let i=e.size;i||(i=this.getViewportSizeMinusPadding_());const s=e.padding!==void 0?e.padding:[0,0,0,0],r=e.nearest!==void 0?e.nearest:!1;let o;e.minResolution!==void 0?o=e.minResolution:e.maxZoom!==void 0?o=this.getResolutionForZoom(e.maxZoom):o=0;const a=this.rotatedExtentForGeometry(t);let l=this.getResolutionForExtentInternal(a,[i[0]-s[1]-s[3],i[1]-s[0]-s[2]]);l=isNaN(l)?o:Math.max(l,o),l=this.getConstrainedResolution(l,r?0:1);const h=this.getRotation(),c=Math.sin(h),u=Math.cos(h),d=wi(a);d[0]+=(s[1]-s[3])/2*l,d[1]+=(s[0]-s[2])/2*l;const f=d[0]*u-d[1]*c,g=d[1]*u+d[0]*c,m=this.getConstrainedCenter([f,g],l),_=e.callback?e.callback:Fn;e.duration!==void 0?this.animateInternal({resolution:l,center:m,duration:e.duration,easing:e.easing},_):(this.targetResolution_=l,this.targetCenter_=m,this.applyTargetState_(!1,!0),Sr(_,!0))}centerOn(t,e,i){this.centerOnInternal(Oe(t,this.getProjection()),e,i)}centerOnInternal(t,e,i){this.setCenterInternal(sa(t,e,i,this.getResolution(),this.getRotation()))}calculateCenterShift(t,e,i,s){let r;const o=this.padding_;if(o&&t){const a=this.getViewportSizeMinusPadding_(-i),l=sa(t,s,[a[0]/2+o[3],a[1]/2+o[0]],e,i);r=[t[0]-l[0],t[1]-l[1]]}return r}isDef(){return!!this.getCenterInternal()&&this.getResolution()!==void 0}adjustCenter(t){const e=wo(this.targetCenter_,this.getProjection());this.setCenter([e[0]+t[0],e[1]+t[1]])}adjustCenterInternal(t){const e=this.targetCenter_;this.setCenterInternal([e[0]+t[0],e[1]+t[1]])}adjustResolution(t,e){e=e&&Oe(e,this.getProjection()),this.adjustResolutionInternal(t,e)}adjustResolutionInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.getViewportSize_(this.getRotation()),r=this.constraints_.resolution(this.targetResolution_*t,0,s,i);e&&(this.targetCenter_=this.calculateCenterZoom(r,e)),this.targetResolution_*=t,this.applyTargetState_()}adjustZoom(t,e){this.adjustResolution(Math.pow(this.zoomFactor_,-t),e)}adjustRotation(t,e){e&&(e=Oe(e,this.getProjection())),this.adjustRotationInternal(t,e)}adjustRotationInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.constraints_.rotation(this.targetRotation_+t,i);e&&(this.targetCenter_=this.calculateCenterRotate(s,e)),this.targetRotation_+=t,this.applyTargetState_()}setCenter(t){this.setCenterInternal(t&&Oe(t,this.getProjection()))}setCenterInternal(t){this.targetCenter_=t,this.applyTargetState_()}setHint(t,e){return this.hints_[t]+=e,this.changed(),this.hints_[t]}setResolution(t){this.targetResolution_=t,this.applyTargetState_()}setRotation(t){this.targetRotation_=t,this.applyTargetState_()}setZoom(t){this.setResolution(this.getResolutionForZoom(t))}applyTargetState_(t,e){const i=this.getAnimating()||this.getInteracting()||e,s=this.constraints_.rotation(this.targetRotation_,i),r=this.getViewportSize_(s),o=this.constraints_.resolution(this.targetResolution_,0,r,i),a=this.constraints_.center(this.targetCenter_,o,r,i,this.calculateCenterShift(this.targetCenter_,o,s,r));this.get(pe.ROTATION)!==s&&this.set(pe.ROTATION,s),this.get(pe.RESOLUTION)!==o&&(this.set(pe.RESOLUTION,o),this.set("zoom",this.getZoom(),!0)),(!a||!this.get(pe.CENTER)||!Js(this.get(pe.CENTER),a))&&this.set(pe.CENTER,a),this.getAnimating()&&!t&&this.cancelAnimations(),this.cancelAnchor_=void 0}resolveConstraints(t,e,i){t=t!==void 0?t:200;const s=e||0,r=this.constraints_.rotation(this.targetRotation_),o=this.getViewportSize_(r),a=this.constraints_.resolution(this.targetResolution_,s,o),l=this.constraints_.center(this.targetCenter_,a,o,!1,this.calculateCenterShift(this.targetCenter_,a,r,o));if(t===0&&!this.cancelAnchor_){this.targetResolution_=a,this.targetRotation_=r,this.targetCenter_=l,this.applyTargetState_();return}i=i||(t===0?this.cancelAnchor_:void 0),this.cancelAnchor_=void 0,(this.getResolution()!==a||this.getRotation()!==r||!this.getCenterInternal()||!Js(this.getCenterInternal(),l))&&(this.getAnimating()&&this.cancelAnimations(),this.animateInternal({rotation:r,center:l,resolution:a,duration:t,easing:fn,anchor:i}))}beginInteraction(){this.resolveConstraints(0),this.setHint(vt.INTERACTING,1)}endInteraction(t,e,i){i=i&&Oe(i,this.getProjection()),this.endInteractionInternal(t,e,i)}endInteractionInternal(t,e,i){this.getInteracting()&&(this.setHint(vt.INTERACTING,-1),this.resolveConstraints(t,e,i))}getConstrainedCenter(t,e){const i=this.getViewportSize_(this.getRotation());return this.constraints_.center(t,e||this.getResolution(),i)}getConstrainedZoom(t,e){const i=this.getResolutionForZoom(t);return this.getZoomForResolution(this.getConstrainedResolution(i,e))}getConstrainedResolution(t,e){e=e||0;const i=this.getViewportSize_(this.getRotation());return this.constraints_.resolution(t,e,i)}}function Sr(n,t){setTimeout(function(){n(t)},0)}function um(n){if(n.extent!==void 0){const e=n.smoothExtentConstraint!==void 0?n.smoothExtentConstraint:!0;return Lc(n.extent,n.constrainOnlyCenter,e)}const t=yo(n.projection,"EPSG:3857");if(n.multiWorld!==!0&&t.isGlobal()){const e=t.getExtent().slice();return e[0]=-1/0,e[2]=1/0,Lc(e,!1,!1)}return nm}function dm(n){let t,e,i,o=n.minZoom!==void 0?n.minZoom:na,a=n.maxZoom!==void 0?n.maxZoom:28;const l=n.zoomFactor!==void 0?n.zoomFactor:2,h=n.multiWorld!==void 0?n.multiWorld:!1,c=n.smoothResolutionConstraint!==void 0?n.smoothResolutionConstraint:!0,u=n.showFullExtent!==void 0?n.showFullExtent:!1,d=yo(n.projection,"EPSG:3857"),f=d.getExtent();let g=n.constrainOnlyCenter,m=n.extent;if(!h&&!m&&d.isGlobal()&&(g=!1,m=f),n.resolutions!==void 0){const _=n.resolutions;e=_[o],i=_[a]!==void 0?_[a]:_[_.length-1],n.constrainResolution?t=om(_,c,!g&&m,u):t=Mc(e,i,c,!g&&m,u)}else{const p=(f?Math.max(tt(f),At(f)):360*lo.degrees/d.getMetersPerUnit())/ia/Math.pow(2,na),y=p/Math.pow(2,28-na);e=n.maxResolution,e!==void 0?o=0:e=p/Math.pow(l,o),i=n.minResolution,i===void 0&&(n.maxZoom!==void 0?n.maxResolution!==void 0?i=e/Math.pow(l,a):i=p/Math.pow(l,a):i=y),a=o+Math.floor(Math.log(e/i)/Math.log(l)),i=e/Math.pow(l,a-o),n.constrainResolution?t=am(l,e,i,c,!g&&m,u):t=Mc(e,i,c,!g&&m,u)}return{constraint:t,maxResolution:e,minResolution:i,minZoom:o,zoomFactor:l}}function fm(n){if(n.enableRotation!==void 0?n.enableRotation:!0){const e=n.constrainRotation;return e===void 0||e===!0?hm():e===!1?Pc:typeof e=="number"?lm(e):Pc}return ea}function gm(n){return!(n.sourceCenter&&n.targetCenter&&!Js(n.sourceCenter,n.targetCenter)||n.sourceResolution!==n.targetResolution||n.sourceRotation!==n.targetRotation)}function sa(n,t,e,i,s){const r=Math.cos(-s);let o=Math.sin(-s),a=n[0]*r-n[1]*o,l=n[1]*r+n[0]*o;a+=(t[0]/2-e[0])*i,l+=(e[1]-t[1]/2)*i,o=-o;const h=a*r-l*o,c=l*r+a*o;return[h,c]}const et={OPACITY:"opacity",VISIBLE:"visible",EXTENT:"extent",Z_INDEX:"zIndex",MAX_RESOLUTION:"maxResolution",MIN_RESOLUTION:"minResolution",MAX_ZOOM:"maxZoom",MIN_ZOOM:"minZoom",SOURCE:"source",MAP:"map"};class Oc extends de{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;const e=Object.assign({},t);typeof t.properties=="object"&&(delete e.properties,Object.assign(e,t.properties)),e[et.OPACITY]=t.opacity!==void 0?t.opacity:1,Q(typeof e[et.OPACITY]=="number","Layer opacity must be a number"),e[et.VISIBLE]=t.visible!==void 0?t.visible:!0,e[et.Z_INDEX]=t.zIndex,e[et.MAX_RESOLUTION]=t.maxResolution!==void 0?t.maxResolution:1/0,e[et.MIN_RESOLUTION]=t.minResolution!==void 0?t.minResolution:0,e[et.MIN_ZOOM]=t.minZoom!==void 0?t.minZoom:-1/0,e[et.MAX_ZOOM]=t.maxZoom!==void 0?t.maxZoom:1/0,this.className_=e.className!==void 0?e.className:"ol-layer",delete e.className,this.setProperties(e),this.state_=null}getBackground(){return this.background_}getClassName(){return this.className_}getLayerState(t){const e=this.state_||{layer:this,managed:t===void 0?!0:t},i=this.getZIndex();return e.opacity=ot(Math.round(this.getOpacity()*100)/100,0,1),e.visible=this.getVisible(),e.extent=this.getExtent(),e.zIndex=i===void 0&&!e.managed?1/0:i,e.maxResolution=this.getMaxResolution(),e.minResolution=Math.max(this.getMinResolution(),0),e.minZoom=this.getMinZoom(),e.maxZoom=this.getMaxZoom(),this.state_=e,e}getLayersArray(t){return V()}getLayerStatesArray(t){return V()}getExtent(){return this.get(et.EXTENT)}getMaxResolution(){return this.get(et.MAX_RESOLUTION)}getMinResolution(){return this.get(et.MIN_RESOLUTION)}getMinZoom(){return this.get(et.MIN_ZOOM)}getMaxZoom(){return this.get(et.MAX_ZOOM)}getOpacity(){return this.get(et.OPACITY)}getSourceState(){return V()}getVisible(){return this.get(et.VISIBLE)}getZIndex(){return this.get(et.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set(et.EXTENT,t)}setMaxResolution(t){this.set(et.MAX_RESOLUTION,t)}setMinResolution(t){this.set(et.MIN_RESOLUTION,t)}setMaxZoom(t){this.set(et.MAX_ZOOM,t)}setMinZoom(t){this.set(et.MIN_ZOOM,t)}setOpacity(t){Q(typeof t=="number","Layer opacity must be a number"),this.set(et.OPACITY,t)}setVisible(t){this.set(et.VISIBLE,t)}setZIndex(t){this.set(et.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}}class br extends Oc{constructor(t){const e=Object.assign({},t);delete e.source,super(e),this.on,this.once,this.un,this.mapPrecomposeKey_=null,this.mapRenderKey_=null,this.sourceChangeKey_=null,this.renderer_=null,this.sourceReady_=!1,this.rendered=!1,t.render&&(this.render=t.render),t.map&&this.setMap(t.map),this.addChangeListener(et.SOURCE,this.handleSourcePropertyChange_);const i=t.source?t.source:null;this.setSource(i)}getLayersArray(t){return t=t||[],t.push(this),t}getLayerStatesArray(t){return t=t||[],t.push(this.getLayerState()),t}getSource(){return this.get(et.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){const t=this.getSource();return t?t.getState():"undefined"}handleSourceChange_(){this.changed(),!(this.sourceReady_||this.getSource().getState()!=="ready")&&(this.sourceReady_=!0,this.dispatchEvent("sourceready"))}handleSourcePropertyChange_(){this.sourceChangeKey_&&(nt(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;const t=this.getSource();t&&(this.sourceChangeKey_=U(t,W.CHANGE,this.handleSourceChange_,this),t.getState()==="ready"&&(this.sourceReady_=!0,setTimeout(()=>{this.dispatchEvent("sourceready")},0))),this.changed()}getFeatures(t){return this.renderer_?this.renderer_.getFeatures(t):Promise.resolve([])}getData(t){return!this.renderer_||!this.rendered?null:this.renderer_.getData(t)}isVisible(t){let e;const i=this.getMapInternal();!t&&i&&(t=i.getView()),t instanceof we?e={viewState:t.getState(),extent:t.calculateExtent()}:e=t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray());let s;if(e.layerStatesArray){if(s=e.layerStatesArray.find(o=>o.layer===this),!s)return!1}else s=this.getLayerState();const r=this.getExtent();return ra(s,e.viewState)&&(!r||kt(r,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];const e=this.getSource()?.getAttributions();if(!e)return[];const i=t instanceof we?t.getViewStateAndExtent():t;let s=e(i);return Array.isArray(s)||(s=[s]),s}render(t,e){const i=this.getRenderer();return i.prepareFrame(t)?(this.rendered=!0,i.renderFrame(t,e)):null}unrender(){this.rendered=!1}getDeclutter(){}renderDeclutter(t,e){}renderDeferred(t){const e=this.getRenderer();e&&e.renderDeferred(t)}setMapInternal(t){t||this.unrender(),this.set(et.MAP,t)}getMapInternal(){return this.get(et.MAP)}setMap(t){this.mapPrecomposeKey_&&(nt(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&(nt(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=U(t,ie.PRECOMPOSE,this.handlePrecompose_,this),this.mapRenderKey_=U(this,W.CHANGE,t.render,t),this.changed())}handlePrecompose_(t){const e=t.frameState.layerStatesArray,i=this.getLayerState(!1);Q(!e.some(s=>s.layer===i.layer),"A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both."),e.push(i)}setSource(t){this.set(et.SOURCE,t)}getRenderer(){return this.renderer_||(this.renderer_=this.createRenderer()),this.renderer_}hasRenderer(){return!!this.renderer_}createRenderer(){return null}clearRenderer(){this.renderer_&&(this.renderer_.dispose(),delete this.renderer_)}disposeInternal(){this.clearRenderer(),this.setSource(null),super.disposeInternal()}}function ra(n,t){if(!n.visible)return!1;const e=t.resolution;if(e<n.minResolution||e>=n.maxResolution)return!1;const i=t.zoom;return i>n.minZoom&&i<=n.maxZoom}const Dc={RENDER_ORDER:"renderOrder"};class Fc extends br{constructor(t){t=t||{};const e=Object.assign({},t);delete e.style,delete e.renderBuffer,delete e.updateWhileAnimating,delete e.updateWhileInteracting,super(e),this.declutter_=t.declutter?String(t.declutter):void 0,this.renderBuffer_=t.renderBuffer!==void 0?t.renderBuffer:100,this.style_=null,this.styleFunction_=void 0,this.setStyle(t.style),this.updateWhileAnimating_=t.updateWhileAnimating!==void 0?t.updateWhileAnimating:!1,this.updateWhileInteracting_=t.updateWhileInteracting!==void 0?t.updateWhileInteracting:!1}getDeclutter(){return this.declutter_}getFeatures(t){return super.getFeatures(t)}getRenderBuffer(){return this.renderBuffer_}getRenderOrder(){return this.get(Dc.RENDER_ORDER)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t,e){const i=this.getDeclutter();i in t.declutter||(t.declutter[i]=new Hh(9)),this.getRenderer().renderDeclutter(t,e)}setRenderOrder(t){this.set(Dc.RENDER_ORDER,t)}setStyle(t){this.style_=t===void 0?ic:t;const e=_m(t);this.styleFunction_=t===null?void 0:qg(e),this.changed()}setDeclutter(t){this.declutter_=t?String(t):void 0,this.changed()}}function _m(n){if(n===void 0)return ic;if(!n)return null;if(typeof n=="function"||n instanceof Ee)return n;if(!Array.isArray(n))return vc([n]);if(n.length===0)return[];const t=n.length,e=n[0];if(e instanceof Ee){const s=new Array(t);for(let r=0;r<t;++r){const o=n[r];if(!(o instanceof Ee))throw new Error("Expected a list of style instances");s[r]=o}return s}if("style"in e){const s=new Array(t);for(let r=0;r<t;++r){const o=n[r];if(!("style"in o))throw new Error("Expected a list of rules with a style property");s[r]=o}return K_(s)}return vc(n)}class mm extends Fc{constructor(t){super(t)}createRenderer(){return new y_(this)}}const G={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};class oa extends Ws{constructor(t,e,i){super(),i=i||{},this.tileCoord=t,this.state=e,this.key="",this.transition_=i.transition===void 0?250:i.transition,this.transitionStarts_={},this.interpolate=!!i.interpolate}changed(){this.dispatchEvent(W.CHANGE)}release(){this.setState(G.EMPTY)}getKey(){return this.key+"/"+this.tileCoord}getTileCoord(){return this.tileCoord}getState(){return this.state}setState(t){if(this.state!==G.EMPTY){if(this.state!==G.ERROR&&this.state>t)throw new Error("Tile load sequence violation");this.state=t,this.changed()}}load(){V()}getAlpha(t,e){if(!this.transition_)return 1;let i=this.transitionStarts_[t];if(!i)i=e,this.transitionStarts_[t]=i;else if(i===-1)return 1;const s=e-i+1e3/60;return s>=this.transition_?1:Ac(s/this.transition_)}inTransition(t){return this.transition_?this.transitionStarts_[t]!==-1:!1}endTransition(t){this.transition_&&(this.transitionStarts_[t]=-1)}disposeInternal(){this.release(),super.disposeInternal()}}class kc extends oa{constructor(t,e,i,s,r,o){super(t,e,o),this.crossOrigin_=s,this.src_=i,this.key=i,this.image_,Bt?this.image_=new OffscreenCanvas(1,1):(this.image_=new Image,s!==null&&(this.image_.crossOrigin=s)),this.unlisten_=null,this.tileLoadFunction_=r}getImage(){return this.image_}setImage(t){this.image_=t,this.state=G.LOADED,this.unlistenImage_(),this.changed()}getCrossOrigin(){return this.crossOrigin_}handleImageError_(){this.state=G.ERROR,this.unlistenImage_(),this.image_=pm(),this.changed()}handleImageLoad_(){if(Bt)this.state=G.LOADED;else{const t=this.image_;t.naturalWidth&&t.naturalHeight?this.state=G.LOADED:this.state=G.EMPTY}this.unlistenImage_(),this.changed()}load(){this.state==G.ERROR&&(this.state=G.IDLE,this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_)),this.state==G.IDLE&&(this.state=G.LOADING,this.changed(),this.tileLoadFunction_(this,this.src_),this.unlisten_=fg(this.image_,this.handleImageLoad_.bind(this),this.handleImageError_.bind(this)))}unlistenImage_(){this.unlisten_&&(this.unlisten_(),this.unlisten_=null)}disposeInternal(){this.unlistenImage_(),this.image_=null,super.disposeInternal()}}function pm(){const n=ct(1,1);return n.fillStyle="rgba(0,0,0,0)",n.fillRect(0,0,1,1),n.canvas}class ym{constructor(t,e,i){this.decay_=t,this.minVelocity_=e,this.delay_=i,this.points_=[],this.angle_=0,this.initialVelocity_=0}begin(){this.points_.length=0,this.angle_=0,this.initialVelocity_=0}update(t,e){this.points_.push(t,e,Date.now())}end(){if(this.points_.length<6)return!1;const t=Date.now()-this.delay_,e=this.points_.length-3;if(this.points_[e+2]<t)return!1;let i=e-3;for(;i>0&&this.points_[i+2]>t;)i-=3;const s=this.points_[e+2]-this.points_[i+2];if(s<1e3/60)return!1;const r=this.points_[e]-this.points_[i],o=this.points_[e+1]-this.points_[i+1];return this.angle_=Math.atan2(o,r),this.initialVelocity_=Math.sqrt(r*r+o*o)/s,this.initialVelocity_>this.minVelocity_}getDistance(){return(this.minVelocity_-this.initialVelocity_)/this.decay_}getAngle(){return this.angle_}}class gn extends Pe{constructor(t,e,i){super(t),this.map=e,this.frameState=i!==void 0?i:null}}class ui extends gn{constructor(t,e,i,s,r,o){super(t,e,r),this.originalEvent=i,this.pixel_=null,this.coordinate_=null,this.dragging=s!==void 0?s:!1,this.activePointers=o}get pixel(){return this.pixel_||(this.pixel_=this.map.getEventPixel(this.originalEvent)),this.pixel_}set pixel(t){this.pixel_=t}get coordinate(){return this.coordinate_||(this.coordinate_=this.map.getCoordinateFromPixel(this.pixel)),this.coordinate_}set coordinate(t){this.coordinate_=t}preventDefault(){super.preventDefault(),"preventDefault"in this.originalEvent&&this.originalEvent.preventDefault()}stopPropagation(){super.stopPropagation(),"stopPropagation"in this.originalEvent&&this.originalEvent.stopPropagation()}}const at={SINGLECLICK:"singleclick",CLICK:W.CLICK,DBLCLICK:W.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"},aa={POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown"};class xm extends Ws{constructor(t,e){super(t),this.map_=t,this.clickTimeoutId_,this.emulateClicks_=!1,this.dragging_=!1,this.dragListenerKeys_=[],this.moveTolerance_=e===void 0?1:e,this.down_=null;const i=this.map_.getViewport();this.activePointers_=[],this.trackedTouches_={},this.element_=i,this.pointerdownListenerKey_=U(i,aa.POINTERDOWN,this.handlePointerDown_,this),this.originalPointerMoveEvent_,this.relayedListenerKey_=U(i,aa.POINTERMOVE,this.relayMoveEvent_,this),this.boundHandleTouchMove_=this.handleTouchMove_.bind(this),this.element_.addEventListener(W.TOUCHMOVE,this.boundHandleTouchMove_,Sh?{passive:!1}:!1)}emulateClick_(t){let e=new ui(at.CLICK,this.map_,t);this.dispatchEvent(e),this.clickTimeoutId_!==void 0?(clearTimeout(this.clickTimeoutId_),this.clickTimeoutId_=void 0,e=new ui(at.DBLCLICK,this.map_,t),this.dispatchEvent(e)):this.clickTimeoutId_=setTimeout(()=>{this.clickTimeoutId_=void 0;const i=new ui(at.SINGLECLICK,this.map_,t);this.dispatchEvent(i)},250)}updateActivePointers_(t){const e=t,i=e.pointerId;if(e.type==at.POINTERUP||e.type==at.POINTERCANCEL){delete this.trackedTouches_[i];for(const s in this.trackedTouches_)if(this.trackedTouches_[s].target!==e.target){delete this.trackedTouches_[s];break}}else(e.type==at.POINTERDOWN||e.type==at.POINTERMOVE)&&(this.trackedTouches_[i]=e);this.activePointers_=Object.values(this.trackedTouches_)}handlePointerUp_(t){this.updateActivePointers_(t);const e=new ui(at.POINTERUP,this.map_,t,void 0,void 0,this.activePointers_);this.dispatchEvent(e),this.emulateClicks_&&!e.defaultPrevented&&!this.dragging_&&this.isMouseActionButton_(t)&&this.emulateClick_(this.down_),this.activePointers_.length===0&&(this.dragListenerKeys_.forEach(nt),this.dragListenerKeys_.length=0,this.dragging_=!1,this.down_=null)}isMouseActionButton_(t){return t.button===0}handlePointerDown_(t){this.emulateClicks_=this.activePointers_.length===0,this.updateActivePointers_(t);const e=new ui(at.POINTERDOWN,this.map_,t,void 0,void 0,this.activePointers_);if(this.dispatchEvent(e),this.down_=new PointerEvent(t.type,t),Object.defineProperty(this.down_,"target",{writable:!1,value:t.target}),this.dragListenerKeys_.length===0){const i=this.map_.getOwnerDocument();this.dragListenerKeys_.push(U(i,at.POINTERMOVE,this.handlePointerMove_,this),U(i,at.POINTERUP,this.handlePointerUp_,this),U(this.element_,at.POINTERCANCEL,this.handlePointerUp_,this)),this.element_.getRootNode&&this.element_.getRootNode()!==i&&this.dragListenerKeys_.push(U(this.element_.getRootNode(),at.POINTERUP,this.handlePointerUp_,this))}}handlePointerMove_(t){if(this.isMoving_(t)){this.updateActivePointers_(t),this.dragging_=!0;const e=new ui(at.POINTERDRAG,this.map_,t,this.dragging_,void 0,this.activePointers_);this.dispatchEvent(e)}}relayMoveEvent_(t){this.originalPointerMoveEvent_=t;const e=!!(this.down_&&this.isMoving_(t));this.dispatchEvent(new ui(at.POINTERMOVE,this.map_,t,e))}handleTouchMove_(t){const e=this.originalPointerMoveEvent_;(!e||e.defaultPrevented)&&(typeof t.cancelable!="boolean"||t.cancelable===!0)&&t.preventDefault()}isMoving_(t){return this.dragging_||Math.abs(t.clientX-this.down_.clientX)>this.moveTolerance_||Math.abs(t.clientY-this.down_.clientY)>this.moveTolerance_}disposeInternal(){this.relayedListenerKey_&&(nt(this.relayedListenerKey_),this.relayedListenerKey_=null),this.element_.removeEventListener(W.TOUCHMOVE,this.boundHandleTouchMove_),this.pointerdownListenerKey_&&(nt(this.pointerdownListenerKey_),this.pointerdownListenerKey_=null),this.dragListenerKeys_.forEach(nt),this.dragListenerKeys_.length=0,this.element_=null,super.disposeInternal()}}const We={POSTRENDER:"postrender",MOVESTART:"movestart",MOVEEND:"moveend",LOADSTART:"loadstart",LOADEND:"loadend"},wt={LAYERGROUP:"layergroup",SIZE:"size",TARGET:"target",VIEW:"view"},Lr=1/0;class Em{constructor(t,e){this.priorityFunction_=t,this.keyFunction_=e,this.elements_=[],this.priorities_=[],this.queuedElements_={}}clear(){this.elements_.length=0,this.priorities_.length=0,kn(this.queuedElements_)}dequeue(){const t=this.elements_,e=this.priorities_,i=t[0];t.length==1?(t.length=0,e.length=0):(t[0]=t.pop(),e[0]=e.pop(),this.siftUp_(0));const s=this.keyFunction_(i);return delete this.queuedElements_[s],i}enqueue(t){Q(!(this.keyFunction_(t)in this.queuedElements_),"Tried to enqueue an `element` that was already added to the queue");const e=this.priorityFunction_(t);return e!=Lr?(this.elements_.push(t),this.priorities_.push(e),this.queuedElements_[this.keyFunction_(t)]=!0,this.siftDown_(0,this.elements_.length-1),!0):!1}getCount(){return this.elements_.length}getLeftChildIndex_(t){return t*2+1}getRightChildIndex_(t){return t*2+2}getParentIndex_(t){return t-1>>1}heapify_(){let t;for(t=(this.elements_.length>>1)-1;t>=0;t--)this.siftUp_(t)}isEmpty(){return this.elements_.length===0}isKeyQueued(t){return t in this.queuedElements_}isQueued(t){return this.isKeyQueued(this.keyFunction_(t))}siftUp_(t){const e=this.elements_,i=this.priorities_,s=e.length,r=e[t],o=i[t],a=t;for(;t<s>>1;){const l=this.getLeftChildIndex_(t),h=this.getRightChildIndex_(t),c=h<s&&i[h]<i[l]?h:l;e[t]=e[c],i[t]=i[c],t=c}e[t]=r,i[t]=o,this.siftDown_(a,t)}siftDown_(t,e){const i=this.elements_,s=this.priorities_,r=i[e],o=s[e];for(;e>t;){const a=this.getParentIndex_(e);if(s[a]>o)i[e]=i[a],s[e]=s[a],e=a;else break}i[e]=r,s[e]=o}reprioritize(){const t=this.priorityFunction_,e=this.elements_,i=this.priorities_;let s=0;const r=e.length;let o,a,l;for(a=0;a<r;++a)o=e[a],l=t(o),l==Lr?delete this.queuedElements_[this.keyFunction_(o)]:(i[s]=l,e[s++]=o);e.length=s,i.length=s,this.heapify_()}}class vm extends Em{constructor(t,e){super(i=>t.apply(null,i),i=>i[0].getKey()),this.boundHandleTileChange_=this.handleTileChange.bind(this),this.tileChangeCallback_=e,this.tilesLoading_=0,this.tilesLoadingKeys_={}}enqueue(t){const e=super.enqueue(t);return e&&t[0].addEventListener(W.CHANGE,this.boundHandleTileChange_),e}getTilesLoading(){return this.tilesLoading_}handleTileChange(t){const e=t.target,i=e.getState();if(i===G.LOADED||i===G.ERROR||i===G.EMPTY){i!==G.ERROR&&e.removeEventListener(W.CHANGE,this.boundHandleTileChange_);const s=e.getKey();s in this.tilesLoadingKeys_&&(delete this.tilesLoadingKeys_[s],--this.tilesLoading_),this.tileChangeCallback_()}}loadMoreTiles(t,e){let i=0;for(;this.tilesLoading_<t&&i<e&&this.getCount()>0;){const s=this.dequeue()[0],r=s.getKey();s.getState()===G.IDLE&&!(r in this.tilesLoadingKeys_)&&(this.tilesLoadingKeys_[r]=!0,++this.tilesLoading_,++i,s.load())}}}function wm(n,t,e,i,s){if(!n||!(e in n.wantedTiles)||!n.wantedTiles[e][t.getKey()])return Lr;const r=n.viewState.center,o=i[0]-r[0],a=i[1]-r[1];return 65536*Math.log(s)+Math.sqrt(o*o+a*a)/s}class la extends de{constructor(t){super();const e=t.element;e&&!t.target&&!e.style.pointerEvents&&(e.style.pointerEvents="auto"),this.element=e||null,this.target_=null,this.map_=null,this.listenerKeys=[],t.render&&(this.render=t.render),t.target&&this.setTarget(t.target)}disposeInternal(){this.element?.remove(),super.disposeInternal()}getMap(){return this.map_}setMap(t){this.map_&&this.element?.remove();for(let e=0,i=this.listenerKeys.length;e<i;++e)nt(this.listenerKeys[e]);if(this.listenerKeys.length=0,this.map_=t,t){const e=this.target_??t.getOverlayContainerStopEvent();this.element&&e.appendChild(this.element),this.render!==Fn&&this.listenerKeys.push(U(t,We.POSTRENDER,this.render,this)),t.render()}}render(t){}setTarget(t){this.target_=typeof t=="string"?document.getElementById(t):t}}class Cm extends la{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target}),this.ulElement_=document.createElement("ul"),this.collapsed_=t.collapsed!==void 0?t.collapsed:!0,this.userCollapsed_=this.collapsed_,this.overrideCollapsible_=t.collapsible!==void 0,this.collapsible_=t.collapsible!==void 0?t.collapsible:!0,this.collapsible_||(this.collapsed_=!1),this.attributions_=t.attributions;const e=t.className!==void 0?t.className:"ol-attribution",i=t.tipLabel!==void 0?t.tipLabel:"Attributions",s=t.expandClassName!==void 0?t.expandClassName:e+"-expand",r=t.collapseLabel!==void 0?t.collapseLabel:"›",o=t.collapseClassName!==void 0?t.collapseClassName:e+"-collapse";typeof r=="string"?(this.collapseLabel_=document.createElement("span"),this.collapseLabel_.textContent=r,this.collapseLabel_.className=o):this.collapseLabel_=r;const a=t.label!==void 0?t.label:"i";typeof a=="string"?(this.label_=document.createElement("span"),this.label_.textContent=a,this.label_.className=s):this.label_=a;const l=this.collapsible_&&!this.collapsed_?this.collapseLabel_:this.label_;this.toggleButton_=document.createElement("button"),this.toggleButton_.setAttribute("type","button"),this.toggleButton_.setAttribute("aria-expanded",String(!this.collapsed_)),this.toggleButton_.title=i,this.toggleButton_.appendChild(l),this.toggleButton_.addEventListener(W.CLICK,this.handleClick_.bind(this),!1);const h=e+" "+fr+" "+zo+(this.collapsed_&&this.collapsible_?" "+Fh:"")+(this.collapsible_?"":" ol-uncollapsible"),c=this.element;c.className=h,c.appendChild(this.toggleButton_),c.appendChild(this.ulElement_),this.renderedAttributions_=[],this.renderedVisible_=!0}collectSourceAttributions_(t){const e=this.getMap().getAllLayers(),i=new Set(e.flatMap(s=>s.getAttributions(t)));if(this.attributions_!==void 0&&(Array.isArray(this.attributions_)?this.attributions_.forEach(s=>i.add(s)):i.add(this.attributions_)),!this.overrideCollapsible_){const s=!e.some(r=>r.getSource()?.getAttributionsCollapsible()===!1);this.setCollapsible(s)}return Array.from(i)}async updateElement_(t){if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}const e=await Promise.all(this.collectSourceAttributions_(t).map(s=>Gd(()=>s))),i=e.length>0;if(this.renderedVisible_!=i&&(this.element.style.display=i?"":"none",this.renderedVisible_=i),!ti(e,this.renderedAttributions_)){Lh(this.ulElement_);for(let s=0,r=e.length;s<r;++s){const o=document.createElement("li");o.innerHTML=e[s],this.ulElement_.appendChild(o)}this.renderedAttributions_=e}}handleClick_(t){t.preventDefault(),this.handleToggle_(),this.userCollapsed_=this.collapsed_}handleToggle_(){this.element.classList.toggle(Fh),this.collapsed_?bh(this.collapseLabel_,this.label_):bh(this.label_,this.collapseLabel_),this.collapsed_=!this.collapsed_,this.toggleButton_.setAttribute("aria-expanded",String(!this.collapsed_))}getCollapsible(){return this.collapsible_}setCollapsible(t){this.collapsible_!==t&&(this.collapsible_=t,this.element.classList.toggle("ol-uncollapsible"),this.userCollapsed_&&this.handleToggle_())}setCollapsed(t){this.userCollapsed_=t,!(!this.collapsible_||this.collapsed_===t)&&this.handleToggle_()}getCollapsed(){return this.collapsed_}render(t){this.updateElement_(t.frameState)}}class Rm extends la{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target});const e=t.className!==void 0?t.className:"ol-rotate",i=t.label!==void 0?t.label:"⇧",s=t.compassClassName!==void 0?t.compassClassName:"ol-compass";this.label_=null,typeof i=="string"?(this.label_=document.createElement("span"),this.label_.className=s,this.label_.textContent=i):(this.label_=i,this.label_.classList.add(s));const r=t.tipLabel?t.tipLabel:"Reset rotation",o=document.createElement("button");o.className=e+"-reset",o.setAttribute("type","button"),o.title=r,o.appendChild(this.label_),o.addEventListener(W.CLICK,this.handleClick_.bind(this),!1);const a=e+" "+fr+" "+zo,l=this.element;l.className=a,l.appendChild(o),this.callResetNorth_=t.resetNorth?t.resetNorth:void 0,this.duration_=t.duration!==void 0?t.duration:250,this.autoHide_=t.autoHide!==void 0?t.autoHide:!0,this.rotation_=void 0,this.autoHide_&&this.element.classList.add(dr)}handleClick_(t){t.preventDefault(),this.callResetNorth_!==void 0?this.callResetNorth_():this.resetNorth_()}resetNorth_(){const e=this.getMap().getView();if(!e)return;const i=e.getRotation();i!==void 0&&(this.duration_>0&&i%(2*Math.PI)!==0?e.animate({rotation:0,duration:this.duration_,easing:fn}):e.setRotation(0))}render(t){const e=t.frameState;if(!e)return;const i=e.viewState.rotation;if(i!=this.rotation_){const s="rotate("+i+"rad)";if(this.autoHide_){const r=this.element.classList.contains(dr);!r&&i===0?this.element.classList.add(dr):r&&i!==0&&this.element.classList.remove(dr)}this.label_.style.transform=s}this.rotation_=i}}class Tm extends la{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target});const e=t.className!==void 0?t.className:"ol-zoom",i=t.delta!==void 0?t.delta:1,s=t.zoomInClassName!==void 0?t.zoomInClassName:e+"-in",r=t.zoomOutClassName!==void 0?t.zoomOutClassName:e+"-out",o=t.zoomInLabel!==void 0?t.zoomInLabel:"+",a=t.zoomOutLabel!==void 0?t.zoomOutLabel:"–",l=t.zoomInTipLabel!==void 0?t.zoomInTipLabel:"Zoom in",h=t.zoomOutTipLabel!==void 0?t.zoomOutTipLabel:"Zoom out",c=document.createElement("button");c.className=s,c.setAttribute("type","button"),c.title=l,c.appendChild(typeof o=="string"?document.createTextNode(o):o),c.addEventListener(W.CLICK,this.handleClick_.bind(this,i),!1);const u=document.createElement("button");u.className=r,u.setAttribute("type","button"),u.title=h,u.appendChild(typeof a=="string"?document.createTextNode(a):a),u.addEventListener(W.CLICK,this.handleClick_.bind(this,-i),!1);const d=e+" "+fr+" "+zo,f=this.element;f.className=d,f.appendChild(c),f.appendChild(u),this.duration_=t.duration!==void 0?t.duration:250}handleClick_(t,e){e.preventDefault(),this.zoomByDelta_(t)}zoomByDelta_(t){const i=this.getMap().getView();if(!i)return;const s=i.getZoom();if(s!==void 0){const r=i.getConstrainedZoom(s+t);this.duration_>0?(i.getAnimating()&&i.cancelAnimations(),i.animate({zoom:r,duration:this.duration_,easing:fn})):i.setZoom(r)}}}function Im(n){n=n||{};const t=new Qt;return(n.zoom!==void 0?n.zoom:!0)&&t.push(new Tm(n.zoomOptions)),(n.rotate!==void 0?n.rotate:!0)&&t.push(new Rm(n.rotateOptions)),(n.attribution!==void 0?n.attribution:!0)&&t.push(new Cm(n.attributionOptions)),t}const Nc={ACTIVE:"active"};class us extends de{constructor(t){super(),this.on,this.once,this.un,t&&t.handleEvent&&(this.handleEvent=t.handleEvent),this.map_=null,this.setActive(!0)}getActive(){return this.get(Nc.ACTIVE)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(Nc.ACTIVE,t)}setMap(t){this.map_=t}}function Sm(n,t,e){const i=n.getCenterInternal();if(i){const s=[i[0]+t[0],i[1]+t[1]];n.animateInternal({duration:e!==void 0?e:250,easing:rm,center:n.getConstrainedCenter(s)})}}function ha(n,t,e,i){const s=n.getZoom();if(s===void 0)return;const r=n.getConstrainedZoom(s+t),o=n.getResolutionForZoom(r);n.getAnimating()&&n.cancelAnimations(),n.animate({resolution:o,anchor:e,duration:i!==void 0?i:250,easing:fn})}class bm extends us{constructor(t){super(),t=t||{},this.delta_=t.delta?t.delta:1,this.duration_=t.duration!==void 0?t.duration:250}handleEvent(t){let e=!1;if(t.type==at.DBLCLICK){const i=t.originalEvent,s=t.map,r=t.coordinate,o=i.shiftKey?-this.delta_:this.delta_,a=s.getView();ha(a,o,r,this.duration_),i.preventDefault(),e=!0}return!e}}function ca(n){const t=arguments;return function(e){let i=!0;for(let s=0,r=t.length;s<r&&(i=i&&t[s](e),!!i);++s);return i}}const Lm=function(n){const t=n.originalEvent;return t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},Am=function(n){const t=n.map.getTargetElement(),e=t.getRootNode(),i=n.map.getOwnerDocument().activeElement;return e instanceof ShadowRoot?e.host.contains(i):t.contains(i)},Gc=function(n){const t=n.map.getTargetElement(),e=t.getRootNode();return(e instanceof ShadowRoot?e.host:t).hasAttribute("tabindex")?Am(n):!0},Mm=Dn,zc=function(n){const t=n.originalEvent;return"pointerId"in t&&t.button==0&&!(Qf&&Th&&t.ctrlKey)},Xc=function(n){const t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&!t.shiftKey},Pm=function(n){const t=n.originalEvent;return Th?t.metaKey:t.ctrlKey},Om=function(n){const t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},Wc=function(n){const t=n.originalEvent,e=t.target.tagName;return e!=="INPUT"&&e!=="SELECT"&&e!=="TEXTAREA"&&!t.target.isContentEditable},ua=function(n){const t=n.originalEvent;return"pointerId"in t&&t.pointerType=="mouse"},Dm=function(n){const t=n.originalEvent;return"pointerId"in t&&t.isPrimary&&t.button===0};class ds extends us{constructor(t){t=t||{},super(t),t.handleDownEvent&&(this.handleDownEvent=t.handleDownEvent),t.handleDragEvent&&(this.handleDragEvent=t.handleDragEvent),t.handleMoveEvent&&(this.handleMoveEvent=t.handleMoveEvent),t.handleUpEvent&&(this.handleUpEvent=t.handleUpEvent),t.stopDown&&(this.stopDown=t.stopDown),this.handlingDownUpSequence=!1,this.targetPointers=[]}getPointerCount(){return this.targetPointers.length}handleDownEvent(t){return!1}handleDragEvent(t){}handleEvent(t){if(!t.originalEvent)return!0;let e=!1;if(this.updateTrackedPointers_(t),this.handlingDownUpSequence){if(t.type==at.POINTERDRAG)this.handleDragEvent(t),t.originalEvent.preventDefault();else if(t.type==at.POINTERUP){const i=this.handleUpEvent(t);this.handlingDownUpSequence=i&&this.targetPointers.length>0}}else if(t.type==at.POINTERDOWN){const i=this.handleDownEvent(t);this.handlingDownUpSequence=i,e=this.stopDown(i)}else t.type==at.POINTERMOVE&&this.handleMoveEvent(t);return!e}handleMoveEvent(t){}handleUpEvent(t){return!1}stopDown(t){return t}updateTrackedPointers_(t){t.activePointers&&(this.targetPointers=t.activePointers)}}function da(n){const t=n.length;let e=0,i=0;for(let s=0;s<t;s++)e+=n[s].clientX,i+=n[s].clientY;return{clientX:e/t,clientY:i/t}}class Fm extends ds{constructor(t){super({stopDown:Xs}),t=t||{},this.kinetic_=t.kinetic,this.lastCentroid=null,this.lastPointersCount_,this.panning_=!1;const e=t.condition?t.condition:ca(Xc,Dm);this.condition_=t.onFocusOnly?ca(Gc,e):e,this.noKinetic_=!1}handleDragEvent(t){const e=t.map;this.panning_||(this.panning_=!0,e.getView().beginInteraction());const i=this.targetPointers,s=e.getEventPixel(da(i));if(i.length==this.lastPointersCount_){if(this.kinetic_&&this.kinetic_.update(s[0],s[1]),this.lastCentroid){const r=[this.lastCentroid[0]-s[0],s[1]-this.lastCentroid[1]],a=t.map.getView();Hd(r,a.getResolution()),ao(r,a.getRotation()),a.adjustCenterInternal(r)}}else this.kinetic_&&this.kinetic_.begin();this.lastCentroid=s,this.lastPointersCount_=i.length,t.originalEvent.preventDefault()}handleUpEvent(t){const e=t.map,i=e.getView();if(this.targetPointers.length===0){if(!this.noKinetic_&&this.kinetic_&&this.kinetic_.end()){const s=this.kinetic_.getDistance(),r=this.kinetic_.getAngle(),o=i.getCenterInternal(),a=e.getPixelFromCoordinateInternal(o),l=e.getCoordinateFromPixelInternal([a[0]-s*Math.cos(r),a[1]-s*Math.sin(r)]);i.animateInternal({center:i.getConstrainedCenter(l),duration:500,easing:fn})}return this.panning_&&(this.panning_=!1,i.endInteraction()),!1}return this.kinetic_&&this.kinetic_.begin(),this.lastCentroid=null,!0}handleDownEvent(t){if(this.targetPointers.length>0&&this.condition_(t)){const i=t.map.getView();return this.lastCentroid=null,i.getAnimating()&&i.cancelAnimations(),this.kinetic_&&this.kinetic_.begin(),this.noKinetic_=this.targetPointers.length>1,!0}return!1}}class km extends ds{constructor(t){t=t||{},super({stopDown:Xs}),this.condition_=t.condition?t.condition:Lm,this.lastAngle_=void 0,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){if(!ua(t))return;const e=t.map,i=e.getView();if(i.getConstraints().rotation===ea)return;const s=e.getSize(),r=t.pixel,o=Math.atan2(s[1]/2-r[1],r[0]-s[0]/2);if(this.lastAngle_!==void 0){const a=o-this.lastAngle_;i.adjustRotationInternal(-a)}this.lastAngle_=o}handleUpEvent(t){return ua(t)?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){return ua(t)&&zc(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,!0):!1}}class Nm extends zs{constructor(t){super(),this.geometry_=null,this.element_=document.createElement("div"),this.element_.style.position="absolute",this.element_.style.pointerEvents="auto",this.element_.className="ol-box "+t,this.map_=null,this.startPixel_=null,this.endPixel_=null}disposeInternal(){this.setMap(null)}render_(){const t=this.startPixel_,e=this.endPixel_,i="px",s=this.element_.style;s.left=Math.min(t[0],e[0])+i,s.top=Math.min(t[1],e[1])+i,s.width=Math.abs(e[0]-t[0])+i,s.height=Math.abs(e[1]-t[1])+i}setMap(t){if(this.map_){this.map_.getOverlayContainer().removeChild(this.element_);const e=this.element_.style;e.left="inherit",e.top="inherit",e.width="inherit",e.height="inherit"}this.map_=t,this.map_&&this.map_.getOverlayContainer().appendChild(this.element_)}setPixels(t,e){this.startPixel_=t,this.endPixel_=e,this.createOrUpdateGeometry(),this.render_()}createOrUpdateGeometry(){if(!this.map_)return;const t=this.startPixel_,e=this.endPixel_,s=[t,[t[0],e[1]],e,[e[0],t[1]]].map(this.map_.getCoordinateFromPixelInternal,this.map_);s[4]=s[0].slice(),this.geometry_?this.geometry_.setCoordinates([s]):this.geometry_=new Kn([s])}getGeometry(){return this.geometry_}}const _n={BOXSTART:"boxstart",BOXDRAG:"boxdrag",BOXEND:"boxend",BOXCANCEL:"boxcancel"};class fs extends Pe{constructor(t,e,i){super(t),this.coordinate=e,this.mapBrowserEvent=i}}class Gm extends ds{constructor(t){super(),this.on,this.once,this.un,t=t??{},this.box_=new Nm(t.className||"ol-dragbox"),this.minArea_=t.minArea??64,t.onBoxEnd&&(this.onBoxEnd=t.onBoxEnd),this.startPixel_=null,this.condition_=t.condition??zc,this.boxEndCondition_=t.boxEndCondition??this.defaultBoxEndCondition}defaultBoxEndCondition(t,e,i){const s=i[0]-e[0],r=i[1]-e[1];return s*s+r*r>=this.minArea_}getGeometry(){return this.box_.getGeometry()}handleDragEvent(t){this.startPixel_&&(this.box_.setPixels(this.startPixel_,t.pixel),this.dispatchEvent(new fs(_n.BOXDRAG,t.coordinate,t)))}handleUpEvent(t){if(!this.startPixel_)return!1;const e=this.boxEndCondition_(t,this.startPixel_,t.pixel);return e&&this.onBoxEnd(t),this.dispatchEvent(new fs(e?_n.BOXEND:_n.BOXCANCEL,t.coordinate,t)),this.box_.setMap(null),this.startPixel_=null,!1}handleDownEvent(t){return this.condition_(t)?(this.startPixel_=t.pixel,this.box_.setMap(t.map),this.box_.setPixels(this.startPixel_,this.startPixel_),this.dispatchEvent(new fs(_n.BOXSTART,t.coordinate,t)),!0):!1}onBoxEnd(t){}setActive(t){t||(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new fs(_n.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setActive(t)}setMap(t){this.getMap()&&(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new fs(_n.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setMap(t)}}class zm extends Gm{constructor(t){t=t||{};const e=t.condition?t.condition:Om;super({condition:e,className:t.className||"ol-dragzoom",minArea:t.minArea}),this.duration_=t.duration!==void 0?t.duration:200,this.out_=t.out!==void 0?t.out:!1}onBoxEnd(t){const i=this.getMap().getView();let s=this.getGeometry();if(this.out_){const r=i.rotatedExtentForGeometry(s),o=i.getResolutionForExtentInternal(r),a=i.getResolution()/o;s=s.clone(),s.scale(a*a)}i.fitInternal(s,{duration:this.duration_,easing:fn})}}const ki={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",DOWN:"ArrowDown"};class Xm extends us{constructor(t){super(),t=t||{},this.defaultCondition_=function(e){return Xc(e)&&Wc(e)},this.condition_=t.condition!==void 0?t.condition:this.defaultCondition_,this.duration_=t.duration!==void 0?t.duration:100,this.pixelDelta_=t.pixelDelta!==void 0?t.pixelDelta:128}handleEvent(t){let e=!1;if(t.type==W.KEYDOWN){const i=t.originalEvent,s=i.key;if(this.condition_(t)&&(s==ki.DOWN||s==ki.LEFT||s==ki.RIGHT||s==ki.UP)){const o=t.map.getView(),a=o.getResolution()*this.pixelDelta_;let l=0,h=0;s==ki.DOWN?h=-a:s==ki.LEFT?l=-a:s==ki.RIGHT?l=a:h=a;const c=[l,h];ao(c,o.getRotation()),Sm(o,c,this.duration_),i.preventDefault(),e=!0}}return!e}}class Wm extends us{constructor(t){super(),t=t||{},this.condition_=t.condition?t.condition:function(e){return!Pm(e)&&Wc(e)},this.delta_=t.delta?t.delta:1,this.duration_=t.duration!==void 0?t.duration:100}handleEvent(t){let e=!1;if(t.type==W.KEYDOWN||t.type==W.KEYPRESS){const i=t.originalEvent,s=i.key;if(this.condition_(t)&&(s==="+"||s==="-")){const r=t.map,o=s==="+"?this.delta_:-this.delta_,a=r.getView();ha(a,o,void 0,this.duration_),i.preventDefault(),e=!0}}return!e}}const Ym=40,$m=300;class Km extends us{constructor(t){t=t||{},super(t),this.totalDelta_=0,this.lastDelta_=0,this.maxDelta_=t.maxDelta!==void 0?t.maxDelta:1,this.duration_=t.duration!==void 0?t.duration:250,this.timeout_=t.timeout!==void 0?t.timeout:80,this.useAnchor_=t.useAnchor!==void 0?t.useAnchor:!0,this.constrainResolution_=t.constrainResolution!==void 0?t.constrainResolution:!1;const e=t.condition?t.condition:Mm;this.condition_=t.onFocusOnly?ca(Gc,e):e,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_,this.mode_=void 0,this.trackpadEventGap_=400,this.trackpadTimeoutId_,this.deltaPerZoom_=300}endInteraction_(){this.trackpadTimeoutId_=void 0;const t=this.getMap();if(!t)return;t.getView().endInteraction(void 0,this.lastDelta_?this.lastDelta_>0?1:-1:0,this.lastAnchor_?t.getCoordinateFromPixel(this.lastAnchor_):null)}handleEvent(t){if(!this.condition_(t)||t.type!==W.WHEEL)return!0;const i=t.map,s=t.originalEvent;s.preventDefault(),this.useAnchor_&&(this.lastAnchor_=t.pixel);let r=s.deltaY;switch(s.deltaMode){case WheelEvent.DOM_DELTA_LINE:r*=Ym;break;case WheelEvent.DOM_DELTA_PAGE:r*=$m;break}if(r===0)return!1;this.lastDelta_=r;const o=Date.now();this.startTime_===void 0&&(this.startTime_=o),(!this.mode_||o-this.startTime_>this.trackpadEventGap_)&&(this.mode_=Math.abs(r)<4?"trackpad":"wheel");const a=i.getView();if(this.mode_==="trackpad"&&!(a.getConstrainResolution()||this.constrainResolution_))return this.trackpadTimeoutId_?clearTimeout(this.trackpadTimeoutId_):(a.getAnimating()&&a.cancelAnimations(),a.beginInteraction()),this.trackpadTimeoutId_=setTimeout(this.endInteraction_.bind(this),this.timeout_),a.adjustZoom(-r/this.deltaPerZoom_,this.lastAnchor_?i.getCoordinateFromPixel(this.lastAnchor_):null),this.startTime_=o,!1;this.totalDelta_+=r;const l=Math.max(this.timeout_-(o-this.startTime_),0);return clearTimeout(this.timeoutId_),this.timeoutId_=setTimeout(this.handleWheelZoom_.bind(this,i),l),!1}handleWheelZoom_(t){const e=t.getView();e.getAnimating()&&e.cancelAnimations();let i=-ot(this.totalDelta_,-this.maxDelta_*this.deltaPerZoom_,this.maxDelta_*this.deltaPerZoom_)/this.deltaPerZoom_;(e.getConstrainResolution()||this.constrainResolution_)&&(i=i?i>0?1:-1:0),ha(e,i,this.lastAnchor_?t.getCoordinateFromPixel(this.lastAnchor_):null,this.duration_),this.mode_=void 0,this.totalDelta_=0,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_=void 0}setMouseAnchor(t){this.useAnchor_=t,t||(this.lastAnchor_=null)}}class Bm extends ds{constructor(t){t=t||{};const e=t;e.stopDown||(e.stopDown=Xs),super(e),this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.threshold_=t.threshold!==void 0?t.threshold:.3,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){let e=0;const i=this.targetPointers[0],s=this.targetPointers[1],r=Math.atan2(s.clientY-i.clientY,s.clientX-i.clientX);if(this.lastAngle_!==void 0){const l=r-this.lastAngle_;this.rotationDelta_+=l,!this.rotating_&&Math.abs(this.rotationDelta_)>this.threshold_&&(this.rotating_=!0),e=l}this.lastAngle_=r;const o=t.map,a=o.getView();a.getConstraints().rotation!==ea&&(this.anchor_=o.getCoordinateFromPixelInternal(o.getEventPixel(da(this.targetPointers))),this.rotating_&&(o.render(),a.adjustRotationInternal(e,this.anchor_)))}handleUpEvent(t){return this.targetPointers.length<2?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}}class Zm extends ds{constructor(t){t=t||{};const e=t;e.stopDown||(e.stopDown=Xs),super(e),this.anchor_=null,this.duration_=t.duration!==void 0?t.duration:400,this.lastDistance_=void 0,this.lastScaleDelta_=1}handleDragEvent(t){let e=1;const i=this.targetPointers[0],s=this.targetPointers[1],r=i.clientX-s.clientX,o=i.clientY-s.clientY,a=Math.sqrt(r*r+o*o);this.lastDistance_!==void 0&&(e=this.lastDistance_/a),this.lastDistance_=a;const l=t.map,h=l.getView();e!=1&&(this.lastScaleDelta_=e),this.anchor_=l.getCoordinateFromPixelInternal(l.getEventPixel(da(this.targetPointers))),l.render(),h.adjustResolutionInternal(e,this.anchor_)}handleUpEvent(t){if(this.targetPointers.length<2){const i=t.map.getView(),s=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,s),!1}return!0}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastDistance_=void 0,this.lastScaleDelta_=1,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}}function Um(n){n=n||{};const t=new Qt,e=new ym(-.005,.05,100);return(n.altShiftDragRotate!==void 0?n.altShiftDragRotate:!0)&&t.push(new km),(n.doubleClickZoom!==void 0?n.doubleClickZoom:!0)&&t.push(new bm({delta:n.zoomDelta,duration:n.zoomDuration})),(n.dragPan!==void 0?n.dragPan:!0)&&t.push(new Fm({onFocusOnly:n.onFocusOnly,kinetic:e})),(n.pinchRotate!==void 0?n.pinchRotate:!0)&&t.push(new Bm),(n.pinchZoom!==void 0?n.pinchZoom:!0)&&t.push(new Zm({duration:n.zoomDuration})),(n.keyboard!==void 0?n.keyboard:!0)&&(t.push(new Xm),t.push(new Wm({delta:n.zoomDelta,duration:n.zoomDuration}))),(n.mouseWheelZoom!==void 0?n.mouseWheelZoom:!0)&&t.push(new Km({onFocusOnly:n.onFocusOnly,duration:n.zoomDuration})),(n.shiftDragZoom!==void 0?n.shiftDragZoom:!0)&&t.push(new zm({duration:n.zoomDuration})),t}const di={ADDLAYER:"addlayer",REMOVELAYER:"removelayer"};class fi extends Pe{constructor(t,e){super(t),this.layer=e}}const fa={LAYERS:"layers"};class mn extends Oc{constructor(t){t=t||{};const e=Object.assign({},t);delete e.layers;let i=t.layers;super(e),this.on,this.once,this.un,this.layersListenerKeys_=[],this.listenerKeys_={},this.addChangeListener(fa.LAYERS,this.handleLayersChanged_),i?Array.isArray(i)?i=new Qt(i.slice(),{unique:!0}):Q(typeof i.getArray=="function","Expected `layers` to be an array or a `Collection`"):i=new Qt(void 0,{unique:!0}),this.setLayers(i)}handleLayerChange_(){this.changed()}handleLayersChanged_(){this.layersListenerKeys_.forEach(nt),this.layersListenerKeys_.length=0;const t=this.getLayers();this.layersListenerKeys_.push(U(t,Ft.ADD,this.handleLayersAdd_,this),U(t,Ft.REMOVE,this.handleLayersRemove_,this));for(const i in this.listenerKeys_)this.listenerKeys_[i].forEach(nt);kn(this.listenerKeys_);const e=t.getArray();for(let i=0,s=e.length;i<s;i++){const r=e[i];this.registerLayerListeners_(r),this.dispatchEvent(new fi(di.ADDLAYER,r))}this.changed()}registerLayerListeners_(t){const e=[U(t,Ki.PROPERTYCHANGE,this.handleLayerChange_,this),U(t,W.CHANGE,this.handleLayerChange_,this)];t instanceof mn&&e.push(U(t,di.ADDLAYER,this.handleLayerGroupAdd_,this),U(t,di.REMOVELAYER,this.handleLayerGroupRemove_,this)),this.listenerKeys_[j(t)]=e}handleLayerGroupAdd_(t){this.dispatchEvent(new fi(di.ADDLAYER,t.layer))}handleLayerGroupRemove_(t){this.dispatchEvent(new fi(di.REMOVELAYER,t.layer))}handleLayersAdd_(t){const e=t.element;this.registerLayerListeners_(e),this.dispatchEvent(new fi(di.ADDLAYER,e)),this.changed()}handleLayersRemove_(t){const e=t.element,i=j(e);this.listenerKeys_[i].forEach(nt),delete this.listenerKeys_[i],this.dispatchEvent(new fi(di.REMOVELAYER,e)),this.changed()}getLayers(){return this.get(fa.LAYERS)}setLayers(t){const e=this.getLayers();if(e){const i=e.getArray();for(let s=0,r=i.length;s<r;++s)this.dispatchEvent(new fi(di.REMOVELAYER,i[s]))}this.set(fa.LAYERS,t)}getLayersArray(t){return t=t!==void 0?t:[],this.getLayers().forEach(function(e){e.getLayersArray(t)}),t}getLayerStatesArray(t){const e=t!==void 0?t:[],i=e.length;this.getLayers().forEach(function(o){o.getLayerStatesArray(e)});const s=this.getLayerState();let r=s.zIndex;!t&&s.zIndex===void 0&&(r=0);for(let o=i,a=e.length;o<a;o++){const l=e[o];l.opacity*=s.opacity,l.visible=l.visible&&s.visible,l.maxResolution=Math.min(l.maxResolution,s.maxResolution),l.minResolution=Math.max(l.minResolution,s.minResolution),l.minZoom=Math.max(l.minZoom,s.minZoom),l.maxZoom=Math.min(l.maxZoom,s.maxZoom),s.extent!==void 0&&(l.extent!==void 0?l.extent=Ci(l.extent,s.extent):l.extent=s.extent),l.zIndex===void 0&&(l.zIndex=r)}return e}getSourceState(){return"ready"}}class Vm extends zs{constructor(t){super(),this.map_=t}dispatchRenderEvent(t,e){V()}calculateMatrices2D(t){const e=t.viewState,i=t.coordinateToPixelTransform,s=t.pixelToCoordinateTransform;De(i,t.size[0]/2,t.size[1]/2,1/e.resolution,-1/e.resolution,-e.rotation,-e.center[0],-e.center[1]),lh(s,i)}forEachFeatureAtCoordinate(t,e,i,s,r,o,a,l){let h;const c=e.viewState;function u(x,E,T,I){return r.call(o,E,x?T:null,I)}const d=c.projection,f=Bl(t.slice(),d),g=[[0,0]];if(d.canWrapX()&&s){const x=d.getExtent(),E=tt(x);g.push([-E,0],[E,0])}const m=e.layerStatesArray,_=m.length,p=[],y=[];for(let x=0;x<g.length;x++)for(let E=_-1;E>=0;--E){const T=m[E],I=T.layer;if(I.hasRenderer()&&ra(T,c)&&a.call(l,I)){const v=I.getRenderer(),R=I.getSource();if(v&&R){const b=R.getWrapX()?f:t,O=u.bind(null,T.managed);y[0]=b[0]+g[x][0],y[1]=b[1]+g[x][1],h=v.forEachFeatureAtCoordinate(y,e,i,O,p)}if(h)return h}}if(p.length===0)return;const w=1/p.length;return p.forEach((x,E)=>x.distanceSq+=E*w),p.sort((x,E)=>x.distanceSq-E.distanceSq),p.some(x=>h=x.callback(x.feature,x.layer,x.geometry)),h}hasFeatureAtCoordinate(t,e,i,s,r,o){return this.forEachFeatureAtCoordinate(t,e,i,s,Dn,this,r,o)!==void 0}getMap(){return this.map_}renderFrame(t){V()}scheduleExpireIconCache(t){ne.canExpireCache()&&t.postRenderFunctions.push(jm)}}function jm(n,t){ne.expire()}class Hm extends Vm{constructor(t){super(t),this.fontChangeListenerKey_=U(rn,Ki.PROPERTYCHANGE,t.redrawText,t),this.element_=Bt?Ah():document.createElement("div");const e=this.element_.style;e.position="absolute",e.width="100%",e.height="100%",e.zIndex="0",this.element_.className=fr+" ol-layers";const i=t.getViewport();i&&i.insertBefore(this.element_,i.firstChild||null),this.children_=[],this.renderedVisible_=!0}dispatchRenderEvent(t,e){const i=this.getMap();if(i.hasListener(t)){const s=new dc(t,void 0,e);i.dispatchEvent(s)}}disposeInternal(){nt(this.fontChangeListenerKey_),this.element_.remove(),super.disposeInternal()}renderFrame(t){if(!t){this.renderedVisible_&&(this.element_.style.display="none",this.renderedVisible_=!1);return}this.calculateMatrices2D(t),this.dispatchRenderEvent(ie.PRECOMPOSE,t);const e=t.layerStatesArray.sort((h,c)=>h.zIndex-c.zIndex);e.some(h=>h.layer instanceof Fc&&h.layer.getDeclutter())&&(t.declutter={});const s=t.viewState;this.children_.length=0;const r=[];let o=null;for(let h=0,c=e.length;h<c;++h){const u=e[h];t.layerIndex=h;const d=u.layer,f=d.getSourceState();if(!ra(u,s)||f!="ready"&&f!="undefined"){d.unrender();continue}const g=d.render(t,o);g&&(g!==o&&(this.children_.push(g),o=g),r.push(u))}this.declutter(t,r),ng(this.element_,this.children_);const l=this.getMap().getTargetElement();if(ri(l)){const h=l.getContext("2d");for(const c of this.children_){const u=c.firstElementChild||c,d=c.style.backgroundColor;if(d&&(!ri(u)||u.width>0)&&(h.fillStyle=d,h.fillRect(0,0,l.width,l.height)),ri(u)&&u.width>0){const f=c.style.opacity||u.style.opacity;h.globalAlpha=f===""?1:Number(f);const g=u.style.transform;if(g)h.setTransform(...Co(g));else{const m=parseFloat(u.style.width)/u.width,_=parseFloat(u.style.height)/u.height;h.setTransform(m,0,0,_,0,0)}h.drawImage(u,0,0)}}h.globalAlpha=1,h.setTransform(1,0,0,1,0,0)}this.dispatchRenderEvent(ie.POSTCOMPOSE,t),this.renderedVisible_||(this.element_.style.display="",this.renderedVisible_=!0),this.scheduleExpireIconCache(t)}declutter(t,e){if(t.declutter){for(let i=e.length-1;i>=0;--i){const s=e[i],r=s.layer;r.getDeclutter()&&r.renderDeclutter(t,s)}e.forEach(i=>i.layer.renderDeferred(t))}}}function Yc(n){if(n instanceof br){n.setMapInternal(null);return}n instanceof mn&&n.getLayers().forEach(Yc)}function $c(n,t){if(n instanceof br){n.setMapInternal(t);return}if(n instanceof mn){const e=n.getLayers().getArray();for(let i=0,s=e.length;i<s;++i)$c(e[i],t)}}let qm=class extends de{constructor(t){super(),t=t||{},this.on,this.once,this.un;const e=Jm(t);this.renderComplete_=!1,this.loaded_=!0,this.boundHandleBrowserEvent_=this.handleBrowserEvent.bind(this),this.maxTilesLoading_=t.maxTilesLoading!==void 0?t.maxTilesLoading:16,this.pixelRatio_=t.pixelRatio!==void 0?t.pixelRatio:tg,this.postRenderTimeoutHandle_,this.animationDelayKey_,this.animationDelay_=this.animationDelay_.bind(this),this.coordinateToPixelTransform_=fe(),this.pixelToCoordinateTransform_=fe(),this.frameIndex_=0,this.frameState_=null,this.previousExtent_=null,this.viewPropertyListenerKey_=null,this.viewChangeListenerKey_=null,this.layerGroupPropertyListenerKeys_=null,Bt||(this.viewport_=document.createElement("div"),this.viewport_.className="ol-viewport"+("ontouchstart"in window?" ol-touch":""),this.viewport_.style.position="relative",this.viewport_.style.overflow="hidden",this.viewport_.style.width="100%",this.viewport_.style.height="100%",this.overlayContainer_=document.createElement("div"),this.overlayContainer_.style.position="absolute",this.overlayContainer_.style.zIndex="0",this.overlayContainer_.style.width="100%",this.overlayContainer_.style.height="100%",this.overlayContainer_.style.pointerEvents="none",this.overlayContainer_.className="ol-overlaycontainer",this.viewport_.appendChild(this.overlayContainer_),this.overlayContainerStopEvent_=document.createElement("div"),this.overlayContainerStopEvent_.style.position="absolute",this.overlayContainerStopEvent_.style.zIndex="0",this.overlayContainerStopEvent_.style.width="100%",this.overlayContainerStopEvent_.style.height="100%",this.overlayContainerStopEvent_.style.pointerEvents="none",this.overlayContainerStopEvent_.className="ol-overlaycontainer-stopevent",this.viewport_.appendChild(this.overlayContainerStopEvent_)),this.mapBrowserEventHandler_=null,this.moveTolerance_=t.moveTolerance,this.keyboardEventTarget_=e.keyboardEventTarget,this.targetChangeHandlerKeys_=null,this.targetElement_=null,Bt||(this.resizeObserver_=new ResizeObserver(()=>this.updateSize())),this.controls=e.controls||(Bt?new Qt:Im()),this.interactions=e.interactions||(Bt?new Qt:Um({onFocusOnly:!0})),this.overlays_=e.overlays,this.overlayIdIndex_={},this.renderer_=null,this.postRenderFunctions_=[],this.tileQueue_=new vm(this.getTilePriority.bind(this),this.handleTileChange_.bind(this)),this.addChangeListener(wt.LAYERGROUP,this.handleLayerGroupChanged_),this.addChangeListener(wt.VIEW,this.handleViewChanged_),this.addChangeListener(wt.SIZE,this.handleSizeChanged_),this.addChangeListener(wt.TARGET,this.handleTargetChanged_),this.setProperties(e.values);const i=this;t.view&&!(t.view instanceof we)&&t.view.then(function(s){i.setView(new we(s))}),this.controls.addEventListener(Ft.ADD,s=>{s.element.setMap(this)}),this.controls.addEventListener(Ft.REMOVE,s=>{s.element.setMap(null)}),this.interactions.addEventListener(Ft.ADD,s=>{s.element.setMap(this)}),this.interactions.addEventListener(Ft.REMOVE,s=>{s.element.setMap(null)}),this.overlays_.addEventListener(Ft.ADD,s=>{this.addOverlayInternal_(s.element)}),this.overlays_.addEventListener(Ft.REMOVE,s=>{const r=s.element.getId();r!==void 0&&delete this.overlayIdIndex_[r.toString()],s.element.setMap(null)}),this.controls.forEach(s=>{s.setMap(this)}),this.interactions.forEach(s=>{s.setMap(this)}),this.overlays_.forEach(this.addOverlayInternal_.bind(this))}addControl(t){this.getControls().push(t)}addInteraction(t){this.getInteractions().push(t)}addLayer(t){this.getLayerGroup().getLayers().push(t)}handleLayerAdd_(t){$c(t.layer,this)}addOverlay(t){this.getOverlays().push(t)}addOverlayInternal_(t){const e=t.getId();e!==void 0&&(this.overlayIdIndex_[e.toString()]=t),t.setMap(this)}disposeInternal(){this.controls.clear(),this.interactions.clear(),this.overlays_.clear(),this.resizeObserver_?.disconnect(),this.setTarget(null),super.disposeInternal()}forEachFeatureAtPixel(t,e,i){if(!this.frameState_||!this.renderer_)return;const s=this.getCoordinateFromPixelInternal(t);i=i!==void 0?i:{};const r=i.hitTolerance!==void 0?i.hitTolerance:0,o=i.layerFilter!==void 0?i.layerFilter:Dn,a=i.checkWrapped!==!1;return this.renderer_.forEachFeatureAtCoordinate(s,this.frameState_,r,a,e,null,o,null)}getFeaturesAtPixel(t,e){const i=[];return this.forEachFeatureAtPixel(t,function(s){i.push(s)},e),i}getAllLayers(){const t=[];function e(i){i.forEach(function(s){s instanceof mn?e(s.getLayers()):t.push(s)})}return e(this.getLayers()),t}hasFeatureAtPixel(t,e){if(!this.frameState_||!this.renderer_)return!1;const i=this.getCoordinateFromPixelInternal(t);e=e!==void 0?e:{};const s=e.layerFilter!==void 0?e.layerFilter:Dn,r=e.hitTolerance!==void 0?e.hitTolerance:0,o=e.checkWrapped!==!1;return this.renderer_.hasFeatureAtCoordinate(i,this.frameState_,r,o,s,null)}getEventCoordinate(t){return this.getCoordinateFromPixel(this.getEventPixel(t))}getEventCoordinateInternal(t){return this.getCoordinateFromPixelInternal(this.getEventPixel(t))}getEventPixel(t){const i=this.viewport_.getBoundingClientRect(),s=this.getSize(),r=i.width/s[0],o=i.height/s[1],a="changedTouches"in t?t.changedTouches[0]:t;return[(a.clientX-i.left)/r,(a.clientY-i.top)/o]}getTarget(){return this.get(wt.TARGET)}getTargetElement(){return this.targetElement_}getCoordinateFromPixel(t){return wo(this.getCoordinateFromPixelInternal(t),this.getView().getProjection())}getCoordinateFromPixelInternal(t){const e=this.frameState_;return e?ft(e.pixelToCoordinateTransform,t.slice()):null}getControls(){return this.controls}getOverlays(){return this.overlays_}getOverlayById(t){const e=this.overlayIdIndex_[t.toString()];return e!==void 0?e:null}getInteractions(){return this.interactions}getLayerGroup(){return this.get(wt.LAYERGROUP)}setLayers(t){const e=this.getLayerGroup();if(t instanceof Qt){e.setLayers(t);return}const i=e.getLayers();i.clear(),i.extend(t)}getLayers(){return this.getLayerGroup().getLayers()}getLoadingOrNotReady(){const t=this.getLayerGroup().getLayerStatesArray();for(let e=0,i=t.length;e<i;++e){const s=t[e];if(!s.visible)continue;const r=s.layer.getRenderer();if(r&&!r.ready)return!0;const o=s.layer.getSource();if(o&&o.loading)return!0}return!1}getPixelFromCoordinate(t){const e=Oe(t,this.getView().getProjection());return this.getPixelFromCoordinateInternal(e)}getPixelFromCoordinateInternal(t){const e=this.frameState_;return e?ft(e.coordinateToPixelTransform,t.slice(0,2)):null}getRenderer(){return this.renderer_}getSize(){return this.get(wt.SIZE)}getView(){return this.get(wt.VIEW)}getViewport(){return this.viewport_}getOverlayContainer(){return this.overlayContainer_}getOverlayContainerStopEvent(){return this.overlayContainerStopEvent_}getOwnerDocument(){const t=this.getTargetElement();return t?t.ownerDocument:document}getTilePriority(t,e,i,s){return wm(this.frameState_,t,e,i,s)}handleBrowserEvent(t,e){e=e||t.type;const i=new ui(e,this,t);this.handleMapBrowserEvent(i)}handleMapBrowserEvent(t){if(!this.frameState_)return;const e=t.originalEvent,i=e.type;if(i===aa.POINTERDOWN||i===W.WHEEL||i===W.KEYDOWN){const s=this.getOwnerDocument(),r=this.viewport_.getRootNode?this.viewport_.getRootNode():s,o=e.target,a=r instanceof ShadowRoot?r.host===o?r.host.ownerDocument:r:r===s?s.documentElement:r;if(this.overlayContainerStopEvent_.contains(o)||!a.contains(o))return}if(t.frameState=this.frameState_,this.dispatchEvent(t)!==!1){const s=this.getInteractions().getArray().slice();for(let r=s.length-1;r>=0;r--){const o=s[r];if(o.getMap()!==this||!o.getActive()||!this.getTargetElement())continue;if(!o.handleEvent(t)||t.propagationStopped)break}}}handlePostRender(){const t=this.frameState_,e=this.tileQueue_;if(!e.isEmpty()){let s=this.maxTilesLoading_,r=s;if(t){const o=t.viewHints;if(o[vt.ANIMATING]||o[vt.INTERACTING]){const a=Date.now()-t.time>8;s=a?0:8,r=a?0:2}}e.getTilesLoading()<s&&(e.reprioritize(),e.loadMoreTiles(s,r))}t&&this.renderer_&&!t.animate&&(this.renderComplete_?(this.hasListener(ie.RENDERCOMPLETE)&&this.renderer_.dispatchRenderEvent(ie.RENDERCOMPLETE,t),this.loaded_===!1&&(this.loaded_=!0,this.dispatchEvent(new gn(We.LOADEND,this,t)))):this.loaded_===!0&&(this.loaded_=!1,this.dispatchEvent(new gn(We.LOADSTART,this,t))));const i=this.postRenderFunctions_;if(t)for(let s=0,r=i.length;s<r;++s)i[s](this,t);i.length=0}handleSizeChanged_(){this.getView()&&!this.getView().getAnimating()&&this.getView().resolveConstraints(0),this.render()}handleTargetChanged_(){if(this.mapBrowserEventHandler_){for(let i=0,s=this.targetChangeHandlerKeys_.length;i<s;++i)nt(this.targetChangeHandlerKeys_[i]);this.targetChangeHandlerKeys_=null,this.viewport_.removeEventListener(W.CONTEXTMENU,this.boundHandleBrowserEvent_),this.viewport_.removeEventListener(W.WHEEL,this.boundHandleBrowserEvent_),this.mapBrowserEventHandler_.dispose(),this.mapBrowserEventHandler_=null,this.viewport_.remove()}if(this.targetElement_&&!ri(this.targetElement_)){this.resizeObserver_?.unobserve(this.targetElement_);const i=this.targetElement_.getRootNode();i instanceof ShadowRoot&&this.resizeObserver_.unobserve(i.host),this.setSize(void 0)}const t=this.getTarget(),e=typeof t=="string"?document.getElementById(t):t;if(this.targetElement_=e,!e)this.renderer_&&(clearTimeout(this.postRenderTimeoutHandle_),this.postRenderTimeoutHandle_=void 0,this.postRenderFunctions_.length=0,this.renderer_.dispose(),this.renderer_=null),this.animationDelayKey_&&(cancelAnimationFrame(this.animationDelayKey_),this.animationDelayKey_=void 0);else{if(ri(e)||e.appendChild(this.viewport_),this.renderer_||(this.renderer_=new Hm(this)),!ri(e)){this.mapBrowserEventHandler_=new xm(this,this.moveTolerance_);for(const s in at)this.mapBrowserEventHandler_.addEventListener(at[s],this.handleMapBrowserEvent.bind(this));this.viewport_.addEventListener(W.CONTEXTMENU,this.boundHandleBrowserEvent_,!1),this.viewport_.addEventListener(W.WHEEL,this.boundHandleBrowserEvent_,Sh?{passive:!1}:!1);let i;if(this.keyboardEventTarget_)i=this.keyboardEventTarget_;else{const s=e.getRootNode();i=s instanceof ShadowRoot?s.host:e}if(this.targetChangeHandlerKeys_=[U(i,W.KEYDOWN,this.handleBrowserEvent,this),U(i,W.KEYPRESS,this.handleBrowserEvent,this)],e instanceof HTMLElement){const s=e.getRootNode();s instanceof ShadowRoot&&this.resizeObserver_.observe(s.host),this.resizeObserver_?.observe(e)}}this.updateSize()}}handleTileChange_(){this.render()}handleViewPropertyChanged_(){this.render()}handleViewChanged_(){this.viewPropertyListenerKey_&&(nt(this.viewPropertyListenerKey_),this.viewPropertyListenerKey_=null),this.viewChangeListenerKey_&&(nt(this.viewChangeListenerKey_),this.viewChangeListenerKey_=null);const t=this.getView();t&&(this.updateViewportSize_(this.getSize()),this.viewPropertyListenerKey_=U(t,Ki.PROPERTYCHANGE,this.handleViewPropertyChanged_,this),this.viewChangeListenerKey_=U(t,W.CHANGE,this.handleViewPropertyChanged_,this),t.resolveConstraints(0)),this.render()}handleLayerGroupChanged_(){this.layerGroupPropertyListenerKeys_&&(this.layerGroupPropertyListenerKeys_.forEach(nt),this.layerGroupPropertyListenerKeys_=null);const t=this.getLayerGroup();t&&(this.handleLayerAdd_(new fi("addlayer",t)),this.layerGroupPropertyListenerKeys_=[U(t,Ki.PROPERTYCHANGE,this.render,this),U(t,W.CHANGE,this.render,this),U(t,"addlayer",this.handleLayerAdd_,this),U(t,"removelayer",this.handleLayerRemove_,this)]),this.render()}isRendered(){return!!this.frameState_}animationDelay_(){this.animationDelayKey_=void 0,this.renderFrame_(Date.now())}renderSync(){this.animationDelayKey_&&cancelAnimationFrame(this.animationDelayKey_),this.animationDelay_()}redrawText(){if(!this.frameState_)return;const t=this.frameState_.layerStatesArray;for(let e=0,i=t.length;e<i;++e){const s=t[e].layer;s.hasRenderer()&&s.getRenderer().handleFontsChanged()}}render(){this.renderer_&&this.animationDelayKey_===void 0&&(this.animationDelayKey_=requestAnimationFrame(this.animationDelay_))}removeControl(t){return this.getControls().remove(t)}removeInteraction(t){return this.getInteractions().remove(t)}removeLayer(t){return this.getLayerGroup().getLayers().remove(t)}handleLayerRemove_(t){Yc(t.layer)}removeOverlay(t){return this.getOverlays().remove(t)}renderFrame_(t){const e=this.getSize(),i=this.getView(),s=this.frameState_;let r=null;if(e!==void 0&&ec(e)&&i&&i.isDef()){const o=i.getHints(this.frameState_?this.frameState_.viewHints:void 0),a=i.getState();if(r={animate:!1,coordinateToPixelTransform:this.coordinateToPixelTransform_,declutter:null,extent:ro(a.center,a.resolution,a.rotation,e),index:this.frameIndex_++,layerIndex:0,layerStatesArray:this.getLayerGroup().getLayerStatesArray(),pixelRatio:this.pixelRatio_,pixelToCoordinateTransform:this.pixelToCoordinateTransform_,postRenderFunctions:[],size:e,tileQueue:this.tileQueue_,time:t,usedTiles:{},viewState:a,viewHints:o,wantedTiles:{},mapId:j(this),renderTargets:{}},a.nextCenter&&a.nextResolution){const l=isNaN(a.nextRotation)?a.rotation:a.nextRotation;r.nextExtent=ro(a.nextCenter,a.nextResolution,l,e)}}this.frameState_=r,this.renderer_.renderFrame(r),r&&(r.animate&&this.render(),Array.prototype.push.apply(this.postRenderFunctions_,r.postRenderFunctions),s&&(!this.previousExtent_||!Vs(this.previousExtent_)&&!Gn(r.extent,this.previousExtent_))&&(this.dispatchEvent(new gn(We.MOVESTART,this,s)),this.previousExtent_=Ks(this.previousExtent_)),this.previousExtent_&&!r.viewHints[vt.ANIMATING]&&!r.viewHints[vt.INTERACTING]&&!Gn(r.extent,this.previousExtent_)&&(this.dispatchEvent(new gn(We.MOVEEND,this,r)),Pl(r.extent,this.previousExtent_))),this.dispatchEvent(new gn(We.POSTRENDER,this,r)),this.renderComplete_=(this.hasListener(We.LOADSTART)||this.hasListener(We.LOADEND)||this.hasListener(ie.RENDERCOMPLETE))&&!this.tileQueue_.getTilesLoading()&&!this.tileQueue_.getCount()&&!this.getLoadingOrNotReady(),this.postRenderTimeoutHandle_||(this.postRenderTimeoutHandle_=setTimeout(()=>{this.postRenderTimeoutHandle_=void 0,this.handlePostRender()},0))}setLayerGroup(t){const e=this.getLayerGroup();e&&this.handleLayerRemove_(new fi("removelayer",e)),this.set(wt.LAYERGROUP,t)}setSize(t){this.set(wt.SIZE,t)}setTarget(t){this.set(wt.TARGET,t)}setView(t){if(!t||t instanceof we){this.set(wt.VIEW,t);return}this.set(wt.VIEW,new we);const e=this;t.then(function(i){e.setView(new we(i))})}updateSize(){const t=this.getTargetElement();let e;if(t){let s,r;if(ri(t))s=t.width,r=t.height;else{const o=getComputedStyle(t);s=t.offsetWidth-parseFloat(o.borderLeftWidth)-parseFloat(o.paddingLeft)-parseFloat(o.paddingRight)-parseFloat(o.borderRightWidth),r=t.offsetHeight-parseFloat(o.borderTopWidth)-parseFloat(o.paddingTop)-parseFloat(o.paddingBottom)-parseFloat(o.borderBottomWidth)}!isNaN(s)&&!isNaN(r)&&(e=[Math.max(0,s),Math.max(0,r)],!ec(e)&&(t.offsetWidth||t.offsetHeight||t.getClientRects().length)&&Kl("No map visible because the map container's width or height are 0."))}const i=this.getSize();e&&(!i||!ti(e,i))&&(this.setSize(e),this.updateViewportSize_(e))}updateViewportSize_(t){const e=this.getView();e&&e.setViewportSize(t)}};function Jm(n){let t=null;n.keyboardEventTarget!==void 0&&(t=typeof n.keyboardEventTarget=="string"?document.getElementById(n.keyboardEventTarget):n.keyboardEventTarget);const e={},i=n.layers&&typeof n.layers.getLayers=="function"?n.layers:new mn({layers:n.layers});e[wt.LAYERGROUP]=i,e[wt.TARGET]=n.target,e[wt.VIEW]=n.view instanceof we?n.view:new we;let s;n.controls!==void 0&&(Array.isArray(n.controls)?s=new Qt(n.controls.slice()):(Q(typeof n.controls.getArray=="function","Expected `controls` to be an array or an `ol/Collection.js`"),s=n.controls));let r;n.interactions!==void 0&&(Array.isArray(n.interactions)?r=new Qt(n.interactions.slice()):(Q(typeof n.interactions.getArray=="function","Expected `interactions` to be an array or an `ol/Collection.js`"),r=n.interactions));let o;return n.overlays!==void 0?Array.isArray(n.overlays)?o=new Qt(n.overlays.slice()):(Q(typeof n.overlays.getArray=="function","Expected `overlays` to be an array or an `ol/Collection.js`"),o=n.overlays):o=new Qt,{controls:s,interactions:r,keyboardEventTarget:t,overlays:o,values:e}}const Ct={ELEMENT:"element",MAP:"map",OFFSET:"offset",POSITION:"position",POSITIONING:"positioning"};class Qm extends de{constructor(t){super(),this.on,this.once,this.un,this.options=t,this.id=t.id,this.insertFirst=t.insertFirst!==void 0?t.insertFirst:!0,this.stopEvent=t.stopEvent!==void 0?t.stopEvent:!0,this.element=document.createElement("div"),this.element.className=t.className!==void 0?t.className:"ol-overlay-container "+yg,this.element.style.position="absolute",this.element.style.pointerEvents="auto",this.autoPan=t.autoPan===!0?{}:t.autoPan||void 0,this.rendered={transform_:"",visible:!0},this.mapPostrenderListenerKey=null,this.addChangeListener(Ct.ELEMENT,this.handleElementChanged),this.addChangeListener(Ct.MAP,this.handleMapChanged),this.addChangeListener(Ct.OFFSET,this.handleOffsetChanged),this.addChangeListener(Ct.POSITION,this.handlePositionChanged),this.addChangeListener(Ct.POSITIONING,this.handlePositioningChanged),t.element!==void 0&&this.setElement(t.element),this.setOffset(t.offset!==void 0?t.offset:[0,0]),this.setPositioning(t.positioning||"top-left"),t.position!==void 0&&this.setPosition(t.position)}getElement(){return this.get(Ct.ELEMENT)}getId(){return this.id}getMap(){return this.get(Ct.MAP)||null}getOffset(){return this.get(Ct.OFFSET)}getPosition(){return this.get(Ct.POSITION)}getPositioning(){return this.get(Ct.POSITIONING)}handleElementChanged(){Lh(this.element);const t=this.getElement();t&&this.element.appendChild(t)}handleMapChanged(){this.mapPostrenderListenerKey&&(this.element?.remove(),nt(this.mapPostrenderListenerKey),this.mapPostrenderListenerKey=null);const t=this.getMap();if(t){this.mapPostrenderListenerKey=U(t,We.POSTRENDER,this.render,this),this.updatePixelPosition();const e=this.stopEvent?t.getOverlayContainerStopEvent():t.getOverlayContainer();this.insertFirst?e.insertBefore(this.element,e.childNodes[0]||null):e.appendChild(this.element),this.performAutoPan()}}render(){this.updatePixelPosition()}handleOffsetChanged(){this.updatePixelPosition()}handlePositionChanged(){this.updatePixelPosition(),this.performAutoPan()}handlePositioningChanged(){this.updatePixelPosition()}setElement(t){this.set(Ct.ELEMENT,t)}setMap(t){this.set(Ct.MAP,t)}setOffset(t){this.set(Ct.OFFSET,t)}setPosition(t){this.set(Ct.POSITION,t)}performAutoPan(){this.autoPan&&this.panIntoView(this.autoPan)}panIntoView(t){const e=this.getMap();if(!e||!e.getTargetElement()||!this.get(Ct.POSITION))return;const i=this.getRect(e.getTargetElement(),e.getSize()),s=this.getElement(),r=this.getRect(s,[eg(s),ig(s)]);t=t||{};const o=t.margin===void 0?20:t.margin;if(!Ui(i,r)){const a=r[0]-i[0],l=i[2]-r[2],h=r[1]-i[1],c=i[3]-r[3],u=[0,0];if(a<0?u[0]=a-o:l<0&&(u[0]=Math.abs(l)+o),h<0?u[1]=h-o:c<0&&(u[1]=Math.abs(c)+o),u[0]!==0||u[1]!==0){const d=e.getView().getCenterInternal(),f=e.getPixelFromCoordinateInternal(d);if(!f)return;const g=[f[0]+u[0],f[1]+u[1]],m=t.animation||{};e.getView().animateInternal({center:e.getCoordinateFromPixelInternal(g),duration:m.duration,easing:m.easing})}}}getRect(t,e){const i=t.getBoundingClientRect(),s=i.left+window.pageXOffset,r=i.top+window.pageYOffset;return[s,r,s+e[0],r+e[1]]}setPositioning(t){this.set(Ct.POSITIONING,t)}setVisible(t){this.rendered.visible!==t&&(this.element.style.display=t?"":"none",this.rendered.visible=t)}updatePixelPosition(){const t=this.getMap(),e=this.getPosition();if(!t||!t.isRendered()||!e){this.setVisible(!1);return}const i=t.getPixelFromCoordinate(e),s=t.getSize();this.updateRenderedPosition(i,s)}updateRenderedPosition(t,e){const i=this.element.style,s=this.getOffset(),r=this.getPositioning();this.setVisible(!0);const o=`${t[0]+s[0]}px`,a=`${t[1]+s[1]}px`;let l="0%",h="0%";r=="bottom-right"||r=="center-right"||r=="top-right"?l="-100%":(r=="bottom-center"||r=="center-center"||r=="top-center")&&(l="-50%"),r=="bottom-left"||r=="bottom-center"||r=="bottom-right"?h="-100%":(r=="center-left"||r=="center-center"||r=="center-right")&&(h="-50%");const c=`translate(${l}, ${h}) translate(${o}, ${a})`;this.rendered.transform_!=c&&(this.rendered.transform_=c,i.transform=c)}getOptions(){return this.options}}class ga{constructor(t,e,i,s){this.minX=t,this.maxX=e,this.minY=i,this.maxY=s}contains(t){return this.containsXY(t[1],t[2])}containsTileRange(t){return this.minX<=t.minX&&t.maxX<=this.maxX&&this.minY<=t.minY&&t.maxY<=this.maxY}containsXY(t,e){return this.minX<=t&&t<=this.maxX&&this.minY<=e&&e<=this.maxY}equals(t){return this.minX==t.minX&&this.minY==t.minY&&this.maxX==t.maxX&&this.maxY==t.maxY}extend(t){t.minX<this.minX&&(this.minX=t.minX),t.maxX>this.maxX&&(this.maxX=t.maxX),t.minY<this.minY&&(this.minY=t.minY),t.maxY>this.maxY&&(this.maxY=t.maxY)}getHeight(){return this.maxY-this.minY+1}getSize(){return[this.getWidth(),this.getHeight()]}getWidth(){return this.maxX-this.minX+1}intersects(t){return this.minX<=t.maxX&&this.maxX>=t.minX&&this.minY<=t.maxY&&this.maxY>=t.minY}}function pn(n,t,e,i,s){return s!==void 0?(s.minX=n,s.maxX=t,s.minY=e,s.maxY=i,s):new ga(n,t,e,i)}let _a;const yn=[];function Kc(n,t,e,i,s){n.beginPath(),n.moveTo(0,0),n.lineTo(t,e),n.lineTo(i,s),n.closePath(),n.save(),n.clip(),n.fillRect(0,0,Math.max(t,i)+1,Math.max(e,s)),n.restore()}function ma(n,t){return Math.abs(n[t*4]-210)>2||Math.abs(n[t*4+3]-.75*255)>2}function tp(){if(_a===void 0){const n=ct(6,6,yn);n.globalCompositeOperation="lighter",n.fillStyle="rgba(210, 0, 0, 0.75)",Kc(n,4,5,4,0),Kc(n,4,5,0,5);const t=n.getImageData(0,0,3,3).data;_a=ma(t,0)||ma(t,4)||ma(t,8),hr(n),yn.push(n.canvas)}return _a}function Bc(n,t,e,i){const s=Yn(e,t,n);let r=rh(t,i,e);const o=t.getMetersPerUnit();o!==void 0&&(r*=o);const a=n.getMetersPerUnit();a!==void 0&&(r/=a);const l=n.getExtent();if(!l||Zi(l,s)){const h=rh(n,r,s)/r;isFinite(h)&&h>0&&(r/=h)}return r}function ep(n,t,e,i){const s=wi(e);let r=Bc(n,t,s,i);return(!isFinite(r)||r<=0)&&Gl(e,function(o){return r=Bc(n,t,o,i),isFinite(r)&&r>0}),r}function ip(n,t,e,i,s,r,o,a,l,h,c,u,d,f){const g=ct(Math.round(e*n),Math.round(e*t),yn);if(u||(g.imageSmoothingEnabled=!1),l.length===0)return g.canvas;g.scale(e,e);function m(E){return Math.round(E*e)/e}g.globalCompositeOperation="lighter";const _=Kt();l.forEach(function(E,T,I){kl(_,E.extent)});let p;const y=e/i,w=(u?1:1+Math.pow(2,-24))/y;p=ct(Math.round(tt(_)*y),Math.round(At(_)*y),yn),u||(p.imageSmoothingEnabled=!1),l.forEach(function(E,T,I){if(E.image.width>0&&E.image.height>0){if(E.clipExtent){p.save();const F=(E.clipExtent[0]-_[0])*y,A=-(E.clipExtent[3]-_[3])*y,L=tt(E.clipExtent)*y,M=At(E.clipExtent)*y;p.rect(u?F:Math.round(F),u?A:Math.round(A),u?L:Math.round(F+L)-Math.round(F),u?M:Math.round(A+M)-Math.round(A)),p.clip()}const v=(E.extent[0]-_[0])*y,R=-(E.extent[3]-_[3])*y,b=tt(E.extent)*y,O=At(E.extent)*y;p.drawImage(E.image,h,h,E.image.width-2*h,E.image.height-2*h,u?v:Math.round(v),u?R:Math.round(R),u?b:Math.round(v+b)-Math.round(v),u?O:Math.round(R+O)-Math.round(R)),E.clipExtent&&p.restore()}});const x=Ri(o);return a.getTriangles().forEach(function(E,T,I){const v=E.source,R=E.target;let b=v[0][0],O=v[0][1],F=v[1][0],A=v[1][1],L=v[2][0],M=v[2][1];const P=m((R[0][0]-x[0])/r),X=m(-(R[0][1]-x[1])/r),D=m((R[1][0]-x[0])/r),k=m(-(R[1][1]-x[1])/r),K=m((R[2][0]-x[0])/r),J=m(-(R[2][1]-x[1])/r),S=b,gt=O;b=0,O=0,F-=S,A-=gt,L-=S,M-=gt;const xt=[[F,A,0,0,D-P],[L,M,0,0,K-P],[0,0,F,A,k-X],[0,0,L,M,J-X]],st=Ud(xt);if(!st)return;if(g.save(),g.beginPath(),tp()||!u){g.moveTo(D,k);const ht=4,Pt=P-D,Rt=X-k;for(let Zt=0;Zt<ht;Zt++)g.lineTo(D+m((Zt+1)*Pt/ht),k+m(Zt*Rt/(ht-1))),Zt!=ht-1&&g.lineTo(D+m((Zt+1)*Pt/ht),k+m((Zt+1)*Rt/(ht-1)));g.lineTo(K,J)}else g.moveTo(D,k),g.lineTo(P,X),g.lineTo(K,J);g.clip(),g.transform(st[0],st[2],st[1],st[3],P,X),g.translate(_[0]-S,_[3]-gt);let _t;if(p)_t=p.canvas,g.scale(w,-w);else{const ht=l[0],Pt=ht.extent;_t=ht.image,g.scale(tt(Pt)/_t.width,-At(Pt)/_t.height)}g.drawImage(_t,0,0),g.restore()}),p&&(hr(p),yn.push(p.canvas)),c&&(g.save(),g.globalCompositeOperation="source-over",g.strokeStyle="black",g.lineWidth=1,a.getTriangles().forEach(function(E,T,I){const v=E.target,R=(v[0][0]-x[0])/r,b=-(v[0][1]-x[1])/r,O=(v[1][0]-x[0])/r,F=-(v[1][1]-x[1])/r,A=(v[2][0]-x[0])/r,L=-(v[2][1]-x[1])/r;g.beginPath(),g.moveTo(O,F),g.lineTo(R,b),g.lineTo(A,L),g.closePath(),g.stroke()}),g.restore()),g.canvas}const np=10,Zc=.25;class sp{constructor(t,e,i,s,r,o,a){this.sourceProj_=t,this.targetProj_=e;let l={};const h=a?Tf(w=>ft(a,Yn(w,this.targetProj_,this.sourceProj_))):rr(this.targetProj_,this.sourceProj_);this.transformInv_=function(w){const x=w[0]+"/"+w[1];return l[x]||(l[x]=h(w)),l[x]},this.maxSourceExtent_=s,this.errorThresholdSquared_=r*r,this.triangles_=[],this.wrapsXInSource_=!1,this.canWrapXInSource_=this.sourceProj_.canWrapX()&&!!s&&!!this.sourceProj_.getExtent()&&tt(s)>=tt(this.sourceProj_.getExtent()),this.sourceWorldWidth_=this.sourceProj_.getExtent()?tt(this.sourceProj_.getExtent()):null,this.targetWorldWidth_=this.targetProj_.getExtent()?tt(this.targetProj_.getExtent()):null;const c=Ri(i),u=Us(i),d=Zs(i),f=Bs(i),g=this.transformInv_(c),m=this.transformInv_(u),_=this.transformInv_(d),p=this.transformInv_(f),y=np+(o?Math.max(0,Math.ceil(Math.log2(so(i)/(o*o*256*256)))):0);if(this.addQuad_(c,u,d,f,g,m,_,p,y),this.wrapsXInSource_){let w=1/0;this.triangles_.forEach(function(x,E,T){w=Math.min(w,x.source[0][0],x.source[1][0],x.source[2][0])}),this.triangles_.forEach(x=>{if(Math.max(x.source[0][0],x.source[1][0],x.source[2][0])-w>this.sourceWorldWidth_/2){const E=[[x.source[0][0],x.source[0][1]],[x.source[1][0],x.source[1][1]],[x.source[2][0],x.source[2][1]]];E[0][0]-w>this.sourceWorldWidth_/2&&(E[0][0]-=this.sourceWorldWidth_),E[1][0]-w>this.sourceWorldWidth_/2&&(E[1][0]-=this.sourceWorldWidth_),E[2][0]-w>this.sourceWorldWidth_/2&&(E[2][0]-=this.sourceWorldWidth_);const T=Math.min(E[0][0],E[1][0],E[2][0]);Math.max(E[0][0],E[1][0],E[2][0])-T<this.sourceWorldWidth_/2&&(x.source=E)}})}l={}}addTriangle_(t,e,i,s,r,o){this.triangles_.push({source:[s,r,o],target:[t,e,i]})}addQuad_(t,e,i,s,r,o,a,l,h){const c=Ml([r,o,a,l]),u=this.sourceWorldWidth_?tt(c)/this.sourceWorldWidth_:null,d=this.sourceWorldWidth_,f=this.sourceProj_.canWrapX()&&u>.5&&u<1;let g=!1;if(h>0){if(this.targetProj_.isGlobal()&&this.targetWorldWidth_){const _=Ml([t,e,i,s]);g=tt(_)/this.targetWorldWidth_>Zc||g}!f&&this.sourceProj_.isGlobal()&&u&&(g=u>Zc||g)}if(!g&&this.maxSourceExtent_&&isFinite(c[0])&&isFinite(c[1])&&isFinite(c[2])&&isFinite(c[3])&&!kt(c,this.maxSourceExtent_))return;let m=0;if(!g&&(!isFinite(r[0])||!isFinite(r[1])||!isFinite(o[0])||!isFinite(o[1])||!isFinite(a[0])||!isFinite(a[1])||!isFinite(l[0])||!isFinite(l[1]))){if(h>0)g=!0;else if(m=(!isFinite(r[0])||!isFinite(r[1])?8:0)+(!isFinite(o[0])||!isFinite(o[1])?4:0)+(!isFinite(a[0])||!isFinite(a[1])?2:0)+(!isFinite(l[0])||!isFinite(l[1])?1:0),m!=1&&m!=2&&m!=4&&m!=8)return}if(h>0){if(!g){const _=[(t[0]+i[0])/2,(t[1]+i[1])/2],p=this.transformInv_(_);let y;f?y=(ji(r[0],d)+ji(a[0],d))/2-ji(p[0],d):y=(r[0]+a[0])/2-p[0];const w=(r[1]+a[1])/2-p[1];g=y*y+w*w>this.errorThresholdSquared_}if(g){if(Math.abs(t[0]-i[0])<=Math.abs(t[1]-i[1])){const _=[(e[0]+i[0])/2,(e[1]+i[1])/2],p=this.transformInv_(_),y=[(s[0]+t[0])/2,(s[1]+t[1])/2],w=this.transformInv_(y);this.addQuad_(t,e,_,y,r,o,p,w,h-1),this.addQuad_(y,_,i,s,w,p,a,l,h-1)}else{const _=[(t[0]+e[0])/2,(t[1]+e[1])/2],p=this.transformInv_(_),y=[(i[0]+s[0])/2,(i[1]+s[1])/2],w=this.transformInv_(y);this.addQuad_(t,_,y,s,r,p,w,l,h-1),this.addQuad_(_,e,i,y,p,o,a,w,h-1)}return}}if(f){if(!this.canWrapXInSource_)return;this.wrapsXInSource_=!0}(m&11)==0&&this.addTriangle_(t,i,s,r,a,l),(m&14)==0&&this.addTriangle_(t,i,e,r,a,o),m&&((m&13)==0&&this.addTriangle_(e,s,t,o,l,r),(m&7)==0&&this.addTriangle_(e,s,i,o,l,a))}calculateSourceExtent(){const t=Kt();return this.triangles_.forEach(function(e,i,s){const r=e.source;zn(t,r[0]),zn(t,r[1]),zn(t,r[2])}),t}getTriangles(){return this.triangles_}}const rp=.5;class Uc extends oa{constructor(t,e,i,s,r,o,a,l,h,c,u,d){super(r,G.IDLE,d),this.renderEdges_=u!==void 0?u:!1,this.pixelRatio_=a,this.gutter_=l,this.canvas_=null,this.sourceTileGrid_=e,this.targetTileGrid_=s,this.wrappedTileCoord_=o||r,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0,this.clipExtent_=t.canWrapX()?t.getExtent():void 0;const f=s.getTileCoordExtent(this.wrappedTileCoord_),g=this.targetTileGrid_.getExtent();let m=this.sourceTileGrid_.getExtent();const _=g?Ci(f,g):f;if(so(_)===0){this.state=G.EMPTY;return}const p=t.getExtent();p&&(m?m=Ci(m,p):m=p);const y=s.getResolution(this.wrappedTileCoord_[0]),w=ep(t,i,_,y);if(!isFinite(w)||w<=0){this.state=G.EMPTY;return}const x=c!==void 0?c:rp;if(this.triangulation_=new sp(t,i,_,m,w*x,y),this.triangulation_.getTriangles().length===0){this.state=G.EMPTY;return}this.sourceZ_=e.getZForResolution(w);let E=this.triangulation_.calculateSourceExtent();if(m&&(t.canWrapX()?(E[1]=ot(E[1],m[1],m[3]),E[3]=ot(E[3],m[1],m[3])):E=Ci(E,m)),!so(E))this.state=G.EMPTY;else{let T=0,I=0;t.canWrapX()&&(T=tt(p),I=Math.floor((E[0]-p[0])/T)),Wl(E.slice(),t,!0).forEach(R=>{const b=e.getTileRangeForExtentAndZ(R,this.sourceZ_);for(let O=b.minX;O<=b.maxX;O++)for(let F=b.minY;F<=b.maxY;F++){const A=h(this.sourceZ_,O,F,a);if(A){const L=I*T;this.sourceTiles_.push({tile:A,offset:L})}}++I}),this.sourceTiles_.length===0&&(this.state=G.EMPTY)}}getImage(){return this.canvas_}reproject_(){const t=[];if(this.sourceTiles_.forEach(e=>{const i=e.tile;if(i&&i.getState()==G.LOADED){const s=this.sourceTileGrid_.getTileCoordExtent(i.tileCoord);s[0]+=e.offset,s[2]+=e.offset;const r=this.clipExtent_?.slice();r&&(r[0]+=e.offset,r[2]+=e.offset),t.push({extent:s,clipExtent:r,image:i.getImage()})}}),this.sourceTiles_.length=0,t.length===0)this.state=G.ERROR;else{const e=this.wrappedTileCoord_[0],i=this.targetTileGrid_.getTileSize(e),s=typeof i=="number"?i:i[0],r=typeof i=="number"?i:i[1],o=this.targetTileGrid_.getResolution(e),a=this.sourceTileGrid_.getResolution(this.sourceZ_),l=this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_);this.canvas_=ip(s,r,this.pixelRatio_,a,this.sourceTileGrid_.getExtent(),o,l,this.triangulation_,t,this.gutter_,this.renderEdges_,this.interpolate),this.state=G.LOADED}this.changed()}load(){if(this.state==G.IDLE){this.state=G.LOADING,this.changed();let t=0;this.sourcesListenerKeys_=[],this.sourceTiles_.forEach(({tile:e})=>{const i=e.getState();if(i==G.IDLE||i==G.LOADING){t++;const s=U(e,W.CHANGE,r=>{const o=e.getState();(o==G.LOADED||o==G.ERROR||o==G.EMPTY)&&(nt(s),t--,t===0&&(this.unlistenSources_(),this.reproject_()))});this.sourcesListenerKeys_.push(s)}}),t===0?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach(function({tile:e},i,s){e.getState()==G.IDLE&&e.load()})}}unlistenSources_(){this.sourcesListenerKeys_.forEach(nt),this.sourcesListenerKeys_=null}release(){this.canvas_&&(hr(this.canvas_.getContext("2d")),yn.push(this.canvas_),this.canvas_=null),super.release()}}function Ar(n,t,e,i){return i!==void 0?(i[0]=n,i[1]=t,i[2]=e,i):[n,t,e]}function op(n,t,e){return n+"/"+t+"/"+e}function Mr(n,t,e,i,s){return`${j(n)},${t},${op(e,i,s)}`}function ap(n){return lp(n[0],n[1],n[2])}function lp(n,t,e){return(t<<n)+e}function hp(n,t){const e=n[0],i=n[1],s=n[2];if(t.getMinZoom()>e||e>t.getMaxZoom())return!1;const r=t.getFullTileRange(e);return r?r.containsXY(i,s):!0}const xn=[0,0,0],gi=5;class Vc{constructor(t){this.minZoom=t.minZoom!==void 0?t.minZoom:0,this.resolutions_=t.resolutions,Q(Nd(this.resolutions_,(s,r)=>r-s),"`resolutions` must be sorted in descending order");let e;if(!t.origins){for(let s=0,r=this.resolutions_.length-1;s<r;++s)if(!e)e=this.resolutions_[s]/this.resolutions_[s+1];else if(this.resolutions_[s]/this.resolutions_[s+1]!==e){e=void 0;break}}this.zoomFactor_=e,this.maxZoom=this.resolutions_.length-1,this.origin_=t.origin!==void 0?t.origin:null,this.origins_=null,t.origins!==void 0&&(this.origins_=t.origins,Q(this.origins_.length==this.resolutions_.length,"Number of `origins` and `resolutions` must be equal"));const i=t.extent;i!==void 0&&!this.origin_&&!this.origins_&&(this.origin_=Ri(i)),Q(!this.origin_&&this.origins_||this.origin_&&!this.origins_,"Either `origin` or `origins` must be configured, never both"),this.tileSizes_=null,t.tileSizes!==void 0&&(this.tileSizes_=t.tileSizes,Q(this.tileSizes_.length==this.resolutions_.length,"Number of `tileSizes` and `resolutions` must be equal")),this.tileSize_=t.tileSize!==void 0?t.tileSize:this.tileSizes_?null:ia,Q(!this.tileSize_&&this.tileSizes_||this.tileSize_&&!this.tileSizes_,"Either `tileSize` or `tileSizes` must be configured, never both"),this.extent_=i!==void 0?i:null,this.fullTileRanges_=null,this.tmpSize_=[0,0],this.tmpExtent_=[0,0,0,0],t.sizes!==void 0?this.fullTileRanges_=t.sizes.map((s,r)=>{const o=new ga(Math.min(0,s[0]),Math.max(s[0]-1,-1),Math.min(0,s[1]),Math.max(s[1]-1,-1));if(i){const a=this.getTileRangeForExtentAndZ(i,r);o.minX=Math.max(a.minX,o.minX),o.maxX=Math.min(a.maxX,o.maxX),o.minY=Math.max(a.minY,o.minY),o.maxY=Math.min(a.maxY,o.maxY)}return o}):i&&this.calculateTileRanges_(i)}forEachTileCoord(t,e,i){const s=this.getTileRangeForExtentAndZ(t,e);for(let r=s.minX,o=s.maxX;r<=o;++r)for(let a=s.minY,l=s.maxY;a<=l;++a)i([e,r,a])}forEachTileCoordParentTileRange(t,e,i,s){let r,o,a,l=null,h=t[0]-1;for(this.zoomFactor_===2?(o=t[1],a=t[2]):l=this.getTileCoordExtent(t,s);h>=this.minZoom;){if(o!==void 0&&a!==void 0?(o=Math.floor(o/2),a=Math.floor(a/2),r=pn(o,o,a,a,i)):r=this.getTileRangeForExtentAndZ(l,h,i),e(h,r))return!0;--h}return!1}getExtent(){return this.extent_}getMaxZoom(){return this.maxZoom}getMinZoom(){return this.minZoom}getOrigin(t){return this.origin_?this.origin_:this.origins_[t]}getResolution(t){return this.resolutions_[t]}getResolutions(){return this.resolutions_}getTileCoordChildTileRange(t,e,i){if(t[0]<this.maxZoom){if(this.zoomFactor_===2){const r=t[1]*2,o=t[2]*2;return pn(r,r+1,o,o+1,e)}const s=this.getTileCoordExtent(t,i||this.tmpExtent_);return this.getTileRangeForExtentAndZ(s,t[0]+1,e)}return null}getTileRangeForTileCoordAndZ(t,e,i){if(e>this.maxZoom||e<this.minZoom)return null;const s=t[0],r=t[1],o=t[2];if(e===s)return pn(r,o,r,o,i);if(this.zoomFactor_){const l=Math.pow(this.zoomFactor_,e-s),h=Math.floor(r*l),c=Math.floor(o*l);if(e<s)return pn(h,h,c,c,i);const u=Math.floor(l*(r+1))-1,d=Math.floor(l*(o+1))-1;return pn(h,u,c,d,i)}const a=this.getTileCoordExtent(t,this.tmpExtent_);return this.getTileRangeForExtentAndZ(a,e,i)}getTileRangeForExtentAndZ(t,e,i){this.getTileCoordForXYAndZ_(t[0],t[3],e,!1,xn);const s=xn[1],r=xn[2];this.getTileCoordForXYAndZ_(t[2],t[1],e,!0,xn);const o=xn[1],a=xn[2];return pn(s,o,r,a,i)}getTileCoordCenter(t){const e=this.getOrigin(t[0]),i=this.getResolution(t[0]),s=zt(this.getTileSize(t[0]),this.tmpSize_);return[e[0]+(t[1]+.5)*s[0]*i,e[1]-(t[2]+.5)*s[1]*i]}getTileCoordExtent(t,e){const i=this.getOrigin(t[0]),s=this.getResolution(t[0]),r=zt(this.getTileSize(t[0]),this.tmpSize_),o=i[0]+t[1]*r[0]*s,a=i[1]-(t[2]+1)*r[1]*s,l=o+r[0]*s,h=a+r[1]*s;return ei(o,a,l,h,e)}getTileCoordForCoordAndResolution(t,e,i){return this.getTileCoordForXYAndResolution_(t[0],t[1],e,!1,i)}getTileCoordForXYAndResolution_(t,e,i,s,r){const o=this.getZForResolution(i),a=i/this.getResolution(o),l=this.getOrigin(o),h=zt(this.getTileSize(o),this.tmpSize_);let c=a*(t-l[0])/i/h[0],u=a*(l[1]-e)/i/h[1];return s?(c=qs(c,gi)-1,u=qs(u,gi)-1):(c=Hs(c,gi),u=Hs(u,gi)),Ar(o,c,u,r)}getTileCoordForXYAndZ_(t,e,i,s,r){const o=this.getOrigin(i),a=this.getResolution(i),l=zt(this.getTileSize(i),this.tmpSize_);let h=(t-o[0])/a/l[0],c=(o[1]-e)/a/l[1];return s?(h=qs(h,gi)-1,c=qs(c,gi)-1):(h=Hs(h,gi),c=Hs(c,gi)),Ar(i,h,c,r)}getTileCoordForCoordAndZ(t,e,i){return this.getTileCoordForXYAndZ_(t[0],t[1],e,!1,i)}getTileCoordResolution(t){return this.resolutions_[t[0]]}getTileSize(t){return this.tileSize_?this.tileSize_:this.tileSizes_[t]}getFullTileRange(t){return this.fullTileRanges_?this.fullTileRanges_[t]:this.extent_?this.getTileRangeForExtentAndZ(this.extent_,t):null}getZForResolution(t,e){const i=Jr(this.resolutions_,t,e||0);return ot(i,this.minZoom,this.maxZoom)}tileCoordIntersectsViewport(t,e){return vh(e,0,e.length,2,this.getTileCoordExtent(t))}calculateTileRanges_(t){const e=this.resolutions_.length,i=new Array(e);for(let s=this.minZoom;s<e;++s)i[s]=this.getTileRangeForExtentAndZ(t,s);this.fullTileRanges_=i}}function jc(n){let t=n.getDefaultTileGrid();return t||(t=fp(n),n.setDefaultTileGrid(t)),t}function cp(n,t,e){const i=t[0],s=n.getTileCoordCenter(t),r=pa(e);if(!Zi(r,s)){const o=tt(r),a=Math.ceil((r[0]-s[0])/o);return s[0]+=o*a,n.getTileCoordForCoordAndZ(s,i)}return t}function up(n,t,e,i){i=i!==void 0?i:"top-left";const s=Hc(n,t,e);return new Vc({extent:n,origin:$d(n,i),resolutions:s,tileSize:e})}function dp(n){const t=n||{},e=t.extent||Nt("EPSG:3857").getExtent(),i={extent:e,minZoom:t.minZoom,tileSize:t.tileSize,resolutions:Hc(e,t.maxZoom,t.tileSize,t.maxResolution)};return new Vc(i)}function Hc(n,t,e,i){t=t!==void 0?t:cm,e=zt(e!==void 0?e:ia);const s=At(n),r=tt(n);i=i>0?i:Math.max(r/e[0],s/e[1]);const o=t+1,a=new Array(o);for(let l=0;l<o;++l)a[l]=i/Math.pow(2,l);return a}function fp(n,t,e,i){const s=pa(n);return up(s,t,e,i)}function pa(n){n=Nt(n);let t=n.getExtent();if(!t){const e=180*lo.degrees/n.getMetersPerUnit();t=ei(-e,-e,e,e)}return t}const gp=/\{z\}/g,_p=/\{x\}/g,mp=/\{y\}/g,pp=/\{-y\}/g;function yp(n,t,e,i,s){return n.replace(gp,t.toString()).replace(_p,e.toString()).replace(mp,i.toString()).replace(pp,function(){if(s===void 0)throw new Error("If the URL template has a {-y} placeholder, the grid extent must be known");return(s-i).toString()})}function xp(n){const t=[];let e=/\{([a-z])-([a-z])\}/.exec(n);if(e){const i=e[1].charCodeAt(0),s=e[2].charCodeAt(0);let r;for(r=i;r<=s;++r)t.push(n.replace(e[0],String.fromCharCode(r)));return t}if(e=/\{(\d+)-(\d+)\}/.exec(n),e){const i=parseInt(e[2],10);for(let s=parseInt(e[1],10);s<=i;s++)t.push(n.replace(e[0],s.toString()));return t}return t.push(n),t}function Ep(n,t){return(function(e,i,s){if(!e)return;let r;const o=e[0];if(t){const a=t.getFullTileRange(o);a&&(r=a.getHeight()-1)}return yp(n,o,e[1],e[2],r)})}function vp(n,t){const e=n.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=Ep(n[s],t);return wp(i)}function wp(n){return n.length===1?n[0]:(function(t,e,i){if(!t)return;const s=ap(t),r=ji(s,n.length);return n[r](t,e,i)})}class Cp extends Qh{constructor(t){super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,projection:t.projection,state:t.state,wrapX:t.wrapX,interpolate:t.interpolate}),this.on,this.once,this.un,this.tilePixelRatio_=t.tilePixelRatio!==void 0?t.tilePixelRatio:1,this.tileGrid=t.tileGrid!==void 0?t.tileGrid:null;const e=[256,256];this.tileGrid&&zt(this.tileGrid.getTileSize(this.tileGrid.getMinZoom()),e),this.tmpSize=[0,0],this.key_=t.key||j(this),this.tileOptions={transition:t.transition,interpolate:t.interpolate},this.zDirection=t.zDirection?t.zDirection:0}getGutterForProjection(t){return 0}getKey(){return this.key_}setKey(t){this.key_!==t&&(this.key_=t,this.changed())}getResolutions(t){const e=t?this.getTileGridForProjection(t):this.tileGrid;return e?e.getResolutions():null}getTile(t,e,i,s,r,o){return V()}getTileGrid(){return this.tileGrid}getTileGridForProjection(t){return this.tileGrid?this.tileGrid:jc(t)}getTilePixelRatio(t){return this.tilePixelRatio_}getTilePixelSize(t,e,i){const s=this.getTileGridForProjection(i),r=this.getTilePixelRatio(e),o=zt(s.getTileSize(t),this.tmpSize);return r==1?o:Hg(o,r,this.tmpSize)}getTileCoordForTileUrlFunction(t,e){const i=e!==void 0?e:this.getProjection(),s=e!==void 0?this.getTileGridForProjection(i):this.tileGrid||this.getTileGridForProjection(i);return this.getWrapX()&&i.isGlobal()&&(t=cp(s,t,i)),hp(t,s)?t:null}clear(){}refresh(){this.clear(),super.refresh()}}class Rp extends Pe{constructor(t,e){super(t),this.tile=e}}const ya={TILELOADSTART:"tileloadstart",TILELOADEND:"tileloadend",TILELOADERROR:"tileloaderror"};class xa extends Cp{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tilePixelRatio:t.tilePixelRatio,wrapX:t.wrapX,transition:t.transition,interpolate:t.interpolate,key:t.key,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.generateTileUrlFunction_=this.tileUrlFunction===xa.prototype.tileUrlFunction,this.tileLoadFunction=t.tileLoadFunction,t.tileUrlFunction&&(this.tileUrlFunction=t.tileUrlFunction),this.urls=null,t.urls?this.setUrls(t.urls):t.url&&this.setUrl(t.url),this.tileLoadingKeys_={}}getTileLoadFunction(){return this.tileLoadFunction}getTileUrlFunction(){return Object.getPrototypeOf(this).tileUrlFunction===this.tileUrlFunction?this.tileUrlFunction.bind(this):this.tileUrlFunction}getUrls(){return this.urls}handleTileChange(t){const e=t.target,i=j(e),s=e.getState();let r;s==G.LOADING?(this.tileLoadingKeys_[i]=!0,r=ya.TILELOADSTART):i in this.tileLoadingKeys_&&(delete this.tileLoadingKeys_[i],r=s==G.ERROR?ya.TILELOADERROR:s==G.LOADED?ya.TILELOADEND:void 0),r!=null&&this.dispatchEvent(new Rp(r,e))}setTileLoadFunction(t){this.tileLoadFunction=t,this.changed()}setTileUrlFunction(t,e){this.tileUrlFunction=t,typeof e<"u"?this.setKey(e):this.changed()}setUrl(t){const e=xp(t);this.urls=e,this.setUrls(e)}setUrls(t){this.urls=t;const e=t.join(`
|
|
8
|
-
`);this.generateTileUrlFunction_?this.setTileUrlFunction(vp(t,this.tileGrid),e):this.setKey(e)}tileUrlFunction(t,e,i){}}class Tp extends xa{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:qc,tilePixelRatio:t.tilePixelRatio,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:t.wrapX,transition:t.transition,interpolate:t.interpolate!==void 0?t.interpolate:!0,key:t.key,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.crossOrigin=t.crossOrigin!==void 0?t.crossOrigin:null,this.tileClass=t.tileClass!==void 0?t.tileClass:kc,this.tileGridForProjection={},this.reprojectionErrorThreshold_=t.reprojectionErrorThreshold,this.renderReprojectionEdges_=!1}getGutterForProjection(t){return this.getProjection()&&t&&!sr(this.getProjection(),t)?0:this.getGutter()}getGutter(){return 0}getKey(){let t=super.getKey();return this.getInterpolate()||(t+=":disable-interpolation"),t}getTileGridForProjection(t){const e=this.getProjection();if(this.tileGrid&&(!e||sr(e,t)))return this.tileGrid;const i=j(t);return i in this.tileGridForProjection||(this.tileGridForProjection[i]=jc(t)),this.tileGridForProjection[i]}createTile_(t,e,i,s,r,o){const a=[t,e,i],l=this.getTileCoordForTileUrlFunction(a,r),h=l?this.tileUrlFunction(l,s,r):void 0,c=new this.tileClass(a,h!==void 0?G.IDLE:G.EMPTY,h!==void 0?h:"",this.crossOrigin,this.tileLoadFunction,this.tileOptions);return c.key=o,c.addEventListener(W.CHANGE,this.handleTileChange.bind(this)),c}getTile(t,e,i,s,r,o){const a=this.getProjection();if(!a||!r||sr(a,r))return this.getTileInternal(t,e,i,s,a||r);const l=[t,e,i],h=this.getKey(),c=this.getTileGridForProjection(a),u=this.getTileGridForProjection(r),d=this.getTileCoordForTileUrlFunction(l,r),f=new Uc(a,c,r,u,l,d,this.getTilePixelRatio(s),this.getGutter(),(g,m,_,p)=>this.getTileInternal(g,m,_,p,a,o),this.reprojectionErrorThreshold_,this.renderReprojectionEdges_,this.tileOptions);return f.key=h,f}getTileInternal(t,e,i,s,r,o){const a=this.getKey(),l=Mr(this,a,t,e,i);if(o&&o.containsKey(l))return o.get(l);const h=this.createTile_(t,e,i,s,r,a);return o?.set(l,h),h}setRenderReprojectionEdges(t){this.renderReprojectionEdges_!=t&&(this.renderReprojectionEdges_=t,this.changed())}setTileGridForProjection(t,e){const i=Nt(t);if(i){const s=j(i);s in this.tileGridForProjection||(this.tileGridForProjection[s]=e)}}}function qc(n,t){if(Bt){const e=n.getCrossOrigin();let i="same-origin",s="same-origin";e==="anonymous"||e===""?(i="cors",s="omit"):e==="use-credentials"&&(i="cors",s="include"),fetch(t,{mode:i,credentials:s}).then(r=>{if(!r.ok)throw new Error(`HTTP ${r.status}`);return r.blob()}).then(r=>createImageBitmap(r)).then(r=>{const o=n.getImage();o.width=r.width,o.height=r.height,o.getContext("2d").drawImage(r,0,0),r.close?.(),o.dispatchEvent(new Event("load"))}).catch(()=>{n.getImage().dispatchEvent(new Event("error"))});return}n.getImage().src=t}class Jc extends Tp{constructor(t){t=t||{};const e=t.projection!==void 0?t.projection:"EPSG:3857",i=t.tileGrid!==void 0?t.tileGrid:dp({extent:pa(e),maxResolution:t.maxResolution,maxZoom:t.maxZoom,minZoom:t.minZoom,tileSize:t.tileSize});super({attributions:t.attributions,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,interpolate:t.interpolate,projection:e,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileGrid:i,tileLoadFunction:t.tileLoadFunction,tilePixelRatio:t.tilePixelRatio,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:t.wrapX!==void 0?t.wrapX:!0,transition:t.transition,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.gutter_=t.gutter!==void 0?t.gutter:0}getGutter(){return this.gutter_}}const Ip='© <a href="https://www.openstreetmap.org/copyright" target="_blank">OpenStreetMap</a> contributors.';class Sp extends Jc{constructor(t){t=t||{};let e;t.attributions!==void 0?e=t.attributions:e=[Ip];const i=t.crossOrigin!==void 0?t.crossOrigin:"anonymous",s=t.url!==void 0?t.url:"https://tile.openstreetmap.org/{z}/{x}/{y}.png";super({attributions:e,attributionsCollapsible:!1,cacheSize:t.cacheSize,crossOrigin:i,interpolate:t.interpolate,maxZoom:t.maxZoom!==void 0?t.maxZoom:19,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileLoadFunction:(r,o)=>{const a=r.getImage();!Bt&&a instanceof HTMLImageElement&&(a.referrerPolicy="origin-when-cross-origin"),(t.tileLoadFunction||qc)(r,o)},transition:t.transition,url:s,wrapX:t.wrapX,zDirection:t.zDirection})}}function Ea(n){return n instanceof Image||n instanceof HTMLCanvasElement||n instanceof HTMLVideoElement||n instanceof ImageBitmap?n:null}const bp=new Error("disposed"),Lp=[256,256];class Qc extends oa{constructor(t){const e=G.IDLE;super(t.tileCoord,e,{transition:t.transition,interpolate:t.interpolate}),this.loader_=t.loader,this.data_=null,this.error_=null,this.size_=t.size||null,this.controller_=t.controller||null}getSize(){if(this.size_)return this.size_;const t=Ea(this.data_);return t?[t.width,t.height]:Lp}getData(){return this.data_}getError(){return this.error_}load(){if(this.state!==G.IDLE&&this.state!==G.ERROR)return;this.state=G.LOADING,this.changed();const t=this;this.loader_().then(function(e){t.data_=e,t.state=G.LOADED,t.changed()}).catch(function(e){t.error_=e,t.state=G.ERROR,t.changed()})}disposeInternal(){this.controller_&&(this.controller_.abort(bp),this.controller_=null),super.disposeInternal()}}class tu{constructor(t){this.highWaterMark=t!==void 0?t:2048,this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}deleteOldest(){const t=this.pop();t instanceof zs&&t.dispose()}canExpireCache(){return this.highWaterMark>0&&this.getCount()>this.highWaterMark}expireCache(t){for(;this.canExpireCache();)this.deleteOldest()}clear(){for(;this.oldest_;)this.deleteOldest()}containsKey(t){return this.entries_.hasOwnProperty(t)}forEach(t){let e=this.oldest_;for(;e;)t(e.value_,e.key_,this),e=e.newer}get(t,e){const i=this.entries_[t];return Q(i!==void 0,"Tried to get a value for a key that does not exist in the cache"),i===this.newest_||(i===this.oldest_?(this.oldest_=this.oldest_.newer,this.oldest_.older=null):(i.newer.older=i.older,i.older.newer=i.newer),i.newer=null,i.older=this.newest_,this.newest_.newer=i,this.newest_=i),i.value_}remove(t){const e=this.entries_[t];return Q(e!==void 0,"Tried to get a value for a key that does not exist in the cache"),e===this.newest_?(this.newest_=e.older,this.newest_&&(this.newest_.newer=null)):e===this.oldest_?(this.oldest_=e.newer,this.oldest_&&(this.oldest_.older=null)):(e.newer.older=e.older,e.older.newer=e.newer),delete this.entries_[t],--this.count_,e.value_}getCount(){return this.count_}getKeys(){const t=new Array(this.count_);let e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.key_;return t}getValues(){const t=new Array(this.count_);let e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.value_;return t}peekLast(){return this.oldest_.value_}peekLastKey(){return this.oldest_.key_}peekFirstKey(){return this.newest_.key_}peek(t){return this.entries_[t]?.value_}pop(){const t=this.oldest_;return delete this.entries_[t.key_],t.newer&&(t.newer.older=null),this.oldest_=t.newer,this.oldest_||(this.newest_=null),--this.count_,t.value_}replace(t,e){this.get(t),this.entries_[t].value_=e}set(t,e){Q(!(t in this.entries_),"Tried to set a value for a key that is used already");const i={key_:t,newer:null,older:this.newest_,value_:e};this.newest_?this.newest_.newer=i:this.oldest_=i,this.newest_=i,this.entries_[t]=i,++this.count_}setSize(t){this.highWaterMark=t}}function va(n,t,e){if(!(e in n))return n[e]=new Set([t]),!0;const i=n[e],s=i.has(t);return s||i.add(t),!s}function Ap(n,t,e){const i=n[e];return i?i.delete(t):!1}function eu(n,t){const e=n.layerStatesArray[n.layerIndex];e.extent&&(t=Ci(t,ni(e.extent,n.viewState.projection)));const i=e.layer.getRenderSource();if(!i.getWrapX()){const s=i.getTileGridForProjection(n.viewState.projection).getExtent();s&&(t=Ci(t,s))}return t}class Mp extends gc{constructor(t,e){super(t),e=e||{},this.extentChanged=!0,this.renderComplete=!1,this.renderedExtent_=null,this.renderedPixelRatio,this.renderedProjection=null,this.renderedTiles=[],this.renderedSourceKey_,this.renderedSourceRevision_,this.tempExtent=Kt(),this.tempTileRange_=new ga(0,0,0,0),this.tempTileCoord_=Ar(0,0,0);const i=e.cacheSize!==void 0?e.cacheSize:512;this.tileCache_=new tu(i),this.sourceTileCache_=null,this.maxStaleKeys=i*.5}getTileCache(){return this.tileCache_}getSourceTileCache(){return this.sourceTileCache_||(this.sourceTileCache_=new tu(512)),this.sourceTileCache_}getOrCreateTile(t,e,i,s){const r=this.tileCache_,a=this.getLayer().getSource(),l=Mr(a,a.getKey(),t,e,i);let h;if(r.containsKey(l))h=r.get(l);else{const c=s.viewState.projection,u=a.getProjection();if(h=a.getTile(t,e,i,s.pixelRatio,c,!u||sr(u,c)?void 0:this.getSourceTileCache()),!h)return null;r.set(l,h)}return h}getTile(t,e,i,s){const r=this.getOrCreateTile(t,e,i,s);return r||null}getData(t){const e=this.frameState;if(!e)return null;const i=this.getLayer(),s=ft(e.pixelToCoordinateTransform,t.slice()),r=i.getExtent();if(r&&!Zi(r,s))return null;const o=e.viewState,a=i.getRenderSource(),l=a.getTileGridForProjection(o.projection),h=a.getTilePixelRatio(e.pixelRatio);for(let c=l.getZForResolution(o.resolution);c>=l.getMinZoom();--c){const u=l.getTileCoordForCoordAndZ(s,c),d=this.getTile(c,u[1],u[2],e);if(!d||d.getState()!==G.LOADED)continue;const f=l.getOrigin(c),g=zt(l.getTileSize(c)),m=l.getResolution(c);let _;if(d instanceof kc||d instanceof Uc)_=d.getImage();else if(d instanceof Qc){if(_=Ea(d.getData()),!_)continue}else continue;const p=Math.floor(h*((s[0]-f[0])/m-u[1]*g[0])),y=Math.floor(h*((f[1]-s[1])/m-u[2]*g[1])),w=Math.round(h*a.getGutterForProjection(o.projection));return this.getImageData(_,p+w,y+w)}return null}prepareFrame(t){this.renderedProjection?t.viewState.projection!==this.renderedProjection&&(this.tileCache_.clear(),this.renderedProjection=t.viewState.projection):this.renderedProjection=t.viewState.projection;const e=this.getLayer().getSource();if(!e)return!1;const i=e.getRevision();return this.renderedSourceRevision_?this.renderedSourceRevision_!==i&&(this.renderedSourceRevision_=i,this.renderedSourceKey_===e.getKey()&&(this.tileCache_.clear(),this.sourceTileCache_?.clear())):this.renderedSourceRevision_=i,!0}enqueueTilesForNextExtent(){return!0}enqueueTiles(t,e,i,s,r){const o=t.viewState,a=this.getLayer(),l=a.getRenderSource(),h=l.getTileGridForProjection(o.projection),c=j(l);c in t.wantedTiles||(t.wantedTiles[c]={});const u=t.wantedTiles[c],d=a.getMapInternal(),f=Math.max(i-r,h.getMinZoom(),h.getZForResolution(Math.min(a.getMaxResolution(),d?d.getView().getResolutionForZoom(Math.max(a.getMinZoom(),0)):h.getResolution(0)),l.zDirection)),g=o.rotation,m=g?zl(o.center,o.resolution,g,t.size):void 0;for(let _=i;_>=f;--_){const p=h.getTileRangeForExtentAndZ(e,_,this.tempTileRange_),y=h.getResolution(_);for(let w=p.minX;w<=p.maxX;++w)for(let x=p.minY;x<=p.maxY;++x){if(g&&!h.tileCoordIntersectsViewport([_,w,x],m))continue;const E=this.getTile(_,w,x,t);if(!E||!va(s,E,_))continue;const I=E.getKey();if(u[I]=!0,E.getState()===G.IDLE&&!t.tileQueue.isKeyQueued(I)){const v=Ar(_,w,x,this.tempTileCoord_);t.tileQueue.enqueue([E,c,h.getTileCoordCenter(v),y])}}}}findStaleTile_(t,e){const i=this.tileCache_,s=t[0],r=t[1],o=t[2],a=this.getStaleKeys();for(let l=0;l<a.length;++l){const h=Mr(this.getLayer().getSource(),a[l],s,r,o);if(i.containsKey(h)){const c=i.peek(h);if(c.getState()===G.LOADED)return c.endTransition(j(this)),va(e,c,s),!0}}return!1}findAltTiles_(t,e,i,s){const r=t.getTileRangeForTileCoordAndZ(e,i,this.tempTileRange_);if(!r)return!1;let o=!0;const a=this.tileCache_,l=this.getLayer().getRenderSource(),h=l.getKey();for(let c=r.minX;c<=r.maxX;++c)for(let u=r.minY;u<=r.maxY;++u){const d=Mr(l,h,i,c,u);let f=!1;if(a.containsKey(d)){const g=a.peek(d);g.getState()===G.LOADED&&(va(s,g,i),f=!0)}f||(o=!1)}return o}renderFrame(t,e){this.renderComplete=!0;const i=t.layerStatesArray[t.layerIndex],s=t.viewState,r=s.projection,o=s.resolution,a=s.center,l=t.pixelRatio,h=this.getLayer(),c=h.getSource(),u=c.getTileGridForProjection(r),d=u.getZForResolution(o,c.zDirection),f=u.getResolution(d),g=c.getKey();this.renderedSourceKey_?this.renderedSourceKey_!==g&&(this.prependStaleKey(this.renderedSourceKey_),this.renderedSourceKey_=g):this.renderedSourceKey_=g;let m=t.extent;const _=c.getTilePixelRatio(l);this.prepareContainer(t,e);const p=this.context.canvas.width,y=this.context.canvas.height,w=i.extent&&ni(i.extent);w&&(m=Ci(m,ni(i.extent)));const x=f*p/2/_,E=f*y/2/_,T=[a[0]-x,a[1]-E,a[0]+x,a[1]+E],I={};this.renderedTiles.length=0;const v=h.getPreload();if(t.nextExtent&&this.enqueueTilesForNextExtent()){const D=u.getZForResolution(s.nextResolution,c.zDirection),k=eu(t,t.nextExtent);this.enqueueTiles(t,k,D,I,v)}const R=eu(t,m);if(this.enqueueTiles(t,R,d,I,0),v>0&&setTimeout(()=>{this.enqueueTiles(t,R,d-1,I,v-1)},0),!(d in I))return this.container;const b=j(this),O=t.time;for(const D of I[d]){const k=D.getState();if(k===G.EMPTY)continue;const K=D.tileCoord;if(k===G.LOADED&&D.getAlpha(b,O)===1){D.endTransition(b);continue}if(k!==G.ERROR&&(this.renderComplete=!1),this.findStaleTile_(K,I)){Ap(I,D,d),t.animate=!0;continue}if(this.findAltTiles_(u,K,d+1,I))continue;const gt=u.getMinZoom();for(let xt=d-1;xt>=gt&&!this.findAltTiles_(u,K,xt,I);--xt);}const F=f/o*l/_,A=this.getRenderContext(t);De(this.tempTransform,p/2,y/2,F,F,0,-p/2,-y/2),i.extent&&this.clipUnrotated(A,t,w),c.getInterpolate()||(A.imageSmoothingEnabled=!1),this.preRender(A,t);const L=Object.keys(I).map(Number);L.sort(Me);let M;const P=[],X=[];for(let D=L.length-1;D>=0;--D){const k=L[D],K=c.getTilePixelSize(k,l,r),S=u.getResolution(k)/f,gt=K[0]*S*F,xt=K[1]*S*F,st=u.getTileCoordForCoordAndZ(Ri(T),k),_t=u.getTileCoordExtent(st),ht=ft(this.tempTransform,[_*(_t[0]-T[0])/f,_*(T[3]-_t[3])/f]),Pt=_*c.getGutterForProjection(r);for(const Rt of I[k]){if(Rt.getState()!==G.LOADED)continue;const Zt=Rt.tileCoord,Or=st[1]-Zt[1],wa=Math.round(ht[0]-(Or-1)*gt),gs=st[2]-Zt[2],Ni=Math.round(ht[1]-(gs-1)*xt),re=Math.round(ht[0]-Or*gt),Ce=Math.round(ht[1]-gs*xt),En=wa-re,vn=Ni-Ce,_s=L.length===1;let Gi=!1;M=[re,Ce,re+En,Ce,re+En,Ce+vn,re,Ce+vn];for(let wn=0,Cn=P.length;wn<Cn;++wn)if(!_s&&k<X[wn]){const mt=P[wn];kt([re,Ce,re+En,Ce+vn],[mt[0],mt[3],mt[4],mt[7]])&&(Gi||(A.save(),Gi=!0),A.beginPath(),A.moveTo(M[0],M[1]),A.lineTo(M[2],M[3]),A.lineTo(M[4],M[5]),A.lineTo(M[6],M[7]),A.moveTo(mt[6],mt[7]),A.lineTo(mt[4],mt[5]),A.lineTo(mt[2],mt[3]),A.lineTo(mt[0],mt[1]),A.clip())}P.push(M),X.push(k),this.drawTile(Rt,t,re,Ce,En,vn,Pt,_s),Gi&&A.restore(),this.renderedTiles.unshift(Rt),this.updateUsedTiles(t.usedTiles,c,Rt)}}if(this.renderedResolution=f,this.extentChanged=!this.renderedExtent_||!Gn(this.renderedExtent_,T),this.renderedExtent_=T,this.renderedPixelRatio=l,this.postRender(this.context,t),i.extent&&A.restore(),A.imageSmoothingEnabled=!0,this.renderComplete){const D=(k,K)=>{const J=j(c),S=K.wantedTiles[J],gt=S?Object.keys(S).length:0;this.updateCacheSize(gt),this.tileCache_.expireCache(),this.sourceTileCache_?.expireCache()};t.postRenderFunctions.push(D)}return this.container}updateCacheSize(t){this.tileCache_.highWaterMark=Math.max(this.tileCache_.highWaterMark,t*2)}drawTile(t,e,i,s,r,o,a,l){let h;if(t instanceof Qc){if(h=Ea(t.getData()),!h)throw new Error("Rendering array data is not yet supported")}else h=this.getTileImage(t);if(!h)return;const c=this.getRenderContext(e),u=j(this),d=e.layerStatesArray[e.layerIndex],f=d.opacity*(l?t.getAlpha(u,e.time):1),g=f!==c.globalAlpha;g&&(c.save(),c.globalAlpha=f),c.drawImage(h,a,a,h.width-2*a,h.height-2*a,i,s,r,o),g&&c.restore(),f!==d.opacity?e.animate=!0:l&&t.endTransition(u)}getImage(){const t=this.context;return t?t.canvas:null}getTileImage(t){return t.getImage()}updateUsedTiles(t,e,i){const s=j(e);s in t||(t[s]={}),t[s][i.getKey()]=!0}}const Pr={PRELOAD:"preload",USE_INTERIM_TILES_ON_ERROR:"useInterimTilesOnError"};class Pp extends br{constructor(t){t=t||{};const e=Object.assign({},t),i=t.cacheSize;delete t.cacheSize,delete e.preload,delete e.useInterimTilesOnError,super(e),this.on,this.once,this.un,this.cacheSize_=i,this.setPreload(t.preload!==void 0?t.preload:0),this.setUseInterimTilesOnError(t.useInterimTilesOnError!==void 0?t.useInterimTilesOnError:!0)}getCacheSize(){return this.cacheSize_}getPreload(){return this.get(Pr.PRELOAD)}setPreload(t){this.set(Pr.PRELOAD,t)}getUseInterimTilesOnError(){return this.get(Pr.USE_INTERIM_TILES_ON_ERROR)}setUseInterimTilesOnError(t){this.set(Pr.USE_INTERIM_TILES_ON_ERROR,t)}getData(t){return super.getData(t)}}class iu extends Pp{constructor(t){super(t)}createRenderer(){return new Mp(this,{cacheSize:this.getCacheSize()})}}const nu=`
|
|
1
|
+
(function(gl){"use strict";typeof window<"u"&&((window.__svelte??={}).v??=new Set).add("5");const id=1,nd=4,sd=8,rd=16,od=2,_l="[",ml="[!",pl="]",Gn={},Lt=Symbol(),ao=!1;var ad=Array.isArray,ld=Array.prototype.indexOf,hd=Array.from,ks=Object.keys,Ns=Object.defineProperty,Si=Object.getOwnPropertyDescriptor,cd=Object.prototype,ud=Array.prototype,dd=Object.getPrototypeOf,yl=Object.isExtensible;function fd(n){for(var t=0;t<n.length;t++)n[t]()}function gd(){var n,t,e=new Promise((i,s)=>{n=i,t=s});return{promise:e,resolve:n,reject:t}}const vt=2,lo=4,xl=8,Ae=16,Je=32,Qe=64,Gs=128,_e=512,At=1024,Bt=2048,Pe=4096,ti=8192,ei=16384,zs=32768,Xs=65536,El=1<<17,wl=1<<18,tn=1<<19,_d=1<<20,Ii=32768,ho=1<<21,vl=1<<22,zn=1<<23,Ys=Symbol("$state"),Cl=Symbol("legacy props"),Tl=new class extends Error{name="StaleReactionError";message="The reaction that called `getAbortSignal()` was re-run or destroyed"},Rl=3,Ws=8;function md(n){throw new Error("https://svelte.dev/e/lifecycle_outside_component")}function pd(n){throw new Error("https://svelte.dev/e/effect_in_teardown")}function yd(){throw new Error("https://svelte.dev/e/effect_in_unowned_derived")}function xd(n){throw new Error("https://svelte.dev/e/effect_orphan")}function Ed(){throw new Error("https://svelte.dev/e/effect_update_depth_exceeded")}function wd(){throw new Error("https://svelte.dev/e/hydration_failed")}function vd(n){throw new Error("https://svelte.dev/e/props_invalid_value")}function Cd(){throw new Error("https://svelte.dev/e/state_descriptors_fixed")}function Td(){throw new Error("https://svelte.dev/e/state_prototype_fixed")}function Rd(){throw new Error("https://svelte.dev/e/state_unsafe_mutation")}function Sd(){throw new Error("https://svelte.dev/e/svelte_boundary_reset_onerror")}function co(n){console.warn("https://svelte.dev/e/hydration_mismatch")}function Id(){console.warn("https://svelte.dev/e/svelte_boundary_reset_noop")}let Tt=!1;function Vs(n){Tt=n}let st;function Me(n){if(n===null)throw co(),Gn;return st=n}function Sl(){return Me(Oe(st))}function bd(n){if(Tt){if(Oe(st)!==null)throw co(),Gn;st=n}}function Il(n=1){if(Tt){for(var t=n,e=st;t--;)e=Oe(e);st=e}}function Ld(n=!0){for(var t=0,e=st;;){if(e.nodeType===Ws){var i=e.data;if(i===pl){if(t===0)return e;t-=1}else(i===_l||i===ml)&&(t+=1)}var s=Oe(e);n&&e.remove(),e=s}}function bl(n){return n===this.v}function Ad(n,t){return n!=n?t==t:n!==t||n!==null&&typeof n=="object"||typeof n=="function"}function Ll(n){return!Ad(n,this.v)}let Pd=!1,Qt=null;function Bs(n){Qt=n}function Al(n,t=!1,e){Qt={p:Qt,i:!1,c:null,e:null,s:n,x:null,l:null}}function Pl(n){var t=Qt,e=t.e;if(e!==null){t.e=null;for(var i of e)jl(i)}return n!==void 0&&(t.x=n),t.i=!0,Qt=t.p,n??{}}function Ml(){return!0}let bi=[];function Fl(){var n=bi;bi=[],fd(n)}function $s(n){if(bi.length===0&&!Xn){var t=bi;queueMicrotask(()=>{t===bi&&Fl()})}bi.push(n)}function Md(){for(;bi.length>0;)Fl()}function Ol(n){var t=it;if(t===null)return q.f|=zn,n;if((t.f&zs)===0){if((t.f&Gs)===0)throw n;t.b.error(n)}else Ks(n,t)}function Ks(n,t){for(;t!==null;){if((t.f&Gs)!==0)try{t.b.error(n);return}catch(e){n=e}t=t.parent}throw n}const js=new Set;let Pt=null,te=null,ee=[],Us=null,uo=!1,Xn=!1;class me{committed=!1;current=new Map;previous=new Map;#e=new Set;#t=new Set;#l=0;#r=0;#h=null;#o=[];#s=[];skipped_effects=new Set;is_fork=!1;is_deferred(){return this.is_fork||this.#r>0}process(t){ee=[],this.apply();var e={parent:null,effect:null,effects:[],render_effects:[],block_effects:[]};for(const i of t)this.#i(i,e);this.is_fork||this.#c(),this.is_deferred()?(this.#n(e.effects),this.#n(e.render_effects),this.#n(e.block_effects)):(Pt=null,kl(e.render_effects),kl(e.effects),this.#h?.resolve()),te=null}#i(t,e){t.f^=At;for(var i=t.first;i!==null;){var s=i.f,r=(s&(Je|Qe))!==0,o=r&&(s&At)!==0,a=o||(s&ti)!==0||this.skipped_effects.has(i);if((i.f&Gs)!==0&&i.b?.is_pending()&&(e={parent:e,effect:i,effects:[],render_effects:[],block_effects:[]}),!a&&i.fn!==null){r?i.f^=At:(s&lo)!==0?e.effects.push(i):$n(i)&&((i.f&Ae)!==0&&e.block_effects.push(i),Kn(i));var l=i.first;if(l!==null){i=l;continue}}var h=i.parent;for(i=i.next;i===null&&h!==null;)h===e.effect&&(this.#n(e.effects),this.#n(e.render_effects),this.#n(e.block_effects),e=e.parent),i=h.next,h=h.parent}}#n(t){for(const e of t)((e.f&Bt)!==0?this.#o:this.#s).push(e),this.#a(e.deps),Ft(e,At)}#a(t){if(t!==null)for(const e of t)(e.f&vt)===0||(e.f&Ii)===0||(e.f^=Ii,this.#a(e.deps))}capture(t,e){this.previous.has(t)||this.previous.set(t,e),(t.f&zn)===0&&(this.current.set(t,t.v),te?.set(t,t.v))}activate(){Pt=this,this.apply()}deactivate(){Pt===this&&(Pt=null,te=null)}flush(){if(this.activate(),ee.length>0){if(Dl(),Pt!==null&&Pt!==this)return}else this.#l===0&&this.process([]);this.deactivate()}discard(){for(const t of this.#t)t(this);this.#t.clear()}#c(){if(this.#r===0){for(const t of this.#e)t();this.#e.clear()}this.#l===0&&this.#u()}#u(){if(js.size>1){this.previous.clear();var t=te,e=!0,i={parent:null,effect:null,effects:[],render_effects:[],block_effects:[]};for(const r of js){if(r===this){e=!1;continue}const o=[];for(const[l,h]of this.current){if(r.current.has(l))if(e&&h!==r.current.get(l))r.current.set(l,h);else continue;o.push(l)}if(o.length===0)continue;const a=[...r.current.keys()].filter(l=>!this.current.has(l));if(a.length>0){var s=ee;ee=[];const l=new Set,h=new Map;for(const c of o)Nl(c,a,l,h);if(ee.length>0){Pt=r,r.apply();for(const c of ee)r.#i(c,i);r.deactivate()}ee=s}}Pt=null,te=t}this.committed=!0,js.delete(this)}increment(t){this.#l+=1,t&&(this.#r+=1)}decrement(t){this.#l-=1,t&&(this.#r-=1),this.revive()}revive(){for(const t of this.#o)Ft(t,Bt),en(t);for(const t of this.#s)Ft(t,Pe),en(t);this.#o=[],this.#s=[],this.flush()}oncommit(t){this.#e.add(t)}ondiscard(t){this.#t.add(t)}settled(){return(this.#h??=gd()).promise}static ensure(){if(Pt===null){const t=Pt=new me;js.add(Pt),Xn||me.enqueue(()=>{Pt===t&&t.flush()})}return Pt}static enqueue(t){$s(t)}apply(){}}function ii(n){var t=Xn;Xn=!0;try{for(var e;;){if(Md(),ee.length===0&&(Pt?.flush(),ee.length===0))return Us=null,e;Dl()}}finally{Xn=t}}function Dl(){var n=ri;uo=!0;var t=null;try{var e=0;for(Js(!0);ee.length>0;){var i=me.ensure();if(e++>1e3){var s,r;Fd()}i.process(ee),ni.clear()}}finally{uo=!1,Js(n),Us=null}}function Fd(){try{Ed()}catch(n){Ks(n,Us)}}let Fe=null;function kl(n){var t=n.length;if(t!==0){for(var e=0;e<t;){var i=n[e++];if((i.f&(ei|ti))===0&&$n(i)&&(Fe=new Set,Kn(i),i.deps===null&&i.first===null&&i.nodes_start===null&&(i.teardown===null&&i.ac===null?ql(i):i.fn=null),Fe?.size>0)){ni.clear();for(const s of Fe){if((s.f&(ei|ti))!==0)continue;const r=[s];let o=s.parent;for(;o!==null;)Fe.has(o)&&(Fe.delete(o),r.push(o)),o=o.parent;for(let a=r.length-1;a>=0;a--){const l=r[a];(l.f&(ei|ti))===0&&Kn(l)}}Fe.clear()}}Fe=null}}function Nl(n,t,e,i){if(!e.has(n)&&(e.add(n),n.reactions!==null))for(const s of n.reactions){const r=s.f;(r&vt)!==0?Nl(s,t,e,i):(r&(vl|Ae))!==0&&(r&Bt)===0&&Gl(s,t,i)&&(Ft(s,Bt),en(s))}}function Gl(n,t,e){const i=e.get(n);if(i!==void 0)return i;if(n.deps!==null)for(const s of n.deps){if(t.includes(s))return!0;if((s.f&vt)!==0&&Gl(s,t,e))return e.set(s,!0),!0}return e.set(n,!1),!1}function en(n){for(var t=Us=n;t.parent!==null;){t=t.parent;var e=t.f;if(uo&&t===it&&(e&Ae)!==0&&(e&wl)===0)return;if((e&(Qe|Je))!==0){if((e&At)===0)return;t.f^=At}}ee.push(t)}function Od(n){let t=0,e=Zs(0),i;return()=>{Hs()&&(Z(e),Ul(()=>(t===0&&(i=Eo(()=>n(()=>Yn(e)))),t+=1,()=>{$s(()=>{t-=1,t===0&&(i?.(),i=void 0,Yn(e))})})))}}var Dd=Xs|tn|Gs;function kd(n,t,e){new Nd(n,t,e)}class Nd{parent;#e=!1;#t;#l=Tt?st:null;#r;#h;#o;#s=null;#i=null;#n=null;#a=null;#c=null;#u=0;#d=0;#g=!1;#f=null;#x=Od(()=>(this.#f=Zs(this.#u),()=>{this.#f=null}));constructor(t,e,i){this.#t=t,this.#r=e,this.#h=i,this.parent=it.b,this.#e=!!this.#r.pending,this.#o=Qd(()=>{if(it.b=this,Tt){const r=this.#l;Sl(),r.nodeType===Ws&&r.data===ml?this.#w():this.#E()}else{var s=this.#p();try{this.#s=Li(()=>i(s))}catch(r){this.error(r)}this.#d>0?this.#m():this.#e=!1}return()=>{this.#c?.remove()}},Dd),Tt&&(this.#t=st)}#E(){try{this.#s=Li(()=>this.#h(this.#t))}catch(t){this.error(t)}this.#e=!1}#w(){const t=this.#r.pending;t&&(this.#i=Li(()=>t(this.#t)),me.enqueue(()=>{var e=this.#p();this.#s=this.#_(()=>(me.ensure(),Li(()=>this.#h(e)))),this.#d>0?this.#m():(qs(this.#i,()=>{this.#i=null}),this.#e=!1)}))}#p(){var t=this.#t;return this.#e&&(this.#c=Wn(),this.#t.before(this.#c),t=this.#c),t}is_pending(){return this.#e||!!this.parent&&this.parent.is_pending()}has_pending_snippet(){return!!this.#r.pending}#_(t){var e=it,i=q,s=Qt;oi(this.#o),ne(this.#o),Bs(this.#o.ctx);try{return t()}catch(r){return Ol(r),null}finally{oi(e),ne(i),Bs(s)}}#m(){const t=this.#r.pending;this.#s!==null&&(this.#a=document.createDocumentFragment(),this.#a.append(this.#c),sf(this.#s,this.#a)),this.#i===null&&(this.#i=Li(()=>t(this.#t)))}#y(t){if(!this.has_pending_snippet()){this.parent&&this.parent.#y(t);return}this.#d+=t,this.#d===0&&(this.#e=!1,this.#i&&qs(this.#i,()=>{this.#i=null}),this.#a&&(this.#t.before(this.#a),this.#a=null))}update_pending_count(t){this.#y(t),this.#u+=t,this.#f&&Wl(this.#f,this.#u)}get_effect_pending(){return this.#x(),Z(this.#f)}error(t){var e=this.#r.onerror;let i=this.#r.failed;if(this.#g||!e&&!i)throw t;this.#s&&(pe(this.#s),this.#s=null),this.#i&&(pe(this.#i),this.#i=null),this.#n&&(pe(this.#n),this.#n=null),Tt&&(Me(this.#l),Il(),Me(Ld()));var s=!1,r=!1;const o=()=>{if(s){Id();return}s=!0,r&&Sd(),me.ensure(),this.#u=0,this.#n!==null&&qs(this.#n,()=>{this.#n=null}),this.#e=this.has_pending_snippet(),this.#s=this.#_(()=>(this.#g=!1,Li(()=>this.#h(this.#t)))),this.#d>0?this.#m():this.#e=!1};var a=q;try{ne(null),r=!0,e?.(t,o),r=!1}catch(l){Ks(l,this.#o&&this.#o.parent)}finally{ne(a)}i&&$s(()=>{this.#n=this.#_(()=>{me.ensure(),this.#g=!0;try{return Li(()=>{i(this.#t,()=>t,()=>o)})}catch(l){return Ks(l,this.#o.parent),null}finally{this.#g=!1}})})}}function fo(n){var t=vt|Bt,e=q!==null&&(q.f&vt)!==0?q:null;return it!==null&&(it.f|=tn),{ctx:Qt,deps:null,effects:null,equals:bl,f:t,fn:n,reactions:null,rv:0,v:Lt,wv:0,parent:e??it,ac:null}}function Gd(n){const t=fo(n);return th(t),t}function zd(n){const t=fo(n);return t.equals=Ll,t}function zl(n){var t=n.effects;if(t!==null){n.effects=null;for(var e=0;e<t.length;e+=1)pe(t[e])}}function Xd(n){for(var t=n.parent;t!==null;){if((t.f&vt)===0)return(t.f&ei)===0?t:null;t=t.parent}return null}function go(n){var t,e=it;oi(Xd(n));try{n.f&=~Ii,zl(n),t=rh(n)}finally{oi(e)}return t}function Xl(n){var t=go(n);if(n.equals(t)||(Pt?.is_fork||(n.v=t),n.wv=nh()),!Ai)if(te!==null)Hs()&&te.set(n,t);else{var e=(n.f&_e)===0?Pe:At;Ft(n,e)}}let _o=new Set;const ni=new Map;let Yl=!1;function Zs(n,t){var e={f:0,v:n,reactions:null,equals:bl,rv:0,wv:0};return e}function ie(n,t){const e=Zs(n);return th(e),e}function Yd(n,t=!1,e=!0){const i=Zs(n);return t||(i.equals=Ll),i}function zt(n,t,e=!1){q!==null&&(!Ce||(q.f&El)!==0)&&Ml()&&(q.f&(vt|Ae|vl|El))!==0&&!De?.includes(n)&&Rd();let i=e?nn(t):t;return Wl(n,i)}function Wl(n,t){if(!n.equals(t)){var e=n.v;Ai?ni.set(n,t):ni.set(n,e),n.v=t;var i=me.ensure();i.capture(n,e),(n.f&vt)!==0&&((n.f&Bt)!==0&&go(n),Ft(n,(n.f&_e)!==0?At:Pe)),n.wv=nh(),Vl(n,Bt),it!==null&&(it.f&At)!==0&&(it.f&(Je|Qe))===0&&(se===null?rf([n]):se.push(n)),!i.is_fork&&_o.size>0&&!Yl&&Wd()}return t}function Wd(){Yl=!1;var n=ri;Js(!0);const t=Array.from(_o);try{for(const e of t)(e.f&At)!==0&&Ft(e,Pe),$n(e)&&Kn(e)}finally{Js(n)}_o.clear()}function Yn(n){zt(n,n.v+1)}function Vl(n,t){var e=n.reactions;if(e!==null)for(var i=e.length,s=0;s<i;s++){var r=e[s],o=r.f,a=(o&Bt)===0;if(a&&Ft(r,t),(o&vt)!==0){var l=r;te?.delete(l),(o&Ii)===0&&(o&_e&&(r.f|=Ii),Vl(l,Pe))}else a&&((o&Ae)!==0&&Fe!==null&&Fe.add(r),en(r))}}function nn(n){if(typeof n!="object"||n===null||Ys in n)return n;const t=dd(n);if(t!==cd&&t!==ud)return n;var e=new Map,i=ad(n),s=ie(0),r=Pi,o=a=>{if(Pi===r)return a();var l=q,h=Pi;ne(null),ih(r);var c=a();return ne(l),ih(h),c};return i&&e.set("length",ie(n.length)),new Proxy(n,{defineProperty(a,l,h){(!("value"in h)||h.configurable===!1||h.enumerable===!1||h.writable===!1)&&Cd();var c=e.get(l);return c===void 0?c=o(()=>{var u=ie(h.value);return e.set(l,u),u}):zt(c,h.value,!0),!0},deleteProperty(a,l){var h=e.get(l);if(h===void 0){if(l in a){const c=o(()=>ie(Lt));e.set(l,c),Yn(s)}}else zt(h,Lt),Yn(s);return!0},get(a,l,h){if(l===Ys)return n;var c=e.get(l),u=l in a;if(c===void 0&&(!u||Si(a,l)?.writable)&&(c=o(()=>{var f=nn(u?a[l]:Lt),g=ie(f);return g}),e.set(l,c)),c!==void 0){var d=Z(c);return d===Lt?void 0:d}return Reflect.get(a,l,h)},getOwnPropertyDescriptor(a,l){var h=Reflect.getOwnPropertyDescriptor(a,l);if(h&&"value"in h){var c=e.get(l);c&&(h.value=Z(c))}else if(h===void 0){var u=e.get(l),d=u?.v;if(u!==void 0&&d!==Lt)return{enumerable:!0,configurable:!0,value:d,writable:!0}}return h},has(a,l){if(l===Ys)return!0;var h=e.get(l),c=h!==void 0&&h.v!==Lt||Reflect.has(a,l);if(h!==void 0||it!==null&&(!c||Si(a,l)?.writable)){h===void 0&&(h=o(()=>{var d=c?nn(a[l]):Lt,f=ie(d);return f}),e.set(l,h));var u=Z(h);if(u===Lt)return!1}return c},set(a,l,h,c){var u=e.get(l),d=l in a;if(i&&l==="length")for(var f=h;f<u.v;f+=1){var g=e.get(f+"");g!==void 0?zt(g,Lt):f in a&&(g=o(()=>ie(Lt)),e.set(f+"",g))}if(u===void 0)(!d||Si(a,l)?.writable)&&(u=o(()=>ie(void 0)),zt(u,nn(h)),e.set(l,u));else{d=u.v!==Lt;var m=o(()=>nn(h));zt(u,m)}var _=Reflect.getOwnPropertyDescriptor(a,l);if(_?.set&&_.set.call(c,h),!d){if(i&&typeof l=="string"){var p=e.get("length"),y=Number(l);Number.isInteger(y)&&y>=p.v&&zt(p,y+1)}Yn(s)}return!0},ownKeys(a){Z(s);var l=Reflect.ownKeys(a).filter(u=>{var d=e.get(u);return d===void 0||d.v!==Lt});for(var[h,c]of e)c.v!==Lt&&!(h in a)&&l.push(h);return l},setPrototypeOf(){Td()}})}var mo,Bl,$l,Kl;function po(){if(mo===void 0){mo=window,Bl=/Firefox/.test(navigator.userAgent);var n=Element.prototype,t=Node.prototype,e=Text.prototype;$l=Si(t,"firstChild").get,Kl=Si(t,"nextSibling").get,yl(n)&&(n.__click=void 0,n.__className=void 0,n.__attributes=null,n.__style=void 0,n.__e=void 0),yl(e)&&(e.__t=void 0)}}function Wn(n=""){return document.createTextNode(n)}function Vn(n){return $l.call(n)}function Oe(n){return Kl.call(n)}function Vd(n,t){if(!Tt)return Vn(n);var e=Vn(st);return e===null&&(e=st.appendChild(Wn())),Me(e),e}function Bd(n,t=!1){if(!Tt){var e=Vn(n);return e instanceof Comment&&e.data===""?Oe(e):e}if(t&&st?.nodeType!==Rl){var i=Wn();return st?.before(i),Me(i),i}return st}function $d(n,t=1,e=!1){let i=Tt?st:n;for(var s;t--;)s=i,i=Oe(i);if(!Tt)return i;if(e&&i?.nodeType!==Rl){var r=Wn();return i===null?s?.after(r):i.before(r),Me(r),r}return Me(i),i}function Kd(n){n.textContent=""}function yo(n){var t=q,e=it;ne(null),oi(null);try{return n()}finally{ne(t),oi(e)}}function jd(n){it===null&&(q===null&&xd(),yd()),Ai&&pd()}function Ud(n,t){var e=t.last;e===null?t.last=t.first=n:(e.next=n,n.prev=e,t.last=n)}function si(n,t,e){var i=it;i!==null&&(i.f&ti)!==0&&(n|=ti);var s={ctx:Qt,deps:null,nodes_start:null,nodes_end:null,f:n|Bt|_e,first:null,fn:t,last:null,next:null,parent:i,b:i&&i.b,prev:null,teardown:null,transitions:null,wv:0,ac:null};if(e)try{Kn(s),s.f|=zs}catch(a){throw pe(s),a}else t!==null&&en(s);var r=s;if(e&&r.deps===null&&r.teardown===null&&r.nodes_start===null&&r.first===r.last&&(r.f&tn)===0&&(r=r.first,(n&Ae)!==0&&(n&Xs)!==0&&r!==null&&(r.f|=Xs)),r!==null&&(r.parent=i,i!==null&&Ud(r,i),q!==null&&(q.f&vt)!==0&&(n&Qe)===0)){var o=q;(o.effects??=[]).push(r)}return s}function Hs(){return q!==null&&!Ce}function Zd(n){const t=si(xl,null,!1);return Ft(t,At),t.teardown=n,t}function xo(n){jd();var t=it.f,e=!q&&(t&Je)!==0&&(t&zs)===0;if(e){var i=Qt;(i.e??=[]).push(n)}else return jl(n)}function jl(n){return si(lo|_d,n,!1)}function Hd(n){me.ensure();const t=si(Qe|tn,n,!0);return()=>{pe(t)}}function qd(n){me.ensure();const t=si(Qe|tn,n,!0);return(e={})=>new Promise(i=>{e.outro?qs(t,()=>{pe(t),i(void 0)}):(pe(t),i(void 0))})}function Jd(n){return si(lo,n,!1)}function Ul(n,t=0){return si(xl|t,n,!0)}function Qd(n,t=0){var e=si(Ae|t,n,!0);return e}function Li(n){return si(Je|tn,n,!0)}function Zl(n){var t=n.teardown;if(t!==null){const e=Ai,i=q;Ql(!0),ne(null);try{t.call(null)}finally{Ql(e),ne(i)}}}function Hl(n,t=!1){var e=n.first;for(n.first=n.last=null;e!==null;){const s=e.ac;s!==null&&yo(()=>{s.abort(Tl)});var i=e.next;(e.f&Qe)!==0?e.parent=null:pe(e,t),e=i}}function tf(n){for(var t=n.first;t!==null;){var e=t.next;(t.f&Je)===0&&pe(t),t=e}}function pe(n,t=!0){var e=!1;(t||(n.f&wl)!==0)&&n.nodes_start!==null&&n.nodes_end!==null&&(ef(n.nodes_start,n.nodes_end),e=!0),Hl(n,t&&!e),Qs(n,0),Ft(n,ei);var i=n.transitions;if(i!==null)for(const r of i)r.stop();Zl(n);var s=n.parent;s!==null&&s.first!==null&&ql(n),n.next=n.prev=n.teardown=n.ctx=n.deps=n.fn=n.nodes_start=n.nodes_end=n.ac=null}function ef(n,t){for(;n!==null;){var e=n===t?null:Oe(n);n.remove(),n=e}}function ql(n){var t=n.parent,e=n.prev,i=n.next;e!==null&&(e.next=i),i!==null&&(i.prev=e),t!==null&&(t.first===n&&(t.first=i),t.last===n&&(t.last=e))}function qs(n,t,e=!0){var i=[];Jl(n,i,!0),nf(i,()=>{e&&pe(n),t&&t()})}function nf(n,t){var e=n.length;if(e>0){var i=()=>--e||t();for(var s of n)s.out(i)}else t()}function Jl(n,t,e){if((n.f&ti)===0){if(n.f^=ti,n.transitions!==null)for(const o of n.transitions)(o.is_global||e)&&t.push(o);for(var i=n.first;i!==null;){var s=i.next,r=(i.f&Xs)!==0||(i.f&Je)!==0&&(n.f&Ae)!==0;Jl(i,t,r?e:!1),i=s}}}function sf(n,t){for(var e=n.nodes_start,i=n.nodes_end;e!==null;){var s=e===i?null:Oe(e);t.append(e),e=s}}let ri=!1;function Js(n){ri=n}let Ai=!1;function Ql(n){Ai=n}let q=null,Ce=!1;function ne(n){q=n}let it=null;function oi(n){it=n}let De=null;function th(n){q!==null&&(De===null?De=[n]:De.push(n))}let Mt=null,$t=0,se=null;function rf(n){se=n}let eh=1,Bn=0,Pi=Bn;function ih(n){Pi=n}function nh(){return++eh}function $n(n){var t=n.f;if((t&Bt)!==0)return!0;if(t&vt&&(n.f&=~Ii),(t&Pe)!==0){var e=n.deps;if(e!==null)for(var i=e.length,s=0;s<i;s++){var r=e[s];if($n(r)&&Xl(r),r.wv>n.wv)return!0}(t&_e)!==0&&te===null&&Ft(n,At)}return!1}function sh(n,t,e=!0){var i=n.reactions;if(i!==null&&!De?.includes(n))for(var s=0;s<i.length;s++){var r=i[s];(r.f&vt)!==0?sh(r,t,!1):t===r&&(e?Ft(r,Bt):(r.f&At)!==0&&Ft(r,Pe),en(r))}}function rh(n){var t=Mt,e=$t,i=se,s=q,r=De,o=Qt,a=Ce,l=Pi,h=n.f;Mt=null,$t=0,se=null,q=(h&(Je|Qe))===0?n:null,De=null,Bs(n.ctx),Ce=!1,Pi=++Bn,n.ac!==null&&(yo(()=>{n.ac.abort(Tl)}),n.ac=null);try{n.f|=ho;var c=n.fn,u=c(),d=n.deps;if(Mt!==null){var f;if(Qs(n,$t),d!==null&&$t>0)for(d.length=$t+Mt.length,f=0;f<Mt.length;f++)d[$t+f]=Mt[f];else n.deps=d=Mt;if(ri&&Hs()&&(n.f&_e)!==0)for(f=$t;f<d.length;f++)(d[f].reactions??=[]).push(n)}else d!==null&&$t<d.length&&(Qs(n,$t),d.length=$t);if(Ml()&&se!==null&&!Ce&&d!==null&&(n.f&(vt|Pe|Bt))===0)for(f=0;f<se.length;f++)sh(se[f],n);return s!==null&&s!==n&&(Bn++,se!==null&&(i===null?i=se:i.push(...se))),(n.f&zn)!==0&&(n.f^=zn),u}catch(g){return Ol(g)}finally{n.f^=ho,Mt=t,$t=e,se=i,q=s,De=r,Bs(o),Ce=a,Pi=l}}function of(n,t){let e=t.reactions;if(e!==null){var i=ld.call(e,n);if(i!==-1){var s=e.length-1;s===0?e=t.reactions=null:(e[i]=e[s],e.pop())}}e===null&&(t.f&vt)!==0&&(Mt===null||!Mt.includes(t))&&(Ft(t,Pe),(t.f&_e)!==0&&(t.f^=_e,t.f&=~Ii),zl(t),Qs(t,0))}function Qs(n,t){var e=n.deps;if(e!==null)for(var i=t;i<e.length;i++)of(n,e[i])}function Kn(n){var t=n.f;if((t&ei)===0){Ft(n,At);var e=it,i=ri;it=n,ri=!0;try{(t&Ae)!==0?tf(n):Hl(n),Zl(n);var s=rh(n);n.teardown=typeof s=="function"?s:null,n.wv=eh;var r;ao&&Pd&&(n.f&Bt)!==0&&n.deps}finally{ri=i,it=e}}}function Z(n){var t=n.f,e=(t&vt)!==0;if(q!==null&&!Ce){var i=it!==null&&(it.f&ei)!==0;if(!i&&!De?.includes(n)){var s=q.deps;if((q.f&ho)!==0)n.rv<Bn&&(n.rv=Bn,Mt===null&&s!==null&&s[$t]===n?$t++:Mt===null?Mt=[n]:Mt.includes(n)||Mt.push(n));else{(q.deps??=[]).push(n);var r=n.reactions;r===null?n.reactions=[q]:r.includes(q)||r.push(q)}}}if(Ai){if(ni.has(n))return ni.get(n);if(e){var o=n,a=o.v;return((o.f&At)===0&&o.reactions!==null||ah(o))&&(a=go(o)),ni.set(o,a),a}}else e&&!te?.has(n)&&(o=n,$n(o)&&Xl(o),ri&&Hs()&&(o.f&_e)===0&&oh(o));if(te?.has(n))return te.get(n);if((n.f&zn)!==0)throw n.v;return n.v}function oh(n){if(n.deps!==null){n.f^=_e;for(const t of n.deps)(t.reactions??=[]).push(n),(t.f&vt)!==0&&(t.f&_e)===0&&oh(t)}}function ah(n){if(n.v===Lt)return!0;if(n.deps===null)return!1;for(const t of n.deps)if(ni.has(t)||(t.f&vt)!==0&&ah(t))return!0;return!1}function Eo(n){var t=Ce;try{return Ce=!0,n()}finally{Ce=t}}const af=-7169;function Ft(n,t){n.f=n.f&af|t}const lh=new Set,wo=new Set;function lf(n,t,e,i={}){function s(r){if(i.capture||jn.call(t,r),!r.cancelBubble)return yo(()=>e?.call(this,r))}return n.startsWith("pointer")||n.startsWith("touch")||n==="wheel"?$s(()=>{t.addEventListener(n,s,i)}):t.addEventListener(n,s,i),s}function hf(n,t,e,i,s){var r={capture:i,passive:s},o=lf(n,t,e,r);(t===document.body||t===window||t===document||t instanceof HTMLMediaElement)&&Zd(()=>{t.removeEventListener(n,o,r)})}function cf(n){for(var t=0;t<n.length;t++)lh.add(n[t]);for(var e of wo)e(n)}let hh=null;function jn(n){var t=this,e=t.ownerDocument,i=n.type,s=n.composedPath?.()||[],r=s[0]||n.target;hh=n;var o=0,a=hh===n&&n.__root;if(a){var l=s.indexOf(a);if(l!==-1&&(t===document||t===window)){n.__root=t;return}var h=s.indexOf(t);if(h===-1)return;l<=h&&(o=l)}if(r=s[o]||n.target,r!==t){Ns(n,"currentTarget",{configurable:!0,get(){return r||e}});var c=q,u=it;ne(null),oi(null);try{for(var d,f=[];r!==null;){var g=r.assignedSlot||r.parentNode||r.host||null;try{var m=r["__"+i];m!=null&&(!r.disabled||n.target===r)&&m.call(r,n)}catch(_){d?f.push(_):d=_}if(n.cancelBubble||g===t||g===null)break;r=g}if(d){for(let _ of f)queueMicrotask(()=>{throw _});throw d}}finally{n.__root=t,delete n.currentTarget,ne(c),oi(u)}}}function uf(n){var t=document.createElement("template");return t.innerHTML=n.replaceAll("<!>","<!---->"),t.content}function vo(n,t){var e=it;e.nodes_start===null&&(e.nodes_start=n,e.nodes_end=t)}function df(n,t){var e=(t&od)!==0,i,s=!n.startsWith("<!>");return()=>{if(Tt)return vo(st,null),st;i===void 0&&(i=uf(s?n:"<!>"+n));var r=e||Bl?document.importNode(i,!0):i.cloneNode(!0);{var o=Vn(r),a=r.lastChild;vo(o,a)}return r}}function ch(n,t){if(Tt){var e=it;((e.f&zs)===0||e.nodes_end===null)&&(e.nodes_end=st),Sl();return}n!==null&&n.before(t)}const ff=["touchstart","touchmove"];function gf(n){return ff.includes(n)}function uh(n,t){return dh(n,t)}function _f(n,t){po(),t.intro=t.intro??!1;const e=t.target,i=Tt,s=st;try{for(var r=Vn(e);r&&(r.nodeType!==Ws||r.data!==_l);)r=Oe(r);if(!r)throw Gn;Vs(!0),Me(r);const o=dh(n,{...t,anchor:r});return Vs(!1),o}catch(o){if(o instanceof Error&&o.message.split(`
|
|
2
|
+
`).some(a=>a.startsWith("https://svelte.dev/e/")))throw o;return o!==Gn&&console.warn("Failed to hydrate: ",o),t.recover===!1&&wd(),po(),Kd(e),Vs(!1),uh(n,t)}finally{Vs(i),Me(s)}}const sn=new Map;function dh(n,{target:t,anchor:e,props:i={},events:s,context:r,intro:o=!0}){po();var a=new Set,l=u=>{for(var d=0;d<u.length;d++){var f=u[d];if(!a.has(f)){a.add(f);var g=gf(f);t.addEventListener(f,jn,{passive:g});var m=sn.get(f);m===void 0?(document.addEventListener(f,jn,{passive:g}),sn.set(f,1)):sn.set(f,m+1)}}};l(hd(lh)),wo.add(l);var h=void 0,c=qd(()=>{var u=e??t.appendChild(Wn());return kd(u,{pending:()=>{}},d=>{if(r){Al({});var f=Qt;f.c=r}if(s&&(i.$$events=s),Tt&&vo(d,null),h=n(d,i)||{},Tt&&(it.nodes_end=st,st===null||st.nodeType!==Ws||st.data!==pl))throw co(),Gn;r&&Pl()}),()=>{for(var d of a){t.removeEventListener(d,jn);var f=sn.get(d);--f===0?(document.removeEventListener(d,jn),sn.delete(d)):sn.set(d,f)}wo.delete(l),u!==e&&u.parentNode?.removeChild(u)}});return Co.set(h,c),h}let Co=new WeakMap;function mf(n,t){const e=Co.get(n);return e?(Co.delete(n),e(t)):Promise.resolve()}function pf(n){Qt===null&&md(),xo(()=>{const t=Eo(n);if(typeof t=="function")return t})}function yf(n,t){Jd(()=>{var e=n.getRootNode(),i=e.host?e:e.head??e.ownerDocument.head;if(!i.querySelector("#"+t.hash)){const s=document.createElement("style");s.id=t.hash,s.textContent=t.code,i.appendChild(s)}})}let tr=!1;function xf(n){var t=tr;try{return tr=!1,[n(),tr]}finally{tr=t}}function Mi(n,t,e,i){var s=(e&sd)!==0,r=(e&rd)!==0,o=i,a=!0,l=()=>(a&&(a=!1,o=r?Eo(i):i),o),h;if(s){var c=Ys in n||Cl in n;h=Si(n,t)?.set??(c&&t in n?y=>n[t]=y:void 0)}var u,d=!1;s?[u,d]=xf(()=>n[t]):u=n[t],u===void 0&&i!==void 0&&(u=l(),h&&(vd(),h(u)));var f;if(f=()=>{var y=n[t];return y===void 0?l():(a=!0,y)},(e&nd)===0)return f;if(h){var g=n.$$legacy;return(function(y,w){return arguments.length>0?((!w||g||d)&&h(w?f():y),y):f()})}var m=!1,_=((e&id)!==0?fo:zd)(()=>(m=!1,f()));s&&Z(_);var p=it;return(function(y,w){if(arguments.length>0){const x=w?Z(_):s?nn(y):y;return zt(_,x),m=!0,o!==void 0&&(o=x),y}return Ai&&m||(p.f&ei)!==0?_.v:Z(_)})}function Ef(n){return new wf(n)}class wf{#e;#t;constructor(t){var e=new Map,i=(r,o)=>{var a=Yd(o,!1,!1);return e.set(r,a),a};const s=new Proxy({...t.props||{},$$events:{}},{get(r,o){return Z(e.get(o)??i(o,Reflect.get(r,o)))},has(r,o){return o===Cl?!0:(Z(e.get(o)??i(o,Reflect.get(r,o))),Reflect.has(r,o))},set(r,o,a){return zt(e.get(o)??i(o,a),a),Reflect.set(r,o,a)}});this.#t=(t.hydrate?_f:uh)(t.component,{target:t.target,anchor:t.anchor,props:s,context:t.context,intro:t.intro??!1,recover:t.recover}),(!t?.props?.$$host||t.sync===!1)&&ii(),this.#e=s.$$events;for(const r of Object.keys(this.#t))r==="$set"||r==="$destroy"||r==="$on"||Ns(this,r,{get(){return this.#t[r]},set(o){this.#t[r]=o},enumerable:!0});this.#t.$set=r=>{Object.assign(s,r)},this.#t.$destroy=()=>{mf(this.#t)}}$set(t){this.#t.$set(t)}$on(t,e){this.#e[t]=this.#e[t]||[];const i=(...s)=>e.call(this,...s);return this.#e[t].push(i),()=>{this.#e[t]=this.#e[t].filter(s=>s!==i)}}$destroy(){this.#t.$destroy()}}let fh;typeof HTMLElement=="function"&&(fh=class extends HTMLElement{$$ctor;$$s;$$c;$$cn=!1;$$d={};$$r=!1;$$p_d={};$$l={};$$l_u=new Map;$$me;constructor(n,t,e){super(),this.$$ctor=n,this.$$s=t,e&&this.attachShadow({mode:"open"})}addEventListener(n,t,e){if(this.$$l[n]=this.$$l[n]||[],this.$$l[n].push(t),this.$$c){const i=this.$$c.$on(n,t);this.$$l_u.set(t,i)}super.addEventListener(n,t,e)}removeEventListener(n,t,e){if(super.removeEventListener(n,t,e),this.$$c){const i=this.$$l_u.get(t);i&&(i(),this.$$l_u.delete(t))}}async connectedCallback(){if(this.$$cn=!0,!this.$$c){let n=function(i){return s=>{const r=document.createElement("slot");i!=="default"&&(r.name=i),ch(s,r)}};if(await Promise.resolve(),!this.$$cn||this.$$c)return;const t={},e=vf(this);for(const i of this.$$s)i in e&&(i==="default"&&!this.$$d.children?(this.$$d.children=n(i),t.default=!0):t[i]=n(i));for(const i of this.attributes){const s=this.$$g_p(i.name);s in this.$$d||(this.$$d[s]=er(s,i.value,this.$$p_d,"toProp"))}for(const i in this.$$p_d)!(i in this.$$d)&&this[i]!==void 0&&(this.$$d[i]=this[i],delete this[i]);this.$$c=Ef({component:this.$$ctor,target:this.shadowRoot||this,props:{...this.$$d,$$slots:t,$$host:this}}),this.$$me=Hd(()=>{Ul(()=>{this.$$r=!0;for(const i of ks(this.$$c)){if(!this.$$p_d[i]?.reflect)continue;this.$$d[i]=this.$$c[i];const s=er(i,this.$$d[i],this.$$p_d,"toAttribute");s==null?this.removeAttribute(this.$$p_d[i].attribute||i):this.setAttribute(this.$$p_d[i].attribute||i,s)}this.$$r=!1})});for(const i in this.$$l)for(const s of this.$$l[i]){const r=this.$$c.$on(i,s);this.$$l_u.set(s,r)}this.$$l={}}}attributeChangedCallback(n,t,e){this.$$r||(n=this.$$g_p(n),this.$$d[n]=er(n,e,this.$$p_d,"toProp"),this.$$c?.$set({[n]:this.$$d[n]}))}disconnectedCallback(){this.$$cn=!1,Promise.resolve().then(()=>{!this.$$cn&&this.$$c&&(this.$$c.$destroy(),this.$$me(),this.$$c=void 0)})}$$g_p(n){return ks(this.$$p_d).find(t=>this.$$p_d[t].attribute===n||!this.$$p_d[t].attribute&&t.toLowerCase()===n)||n}});function er(n,t,e,i){const s=e[n]?.type;if(t=s==="Boolean"&&typeof t!="boolean"?t!=null:t,!i||!e[n])return t;if(i==="toAttribute")switch(s){case"Object":case"Array":return t==null?null:JSON.stringify(t);case"Boolean":return t?"":null;case"Number":return t??null;default:return t}else switch(s){case"Object":case"Array":return t&&JSON.parse(t);case"Boolean":return t;case"Number":return t!=null?+t:t;default:return t}}function vf(n){const t={};return n.childNodes.forEach(e=>{t[e.slot||"default"]=!0}),t}function Cf(n,t,e,i,s,r){let o=class extends fh{constructor(){super(n,e,s),this.$$p_d=t}static get observedAttributes(){return ks(t).map(a=>(t[a].attribute||a).toLowerCase())}};return ks(t).forEach(a=>{Ns(o.prototype,a,{get(){return this.$$c&&a in this.$$c?this.$$c[a]:this.$$d[a]},set(l){l=er(a,l,t),this.$$d[a]=l;var h=this.$$c;if(h){var c=Si(h,a)?.get;c?h[a]=l:h.$set({[a]:l})}}})}),i.forEach(a=>{Ns(o.prototype,a,{get(){return this.$$c?.[a]}})}),n.element=o,o}const Xt={ADD:"add",REMOVE:"remove"},rn={PROPERTYCHANGE:"propertychange"},V={CHANGE:"change",ERROR:"error",CONTEXTMENU:"contextmenu",CLICK:"click",DBLCLICK:"dblclick",KEYDOWN:"keydown",KEYPRESS:"keypress",LOAD:"load",TOUCHMOVE:"touchmove",WHEEL:"wheel"};class ir{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}}function Tf(n,t,e){let i,s;e=e||Te;let r=0,o=n.length,a=!1;for(;r<o;)i=r+(o-r>>1),s=+e(n[i],t),s<0?r=i+1:(o=i,a=!s);return a?r:~r}function Te(n,t){return n>t?1:n<t?-1:0}function Rf(n,t){return n<t?1:n>t?-1:0}function To(n,t,e){if(n[0]<=t)return 0;const i=n.length;if(t<=n[i-1])return i-1;if(typeof e=="function"){for(let s=1;s<i;++s){const r=n[s];if(r===t)return s;if(r<t)return e(t,n[s-1],r)>0?s-1:s}return i-1}if(e>0){for(let s=1;s<i;++s)if(n[s]<t)return s-1;return i-1}if(e<0){for(let s=1;s<i;++s)if(n[s]<=t)return s;return i-1}for(let s=1;s<i;++s){if(n[s]==t)return s;if(n[s]<t)return n[s-1]-t<t-n[s]?s-1:s}return i-1}function Sf(n,t,e){for(;t<e;){const i=n[t];n[t]=n[e],n[e]=i,++t,--e}}function Re(n,t){const e=Array.isArray(t)?t:[t],i=e.length;for(let s=0;s<i;s++)n[n.length]=e[s]}function ai(n,t){const e=n.length;if(e!==t.length)return!1;for(let i=0;i<e;i++)if(n[i]!==t[i])return!1;return!0}function If(n,t,e){const i=t||Te;return n.every(function(s,r){if(r===0)return!0;const o=i(n[r-1],s);return!(o>0||o===0)})}function Un(){return!0}function nr(){return!1}function Zn(){}function gh(n){let t,e,i;return function(){const s=Array.prototype.slice.call(arguments);return(!e||this!==i||!ai(s,e))&&(i=this,e=s,t=n.apply(this,arguments)),t}}function bf(n){function t(){let e;try{e=n()}catch(i){return Promise.reject(i)}return e instanceof Promise?e:Promise.resolve(e)}return t()}function Hn(n){for(const t in n)delete n[t]}function Fi(n){let t;for(t in n)return!1;return!t}class ke{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}}class sr extends ir{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;const i=this.listeners_||(this.listeners_={}),s=i[t]||(i[t]=[]);s.includes(e)||s.push(e)}dispatchEvent(t){const e=typeof t=="string",i=e?t:t.type,s=this.listeners_&&this.listeners_[i];if(!s)return;const r=e?new ke(t):t;r.target||(r.target=this.eventTarget_||this);const o=this.dispatching_||(this.dispatching_={}),a=this.pendingRemovals_||(this.pendingRemovals_={});i in o||(o[i]=0,a[i]=0),++o[i];let l;for(let h=0,c=s.length;h<c;++h)if("handleEvent"in s[h]?l=s[h].handleEvent(r):l=s[h].call(this,r),l===!1||r.propagationStopped){l=!1;break}if(--o[i]===0){let h=a[i];for(delete a[i];h--;)this.removeEventListener(i,Zn);delete o[i]}return l}disposeInternal(){this.listeners_&&Hn(this.listeners_)}getListeners(t){return this.listeners_&&this.listeners_[t]||void 0}hasListener(t){return this.listeners_?t?t in this.listeners_:Object.keys(this.listeners_).length>0:!1}removeEventListener(t,e){if(!this.listeners_)return;const i=this.listeners_[t];if(!i)return;const s=i.indexOf(e);s!==-1&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[s]=Zn,++this.pendingRemovals_[t]):(i.splice(s,1),i.length===0&&delete this.listeners_[t]))}}function H(n,t,e,i,s){if(s){const o=e;e=function(a){return n.removeEventListener(t,e),o.call(i??this,a)}}else i&&i!==n&&(e=e.bind(i));const r={target:n,type:t,listener:e};return n.addEventListener(t,e),r}function rr(n,t,e,i){return H(n,t,e,i,!0)}function nt(n){n&&n.target&&(n.target.removeEventListener(n.type,n.listener),Hn(n))}class qn extends sr{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(V.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){const i=t.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=H(this,t[r],e);return s}return H(this,t,e)}onceInternal(t,e){let i;if(Array.isArray(t)){const s=t.length;i=new Array(s);for(let r=0;r<s;++r)i[r]=rr(this,t[r],e)}else i=rr(this,t,e);return e.ol_key=i,i}unInternal(t,e){const i=e.ol_key;if(i)Lf(i);else if(Array.isArray(t))for(let s=0,r=t.length;s<r;++s)this.removeEventListener(t[s],e);else this.removeEventListener(t,e)}}qn.prototype.on,qn.prototype.once,qn.prototype.un;function Lf(n){if(Array.isArray(n))for(let t=0,e=n.length;t<e;++t)nt(n[t]);else nt(n)}function j(){throw new Error("Unimplemented abstract method.")}let Af=0;function B(n){return n.ol_uid||(n.ol_uid=String(++Af))}class _h extends ke{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}}class ye extends qn{constructor(t){super(),this.on,this.once,this.un,B(this),this.values_=null,t!==void 0&&this.setProperties(t)}get(t){let e;return this.values_&&this.values_.hasOwnProperty(t)&&(e=this.values_[t]),e}getKeys(){return this.values_&&Object.keys(this.values_)||[]}getProperties(){return this.values_&&Object.assign({},this.values_)||{}}getPropertiesInternal(){return this.values_}hasProperties(){return!!this.values_}notify(t,e){let i;i=`change:${t}`,this.hasListener(i)&&this.dispatchEvent(new _h(i,t,e)),i=rn.PROPERTYCHANGE,this.hasListener(i)&&this.dispatchEvent(new _h(i,t,e))}addChangeListener(t,e){this.addEventListener(`change:${t}`,e)}removeChangeListener(t,e){this.removeEventListener(`change:${t}`,e)}set(t,e,i){const s=this.values_||(this.values_={});if(i)s[t]=e;else{const r=s[t];s[t]=e,r!==e&&this.notify(t,r)}}setProperties(t,e){for(const i in t)this.set(i,t[i],e)}applyProperties(t){t.values_&&Object.assign(this.values_||(this.values_={}),t.values_)}unset(t,e){if(this.values_&&t in this.values_){const i=this.values_[t];delete this.values_[t],Fi(this.values_)&&(this.values_=null),e||this.notify(t,i)}}}const mh={LENGTH:"length"};class or extends ke{constructor(t,e,i){super(t),this.element=e,this.index=i}}class re extends ye{constructor(t,e){if(super(),this.on,this.once,this.un,e=e||{},this.unique_=!!e.unique,this.array_=t??[],this.unique_)for(let i=1,s=this.array_.length;i<s;++i)this.assertUnique_(this.array_[i],i);this.updateLength_()}clear(){for(;this.getLength()>0;)this.pop()}extend(t){for(let e=0,i=t.length;e<i;++e)this.push(t[e]);return this}forEach(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)t(e[i],i,e)}getArray(){return this.array_}item(t){return this.array_[t]}getLength(){return this.get(mh.LENGTH)}insertAt(t,e){if(t<0||t>this.getLength())throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e),this.array_.splice(t,0,e),this.updateLength_(),this.dispatchEvent(new or(Xt.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){const e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){const e=this.array_;for(let i=0,s=e.length;i<s;++i)if(e[i]===t)return this.removeAt(i)}removeAt(t){if(t<0||t>=this.getLength())return;const e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new or(Xt.REMOVE,e,t)),e}setAt(t,e){const i=this.getLength();if(t>=i){this.insertAt(t,e);return}if(t<0)throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e,t);const s=this.array_[t];this.array_[t]=e,this.dispatchEvent(new or(Xt.REMOVE,s,t)),this.dispatchEvent(new or(Xt.ADD,e,t))}updateLength_(){this.set(mh.LENGTH,this.array_.length)}assertUnique_(t,e){const i=this.array_;for(let s=0,r=i.length;s<r;++s)if(i[s]===t&&s!==e)throw new Error("Duplicate item added to a unique collection")}}function J(n,t){if(!n)throw new Error(t)}class ar extends ye{constructor(t){if(super(),this.on,this.once,this.un,this.id_=void 0,this.geometryName_="geometry",this.style_=null,this.styleFunction_=void 0,this.geometryChangeKey_=null,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),t)if(typeof t.getSimplifiedGeometry=="function"){const e=t;this.setGeometry(e)}else{const e=t;this.setProperties(e)}}clone(){const t=new ar(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());const e=this.getGeometry();e&&t.setGeometry(e.clone());const i=this.getStyle();return i&&t.setStyle(i),t}getGeometry(){return this.get(this.geometryName_)}getId(){return this.id_}getGeometryName(){return this.geometryName_}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}handleGeometryChange_(){this.changed()}handleGeometryChanged_(){this.geometryChangeKey_&&(nt(this.geometryChangeKey_),this.geometryChangeKey_=null);const t=this.getGeometry();t&&(this.geometryChangeKey_=H(t,V.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?Pf(t):void 0,this.changed()}setId(t){this.id_=t,this.changed()}setGeometryName(t){this.removeChangeListener(this.geometryName_,this.handleGeometryChanged_),this.geometryName_=t,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),this.handleGeometryChanged_()}}function Pf(n){if(typeof n=="function")return n;let t;return Array.isArray(n)?t=n:(J(typeof n.getZIndex=="function","Expected an `ol/style/Style` or an array of `ol/style/Style.js`"),t=[n]),function(){return t}}const xt={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16};function Ro(n){const t=Kt();for(let e=0,i=n.length;e<i;++e)Qn(t,n[e]);return t}function Mf(n,t,e){const i=Math.min.apply(null,n),s=Math.min.apply(null,t),r=Math.max.apply(null,n),o=Math.max.apply(null,t);return Ne(i,s,r,o,e)}function li(n,t,e){return e?(e[0]=n[0]-t,e[1]=n[1]-t,e[2]=n[2]+t,e[3]=n[3]+t,e):[n[0]-t,n[1]-t,n[2]+t,n[3]+t]}function ph(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n.slice()}function on(n,t,e){let i,s;return t<n[0]?i=n[0]-t:n[2]<t?i=t-n[2]:i=0,e<n[1]?s=n[1]-e:n[3]<e?s=e-n[3]:s=0,i*i+s*s}function an(n,t){return So(n,t[0],t[1])}function Oi(n,t){return n[0]<=t[0]&&t[2]<=n[2]&&n[1]<=t[1]&&t[3]<=n[3]}function So(n,t,e){return n[0]<=t&&t<=n[2]&&n[1]<=e&&e<=n[3]}function Io(n,t){const e=n[0],i=n[1],s=n[2],r=n[3],o=t[0],a=t[1];let l=xt.UNKNOWN;return o<e?l=l|xt.LEFT:o>s&&(l=l|xt.RIGHT),a<i?l=l|xt.BELOW:a>r&&(l=l|xt.ABOVE),l===xt.UNKNOWN&&(l=xt.INTERSECTING),l}function Kt(){return[1/0,1/0,-1/0,-1/0]}function Ne(n,t,e,i,s){return s?(s[0]=n,s[1]=t,s[2]=e,s[3]=i,s):[n,t,e,i]}function Jn(n){return Ne(1/0,1/0,-1/0,-1/0,n)}function yh(n,t){const e=n[0],i=n[1];return Ne(e,i,e,i,t)}function bo(n,t,e,i,s){const r=Jn(s);return Eh(r,n,t,e,i)}function ln(n,t){return n[0]==t[0]&&n[2]==t[2]&&n[1]==t[1]&&n[3]==t[3]}function xh(n,t){return t[0]<n[0]&&(n[0]=t[0]),t[2]>n[2]&&(n[2]=t[2]),t[1]<n[1]&&(n[1]=t[1]),t[3]>n[3]&&(n[3]=t[3]),n}function Qn(n,t){t[0]<n[0]&&(n[0]=t[0]),t[0]>n[2]&&(n[2]=t[0]),t[1]<n[1]&&(n[1]=t[1]),t[1]>n[3]&&(n[3]=t[1])}function Eh(n,t,e,i,s){for(;e<i;e+=s)Ff(n,t[e],t[e+1]);return n}function Ff(n,t,e){n[0]=Math.min(n[0],t),n[1]=Math.min(n[1],e),n[2]=Math.max(n[2],t),n[3]=Math.max(n[3],e)}function wh(n,t){let e;return e=t(lr(n)),e||(e=t(hr(n)),e)||(e=t(cr(n)),e)||(e=t(hi(n)),e)?e:!1}function Lo(n){let t=0;return ts(n)||(t=tt(n)*Ot(n)),t}function lr(n){return[n[0],n[1]]}function hr(n){return[n[2],n[1]]}function Di(n){return[(n[0]+n[2])/2,(n[1]+n[3])/2]}function Of(n,t){let e;if(t==="bottom-left")e=lr(n);else if(t==="bottom-right")e=hr(n);else if(t==="top-left")e=hi(n);else if(t==="top-right")e=cr(n);else throw new Error("Invalid corner");return e}function Ao(n,t,e,i,s){const[r,o,a,l,h,c,u,d]=vh(n,t,e,i);return Ne(Math.min(r,a,h,u),Math.min(o,l,c,d),Math.max(r,a,h,u),Math.max(o,l,c,d),s)}function vh(n,t,e,i){const s=t*i[0]/2,r=t*i[1]/2,o=Math.cos(e),a=Math.sin(e),l=s*o,h=s*a,c=r*o,u=r*a,d=n[0],f=n[1];return[d-l+u,f-h-c,d-l-u,f-h+c,d+l-u,f+h+c,d+l+u,f+h-c,d-l+u,f-h-c]}function Ot(n){return n[3]-n[1]}function Ge(n,t,e){const i=e||Kt();return ct(n,t)?(n[0]>t[0]?i[0]=n[0]:i[0]=t[0],n[1]>t[1]?i[1]=n[1]:i[1]=t[1],n[2]<t[2]?i[2]=n[2]:i[2]=t[2],n[3]<t[3]?i[3]=n[3]:i[3]=t[3]):Jn(i),i}function hi(n){return[n[0],n[3]]}function cr(n){return[n[2],n[3]]}function tt(n){return n[2]-n[0]}function ct(n,t){return n[0]<=t[2]&&n[2]>=t[0]&&n[1]<=t[3]&&n[3]>=t[1]}function ts(n){return n[2]<n[0]||n[3]<n[1]}function Df(n,t){return t?(t[0]=n[0],t[1]=n[1],t[2]=n[2],t[3]=n[3],t):n}function kf(n,t,e){let i=!1;const s=Io(n,t),r=Io(n,e);if(s===xt.INTERSECTING||r===xt.INTERSECTING)i=!0;else{const o=n[0],a=n[1],l=n[2],h=n[3],c=t[0],u=t[1],d=e[0],f=e[1],g=(f-u)/(d-c);let m,_;r&xt.ABOVE&&!(s&xt.ABOVE)&&(m=d-(f-h)/g,i=m>=o&&m<=l),!i&&r&xt.RIGHT&&!(s&xt.RIGHT)&&(_=f-(d-l)*g,i=_>=a&&_<=h),!i&&r&xt.BELOW&&!(s&xt.BELOW)&&(m=d-(f-a)/g,i=m>=o&&m<=l),!i&&r&xt.LEFT&&!(s&xt.LEFT)&&(_=f-(d-o)*g,i=_>=a&&_<=h)}return i}function Nf(n,t,e,i){if(ts(n))return Jn(e);let s=[];if(i>1){const a=n[2]-n[0],l=n[3]-n[1];for(let h=0;h<i;++h)s.push(n[0]+a*h/i,n[1],n[2],n[1]+l*h/i,n[2]-a*h/i,n[3],n[0],n[3]-l*h/i)}else s=[n[0],n[1],n[2],n[1],n[2],n[3],n[0],n[3]];t(s,s,2);const r=[],o=[];for(let a=0,l=s.length;a<l;a+=2)r.push(s[a]),o.push(s[a+1]);return Mf(r,o,e)}function Ch(n,t){const e=t.getExtent(),i=Di(n);if(t.canWrapX()&&(i[0]<e[0]||i[0]>=e[2])){const s=tt(e),o=Math.floor((i[0]-e[0])/s)*s;n[0]-=o,n[2]-=o}return n}function Th(n,t,e){if(t.canWrapX()){const i=t.getExtent();if(!isFinite(n[0])||!isFinite(n[2]))return[[i[0],n[1],i[2],n[3]]];Ch(n,t);const s=tt(i);if(tt(n)>s&&!e)return[[i[0],n[1],i[2],n[3]]];if(n[0]<i[0])return[[n[0]+s,n[1],i[2],n[3]],[i[0],n[1],n[2],n[3]]];if(n[2]>i[2])return[[n[0],n[1],i[2],n[3]],[i[0],n[1],n[2]-s,n[3]]]}return[n]}function rt(n,t,e){return Math.min(Math.max(n,t),e)}function Gf(n,t,e,i,s,r){const o=s-e,a=r-i;if(o!==0||a!==0){const l=((n-e)*o+(t-i)*a)/(o*o+a*a);l>1?(e=s,i=r):l>0&&(e+=o*l,i+=a*l)}return ki(n,t,e,i)}function ki(n,t,e,i){const s=e-n,r=i-t;return s*s+r*r}function zf(n){const t=n.length;for(let i=0;i<t;i++){let s=i,r=Math.abs(n[i][i]);for(let a=i+1;a<t;a++){const l=Math.abs(n[a][i]);l>r&&(r=l,s=a)}if(r===0)return null;const o=n[s];n[s]=n[i],n[i]=o;for(let a=i+1;a<t;a++){const l=-n[a][i]/n[i][i];for(let h=i;h<t+1;h++)i==h?n[a][h]=0:n[a][h]+=l*n[i][h]}}const e=new Array(t);for(let i=t-1;i>=0;i--){e[i]=n[i][t]/n[i][i];for(let s=i-1;s>=0;s--)n[s][t]-=n[s][i]*e[i]}return e}function Rh(n){return n*180/Math.PI}function ci(n){return n*Math.PI/180}function hn(n,t){const e=n%t;return e*t<0?e+t:e}function jt(n,t,e){return n+e*(t-n)}function ur(n,t){const e=Math.pow(10,t);return Math.round(n*e)/e}function dr(n,t){return Math.floor(ur(n,t))}function fr(n,t){return Math.ceil(ur(n,t))}function Po(n,t,e){if(n>=t&&n<e)return n;const i=e-t;return((n-t)%i+i)%i+t}const Xf=63710088e-1;function Sh(n,t,e){e=e||Xf;const i=ci(n[1]),s=ci(t[1]),r=(s-i)/2,o=ci(t[0]-n[0])/2,a=Math.sin(r)*Math.sin(r)+Math.sin(o)*Math.sin(o)*Math.cos(i)*Math.cos(s);return 2*e*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}function Ih(...n){console.warn(...n)}function Yf(n,t){return n[0]+=+t[0],n[1]+=+t[1],n}function gr(n,t){let e=!0;for(let i=n.length-1;i>=0;--i)if(n[i]!=t[i]){e=!1;break}return e}function Mo(n,t){const e=Math.cos(t),i=Math.sin(t),s=n[0]*e-n[1]*i,r=n[1]*e+n[0]*i;return n[0]=s,n[1]=r,n}function Wf(n,t){return n[0]*=t,n[1]*=t,n}function Fo(n,t){if(t.canWrapX()){const e=tt(t.getExtent()),i=Vf(n,t,e);i&&(n[0]-=i*e)}return n}function Vf(n,t,e){const i=t.getExtent();let s=0;return t.canWrapX()&&(n[0]<i[0]||n[0]>i[2])&&(e=e||tt(i),s=Math.floor((n[0]-i[0])/e)),s}const Oo={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937};class _r{constructor(t){this.code_=t.code,this.units_=t.units,this.extent_=t.extent!==void 0?t.extent:null,this.worldExtent_=t.worldExtent!==void 0?t.worldExtent:null,this.axisOrientation_=t.axisOrientation!==void 0?t.axisOrientation:"enu",this.global_=t.global!==void 0?t.global:!1,this.canWrapX_=!!(this.global_&&this.extent_),this.getPointResolutionFunc_=t.getPointResolution,this.defaultTileGrid_=null,this.metersPerUnit_=t.metersPerUnit}canWrapX(){return this.canWrapX_}getCode(){return this.code_}getExtent(){return this.extent_}getUnits(){return this.units_}getMetersPerUnit(){return this.metersPerUnit_||Oo[this.units_]}getWorldExtent(){return this.worldExtent_}getAxisOrientation(){return this.axisOrientation_}isGlobal(){return this.global_}setGlobal(t){this.global_=t,this.canWrapX_=!!(t&&this.extent_)}getDefaultTileGrid(){return this.defaultTileGrid_}setDefaultTileGrid(t){this.defaultTileGrid_=t}setExtent(t){this.extent_=t,this.canWrapX_=!!(this.global_&&t)}setWorldExtent(t){this.worldExtent_=t}setGetPointResolution(t){this.getPointResolutionFunc_=t}getPointResolutionFunc(){return this.getPointResolutionFunc_}}const es=6378137,cn=Math.PI*es,Bf=[-cn,-cn,cn,cn],$f=[-180,-85,180,85],mr=es*Math.log(Math.tan(Math.PI/2));class un extends _r{constructor(t){super({code:t,units:"m",extent:Bf,global:!0,worldExtent:$f,getPointResolution:function(e,i){return e/Math.cosh(i[1]/es)}})}}const bh=[new un("EPSG:3857"),new un("EPSG:102100"),new un("EPSG:102113"),new un("EPSG:900913"),new un("http://www.opengis.net/def/crs/EPSG/0/3857"),new un("http://www.opengis.net/gml/srs/epsg.xml#3857")];function Kf(n,t,e,i){const s=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(s));for(let r=0;r<s;r+=i){t[r]=cn*n[r]/180;let o=es*Math.log(Math.tan(Math.PI*(+n[r+1]+90)/360));o>mr?o=mr:o<-mr&&(o=-mr),t[r+1]=o}return t}function jf(n,t,e,i){const s=n.length;e=e>1?e:2,i=i??e,t===void 0&&(e>2?t=n.slice():t=new Array(s));for(let r=0;r<s;r+=i)t[r]=180*n[r]/cn,t[r+1]=360*Math.atan(Math.exp(n[r+1]/es))/Math.PI-90;return t}const Uf=6378137,Lh=[-180,-90,180,90],Zf=Math.PI*Uf/180;class Ni extends _r{constructor(t,e){super({code:t,units:"degrees",extent:Lh,axisOrientation:e,global:!0,metersPerUnit:Zf,worldExtent:Lh})}}const Ah=[new Ni("CRS:84"),new Ni("EPSG:4326","neu"),new Ni("urn:ogc:def:crs:OGC:1.3:CRS84"),new Ni("urn:ogc:def:crs:OGC:2:84"),new Ni("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new Ni("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new Ni("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];let Do={};function Hf(n){return Do[n]||Do[n.replace(/urn:(x-)?ogc:def:crs:EPSG:(.*:)?(\w+)$/,"EPSG:$3")]||null}function qf(n,t){Do[n]=t}let dn={};function is(n,t,e){const i=n.getCode(),s=t.getCode();i in dn||(dn[i]={}),dn[i][s]=e}function ko(n,t){return n in dn&&t in dn[n]?dn[n][t]:null}const pr=.9996,oe=.00669438,yr=oe*oe,xr=yr*oe,Gi=oe/(1-oe),Ph=Math.sqrt(1-oe),fn=(1-Ph)/(1+Ph),Mh=fn*fn,No=Mh*fn,Go=No*fn,Fh=Go*fn,Oh=1-oe/4-3*yr/64-5*xr/256,Jf=3*oe/8+3*yr/32+45*xr/1024,Qf=15*yr/256+45*xr/1024,tg=35*xr/3072,eg=3/2*fn-27/32*No+269/512*Fh,ig=21/16*Mh-55/32*Go,ng=151/96*No-417/128*Fh,sg=1097/512*Go,Er=6378137;function rg(n,t,e){const i=n-5e5,o=(e.north?t:t-1e7)/pr/(Er*Oh),a=o+eg*Math.sin(2*o)+ig*Math.sin(4*o)+ng*Math.sin(6*o)+sg*Math.sin(8*o),l=Math.sin(a),h=l*l,c=Math.cos(a),u=l/c,d=u*u,f=d*d,g=1-oe*h,m=Math.sqrt(1-oe*h),_=Er/m,p=(1-oe)/g,y=Gi*c**2,w=y*y,x=i/(_*pr),E=x*x,C=E*x,R=C*x,S=R*x,b=S*x,v=a-u/p*(E/2-R/24*(5+3*d+10*y-4*w-9*Gi))+b/720*(61+90*d+298*y+45*f-252*Gi-3*w);let I=(x-C/6*(1+2*d+y)+S/120*(5-2*y+28*d-3*w+8*Gi+24*f))/c;return I=Po(I+ci(Nh(e.number)),-Math.PI,Math.PI),[Rh(I),Rh(v)]}const Dh=-80,kh=84,og=-180,ag=180;function lg(n,t,e){n=Po(n,og,ag),t<Dh?t=Dh:t>kh&&(t=kh);const i=ci(t),s=Math.sin(i),r=Math.cos(i),o=s/r,a=o*o,l=a*a,h=ci(n),c=Nh(e.number),u=ci(c),d=Er/Math.sqrt(1-oe*s**2),f=Gi*r**2,g=r*Po(h-u,-Math.PI,Math.PI),m=g*g,_=m*g,p=_*g,y=p*g,w=y*g,x=Er*(Oh*i-Jf*Math.sin(2*i)+Qf*Math.sin(4*i)-tg*Math.sin(6*i)),E=pr*d*(g+_/6*(1-a+f)+y/120*(5-18*a+l+72*f-58*Gi))+5e5;let C=pr*(x+d*o*(m/2+p/24*(5-a+9*f+4*f**2)+w/720*(61-58*a+l+600*f-330*Gi)));return e.north||(C+=1e7),[E,C]}function Nh(n){return(n-1)*6-180+3}const hg=[/^EPSG:(\d+)$/,/^urn:ogc:def:crs:EPSG::(\d+)$/,/^http:\/\/www\.opengis\.net\/def\/crs\/EPSG\/0\/(\d+)$/];function Gh(n){let t=0;for(const s of hg){const r=n.match(s);if(r){t=parseInt(r[1]);break}}if(!t)return null;let e=0,i=!1;return t>32700&&t<32761?e=t-32700:t>32600&&t<32661&&(i=!0,e=t-32600),e?{number:e,north:i}:null}function zh(n,t){return function(e,i,s,r){const o=e.length;s=s>1?s:2,r=r??s,i||(s>2?i=e.slice():i=new Array(o));for(let a=0;a<o;a+=r){const l=e[a],h=e[a+1],c=n(l,h,t);i[a]=c[0],i[a+1]=c[1]}return i}}function cg(n){return Gh(n)?new _r({code:n,units:"m"}):null}function ug(n){const t=Gh(n.getCode());return t?{forward:zh(lg,t),inverse:zh(rg,t)}:null}const dg=[ug],fg=[cg];let zo=!0;function Xh(n){zo=!1}function Xo(n,t){if(t!==void 0){for(let e=0,i=n.length;e<i;++e)t[e]=n[e];t=t}else t=n.slice();return t}function Yo(n){qf(n.getCode(),n),is(n,n,Xo)}function gg(n){n.forEach(Yo)}function ft(n){if(typeof n!="string")return n;const t=Hf(n);if(t)return t;for(const e of fg){const i=e(n);if(i)return i}return null}function Yh(n,t,e,i){n=ft(n);let s;const r=n.getPointResolutionFunc();if(r)s=r(t,e);else{const o=n.getUnits();if(o=="degrees"&&!i||i=="degrees")s=t;else{const a=wr(n,ft("EPSG:4326"));if(!a&&o!=="degrees")s=t*n.getMetersPerUnit();else{let h=[e[0]-t/2,e[1],e[0]+t/2,e[1],e[0],e[1]-t/2,e[0],e[1]+t/2];h=a(h,h,2);const c=Sh(h.slice(0,2),h.slice(2,4)),u=Sh(h.slice(4,6),h.slice(6,8));s=(c+u)/2}const l=n.getMetersPerUnit();l!==void 0&&(s/=l)}}return s}function Wh(n){gg(n),n.forEach(function(t){n.forEach(function(e){t!==e&&is(t,e,Xo)})})}function _g(n,t,e,i){n.forEach(function(s){t.forEach(function(r){is(s,r,e),is(r,s,i)})})}function Wo(n,t){return n?typeof n=="string"?ft(n):n:ft(t)}function mg(n){return(function(t,e,i,s){const r=t.length;i=i!==void 0?i:2,s=s??i,e=e!==void 0?e:new Array(r);for(let o=0;o<r;o+=s){const a=n(t.slice(o,o+i)),l=a.length;for(let h=0,c=s;h<c;++h)e[o+h]=h>=l?t[o+h]:a[h]}return e})}function Vo(n,t){return Xh(),ns(n,"EPSG:4326","EPSG:3857")}function Ut(n,t){if(n===t)return!0;const e=n.getUnits()===t.getUnits();return(n.getCode()===t.getCode()||wr(n,t)===Xo)&&e}function wr(n,t){const e=n.getCode(),i=t.getCode();let s=ko(e,i);if(s)return s;let r=null,o=null;for(const l of dg)r||(r=l(n)),o||(o=l(t));if(!r&&!o)return null;const a="EPSG:4326";if(o)if(r)s=Bo(r.inverse,o.forward);else{const l=ko(e,a);l&&(s=Bo(l,o.forward))}else{const l=ko(a,i);l&&(s=Bo(r.inverse,l))}return s&&(Yo(n),Yo(t),is(n,t,s)),s}function Bo(n,t){return function(e,i,s,r){return i=n(e,i,s,r),t(i,i,s,r)}}function zi(n,t){const e=ft(n),i=ft(t);return wr(e,i)}function ns(n,t,e){const i=zi(t,e);if(!i){const s=ft(t).getCode(),r=ft(e).getCode();throw new Error(`No transform available between ${s} and ${r}`)}return i(n,void 0,n.length)}function vr(n,t,e,i){const s=zi(t,e);return Nf(n,s,void 0,i)}let pg=null;function yg(){return pg}function $o(n,t){return n}function ze(n,t){return zo&&!gr(n,[0,0])&&n[0]>=-180&&n[0]<=180&&n[1]>=-90&&n[1]<=90&&(zo=!1,Ih("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),n}function Ko(n,t){return n}function ui(n,t){return n}function xg(){Wh(bh),Wh(Ah),_g(Ah,bh,Kf,jf)}xg();const Vh=new Array(6);function ae(){return[1,0,0,1,0,0]}function Bh(n){return Uo(n,1,0,0,1,0,0)}function jo(n,t){const e=n[0],i=n[1],s=n[2],r=n[3],o=n[4],a=n[5],l=t[0],h=t[1],c=t[2],u=t[3],d=t[4],f=t[5];return n[0]=e*l+s*h,n[1]=i*l+r*h,n[2]=e*c+s*u,n[3]=i*c+r*u,n[4]=e*d+s*f+o,n[5]=i*d+r*f+a,n}function Uo(n,t,e,i,s,r,o){return n[0]=t,n[1]=e,n[2]=i,n[3]=s,n[4]=r,n[5]=o,n}function Eg(n,t){return n[0]=t[0],n[1]=t[1],n[2]=t[2],n[3]=t[3],n[4]=t[4],n[5]=t[5],n}function gt(n,t){const e=t[0],i=t[1];return t[0]=n[0]*e+n[2]*i+n[4],t[1]=n[1]*e+n[3]*i+n[5],t}function Zo(n,t,e){return jo(n,Uo(Vh,t,0,0,e,0,0))}function wg(n,t,e){return jo(n,Uo(Vh,1,0,0,1,t,e))}function Xe(n,t,e,i,s,r,o,a){const l=Math.sin(r),h=Math.cos(r);return n[0]=i*h,n[1]=s*l,n[2]=-i*l,n[3]=s*h,n[4]=o*i*h-a*i*l+t,n[5]=o*s*l+a*s*h+e,n}function $h(n,t){const e=vg(t);J(e!==0,"Transformation matrix cannot be inverted");const i=t[0],s=t[1],r=t[2],o=t[3],a=t[4],l=t[5];return n[0]=o/e,n[1]=-s/e,n[2]=-r/e,n[3]=i/e,n[4]=(r*l-o*a)/e,n[5]=-(i*l-s*a)/e,n}function vg(n){return n[0]*n[3]-n[1]*n[2]}const Cg=[1e5,1e5,1e5,1e5,2,2];function Tg(n){return"matrix("+n.join(", ")+")"}function Ho(n){return n.substring(7,n.length-1).split(",").map(parseFloat)}function Rg(n,t){const e=Ho(n),i=Ho(t);for(let s=0;s<6;++s)if(Math.round((e[s]-i[s])*Cg[s])!==0)return!1;return!0}function di(n,t,e,i,s,r,o){r=r||[],o=o||2;let a=0;for(let l=t;l<e;l+=i){const h=n[l],c=n[l+1];r[a++]=s[0]*h+s[2]*c+s[4],r[a++]=s[1]*h+s[3]*c+s[5];for(let u=2;u<o;u++)r[a++]=n[l+u]}return r&&r.length!=a&&(r.length=a),r}function Kh(n,t,e,i,s,r,o){o=o||[];const a=Math.cos(s),l=Math.sin(s),h=r[0],c=r[1];let u=0;for(let d=t;d<e;d+=i){const f=n[d]-h,g=n[d+1]-c;o[u++]=h+f*a-g*l,o[u++]=c+f*l+g*a;for(let m=d+2;m<d+i;++m)o[u++]=n[m]}return o&&o.length!=u&&(o.length=u),o}function Sg(n,t,e,i,s,r,o,a){a=a||[];const l=o[0],h=o[1];let c=0;for(let u=t;u<e;u+=i){const d=n[u]-l,f=n[u+1]-h;a[c++]=l+s*d,a[c++]=h+r*f;for(let g=u+2;g<u+i;++g)a[c++]=n[g]}return a&&a.length!=c&&(a.length=c),a}function Ig(n,t,e,i,s,r,o){o=o||[];let a=0;for(let l=t;l<e;l+=i){o[a++]=n[l]+s,o[a++]=n[l+1]+r;for(let h=l+2;h<l+i;++h)o[a++]=n[h]}return o&&o.length!=a&&(o.length=a),o}const jh=ae(),bg=[NaN,NaN];class Lg extends ye{constructor(){super(),this.extent_=Kt(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=gh((t,e,i)=>{if(!i)return this.getSimplifiedGeometry(e);const s=this.clone();return s.applyTransform(i),s.getSimplifiedGeometry(e)})}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return j()}closestPointXY(t,e,i,s){return j()}containsXY(t,e){return this.closestPointXY(t,e,bg,Number.MIN_VALUE)===0}getClosestPoint(t,e){return e=e||[NaN,NaN],this.closestPointXY(t[0],t[1],e,1/0),e}intersectsCoordinate(t){return this.containsXY(t[0],t[1])}computeExtent(t){return j()}getExtent(t){if(this.extentRevision_!=this.getRevision()){const e=this.computeExtent(this.extent_);(isNaN(e[0])||isNaN(e[1]))&&Jn(e),this.extentRevision_=this.getRevision()}return Df(this.extent_,t)}rotate(t,e){j()}scale(t,e,i){j()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return j()}getType(){return j()}applyTransform(t){j()}intersectsExtent(t){return j()}translate(t,e){j()}transform(t,e){const i=ft(t),s=i.getUnits()=="tile-pixels"?function(r,o,a){const l=i.getExtent(),h=i.getWorldExtent(),c=Ot(h)/Ot(l);Xe(jh,h[0],h[3],c,-c,0,0,0);const u=di(r,0,r.length,a,jh,o),d=zi(i,e);return d?d(u,u,a):u}:zi(i,e);return this.applyTransform(s),this}}class Xi extends Lg{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates}computeExtent(t){return bo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return j()}getFirstCoordinate(){return this.flatCoordinates.slice(0,this.stride)}getFlatCoordinates(){return this.flatCoordinates}getLastCoordinate(){return this.flatCoordinates.slice(this.flatCoordinates.length-this.stride)}getLayout(){return this.layout}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||this.simplifiedGeometryMaxMinSquaredTolerance!==0&&t<=this.simplifiedGeometryMaxMinSquaredTolerance)return this;const e=this.getSimplifiedGeometryInternal(t);return e.getFlatCoordinates().length<this.flatCoordinates.length?e:(this.simplifiedGeometryMaxMinSquaredTolerance=t,this)}getSimplifiedGeometryInternal(t){return this}getStride(){return this.stride}setFlatCoordinates(t,e){this.stride=Uh(t),this.layout=t,this.flatCoordinates=e}setCoordinates(t,e){j()}setLayout(t,e,i){let s;if(t)s=Uh(t);else{for(let r=0;r<i;++r){if(e.length===0){this.layout="XY",this.stride=2;return}e=e[0]}s=e.length,t=Ag(s)}this.layout=t,this.stride=s}applyTransform(t){this.flatCoordinates&&(t(this.flatCoordinates,this.flatCoordinates,this.layout.startsWith("XYZ")?3:2,this.stride),this.changed())}rotate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();Kh(i,0,i.length,s,t,e,i),this.changed()}}scale(t,e,i){e===void 0&&(e=t),i||(i=Di(this.getExtent()));const s=this.getFlatCoordinates();if(s){const r=this.getStride();Sg(s,0,s.length,r,t,e,i,s),this.changed()}}translate(t,e){const i=this.getFlatCoordinates();if(i){const s=this.getStride();Ig(i,0,i.length,s,t,e,i),this.changed()}}}function Ag(n){let t;return n==2?t="XY":n==3?t="XYZ":n==4&&(t="XYZM"),t}function Uh(n){let t;return n=="XY"?t=2:n=="XYZ"||n=="XYM"?t=3:n=="XYZM"&&(t=4),t}function Pg(n,t,e){const i=n.getFlatCoordinates();if(!i)return null;const s=n.getStride();return di(i,0,i.length,s,t,e)}function Zh(n,t,e,i){let s=0;const r=n[e-i],o=n[e-i+1];let a=0,l=0;for(;t<e;t+=i){const h=n[t]-r,c=n[t+1]-o;s+=l*h-a*c,a=h,l=c}return s/2}function Hh(n,t,e,i){let s=0;for(let r=0,o=e.length;r<o;++r){const a=e[r];s+=Zh(n,t,a,i),t=a}return s}function Mg(n,t,e,i){let s=0;for(let r=0,o=e.length;r<o;++r){const a=e[r];s+=Hh(n,t,a,i),t=a[a.length-1]}return s}function qh(n,t,e,i,s,r,o){const a=n[t],l=n[t+1],h=n[e]-a,c=n[e+1]-l;let u;if(h===0&&c===0)u=t;else{const d=((s-a)*h+(r-l)*c)/(h*h+c*c);if(d>1)u=e;else if(d>0){for(let f=0;f<i;++f)o[f]=jt(n[t+f],n[e+f],d);o.length=i;return}else u=t}for(let d=0;d<i;++d)o[d]=n[u+d];o.length=i}function qo(n,t,e,i,s){let r=n[t],o=n[t+1];for(t+=i;t<e;t+=i){const a=n[t],l=n[t+1],h=ki(r,o,a,l);h>s&&(s=h),r=a,o=l}return s}function Jo(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];s=qo(n,t,a,i,s),t=a}return s}function Fg(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];s=Jo(n,t,a,i,s),t=a[a.length-1]}return s}function Qo(n,t,e,i,s,r,o,a,l,h,c){if(t==e)return h;let u,d;if(s===0){if(d=ki(o,a,n[t],n[t+1]),d<h){for(u=0;u<i;++u)l[u]=n[t+u];return l.length=i,d}return h}c=c||[NaN,NaN];let f=t+i;for(;f<e;)if(qh(n,f-i,f,i,o,a,c),d=ki(o,a,c[0],c[1]),d<h){for(h=d,u=0;u<i;++u)l[u]=c[u];l.length=i,f+=i}else f+=i*Math.max((Math.sqrt(d)-Math.sqrt(h))/s|0,1);if(r&&(qh(n,e-i,t,i,o,a,c),d=ki(o,a,c[0],c[1]),d<h)){for(h=d,u=0;u<i;++u)l[u]=c[u];l.length=i}return h}function ta(n,t,e,i,s,r,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){const f=e[u];h=Qo(n,t,f,i,s,r,o,a,l,h,c),t=f}return h}function Og(n,t,e,i,s,r,o,a,l,h,c){c=c||[NaN,NaN];for(let u=0,d=e.length;u<d;++u){const f=e[u];h=ta(n,t,f,i,s,r,o,a,l,h,c),t=f[f.length-1]}return h}function Dg(n,t,e,i){for(let s=0,r=e.length;s<r;++s)n[t++]=e[s];return t}function Cr(n,t,e,i){for(let s=0,r=e.length;s<r;++s){const o=e[s];for(let a=0;a<i;++a)n[t++]=o[a]}return t}function ea(n,t,e,i,s){s=s||[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=Cr(n,t,e[o],i);s[r++]=l,t=l}return s.length=r,s}function kg(n,t,e,i,s){s=s||[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=ea(n,t,e[o],i,s[r]);l.length===0&&(l[0]=t),s[r++]=l,t=l[l.length-1]}return s.length=r,s}function fi(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=t;o<e;o+=i)s[r++]=n.slice(o,o+i);return s.length=r,s}function ss(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=fi(n,t,l,i,s[r]),t=l}return s.length=r,s}function ia(n,t,e,i,s){s=s!==void 0?s:[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o];s[r++]=l.length===1&&l[0]===t?[]:ss(n,t,l,i,s[r]),t=l[l.length-1]}return s.length=r,s}function Tr(n,t,e,i,s,r,o){const a=(e-t)/i;if(a<3){for(;t<e;t+=i)r[o++]=n[t],r[o++]=n[t+1];return o}const l=new Array(a);l[0]=1,l[a-1]=1;const h=[t,e-i];let c=0;for(;h.length>0;){const u=h.pop(),d=h.pop();let f=0;const g=n[d],m=n[d+1],_=n[u],p=n[u+1];for(let y=d+i;y<u;y+=i){const w=n[y],x=n[y+1],E=Gf(w,x,g,m,_,p);E>f&&(c=y,f=E)}f>s&&(l[(c-t)/i]=1,d+i<c&&h.push(d,c),c+i<u&&h.push(c,u))}for(let u=0;u<a;++u)l[u]&&(r[o++]=n[t+u*i],r[o++]=n[t+u*i+1]);return o}function Jh(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l];o=Tr(n,t,c,i,s,r,o),a.push(o),t=c}return o}function Yi(n,t){return t*Math.round(n/t)}function Ng(n,t,e,i,s,r,o){if(t==e)return o;let a=Yi(n[t],s),l=Yi(n[t+1],s);t+=i,r[o++]=a,r[o++]=l;let h,c;do if(h=Yi(n[t],s),c=Yi(n[t+1],s),t+=i,t==e)return r[o++]=h,r[o++]=c,o;while(h==a&&c==l);for(;t<e;){const u=Yi(n[t],s),d=Yi(n[t+1],s);if(t+=i,u==h&&d==c)continue;const f=h-a,g=c-l,m=u-a,_=d-l;if(f*_==g*m&&(f<0&&m<f||f==m||f>0&&m>f)&&(g<0&&_<g||g==_||g>0&&_>g)){h=u,c=d;continue}r[o++]=h,r[o++]=c,a=h,l=c,h=u,c=d}return r[o++]=h,r[o++]=c,o}function na(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l];o=Ng(n,t,c,i,s,r,o),a.push(o),t=c}return o}function Gg(n,t,e,i,s,r,o,a){for(let l=0,h=e.length;l<h;++l){const c=e[l],u=[];o=na(n,t,c,i,s,r,o,u),a.push(u),t=c[c.length-1]}return o}class rs extends Xi{constructor(t,e){super(),this.maxDelta_=-1,this.maxDeltaRevision_=-1,e!==void 0&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}clone(){return new rs(this.flatCoordinates.slice(),this.layout)}closestPointXY(t,e,i,s){return s<on(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(qo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),Qo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,s))}getArea(){return Zh(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return fi(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){const e=[];return e.length=Tr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new rs(e,"XY")}getType(){return"LinearRing"}intersectsExtent(t){return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=Cr(this.flatCoordinates,0,t,this.stride),this.changed()}}class Wi extends Xi{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){const t=new Wi(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){const r=this.flatCoordinates,o=ki(t,e,r[0],r[1]);if(o<s){const a=this.stride;for(let l=0;l<a;++l)i[l]=r[l];return i.length=a,o}return s}getCoordinates(){return this.flatCoordinates.slice()}computeExtent(t){return yh(this.flatCoordinates,t)}getType(){return"Point"}intersectsExtent(t){return So(t,this.flatCoordinates[0],this.flatCoordinates[1])}setCoordinates(t,e){this.setLayout(e,t,0),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=Dg(this.flatCoordinates,0,t,this.stride),this.changed()}}function zg(n,t,e,i,s){return!wh(s,function(o){return!Vi(n,t,e,i,o[0],o[1])})}function Vi(n,t,e,i,s,r){let o=0,a=n[e-i],l=n[e-i+1];for(;t<e;t+=i){const h=n[t],c=n[t+1];l<=r?c>r&&(h-a)*(r-l)-(s-a)*(c-l)>0&&o++:c<=r&&(h-a)*(r-l)-(s-a)*(c-l)<0&&o--,a=h,l=c}return o!==0}function sa(n,t,e,i,s,r){if(e.length===0||!Vi(n,t,e[0],i,s,r))return!1;for(let o=1,a=e.length;o<a;++o)if(Vi(n,e[o-1],e[o],i,s,r))return!1;return!0}function Xg(n,t,e,i,s,r){if(e.length===0)return!1;for(let o=0,a=e.length;o<a;++o){const l=e[o];if(sa(n,t,l,i,s,r))return!0;t=l[l.length-1]}return!1}function ra(n,t,e,i,s,r,o){let a,l,h,c,u,d,f;const g=s[r+1],m=[];for(let y=0,w=e.length;y<w;++y){const x=e[y];for(c=n[x-i],d=n[x-i+1],a=t;a<x;a+=i)u=n[a],f=n[a+1],(g<=d&&f<=g||d<=g&&g<=f)&&(h=(g-d)/(f-d)*(u-c)+c,m.push(h)),c=u,d=f}let _=NaN,p=-1/0;for(m.sort(Te),c=m[0],a=1,l=m.length;a<l;++a){u=m[a];const y=Math.abs(u-c);y>p&&(h=(c+u)/2,sa(n,t,e,i,h,g)&&(_=h,p=y)),c=u}return isNaN(_)&&(_=s[r]),o?(o.push(_,g,p),o):[_,g,p]}function Qh(n,t,e,i,s){let r=[];for(let o=0,a=e.length;o<a;++o){const l=e[o];r=ra(n,t,l,i,s,2*o,r),t=l[l.length-1]}return r}function tc(n,t,e,i,s){let r;for(t+=i;t<e;t+=i)if(r=s(n.slice(t-i,t),n.slice(t,t+i)),r)return r;return!1}function Rr(n,t,e,i,s,r){return r=r??Eh(Kt(),n,t,e,i),ct(s,r)?r[0]>=s[0]&&r[2]<=s[2]||r[1]>=s[1]&&r[3]<=s[3]?!0:tc(n,t,e,i,function(o,a){return kf(s,o,a)}):!1}function Yg(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){if(Rr(n,t,e[r],i,s))return!0;t=e[r]}return!1}function ec(n,t,e,i,s){return!!(Rr(n,t,e,i,s)||Vi(n,t,e,i,s[0],s[1])||Vi(n,t,e,i,s[0],s[3])||Vi(n,t,e,i,s[2],s[1])||Vi(n,t,e,i,s[2],s[3]))}function ic(n,t,e,i,s){if(!ec(n,t,e[0],i,s))return!1;if(e.length===1)return!0;for(let r=1,o=e.length;r<o;++r)if(zg(n,e[r-1],e[r],i,s)&&!Rr(n,e[r-1],e[r],i,s))return!1;return!0}function Wg(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];if(ic(n,t,a,i,s))return!0;t=a[a.length-1]}return!1}function Vg(n,t,e,i){for(;t<e-i;){for(let s=0;s<i;++s){const r=n[t+s];n[t+s]=n[e-i+s],n[e-i+s]=r}t+=i,e-=i}}function oa(n,t,e,i){let s=0,r=n[e-i],o=n[e-i+1];for(;t<e;t+=i){const a=n[t],l=n[t+1];s+=(a-r)*(l+o),r=a,o=l}return s===0?void 0:s>0}function nc(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=oa(n,t,a,i);if(r===0){if(s&&l||!s&&!l)return!1}else if(s&&!l||!s&&l)return!1;t=a}return!0}function Bg(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r){const a=e[r];if(!nc(n,t,a,i,s))return!1;a.length&&(t=a[a.length-1])}return!0}function aa(n,t,e,i,s){s=s!==void 0?s:!1;for(let r=0,o=e.length;r<o;++r){const a=e[r],l=oa(n,t,a,i);(r===0?s&&l||!s&&!l:s&&!l||!s&&l)&&Vg(n,t,a,i),t=a}return t}function sc(n,t,e,i,s){for(let r=0,o=e.length;r<o;++r)t=aa(n,t,e[r],i,s);return t}function rc(n,t){const e=[];let i=0,s=0,r;for(let o=0,a=t.length;o<a;++o){const l=t[o],h=oa(n,i,l,2);if(r===void 0&&(r=h),h===r)e.push(t.slice(s,o+1));else{if(e.length===0)continue;e[e.length-1].push(t[s])}s=o+1,i=l}return e}class gi extends Xi{constructor(t,e,i){super(),this.ends_=[],this.flatInteriorPointRevision_=-1,this.flatInteriorPoint_=null,this.maxDelta_=-1,this.maxDeltaRevision_=-1,this.orientedRevision_=-1,this.orientedFlatCoordinates_=null,e!==void 0&&i?(this.setFlatCoordinates(e,t),this.ends_=i):this.setCoordinates(t,e)}appendLinearRing(t){this.flatCoordinates?Re(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){const t=new gi(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<on(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(Jo(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),ta(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,s))}containsXY(t,e){return sa(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return Hh(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),aa(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,ss(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){const t=Di(this.getExtent());this.flatInteriorPoint_=ra(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new Wi(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new rs(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){const t=this.layout,e=this.flatCoordinates,i=this.ends_,s=[];let r=0;for(let o=0,a=i.length;o<a;++o){const l=i[o],h=new rs(e.slice(r,l),t);s.push(h),r=l}return s}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){const t=this.flatCoordinates;nc(t,0,this.ends_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=aa(this.orientedFlatCoordinates_,0,this.ends_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){const e=[],i=[];return e.length=na(this.flatCoordinates,0,this.ends_,this.stride,Math.sqrt(t),e,0,i),new gi(e,"XY",i)}getType(){return"Polygon"}intersectsExtent(t){return ic(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);const i=ea(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}}function oc(n){if(ts(n))throw new Error("Cannot create polygon from empty extent");const t=n[0],e=n[1],i=n[2],s=n[3],r=[t,e,t,s,i,s,i,e,t,e];return new gi(r,"XY",[r.length])}function Sr(n,t,e,i,s,r,o){let a,l;const h=(e-t)/i;if(h===1)a=t;else if(h===2)a=t,l=s;else if(h!==0){let c=n[t],u=n[t+1],d=0;const f=[0];for(let _=t+i;_<e;_+=i){const p=n[_],y=n[_+1];d+=Math.sqrt((p-c)*(p-c)+(y-u)*(y-u)),f.push(d),c=p,u=y}const g=s*d,m=Tf(f,g);m<0?(l=(g-f[-m-2])/(f[-m-1]-f[-m-2]),a=t+(-m-2)*i):a=t+m*i}o=o>1?o:2,r=r||new Array(o);for(let c=0;c<o;++c)r[c]=a===void 0?NaN:l===void 0?n[a+c]:jt(n[a+c],n[a+i+c],l);return r}function la(n,t,e,i,s,r){if(e==t)return null;let o;if(s<n[t+i-1])return r?(o=n.slice(t,t+i),o[i-1]=s,o):null;if(n[e-1]<s)return r?(o=n.slice(e-i,e),o[i-1]=s,o):null;if(s==n[t+i-1])return n.slice(t,t+i);let a=t/i,l=e/i;for(;a<l;){const d=a+l>>1;s<n[(d+1)*i-1]?l=d:a=d+1}const h=n[a*i-1];if(s==h)return n.slice((a-1)*i,(a-1)*i+i);const c=n[(a+1)*i-1],u=(s-h)/(c-h);o=[];for(let d=0;d<i-1;++d)o.push(jt(n[(a-1)*i+d],n[a*i+d],u));return o.push(s),o}function $g(n,t,e,i,s,r,o){if(o)return la(n,t,e[e.length-1],i,s,r);let a;if(s<n[i-1])return r?(a=n.slice(0,i),a[i-1]=s,a):null;if(n[n.length-1]<s)return r?(a=n.slice(n.length-i),a[i-1]=s,a):null;for(let l=0,h=e.length;l<h;++l){const c=e[l];if(t!=c){if(s<n[t+i-1])return null;if(s<=n[c-1])return la(n,t,c,i,s,!1);t=c}}return null}function ha(n,t,e,i){let s=n[t],r=n[t+1],o=0;for(let a=t+i;a<e;a+=i){const l=n[a],h=n[a+1];o+=Math.sqrt((l-s)*(l-s)+(h-r)*(h-r)),s=l,r=h}return o}class gn extends Xi{constructor(t,e){super(),this.flatMidpoint_=null,this.flatMidpointRevision_=-1,this.maxDelta_=-1,this.maxDeltaRevision_=-1,e!==void 0&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}appendCoordinate(t){Re(this.flatCoordinates,t),this.changed()}clone(){const t=new gn(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<on(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(qo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),Qo(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!1,t,e,i,s))}forEachSegment(t){return tc(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinateAtM(t,e){return this.layout!="XYM"&&this.layout!="XYZM"?null:(e=e!==void 0?e:!1,la(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e))}getCoordinates(){return fi(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinateAt(t,e){return Sr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,this.stride)}getLength(){return ha(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getFlatMidpoint(){return this.flatMidpointRevision_!=this.getRevision()&&(this.flatMidpoint_=this.getCoordinateAt(.5,this.flatMidpoint_??void 0),this.flatMidpointRevision_=this.getRevision()),this.flatMidpoint_}getSimplifiedGeometryInternal(t){const e=[];return e.length=Tr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new gn(e,"XY")}getType(){return"LineString"}intersectsExtent(t){return Rr(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,this.getExtent())}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=Cr(this.flatCoordinates,0,t,this.stride),this.changed()}}const le={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"},Bi=typeof navigator<"u"&&typeof navigator.userAgent<"u"?navigator.userAgent.toLowerCase():"";Bi.includes("safari")&&!Bi.includes("chrom")&&(Bi.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(Bi));const Kg=Bi.includes("webkit")&&!Bi.includes("edge"),ac=Bi.includes("macintosh"),jg=typeof devicePixelRatio<"u"?devicePixelRatio:1,Zt=typeof WorkerGlobalScope<"u"&&typeof OffscreenCanvas<"u"&&self instanceof WorkerGlobalScope,lc=typeof Image<"u"&&Image.prototype.decode,hc=(function(){let n=!1;try{const t=Object.defineProperty({},"passive",{get:function(){n=!0}});window.addEventListener("_",null,t),window.removeEventListener("_",null,t)}catch{}return n})(),$={IDLE:0,LOADING:1,LOADED:2,ERROR:3};function ut(n,t,e,i){let s;return e&&e.length?s=e.shift():Zt?s=new class extends OffscreenCanvas{style={}}(n??300,t??150):s=document.createElement("canvas"),n&&(s.width=n),t&&(s.height=t),s.getContext("2d",i)}let ca;function Ir(){return ca||(ca=ut(1,1)),ca}function os(n){const t=n.canvas;t.width=1,t.height=1,n.clearRect(0,0,1,1)}function Ug(n){let t=n.offsetWidth;const e=getComputedStyle(n);return t+=parseInt(e.marginLeft,10)+parseInt(e.marginRight,10),t}function Zg(n){let t=n.offsetHeight;const e=getComputedStyle(n);return t+=parseInt(e.marginTop,10)+parseInt(e.marginBottom,10),t}function cc(n,t){const e=t.parentNode;e&&e.replaceChild(n,t)}function uc(n){for(;n.lastChild;)n.lastChild.remove()}function Hg(n,t){const e=n.childNodes;for(let i=0;;++i){const s=e[i],r=t[i];if(!s&&!r)break;if(s!==r){if(!s){n.appendChild(r);continue}if(!r){n.removeChild(s),--i;continue}n.insertBefore(r,s)}}}function dc(){return new Proxy({childNodes:[],appendChild:function(t){return this.childNodes.push(t),t},remove:function(){},removeChild:function(t){const e=this.childNodes.indexOf(t);if(e===-1)throw new Error("Node to remove was not found");return this.childNodes.splice(e,1),t},insertBefore:function(t,e){const i=this.childNodes.indexOf(e);if(i===-1)throw new Error("Reference node not found");return this.childNodes.splice(i,0,t),t},style:{}},{get(t,e,i){return e==="firstElementChild"?t.childNodes.length>0?t.childNodes[0]:null:Reflect.get(t,e,i)}})}function _i(n){return typeof HTMLCanvasElement<"u"&&n instanceof HTMLCanvasElement||typeof OffscreenCanvas<"u"&&n instanceof OffscreenCanvas}const ua=[NaN,NaN,NaN,0];let da;function qg(){return da||(da=ut(1,1,void 0,{willReadFrequently:!0,desynchronized:!0})),da}const Jg=/^rgba?\(\s*(\d+%?)\s+(\d+%?)\s+(\d+%?)(?:\s*\/\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,Qg=/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,t_=/^rgba?\(\s*(\d+%)\s*,\s*(\d+%)\s*,\s*(\d+%)(?:\s*,\s*(\d+%|\d*\.\d+|[01]))?\s*\)$/i,e_=/^#([\da-f]{3,4}|[\da-f]{6}|[\da-f]{8})$/i;function br(n,t){return n.endsWith("%")?Number(n.substring(0,n.length-1))/t:Number(n)}function as(n){throw new Error('failed to parse "'+n+'" as color')}function fc(n){if(n.toLowerCase().startsWith("rgb")){const r=n.match(Qg)||n.match(Jg)||n.match(t_);if(r){const o=r[4],a=100/255;return[rt(br(r[1],a)+.5|0,0,255),rt(br(r[2],a)+.5|0,0,255),rt(br(r[3],a)+.5|0,0,255),o!==void 0?rt(br(o,100),0,1):1]}as(n)}if(n.startsWith("#")){if(e_.test(n)){const r=n.substring(1),o=r.length<=4?1:2,a=[0,0,0,255];for(let l=0,h=r.length;l<h;l+=o){let c=parseInt(r.substring(l,l+o),16);o===1&&(c+=c<<4),a[l/o]=c}return a[3]=a[3]/255,a}as(n)}const t=qg();t.fillStyle="#abcdef";let e=t.fillStyle;t.fillStyle=n,t.fillStyle===e&&(t.fillStyle="#fedcba",e=t.fillStyle,t.fillStyle=n,t.fillStyle===e&&as(n));const i=t.fillStyle;if(i.startsWith("#")||i.startsWith("rgba"))return fc(i);t.clearRect(0,0,1,1),t.fillRect(0,0,1,1);const s=Array.from(t.getImageData(0,0,1,1).data);return s[3]=ur(s[3]/255,3),s}function i_(n){return typeof n=="string"?n:xa(n)}const n_=1024,ls={};let fa=0;function s_(n){if(n.length===4)return n;const t=n.slice();return t[3]=1,t}function ga(n){return n>.0031308?Math.pow(n,1/2.4)*269.025-14.025:n*3294.6}function _a(n){return n>.2068965?Math.pow(n,3):(n-4/29)*(108/841)}function ma(n){return n>10.314724?Math.pow((n+14.025)/269.025,2.4):n/3294.6}function pa(n){return n>.0088564?Math.pow(n,1/3):n/(108/841)+4/29}function gc(n){const t=ma(n[0]),e=ma(n[1]),i=ma(n[2]),s=pa(t*.222488403+e*.716873169+i*.06060791),r=500*(pa(t*.452247074+e*.399439023+i*.148375274)-s),o=200*(s-pa(t*.016863605+e*.117638439+i*.865350722)),a=Math.atan2(o,r)*(180/Math.PI);return[116*s-16,Math.sqrt(r*r+o*o),a<0?a+360:a,n[3]]}function r_(n){const t=(n[0]+16)/116,e=n[1],i=n[2]*Math.PI/180,s=_a(t),r=_a(t+e/500*Math.cos(i)),o=_a(t-e/200*Math.sin(i)),a=ga(r*3.021973625-s*1.617392459-o*.404875592),l=ga(r*-.943766287+s*1.916279586+o*.027607165),h=ga(r*.069407491-s*.22898585+o*1.159737864);return[rt(a+.5|0,0,255),rt(l+.5|0,0,255),rt(h+.5|0,0,255),n[3]]}function ya(n){if(n==="none")return ua;if(ls.hasOwnProperty(n))return ls[n];if(fa>=n_){let e=0;for(const i in ls)(e++&3)===0&&(delete ls[i],--fa)}const t=fc(n);t.length!==4&&as(n);for(const e of t)isNaN(e)&&as(n);return ls[n]=t,++fa,t}function _n(n){return Array.isArray(n)?n:ya(n)}function xa(n){let t=n[0];t!=(t|0)&&(t=t+.5|0);let e=n[1];e!=(e|0)&&(e=e+.5|0);let i=n[2];i!=(i|0)&&(i=i+.5|0);const s=n[3]===void 0?1:Math.round(n[3]*1e3)/1e3;return"rgba("+t+","+e+","+i+","+s+")"}function o_(n,t,e){const i=n;let s=!0,r=!1,o=!1;const a=[rr(i,V.LOAD,function(){o=!0,r||t()})];return i.src&&lc?(r=!0,i.decode().then(function(){s&&t()}).catch(function(l){s&&(o?t():e())})):a.push(rr(i,V.ERROR,e)),function(){s=!1,a.forEach(nt)}}function a_(n,t){return new Promise((e,i)=>{function s(){o(),e(n)}function r(){o(),i(new Error("Image load error"))}function o(){n.removeEventListener("load",s),n.removeEventListener("error",r)}n.addEventListener("load",s),n.addEventListener("error",r)})}function l_(n,t){return t&&(n.src=t),n.src&&lc?new Promise((e,i)=>n.decode().then(()=>e(n)).catch(s=>n.complete&&n.width?e(n):i(s))):a_(n)}class h_{constructor(){this.cache_={},this.patternCache_={},this.cacheSize_=0,this.maxCacheSize_=1024}clear(){this.cache_={},this.patternCache_={},this.cacheSize_=0}canExpireCache(){return this.cacheSize_>this.maxCacheSize_}expire(){if(this.canExpireCache()){let t=0;for(const e in this.cache_){const i=this.cache_[e];(t++&3)===0&&!i.hasListener()&&(delete this.cache_[e],delete this.patternCache_[e],--this.cacheSize_)}}}get(t,e,i){const s=Ea(t,e,i);return s in this.cache_?this.cache_[s]:null}getPattern(t,e,i){const s=Ea(t,e,i);return s in this.patternCache_?this.patternCache_[s]:null}set(t,e,i,s,r){const o=Ea(t,e,i),a=o in this.cache_;this.cache_[o]=s,r&&(s.getImageState()===$.IDLE&&s.load(),s.getImageState()===$.LOADING?s.ready().then(()=>{this.patternCache_[o]=Ir().createPattern(s.getImage(1),"repeat")}):this.patternCache_[o]=Ir().createPattern(s.getImage(1),"repeat")),a||++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}}function Ea(n,t,e){const i=e?_n(e):"null";return t+":"+n+":"+i}const he=new h_;let hs=null;class _c extends sr{constructor(t,e,i,s,r){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=i,this.canvas_={},this.color_=r,this.imageState_=s===void 0?$.IDLE:s,this.size_=t&&t.width&&t.height?[t.width,t.height]:null,this.src_=e,this.tainted_,this.ready_=null}initializeImage_(){this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_)}isTainted_(){if(this.tainted_===void 0&&this.imageState_===$.LOADED){hs||(hs=ut(1,1,void 0,{willReadFrequently:!0})),hs.drawImage(this.image_,0,0);try{hs.getImageData(0,0,1,1),this.tainted_=!1}catch{hs=null,this.tainted_=!0}}return this.tainted_===!0}dispatchChangeEvent_(){this.dispatchEvent(V.CHANGE)}handleImageError_(){this.imageState_=$.ERROR,this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=$.LOADED,this.size_=[this.image_.width,this.image_.height],this.dispatchChangeEvent_()}getImage(t){return this.image_||this.initializeImage_(),this.replaceColor_(t),this.canvas_[t]?this.canvas_[t]:this.image_}getPixelRatio(t){return this.replaceColor_(t),this.canvas_[t]?t:1}getImageState(){return this.imageState_}getHitDetectionImage(){if(this.image_||this.initializeImage_(),!this.hitDetectionImage_)if(this.isTainted_()){const t=this.size_[0],e=this.size_[1],i=ut(t,e);i.fillRect(0,0,t,e),this.hitDetectionImage_=i.canvas}else this.hitDetectionImage_=this.image_;return this.hitDetectionImage_}getSize(){return this.size_}getSrc(){return this.src_}load(){if(this.imageState_===$.IDLE){this.image_||this.initializeImage_(),this.imageState_=$.LOADING;try{this.src_!==void 0&&(this.image_.src=this.src_)}catch{this.handleImageError_()}this.image_ instanceof HTMLImageElement&&l_(this.image_,this.src_).then(t=>{this.image_=t,this.handleImageLoad_()}).catch(this.handleImageError_.bind(this))}}replaceColor_(t){if(!this.color_||this.canvas_[t]||this.imageState_!==$.LOADED)return;const e=this.image_,i=ut(Math.ceil(e.width*t),Math.ceil(e.height*t)),s=i.canvas;i.scale(t,t),i.drawImage(e,0,0),i.globalCompositeOperation="multiply",i.fillStyle=i_(this.color_),i.fillRect(0,0,s.width/t,s.height/t),i.globalCompositeOperation="destination-in",i.drawImage(e,0,0),this.canvas_[t]=s}ready(){return this.ready_||(this.ready_=new Promise(t=>{if(this.imageState_===$.LOADED||this.imageState_===$.ERROR)t();else{const e=()=>{(this.imageState_===$.LOADED||this.imageState_===$.ERROR)&&(this.removeEventListener(V.CHANGE,e),t())};this.addEventListener(V.CHANGE,e)}})),this.ready_}}function Lr(n,t,e,i,s,r){let o=t===void 0?void 0:he.get(t,e,s);return o||(o=new _c(n,n&&"src"in n?n.src||void 0:t,e,i,s),he.set(t,e,s,o,r)),r&&o&&!he.getPattern(t,e,s)&&he.set(t,e,s,o,r),o}function Se(n){return n?Array.isArray(n)?xa(n):typeof n=="object"&&"src"in n?c_(n):n:null}function c_(n){if(!n.offset||!n.size)return he.getPattern(n.src,"anonymous",n.color);const t=n.src+":"+n.offset,e=he.getPattern(t,void 0,n.color);if(e)return e;const i=he.get(n.src,"anonymous",null);if(i.getImageState()!==$.LOADED)return null;const s=ut(n.size[0],n.size[1]);return s.drawImage(i.getImage(1),n.offset[0],n.offset[1],n.size[0],n.size[1],0,0,n.size[0],n.size[1]),Lr(s.canvas,t,void 0,$.LOADED,n.color,!0),he.getPattern(t,void 0,n.color)}class mc{drawCustom(t,e,i,s,r){}drawGeometry(t){}setStyle(t){}drawCircle(t,e,i){}drawFeature(t,e,i){}drawGeometryCollection(t,e,i){}drawLineString(t,e,i){}drawMultiLineString(t,e,i){}drawMultiPoint(t,e,i){}drawMultiPolygon(t,e,i){}drawPoint(t,e,i){}drawPolygon(t,e,i){}drawText(t,e,i){}setFillStrokeStyle(t,e){}setImageStyle(t,e){}setTextStyle(t,e){}}const Ar="ol-hidden",u_="ol-selectable",Pr="ol-unselectable",wa="ol-control",pc="ol-collapsed",d_=new RegExp(["^\\s*(?=(?:(?:[-a-z]+\\s*){0,2}(italic|oblique))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(small-caps))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(bold(?:er)?|lighter|[1-9]00 ))?)","(?:(?:normal|\\1|\\2|\\3)\\s*){0,3}((?:xx?-)?","(?:small|large)|medium|smaller|larger|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx]))","(?:\\s*\\/\\s*(normal|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx])?))",`?\\s*([-,\\"\\'\\sa-z0-9]+?)\\s*$`].join(""),"i"),yc=["style","variant","weight","size","lineHeight","family"],va={normal:400,bold:700},Ca=function(n){const t=n.match(d_);if(!t)return null;const e={lineHeight:"normal",size:"1.2em",style:"normal",weight:"400",variant:"normal"};for(let i=0,s=yc.length;i<s;++i){const r=t[i+1];r!==void 0&&(e[yc[i]]=typeof r=="string"?r.trim():r)}return isNaN(Number(e.weight))&&e.weight in va&&(e.weight=va[e.weight]),e.families=e.family.split(/,\s?/).map(i=>i.trim().replace(/^['"]|['"]$/g,"")),e},xc="10px sans-serif",Yt="#000",mn="round",Ye=[],We=0,pn="round",cs=10,us="#000",ds="center",Mr="middle",$i=[0,0,0,0],fs=1,yn=new ye;let gs=null,Ec;const Ta={},f_=new Set(["serif","sans-serif","monospace","cursive","fantasy","system-ui","ui-serif","ui-sans-serif","ui-monospace","ui-rounded","emoji","math","fangsong"]);function g_(n,t,e){return`${n} ${t} 16px "${e}"`}const __=(function(){let t,e;async function i(r){await e.ready;const o=await e.load(r);if(o.length===0)return!1;const a=Ca(r),l=a.families[0].toLowerCase(),h=a.weight;return o.some(c=>{const u=c.family.replace(/^['"]|['"]$/g,"").toLowerCase(),d=va[c.weight]||c.weight;return u===l&&c.style===a.style&&d==h})}async function s(){await e.ready;let r=!0;const o=yn.getProperties(),a=Object.keys(o).filter(l=>o[l]<100);for(let l=a.length-1;l>=0;--l){const h=a[l];let c=o[h];c<100&&(await i(h)?(Hn(Ta),yn.set(h,100)):(c+=10,yn.set(h,c,!0),c<100&&(r=!1)))}t=void 0,r||(t=setTimeout(s,100))}return async function(r){e||(e=Zt?self.fonts:document.fonts);const o=Ca(r);if(!o)return;const a=o.families;let l=!1;for(const h of a){if(f_.has(h))continue;const c=g_(o.style,o.weight,h);yn.get(c)===void 0&&(yn.set(c,0,!0),l=!0)}l&&(clearTimeout(t),t=setTimeout(s,100))}})(),m_=(function(){let n;return function(t){let e=Ta[t];if(e==null){if(Zt){const i=Ca(t),s=wc(t,"Žg");e=(isNaN(Number(i.lineHeight))?1.2:Number(i.lineHeight))*(s.actualBoundingBoxAscent+s.actualBoundingBoxDescent)}else n||(n=document.createElement("div"),n.innerHTML="M",n.style.minHeight="0",n.style.maxHeight="none",n.style.height="auto",n.style.padding="0",n.style.border="none",n.style.position="absolute",n.style.display="block",n.style.left="-99999px"),n.style.font=t,document.body.appendChild(n),e=n.offsetHeight,document.body.removeChild(n);Ta[t]=e}return e}})();function wc(n,t){return gs||(gs=ut(1,1)),n!=Ec&&(gs.font=n,Ec=gs.font),gs.measureText(t)}function vc(n,t){return wc(n,t).width}function Cc(n,t,e){if(t in e)return e[t];const i=t.split(`
|
|
3
|
+
`).reduce((s,r)=>Math.max(s,vc(n,r)),0);return e[t]=i,i}function p_(n,t){const e=[],i=[],s=[];let r=0,o=0,a=0,l=0;for(let h=0,c=t.length;h<=c;h+=2){const u=t[h];if(u===`
|
|
4
|
+
`||h===c){r=Math.max(r,o),s.push(o),o=0,a+=l,l=0;continue}const d=t[h+1]||n.font,f=vc(d,u);e.push(f),o+=f;const g=m_(d);i.push(g),l=Math.max(l,g)}return{width:r,height:a,widths:e,heights:i,lineWidths:s}}function y_(n,t,e,i,s,r,o,a,l,h,c){n.save(),e!==1&&(n.globalAlpha===void 0?n.globalAlpha=u=>u.globalAlpha*=e:n.globalAlpha*=e),t&&n.transform.apply(n,t),i.contextInstructions?(n.translate(l,h),n.scale(c[0],c[1]),x_(i,n)):c[0]<0||c[1]<0?(n.translate(l,h),n.scale(c[0],c[1]),n.drawImage(i,s,r,o,a,0,0,o,a)):n.drawImage(i,s,r,o,a,l,h,o*c[0],a*c[1]),n.restore()}function x_(n,t){const e=n.contextInstructions;for(let i=0,s=e.length;i<s;i+=2)Array.isArray(e[i+1])?t[e[i]].apply(t,e[i+1]):t[e[i]]=e[i+1]}class E_ extends mc{constructor(t,e,i,s,r,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=s,this.transformRotation_=s?ur(Math.atan2(s[1],s[0]),10):0,this.viewRotation_=r,this.squaredTolerance_=o,this.userTransform_=a,this.contextFillState_=null,this.contextStrokeState_=null,this.contextTextState_=null,this.fillState_=null,this.strokeState_=null,this.image_=null,this.imageAnchorX_=0,this.imageAnchorY_=0,this.imageHeight_=0,this.imageOpacity_=0,this.imageOriginX_=0,this.imageOriginY_=0,this.imageRotateWithView_=!1,this.imageRotation_=0,this.imageScale_=[0,0],this.imageWidth_=0,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=!1,this.textRotation_=0,this.textScale_=[0,0],this.textFillState_=null,this.textStrokeState_=null,this.textState_=null,this.pixelCoordinates_=[],this.tmpLocalTransform_=ae()}drawImages_(t,e,i,s){if(!this.image_)return;const r=di(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.tmpLocalTransform_,l=o.globalAlpha;this.imageOpacity_!=1&&(o.globalAlpha=l*this.imageOpacity_);let h=this.imageRotation_;this.transformRotation_===0&&(h-=this.viewRotation_),this.imageRotateWithView_&&(h+=this.viewRotation_);for(let c=0,u=r.length;c<u;c+=2){const d=r[c]-this.imageAnchorX_,f=r[c+1]-this.imageAnchorY_;if(h!==0||this.imageScale_[0]!=1||this.imageScale_[1]!=1){const g=d+this.imageAnchorX_,m=f+this.imageAnchorY_;Xe(a,g,m,1,1,h,-g,-m),o.save(),o.transform.apply(o,a),o.translate(g,m),o.scale(this.imageScale_[0],this.imageScale_[1]),o.drawImage(this.image_,this.imageOriginX_,this.imageOriginY_,this.imageWidth_,this.imageHeight_,-this.imageAnchorX_,-this.imageAnchorY_,this.imageWidth_,this.imageHeight_),o.restore()}else o.drawImage(this.image_,this.imageOriginX_,this.imageOriginY_,this.imageWidth_,this.imageHeight_,d,f,this.imageWidth_,this.imageHeight_)}this.imageOpacity_!=1&&(o.globalAlpha=l)}drawText_(t,e,i,s){if(!this.textState_||this.text_==="")return;this.textFillState_&&this.setContextFillState_(this.textFillState_),this.textStrokeState_&&this.setContextStrokeState_(this.textStrokeState_),this.setContextTextState_(this.textState_);const r=di(t,e,i,s,this.transform_,this.pixelCoordinates_),o=this.context_;let a=this.textRotation_;for(this.transformRotation_===0&&(a-=this.viewRotation_),this.textRotateWithView_&&(a+=this.viewRotation_);e<i;e+=s){const l=r[e]+this.textOffsetX_,h=r[e+1]+this.textOffsetY_;a!==0||this.textScale_[0]!=1||this.textScale_[1]!=1?(o.save(),o.translate(l-this.textOffsetX_,h-this.textOffsetY_),o.rotate(a),o.translate(this.textOffsetX_,this.textOffsetY_),o.scale(this.textScale_[0],this.textScale_[1]),this.textStrokeState_&&o.strokeText(this.text_,0,0),this.textFillState_&&o.fillText(this.text_,0,0),o.restore()):(this.textStrokeState_&&o.strokeText(this.text_,l,h),this.textFillState_&&o.fillText(this.text_,l,h))}}moveToLineTo_(t,e,i,s,r){const o=this.context_,a=di(t,e,i,s,this.transform_,this.pixelCoordinates_);o.moveTo(a[0],a[1]);let l=a.length;r&&(l-=2);for(let h=2;h<l;h+=2)o.lineTo(a[h],a[h+1]);return r&&o.closePath(),i}drawRings_(t,e,i,s){for(let r=0,o=i.length;r<o;++r)e=this.moveToLineTo_(t,e,i[r],s,!0);return e}drawCircle(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!ct(this.extent_,t.getExtent())){if(this.fillState_||this.strokeState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=Pg(t,this.transform_,this.pixelCoordinates_),i=e[2]-e[0],s=e[3]-e[1],r=Math.sqrt(i*i+s*s),o=this.context_;o.beginPath(),o.arc(e[0],e[1],r,0,2*Math.PI),this.fillState_&&o.fill(),this.strokeState_&&o.stroke()}this.text_!==""&&this.drawText_(t.getCenter(),0,2,2)}}setStyle(t){this.setFillStrokeStyle(t.getFill(),t.getStroke()),this.setImageStyle(t.getImage()),this.setTextStyle(t.getText())}setTransform(t){this.transform_=t}drawGeometry(t){switch(t.getType()){case"Point":this.drawPoint(t);break;case"LineString":this.drawLineString(t);break;case"Polygon":this.drawPolygon(t);break;case"MultiPoint":this.drawMultiPoint(t);break;case"MultiLineString":this.drawMultiLineString(t);break;case"MultiPolygon":this.drawMultiPolygon(t);break;case"GeometryCollection":this.drawGeometryCollection(t);break;case"Circle":this.drawCircle(t);break}}drawFeature(t,e){const i=e.getGeometryFunction()(t);i&&(this.setStyle(e),this.drawGeometry(i))}drawGeometryCollection(t){const e=t.getGeometriesArray();for(let i=0,s=e.length;i<s;++i)this.drawGeometry(e[i])}drawPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawMultiPoint(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getFlatCoordinates(),i=t.getStride();this.image_&&this.drawImages_(e,0,e.length,i),this.text_!==""&&this.drawText_(e,0,e.length,i)}drawLineString(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!ct(this.extent_,t.getExtent())){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getFlatCoordinates();e.beginPath(),this.moveToLineTo_(i,0,i.length,t.getStride(),!1),e.stroke()}if(this.text_!==""){const e=t.getFlatMidpoint();this.drawText_(e,0,2,2)}}}drawMultiLineString(t){this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_));const e=t.getExtent();if(ct(this.extent_,e)){if(this.strokeState_){this.setContextStrokeState_(this.strokeState_);const i=this.context_,s=t.getFlatCoordinates();let r=0;const o=t.getEnds(),a=t.getStride();i.beginPath();for(let l=0,h=o.length;l<h;++l)r=this.moveToLineTo_(s,r,o[l],a,!1);i.stroke()}if(this.text_!==""){const i=t.getFlatMidpoints();this.drawText_(i,0,i.length,2)}}}drawPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!ct(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_;e.beginPath(),this.drawRings_(t.getOrientedFlatCoordinates(),0,t.getEnds(),t.getStride()),this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoint();this.drawText_(e,0,2,2)}}}drawMultiPolygon(t){if(this.squaredTolerance_&&(t=t.simplifyTransformed(this.squaredTolerance_,this.userTransform_)),!!ct(this.extent_,t.getExtent())){if(this.strokeState_||this.fillState_){this.fillState_&&this.setContextFillState_(this.fillState_),this.strokeState_&&this.setContextStrokeState_(this.strokeState_);const e=this.context_,i=t.getOrientedFlatCoordinates();let s=0;const r=t.getEndss(),o=t.getStride();e.beginPath();for(let a=0,l=r.length;a<l;++a){const h=r[a];s=this.drawRings_(i,s,h,o)}this.fillState_&&e.fill(),this.strokeState_&&e.stroke()}if(this.text_!==""){const e=t.getFlatInteriorPoints();this.drawText_(e,0,e.length,2)}}}setContextFillState_(t){const e=this.context_,i=this.contextFillState_;i?i.fillStyle!=t.fillStyle&&(i.fillStyle=t.fillStyle,e.fillStyle=t.fillStyle):(e.fillStyle=t.fillStyle,this.contextFillState_={fillStyle:t.fillStyle})}setContextStrokeState_(t){const e=this.context_,i=this.contextStrokeState_;i?(i.lineCap!=t.lineCap&&(i.lineCap=t.lineCap,e.lineCap=t.lineCap),ai(i.lineDash,t.lineDash)||e.setLineDash(i.lineDash=t.lineDash),i.lineDashOffset!=t.lineDashOffset&&(i.lineDashOffset=t.lineDashOffset,e.lineDashOffset=t.lineDashOffset),i.lineJoin!=t.lineJoin&&(i.lineJoin=t.lineJoin,e.lineJoin=t.lineJoin),i.lineWidth!=t.lineWidth&&(i.lineWidth=t.lineWidth,e.lineWidth=t.lineWidth),i.miterLimit!=t.miterLimit&&(i.miterLimit=t.miterLimit,e.miterLimit=t.miterLimit),i.strokeStyle!=t.strokeStyle&&(i.strokeStyle=t.strokeStyle,e.strokeStyle=t.strokeStyle)):(e.lineCap=t.lineCap,e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset,e.lineJoin=t.lineJoin,e.lineWidth=t.lineWidth,e.miterLimit=t.miterLimit,e.strokeStyle=t.strokeStyle,this.contextStrokeState_={lineCap:t.lineCap,lineDash:t.lineDash,lineDashOffset:t.lineDashOffset,lineJoin:t.lineJoin,lineWidth:t.lineWidth,miterLimit:t.miterLimit,strokeStyle:t.strokeStyle})}setContextTextState_(t){const e=this.context_,i=this.contextTextState_,s=t.textAlign?t.textAlign:ds;i?(i.font!=t.font&&(i.font=t.font,e.font=t.font),i.textAlign!=s&&(i.textAlign=s,e.textAlign=s),i.textBaseline!=t.textBaseline&&(i.textBaseline=t.textBaseline,e.textBaseline=t.textBaseline)):(e.font=t.font,e.textAlign=s,e.textBaseline=t.textBaseline,this.contextTextState_={font:t.font,textAlign:s,textBaseline:t.textBaseline})}setFillStrokeStyle(t,e){if(!t)this.fillState_=null;else{const i=t.getColor();this.fillState_={fillStyle:Se(i||Yt)}}if(!e)this.strokeState_=null;else{const i=e.getColor(),s=e.getLineCap(),r=e.getLineDash(),o=e.getLineDashOffset(),a=e.getLineJoin(),l=e.getWidth(),h=e.getMiterLimit(),c=r||Ye;this.strokeState_={lineCap:s!==void 0?s:mn,lineDash:this.pixelRatio_===1?c:c.map(u=>u*this.pixelRatio_),lineDashOffset:(o||We)*this.pixelRatio_,lineJoin:a!==void 0?a:pn,lineWidth:(l!==void 0?l:fs)*this.pixelRatio_,miterLimit:h!==void 0?h:cs,strokeStyle:Se(i||us)}}}setImageStyle(t){let e;if(!t||!(e=t.getSize())){this.image_=null;return}const i=t.getPixelRatio(this.pixelRatio_),s=t.getAnchor(),r=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=s[0]*i,this.imageAnchorY_=s[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=r[0],this.imageOriginY_=r[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();const o=t.getScaleArray();this.imageScale_=[o[0]*this.pixelRatio_/i,o[1]*this.pixelRatio_/i],this.imageWidth_=e[0]*i}setTextStyle(t){if(!t)this.text_="";else{const e=t.getFill();if(!e)this.textFillState_=null;else{const f=e.getColor();this.textFillState_={fillStyle:Se(f||Yt)}}const i=t.getStroke();if(!i)this.textStrokeState_=null;else{const f=i.getColor(),g=i.getLineCap(),m=i.getLineDash(),_=i.getLineDashOffset(),p=i.getLineJoin(),y=i.getWidth(),w=i.getMiterLimit();this.textStrokeState_={lineCap:g!==void 0?g:mn,lineDash:m||Ye,lineDashOffset:_||We,lineJoin:p!==void 0?p:pn,lineWidth:y!==void 0?y:fs,miterLimit:w!==void 0?w:cs,strokeStyle:Se(f||us)}}const s=t.getFont(),r=t.getOffsetX(),o=t.getOffsetY(),a=t.getRotateWithView(),l=t.getRotation(),h=t.getScaleArray(),c=t.getText(),u=t.getTextAlign(),d=t.getTextBaseline();this.textState_={font:s!==void 0?s:xc,textAlign:u!==void 0?u:ds,textBaseline:d!==void 0?d:Mr},this.text_=c!==void 0?Array.isArray(c)?c.reduce((f,g,m)=>f+=m%2?" ":g,""):c:"",this.textOffsetX_=r!==void 0?this.pixelRatio_*r:0,this.textOffsetY_=o!==void 0?this.pixelRatio_*o:0,this.textRotateWithView_=a!==void 0?a:!1,this.textRotation_=l!==void 0?l:0,this.textScale_=[this.pixelRatio_*h[0],this.pixelRatio_*h[1]]}}}const w_=.5,Tc={Point:L_,LineString:S_,Polygon:P_,MultiPoint:A_,MultiLineString:I_,MultiPolygon:b_,GeometryCollection:R_,Circle:C_};function v_(n,t){return parseInt(B(n),10)-parseInt(B(t),10)}function Ra(n,t){const e=Rc(n,t);return e*e}function Rc(n,t){return w_*n/t}function C_(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Circle");l.setFillStrokeStyle(r,o),l.drawCircle(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i)}}function Fr(n,t,e,i,s,r,o,a){const l=[],h=e.getImage();if(h){let d=!0;const f=h.getImageState();f==$.LOADED||f==$.ERROR?d=!1:f==$.IDLE&&h.load(),d&&l.push(h.ready())}const c=e.getFill();c&&c.loading()&&l.push(c.ready());const u=l.length>0;return u&&Promise.all(l).then(()=>s(null)),T_(n,t,e,i,r,o,a),u}function T_(n,t,e,i,s,r,o){const a=e.getGeometryFunction()(t);if(!a)return;const l=a.simplifyTransformed(i,s);if(e.getRenderer())Sc(n,l,e,t,o);else{const c=Tc[l.getType()];c(n,l,e,t,o,r)}}function Sc(n,t,e,i,s){if(t.getType()=="GeometryCollection"){const o=t.getGeometries();for(let a=0,l=o.length;a<l;++a)Sc(n,o[a],e,i,s);return}n.getBuilder(e.getZIndex(),"Default").drawCustom(t,i,e.getRenderer(),e.getHitDetectionRenderer(),s)}function R_(n,t,e,i,s,r){const o=t.getGeometriesArray();let a,l;for(a=0,l=o.length;a<l;++a){const h=Tc[o[a].getType()];h(n,o[a],e,i,s,r)}}function S_(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawLineString(t,i,s)}const o=e.getText();if(o&&o.getText()){const a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,s)}}function I_(n,t,e,i,s){const r=e.getStroke();if(r){const a=n.getBuilder(e.getZIndex(),"LineString");a.setFillStrokeStyle(null,r),a.drawMultiLineString(t,i,s)}const o=e.getText();if(o&&o.getText()){const a=n.getBuilder(e.getZIndex(),"Text");a.setTextStyle(o),a.drawText(t,i,s)}}function b_(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(o||r){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawMultiPolygon(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,s)}}function L_(n,t,e,i,s,r){const o=e.getImage(),a=e.getText(),l=a&&a.getText(),h=r&&o&&l?{}:void 0;if(o){if(o.getImageState()!=$.LOADED)return;const c=n.getBuilder(e.getZIndex(),"Image");c.setImageStyle(o,h),c.drawPoint(t,i,s)}if(l){const c=n.getBuilder(e.getZIndex(),"Text");c.setTextStyle(a,h),c.drawText(t,i,s)}}function A_(n,t,e,i,s,r){const o=e.getImage(),a=o&&o.getOpacity()!==0,l=e.getText(),h=l&&l.getText(),c=r&&a&&h?{}:void 0;if(a){if(o.getImageState()!=$.LOADED)return;const u=n.getBuilder(e.getZIndex(),"Image");u.setImageStyle(o,c),u.drawMultiPoint(t,i,s)}if(h){const u=n.getBuilder(e.getZIndex(),"Text");u.setTextStyle(l,c),u.drawText(t,i,s)}}function P_(n,t,e,i,s){const r=e.getFill(),o=e.getStroke();if(r||o){const l=n.getBuilder(e.getZIndex(),"Polygon");l.setFillStrokeStyle(r,o),l.drawPolygon(t,i,s)}const a=e.getText();if(a&&a.getText()){const l=n.getBuilder(e.getZIndex(),"Text");l.setTextStyle(a),l.drawText(t,i,s)}}let M_=!1;function Ic(n,t,e,i,s,r,o){const a=new XMLHttpRequest;a.open("GET",typeof n=="function"?n(e,i,s):n,!0),t.getType()=="arraybuffer"&&(a.responseType="arraybuffer"),a.withCredentials=M_,a.onload=function(l){if(!a.status||a.status>=200&&a.status<300){const h=t.getType();try{let c;h=="text"||h=="json"?c=a.responseText:h=="xml"?c=a.responseXML||a.responseText:h=="arraybuffer"&&(c=a.response),c?r(t.readFeatures(c,{extent:e,featureProjection:s}),t.readProjection(c)):o()}catch{o()}}else o()},a.onerror=o,a.send()}function bc(n,t){return function(e,i,s,r,o){Ic(n,t,e,i,s,(a,l)=>{this.addFeatures(a),r!==void 0&&r(a)},()=>{this.changed(),o!==void 0&&o()})}}function F_(n,t){return[[-1/0,-1/0,1/0,1/0]]}function Lc(n,t,e,i){const s=[];let r=Kt();for(let o=0,a=e.length;o<a;++o){const l=e[o];r=bo(n,t,l[0],i),s.push((r[0]+r[2])/2,(r[1]+r[3])/2),t=l[l.length-1]}return s}class Or extends Xi{constructor(t,e,i){if(super(),this.ends_=[],this.maxDelta_=-1,this.maxDeltaRevision_=-1,Array.isArray(t[0]))this.setCoordinates(t,e);else if(e!==void 0&&i)this.setFlatCoordinates(e,t),this.ends_=i;else{const s=t,r=[],o=[];for(let l=0,h=s.length;l<h;++l){const c=s[l];Re(r,c.getFlatCoordinates()),o.push(r.length)}const a=s.length===0?this.getLayout():s[0].getLayout();this.setFlatCoordinates(a,r),this.ends_=o}}appendLineString(t){Re(this.flatCoordinates,t.getFlatCoordinates().slice()),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){const t=new Or(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,s){return s<on(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(Jo(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),ta(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!1,t,e,i,s))}getCoordinateAtM(t,e,i){return this.layout!="XYM"&&this.layout!="XYZM"||this.flatCoordinates.length===0?null:(e=e!==void 0?e:!1,i=i!==void 0?i:!1,$g(this.flatCoordinates,0,this.ends_,this.stride,t,e,i))}getCoordinates(){return ss(this.flatCoordinates,0,this.ends_,this.stride)}getEnds(){return this.ends_}getLineString(t){return t<0||this.ends_.length<=t?null:new gn(this.flatCoordinates.slice(t===0?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLineStrings(){const t=this.flatCoordinates,e=this.ends_,i=this.layout,s=[];let r=0;for(let o=0,a=e.length;o<a;++o){const l=e[o],h=new gn(t.slice(r,l),i);s.push(h),r=l}return s}getLength(){const t=this.ends_;let e=0,i=0;for(let s=0,r=t.length;s<r;++s)i+=ha(this.flatCoordinates,e,t[s],this.stride),e=t[s];return i}getFlatMidpoints(){const t=[],e=this.flatCoordinates;let i=0;const s=this.ends_,r=this.stride;for(let o=0,a=s.length;o<a;++o){const l=s[o],h=Sr(e,i,l,r,.5);Re(t,h),i=l}return t}getSimplifiedGeometryInternal(t){const e=[],i=[];return e.length=Jh(this.flatCoordinates,0,this.ends_,this.stride,t,e,0,i),new Or(e,"XY",i)}getType(){return"MultiLineString"}intersectsExtent(t){return Yg(this.flatCoordinates,0,this.ends_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,2),this.flatCoordinates||(this.flatCoordinates=[]);const i=ea(this.flatCoordinates,0,t,this.stride,this.ends_);this.flatCoordinates.length=i.length===0?0:i[i.length-1],this.changed()}}class Dr extends Xi{constructor(t,e){super(),e&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}appendPoint(t){Re(this.flatCoordinates,t.getFlatCoordinates()),this.changed()}clone(){const t=new Dr(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,s){if(s<on(this.getExtent(),t,e))return s;const r=this.flatCoordinates,o=this.stride;for(let a=0,l=r.length;a<l;a+=o){const h=ki(t,e,r[a],r[a+1]);if(h<s){s=h;for(let c=0;c<o;++c)i[c]=r[a+c];i.length=o}}return s}getCoordinates(){return fi(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getPoint(t){const e=this.flatCoordinates.length/this.stride;return t<0||e<=t?null:new Wi(this.flatCoordinates.slice(t*this.stride,(t+1)*this.stride),this.layout)}getPoints(){const t=this.flatCoordinates,e=this.layout,i=this.stride,s=[];for(let r=0,o=t.length;r<o;r+=i){const a=new Wi(t.slice(r,r+i),e);s.push(a)}return s}getType(){return"MultiPoint"}intersectsExtent(t){const e=this.flatCoordinates,i=this.stride;for(let s=0,r=e.length;s<r;s+=i){const o=e[s],a=e[s+1];if(So(t,o,a))return!0}return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=Cr(this.flatCoordinates,0,t,this.stride),this.changed()}}class kr extends Xi{constructor(t,e,i){if(super(),this.endss_=[],this.flatInteriorPointsRevision_=-1,this.flatInteriorPoints_=null,this.maxDelta_=-1,this.maxDeltaRevision_=-1,this.orientedRevision_=-1,this.orientedFlatCoordinates_=null,!i&&!Array.isArray(t[0])){const s=t,r=[],o=[];for(let a=0,l=s.length;a<l;++a){const h=s[a],c=r.length,u=h.getEnds();for(let d=0,f=u.length;d<f;++d)u[d]+=c;Re(r,h.getFlatCoordinates()),o.push(u)}e=s.length===0?this.getLayout():s[0].getLayout(),t=r,i=o}e!==void 0&&i?(this.setFlatCoordinates(e,t),this.endss_=i):this.setCoordinates(t,e)}appendPolygon(t){let e;if(!this.flatCoordinates)this.flatCoordinates=t.getFlatCoordinates().slice(),e=t.getEnds().slice(),this.endss_.push();else{const i=this.flatCoordinates.length;Re(this.flatCoordinates,t.getFlatCoordinates()),e=t.getEnds().slice();for(let s=0,r=e.length;s<r;++s)e[s]+=i}this.endss_.push(e),this.changed()}clone(){const t=this.endss_.length,e=new Array(t);for(let s=0;s<t;++s)e[s]=this.endss_[s].slice();const i=new kr(this.flatCoordinates.slice(),this.layout,e);return i.applyProperties(this),i}closestPointXY(t,e,i,s){return s<on(this.getExtent(),t,e)?s:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt(Fg(this.flatCoordinates,0,this.endss_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),Og(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,this.maxDelta_,!0,t,e,i,s))}containsXY(t,e){return Xg(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t,e)}getArea(){return Mg(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride)}getCoordinates(t){let e;return t!==void 0?(e=this.getOrientedFlatCoordinates().slice(),sc(e,0,this.endss_,this.stride,t)):e=this.flatCoordinates,ia(e,0,this.endss_,this.stride)}getEndss(){return this.endss_}getFlatInteriorPoints(){if(this.flatInteriorPointsRevision_!=this.getRevision()){const t=Lc(this.flatCoordinates,0,this.endss_,this.stride);this.flatInteriorPoints_=Qh(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t),this.flatInteriorPointsRevision_=this.getRevision()}return this.flatInteriorPoints_}getInteriorPoints(){return new Dr(this.getFlatInteriorPoints().slice(),"XYM")}getOrientedFlatCoordinates(){if(this.orientedRevision_!=this.getRevision()){const t=this.flatCoordinates;Bg(t,0,this.endss_,this.stride)?this.orientedFlatCoordinates_=t:(this.orientedFlatCoordinates_=t.slice(),this.orientedFlatCoordinates_.length=sc(this.orientedFlatCoordinates_,0,this.endss_,this.stride)),this.orientedRevision_=this.getRevision()}return this.orientedFlatCoordinates_}getSimplifiedGeometryInternal(t){const e=[],i=[];return e.length=Gg(this.flatCoordinates,0,this.endss_,this.stride,Math.sqrt(t),e,0,i),new kr(e,"XY",i)}getPolygon(t){if(t<0||this.endss_.length<=t)return null;let e;if(t===0)e=0;else{const r=this.endss_[t-1];e=r[r.length-1]}const i=this.endss_[t].slice(),s=i[i.length-1];if(e!==0)for(let r=0,o=i.length;r<o;++r)i[r]-=e;return new gi(this.flatCoordinates.slice(e,s),this.layout,i)}getPolygons(){const t=this.layout,e=this.flatCoordinates,i=this.endss_,s=[];let r=0;for(let o=0,a=i.length;o<a;++o){const l=i[o].slice(),h=l[l.length-1];if(r!==0)for(let u=0,d=l.length;u<d;++u)l[u]-=r;const c=new gi(e.slice(r,h),t,l);s.push(c),r=h}return s}getType(){return"MultiPolygon"}intersectsExtent(t){return Wg(this.getOrientedFlatCoordinates(),0,this.endss_,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,3),this.flatCoordinates||(this.flatCoordinates=[]);const i=kg(this.flatCoordinates,0,t,this.stride,this.endss_);if(i.length===0)this.flatCoordinates.length=0;else{const s=i[i.length-1];this.flatCoordinates.length=s.length===0?0:s[s.length-1]}this.changed()}}const Ac=ae();class Ht{constructor(t,e,i,s,r,o){this.styleFunction,this.extent_,this.id_=o,this.type_=t,this.flatCoordinates_=e,this.flatInteriorPoints_=null,this.flatMidpoints_=null,this.ends_=i||null,this.properties_=r,this.squaredTolerance_,this.stride_=s,this.simplifiedGeometry_}get(t){return this.properties_[t]}getExtent(){return this.extent_||(this.extent_=this.type_==="Point"?yh(this.flatCoordinates_):bo(this.flatCoordinates_,0,this.flatCoordinates_.length,2)),this.extent_}getFlatInteriorPoint(){if(!this.flatInteriorPoints_){const t=Di(this.getExtent());this.flatInteriorPoints_=ra(this.flatCoordinates_,0,this.ends_,2,t,0)}return this.flatInteriorPoints_}getFlatInteriorPoints(){if(!this.flatInteriorPoints_){const t=rc(this.flatCoordinates_,this.ends_),e=Lc(this.flatCoordinates_,0,t,2);this.flatInteriorPoints_=Qh(this.flatCoordinates_,0,t,2,e)}return this.flatInteriorPoints_}getFlatMidpoint(){return this.flatMidpoints_||(this.flatMidpoints_=Sr(this.flatCoordinates_,0,this.flatCoordinates_.length,2,.5)),this.flatMidpoints_}getFlatMidpoints(){if(!this.flatMidpoints_){this.flatMidpoints_=[];const t=this.flatCoordinates_;let e=0;const i=this.ends_;for(let s=0,r=i.length;s<r;++s){const o=i[s],a=Sr(t,e,o,2,.5);Re(this.flatMidpoints_,a),e=o}}return this.flatMidpoints_}getId(){return this.id_}getOrientedFlatCoordinates(){return this.flatCoordinates_}getGeometry(){return this}getSimplifiedGeometry(t){return this}simplifyTransformed(t,e){return this}getProperties(){return this.properties_}getPropertiesInternal(){return this.properties_}getStride(){return this.stride_}getStyleFunction(){return this.styleFunction}getType(){return this.type_}transform(t){t=ft(t);const e=t.getExtent(),i=t.getWorldExtent();if(e&&i){const s=Ot(i)/Ot(e);Xe(Ac,i[0],i[3],s,-s,0,0,0),di(this.flatCoordinates_,0,this.flatCoordinates_.length,2,Ac,this.flatCoordinates_)}}applyTransform(t){t(this.flatCoordinates_,this.flatCoordinates_,this.stride_)}clone(){return new Ht(this.type_,this.flatCoordinates_.slice(),this.ends_?.slice(),this.stride_,Object.assign({},this.properties_),this.id_)}getEnds(){return this.ends_}enableSimplifyTransformed(){return this.simplifyTransformed=gh((t,e)=>{if(t===this.squaredTolerance_)return this.simplifiedGeometry_;this.simplifiedGeometry_=this.clone(),e&&this.simplifiedGeometry_.applyTransform(e);const i=this.simplifiedGeometry_.getFlatCoordinates();let s;switch(this.type_){case"LineString":i.length=Tr(i,0,this.simplifiedGeometry_.flatCoordinates_.length,this.simplifiedGeometry_.stride_,t,i,0),s=[i.length];break;case"MultiLineString":s=[],i.length=Jh(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,t,i,0,s);break;case"Polygon":s=[],i.length=na(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,Math.sqrt(t),i,0,s);break}return s&&(this.simplifiedGeometry_=new Ht(this.type_,i,s,2,this.properties_,this.id_)),this.squaredTolerance_=t,this.simplifiedGeometry_}),this}}Ht.prototype.getFlatCoordinates=Ht.prototype.getOrientedFlatCoordinates;function Pc(n,t,e=0,i=n.length-1,s=O_){for(;i>e;){if(i-e>600){const l=i-e+1,h=t-e+1,c=Math.log(l),u=.5*Math.exp(2*c/3),d=.5*Math.sqrt(c*u*(l-u)/l)*(h-l/2<0?-1:1),f=Math.max(e,Math.floor(t-h*u/l+d)),g=Math.min(i,Math.floor(t+(l-h)*u/l+d));Pc(n,t,f,g,s)}const r=n[t];let o=e,a=i;for(_s(n,e,t),s(n[i],r)>0&&_s(n,e,i);o<a;){for(_s(n,o,a),o++,a--;s(n[o],r)<0;)o++;for(;s(n[a],r)>0;)a--}s(n[e],r)===0?_s(n,e,a):(a++,_s(n,a,i)),a<=t&&(e=a+1),t<=a&&(i=a-1)}}function _s(n,t,e){const i=n[t];n[t]=n[e],n[e]=i}function O_(n,t){return n<t?-1:n>t?1:0}let Mc=class{constructor(t=9){this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(this._maxEntries*.4)),this.clear()}all(){return this._all(this.data,[])}search(t){let e=this.data;const i=[];if(!Gr(t,e))return i;const s=this.toBBox,r=[];for(;e;){for(let o=0;o<e.children.length;o++){const a=e.children[o],l=e.leaf?s(a):a;Gr(t,l)&&(e.leaf?i.push(a):Ia(t,l)?this._all(a,i):r.push(a))}e=r.pop()}return i}collides(t){let e=this.data;if(!Gr(t,e))return!1;const i=[];for(;e;){for(let s=0;s<e.children.length;s++){const r=e.children[s],o=e.leaf?this.toBBox(r):r;if(Gr(t,o)){if(e.leaf||Ia(t,o))return!0;i.push(r)}}e=i.pop()}return!1}load(t){if(!(t&&t.length))return this;if(t.length<this._minEntries){for(let i=0;i<t.length;i++)this.insert(t[i]);return this}let e=this._build(t.slice(),0,t.length-1,0);if(!this.data.children.length)this.data=e;else if(this.data.height===e.height)this._splitRoot(this.data,e);else{if(this.data.height<e.height){const i=this.data;this.data=e,e=i}this._insert(e,this.data.height-e.height-1,!0)}return this}insert(t){return t&&this._insert(t,this.data.height-1),this}clear(){return this.data=En([]),this}remove(t,e){if(!t)return this;let i=this.data;const s=this.toBBox(t),r=[],o=[];let a,l,h;for(;i||r.length;){if(i||(i=r.pop(),l=r[r.length-1],a=o.pop(),h=!0),i.leaf){const c=D_(t,i.children,e);if(c!==-1)return i.children.splice(c,1),r.push(i),this._condense(r),this}!h&&!i.leaf&&Ia(i,s)?(r.push(i),o.push(a),a=0,l=i,i=i.children[0]):l?(a++,i=l.children[a],h=!1):i=null}return this}toBBox(t){return t}compareMinX(t,e){return t.minX-e.minX}compareMinY(t,e){return t.minY-e.minY}toJSON(){return this.data}fromJSON(t){return this.data=t,this}_all(t,e){const i=[];for(;t;)t.leaf?e.push(...t.children):i.push(...t.children),t=i.pop();return e}_build(t,e,i,s){const r=i-e+1;let o=this._maxEntries,a;if(r<=o)return a=En(t.slice(e,i+1)),xn(a,this.toBBox),a;s||(s=Math.ceil(Math.log(r)/Math.log(o)),o=Math.ceil(r/Math.pow(o,s-1))),a=En([]),a.leaf=!1,a.height=s;const l=Math.ceil(r/o),h=l*Math.ceil(Math.sqrt(o));Fc(t,e,i,h,this.compareMinX);for(let c=e;c<=i;c+=h){const u=Math.min(c+h-1,i);Fc(t,c,u,l,this.compareMinY);for(let d=c;d<=u;d+=l){const f=Math.min(d+l-1,u);a.children.push(this._build(t,d,f,s-1))}}return xn(a,this.toBBox),a}_chooseSubtree(t,e,i,s){for(;s.push(e),!(e.leaf||s.length-1===i);){let r=1/0,o=1/0,a;for(let l=0;l<e.children.length;l++){const h=e.children[l],c=Sa(h),u=G_(t,h)-c;u<o?(o=u,r=c<r?c:r,a=h):u===o&&c<r&&(r=c,a=h)}e=a||e.children[0]}return e}_insert(t,e,i){const s=i?t:this.toBBox(t),r=[],o=this._chooseSubtree(s,this.data,e,r);for(o.children.push(t),ps(o,s);e>=0&&r[e].children.length>this._maxEntries;)this._split(r,e),e--;this._adjustParentBBoxes(s,r,e)}_split(t,e){const i=t[e],s=i.children.length,r=this._minEntries;this._chooseSplitAxis(i,r,s);const o=this._chooseSplitIndex(i,r,s),a=En(i.children.splice(o,i.children.length-o));a.height=i.height,a.leaf=i.leaf,xn(i,this.toBBox),xn(a,this.toBBox),e?t[e-1].children.push(a):this._splitRoot(i,a)}_splitRoot(t,e){this.data=En([t,e]),this.data.height=t.height+1,this.data.leaf=!1,xn(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let s,r=1/0,o=1/0;for(let a=e;a<=i-e;a++){const l=ms(t,0,a,this.toBBox),h=ms(t,a,i,this.toBBox),c=z_(l,h),u=Sa(l)+Sa(h);c<r?(r=c,s=a,o=u<o?u:o):c===r&&u<o&&(o=u,s=a)}return s||i-e}_chooseSplitAxis(t,e,i){const s=t.leaf?this.compareMinX:k_,r=t.leaf?this.compareMinY:N_,o=this._allDistMargin(t,e,i,s),a=this._allDistMargin(t,e,i,r);o<a&&t.children.sort(s)}_allDistMargin(t,e,i,s){t.children.sort(s);const r=this.toBBox,o=ms(t,0,e,r),a=ms(t,i-e,i,r);let l=Nr(o)+Nr(a);for(let h=e;h<i-e;h++){const c=t.children[h];ps(o,t.leaf?r(c):c),l+=Nr(o)}for(let h=i-e-1;h>=e;h--){const c=t.children[h];ps(a,t.leaf?r(c):c),l+=Nr(a)}return l}_adjustParentBBoxes(t,e,i){for(let s=i;s>=0;s--)ps(e[s],t)}_condense(t){for(let e=t.length-1,i;e>=0;e--)t[e].children.length===0?e>0?(i=t[e-1].children,i.splice(i.indexOf(t[e]),1)):this.clear():xn(t[e],this.toBBox)}};function D_(n,t,e){if(!e)return t.indexOf(n);for(let i=0;i<t.length;i++)if(e(n,t[i]))return i;return-1}function xn(n,t){ms(n,0,n.children.length,t,n)}function ms(n,t,e,i,s){s||(s=En(null)),s.minX=1/0,s.minY=1/0,s.maxX=-1/0,s.maxY=-1/0;for(let r=t;r<e;r++){const o=n.children[r];ps(s,n.leaf?i(o):o)}return s}function ps(n,t){return n.minX=Math.min(n.minX,t.minX),n.minY=Math.min(n.minY,t.minY),n.maxX=Math.max(n.maxX,t.maxX),n.maxY=Math.max(n.maxY,t.maxY),n}function k_(n,t){return n.minX-t.minX}function N_(n,t){return n.minY-t.minY}function Sa(n){return(n.maxX-n.minX)*(n.maxY-n.minY)}function Nr(n){return n.maxX-n.minX+(n.maxY-n.minY)}function G_(n,t){return(Math.max(t.maxX,n.maxX)-Math.min(t.minX,n.minX))*(Math.max(t.maxY,n.maxY)-Math.min(t.minY,n.minY))}function z_(n,t){const e=Math.max(n.minX,t.minX),i=Math.max(n.minY,t.minY),s=Math.min(n.maxX,t.maxX),r=Math.min(n.maxY,t.maxY);return Math.max(0,s-e)*Math.max(0,r-i)}function Ia(n,t){return n.minX<=t.minX&&n.minY<=t.minY&&t.maxX<=n.maxX&&t.maxY<=n.maxY}function Gr(n,t){return t.minX<=n.maxX&&t.minY<=n.maxY&&t.maxX>=n.minX&&t.maxY>=n.minY}function En(n){return{children:n,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function Fc(n,t,e,i,s){const r=[t,e];for(;r.length;){if(e=r.pop(),t=r.pop(),e-t<=i)continue;const o=t+Math.ceil((e-t)/i/2)*i;Pc(n,o,t,e,s),r.push(t,o,o,e)}}class Oc{constructor(t){this.rbush_=new Mc(t),this.items_={}}insert(t,e){const i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[B(e)]=i}load(t,e){const i=new Array(e.length);for(let s=0,r=e.length;s<r;s++){const o=t[s],a=e[s],l={minX:o[0],minY:o[1],maxX:o[2],maxY:o[3],value:a};i[s]=l,this.items_[B(a)]=l}this.rbush_.load(i)}remove(t){const e=B(t),i=this.items_[e];return delete this.items_[e],this.rbush_.remove(i)!==null}update(t,e){const i=this.items_[B(e)],s=[i.minX,i.minY,i.maxX,i.maxY];ln(s,t)||(this.remove(e),this.insert(t,e))}getAll(){return this.rbush_.all().map(function(e){return e.value})}getInExtent(t){const e={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3]};return this.rbush_.search(e).map(function(s){return s.value})}forEach(t){return this.forEach_(this.getAll(),t)}forEachInExtent(t,e){return this.forEach_(this.getInExtent(t),e)}forEach_(t,e){let i;for(let s=0,r=t.length;s<r;s++)if(i=e(t[s]),i)return i;return i}isEmpty(){return Fi(this.items_)}clear(){this.rbush_.clear(),this.items_={}}getExtent(t){const e=this.rbush_.toJSON();return Ne(e.minX,e.minY,e.maxX,e.maxY,t)}concat(t){this.rbush_.load(t.rbush_.all());for(const e in t.items_)this.items_[e]=t.items_[e]}}class Dc extends ye{constructor(t){super(),this.projection=ft(t.projection),this.attributions_=kc(t.attributions),this.attributionsCollapsible_=t.attributionsCollapsible??!0,this.loading=!1,this.state_=t.state!==void 0?t.state:"ready",this.wrapX_=t.wrapX!==void 0?t.wrapX:!1,this.interpolate_=!!t.interpolate,this.viewResolver=null,this.viewRejector=null;const e=this;this.viewPromise_=new Promise(function(i,s){e.viewResolver=i,e.viewRejector=s})}getAttributions(){return this.attributions_}getAttributionsCollapsible(){return this.attributionsCollapsible_}getProjection(){return this.projection}getResolutions(t){return null}getView(){return this.viewPromise_}getState(){return this.state_}getWrapX(){return this.wrapX_}getInterpolate(){return this.interpolate_}refresh(){this.changed()}setAttributions(t){this.attributions_=kc(t),this.changed()}setState(t){this.state_=t,this.changed()}}function kc(n){return n?typeof n=="function"?n:(Array.isArray(n)||(n=[n]),t=>n):null}const ce={ADDFEATURE:"addfeature",CHANGEFEATURE:"changefeature",CLEAR:"clear",REMOVEFEATURE:"removefeature",FEATURESLOADSTART:"featuresloadstart",FEATURESLOADEND:"featuresloadend",FEATURESLOADERROR:"featuresloaderror"};class mi extends ke{constructor(t,e,i){super(t),this.feature=e,this.features=i}}class X_ extends Dc{constructor(t){t=t||{},super({attributions:t.attributions,interpolate:!0,projection:void 0,state:"ready",wrapX:t.wrapX!==void 0?t.wrapX:!0}),this.on,this.once,this.un,this.loader_=Zn,this.format_=t.format||null,this.overlaps_=t.overlaps===void 0?!0:t.overlaps,this.url_=t.url,t.loader!==void 0?this.loader_=t.loader:this.url_!==void 0&&(J(this.format_,"`format` must be set when `url` is set"),this.loader_=bc(this.url_,this.format_)),this.strategy_=t.strategy!==void 0?t.strategy:F_;const e=t.useSpatialIndex!==void 0?t.useSpatialIndex:!0;this.featuresRtree_=e?new Oc:null,this.loadedExtentsRtree_=new Oc,this.loadingExtentsCount_=0,this.nullGeometryFeatures_={},this.idIndex_={},this.uidIndex_={},this.featureChangeKeys_={},this.featuresCollection_=null;let i,s;Array.isArray(t.features)?s=t.features:t.features&&(i=t.features,s=i.getArray()),!e&&i===void 0&&(i=new re(s)),s!==void 0&&this.addFeaturesInternal(s),i!==void 0&&this.bindFeaturesCollection_(i)}addFeature(t){this.addFeatureInternal(t),this.changed()}addFeatureInternal(t){const e=B(t);if(!this.addToIndex_(e,t)){this.featuresCollection_&&this.featuresCollection_.remove(t);return}this.setupChangeEvents_(e,t);const i=t.getGeometry();if(i){const s=i.getExtent();this.featuresRtree_&&this.featuresRtree_.insert(s,t)}else this.nullGeometryFeatures_[e]=t;this.dispatchEvent(new mi(ce.ADDFEATURE,t))}setupChangeEvents_(t,e){e instanceof Ht||(this.featureChangeKeys_[t]=[H(e,V.CHANGE,this.handleFeatureChange_,this),H(e,rn.PROPERTYCHANGE,this.handleFeatureChange_,this)])}addToIndex_(t,e){let i=!0;if(e.getId()!==void 0){const s=String(e.getId());if(!(s in this.idIndex_))this.idIndex_[s]=e;else if(e instanceof Ht){const r=this.idIndex_[s];r instanceof Ht?Array.isArray(r)?r.push(e):this.idIndex_[s]=[r,e]:i=!1}else i=!1}return i&&(J(!(t in this.uidIndex_),"The passed `feature` was already added to the source"),this.uidIndex_[t]=e),i}addFeatures(t){this.addFeaturesInternal(t),this.changed()}addFeaturesInternal(t){const e=[],i=[],s=[];for(let r=0,o=t.length;r<o;r++){const a=t[r],l=B(a);this.addToIndex_(l,a)&&i.push(a)}for(let r=0,o=i.length;r<o;r++){const a=i[r],l=B(a);this.setupChangeEvents_(l,a);const h=a.getGeometry();if(h){const c=h.getExtent();e.push(c),s.push(a)}else this.nullGeometryFeatures_[l]=a}if(this.featuresRtree_&&this.featuresRtree_.load(e,s),this.hasListener(ce.ADDFEATURE))for(let r=0,o=i.length;r<o;r++)this.dispatchEvent(new mi(ce.ADDFEATURE,i[r]))}bindFeaturesCollection_(t){let e=!1;this.addEventListener(ce.ADDFEATURE,function(i){e||(e=!0,t.push(i.feature),e=!1)}),this.addEventListener(ce.REMOVEFEATURE,function(i){e||(e=!0,t.remove(i.feature),e=!1)}),t.addEventListener(Xt.ADD,i=>{e||(e=!0,this.addFeature(i.element),e=!1)}),t.addEventListener(Xt.REMOVE,i=>{e||(e=!0,this.removeFeature(i.element),e=!1)}),this.featuresCollection_=t}clear(t){if(t){for(const i in this.featureChangeKeys_)this.featureChangeKeys_[i].forEach(nt);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){this.featuresRtree_.forEach(i=>{this.removeFeatureInternal(i)});for(const i in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[i])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};const e=new mi(ce.CLEAR);this.dispatchEvent(e),this.changed()}forEachFeature(t){if(this.featuresRtree_)return this.featuresRtree_.forEach(t);this.featuresCollection_&&this.featuresCollection_.forEach(t)}forEachFeatureAtCoordinateDirect(t,e){const i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,function(s){const r=s.getGeometry();if(r instanceof Ht||r.intersectsCoordinate(t))return e(s)})}forEachFeatureInExtent(t,e){if(this.featuresRtree_)return this.featuresRtree_.forEachInExtent(t,e);this.featuresCollection_&&this.featuresCollection_.forEach(e)}forEachFeatureIntersectingExtent(t,e){return this.forEachFeatureInExtent(t,function(i){const s=i.getGeometry();if(s instanceof Ht||s.intersectsExtent(t)){const r=e(i);if(r)return r}})}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),Fi(this.nullGeometryFeatures_)||Re(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){const e=[];return this.forEachFeatureAtCoordinateDirect(t,function(i){e.push(i)}),e}getFeaturesInExtent(t,e){if(this.featuresRtree_){if(!(e&&e.canWrapX()&&this.getWrapX()))return this.featuresRtree_.getInExtent(t);const s=Th(t,e);return[].concat(...s.map(r=>this.featuresRtree_.getInExtent(r)))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){const i=t[0],s=t[1];let r=null;const o=[NaN,NaN];let a=1/0;const l=[-1/0,-1/0,1/0,1/0];return e=e||Un,this.featuresRtree_.forEachInExtent(l,function(h){if(e(h)){const c=h.getGeometry(),u=a;if(a=c instanceof Ht?0:c.closestPointXY(i,s,o,a),a<u){r=h;const d=Math.sqrt(a);l[0]=i-d,l[1]=s-d,l[2]=i+d,l[3]=s+d}}}),r}getExtent(t){return this.featuresRtree_.getExtent(t)}getFeatureById(t){const e=this.idIndex_[t.toString()];return e!==void 0?e:null}getFeatureByUid(t){const e=this.uidIndex_[t];return e!==void 0?e:null}getFormat(){return this.format_}getOverlaps(){return this.overlaps_}getUrl(){return this.url_}handleFeatureChange_(t){const e=t.target,i=B(e),s=e.getGeometry();if(!s)i in this.nullGeometryFeatures_||(this.featuresRtree_&&this.featuresRtree_.remove(e),this.nullGeometryFeatures_[i]=e);else{const o=s.getExtent();i in this.nullGeometryFeatures_?(delete this.nullGeometryFeatures_[i],this.featuresRtree_&&this.featuresRtree_.insert(o,e)):this.featuresRtree_&&this.featuresRtree_.update(o,e)}const r=e.getId();if(r!==void 0){const o=r.toString();this.idIndex_[o]!==e&&(this.removeFromIdIndex_(e),this.idIndex_[o]=e)}else this.removeFromIdIndex_(e),this.uidIndex_[i]=e;this.changed(),this.dispatchEvent(new mi(ce.CHANGEFEATURE,e))}hasFeature(t){const e=t.getId();return e!==void 0?e in this.idIndex_:B(t)in this.uidIndex_}isEmpty(){return this.featuresRtree_?this.featuresRtree_.isEmpty()&&Fi(this.nullGeometryFeatures_):this.featuresCollection_?this.featuresCollection_.getLength()===0:!0}loadFeatures(t,e,i){const s=this.loadedExtentsRtree_,r=this.strategy_(t,e,i);for(let o=0,a=r.length;o<a;++o){const l=r[o];s.forEachInExtent(l,function(c){return Oi(c.extent,l)})||(++this.loadingExtentsCount_,this.dispatchEvent(new mi(ce.FEATURESLOADSTART)),this.loader_.call(this,l,e,i,c=>{--this.loadingExtentsCount_,this.dispatchEvent(new mi(ce.FEATURESLOADEND,void 0,c))},()=>{--this.loadingExtentsCount_,this.dispatchEvent(new mi(ce.FEATURESLOADERROR))}),s.insert(l,{extent:l.slice()}))}this.loading=this.loader_.length<4?!1:this.loadingExtentsCount_>0}refresh(){this.clear(!0),this.loadedExtentsRtree_.clear(),super.refresh()}removeLoadedExtent(t){const e=this.loadedExtentsRtree_,i=e.forEachInExtent(t,function(s){if(ln(s.extent,t))return s});i&&e.remove(i)}removeFeatures(t){let e=!1;for(let i=0,s=t.length;i<s;++i)e=this.removeFeatureInternal(t[i])||e;e&&this.changed()}removeFeature(t){if(!t)return;this.removeFeatureInternal(t)&&this.changed()}removeFeatureInternal(t){const e=B(t);if(!(e in this.uidIndex_))return!1;e in this.nullGeometryFeatures_?delete this.nullGeometryFeatures_[e]:this.featuresRtree_&&this.featuresRtree_.remove(t),this.featureChangeKeys_[e]?.forEach(nt),delete this.featureChangeKeys_[e];const s=t.getId();if(s!==void 0){const r=s.toString(),o=this.idIndex_[r];o===t?delete this.idIndex_[r]:Array.isArray(o)&&(o.splice(o.indexOf(t),1),o.length===1&&(this.idIndex_[r]=o[0]))}return delete this.uidIndex_[e],this.hasListener(ce.REMOVEFEATURE)&&this.dispatchEvent(new mi(ce.REMOVEFEATURE,t)),!0}removeFromIdIndex_(t){for(const e in this.idIndex_)if(this.idIndex_[e]===t){delete this.idIndex_[e];break}}setLoader(t){this.loader_=t}setUrl(t){J(this.format_,"`format` must be set when `url` is set"),this.url_=t,this.setLoader(bc(t,this.format_))}setOverlaps(t){this.overlaps_=t,this.changed()}}class qt{constructor(t){t=t||{},this.patternImage_=null,this.color_=null,t.color!==void 0&&this.setColor(t.color)}clone(){const t=this.getColor();return new qt({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){if(t!==null&&typeof t=="object"&&"src"in t){const e=Lr(null,t.src,"anonymous",void 0,t.offset?null:t.color?t.color:null,!(t.offset&&t.size));e.ready().then(()=>{this.patternImage_=null}),e.getImageState()===$.IDLE&&e.load(),e.getImageState()===$.LOADING&&(this.patternImage_=e)}this.color_=t}getKey(){const t=this.getColor();return t?t instanceof CanvasPattern||t instanceof CanvasGradient?B(t):typeof t=="object"&&"src"in t?t.src+":"+t.offset:_n(t).toString():""}loading(){return!!this.patternImage_}ready(){return this.patternImage_?this.patternImage_.ready():Promise.resolve()}}class xe{constructor(t){t=t||{},this.color_=t.color!==void 0?t.color:null,this.lineCap_=t.lineCap,this.lineDash_=t.lineDash!==void 0?t.lineDash:null,this.lineDashOffset_=t.lineDashOffset,this.lineJoin_=t.lineJoin,this.miterLimit_=t.miterLimit,this.width_=t.width}clone(){const t=this.getColor();return new xe({color:Array.isArray(t)?t.slice():t||void 0,lineCap:this.getLineCap(),lineDash:this.getLineDash()?this.getLineDash().slice():void 0,lineDashOffset:this.getLineDashOffset(),lineJoin:this.getLineJoin(),miterLimit:this.getMiterLimit(),width:this.getWidth()})}getColor(){return this.color_}getLineCap(){return this.lineCap_}getLineDash(){return this.lineDash_}getLineDashOffset(){return this.lineDashOffset_}getLineJoin(){return this.lineJoin_}getMiterLimit(){return this.miterLimit_}getWidth(){return this.width_}setColor(t){this.color_=t}setLineCap(t){this.lineCap_=t}setLineDash(t){this.lineDash_=t}setLineDashOffset(t){this.lineDashOffset_=t}setLineJoin(t){this.lineJoin_=t}setMiterLimit(t){this.miterLimit_=t}setWidth(t){this.width_=t}}function Nc(n){return n[0]>0&&n[1]>0}function Y_(n,t,e){return e===void 0&&(e=[0,0]),e[0]=n[0]*t+.5|0,e[1]=n[1]*t+.5|0,e}function Rt(n,t){return Array.isArray(n)?n:(t===void 0?t=[n,n]:(t[0]=n,t[1]=n),t)}class zr{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=Rt(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new zr({opacity:this.getOpacity(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getOpacity(){return this.opacity_}getRotateWithView(){return this.rotateWithView_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getDisplacement(){return this.displacement_}getDeclutterMode(){return this.declutterMode_}getAnchor(){return j()}getImage(t){return j()}getHitDetectionImage(){return j()}getPixelRatio(t){return 1}getImageState(){return j()}getImageSize(){return j()}getOrigin(){return j()}getSize(){return j()}setDisplacement(t){this.displacement_=t}setOpacity(t){this.opacity_=t}setRotateWithView(t){this.rotateWithView_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=Rt(t)}listenImageChange(t){j()}load(){j()}unlistenImageChange(t){j()}ready(){return Promise.resolve()}}class Xr extends zr{constructor(t){super({opacity:1,rotateWithView:t.rotateWithView!==void 0?t.rotateWithView:!1,rotation:t.rotation!==void 0?t.rotation:0,scale:t.scale!==void 0?t.scale:1,displacement:t.displacement!==void 0?t.displacement:[0,0],declutterMode:t.declutterMode}),this.hitDetectionCanvas_=null,this.fill_=t.fill!==void 0?t.fill:null,this.origin_=[0,0],this.points_=t.points,this.radius=t.radius,this.radius2_=t.radius2,this.angle_=t.angle!==void 0?t.angle:0,this.stroke_=t.stroke!==void 0?t.stroke:null,this.size_,this.renderOptions_,this.imageState_=this.fill_&&this.fill_.loading()?$.LOADING:$.LOADED,this.imageState_===$.LOADING&&this.ready().then(()=>this.imageState_=$.LOADED),this.render()}clone(){const t=this.getScale(),e=new Xr({fill:this.getFill()?this.getFill().clone():void 0,points:this.getPoints(),radius:this.getRadius(),radius2:this.getRadius2(),angle:this.getAngle(),stroke:this.getStroke()?this.getStroke().clone():void 0,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),scale:Array.isArray(t)?t.slice():t,displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}getAnchor(){const t=this.size_,e=this.getDisplacement(),i=this.getScaleArray();return[t[0]/2-e[0]/i[0],t[1]/2+e[1]/i[1]]}getAngle(){return this.angle_}getFill(){return this.fill_}setFill(t){this.fill_=t,this.render()}getHitDetectionImage(){return this.hitDetectionCanvas_||(this.hitDetectionCanvas_=this.createHitDetectionCanvas_(this.renderOptions_)),this.hitDetectionCanvas_}getImage(t){const e=this.fill_?.getKey(),i=`${t},${this.angle_},${this.radius},${this.radius2_},${this.points_},${e}`+Object.values(this.renderOptions_).join(",");let s=he.get(i,null,null)?.getImage(1);if(!s){const r=this.renderOptions_,o=Math.ceil(r.size*t),a=ut(o,o);this.draw_(r,a,t),s=a.canvas,he.set(i,null,null,new _c(s,void 0,null,$.LOADED,null))}return s}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return this.imageState_}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius}getRadius2(){return this.radius2_}getSize(){return this.size_}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t,this.render()}listenImageChange(t){}load(){}unlistenImageChange(t){}calculateLineJoinSize_(t,e,i){if(e===0||this.points_===1/0||t!=="bevel"&&t!=="miter")return e;let s=this.radius,r=this.radius2_===void 0?s:this.radius2_;if(s<r){const C=s;s=r,r=C}const o=this.radius2_===void 0?this.points_:this.points_*2,a=2*Math.PI/o,l=r*Math.sin(a),h=Math.sqrt(r*r-l*l),c=s-h,u=Math.sqrt(l*l+c*c),d=u/l;if(t==="miter"&&d<=i)return d*e;const f=e/2/d,g=e/2*(c/u),_=Math.sqrt((s+f)*(s+f)+g*g)-s;if(this.radius2_===void 0||t==="bevel")return _*2;const p=s*Math.sin(a),y=Math.sqrt(s*s-p*p),w=r-y,E=Math.sqrt(p*p+w*w)/p;if(E<=i){const C=E*e/2-r-s;return 2*Math.max(_,C)}return _*2}createRenderOptions(){let t=mn,e=pn,i=0,s=null,r=0,o,a=0;this.stroke_&&(o=Se(this.stroke_.getColor()??us),a=this.stroke_.getWidth()??fs,s=this.stroke_.getLineDash(),r=this.stroke_.getLineDashOffset()??0,e=this.stroke_.getLineJoin()??pn,t=this.stroke_.getLineCap()??mn,i=this.stroke_.getMiterLimit()??cs);const l=this.calculateLineJoinSize_(e,a,i),h=Math.max(this.radius,this.radius2_||0),c=Math.ceil(2*h+l);return{strokeStyle:o,strokeWidth:a,size:c,lineCap:t,lineDash:s,lineDashOffset:r,lineJoin:e,miterLimit:i}}render(){this.renderOptions_=this.createRenderOptions();const t=this.renderOptions_.size;this.hitDetectionCanvas_=null,this.size_=[t,t]}draw_(t,e,i){if(e.scale(i,i),e.translate(t.size/2,t.size/2),this.createPath_(e),this.fill_){let s=this.fill_.getColor();s===null&&(s=Yt),e.fillStyle=Se(s),e.fill()}t.strokeStyle&&(e.strokeStyle=t.strokeStyle,e.lineWidth=t.strokeWidth,t.lineDash&&(e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset),e.lineCap=t.lineCap,e.lineJoin=t.lineJoin,e.miterLimit=t.miterLimit,e.stroke())}createHitDetectionCanvas_(t){let e;if(this.fill_){let i=this.fill_.getColor(),s=0;typeof i=="string"&&(i=_n(i)),i===null?s=1:Array.isArray(i)&&(s=i.length===4?i[3]:1),s===0&&(e=ut(t.size,t.size),this.drawHitDetectionCanvas_(t,e))}return e?e.canvas:this.getImage(1)}createPath_(t){let e=this.points_;const i=this.radius;if(e===1/0)t.arc(0,0,i,0,2*Math.PI);else{const s=this.radius2_===void 0?i:this.radius2_;this.radius2_!==void 0&&(e*=2);const r=this.angle_-Math.PI/2,o=2*Math.PI/e;for(let a=0;a<e;a++){const l=r+a*o,h=a%2===0?i:s;t.lineTo(h*Math.cos(l),h*Math.sin(l))}t.closePath()}}drawHitDetectionCanvas_(t,e){e.translate(t.size/2,t.size/2),this.createPath_(e),e.fillStyle=Yt,e.fill(),t.strokeStyle&&(e.strokeStyle=t.strokeStyle,e.lineWidth=t.strokeWidth,t.lineDash&&(e.setLineDash(t.lineDash),e.lineDashOffset=t.lineDashOffset),e.lineJoin=t.lineJoin,e.miterLimit=t.miterLimit,e.stroke())}ready(){return this.fill_?this.fill_.ready():Promise.resolve()}}class Yr extends Xr{constructor(t){t=t||{radius:5},super({points:1/0,fill:t.fill,radius:t.radius,stroke:t.stroke,scale:t.scale!==void 0?t.scale:1,rotation:t.rotation!==void 0?t.rotation:0,rotateWithView:t.rotateWithView!==void 0?t.rotateWithView:!1,displacement:t.displacement!==void 0?t.displacement:[0,0],declutterMode:t.declutterMode})}clone(){const t=this.getScale(),e=new Yr({fill:this.getFill()?this.getFill().clone():void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,radius:this.getRadius(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}setRadius(t){this.radius=t,this.render()}}class _t{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=zc,t.geometry!==void 0&&this.setGeometry(t.geometry),this.fill_=t.fill!==void 0?t.fill:null,this.image_=t.image!==void 0?t.image:null,this.renderer_=t.renderer!==void 0?t.renderer:null,this.hitDetectionRenderer_=t.hitDetectionRenderer!==void 0?t.hitDetectionRenderer:null,this.stroke_=t.stroke!==void 0?t.stroke:null,this.text_=t.text!==void 0?t.text:null,this.zIndex_=t.zIndex}clone(){let t=this.getGeometry();return t&&typeof t=="object"&&(t=t.clone()),new _t({geometry:t??void 0,fill:this.getFill()?this.getFill().clone():void 0,image:this.getImage()?this.getImage().clone():void 0,renderer:this.getRenderer()??void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,text:this.getText()?this.getText().clone():void 0,zIndex:this.getZIndex()})}getRenderer(){return this.renderer_}setRenderer(t){this.renderer_=t}setHitDetectionRenderer(t){this.hitDetectionRenderer_=t}getHitDetectionRenderer(){return this.hitDetectionRenderer_}getGeometry(){return this.geometry_}getGeometryFunction(){return this.geometryFunction_}getFill(){return this.fill_}setFill(t){this.fill_=t}getImage(){return this.image_}setImage(t){this.image_=t}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t}getText(){return this.text_}setText(t){this.text_=t}getZIndex(){return this.zIndex_}setGeometry(t){typeof t=="function"?this.geometryFunction_=t:typeof t=="string"?this.geometryFunction_=function(e){return e.get(t)}:t?t!==void 0&&(this.geometryFunction_=function(){return t}):this.geometryFunction_=zc,this.geometry_=t}setZIndex(t){this.zIndex_=t}}function W_(n){let t;if(typeof n=="function")t=n;else{let e;Array.isArray(n)?e=n:(J(typeof n.getZIndex=="function","Expected an `Style` or an array of `Style`"),e=[n]),t=function(){return e}}return t}let ba=null;function Gc(n,t){if(!ba){const e=new qt({color:"rgba(255,255,255,0.4)"}),i=new xe({color:"#3399CC",width:1.25});ba=[new _t({image:new Yr({fill:e,stroke:i,radius:5}),fill:e,stroke:i})]}return ba}function zc(n){return n.getGeometry()}const V_="#333";let Xc=class ed{constructor(t){t=t||{},this.font_=t.font,this.rotation_=t.rotation,this.rotateWithView_=t.rotateWithView,this.keepUpright_=t.keepUpright,this.scale_=t.scale,this.scaleArray_=Rt(t.scale!==void 0?t.scale:1),this.text_=t.text,this.textAlign_=t.textAlign,this.justify_=t.justify,this.repeat_=t.repeat,this.textBaseline_=t.textBaseline,this.fill_=t.fill!==void 0?t.fill:new qt({color:V_}),this.maxAngle_=t.maxAngle!==void 0?t.maxAngle:Math.PI/4,this.placement_=t.placement!==void 0?t.placement:"point",this.overflow_=!!t.overflow,this.stroke_=t.stroke!==void 0?t.stroke:null,this.offsetX_=t.offsetX!==void 0?t.offsetX:0,this.offsetY_=t.offsetY!==void 0?t.offsetY:0,this.backgroundFill_=t.backgroundFill?t.backgroundFill:null,this.backgroundStroke_=t.backgroundStroke?t.backgroundStroke:null,this.padding_=t.padding===void 0?null:t.padding,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new ed({font:this.getFont(),placement:this.getPlacement(),repeat:this.getRepeat(),maxAngle:this.getMaxAngle(),overflow:this.getOverflow(),rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),keepUpright:this.getKeepUpright(),scale:Array.isArray(t)?t.slice():t,text:this.getText(),textAlign:this.getTextAlign(),justify:this.getJustify(),textBaseline:this.getTextBaseline(),fill:this.getFill()instanceof qt?this.getFill().clone():this.getFill(),stroke:this.getStroke()?this.getStroke().clone():void 0,offsetX:this.getOffsetX(),offsetY:this.getOffsetY(),backgroundFill:this.getBackgroundFill()?this.getBackgroundFill().clone():void 0,backgroundStroke:this.getBackgroundStroke()?this.getBackgroundStroke().clone():void 0,padding:this.getPadding()||void 0,declutterMode:this.getDeclutterMode()})}getOverflow(){return this.overflow_}getFont(){return this.font_}getMaxAngle(){return this.maxAngle_}getPlacement(){return this.placement_}getRepeat(){return this.repeat_}getOffsetX(){return this.offsetX_}getOffsetY(){return this.offsetY_}getFill(){return this.fill_}getRotateWithView(){return this.rotateWithView_}getKeepUpright(){return this.keepUpright_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getStroke(){return this.stroke_}getText(){return this.text_}getTextAlign(){return this.textAlign_}getJustify(){return this.justify_}getTextBaseline(){return this.textBaseline_}getBackgroundFill(){return this.backgroundFill_}getBackgroundStroke(){return this.backgroundStroke_}getPadding(){return this.padding_}getDeclutterMode(){return this.declutterMode_}setOverflow(t){this.overflow_=t}setFont(t){this.font_=t}setMaxAngle(t){this.maxAngle_=t}setOffsetX(t){this.offsetX_=t}setOffsetY(t){this.offsetY_=t}setPlacement(t){this.placement_=t}setRepeat(t){this.repeat_=t}setRotateWithView(t){this.rotateWithView_=t}setKeepUpright(t){this.keepUpright_=t}setFill(t){this.fill_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=Rt(t!==void 0?t:1)}setStroke(t){this.stroke_=t}setText(t){this.text_=t}setTextAlign(t){this.textAlign_=t}setJustify(t){this.justify_=t}setTextBaseline(t){this.textBaseline_=t}setBackgroundFill(t){this.backgroundFill_=t}setBackgroundStroke(t){this.backgroundStroke_=t}setPadding(t){this.padding_=t}};const at={ANIMATING:0,INTERACTING:1},G={BEGIN_GEOMETRY:0,BEGIN_PATH:1,CIRCLE:2,CLOSE_PATH:3,CUSTOM:4,DRAW_CHARS:5,DRAW_IMAGE:6,END_GEOMETRY:7,FILL:8,MOVE_TO_LINE_TO:9,SET_FILL_STYLE:10,SET_STROKE_STYLE:11,STROKE:12},Wr=[G.FILL],pi=[G.STROKE],Ki=[G.BEGIN_PATH],Yc=[G.CLOSE_PATH];class ys extends mc{constructor(t,e,i,s){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=s,this.maxLineWidth=0,this.resolution=i,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_=null,this.bufferedMaxExtent_=null,this.instructions=[],this.coordinates=[],this.tmpCoordinate_=[],this.hitDetectionInstructions=[],this.state={}}applyPixelRatio(t){const e=this.pixelRatio;return e==1?t:t.map(function(i){return i*e})}appendFlatPointCoordinates(t,e){const i=this.getBufferedMaxExtent(),s=this.tmpCoordinate_,r=this.coordinates;let o=r.length;for(let a=0,l=t.length;a<l;a+=e)s[0]=t[a],s[1]=t[a+1],an(i,s)&&(r[o++]=s[0],r[o++]=s[1]);return o}appendFlatLineCoordinates(t,e,i,s,r,o){const a=this.coordinates;let l=a.length;const h=this.getBufferedMaxExtent();o&&(e+=s);let c=t[e],u=t[e+1];const d=this.tmpCoordinate_;let f=!0,g,m,_;for(g=e+s;g<i;g+=s)d[0]=t[g],d[1]=t[g+1],_=Io(h,d),_!==m?(f&&(a[l++]=c,a[l++]=u,f=!1),a[l++]=d[0],a[l++]=d[1]):_===xt.INTERSECTING?(a[l++]=d[0],a[l++]=d[1],f=!1):f=!0,c=d[0],u=d[1],m=_;return(r&&f||g===e+s)&&(a[l++]=c,a[l++]=u),l}drawCustomCoordinates_(t,e,i,s,r){for(let o=0,a=i.length;o<a;++o){const l=i[o],h=this.appendFlatLineCoordinates(t,e,l,s,!1,!1);r.push(h),e=l}return e}drawCustom(t,e,i,s,r){this.beginGeometry(t,e,r);const o=t.getType(),a=t.getStride(),l=this.coordinates.length;let h,c,u,d,f;switch(o){case"MultiPolygon":h=t.getOrientedFlatCoordinates(),d=[];const g=t.getEndss();f=0;for(let m=0,_=g.length;m<_;++m){const p=[];f=this.drawCustomCoordinates_(h,f,g[m],a,p),d.push(p)}this.instructions.push([G.CUSTOM,l,d,t,i,ia,r]),this.hitDetectionInstructions.push([G.CUSTOM,l,d,t,s||i,ia,r]);break;case"Polygon":case"MultiLineString":u=[],h=o=="Polygon"?t.getOrientedFlatCoordinates():t.getFlatCoordinates(),f=this.drawCustomCoordinates_(h,0,t.getEnds(),a,u),this.instructions.push([G.CUSTOM,l,u,t,i,ss,r]),this.hitDetectionInstructions.push([G.CUSTOM,l,u,t,s||i,ss,r]);break;case"LineString":case"Circle":h=t.getFlatCoordinates(),c=this.appendFlatLineCoordinates(h,0,h.length,a,!1,!1),this.instructions.push([G.CUSTOM,l,c,t,i,fi,r]),this.hitDetectionInstructions.push([G.CUSTOM,l,c,t,s||i,fi,r]);break;case"MultiPoint":h=t.getFlatCoordinates(),c=this.appendFlatPointCoordinates(h,a),c>l&&(this.instructions.push([G.CUSTOM,l,c,t,i,fi,r]),this.hitDetectionInstructions.push([G.CUSTOM,l,c,t,s||i,fi,r]));break;case"Point":h=t.getFlatCoordinates(),this.coordinates.push(h[0],h[1]),c=this.coordinates.length,this.instructions.push([G.CUSTOM,l,c,t,i,void 0,r]),this.hitDetectionInstructions.push([G.CUSTOM,l,c,t,s||i,void 0,r]);break}this.endGeometry(e)}beginGeometry(t,e,i){this.beginGeometryInstruction1_=[G.BEGIN_GEOMETRY,e,0,t,i],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[G.BEGIN_GEOMETRY,e,0,t,i],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){const t=this.hitDetectionInstructions;t.reverse();let e;const i=t.length;let s,r,o=-1;for(e=0;e<i;++e)s=t[e],r=s[0],r==G.END_GEOMETRY?o=e:r==G.BEGIN_GEOMETRY&&(s[2]=e,Sf(this.hitDetectionInstructions,o,e),o=-1)}fillStyleToState(t,e={}){if(t){const i=t.getColor();e.fillPatternScale=i&&typeof i=="object"&&"src"in i?this.pixelRatio:1,e.fillStyle=Se(i||Yt)}else e.fillStyle=void 0;return e}strokeStyleToState(t,e={}){if(t){const i=t.getColor();e.strokeStyle=Se(i||us);const s=t.getLineCap();e.lineCap=s!==void 0?s:mn;const r=t.getLineDash();e.lineDash=r?r.slice():Ye;const o=t.getLineDashOffset();e.lineDashOffset=o||We;const a=t.getLineJoin();e.lineJoin=a!==void 0?a:pn;const l=t.getWidth();e.lineWidth=l!==void 0?l:fs;const h=t.getMiterLimit();e.miterLimit=h!==void 0?h:cs,e.lineWidth>this.maxLineWidth&&(this.maxLineWidth=e.lineWidth,this.bufferedMaxExtent_=null)}else e.strokeStyle=void 0,e.lineCap=void 0,e.lineDash=null,e.lineDashOffset=void 0,e.lineJoin=void 0,e.lineWidth=void 0,e.miterLimit=void 0;return e}setFillStrokeStyle(t,e){const i=this.state;this.fillStyleToState(t,i),this.strokeStyleToState(e,i)}createFill(t){const e=t.fillStyle,i=[G.SET_FILL_STYLE,e];return typeof e!="string"&&i.push(t.fillPatternScale),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[G.SET_STROKE_STYLE,t.strokeStyle,t.lineWidth*this.pixelRatio,t.lineCap,t.lineJoin,t.miterLimit,t.lineDash?this.applyPixelRatio(t.lineDash):null,t.lineDashOffset*this.pixelRatio]}updateFillStyle(t,e){const i=t.fillStyle;(typeof i!="string"||t.currentFillStyle!=i)&&(this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){const i=t.strokeStyle,s=t.lineCap,r=t.lineDash,o=t.lineDashOffset,a=t.lineJoin,l=t.lineWidth,h=t.miterLimit;(t.currentStrokeStyle!=i||t.currentLineCap!=s||r!=t.currentLineDash&&!ai(t.currentLineDash,r)||t.currentLineDashOffset!=o||t.currentLineJoin!=a||t.currentLineWidth!=l||t.currentMiterLimit!=h)&&(e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=s,t.currentLineDash=r,t.currentLineDashOffset=o,t.currentLineJoin=a,t.currentLineWidth=l,t.currentMiterLimit=h)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;const e=[G.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=ph(this.maxExtent),this.maxLineWidth>0)){const t=this.resolution*(this.maxLineWidth+1)/2;li(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}}class B_ extends ys{constructor(t,e,i,s){super(t,e,i,s),this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.anchorX_=void 0,this.anchorY_=void 0,this.height_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.scale_=void 0,this.width_=void 0,this.declutterMode_=void 0,this.declutterImageWithText_=void 0}drawPoint(t,e,i){if(!this.image_||this.maxExtent&&!an(this.maxExtent,t.getFlatCoordinates()))return;this.beginGeometry(t,e,i);const s=t.getFlatCoordinates(),r=t.getStride(),o=this.coordinates.length,a=this.appendFlatPointCoordinates(s,r);this.instructions.push([G.DRAW_IMAGE,o,a,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([G.DRAW_IMAGE,o,a,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,1,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}drawMultiPoint(t,e,i){if(!this.image_)return;this.beginGeometry(t,e,i);const s=t.getFlatCoordinates(),r=[];for(let l=0,h=s.length;l<h;l+=t.getStride())(!this.maxExtent||an(this.maxExtent,s.slice(l,l+2)))&&r.push(s[l],s[l+1]);const o=this.coordinates.length,a=this.appendFlatPointCoordinates(r,2);this.instructions.push([G.DRAW_IMAGE,o,a,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([G.DRAW_IMAGE,o,a,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,1,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}finish(){return this.reverseHitDetectionInstructions(),this.anchorX_=void 0,this.anchorY_=void 0,this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.height_=void 0,this.scale_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.width_=void 0,super.finish()}setImageStyle(t,e){const i=t.getAnchor(),s=t.getSize(),r=t.getOrigin();this.imagePixelRatio_=t.getPixelRatio(this.pixelRatio),this.anchorX_=i[0],this.anchorY_=i[1],this.hitDetectionImage_=t.getHitDetectionImage(),this.image_=t.getImage(this.pixelRatio),this.height_=s[1],this.opacity_=t.getOpacity(),this.originX_=r[0],this.originY_=r[1],this.rotateWithView_=t.getRotateWithView(),this.rotation_=t.getRotation(),this.scale_=t.getScaleArray(),this.width_=s[0],this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}}class $_ extends ys{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinates_(t,e,i,s){const r=this.coordinates.length,o=this.appendFlatLineCoordinates(t,e,i,s,!1,!1),a=[G.MOVE_TO_LINE_TO,r,o];return this.instructions.push(a),this.hitDetectionInstructions.push(a),i}drawLineString(t,e,i){const s=this.state,r=s.strokeStyle,o=s.lineWidth;if(r===void 0||o===void 0)return;this.updateStrokeStyle(s,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Ye,We],Ki);const a=t.getFlatCoordinates(),l=t.getStride();this.drawFlatCoordinates_(a,0,a.length,l),this.hitDetectionInstructions.push(pi),this.endGeometry(e)}drawMultiLineString(t,e,i){const s=this.state,r=s.strokeStyle,o=s.lineWidth;if(r===void 0||o===void 0)return;this.updateStrokeStyle(s,this.applyStroke),this.beginGeometry(t,e,i),this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Ye,We],Ki);const a=t.getEnds(),l=t.getFlatCoordinates(),h=t.getStride();let c=0;for(let u=0,d=a.length;u<d;++u)c=this.drawFlatCoordinates_(l,c,a[u],h);this.hitDetectionInstructions.push(pi),this.endGeometry(e)}finish(){const t=this.state;return t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&this.instructions.push(pi),this.reverseHitDetectionInstructions(),this.state=null,super.finish()}applyStroke(t){t.lastStroke!=null&&t.lastStroke!=this.coordinates.length&&(this.instructions.push(pi),t.lastStroke=this.coordinates.length),t.lastStroke=0,super.applyStroke(t),this.instructions.push(Ki)}}class Wc extends ys{constructor(t,e,i,s){super(t,e,i,s)}drawFlatCoordinatess_(t,e,i,s){const r=this.state,o=r.fillStyle!==void 0,a=r.strokeStyle!==void 0,l=i.length;this.instructions.push(Ki),this.hitDetectionInstructions.push(Ki);for(let h=0;h<l;++h){const c=i[h],u=this.coordinates.length,d=this.appendFlatLineCoordinates(t,e,c,s,!0,!a),f=[G.MOVE_TO_LINE_TO,u,d];this.instructions.push(f),this.hitDetectionInstructions.push(f),a&&(this.instructions.push(Yc),this.hitDetectionInstructions.push(Yc)),e=c}return o&&(this.instructions.push(Wr),this.hitDetectionInstructions.push(Wr)),a&&(this.instructions.push(pi),this.hitDetectionInstructions.push(pi)),e}drawCircle(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Yt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Ye,We]);const a=t.getFlatCoordinates(),l=t.getStride(),h=this.coordinates.length;this.appendFlatLineCoordinates(a,0,a.length,l,!1,!1);const c=[G.CIRCLE,h];this.instructions.push(Ki,c),this.hitDetectionInstructions.push(Ki,c),s.fillStyle!==void 0&&(this.instructions.push(Wr),this.hitDetectionInstructions.push(Wr)),s.strokeStyle!==void 0&&(this.instructions.push(pi),this.hitDetectionInstructions.push(pi)),this.endGeometry(e)}drawPolygon(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Yt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Ye,We]);const a=t.getEnds(),l=t.getOrientedFlatCoordinates(),h=t.getStride();this.drawFlatCoordinatess_(l,0,a,h),this.endGeometry(e)}drawMultiPolygon(t,e,i){const s=this.state,r=s.fillStyle,o=s.strokeStyle;if(r===void 0&&o===void 0)return;this.setFillStrokeStyles_(),this.beginGeometry(t,e,i),s.fillStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_FILL_STYLE,Yt]),s.strokeStyle!==void 0&&this.hitDetectionInstructions.push([G.SET_STROKE_STYLE,s.strokeStyle,s.lineWidth,s.lineCap,s.lineJoin,s.miterLimit,Ye,We]);const a=t.getEndss(),l=t.getOrientedFlatCoordinates(),h=t.getStride();let c=0;for(let u=0,d=a.length;u<d;++u)c=this.drawFlatCoordinatess_(l,c,a[u],h);this.endGeometry(e)}finish(){this.reverseHitDetectionInstructions(),this.state=null;const t=this.tolerance;if(t!==0){const e=this.coordinates;for(let i=0,s=e.length;i<s;++i)e[i]=Yi(e[i],t)}return super.finish()}setFillStrokeStyles_(){const t=this.state;this.updateFillStyle(t,this.createFill),this.updateStrokeStyle(t,this.applyStroke)}}function K_(n,t,e,i,s){const r=[];let o=e,a=0,l=t.slice(e,2);for(;a<n&&o+s<i;){const[h,c]=l.slice(-2),u=t[o+s],d=t[o+s+1],f=Math.sqrt((u-h)*(u-h)+(d-c)*(d-c));if(a+=f,a>=n){const g=(n-a+f)/f,m=jt(h,u,g),_=jt(c,d,g);l.push(m,_),r.push(l),l=[m,_],a==n&&(o+=s),a=0}else if(a<n)l.push(t[o+s],t[o+s+1]),o+=s;else{const g=f-a,m=jt(h,u,g/f),_=jt(c,d,g/f);l.push(m,_),r.push(l),l=[m,_],a=0,o+=s}}return a>0&&r.push(l),r}function j_(n,t,e,i,s){let r=e,o=e,a=0,l=0,h=e,c,u,d,f,g,m,_,p,y,w;for(u=e;u<i;u+=s){const x=t[u],E=t[u+1];g!==void 0&&(y=x-g,w=E-m,f=Math.sqrt(y*y+w*w),_!==void 0&&(l+=d,c=Math.acos((_*y+p*w)/(d*f)),c>n&&(l>a&&(a=l,r=h,o=u),l=0,h=u-s)),d=f,_=y,p=w),g=x,m=E}return l+=f,l>a?[h,u]:[r,o]}const Vr={left:0,center:.5,right:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1};class U_ extends ys{constructor(t,e,i,s){super(t,e,i,s),this.labels_=null,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=void 0,this.textKeepUpright_=void 0,this.textRotation_=0,this.textFillState_=null,this.fillStates={},this.fillStates[Yt]={fillStyle:Yt},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterMode_=void 0,this.declutterImageWithText_=void 0}finish(){const t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e,i){const s=this.textFillState_,r=this.textStrokeState_,o=this.textState_;if(this.text_===""||!o||!s&&!r)return;const a=this.coordinates;let l=a.length;const h=t.getType();let c=null,u=t.getStride();if(o.placement==="line"&&(h=="LineString"||h=="MultiLineString"||h=="Polygon"||h=="MultiPolygon")){if(!ct(this.maxExtent,t.getExtent()))return;let d;if(c=t.getFlatCoordinates(),h=="LineString")d=[c.length];else if(h=="MultiLineString")d=t.getEnds();else if(h=="Polygon")d=t.getEnds().slice(0,1);else if(h=="MultiPolygon"){const _=t.getEndss();d=[];for(let p=0,y=_.length;p<y;++p)d.push(_[p][0])}this.beginGeometry(t,e,i);const f=o.repeat,g=f?void 0:o.textAlign;let m=0;for(let _=0,p=d.length;_<p;++_){let y;f?y=K_(f*this.resolution,c,m,d[_],u):y=[c.slice(m,d[_])];for(let w=0,x=y.length;w<x;++w){const E=y[w];let C=0,R=E.length;if(g==null){const b=j_(o.maxAngle,E,0,E.length,2);C=b[0],R=b[1]}for(let b=C;b<R;b+=u)a.push(E[b],E[b+1]);const S=a.length;m=d[_],this.drawChars_(l,S),l=S}}this.endGeometry(e)}else{let d=o.overflow?null:[];switch(h){case"Point":case"MultiPoint":c=t.getFlatCoordinates();break;case"LineString":c=t.getFlatMidpoint();break;case"Circle":c=t.getCenter();break;case"MultiLineString":c=t.getFlatMidpoints(),u=2;break;case"Polygon":c=t.getFlatInteriorPoint(),o.overflow||d.push(c[2]/this.resolution),u=3;break;case"MultiPolygon":const x=t.getFlatInteriorPoints();c=[];for(let E=0,C=x.length;E<C;E+=3)o.overflow||d.push(x[E+2]/this.resolution),c.push(x[E],x[E+1]);if(c.length===0)return;u=2;break}const f=this.appendFlatPointCoordinates(c,u);if(f===l)return;if(d&&(f-l)/2!==c.length/u){let x=l/2;d=d.filter((E,C)=>{const R=a[(x+C)*2]===c[C*u]&&a[(x+C)*2+1]===c[C*u+1];return R||--x,R})}this.saveTextStates_();const g=o.backgroundFill?this.createFill(this.fillStyleToState(o.backgroundFill)):null,m=o.backgroundStroke?this.createStroke(this.strokeStyleToState(o.backgroundStroke)):null;this.beginGeometry(t,e,i);let _=o.padding;if(_!=$i&&(o.scale[0]<0||o.scale[1]<0)){let x=o.padding[0],E=o.padding[1],C=o.padding[2],R=o.padding[3];o.scale[0]<0&&(E=-E,R=-R),o.scale[1]<0&&(x=-x,C=-C),_=[x,E,C,R]}const p=this.pixelRatio;this.instructions.push([G.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,this.declutterMode_,this.declutterImageWithText_,_==$i?$i:_.map(function(x){return x*p}),g,m,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]);const y=1/p,w=g?g.slice(0):null;w&&(w[1]=Yt),this.hitDetectionInstructions.push([G.DRAW_IMAGE,l,f,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[y,y],NaN,this.declutterMode_,this.declutterImageWithText_,_,w,m,this.text_,this.textKey_,this.strokeKey_,this.fillKey_?Yt:this.fillKey_,this.textOffsetX_,this.textOffsetY_,d]),this.endGeometry(e)}}saveTextStates_(){const t=this.textStrokeState_,e=this.textState_,i=this.textFillState_,s=this.strokeKey_;t&&(s in this.strokeStates||(this.strokeStates[s]={strokeStyle:t.strokeStyle,lineCap:t.lineCap,lineDashOffset:t.lineDashOffset,lineWidth:t.lineWidth,lineJoin:t.lineJoin,miterLimit:t.miterLimit,lineDash:t.lineDash}));const r=this.textKey_;r in this.textStates||(this.textStates[r]={font:e.font,textAlign:e.textAlign||ds,justify:e.justify,textBaseline:e.textBaseline||Mr,scale:e.scale});const o=this.fillKey_;i&&(o in this.fillStates||(this.fillStates[o]={fillStyle:i.fillStyle}))}drawChars_(t,e){const i=this.textStrokeState_,s=this.textState_,r=this.strokeKey_,o=this.textKey_,a=this.fillKey_;this.saveTextStates_();const l=this.pixelRatio,h=Vr[s.textBaseline],c=this.textOffsetY_*l,u=this.text_,d=i?i.lineWidth*Math.abs(s.scale[0])/2:0;this.instructions.push([G.DRAW_CHARS,t,e,h,s.overflow,a,s.maxAngle,l,c,r,d*l,u,o,1,this.declutterMode_,this.textKeepUpright_]),this.hitDetectionInstructions.push([G.DRAW_CHARS,t,e,h,s.overflow,a&&Yt,s.maxAngle,l,c,r,d*l,u,o,1/l,this.declutterMode_,this.textKeepUpright_])}setTextStyle(t,e){let i,s,r;if(!t)this.text_="";else{const o=t.getFill();o?(s=this.textFillState_,s||(s={},this.textFillState_=s),s.fillStyle=Se(o.getColor()||Yt)):(s=null,this.textFillState_=s);const a=t.getStroke();if(!a)r=null,this.textStrokeState_=r;else{r=this.textStrokeState_,r||(r={},this.textStrokeState_=r);const m=a.getLineDash(),_=a.getLineDashOffset(),p=a.getWidth(),y=a.getMiterLimit();r.lineCap=a.getLineCap()||mn,r.lineDash=m?m.slice():Ye,r.lineDashOffset=_===void 0?We:_,r.lineJoin=a.getLineJoin()||pn,r.lineWidth=p===void 0?fs:p,r.miterLimit=y===void 0?cs:y,r.strokeStyle=Se(a.getColor()||us)}i=this.textState_;const l=t.getFont()||xc;__(l);const h=t.getScaleArray();i.overflow=t.getOverflow(),i.font=l,i.maxAngle=t.getMaxAngle(),i.placement=t.getPlacement(),i.textAlign=t.getTextAlign(),i.repeat=t.getRepeat(),i.justify=t.getJustify(),i.textBaseline=t.getTextBaseline()||Mr,i.backgroundFill=t.getBackgroundFill(),i.backgroundStroke=t.getBackgroundStroke(),i.padding=t.getPadding()||$i,i.scale=h===void 0?[1,1]:h;const c=t.getOffsetX(),u=t.getOffsetY(),d=t.getRotateWithView(),f=t.getKeepUpright(),g=t.getRotation();this.text_=t.getText()||"",this.textOffsetX_=c===void 0?0:c,this.textOffsetY_=u===void 0?0:u,this.textRotateWithView_=d===void 0?!1:d,this.textKeepUpright_=f===void 0?!0:f,this.textRotation_=g===void 0?0:g,this.strokeKey_=r?(typeof r.strokeStyle=="string"?r.strokeStyle:B(r.strokeStyle))+r.lineCap+r.lineDashOffset+"|"+r.lineWidth+r.lineJoin+r.miterLimit+"["+r.lineDash.join()+"]":"",this.textKey_=i.font+i.scale+(i.textAlign||"?")+(i.repeat||"?")+(i.justify||"?")+(i.textBaseline||"?"),this.fillKey_=s&&s.fillStyle?typeof s.fillStyle=="string"?s.fillStyle:"|"+B(s.fillStyle):""}this.declutterMode_=t.getDeclutterMode(),this.declutterImageWithText_=e}}const Z_={Circle:Wc,Default:ys,Image:B_,LineString:$_,Polygon:Wc,Text:U_};class Vc{constructor(t,e,i,s){this.tolerance_=t,this.maxExtent_=e,this.pixelRatio_=s,this.resolution_=i,this.buildersByZIndex_={}}finish(){const t={};for(const e in this.buildersByZIndex_){t[e]=t[e]||{};const i=this.buildersByZIndex_[e];for(const s in i){const r=i[s].finish();t[e][s]=r}}return t}getBuilder(t,e){const i=t!==void 0?t.toString():"0";let s=this.buildersByZIndex_[i];s===void 0&&(s={},this.buildersByZIndex_[i]=s);let r=s[e];if(r===void 0){const o=Z_[e];r=new o(this.tolerance_,this.maxExtent_,this.resolution_,this.pixelRatio_),s[e]=r}return r}}function H_(n,t,e,i,s,r,o,a,l,h,c,u,d=!0){let f=n[t],g=n[t+1],m=0,_=0,p=0,y=0;function w(){m=f,_=g,t+=i,f=n[t],g=n[t+1],y+=p,p=Math.sqrt((f-m)*(f-m)+(g-_)*(g-_))}do w();while(t<e-i&&y+p<r);let x=p===0?0:(r-y)/p;const E=jt(m,f,x),C=jt(_,g,x),R=t-i,S=y,b=r+a*l(h,s,c);for(;t<e-i&&y+p<b;)w();x=p===0?0:(b-y)/p;const v=jt(m,f,x),I=jt(_,g,x);let A=!1;if(d)if(u){const k=[E,C,v,I];Kh(k,0,4,2,u,k,k),A=k[0]>k[2]}else A=E>v;const F=Math.PI,M=[],N=R+i===t;t=R,p=0,y=S,f=n[t],g=n[t+1];let L;if(N){w(),L=Math.atan2(g-_,f-m),A&&(L+=L>0?-F:F);const k=(v+E)/2,D=(I+C)/2;return M[0]=[k,D,(b-r)/2,L,s],M}s=s.replace(/\n/g," ");for(let k=0,D=s.length;k<D;){w();let X=Math.atan2(g-_,f-m);if(A&&(X+=X>0?-F:F),L!==void 0){let ot=X-L;if(ot+=ot>F?-2*F:ot<-F?2*F:0,Math.abs(ot)>o)return null}L=X;const Y=k;let W=0;for(;k<D;++k){const ot=A?D-k-1:k,kt=a*l(h,s[ot],c);if(t+i<e&&y+p<r+W+kt/2)break;W+=kt}if(k===Y)continue;const P=A?s.substring(D-Y,D-k):s.substring(Y,k);x=p===0?0:(r+W/2-y)/p;const pt=jt(m,f,x),yt=jt(_,g,x);M.push([pt,yt,W/2,X,P]),r+=W}return M}class La{constructor(){this.instructions_=[],this.zIndex=0,this.offset_=0,this.context_=new Proxy(Ir(),{get:(t,e)=>{if(typeof Ir()[e]=="function")return this.push_(e),this.pushMethodArgs_},set:(t,e,i)=>(this.push_(e,i),!0)})}push_(...t){const e=this.instructions_,i=this.zIndex+this.offset_;e[i]||(e[i]=[]),e[i].push(...t)}pushMethodArgs_=(...t)=>(this.push_(t),this);pushFunction(t){this.push_(t)}getContext(){return this.context_}draw(t){this.instructions_.forEach(e=>{for(let i=0,s=e.length;i<s;++i){const r=e[i];if(typeof r=="function"){r(t);continue}const o=e[++i];if(typeof t[r]=="function")t[r](...o);else{if(typeof o=="function"){t[r]=o(t);continue}t[r]=o}}})}clear(){this.instructions_.length=0,this.zIndex=0,this.offset_=0}offset(){this.offset_=this.instructions_.length,this.zIndex=0}}const wn=Kt(),yi=[],Ve=[],Be=[],xi=[];function Bc(n){return n[3].declutterBox}const $c=new RegExp("[֑-ࣿיִ-﷿ﹰ-ﻼࠀ--]");function Aa(n,t){return t==="start"?t=$c.test(n)?"right":"left":t==="end"&&(t=$c.test(n)?"left":"right"),Vr[t]}function q_(n,t,e){return e>0&&n.push(`
|
|
5
|
+
`,""),n.push(t,""),n}function J_(n,t,e){return e%2===0&&(n+=t),n}class Q_{constructor(t,e,i,s,r){this.overlaps=i,this.pixelRatio=e,this.resolution=t,this.alignAndScaleFill_,this.instructions=s.instructions,this.coordinates=s.coordinates,this.coordinateCache_={},this.renderedTransform_=ae(),this.hitDetectionInstructions=s.hitDetectionInstructions,this.pixelCoordinates_=null,this.viewRotation_=0,this.fillStates=s.fillStates||{},this.strokeStates=s.strokeStates||{},this.textStates=s.textStates||{},this.widths_={},this.labels_={},this.zIndexContext_=r?new La:null}getZIndexContext(){return this.zIndexContext_}createLabel(t,e,i,s){const r=t+e+i+s;if(this.labels_[r])return this.labels_[r];const o=s?this.strokeStates[s]:null,a=i?this.fillStates[i]:null,l=this.textStates[e],h=this.pixelRatio,c=[l.scale[0]*h,l.scale[1]*h],u=l.justify?Vr[l.justify]:Aa(Array.isArray(t)?t[0]:t,l.textAlign||ds),d=s&&o.lineWidth?o.lineWidth:0,f=Array.isArray(t)?t:String(t).split(`
|
|
6
|
+
`).reduce(q_,[]),{width:g,height:m,widths:_,heights:p,lineWidths:y}=p_(l,f),w=g+d,x=[],E=(w+2)*c[0],C=(m+d)*c[1],R={width:E<0?Math.floor(E):Math.ceil(E),height:C<0?Math.floor(C):Math.ceil(C),contextInstructions:x};(c[0]!=1||c[1]!=1)&&x.push("scale",c),s&&(x.push("strokeStyle",o.strokeStyle),x.push("lineWidth",d),x.push("lineCap",o.lineCap),x.push("lineJoin",o.lineJoin),x.push("miterLimit",o.miterLimit),x.push("setLineDash",[o.lineDash]),x.push("lineDashOffset",o.lineDashOffset)),i&&x.push("fillStyle",a.fillStyle),x.push("textBaseline","middle"),x.push("textAlign","center");const S=.5-u;let b=u*w+S*d;const v=[],I=[];let A=0,F=0,M=0,N=0,L;for(let k=0,D=f.length;k<D;k+=2){const X=f[k];if(X===`
|
|
7
|
+
`){F+=A,A=0,b=u*w+S*d,++N;continue}const Y=f[k+1]||l.font;Y!==L&&(s&&v.push("font",Y),i&&I.push("font",Y),L=Y),A=Math.max(A,p[M]);const W=[X,b+S*_[M]+u*(_[M]-y[N]),.5*(d+A)+F];b+=_[M],s&&v.push("strokeText",W),i&&I.push("fillText",W),++M}return Array.prototype.push.apply(x,v),Array.prototype.push.apply(x,I),this.labels_[r]=R,R}replayTextBackground_(t,e,i,s,r,o,a){t.beginPath(),t.moveTo.apply(t,e),t.lineTo.apply(t,i),t.lineTo.apply(t,s),t.lineTo.apply(t,r),t.lineTo.apply(t,e),o&&(this.alignAndScaleFill_=o[2],t.fillStyle=o[1],this.fill_(t)),a&&(this.setStrokeStyle_(t,a),t.stroke())}calculateImageOrLabelDimensions_(t,e,i,s,r,o,a,l,h,c,u,d,f,g,m,_){a*=d[0],l*=d[1];let p=i-a,y=s-l;const w=r+h>t?t-h:r,x=o+c>e?e-c:o,E=g[3]+w*d[0]+g[1],C=g[0]+x*d[1]+g[2],R=p-g[3],S=y-g[0];(m||u!==0)&&(yi[0]=R,xi[0]=R,yi[1]=S,Ve[1]=S,Ve[0]=R+E,Be[0]=Ve[0],Be[1]=S+C,xi[1]=Be[1]);let b;return u!==0?(b=Xe(ae(),i,s,1,1,u,-i,-s),gt(b,yi),gt(b,Ve),gt(b,Be),gt(b,xi),Ne(Math.min(yi[0],Ve[0],Be[0],xi[0]),Math.min(yi[1],Ve[1],Be[1],xi[1]),Math.max(yi[0],Ve[0],Be[0],xi[0]),Math.max(yi[1],Ve[1],Be[1],xi[1]),wn)):Ne(Math.min(R,R+E),Math.min(S,S+C),Math.max(R,R+E),Math.max(S,S+C),wn),f&&(p=Math.round(p),y=Math.round(y)),{drawImageX:p,drawImageY:y,drawImageW:w,drawImageH:x,originX:h,originY:c,declutterBox:{minX:wn[0],minY:wn[1],maxX:wn[2],maxY:wn[3],value:_},canvasTransform:b,scale:d}}replayImageOrLabel_(t,e,i,s,r,o,a){const l=!!(o||a),h=s.declutterBox,c=a?a[2]*s.scale[0]/2:0;return h.minX-c<=e[0]&&h.maxX+c>=0&&h.minY-c<=e[1]&&h.maxY+c>=0&&(l&&this.replayTextBackground_(t,yi,Ve,Be,xi,o,a),y_(t,s.canvasTransform,r,i,s.originX,s.originY,s.drawImageW,s.drawImageH,s.drawImageX,s.drawImageY,s.scale)),!0}fill_(t){const e=this.alignAndScaleFill_;if(e){const i=gt(this.renderedTransform_,[0,0]),s=512*this.pixelRatio;t.save(),t.translate(i[0]%s,i[1]%s),e!==1&&t.scale(e,e),t.rotate(this.viewRotation_)}t.fill(),e&&t.restore()}setStrokeStyle_(t,e){t.strokeStyle=e[1],e[1]&&(t.lineWidth=e[2],t.lineCap=e[3],t.lineJoin=e[4],t.miterLimit=e[5],t.lineDashOffset=e[7],t.setLineDash(e[6]))}drawLabelWithPointPlacement_(t,e,i,s){const r=this.textStates[e],o=this.createLabel(t,e,s,i),a=this.strokeStates[i],l=this.pixelRatio,h=Aa(Array.isArray(t)?t[0]:t,r.textAlign||ds),c=Vr[r.textBaseline||Mr],u=a&&a.lineWidth?a.lineWidth:0,d=o.width/l-2*r.scale[0],f=h*d+2*(.5-h)*u,g=c*o.height/l+2*(.5-c)*u;return{label:o,anchorX:f,anchorY:g}}execute_(t,e,i,s,r,o,a,l){const h=this.zIndexContext_;let c;this.pixelCoordinates_&&ai(i,this.renderedTransform_)?c=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),c=di(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),Eg(this.renderedTransform_,i));let u=0;const d=s.length;let f=0,g,m,_,p,y,w,x,E,C,R,S,b,v,I=0,A=0;const F=this.coordinateCache_,M=this.viewRotation_,N=Math.round(Math.atan2(-i[1],i[0])*1e12)/1e12,L={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:M},k=this.instructions!=s||this.overlaps?0:200;let D,X,Y,W;for(;u<d;){const P=s[u];switch(P[0]){case G.BEGIN_GEOMETRY:D=P[1],W=P[3],D.getGeometry()?a!==void 0&&!ct(a,W.getExtent())?u=P[2]+1:++u:u=P[2],h&&(h.zIndex=P[4]);break;case G.BEGIN_PATH:I>k&&(this.fill_(t),I=0),A>k&&(t.stroke(),A=0),!I&&!A&&(t.beginPath(),y=NaN,w=NaN),++u;break;case G.CIRCLE:f=P[1];const yt=c[f],ot=c[f+1],kt=c[f+2],dt=c[f+3],Nt=kt-yt,bt=dt-ot,Et=Math.sqrt(Nt*Nt+bt*bt);t.moveTo(yt+Et,ot),t.arc(yt,ot,Et,0,2*Math.PI,!0),++u;break;case G.CLOSE_PATH:t.closePath(),++u;break;case G.CUSTOM:f=P[1],g=P[2];const Ue=P[3],ll=P[4],Ps=P[5];L.geometry=Ue,L.feature=D,u in F||(F[u]=[]);const qi=F[u];Ps?Ps(c,f,g,2,qi):(qi[0]=c[f],qi[1]=c[f+1],qi.length=2),h&&(h.zIndex=P[6]),ll(qi,L),++u;break;case G.DRAW_IMAGE:f=P[1],g=P[2],C=P[3],m=P[4],_=P[5];let ue=P[6];const be=P[7],On=P[8],Dn=P[9],Ms=P[10];let Ji=P[11];const kn=P[12];let Nn=P[13];p=P[14]||"declutter";const wt=P[15];if(!C&&P.length>=20){R=P[19],S=P[20],b=P[21],v=P[22];const de=this.drawLabelWithPointPlacement_(R,S,b,v);C=de.label,P[3]=C;const Qi=P[23];m=(de.anchorX-Qi)*this.pixelRatio,P[4]=m;const fe=P[24];_=(de.anchorY-fe)*this.pixelRatio,P[5]=_,ue=C.height,P[6]=ue,Nn=C.width,P[13]=Nn}let hl;P.length>25&&(hl=P[25]);let cl,ro,oo;P.length>17?(cl=P[16],ro=P[17],oo=P[18]):(cl=$i,ro=null,oo=null),Ms&&N?Ji+=M:!Ms&&!N&&(Ji-=M);let J0=0;for(;f<g;f+=2){if(hl&&hl[J0++]<Nn/this.pixelRatio)continue;const de=this.calculateImageOrLabelDimensions_(C.width,C.height,c[f],c[f+1],Nn,ue,m,_,On,Dn,Ji,kn,r,cl,!!ro||!!oo,D),Qi=[t,e,C,de,be,ro,oo];if(l){let fe,Le,ge;if(wt){const ht=g-f;if(!wt[ht]){wt[ht]={args:Qi,declutterMode:p};continue}const Gt=wt[ht];fe=Gt.args,Le=Gt.declutterMode,delete wt[ht],ge=Bc(fe)}let Ze,He;if(fe&&(Le!=="declutter"||!l.collides(ge))&&(Ze=!0),(p!=="declutter"||!l.collides(de.declutterBox))&&(He=!0),Le==="declutter"&&p==="declutter"){const ht=Ze&&He;Ze=ht,He=ht}Ze&&(Le!=="none"&&l.insert(ge),this.replayImageOrLabel_.apply(this,fe)),He&&(p!=="none"&&l.insert(de.declutterBox),this.replayImageOrLabel_.apply(this,Qi))}else this.replayImageOrLabel_.apply(this,Qi)}++u;break;case G.DRAW_CHARS:const Uu=P[1],Zu=P[2],ul=P[3],Q0=P[4];v=P[5];const ty=P[6],Hu=P[7],qu=P[8];b=P[9];const dl=P[10];R=P[11],Array.isArray(R)&&(R=R.reduce(J_,"")),S=P[12];const Ju=[P[13],P[13]];p=P[14]||"declutter";const ey=P[15],fl=this.textStates[S],Fs=fl.font,Os=[fl.scale[0]*Hu,fl.scale[1]*Hu];let Ds;Fs in this.widths_?Ds=this.widths_[Fs]:(Ds={},this.widths_[Fs]=Ds);const Qu=ha(c,Uu,Zu,2),td=Math.abs(Os[0])*Cc(Fs,R,Ds);if(Q0||td<=Qu){const de=this.textStates[S].textAlign,Qi=(Qu-td)*Aa(R,de),fe=H_(c,Uu,Zu,2,R,Qi,ty,Math.abs(Os[0]),Cc,Fs,Ds,N?0:this.viewRotation_,ey);t:if(fe){const Le=[];let ge,Ze,He,ht,Gt;if(b)for(ge=0,Ze=fe.length;ge<Ze;++ge){Gt=fe[ge],He=Gt[4],ht=this.createLabel(He,S,"",b),m=Gt[2]+(Os[0]<0?-dl:dl),_=ul*ht.height+(.5-ul)*2*dl*Os[1]/Os[0]-qu;const qe=this.calculateImageOrLabelDimensions_(ht.width,ht.height,Gt[0],Gt[1],ht.width,ht.height,m,_,0,0,Gt[3],Ju,!1,$i,!1,D);if(l&&p==="declutter"&&l.collides(qe.declutterBox))break t;Le.push([t,e,ht,qe,1,null,null])}if(v)for(ge=0,Ze=fe.length;ge<Ze;++ge){Gt=fe[ge],He=Gt[4],ht=this.createLabel(He,S,v,""),m=Gt[2],_=ul*ht.height-qu;const qe=this.calculateImageOrLabelDimensions_(ht.width,ht.height,Gt[0],Gt[1],ht.width,ht.height,m,_,0,0,Gt[3],Ju,!1,$i,!1,D);if(l&&p==="declutter"&&l.collides(qe.declutterBox))break t;Le.push([t,e,ht,qe,1,null,null])}l&&p!=="none"&&l.load(Le.map(Bc));for(let qe=0,iy=Le.length;qe<iy;++qe)this.replayImageOrLabel_.apply(this,Le[qe])}}++u;break;case G.END_GEOMETRY:if(o!==void 0){D=P[1];const de=o(D,W,p);if(de)return de}++u;break;case G.FILL:k?I++:this.fill_(t),++u;break;case G.MOVE_TO_LINE_TO:for(f=P[1],g=P[2],X=c[f],Y=c[f+1],t.moveTo(X,Y),y=X+.5|0,w=Y+.5|0,f+=2;f<g;f+=2)X=c[f],Y=c[f+1],x=X+.5|0,E=Y+.5|0,(f==g-2||x!==y||E!==w)&&(t.lineTo(X,Y),y=x,w=E);++u;break;case G.SET_FILL_STYLE:this.alignAndScaleFill_=P[2],I&&(this.fill_(t),I=0,A&&(t.stroke(),A=0)),t.fillStyle=P[1],++u;break;case G.SET_STROKE_STYLE:A&&(t.stroke(),A=0),this.setStrokeStyle_(t,P),++u;break;case G.STROKE:k?A++:t.stroke(),++u;break;default:++u;break}}I&&this.fill_(t),A&&t.stroke()}execute(t,e,i,s,r,o){this.viewRotation_=s,this.execute_(t,e,i,this.instructions,r,void 0,void 0,o)}executeHitDetection(t,e,i,s,r){return this.viewRotation_=i,this.execute_(t,[t.canvas.width,t.canvas.height],e,this.hitDetectionInstructions,!0,s,r)}}const ji=["Polygon","Circle","LineString","Image","Text","Default"],Br=["Image","Text"],tm=ji.filter(n=>!Br.includes(n));class Kc{constructor(t,e,i,s,r,o,a){this.maxExtent_=t,this.overlaps_=s,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=o,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=ae(),this.renderedContext_=null,this.deferredZIndexContexts_={},this.createExecutors_(r,a)}clip(t,e){const i=this.getClipCoords(e);t.beginPath(),t.moveTo(i[0],i[1]),t.lineTo(i[2],i[3]),t.lineTo(i[4],i[5]),t.lineTo(i[6],i[7]),t.clip()}createExecutors_(t,e){for(const i in t){let s=this.executorsByZIndex_[i];s===void 0&&(s={},this.executorsByZIndex_[i]=s);const r=t[i];for(const o in r){const a=r[o];s[o]=new Q_(this.resolution_,this.pixelRatio_,this.overlaps_,a,e)}}}hasExecutors(t){for(const e in this.executorsByZIndex_){const i=this.executorsByZIndex_[e];for(let s=0,r=t.length;s<r;++s)if(t[s]in i)return!0}return!1}forEachFeatureAtCoordinate(t,e,i,s,r,o){s=Math.round(s);const a=s*2+1,l=Xe(this.hitDetectionTransform_,s+.5,s+.5,1/e,-1/e,-i,-t[0],-t[1]),h=!this.hitDetectionContext_;h&&(this.hitDetectionContext_=ut(a,a));const c=this.hitDetectionContext_;c.canvas.width!==a||c.canvas.height!==a?(c.canvas.width=a,c.canvas.height=a):h||c.clearRect(0,0,a,a);let u;this.renderBuffer_!==void 0&&(u=Kt(),Qn(u,t),li(u,e*(this.renderBuffer_+s),u));const d=em(s);let f;function g(E,C,R){const S=c.getImageData(0,0,a,a).data;for(let b=0,v=d.length;b<v;b++)if(S[d[b]]>0){if(!o||R==="none"||f!=="Image"&&f!=="Text"||o.includes(E)){const I=(d[b]-3)/4,A=s-I%a,F=s-(I/a|0),M=r(E,C,A*A+F*F);if(M)return M}c.clearRect(0,0,a,a);break}}const m=Object.keys(this.executorsByZIndex_).map(Number);m.sort(Te);let _,p,y,w,x;for(_=m.length-1;_>=0;--_){const E=m[_].toString();for(y=this.executorsByZIndex_[E],p=ji.length-1;p>=0;--p)if(f=ji[p],w=y[f],w!==void 0&&(x=w.executeHitDetection(c,l,i,g,u),x))return x}}getClipCoords(t){const e=this.maxExtent_;if(!e)return null;const i=e[0],s=e[1],r=e[2],o=e[3],a=[i,s,i,o,r,o,r,s];return di(a,0,8,2,t,a),a}isEmpty(){return Fi(this.executorsByZIndex_)}execute(t,e,i,s,r,o,a){const l=Object.keys(this.executorsByZIndex_).map(Number);l.sort(a?Rf:Te),o=o||ji;const h=ji.length;for(let c=0,u=l.length;c<u;++c){const d=l[c].toString(),f=this.executorsByZIndex_[d];for(let g=0,m=o.length;g<m;++g){const _=o[g],p=f[_];if(p!==void 0){const y=a===null?void 0:p.getZIndexContext(),w=y?y.getContext():t,x=this.maxExtent_&&_!=="Image"&&_!=="Text";if(x&&(w.save(),this.clip(w,i)),!y||_==="Text"||_==="Image"?p.execute(w,e,i,s,r,a):y.pushFunction(E=>p.execute(E,e,i,s,r,a)),x&&w.restore(),y){y.offset();const E=l[c]*h+ji.indexOf(_);this.deferredZIndexContexts_[E]||(this.deferredZIndexContexts_[E]=[]),this.deferredZIndexContexts_[E].push(y)}}}}this.renderedContext_=t}getDeferredZIndexContexts(){return this.deferredZIndexContexts_}getRenderedContext(){return this.renderedContext_}renderDeferred(){const t=this.deferredZIndexContexts_,e=Object.keys(t).map(Number).sort(Te);for(let i=0,s=e.length;i<s;++i)t[e[i]].forEach(r=>{r.draw(this.renderedContext_),r.clear()}),t[e[i]].length=0}}const Pa={};function em(n){if(Pa[n]!==void 0)return Pa[n];const t=n*2+1,e=n*n,i=new Array(e+1);for(let r=0;r<=n;++r)for(let o=0;o<=n;++o){const a=r*r+o*o;if(a>e)break;let l=i[a];l||(l=[],i[a]=l),l.push(((n+r)*t+(n+o))*4+3),r>0&&l.push(((n-r)*t+(n+o))*4+3),o>0&&(l.push(((n+r)*t+(n-o))*4+3),r>0&&l.push(((n-r)*t+(n-o))*4+3))}const s=[];for(let r=0,o=i.length;r<o;++r)i[r]&&s.push(...i[r]);return Pa[n]=s,s}function jc(n,t,e,i){return e!==void 0&&i!==void 0?[e/n,i/t]:e!==void 0?e/n:i!==void 0?i/t:1}class vn extends zr{constructor(t){t=t||{};const e=t.opacity!==void 0?t.opacity:1,i=t.rotation!==void 0?t.rotation:0,s=t.scale!==void 0?t.scale:1,r=t.rotateWithView!==void 0?t.rotateWithView:!1;super({opacity:e,rotation:i,scale:s,displacement:t.displacement!==void 0?t.displacement:[0,0],rotateWithView:r,declutterMode:t.declutterMode}),this.anchor_=t.anchor!==void 0?t.anchor:[.5,.5],this.normalizedAnchor_=null,this.anchorOrigin_=t.anchorOrigin!==void 0?t.anchorOrigin:"top-left",this.anchorXUnits_=t.anchorXUnits!==void 0?t.anchorXUnits:"fraction",this.anchorYUnits_=t.anchorYUnits!==void 0?t.anchorYUnits:"fraction",this.crossOrigin_=t.crossOrigin!==void 0?t.crossOrigin:null;const o=t.img!==void 0?t.img:null;let a=t.src;J(!(a!==void 0&&o),"`image` and `src` cannot be provided at the same time"),(a===void 0||a.length===0)&&o&&(a=o.src||B(o)),J(a!==void 0&&a.length>0,"A defined and non-empty `src` or `image` must be provided"),J(!((t.width!==void 0||t.height!==void 0)&&t.scale!==void 0),"`width` or `height` cannot be provided together with `scale`");let l;if(t.src!==void 0?l=$.IDLE:o!==void 0&&("complete"in o?o.complete?l=o.src?$.LOADED:$.IDLE:l=$.LOADING:l=$.LOADED),this.color_=t.color!==void 0?_n(t.color):null,this.iconImage_=Lr(o,a,this.crossOrigin_,l,this.color_),this.offset_=t.offset!==void 0?t.offset:[0,0],this.offsetOrigin_=t.offsetOrigin!==void 0?t.offsetOrigin:"top-left",this.origin_=null,this.size_=t.size!==void 0?t.size:null,this.initialOptions_,t.width!==void 0||t.height!==void 0){let h,c;if(t.size)[h,c]=t.size;else{const u=this.getImage(1);if(u.width&&u.height)h=u.width,c=u.height;else if(u instanceof HTMLImageElement){this.initialOptions_=t;const d=()=>{if(this.unlistenImageChange(d),!this.initialOptions_)return;const f=this.iconImage_.getSize();this.setScale(jc(f[0],f[1],t.width,t.height))};this.listenImageChange(d);return}}h!==void 0&&this.setScale(jc(h,c,t.width,t.height))}}clone(){let t,e,i;return this.initialOptions_?(e=this.initialOptions_.width,i=this.initialOptions_.height):(t=this.getScale(),t=Array.isArray(t)?t.slice():t),new vn({anchor:this.anchor_.slice(),anchorOrigin:this.anchorOrigin_,anchorXUnits:this.anchorXUnits_,anchorYUnits:this.anchorYUnits_,color:this.color_&&this.color_.slice?this.color_.slice():this.color_||void 0,crossOrigin:this.crossOrigin_,offset:this.offset_.slice(),offsetOrigin:this.offsetOrigin_,opacity:this.getOpacity(),rotateWithView:this.getRotateWithView(),rotation:this.getRotation(),scale:t,width:e,height:i,size:this.size_!==null?this.size_.slice():void 0,src:this.getSrc(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getAnchor(){let t=this.normalizedAnchor_;if(!t){t=this.anchor_;const s=this.getSize();if(this.anchorXUnits_=="fraction"||this.anchorYUnits_=="fraction"){if(!s)return null;t=this.anchor_.slice(),this.anchorXUnits_=="fraction"&&(t[0]*=s[0]),this.anchorYUnits_=="fraction"&&(t[1]*=s[1])}if(this.anchorOrigin_!="top-left"){if(!s)return null;t===this.anchor_&&(t=this.anchor_.slice()),(this.anchorOrigin_=="top-right"||this.anchorOrigin_=="bottom-right")&&(t[0]=-t[0]+s[0]),(this.anchorOrigin_=="bottom-left"||this.anchorOrigin_=="bottom-right")&&(t[1]=-t[1]+s[1])}this.normalizedAnchor_=t}const e=this.getDisplacement(),i=this.getScaleArray();return[t[0]-e[0]/i[0],t[1]+e[1]/i[1]]}setAnchor(t){this.anchor_=t,this.normalizedAnchor_=null}getColor(){return this.color_}getImage(t){return this.iconImage_.getImage(t)}getPixelRatio(t){return this.iconImage_.getPixelRatio(t)}getImageSize(){return this.iconImage_.getSize()}getImageState(){return this.iconImage_.getImageState()}getHitDetectionImage(){return this.iconImage_.getHitDetectionImage()}getOrigin(){if(this.origin_)return this.origin_;let t=this.offset_;if(this.offsetOrigin_!="top-left"){const e=this.getSize(),i=this.iconImage_.getSize();if(!e||!i)return null;t=t.slice(),(this.offsetOrigin_=="top-right"||this.offsetOrigin_=="bottom-right")&&(t[0]=i[0]-e[0]-t[0]),(this.offsetOrigin_=="bottom-left"||this.offsetOrigin_=="bottom-right")&&(t[1]=i[1]-e[1]-t[1])}return this.origin_=t,this.origin_}getSrc(){return this.iconImage_.getSrc()}setSrc(t){this.iconImage_=Lr(null,t,this.crossOrigin_,$.IDLE,this.color_)}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){const t=this.getScaleArray();if(this.size_)return this.size_[0]*t[0];if(this.iconImage_.getImageState()==$.LOADED)return this.iconImage_.getSize()[0]*t[0]}getHeight(){const t=this.getScaleArray();if(this.size_)return this.size_[1]*t[1];if(this.iconImage_.getImageState()==$.LOADED)return this.iconImage_.getSize()[1]*t[1]}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(V.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(V.CHANGE,t)}ready(){return this.iconImage_.ready()}}const Jt=.5;function Uc(n,t,e,i,s,r,o,a,l){const h=l?Ko(s):s,c=n[0]*Jt,u=n[1]*Jt,d=ut(c,u);d.imageSmoothingEnabled=!1;const f=d.canvas,g=new E_(d,Jt,s,null,o,a,l?wr(yg(),l):null),m=e.length,_=Math.floor((256*256*256-1)/m),p={};for(let w=1;w<=m;++w){const x=e[w-1],E=x.getStyleFunction()||i;if(!E)continue;let C=E(x,r);if(!C)continue;Array.isArray(C)||(C=[C]);const S=(w*_).toString(16).padStart(7,"#00000");for(let b=0,v=C.length;b<v;++b){const I=C[b],A=I.getGeometryFunction()(x);if(!A||!ct(h,A.getExtent()))continue;const F=I.clone(),M=F.getFill();M&&M.setColor(S);const N=F.getStroke();N&&(N.setColor(S),N.setLineDash(null)),F.setText(void 0);const L=I.getImage();if(L){const Y=L.getImageSize();if(!Y)continue;const W=ut(Y[0],Y[1],void 0,{alpha:!1}),P=W.canvas;W.fillStyle=S,W.fillRect(0,0,P.width,P.height),F.setImage(new vn({img:P,anchor:L.getAnchor(),anchorXUnits:"pixels",anchorYUnits:"pixels",offset:L.getOrigin(),opacity:1,size:L.getSize(),scale:L.getScale(),rotation:L.getRotation(),rotateWithView:L.getRotateWithView()}))}const k=F.getZIndex()||0;let D=p[k];D||(D={},p[k]=D,D.Polygon=[],D.Circle=[],D.LineString=[],D.Point=[]);const X=A.getType();if(X==="GeometryCollection"){const Y=A.getGeometriesArrayRecursive();for(let W=0,P=Y.length;W<P;++W){const pt=Y[W];D[pt.getType().replace("Multi","")].push(pt,F)}}else D[X.replace("Multi","")].push(A,F)}}const y=Object.keys(p).map(Number).sort(Te);for(let w=0,x=y.length;w<x;++w){const E=p[y[w]];for(const C in E){const R=E[C];for(let S=0,b=R.length;S<b;S+=2){g.setStyle(R[S+1]);for(let v=0,I=t.length;v<I;++v)g.setTransform(t[v]),g.drawGeometry(R[S])}}}return d.getImageData(0,0,f.width,f.height)}function Zc(n,t,e){const i=[];if(e){const s=Math.floor(Math.round(n[0])*Jt),r=Math.floor(Math.round(n[1])*Jt),o=(rt(s,0,e.width-1)+rt(r,0,e.height-1)*e.width)*4,a=e.data[o],l=e.data[o+1],c=e.data[o+2]+256*(l+256*a),u=Math.floor((256*256*256-1)/t.length);c&&c%u===0&&i.push(t[c/u-1])}return i}class Hc extends ke{constructor(t,e,i,s){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=s}}const im=5;class nm extends qn{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.staleKeys_=new Array,this.maxStaleKeys=im}getStaleKeys(){return this.staleKeys_}prependStaleKey(t){this.staleKeys_.unshift(t),this.staleKeys_.length>this.maxStaleKeys&&(this.staleKeys_.length=this.maxStaleKeys)}getFeatures(t){return j()}getData(t){return null}prepareFrame(t){return j()}renderFrame(t,e){return j()}forEachFeatureAtCoordinate(t,e,i,s,r){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){const e=t.target;(e.getState()===$.LOADED||e.getState()===$.ERROR)&&this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=$.LOADED&&e!=$.ERROR&&t.addEventListener(V.CHANGE,this.boundHandleImageChange_),e==$.IDLE&&(t.load(),e=t.getState()),e==$.LOADED}renderIfReadyAndVisible(){const t=this.getLayer();t&&t.getVisible()&&t.getSourceState()==="ready"&&t.changed()}renderDeferred(t){}disposeInternal(){delete this.layer_,super.disposeInternal()}}const qc=[];let Cn=null;function sm(){Cn=ut(1,1,void 0,{willReadFrequently:!0})}class Jc extends nm{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=ae(),this.pixelTransform=ae(),this.inversePixelTransform=ae(),this.context=null,this.deferredContext_=null,this.containerReused=!1,this.frameState=null}getImageData(t,e,i){Cn||sm(),Cn.clearRect(0,0,1,1);let s;try{Cn.drawImage(t,e,i,1,1,0,0,1,1),s=Cn.getImageData(0,0,1,1).data}catch{return Cn=null,null}return s}getBackground(t){let i=this.getLayer().getBackground();return typeof i=="function"&&(i=i(t.viewState.resolution)),i||void 0}useContainer(t,e,i){const s=this.getLayer().getClassName();let r,o;if(t&&t.className===s&&(!i||t&&t.style.backgroundColor&&ai(_n(t.style.backgroundColor),_n(i)))){const a=t.firstElementChild;_i(a)&&(o=a.getContext("2d"))}if(o&&Rg(o.canvas.style.transform,e)?(this.container=t,this.context=o,this.containerReused=!0):this.containerReused?(this.container=null,this.context=null,this.containerReused=!1):this.container&&(this.container.style.backgroundColor=null),!this.container){r=Zt?dc():document.createElement("div"),r.className=s;let a=r.style;a.position="absolute",a.width="100%",a.height="100%",o=ut();const l=o.canvas;r.appendChild(l),a=l.style,a.position="absolute",a.left="0",a.transformOrigin="top left",this.container=r,this.context=o}!this.containerReused&&i&&!this.container.style.backgroundColor&&(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){const s=hi(i),r=cr(i),o=hr(i),a=lr(i);gt(e.coordinateToPixelTransform,s),gt(e.coordinateToPixelTransform,r),gt(e.coordinateToPixelTransform,o),gt(e.coordinateToPixelTransform,a);const l=this.inversePixelTransform;gt(l,s),gt(l,r),gt(l,o),gt(l,a),t.save(),t.beginPath(),t.moveTo(Math.round(s[0]),Math.round(s[1])),t.lineTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(o[0]),Math.round(o[1])),t.lineTo(Math.round(a[0]),Math.round(a[1])),t.clip()}prepareContainer(t,e){const i=t.extent,s=t.viewState.resolution,r=t.viewState.rotation,o=t.pixelRatio,a=Math.round(tt(i)/s*o),l=Math.round(Ot(i)/s*o);Xe(this.pixelTransform,t.size[0]/2,t.size[1]/2,1/o,1/o,r,-a/2,-l/2),$h(this.inversePixelTransform,this.pixelTransform);const h=Tg(this.pixelTransform);if(this.useContainer(e,h,this.getBackground(t)),!this.containerReused){const c=this.context.canvas;c.width!=a||c.height!=l?(c.width=a,c.height=l):this.context.clearRect(0,0,a,l),h!==c.style.transform&&(c.style.transform=h)}}dispatchRenderEvent_(t,e,i){const s=this.getLayer();if(s.hasListener(t)){const r=new Hc(t,this.inversePixelTransform,i,e);s.dispatchEvent(r)}}preRender(t,e){this.frameState=e,!e.declutter&&this.dispatchRenderEvent_(le.PRERENDER,t,e)}postRender(t,e){e.declutter||this.dispatchRenderEvent_(le.POSTRENDER,t,e)}renderDeferredInternal(t){}getRenderContext(t){return t.declutter&&!this.deferredContext_&&(this.deferredContext_=new La),t.declutter?this.deferredContext_.getContext():this.context}renderDeferred(t){t.declutter&&(this.dispatchRenderEvent_(le.PRERENDER,this.context,t),t.declutter&&this.deferredContext_&&(this.deferredContext_.draw(this.context),this.deferredContext_.clear()),this.renderDeferredInternal(t),this.dispatchRenderEvent_(le.POSTRENDER,this.context,t))}getRenderTransform(t,e,i,s,r,o,a){const l=r/2,h=o/2,c=s/e,u=-c,d=-t[0]+a,f=-t[1];return Xe(this.tempTransform,l,h,c,u,-i,d,f)}disposeInternal(){delete this.frameState,super.disposeInternal()}}class rm extends Jc{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.clipped_=!1,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=Kt(),this.wrappedRenderedExtent_=Kt(),this.renderedRotation_,this.renderedCenter_=null,this.renderedProjection_=null,this.renderedPixelRatio_=1,this.renderedRenderOrder_=null,this.renderedFrameDeclutter_,this.replayGroup_=null,this.replayGroupChanged=!0,this.clipping=!0,this.targetContext_=null,this.opacity_=1}renderWorlds(t,e,i){const s=e.extent,r=e.viewState,o=r.center,a=r.resolution,l=r.projection,h=r.rotation,c=l.getExtent(),u=this.getLayer().getSource(),d=this.getLayer().getDeclutter(),f=e.pixelRatio,g=e.viewHints,m=!(g[at.ANIMATING]||g[at.INTERACTING]),_=this.context,p=Math.round(tt(s)/a*f),y=Math.round(Ot(s)/a*f),w=u.getWrapX()&&l.canWrapX(),x=w?tt(c):null,E=w?Math.ceil((s[2]-c[2])/x)+1:1;let C=w?Math.floor((s[0]-c[0])/x):0;do{let R=this.getRenderTransform(o,a,0,f,p,y,C*x);e.declutter&&(R=R.slice(0)),t.execute(_,[_.canvas.width,_.canvas.height],R,h,m,i===void 0?ji:i?Br:tm,i?d&&e.declutter[d]:void 0)}while(++C<E)}setDrawContext_(){this.opacity_!==1&&(this.targetContext_=this.context,this.context=ut(this.context.canvas.width,this.context.canvas.height,qc))}resetDrawContext_(){if(this.opacity_!==1&&this.targetContext_){const t=this.targetContext_.globalAlpha;this.targetContext_.globalAlpha=this.opacity_,this.targetContext_.drawImage(this.context.canvas,0,0),this.targetContext_.globalAlpha=t,os(this.context),qc.push(this.context.canvas),this.context=this.targetContext_,this.targetContext_=null}}renderDeclutter(t){!this.replayGroup_||!this.getLayer().getDeclutter()||this.renderWorlds(this.replayGroup_,t,!0)}renderDeferredInternal(t){this.replayGroup_&&(this.replayGroup_.renderDeferred(),this.clipped_&&this.context.restore(),this.resetDrawContext_())}renderFrame(t,e){const i=t.layerStatesArray[t.layerIndex];this.opacity_=i.opacity;const s=t.viewState;this.prepareContainer(t,e);const r=this.context,o=this.replayGroup_;let a=o&&!o.isEmpty();if(!a&&!(this.getLayer().hasListener(le.PRERENDER)||this.getLayer().hasListener(le.POSTRENDER)))return this.container;if(this.setDrawContext_(),this.preRender(r,t),s.projection,this.clipped_=!1,a&&i.extent&&this.clipping){const l=ui(i.extent);a=ct(l,t.extent),this.clipped_=a&&!Oi(l,t.extent),this.clipped_&&this.clipUnrotated(r,t,l)}return a&&this.renderWorlds(o,t,this.getLayer().getDeclutter()?!1:void 0),!t.declutter&&this.clipped_&&r.restore(),this.postRender(r,t),this.renderedRotation_!==s.rotation&&(this.renderedRotation_=s.rotation,this.hitDetectionImageData_=null),t.declutter||this.resetDrawContext_(),this.container}getFeatures(t){return new Promise(e=>{if(this.frameState&&!this.hitDetectionImageData_&&!this.animatingOrInteracting_){const i=this.frameState.size.slice(),s=this.renderedCenter_,r=this.renderedResolution_,o=this.renderedRotation_,a=this.renderedProjection_,l=this.wrappedRenderedExtent_,h=this.getLayer(),c=[],u=i[0]*Jt,d=i[1]*Jt;c.push(this.getRenderTransform(s,r,o,Jt,u,d,0).slice());const f=h.getSource(),g=a.getExtent();if(f.getWrapX()&&a.canWrapX()&&!Oi(g,l)){let m=l[0];const _=tt(g);let p=0,y;for(;m<g[0];)--p,y=_*p,c.push(this.getRenderTransform(s,r,o,Jt,u,d,y).slice()),m+=_;for(p=0,m=l[2];m>g[2];)++p,y=_*p,c.push(this.getRenderTransform(s,r,o,Jt,u,d,y).slice()),m-=_}this.hitDetectionImageData_=Uc(i,c,this.renderedFeatures_,h.getStyleFunction(),l,r,o,Ra(r,this.renderedPixelRatio_),null)}e(Zc(t,this.renderedFeatures_,this.hitDetectionImageData_))})}forEachFeatureAtCoordinate(t,e,i,s,r){if(!this.replayGroup_)return;const o=e.viewState.resolution,a=e.viewState.rotation,l=this.getLayer(),h={},c=function(d,f,g){const m=B(d),_=h[m];if(_){if(_!==!0&&g<_.distanceSq){if(g===0)return h[m]=!0,r.splice(r.lastIndexOf(_),1),s(d,l,f);_.geometry=f,_.distanceSq=g}}else{if(g===0)return h[m]=!0,s(d,l,f);r.push(h[m]={feature:d,layer:l,geometry:f,distanceSq:g,callback:s})}},u=this.getLayer().getDeclutter();return this.replayGroup_.forEachFeatureAtCoordinate(t,o,a,i,c,u?e.declutter?.[u]?.all().map(d=>d.value):null)}handleFontsChanged(){const t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){const e=this.getLayer(),i=e.getSource();if(!i)return!1;const s=t.viewHints[at.ANIMATING],r=t.viewHints[at.INTERACTING],o=e.getUpdateWhileAnimating(),a=e.getUpdateWhileInteracting();if(this.ready&&!o&&s||!a&&r)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;const l=t.extent,h=t.viewState,c=h.projection,u=h.resolution,d=t.pixelRatio,f=e.getRevision(),g=e.getRenderBuffer();let m=e.getRenderOrder();m===void 0&&(m=v_);const _=h.center.slice(),p=li(l,g*u),y=p.slice(),w=[p.slice()],x=c.getExtent();if(i.getWrapX()&&c.canWrapX()&&!Oi(x,t.extent)){const M=tt(x),N=Math.max(tt(p)/2,M);p[0]=x[0]-N,p[2]=x[2]+N,Fo(_,c);const L=Ch(w[0],c);L[0]<x[0]&&L[2]<x[2]?w.push([L[0]+M,L[1],L[2]+M,L[3]]):L[0]>x[0]&&L[2]>x[2]&&w.push([L[0]-M,L[1],L[2]-M,L[3]])}if(this.ready&&this.renderedResolution_==u&&this.renderedRevision_==f&&this.renderedRenderOrder_==m&&this.renderedFrameDeclutter_===!!t.declutter&&Oi(this.wrappedRenderedExtent_,p))return ai(this.renderedExtent_,y)||(this.hitDetectionImageData_=null,this.renderedExtent_=y),this.renderedCenter_=_,this.replayGroupChanged=!1,!0;this.replayGroup_=null;const E=new Vc(Rc(u,d),p,u,d);let C;for(let M=0,N=w.length;M<N;++M)i.loadFeatures(w[M],u,c);const R=Ra(u,d);let S=!0;const b=(M,N)=>{let L;const k=M.getStyleFunction()||e.getStyleFunction();if(k&&(L=k(M,u)),L){const D=this.renderFeature(M,R,L,E,C,this.getLayer().getDeclutter(),N);S=S&&!D}},v=Ko(p),I=i.getFeaturesInExtent(v);m&&I.sort(m);for(let M=0,N=I.length;M<N;++M)b(I[M],M);this.renderedFeatures_=I,this.ready=S;const A=E.finish(),F=new Kc(p,u,d,i.getOverlaps(),A,e.getRenderBuffer(),!!t.declutter);return this.renderedResolution_=u,this.renderedRevision_=f,this.renderedRenderOrder_=m,this.renderedFrameDeclutter_=!!t.declutter,this.renderedExtent_=y,this.wrappedRenderedExtent_=p,this.renderedCenter_=_,this.renderedProjection_=c,this.renderedPixelRatio_=d,this.replayGroup_=F,this.hitDetectionImageData_=null,this.replayGroupChanged=!0,!0}renderFeature(t,e,i,s,r,o,a){if(!i)return!1;let l=!1;if(Array.isArray(i))for(let h=0,c=i.length;h<c;++h)l=Fr(s,t,i[h],e,this.boundHandleStyleImageChange_,r,o,a)||l;else l=Fr(s,t,i,e,this.boundHandleStyleImageChange_,r,o,a);return l}}let Ui=0;const Dt=1<<Ui++,U=1<<Ui++,Wt=1<<Ui++,Ee=1<<Ui++,Zi=1<<Ui++,xs=1<<Ui++,$r=Math.pow(2,Ui)-1,Ma={[Dt]:"boolean",[U]:"number",[Wt]:"string",[Ee]:"color",[Zi]:"number[]",[xs]:"size"},om=Object.keys(Ma).map(Number).sort(Te);function am(n){return n in Ma}function Es(n){const t=[];for(const e of om)ws(n,e)&&t.push(Ma[e]);return t.length===0?"untyped":t.length<3?t.join(" or "):t.slice(0,-1).join(", ")+", or "+t[t.length-1]}function ws(n,t){return(n&t)===t}function Ei(n,t){return n===t}class mt{constructor(t,e){if(!am(t))throw new Error(`literal expressions must have a specific type, got ${Es(t)}`);this.type=t,this.value=e}}class lm{constructor(t,e,...i){this.type=t,this.operator=e,this.args=i}}function Qc(){return{variables:new Set,properties:new Set,featureId:!1,geometryType:!1,mapState:!1}}function Ct(n,t,e){switch(typeof n){case"boolean":{if(Ei(t,Wt))return new mt(Wt,n?"true":"false");if(!ws(t,Dt))throw new Error(`got a boolean, but expected ${Es(t)}`);return new mt(Dt,n)}case"number":{if(Ei(t,xs))return new mt(xs,Rt(n));if(Ei(t,Dt))return new mt(Dt,!!n);if(Ei(t,Wt))return new mt(Wt,n.toString());if(!ws(t,U))throw new Error(`got a number, but expected ${Es(t)}`);return new mt(U,n)}case"string":{if(Ei(t,Ee))return new mt(Ee,ya(n));if(Ei(t,Dt))return new mt(Dt,!!n);if(!ws(t,Wt))throw new Error(`got a string, but expected ${Es(t)}`);return new mt(Wt,n)}}if(!Array.isArray(n))throw new Error("expression must be an array or a primitive value");if(n.length===0)throw new Error("empty expression");if(typeof n[0]=="string")return xm(n,t,e);for(const i of n)if(typeof i!="number")throw new Error("expected an array of numbers");if(Ei(t,xs)){if(n.length!==2)throw new Error(`expected an array of two values for a size, got ${n.length}`);return new mt(xs,n)}if(Ei(t,Ee)){if(n.length===3)return new mt(Ee,[...n,1]);if(n.length===4)return new mt(Ee,n);throw new Error(`expected an array of 3 or 4 values for a color, got ${n.length}`)}if(!ws(t,Zi))throw new Error(`got an array of numbers, but expected ${Es(t)}`);return new mt(Zi,n)}const T={Get:"get",Var:"var",Concat:"concat",GeometryType:"geometry-type",LineMetric:"line-metric",Any:"any",All:"all",Not:"!",Resolution:"resolution",Zoom:"zoom",Time:"time",Equal:"==",NotEqual:"!=",GreaterThan:">",GreaterThanOrEqualTo:">=",LessThan:"<",LessThanOrEqualTo:"<=",Multiply:"*",Divide:"/",Add:"+",Subtract:"-",Clamp:"clamp",Mod:"%",Pow:"^",Abs:"abs",Floor:"floor",Ceil:"ceil",Round:"round",Sin:"sin",Cos:"cos",Atan:"atan",Sqrt:"sqrt",Match:"match",Between:"between",Interpolate:"interpolate",Coalesce:"coalesce",Case:"case",In:"in",Number:"number",String:"string",Array:"array",Color:"color",Id:"id",Band:"band",Palette:"palette",ToString:"to-string",Has:"has"},hm={[T.Get]:z(K(1,1/0),tu),[T.Var]:z(K(1,1),cm),[T.Has]:z(K(1,1/0),tu),[T.Id]:z(um,Tn),[T.Concat]:z(K(2,1/0),Q(Wt)),[T.GeometryType]:z(dm,Tn),[T.LineMetric]:z(Tn),[T.Resolution]:z(Fa,Tn),[T.Zoom]:z(Fa,Tn),[T.Time]:z(Fa,Tn),[T.Any]:z(K(2,1/0),Q(Dt)),[T.All]:z(K(2,1/0),Q(Dt)),[T.Not]:z(K(1,1),Q(Dt)),[T.Equal]:z(K(2,2),Q($r)),[T.NotEqual]:z(K(2,2),Q($r)),[T.GreaterThan]:z(K(2,2),Q(U)),[T.GreaterThanOrEqualTo]:z(K(2,2),Q(U)),[T.LessThan]:z(K(2,2),Q(U)),[T.LessThanOrEqualTo]:z(K(2,2),Q(U)),[T.Multiply]:z(K(2,1/0),eu),[T.Coalesce]:z(K(2,1/0),eu),[T.Divide]:z(K(2,2),Q(U)),[T.Add]:z(K(2,1/0),Q(U)),[T.Subtract]:z(K(2,2),Q(U)),[T.Clamp]:z(K(3,3),Q(U)),[T.Mod]:z(K(2,2),Q(U)),[T.Pow]:z(K(2,2),Q(U)),[T.Abs]:z(K(1,1),Q(U)),[T.Floor]:z(K(1,1),Q(U)),[T.Ceil]:z(K(1,1),Q(U)),[T.Round]:z(K(1,1),Q(U)),[T.Sin]:z(K(1,1),Q(U)),[T.Cos]:z(K(1,1),Q(U)),[T.Atan]:z(K(1,2),Q(U)),[T.Sqrt]:z(K(1,1),Q(U)),[T.Match]:z(K(4,1/0),iu,gm),[T.Between]:z(K(3,3),Q(U)),[T.Interpolate]:z(K(6,1/0),iu,_m),[T.Case]:z(K(3,1/0),fm,mm),[T.In]:z(K(2,2),pm),[T.Number]:z(K(1,1/0),Q($r)),[T.String]:z(K(1,1/0),Q($r)),[T.Array]:z(K(1,1/0),Q(U)),[T.Color]:z(K(1,4),Q(U)),[T.Band]:z(K(1,3),Q(U)),[T.Palette]:z(K(2,2),ym),[T.ToString]:z(K(1,1),Q(Dt|U|Wt|Ee))};function tu(n,t,e){const i=n.length-1,s=new Array(i);for(let r=0;r<i;++r){const o=n[r+1];switch(typeof o){case"number":{s[r]=new mt(U,o);break}case"string":{s[r]=new mt(Wt,o);break}default:throw new Error(`expected a string key or numeric array index for a get operation, got ${o}`)}r===0&&e.properties.add(String(o))}return s}function cm(n,t,e){const i=n[1];if(typeof i!="string")throw new Error("expected a string argument for var operation");return e.variables.add(i),[new mt(Wt,i)]}function um(n,t,e){e.featureId=!0}function dm(n,t,e){e.geometryType=!0}function Fa(n,t,e){e.mapState=!0}function Tn(n,t,e){const i=n[0];if(n.length!==1)throw new Error(`expected no arguments for ${i} operation`);return[]}function K(n,t){return function(e,i,s){const r=e[0],o=e.length-1;if(n===t){if(o!==n){const a=n===1?"":"s";throw new Error(`expected ${n} argument${a} for ${r}, got ${o}`)}}else if(o<n||o>t){const a=t===1/0?`${n} or more`:`${n} to ${t}`;throw new Error(`expected ${a} arguments for ${r}, got ${o}`)}}}function eu(n,t,e){const i=n.length-1,s=new Array(i);for(let r=0;r<i;++r){const o=Ct(n[r+1],t,e);s[r]=o}return s}function Q(n){return function(t,e,i){const s=t.length-1,r=new Array(s);for(let o=0;o<s;++o){const a=Ct(t[o+1],n,i);r[o]=a}return r}}function fm(n,t,e){const i=n[0],s=n.length-1;if(s%2===0)throw new Error(`expected an odd number of arguments for ${i}, got ${s} instead`)}function iu(n,t,e){const i=n[0],s=n.length-1;if(s%2===1)throw new Error(`expected an even number of arguments for operation ${i}, got ${s} instead`)}function gm(n,t,e){const i=n.length-1,s=Wt|U|Dt,r=Ct(n[1],s,e),o=Ct(n[n.length-1],t,e),a=new Array(i-2);for(let l=0;l<i-2;l+=2){try{const h=Ct(n[l+2],r.type,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+1} of match expression: ${h.message}`)}try{const h=Ct(n[l+3],o.type,e);a[l+1]=h}catch(h){throw new Error(`failed to parse argument ${l+2} of match expression: ${h.message}`)}}return[r,...a,o]}function _m(n,t,e){const i=n[1];let s;switch(i[0]){case"linear":s=1;break;case"exponential":const l=i[1];if(typeof l!="number"||l<=0)throw new Error(`expected a number base for exponential interpolation, got ${JSON.stringify(l)} instead`);s=l;break;default:throw new Error(`invalid interpolation type: ${JSON.stringify(i)}`)}const r=new mt(U,s);let o;try{o=Ct(n[2],U,e)}catch(l){throw new Error(`failed to parse argument 1 in interpolate expression: ${l.message}`)}const a=new Array(n.length-3);for(let l=0;l<a.length;l+=2){try{const h=Ct(n[l+3],U,e);a[l]=h}catch(h){throw new Error(`failed to parse argument ${l+2} for interpolate expression: ${h.message}`)}try{const h=Ct(n[l+4],t,e);a[l+1]=h}catch(h){throw new Error(`failed to parse argument ${l+3} for interpolate expression: ${h.message}`)}}return[r,o,...a]}function mm(n,t,e){const i=Ct(n[n.length-1],t,e),s=new Array(n.length-1);for(let r=0;r<s.length-1;r+=2){try{const o=Ct(n[r+1],Dt,e);s[r]=o}catch(o){throw new Error(`failed to parse argument ${r} of case expression: ${o.message}`)}try{const o=Ct(n[r+2],i.type,e);s[r+1]=o}catch(o){throw new Error(`failed to parse argument ${r+1} of case expression: ${o.message}`)}}return s[s.length-1]=i,s}function pm(n,t,e){let i=n[2];if(!Array.isArray(i))throw new Error('the second argument for the "in" operator must be an array');let s;if(typeof i[0]=="string"){if(i[0]!=="literal")throw new Error('for the "in" operator, a string array should be wrapped in a "literal" operator to disambiguate from expressions');if(!Array.isArray(i[1]))throw new Error('failed to parse "in" expression: the literal operator must be followed by an array');i=i[1],s=Wt}else s=U;const r=new Array(i.length);for(let a=0;a<r.length;a++)try{const l=Ct(i[a],s,e);r[a]=l}catch(l){throw new Error(`failed to parse haystack item ${a} for "in" expression: ${l.message}`)}return[Ct(n[1],s,e),...r]}function ym(n,t,e){let i;try{i=Ct(n[1],U,e)}catch(o){throw new Error(`failed to parse first argument in palette expression: ${o.message}`)}const s=n[2];if(!Array.isArray(s))throw new Error("the second argument of palette must be an array");const r=new Array(s.length);for(let o=0;o<r.length;o++){let a;try{a=Ct(s[o],Ee,e)}catch(l){throw new Error(`failed to parse color at index ${o} in palette expression: ${l.message}`)}if(!(a instanceof mt))throw new Error(`the palette color at index ${o} must be a literal value`);r[o]=a}return[i,...r]}function z(...n){return function(t,e,i){const s=t[0];let r;for(let o=0;o<n.length;o++){const a=n[o](t,e,i);if(o==n.length-1){if(!a)throw new Error("expected last argument validator to return the parsed args");r=a}}return new lm(e,s,...r)}}function xm(n,t,e){const i=n[0],s=hm[i];if(!s)throw new Error(`unknown operator: ${i}`);return s(n,t,e)}function nu(n){if(!n)return"";const t=n.getType();switch(t){case"Point":case"LineString":case"Polygon":return t;case"MultiPoint":case"MultiLineString":case"MultiPolygon":return t.substring(5);case"Circle":return"Polygon";case"GeometryCollection":return nu(n.getGeometries()[0]);default:return""}}function su(){return{variables:{},properties:{},resolution:NaN,featureId:null,geometryType:""}}function $e(n,t,e){const i=Ct(n,t,e);return we(i)}function we(n,t){if(n instanceof mt){if(n.type===Ee&&typeof n.value=="string"){const i=ya(n.value);return function(){return i}}return function(){return n.value}}const e=n.operator;switch(e){case T.Number:case T.String:case T.Coalesce:return Em(n);case T.Get:case T.Var:case T.Has:return wm(n);case T.Id:return i=>i.featureId;case T.GeometryType:return i=>i.geometryType;case T.Concat:{const i=n.args.map(s=>we(s));return s=>"".concat(...i.map(r=>r(s).toString()))}case T.Resolution:return i=>i.resolution;case T.Any:case T.All:case T.Between:case T.In:case T.Not:return Cm(n);case T.Equal:case T.NotEqual:case T.LessThan:case T.LessThanOrEqualTo:case T.GreaterThan:case T.GreaterThanOrEqualTo:return vm(n);case T.Multiply:case T.Divide:case T.Add:case T.Subtract:case T.Clamp:case T.Mod:case T.Pow:case T.Abs:case T.Floor:case T.Ceil:case T.Round:case T.Sin:case T.Cos:case T.Atan:case T.Sqrt:return Tm(n);case T.Case:return Rm(n);case T.Match:return Sm(n);case T.Interpolate:return Im(n);case T.ToString:return bm(n);default:throw new Error(`Unsupported operator ${e}`)}}function Em(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=we(n.args[r]);switch(e){case T.Coalesce:return r=>{for(let o=0;o<i;++o){const a=s[o](r);if(typeof a<"u"&&a!==null)return a}throw new Error("Expected one of the values to be non-null")};case T.Number:case T.String:return r=>{for(let o=0;o<i;++o){const a=s[o](r);if(typeof a===e)return a}throw new Error(`Expected one of the values to be a ${e}`)};default:throw new Error(`Unsupported assertion operator ${e}`)}}function wm(n,t){const i=n.args[0].value;switch(n.operator){case T.Get:return s=>{const r=n.args;let o=s.properties[i];for(let a=1,l=r.length;a<l;++a){const c=r[a].value;o=o[c]}return o};case T.Var:return s=>s.variables[i];case T.Has:return s=>{const r=n.args;if(!(i in s.properties))return!1;let o=s.properties[i];for(let a=1,l=r.length;a<l;++a){const c=r[a].value;if(!o||!Object.hasOwn(o,c))return!1;o=o[c]}return!0};default:throw new Error(`Unsupported accessor operator ${n.operator}`)}}function vm(n,t){const e=n.operator,i=we(n.args[0]),s=we(n.args[1]);switch(e){case T.Equal:return r=>i(r)===s(r);case T.NotEqual:return r=>i(r)!==s(r);case T.LessThan:return r=>i(r)<s(r);case T.LessThanOrEqualTo:return r=>i(r)<=s(r);case T.GreaterThan:return r=>i(r)>s(r);case T.GreaterThanOrEqualTo:return r=>i(r)>=s(r);default:throw new Error(`Unsupported comparison operator ${e}`)}}function Cm(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=we(n.args[r]);switch(e){case T.Any:return r=>{for(let o=0;o<i;++o)if(s[o](r))return!0;return!1};case T.All:return r=>{for(let o=0;o<i;++o)if(!s[o](r))return!1;return!0};case T.Between:return r=>{const o=s[0](r),a=s[1](r),l=s[2](r);return o>=a&&o<=l};case T.In:return r=>{const o=s[0](r);for(let a=1;a<i;++a)if(o===s[a](r))return!0;return!1};case T.Not:return r=>!s[0](r);default:throw new Error(`Unsupported logical operator ${e}`)}}function Tm(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=we(n.args[r]);switch(e){case T.Multiply:return r=>{let o=1;for(let a=0;a<i;++a)o*=s[a](r);return o};case T.Divide:return r=>s[0](r)/s[1](r);case T.Add:return r=>{let o=0;for(let a=0;a<i;++a)o+=s[a](r);return o};case T.Subtract:return r=>s[0](r)-s[1](r);case T.Clamp:return r=>{const o=s[0](r),a=s[1](r);if(o<a)return a;const l=s[2](r);return o>l?l:o};case T.Mod:return r=>s[0](r)%s[1](r);case T.Pow:return r=>Math.pow(s[0](r),s[1](r));case T.Abs:return r=>Math.abs(s[0](r));case T.Floor:return r=>Math.floor(s[0](r));case T.Ceil:return r=>Math.ceil(s[0](r));case T.Round:return r=>Math.round(s[0](r));case T.Sin:return r=>Math.sin(s[0](r));case T.Cos:return r=>Math.cos(s[0](r));case T.Atan:return i===2?r=>Math.atan2(s[0](r),s[1](r)):r=>Math.atan(s[0](r));case T.Sqrt:return r=>Math.sqrt(s[0](r));default:throw new Error(`Unsupported numeric operator ${e}`)}}function Rm(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=we(n.args[s]);return s=>{for(let r=0;r<e-1;r+=2)if(i[r](s))return i[r+1](s);return i[e-1](s)}}function Sm(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=we(n.args[s]);return s=>{const r=i[0](s);for(let o=1;o<e-1;o+=2)if(r===i[o](s))return i[o+1](s);return i[e-1](s)}}function Im(n,t){const e=n.args.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=we(n.args[s]);return s=>{const r=i[0](s),o=i[1](s);let a,l;for(let h=2;h<e;h+=2){const c=i[h](s);let u=i[h+1](s);const d=Array.isArray(u);if(d&&(u=s_(u)),c>=o)return h===2?u:d?Lm(r,o,a,l,c,u):vs(r,o,a,l,c,u);a=c,l=u}return l}}function bm(n,t){const e=n.operator,i=n.args.length,s=new Array(i);for(let r=0;r<i;++r)s[r]=we(n.args[r]);switch(e){case T.ToString:return r=>{const o=s[0](r);return n.args[0].type===Ee?xa(o):o.toString()};default:throw new Error(`Unsupported convert operator ${e}`)}}function vs(n,t,e,i,s,r){const o=s-e;if(o===0)return i;const a=t-e,l=n===1?a/o:(Math.pow(n,a)-1)/(Math.pow(n,o)-1);return i+l*(r-i)}function Lm(n,t,e,i,s,r){if(s-e===0)return i;const a=gc(i),l=gc(r);let h=l[2]-a[2];h>180?h-=360:h<-180&&(h+=360);const c=[vs(n,t,e,a[0],s,l[0]),vs(n,t,e,a[1],s,l[1]),a[2]+vs(n,t,e,0,s,h),vs(n,t,e,i[3],s,r[3])];return r_(c)}function Am(n){return!0}function Pm(n){const t=Qc(),e=Mm(n,t),i=su();return function(s,r){if(i.properties=s.getPropertiesInternal(),i.resolution=r,t.featureId){const o=s.getId();o!==void 0?i.featureId=o:i.featureId=null}return t.geometryType&&(i.geometryType=nu(s.getGeometry())),e(i)}}function ru(n){const t=Qc(),e=n.length,i=new Array(e);for(let o=0;o<e;++o)i[o]=Oa(n[o],t);const s=su(),r=new Array(e);return function(o,a){if(s.properties=o.getPropertiesInternal(),s.resolution=a,t.featureId){const h=o.getId();h!==void 0?s.featureId=h:s.featureId=null}let l=0;for(let h=0;h<e;++h){const c=i[h](s);c&&(r[l]=c,l+=1)}return r.length=l,r}}function Mm(n,t){const e=n.length,i=new Array(e);for(let s=0;s<e;++s){const r=n[s],o="filter"in r?$e(r.filter,Dt,t):Am;let a;if(Array.isArray(r.style)){const l=r.style.length;a=new Array(l);for(let h=0;h<l;++h)a[h]=Oa(r.style[h],t)}else a=[Oa(r.style,t)];i[s]={filter:o,styles:a}}return function(s){const r=[];let o=!1;for(let a=0;a<e;++a){const l=i[a].filter;if(l(s)&&!(n[a].else&&o)){o=!0;for(const h of i[a].styles){const c=h(s);c&&r.push(c)}}}return r}}function Oa(n,t){const e=Cs(n,"",t),i=Ts(n,"",t),s=Fm(n,t),r=Om(n,t),o=Vt(n,"z-index",t);if(!e&&!i&&!s&&!r&&!Fi(n))throw new Error("No fill, stroke, point, or text symbolizer properties in style: "+JSON.stringify(n));const a=new _t;return function(l){let h=!0;if(e){const c=e(l);c&&(h=!1),a.setFill(c)}if(i){const c=i(l);c&&(h=!1),a.setStroke(c)}if(s){const c=s(l);c&&(h=!1),a.setText(c)}if(r){const c=r(l);c&&(h=!1),a.setImage(c)}return o&&a.setZIndex(o(l)),h?null:a}}function Cs(n,t,e){let i;if(t+"fill-pattern-src"in n)i=Gm(n,t+"fill-",e);else{if(n[t+"fill-color"]==="none")return r=>null;i=Da(n,t+"fill-color",e)}if(!i)return null;const s=new qt;return function(r){const o=i(r);return o===ua?null:(s.setColor(o),s)}}function Ts(n,t,e){const i=Vt(n,t+"stroke-width",e),s=Da(n,t+"stroke-color",e);if(!i&&!s)return null;const r=Ke(n,t+"stroke-line-cap",e),o=Ke(n,t+"stroke-line-join",e),a=ou(n,t+"stroke-line-dash",e),l=Vt(n,t+"stroke-line-dash-offset",e),h=Vt(n,t+"stroke-miter-limit",e),c=new xe;return function(u){if(s){const d=s(u);if(d===ua)return null;c.setColor(d)}if(i&&c.setWidth(i(u)),r){const d=r(u);if(d!=="butt"&&d!=="round"&&d!=="square")throw new Error("Expected butt, round, or square line cap");c.setLineCap(d)}if(o){const d=o(u);if(d!=="bevel"&&d!=="round"&&d!=="miter")throw new Error("Expected bevel, round, or miter line join");c.setLineJoin(d)}return a&&c.setLineDash(a(u)),l&&c.setLineDashOffset(l(u)),h&&c.setMiterLimit(h(u)),c}}function Fm(n,t){const e="text-",i=Ke(n,e+"value",t);if(!i)return null;const s=Cs(n,e,t),r=Cs(n,e+"background-",t),o=Ts(n,e,t),a=Ts(n,e+"background-",t),l=Ke(n,e+"font",t),h=Vt(n,e+"max-angle",t),c=Vt(n,e+"offset-x",t),u=Vt(n,e+"offset-y",t),d=Rn(n,e+"overflow",t),f=Ke(n,e+"placement",t),g=Vt(n,e+"repeat",t),m=jr(n,e+"scale",t),_=Rn(n,e+"rotate-with-view",t),p=Vt(n,e+"rotation",t),y=Ke(n,e+"align",t),w=Ke(n,e+"justify",t),x=Ke(n,e+"baseline",t),E=Rn(n,e+"keep-upright",t),C=ou(n,e+"padding",t),R=Zr(n,e+"declutter-mode"),S=new Xc({declutterMode:R});return function(b){if(S.setText(i(b)),s&&S.setFill(s(b)),r&&S.setBackgroundFill(r(b)),o&&S.setStroke(o(b)),a&&S.setBackgroundStroke(a(b)),l&&S.setFont(l(b)),h&&S.setMaxAngle(h(b)),c&&S.setOffsetX(c(b)),u&&S.setOffsetY(u(b)),d&&S.setOverflow(d(b)),f){const v=f(b);if(v!=="point"&&v!=="line")throw new Error("Expected point or line for text-placement");S.setPlacement(v)}if(g&&S.setRepeat(g(b)),m&&S.setScale(m(b)),_&&S.setRotateWithView(_(b)),p&&S.setRotation(p(b)),y){const v=y(b);if(v!=="left"&&v!=="center"&&v!=="right"&&v!=="end"&&v!=="start")throw new Error("Expected left, right, center, start, or end for text-align");S.setTextAlign(v)}if(w){const v=w(b);if(v!=="left"&&v!=="right"&&v!=="center")throw new Error("Expected left, right, or center for text-justify");S.setJustify(v)}if(x){const v=x(b);if(v!=="bottom"&&v!=="top"&&v!=="middle"&&v!=="alphabetic"&&v!=="hanging")throw new Error("Expected bottom, top, middle, alphabetic, or hanging for text-baseline");S.setTextBaseline(v)}return C&&S.setPadding(C(b)),E&&S.setKeepUpright(E(b)),S}}function Om(n,t){return"icon-src"in n?Dm(n,t):"shape-points"in n?km(n,t):"circle-radius"in n?Nm(n,t):null}function Dm(n,t){const e="icon-",i=e+"src",s=cu(n[i],i),r=Kr(n,e+"anchor",t),o=jr(n,e+"scale",t),a=Vt(n,e+"opacity",t),l=Kr(n,e+"displacement",t),h=Vt(n,e+"rotation",t),c=Rn(n,e+"rotate-with-view",t),u=lu(n,e+"anchor-origin"),d=hu(n,e+"anchor-x-units"),f=hu(n,e+"anchor-y-units"),g=Wm(n,e+"color"),m=Xm(n,e+"cross-origin"),_=Ym(n,e+"offset"),p=lu(n,e+"offset-origin"),y=Ur(n,e+"width"),w=Ur(n,e+"height"),x=zm(n,e+"size"),E=Zr(n,e+"declutter-mode"),C=new vn({src:s,anchorOrigin:u,anchorXUnits:d,anchorYUnits:f,color:g,crossOrigin:m,offset:_,offsetOrigin:p,height:w,width:y,size:x,declutterMode:E});return function(R){return a&&C.setOpacity(a(R)),l&&C.setDisplacement(l(R)),h&&C.setRotation(h(R)),c&&C.setRotateWithView(c(R)),o&&C.setScale(o(R)),r&&C.setAnchor(r(R)),C}}function km(n,t){const e="shape-",i=e+"points",s=e+"radius",r=ka(n[i],i),o=ka(n[s],s),a=Cs(n,e,t),l=Ts(n,e,t),h=jr(n,e+"scale",t),c=Kr(n,e+"displacement",t),u=Vt(n,e+"rotation",t),d=Rn(n,e+"rotate-with-view",t),f=Ur(n,e+"radius2"),g=Ur(n,e+"angle"),m=Zr(n,e+"declutter-mode"),_=new Xr({points:r,radius:o,radius2:f,angle:g,declutterMode:m});return function(p){return a&&_.setFill(a(p)),l&&_.setStroke(l(p)),c&&_.setDisplacement(c(p)),u&&_.setRotation(u(p)),d&&_.setRotateWithView(d(p)),h&&_.setScale(h(p)),_}}function Nm(n,t){const e="circle-",i=Cs(n,e,t),s=Ts(n,e,t),r=Vt(n,e+"radius",t),o=jr(n,e+"scale",t),a=Kr(n,e+"displacement",t),l=Vt(n,e+"rotation",t),h=Rn(n,e+"rotate-with-view",t),c=Zr(n,e+"declutter-mode"),u=new Yr({radius:5,declutterMode:c});return function(d){return r&&u.setRadius(r(d)),i&&u.setFill(i(d)),s&&u.setStroke(s(d)),a&&u.setDisplacement(a(d)),l&&u.setRotation(l(d)),h&&u.setRotateWithView(h(d)),o&&u.setScale(o(d)),u}}function Vt(n,t,e){if(!(t in n))return;const i=$e(n[t],U,e);return function(s){return ka(i(s),t)}}function Ke(n,t,e){if(!(t in n))return null;const i=$e(n[t],Wt,e);return function(s){return cu(i(s),t)}}function Gm(n,t,e){const i=Ke(n,t+"pattern-src",e),s=au(n,t+"pattern-offset",e),r=au(n,t+"pattern-size",e),o=Da(n,t+"color",e);return function(a){return{src:i(a),offset:s&&s(a),size:r&&r(a),color:o&&o(a)}}}function Rn(n,t,e){if(!(t in n))return null;const i=$e(n[t],Dt,e);return function(s){const r=i(s);if(typeof r!="boolean")throw new Error(`Expected a boolean for ${t}`);return r}}function Da(n,t,e){if(!(t in n))return null;const i=$e(n[t],Ee,e);return function(s){return uu(i(s),t)}}function ou(n,t,e){if(!(t in n))return null;const i=$e(n[t],Zi,e);return function(s){return Rs(i(s),t)}}function Kr(n,t,e){if(!(t in n))return null;const i=$e(n[t],Zi,e);return function(s){const r=Rs(i(s),t);if(r.length!==2)throw new Error(`Expected two numbers for ${t}`);return r}}function au(n,t,e){if(!(t in n))return null;const i=$e(n[t],Zi,e);return function(s){return du(i(s),t)}}function jr(n,t,e){if(!(t in n))return null;const i=$e(n[t],Zi|U,e);return function(s){return Vm(i(s),t)}}function Ur(n,t){const e=n[t];if(e!==void 0){if(typeof e!="number")throw new Error(`Expected a number for ${t}`);return e}}function zm(n,t){const e=n[t];if(e!==void 0){if(typeof e=="number")return Rt(e);if(!Array.isArray(e))throw new Error(`Expected a number or size array for ${t}`);if(e.length!==2||typeof e[0]!="number"||typeof e[1]!="number")throw new Error(`Expected a number or size array for ${t}`);return e}}function Xm(n,t){const e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);return e}}function lu(n,t){const e=n[t];if(e!==void 0){if(e!=="bottom-left"&&e!=="bottom-right"&&e!=="top-left"&&e!=="top-right")throw new Error(`Expected bottom-left, bottom-right, top-left, or top-right for ${t}`);return e}}function hu(n,t){const e=n[t];if(e!==void 0){if(e!=="pixels"&&e!=="fraction")throw new Error(`Expected pixels or fraction for ${t}`);return e}}function Ym(n,t){const e=n[t];if(e!==void 0)return Rs(e,t)}function Zr(n,t){const e=n[t];if(e!==void 0){if(typeof e!="string")throw new Error(`Expected a string for ${t}`);if(e!=="declutter"&&e!=="obstacle"&&e!=="none")throw new Error(`Expected declutter, obstacle, or none for ${t}`);return e}}function Wm(n,t){const e=n[t];if(e!==void 0)return uu(e,t)}function Rs(n,t){if(!Array.isArray(n))throw new Error(`Expected an array for ${t}`);const e=n.length;for(let i=0;i<e;++i)if(typeof n[i]!="number")throw new Error(`Expected an array of numbers for ${t}`);return n}function cu(n,t){if(typeof n!="string")throw new Error(`Expected a string for ${t}`);return n}function ka(n,t){if(typeof n!="number")throw new Error(`Expected a number for ${t}`);return n}function uu(n,t){if(typeof n=="string")return n;const e=Rs(n,t),i=e.length;if(i<3||i>4)throw new Error(`Expected a color with 3 or 4 values for ${t}`);return e}function du(n,t){const e=Rs(n,t);if(e.length!==2)throw new Error(`Expected an array of two numbers for ${t}`);return e}function Vm(n,t){return typeof n=="number"?n:du(n,t)}const ve={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};function fu(n,t,e){return(function(i,s,r,o,a){if(!i)return;if(!s&&!t)return i;const l=t?0:r[0]*s,h=t?0:r[1]*s,c=a?a[0]:0,u=a?a[1]:0;let d=n[0]+l/2+c,f=n[2]-l/2+c,g=n[1]+h/2+u,m=n[3]-h/2+u;d>f&&(d=(f+d)/2,f=d),g>m&&(g=(m+g)/2,m=g);let _=rt(i[0],d,f),p=rt(i[1],g,m);if(o&&e&&s){const y=30*s;_+=-y*Math.log(1+Math.max(0,d-i[0])/y)+y*Math.log(1+Math.max(0,i[0]-f)/y),p+=-y*Math.log(1+Math.max(0,g-i[1])/y)+y*Math.log(1+Math.max(0,i[1]-m)/y)}return[_,p]})}function Bm(n){return n}function gu(n){return Math.pow(n,3)}function Sn(n){return 1-gu(1-n)}function $m(n){return 3*n*n-2*n*n*n}function Km(n){return n}function Na(n,t,e,i){const s=tt(t)/e[0],r=Ot(t)/e[1];return i?Math.min(n,Math.max(s,r)):Math.min(n,Math.min(s,r))}function Ga(n,t,e){let i=Math.min(n,t);const s=50;return i*=Math.log(1+s*Math.max(0,n/t-1))/s+1,e&&(i=Math.max(i,e),i/=Math.log(1+s*Math.max(0,e/n-1))/s+1),rt(i,e/2,t*2)}function jm(n,t,e,i){return t=t!==void 0?t:!0,(function(s,r,o,a){if(s!==void 0){const l=n[0],h=n[n.length-1],c=e?Na(l,e,o,i):l;if(a)return t?Ga(s,c,h):rt(s,h,c);const u=Math.min(c,s),d=Math.floor(To(n,u,r));return n[d]>c&&d<n.length-1?n[d+1]:n[d]}})}function Um(n,t,e,i,s,r){return i=i!==void 0?i:!0,e=e!==void 0?e:0,(function(o,a,l,h){if(o!==void 0){const c=s?Na(t,s,l,r):t;if(h)return i?Ga(o,c,e):rt(o,e,c);const u=1e-9,d=Math.ceil(Math.log(t/c)/Math.log(n)-u),f=-a*(.5-u)+.5,g=Math.min(c,o),m=Math.floor(Math.log(t/g)/Math.log(n)+f),_=Math.max(d,m),p=t/Math.pow(n,_);return rt(p,e,c)}})}function _u(n,t,e,i,s){return e=e!==void 0?e:!0,(function(r,o,a,l){if(r!==void 0){const h=i?Na(n,i,a,s):n;return!e||!l?rt(r,t,h):Ga(r,h,t)}})}function za(n){if(n!==void 0)return 0}function mu(n){if(n!==void 0)return n}function Zm(n){const t=2*Math.PI/n;return(function(e,i){if(i)return e;if(e!==void 0)return e=Math.floor(e/t+.5)*t,e})}function Hm(n){const t=ci(5);return(function(e,i){return i||e===void 0?e:Math.abs(e)<=t?0:e})}const pu=42,Xa=256,Ya=0;class Ie extends ye{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=Wo(t.projection,"EPSG:3857"),this.viewportSize_=[100,100],this.targetCenter_=null,this.targetResolution_,this.targetRotation_,this.nextCenter_=null,this.nextResolution_,this.nextRotation_,this.cancelAnchor_=void 0,t.projection&&Xh(),t.center&&(t.center=ze(t.center,this.projection_)),t.extent&&(t.extent=ui(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){const e=Object.assign({},t);for(const a in ve)delete e[a];this.setProperties(e,!0);const i=Jm(t);this.maxResolution_=i.maxResolution,this.minResolution_=i.minResolution,this.zoomFactor_=i.zoomFactor,this.resolutions_=t.resolutions,this.padding_=t.padding,this.minZoom_=i.minZoom;const s=qm(t),r=i.constraint,o=Qm(t);this.constraints_={center:s,resolution:r,rotation:o},this.setRotation(t.rotation!==void 0?t.rotation:0),this.setCenterInternal(t.center!==void 0?t.center:null),t.resolution!==void 0?this.setResolution(t.resolution):t.zoom!==void 0&&this.setZoom(t.zoom)}get padding(){return this.padding_}set padding(t){let e=this.padding_;this.padding_=t;const i=this.getCenterInternal();if(i){const s=t||[0,0,0,0];e=e||[0,0,0,0];const r=this.getResolution(),o=r/2*(s[3]-e[3]+e[1]-s[1]),a=r/2*(s[0]-e[0]+e[2]-s[2]);this.setCenterInternal([i[0]+o,i[1]-a])}}getUpdatedOptions_(t){const e=this.getProperties();return e.resolution!==void 0?e.resolution=this.getResolution():e.zoom=this.getZoom(),e.center=this.getCenterInternal(),e.rotation=this.getRotation(),Object.assign({},e,t)}animate(t){this.isDef()&&!this.getAnimating()&&this.resolveConstraints(0);const e=new Array(arguments.length);for(let i=0;i<e.length;++i){let s=arguments[i];s.center&&(s=Object.assign({},s),s.center=ze(s.center,this.getProjection())),s.anchor&&(s=Object.assign({},s),s.anchor=ze(s.anchor,this.getProjection())),e[i]=s}this.animateInternal.apply(this,e)}animateInternal(t){let e=arguments.length,i;e>1&&typeof arguments[e-1]=="function"&&(i=arguments[e-1],--e);let s=0;for(;s<e&&!this.isDef();++s){const c=arguments[s];c.center&&this.setCenterInternal(c.center),c.zoom!==void 0?this.setZoom(c.zoom):c.resolution&&this.setResolution(c.resolution),c.rotation!==void 0&&this.setRotation(c.rotation)}if(s===e){i&&Hr(i,!0);return}let r=Date.now(),o=this.targetCenter_.slice(),a=this.targetResolution_,l=this.targetRotation_;const h=[];for(;s<e;++s){const c=arguments[s],u={start:r,complete:!1,anchor:c.anchor,duration:c.duration!==void 0?c.duration:1e3,easing:c.easing||$m,callback:i};if(c.center&&(u.sourceCenter=o,u.targetCenter=c.center.slice(),o=u.targetCenter),c.zoom!==void 0?(u.sourceResolution=a,u.targetResolution=this.getResolutionForZoom(c.zoom),a=u.targetResolution):c.resolution&&(u.sourceResolution=a,u.targetResolution=c.resolution,a=u.targetResolution),c.rotation!==void 0){u.sourceRotation=l;const d=hn(c.rotation-l+Math.PI,2*Math.PI)-Math.PI;u.targetRotation=l+d,l=u.targetRotation}tp(u)?u.complete=!0:r+=u.duration,h.push(u)}this.animations_.push(h),this.setHint(at.ANIMATING,1),this.updateAnimations_()}getAnimating(){return this.hints_[at.ANIMATING]>0}getInteracting(){return this.hints_[at.INTERACTING]>0}cancelAnimations(){this.setHint(at.ANIMATING,-this.hints_[at.ANIMATING]);let t;for(let e=0,i=this.animations_.length;e<i;++e){const s=this.animations_[e];if(s[0].callback&&Hr(s[0].callback,!1),!t)for(let r=0,o=s.length;r<o;++r){const a=s[r];if(!a.complete){t=a.anchor;break}}}this.animations_.length=0,this.cancelAnchor_=t,this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN}updateAnimations_(){if(this.updateAnimationKey_!==void 0&&(cancelAnimationFrame(this.updateAnimationKey_),this.updateAnimationKey_=void 0),!this.getAnimating())return;const t=Date.now();let e=!1;for(let i=this.animations_.length-1;i>=0;--i){const s=this.animations_[i];let r=!0;for(let o=0,a=s.length;o<a;++o){const l=s[o];if(l.complete)continue;const h=t-l.start;let c=l.duration>0?h/l.duration:1;c>=1?(l.complete=!0,c=1):r=!1;const u=l.easing(c);if(l.sourceCenter){const d=l.sourceCenter[0],f=l.sourceCenter[1],g=l.targetCenter[0],m=l.targetCenter[1];this.nextCenter_=l.targetCenter;const _=d+u*(g-d),p=f+u*(m-f);this.targetCenter_=[_,p]}if(l.sourceResolution&&l.targetResolution){const d=u===1?l.targetResolution:l.sourceResolution+u*(l.targetResolution-l.sourceResolution);if(l.anchor){const f=this.getViewportSize_(this.getRotation()),g=this.constraints_.resolution(d,0,f,!0);this.targetCenter_=this.calculateCenterZoom(g,l.anchor)}this.nextResolution_=l.targetResolution,this.targetResolution_=d,this.applyTargetState_(!0)}if(l.sourceRotation!==void 0&&l.targetRotation!==void 0){const d=u===1?hn(l.targetRotation+Math.PI,2*Math.PI)-Math.PI:l.sourceRotation+u*(l.targetRotation-l.sourceRotation);if(l.anchor){const f=this.constraints_.rotation(d,!0);this.targetCenter_=this.calculateCenterRotate(f,l.anchor)}this.nextRotation_=l.targetRotation,this.targetRotation_=d}if(this.applyTargetState_(!0),e=!0,!l.complete)break}if(r){this.animations_[i]=null,this.setHint(at.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;const o=s[0].callback;o&&Hr(o,!0)}}this.animations_=this.animations_.filter(Boolean),e&&this.updateAnimationKey_===void 0&&(this.updateAnimationKey_=requestAnimationFrame(this.updateAnimations_.bind(this)))}calculateCenterRotate(t,e){let i;const s=this.getCenterInternal();return s!==void 0&&(i=[s[0]-e[0],s[1]-e[1]],Mo(i,t-this.getRotation()),Yf(i,e)),i}calculateCenterZoom(t,e){let i;const s=this.getCenterInternal(),r=this.getResolution();if(s!==void 0&&r!==void 0){const o=e[0]-t*(e[0]-s[0])/r,a=e[1]-t*(e[1]-s[1])/r;i=[o,a]}return i}getViewportSize_(t){const e=this.viewportSize_;if(t){const i=e[0],s=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(s*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(s*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){const t=this.getCenterInternal();return t&&$o(t,this.getProjection())}getCenterInternal(){return this.get(ve.CENTER)}getConstraints(){return this.constraints_}getConstrainResolution(){return this.get("constrainResolution")}getHints(t){return t!==void 0?(t[0]=this.hints_[0],t[1]=this.hints_[1],t):this.hints_.slice()}calculateExtent(t){const e=this.calculateExtentInternal(t);return Ko(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();const e=this.getCenterInternal();J(e,"The view center is not defined");const i=this.getResolution();J(i!==void 0,"The view resolution is not defined");const s=this.getRotation();return J(s!==void 0,"The view rotation is not defined"),Ao(e,i,s,t)}getMaxResolution(){return this.maxResolution_}getMinResolution(){return this.minResolution_}getMaxZoom(){return this.getZoomForResolution(this.minResolution_)}setMaxZoom(t){this.applyOptions_(this.getUpdatedOptions_({maxZoom:t}))}getMinZoom(){return this.getZoomForResolution(this.maxResolution_)}setMinZoom(t){this.applyOptions_(this.getUpdatedOptions_({minZoom:t}))}setConstrainResolution(t){this.applyOptions_(this.getUpdatedOptions_({constrainResolution:t}))}getProjection(){return this.projection_}getResolution(){return this.get(ve.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal(ui(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();const i=tt(t)/e[0],s=Ot(t)/e[1];return Math.max(i,s)}getResolutionForValueFunction(t){t=t||2;const e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,s=Math.log(e/i)/Math.log(t);return(function(r){return e/Math.pow(t,r*s)})}getRotation(){return this.get(ve.ROTATION)}getValueForResolutionFunction(t){const e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),s=this.minResolution_,r=Math.log(i/s)/e;return(function(o){return Math.log(i/o)/e/r})}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t);const i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){const t=this.getProjection(),e=this.getResolution(),i=this.getRotation();let s=this.getCenterInternal();const r=this.padding_;if(r){const o=this.getViewportSizeMinusPadding_();s=Wa(s,this.getViewportSize_(),[o[0]/2+r[3],o[1]/2+r[0]],e,i)}return{center:s.slice(0),projection:t!==void 0?t:null,resolution:e,nextCenter:this.nextCenter_,nextResolution:this.nextResolution_,nextRotation:this.nextRotation_,rotation:i,zoom:this.getZoom()}}getViewStateAndExtent(){return{viewState:this.getState(),extent:this.calculateExtent()}}getZoom(){let t;const e=this.getResolution();return e!==void 0&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e=this.minZoom_||0,i,s;if(this.resolutions_){const r=To(this.resolutions_,t,1);e=r,i=this.resolutions_[r],r==this.resolutions_.length-1?s=2:s=i/this.resolutions_[r+1]}else i=this.maxResolution_,s=this.zoomFactor_;return e+Math.log(i/t)/Math.log(s)}getResolutionForZoom(t){if(this.resolutions_?.length){if(this.resolutions_.length===1)return this.resolutions_[0];const e=rt(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,rt(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if(J(Array.isArray(t)||typeof t.getSimplifiedGeometry=="function","Invalid extent or geometry provided as `geometry`"),Array.isArray(t)){J(!ts(t),"Cannot fit empty extent provided as `geometry`");const s=ui(t,this.getProjection());i=oc(s)}else if(t.getType()==="Circle"){const s=ui(t.getExtent(),this.getProjection());i=oc(s),i.rotate(this.getRotation(),Di(s))}else i=t;this.fitInternal(i,e)}rotatedExtentForGeometry(t){const e=this.getRotation(),i=Math.cos(e),s=Math.sin(-e),r=t.getFlatCoordinates(),o=t.getStride();let a=1/0,l=1/0,h=-1/0,c=-1/0;for(let u=0,d=r.length;u<d;u+=o){const f=r[u]*i-r[u+1]*s,g=r[u]*s+r[u+1]*i;a=Math.min(a,f),l=Math.min(l,g),h=Math.max(h,f),c=Math.max(c,g)}return[a,l,h,c]}fitInternal(t,e){e=e||{};let i=e.size;i||(i=this.getViewportSizeMinusPadding_());const s=e.padding!==void 0?e.padding:[0,0,0,0],r=e.nearest!==void 0?e.nearest:!1;let o;e.minResolution!==void 0?o=e.minResolution:e.maxZoom!==void 0?o=this.getResolutionForZoom(e.maxZoom):o=0;const a=this.rotatedExtentForGeometry(t);let l=this.getResolutionForExtentInternal(a,[i[0]-s[1]-s[3],i[1]-s[0]-s[2]]);l=isNaN(l)?o:Math.max(l,o),l=this.getConstrainedResolution(l,r?0:1);const h=this.getRotation(),c=Math.sin(h),u=Math.cos(h),d=Di(a);d[0]+=(s[1]-s[3])/2*l,d[1]+=(s[0]-s[2])/2*l;const f=d[0]*u-d[1]*c,g=d[1]*u+d[0]*c,m=this.getConstrainedCenter([f,g],l),_=e.callback?e.callback:Zn;e.duration!==void 0?this.animateInternal({resolution:l,center:m,duration:e.duration,easing:e.easing},_):(this.targetResolution_=l,this.targetCenter_=m,this.applyTargetState_(!1,!0),Hr(_,!0))}centerOn(t,e,i){this.centerOnInternal(ze(t,this.getProjection()),e,i)}centerOnInternal(t,e,i){this.setCenterInternal(Wa(t,e,i,this.getResolution(),this.getRotation()))}calculateCenterShift(t,e,i,s){let r;const o=this.padding_;if(o&&t){const a=this.getViewportSizeMinusPadding_(-i),l=Wa(t,s,[a[0]/2+o[3],a[1]/2+o[0]],e,i);r=[t[0]-l[0],t[1]-l[1]]}return r}isDef(){return!!this.getCenterInternal()&&this.getResolution()!==void 0}adjustCenter(t){const e=$o(this.targetCenter_,this.getProjection());this.setCenter([e[0]+t[0],e[1]+t[1]])}adjustCenterInternal(t){const e=this.targetCenter_;this.setCenterInternal([e[0]+t[0],e[1]+t[1]])}adjustResolution(t,e){e=e&&ze(e,this.getProjection()),this.adjustResolutionInternal(t,e)}adjustResolutionInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.getViewportSize_(this.getRotation()),r=this.constraints_.resolution(this.targetResolution_*t,0,s,i);e&&(this.targetCenter_=this.calculateCenterZoom(r,e)),this.targetResolution_*=t,this.applyTargetState_()}adjustZoom(t,e){this.adjustResolution(Math.pow(this.zoomFactor_,-t),e)}adjustRotation(t,e){e&&(e=ze(e,this.getProjection())),this.adjustRotationInternal(t,e)}adjustRotationInternal(t,e){const i=this.getAnimating()||this.getInteracting(),s=this.constraints_.rotation(this.targetRotation_+t,i);e&&(this.targetCenter_=this.calculateCenterRotate(s,e)),this.targetRotation_+=t,this.applyTargetState_()}setCenter(t){this.setCenterInternal(t&&ze(t,this.getProjection()))}setCenterInternal(t){this.targetCenter_=t,this.applyTargetState_()}setHint(t,e){return this.hints_[t]+=e,this.changed(),this.hints_[t]}setResolution(t){this.targetResolution_=t,this.applyTargetState_()}setRotation(t){this.targetRotation_=t,this.applyTargetState_()}setZoom(t){this.setResolution(this.getResolutionForZoom(t))}applyTargetState_(t,e){const i=this.getAnimating()||this.getInteracting()||e,s=this.constraints_.rotation(this.targetRotation_,i),r=this.getViewportSize_(s),o=this.constraints_.resolution(this.targetResolution_,0,r,i),a=this.constraints_.center(this.targetCenter_,o,r,i,this.calculateCenterShift(this.targetCenter_,o,s,r));this.get(ve.ROTATION)!==s&&this.set(ve.ROTATION,s),this.get(ve.RESOLUTION)!==o&&(this.set(ve.RESOLUTION,o),this.set("zoom",this.getZoom(),!0)),(!a||!this.get(ve.CENTER)||!gr(this.get(ve.CENTER),a))&&this.set(ve.CENTER,a),this.getAnimating()&&!t&&this.cancelAnimations(),this.cancelAnchor_=void 0}resolveConstraints(t,e,i){t=t!==void 0?t:200;const s=e||0,r=this.constraints_.rotation(this.targetRotation_),o=this.getViewportSize_(r),a=this.constraints_.resolution(this.targetResolution_,s,o),l=this.constraints_.center(this.targetCenter_,a,o,!1,this.calculateCenterShift(this.targetCenter_,a,r,o));if(t===0&&!this.cancelAnchor_){this.targetResolution_=a,this.targetRotation_=r,this.targetCenter_=l,this.applyTargetState_();return}i=i||(t===0?this.cancelAnchor_:void 0),this.cancelAnchor_=void 0,(this.getResolution()!==a||this.getRotation()!==r||!this.getCenterInternal()||!gr(this.getCenterInternal(),l))&&(this.getAnimating()&&this.cancelAnimations(),this.animateInternal({rotation:r,center:l,resolution:a,duration:t,easing:Sn,anchor:i}))}beginInteraction(){this.resolveConstraints(0),this.setHint(at.INTERACTING,1)}endInteraction(t,e,i){i=i&&ze(i,this.getProjection()),this.endInteractionInternal(t,e,i)}endInteractionInternal(t,e,i){this.getInteracting()&&(this.setHint(at.INTERACTING,-1),this.resolveConstraints(t,e,i))}getConstrainedCenter(t,e){const i=this.getViewportSize_(this.getRotation());return this.constraints_.center(t,e||this.getResolution(),i)}getConstrainedZoom(t,e){const i=this.getResolutionForZoom(t);return this.getZoomForResolution(this.getConstrainedResolution(i,e))}getConstrainedResolution(t,e){e=e||0;const i=this.getViewportSize_(this.getRotation());return this.constraints_.resolution(t,e,i)}}function Hr(n,t){setTimeout(function(){n(t)},0)}function qm(n){if(n.extent!==void 0){const e=n.smoothExtentConstraint!==void 0?n.smoothExtentConstraint:!0;return fu(n.extent,n.constrainOnlyCenter,e)}const t=Wo(n.projection,"EPSG:3857");if(n.multiWorld!==!0&&t.isGlobal()){const e=t.getExtent().slice();return e[0]=-1/0,e[2]=1/0,fu(e,!1,!1)}return Bm}function Jm(n){let t,e,i,o=n.minZoom!==void 0?n.minZoom:Ya,a=n.maxZoom!==void 0?n.maxZoom:28;const l=n.zoomFactor!==void 0?n.zoomFactor:2,h=n.multiWorld!==void 0?n.multiWorld:!1,c=n.smoothResolutionConstraint!==void 0?n.smoothResolutionConstraint:!0,u=n.showFullExtent!==void 0?n.showFullExtent:!1,d=Wo(n.projection,"EPSG:3857"),f=d.getExtent();let g=n.constrainOnlyCenter,m=n.extent;if(!h&&!m&&d.isGlobal()&&(g=!1,m=f),n.resolutions!==void 0){const _=n.resolutions;e=_[o],i=_[a]!==void 0?_[a]:_[_.length-1],n.constrainResolution?t=jm(_,c,!g&&m,u):t=_u(e,i,c,!g&&m,u)}else{const p=(f?Math.max(tt(f),Ot(f)):360*Oo.degrees/d.getMetersPerUnit())/Xa/Math.pow(2,Ya),y=p/Math.pow(2,28-Ya);e=n.maxResolution,e!==void 0?o=0:e=p/Math.pow(l,o),i=n.minResolution,i===void 0&&(n.maxZoom!==void 0?n.maxResolution!==void 0?i=e/Math.pow(l,a):i=p/Math.pow(l,a):i=y),a=o+Math.floor(Math.log(e/i)/Math.log(l)),i=e/Math.pow(l,a-o),n.constrainResolution?t=Um(l,e,i,c,!g&&m,u):t=_u(e,i,c,!g&&m,u)}return{constraint:t,maxResolution:e,minResolution:i,minZoom:o,zoomFactor:l}}function Qm(n){if(n.enableRotation!==void 0?n.enableRotation:!0){const e=n.constrainRotation;return e===void 0||e===!0?Hm():e===!1?mu:typeof e=="number"?Zm(e):mu}return za}function tp(n){return!(n.sourceCenter&&n.targetCenter&&!gr(n.sourceCenter,n.targetCenter)||n.sourceResolution!==n.targetResolution||n.sourceRotation!==n.targetRotation)}function Wa(n,t,e,i,s){const r=Math.cos(-s);let o=Math.sin(-s),a=n[0]*r-n[1]*o,l=n[1]*r+n[0]*o;a+=(t[0]/2-e[0])*i,l+=(e[1]-t[1]/2)*i,o=-o;const h=a*r-l*o,c=l*r+a*o;return[h,c]}const et={OPACITY:"opacity",VISIBLE:"visible",EXTENT:"extent",Z_INDEX:"zIndex",MAX_RESOLUTION:"maxResolution",MIN_RESOLUTION:"minResolution",MAX_ZOOM:"maxZoom",MIN_ZOOM:"minZoom",SOURCE:"source",MAP:"map"};class yu extends ye{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;const e=Object.assign({},t);typeof t.properties=="object"&&(delete e.properties,Object.assign(e,t.properties)),e[et.OPACITY]=t.opacity!==void 0?t.opacity:1,J(typeof e[et.OPACITY]=="number","Layer opacity must be a number"),e[et.VISIBLE]=t.visible!==void 0?t.visible:!0,e[et.Z_INDEX]=t.zIndex,e[et.MAX_RESOLUTION]=t.maxResolution!==void 0?t.maxResolution:1/0,e[et.MIN_RESOLUTION]=t.minResolution!==void 0?t.minResolution:0,e[et.MIN_ZOOM]=t.minZoom!==void 0?t.minZoom:-1/0,e[et.MAX_ZOOM]=t.maxZoom!==void 0?t.maxZoom:1/0,this.className_=e.className!==void 0?e.className:"ol-layer",delete e.className,this.setProperties(e),this.state_=null}getBackground(){return this.background_}getClassName(){return this.className_}getLayerState(t){const e=this.state_||{layer:this,managed:t===void 0?!0:t},i=this.getZIndex();return e.opacity=rt(Math.round(this.getOpacity()*100)/100,0,1),e.visible=this.getVisible(),e.extent=this.getExtent(),e.zIndex=i===void 0&&!e.managed?1/0:i,e.maxResolution=this.getMaxResolution(),e.minResolution=Math.max(this.getMinResolution(),0),e.minZoom=this.getMinZoom(),e.maxZoom=this.getMaxZoom(),this.state_=e,e}getLayersArray(t){return j()}getLayerStatesArray(t){return j()}getExtent(){return this.get(et.EXTENT)}getMaxResolution(){return this.get(et.MAX_RESOLUTION)}getMinResolution(){return this.get(et.MIN_RESOLUTION)}getMinZoom(){return this.get(et.MIN_ZOOM)}getMaxZoom(){return this.get(et.MAX_ZOOM)}getOpacity(){return this.get(et.OPACITY)}getSourceState(){return j()}getVisible(){return this.get(et.VISIBLE)}getZIndex(){return this.get(et.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set(et.EXTENT,t)}setMaxResolution(t){this.set(et.MAX_RESOLUTION,t)}setMinResolution(t){this.set(et.MIN_RESOLUTION,t)}setMaxZoom(t){this.set(et.MAX_ZOOM,t)}setMinZoom(t){this.set(et.MIN_ZOOM,t)}setOpacity(t){J(typeof t=="number","Layer opacity must be a number"),this.set(et.OPACITY,t)}setVisible(t){this.set(et.VISIBLE,t)}setZIndex(t){this.set(et.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}}class qr extends yu{constructor(t){const e=Object.assign({},t);delete e.source,super(e),this.on,this.once,this.un,this.mapPrecomposeKey_=null,this.mapRenderKey_=null,this.sourceChangeKey_=null,this.renderer_=null,this.sourceReady_=!1,this.rendered=!1,t.render&&(this.render=t.render),t.map&&this.setMap(t.map),this.addChangeListener(et.SOURCE,this.handleSourcePropertyChange_);const i=t.source?t.source:null;this.setSource(i)}getLayersArray(t){return t=t||[],t.push(this),t}getLayerStatesArray(t){return t=t||[],t.push(this.getLayerState()),t}getSource(){return this.get(et.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){const t=this.getSource();return t?t.getState():"undefined"}handleSourceChange_(){this.changed(),!(this.sourceReady_||this.getSource().getState()!=="ready")&&(this.sourceReady_=!0,this.dispatchEvent("sourceready"))}handleSourcePropertyChange_(){this.sourceChangeKey_&&(nt(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;const t=this.getSource();t&&(this.sourceChangeKey_=H(t,V.CHANGE,this.handleSourceChange_,this),t.getState()==="ready"&&(this.sourceReady_=!0,setTimeout(()=>{this.dispatchEvent("sourceready")},0))),this.changed()}getFeatures(t){return this.renderer_?this.renderer_.getFeatures(t):Promise.resolve([])}getData(t){return!this.renderer_||!this.rendered?null:this.renderer_.getData(t)}isVisible(t){let e;const i=this.getMapInternal();!t&&i&&(t=i.getView()),t instanceof Ie?e={viewState:t.getState(),extent:t.calculateExtent()}:e=t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray());let s;if(e.layerStatesArray){if(s=e.layerStatesArray.find(o=>o.layer===this),!s)return!1}else s=this.getLayerState();const r=this.getExtent();return Va(s,e.viewState)&&(!r||ct(r,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];const e=this.getSource()?.getAttributions();if(!e)return[];const i=t instanceof Ie?t.getViewStateAndExtent():t;let s=e(i);return Array.isArray(s)||(s=[s]),s}render(t,e){const i=this.getRenderer();return i.prepareFrame(t)?(this.rendered=!0,i.renderFrame(t,e)):null}unrender(){this.rendered=!1}getDeclutter(){}renderDeclutter(t,e){}renderDeferred(t){const e=this.getRenderer();e&&e.renderDeferred(t)}setMapInternal(t){t||this.unrender(),this.set(et.MAP,t)}getMapInternal(){return this.get(et.MAP)}setMap(t){this.mapPrecomposeKey_&&(nt(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&(nt(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=H(t,le.PRECOMPOSE,this.handlePrecompose_,this),this.mapRenderKey_=H(this,V.CHANGE,t.render,t),this.changed())}handlePrecompose_(t){const e=t.frameState.layerStatesArray,i=this.getLayerState(!1);J(!e.some(s=>s.layer===i.layer),"A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both."),e.push(i)}setSource(t){this.set(et.SOURCE,t)}getRenderer(){return this.renderer_||(this.renderer_=this.createRenderer()),this.renderer_}hasRenderer(){return!!this.renderer_}createRenderer(){return null}clearRenderer(){this.renderer_&&(this.renderer_.dispose(),delete this.renderer_)}disposeInternal(){this.clearRenderer(),this.setSource(null),super.disposeInternal()}}function Va(n,t){if(!n.visible)return!1;const e=t.resolution;if(e<n.minResolution||e>=n.maxResolution)return!1;const i=t.zoom;return i>n.minZoom&&i<=n.maxZoom}const xu={RENDER_ORDER:"renderOrder"};class Ba extends qr{constructor(t){t=t||{};const e=Object.assign({},t);delete e.style,delete e.renderBuffer,delete e.updateWhileAnimating,delete e.updateWhileInteracting,super(e),this.declutter_=t.declutter?String(t.declutter):void 0,this.renderBuffer_=t.renderBuffer!==void 0?t.renderBuffer:100,this.style_=null,this.styleFunction_=void 0,this.setStyle(t.style),this.updateWhileAnimating_=t.updateWhileAnimating!==void 0?t.updateWhileAnimating:!1,this.updateWhileInteracting_=t.updateWhileInteracting!==void 0?t.updateWhileInteracting:!1}getDeclutter(){return this.declutter_}getFeatures(t){return super.getFeatures(t)}getRenderBuffer(){return this.renderBuffer_}getRenderOrder(){return this.get(xu.RENDER_ORDER)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t,e){const i=this.getDeclutter();i in t.declutter||(t.declutter[i]=new Mc(9)),this.getRenderer().renderDeclutter(t,e)}setRenderOrder(t){this.set(xu.RENDER_ORDER,t)}setStyle(t){this.style_=t===void 0?Gc:t;const e=ep(t);this.styleFunction_=t===null?void 0:W_(e),this.changed()}setDeclutter(t){this.declutter_=t?String(t):void 0,this.changed()}}function ep(n){if(n===void 0)return Gc;if(!n)return null;if(typeof n=="function"||n instanceof _t)return n;if(!Array.isArray(n))return ru([n]);if(n.length===0)return[];const t=n.length,e=n[0];if(e instanceof _t){const s=new Array(t);for(let r=0;r<t;++r){const o=n[r];if(!(o instanceof _t))throw new Error("Expected a list of style instances");s[r]=o}return s}if("style"in e){const s=new Array(t);for(let r=0;r<t;++r){const o=n[r];if(!("style"in o))throw new Error("Expected a list of rules with a style property");s[r]=o}return Pm(s)}return ru(n)}class ip extends Ba{constructor(t){super(t)}createRenderer(){return new rm(this)}}const O={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4};class Ss extends sr{constructor(t,e,i){super(),i=i||{},this.tileCoord=t,this.state=e,this.key="",this.transition_=i.transition===void 0?250:i.transition,this.transitionStarts_={},this.interpolate=!!i.interpolate}changed(){this.dispatchEvent(V.CHANGE)}release(){this.setState(O.EMPTY)}getKey(){return this.key+"/"+this.tileCoord}getTileCoord(){return this.tileCoord}getState(){return this.state}setState(t){if(this.state!==O.EMPTY){if(this.state!==O.ERROR&&this.state>t)throw new Error("Tile load sequence violation");this.state=t,this.changed()}}load(){j()}getAlpha(t,e){if(!this.transition_)return 1;let i=this.transitionStarts_[t];if(!i)i=e,this.transitionStarts_[t]=i;else if(i===-1)return 1;const s=e-i+1e3/60;return s>=this.transition_?1:gu(s/this.transition_)}inTransition(t){return this.transition_?this.transitionStarts_[t]!==-1:!1}endTransition(t){this.transition_&&(this.transitionStarts_[t]=-1)}disposeInternal(){this.release(),super.disposeInternal()}}class Eu extends Ss{constructor(t,e,i,s,r,o){super(t,e,o),this.crossOrigin_=s,this.src_=i,this.key=i,this.image_,Zt?this.image_=new OffscreenCanvas(1,1):(this.image_=new Image,s!==null&&(this.image_.crossOrigin=s)),this.unlisten_=null,this.tileLoadFunction_=r}getImage(){return this.image_}setImage(t){this.image_=t,this.state=O.LOADED,this.unlistenImage_(),this.changed()}getCrossOrigin(){return this.crossOrigin_}handleImageError_(){this.state=O.ERROR,this.unlistenImage_(),this.image_=np(),this.changed()}handleImageLoad_(){if(Zt)this.state=O.LOADED;else{const t=this.image_;t.naturalWidth&&t.naturalHeight?this.state=O.LOADED:this.state=O.EMPTY}this.unlistenImage_(),this.changed()}load(){this.state==O.ERROR&&(this.state=O.IDLE,this.image_=new Image,this.crossOrigin_!==null&&(this.image_.crossOrigin=this.crossOrigin_)),this.state==O.IDLE&&(this.state=O.LOADING,this.changed(),this.tileLoadFunction_(this,this.src_),this.unlisten_=o_(this.image_,this.handleImageLoad_.bind(this),this.handleImageError_.bind(this)))}unlistenImage_(){this.unlisten_&&(this.unlisten_(),this.unlisten_=null)}disposeInternal(){this.unlistenImage_(),this.image_=null,super.disposeInternal()}}function np(){const n=ut(1,1);return n.fillStyle="rgba(0,0,0,0)",n.fillRect(0,0,1,1),n.canvas}class sp{constructor(t,e,i){this.decay_=t,this.minVelocity_=e,this.delay_=i,this.points_=[],this.angle_=0,this.initialVelocity_=0}begin(){this.points_.length=0,this.angle_=0,this.initialVelocity_=0}update(t,e){this.points_.push(t,e,Date.now())}end(){if(this.points_.length<6)return!1;const t=Date.now()-this.delay_,e=this.points_.length-3;if(this.points_[e+2]<t)return!1;let i=e-3;for(;i>0&&this.points_[i+2]>t;)i-=3;const s=this.points_[e+2]-this.points_[i+2];if(s<1e3/60)return!1;const r=this.points_[e]-this.points_[i],o=this.points_[e+1]-this.points_[i+1];return this.angle_=Math.atan2(o,r),this.initialVelocity_=Math.sqrt(r*r+o*o)/s,this.initialVelocity_>this.minVelocity_}getDistance(){return(this.minVelocity_-this.initialVelocity_)/this.decay_}getAngle(){return this.angle_}}class In extends ke{constructor(t,e,i){super(t),this.map=e,this.frameState=i!==void 0?i:null}}class wi extends In{constructor(t,e,i,s,r,o){super(t,e,r),this.originalEvent=i,this.pixel_=null,this.coordinate_=null,this.dragging=s!==void 0?s:!1,this.activePointers=o}get pixel(){return this.pixel_||(this.pixel_=this.map.getEventPixel(this.originalEvent)),this.pixel_}set pixel(t){this.pixel_=t}get coordinate(){return this.coordinate_||(this.coordinate_=this.map.getCoordinateFromPixel(this.pixel)),this.coordinate_}set coordinate(t){this.coordinate_=t}preventDefault(){super.preventDefault(),"preventDefault"in this.originalEvent&&this.originalEvent.preventDefault()}stopPropagation(){super.stopPropagation(),"stopPropagation"in this.originalEvent&&this.originalEvent.stopPropagation()}}const lt={SINGLECLICK:"singleclick",CLICK:V.CLICK,DBLCLICK:V.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"},$a={POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown"};class rp extends sr{constructor(t,e){super(t),this.map_=t,this.clickTimeoutId_,this.emulateClicks_=!1,this.dragging_=!1,this.dragListenerKeys_=[],this.moveTolerance_=e===void 0?1:e,this.down_=null;const i=this.map_.getViewport();this.activePointers_=[],this.trackedTouches_={},this.element_=i,this.pointerdownListenerKey_=H(i,$a.POINTERDOWN,this.handlePointerDown_,this),this.originalPointerMoveEvent_,this.relayedListenerKey_=H(i,$a.POINTERMOVE,this.relayMoveEvent_,this),this.boundHandleTouchMove_=this.handleTouchMove_.bind(this),this.element_.addEventListener(V.TOUCHMOVE,this.boundHandleTouchMove_,hc?{passive:!1}:!1)}emulateClick_(t){let e=new wi(lt.CLICK,this.map_,t);this.dispatchEvent(e),this.clickTimeoutId_!==void 0?(clearTimeout(this.clickTimeoutId_),this.clickTimeoutId_=void 0,e=new wi(lt.DBLCLICK,this.map_,t),this.dispatchEvent(e)):this.clickTimeoutId_=setTimeout(()=>{this.clickTimeoutId_=void 0;const i=new wi(lt.SINGLECLICK,this.map_,t);this.dispatchEvent(i)},250)}updateActivePointers_(t){const e=t,i=e.pointerId;if(e.type==lt.POINTERUP||e.type==lt.POINTERCANCEL){delete this.trackedTouches_[i];for(const s in this.trackedTouches_)if(this.trackedTouches_[s].target!==e.target){delete this.trackedTouches_[s];break}}else(e.type==lt.POINTERDOWN||e.type==lt.POINTERMOVE)&&(this.trackedTouches_[i]=e);this.activePointers_=Object.values(this.trackedTouches_)}handlePointerUp_(t){this.updateActivePointers_(t);const e=new wi(lt.POINTERUP,this.map_,t,void 0,void 0,this.activePointers_);this.dispatchEvent(e),this.emulateClicks_&&!e.defaultPrevented&&!this.dragging_&&this.isMouseActionButton_(t)&&this.emulateClick_(this.down_),this.activePointers_.length===0&&(this.dragListenerKeys_.forEach(nt),this.dragListenerKeys_.length=0,this.dragging_=!1,this.down_=null)}isMouseActionButton_(t){return t.button===0}handlePointerDown_(t){this.emulateClicks_=this.activePointers_.length===0,this.updateActivePointers_(t);const e=new wi(lt.POINTERDOWN,this.map_,t,void 0,void 0,this.activePointers_);if(this.dispatchEvent(e),this.down_=new PointerEvent(t.type,t),Object.defineProperty(this.down_,"target",{writable:!1,value:t.target}),this.dragListenerKeys_.length===0){const i=this.map_.getOwnerDocument();this.dragListenerKeys_.push(H(i,lt.POINTERMOVE,this.handlePointerMove_,this),H(i,lt.POINTERUP,this.handlePointerUp_,this),H(this.element_,lt.POINTERCANCEL,this.handlePointerUp_,this)),this.element_.getRootNode&&this.element_.getRootNode()!==i&&this.dragListenerKeys_.push(H(this.element_.getRootNode(),lt.POINTERUP,this.handlePointerUp_,this))}}handlePointerMove_(t){if(this.isMoving_(t)){this.updateActivePointers_(t),this.dragging_=!0;const e=new wi(lt.POINTERDRAG,this.map_,t,this.dragging_,void 0,this.activePointers_);this.dispatchEvent(e)}}relayMoveEvent_(t){this.originalPointerMoveEvent_=t;const e=!!(this.down_&&this.isMoving_(t));this.dispatchEvent(new wi(lt.POINTERMOVE,this.map_,t,e))}handleTouchMove_(t){const e=this.originalPointerMoveEvent_;(!e||e.defaultPrevented)&&(typeof t.cancelable!="boolean"||t.cancelable===!0)&&t.preventDefault()}isMoving_(t){return this.dragging_||Math.abs(t.clientX-this.down_.clientX)>this.moveTolerance_||Math.abs(t.clientY-this.down_.clientY)>this.moveTolerance_}disposeInternal(){this.relayedListenerKey_&&(nt(this.relayedListenerKey_),this.relayedListenerKey_=null),this.element_.removeEventListener(V.TOUCHMOVE,this.boundHandleTouchMove_),this.pointerdownListenerKey_&&(nt(this.pointerdownListenerKey_),this.pointerdownListenerKey_=null),this.dragListenerKeys_.forEach(nt),this.dragListenerKeys_.length=0,this.element_=null,super.disposeInternal()}}const je={POSTRENDER:"postrender",MOVESTART:"movestart",MOVEEND:"moveend",LOADSTART:"loadstart",LOADEND:"loadend"},St={LAYERGROUP:"layergroup",SIZE:"size",TARGET:"target",VIEW:"view"},Jr=1/0;class op{constructor(t,e){this.priorityFunction_=t,this.keyFunction_=e,this.elements_=[],this.priorities_=[],this.queuedElements_={}}clear(){this.elements_.length=0,this.priorities_.length=0,Hn(this.queuedElements_)}dequeue(){const t=this.elements_,e=this.priorities_,i=t[0];t.length==1?(t.length=0,e.length=0):(t[0]=t.pop(),e[0]=e.pop(),this.siftUp_(0));const s=this.keyFunction_(i);return delete this.queuedElements_[s],i}enqueue(t){J(!(this.keyFunction_(t)in this.queuedElements_),"Tried to enqueue an `element` that was already added to the queue");const e=this.priorityFunction_(t);return e!=Jr?(this.elements_.push(t),this.priorities_.push(e),this.queuedElements_[this.keyFunction_(t)]=!0,this.siftDown_(0,this.elements_.length-1),!0):!1}getCount(){return this.elements_.length}getLeftChildIndex_(t){return t*2+1}getRightChildIndex_(t){return t*2+2}getParentIndex_(t){return t-1>>1}heapify_(){let t;for(t=(this.elements_.length>>1)-1;t>=0;t--)this.siftUp_(t)}isEmpty(){return this.elements_.length===0}isKeyQueued(t){return t in this.queuedElements_}isQueued(t){return this.isKeyQueued(this.keyFunction_(t))}siftUp_(t){const e=this.elements_,i=this.priorities_,s=e.length,r=e[t],o=i[t],a=t;for(;t<s>>1;){const l=this.getLeftChildIndex_(t),h=this.getRightChildIndex_(t),c=h<s&&i[h]<i[l]?h:l;e[t]=e[c],i[t]=i[c],t=c}e[t]=r,i[t]=o,this.siftDown_(a,t)}siftDown_(t,e){const i=this.elements_,s=this.priorities_,r=i[e],o=s[e];for(;e>t;){const a=this.getParentIndex_(e);if(s[a]>o)i[e]=i[a],s[e]=s[a],e=a;else break}i[e]=r,s[e]=o}reprioritize(){const t=this.priorityFunction_,e=this.elements_,i=this.priorities_;let s=0;const r=e.length;let o,a,l;for(a=0;a<r;++a)o=e[a],l=t(o),l==Jr?delete this.queuedElements_[this.keyFunction_(o)]:(i[s]=l,e[s++]=o);e.length=s,i.length=s,this.heapify_()}}class ap extends op{constructor(t,e){super(i=>t.apply(null,i),i=>i[0].getKey()),this.boundHandleTileChange_=this.handleTileChange.bind(this),this.tileChangeCallback_=e,this.tilesLoading_=0,this.tilesLoadingKeys_={}}enqueue(t){const e=super.enqueue(t);return e&&t[0].addEventListener(V.CHANGE,this.boundHandleTileChange_),e}getTilesLoading(){return this.tilesLoading_}handleTileChange(t){const e=t.target,i=e.getState();if(i===O.LOADED||i===O.ERROR||i===O.EMPTY){i!==O.ERROR&&e.removeEventListener(V.CHANGE,this.boundHandleTileChange_);const s=e.getKey();s in this.tilesLoadingKeys_&&(delete this.tilesLoadingKeys_[s],--this.tilesLoading_),this.tileChangeCallback_()}}loadMoreTiles(t,e){let i=0;for(;this.tilesLoading_<t&&i<e&&this.getCount()>0;){const s=this.dequeue()[0],r=s.getKey();s.getState()===O.IDLE&&!(r in this.tilesLoadingKeys_)&&(this.tilesLoadingKeys_[r]=!0,++this.tilesLoading_,++i,s.load())}}}function lp(n,t,e,i,s){if(!n||!(e in n.wantedTiles)||!n.wantedTiles[e][t.getKey()])return Jr;const r=n.viewState.center,o=i[0]-r[0],a=i[1]-r[1];return 65536*Math.log(s)+Math.sqrt(o*o+a*a)/s}class Ka extends ye{constructor(t){super();const e=t.element;e&&!t.target&&!e.style.pointerEvents&&(e.style.pointerEvents="auto"),this.element=e||null,this.target_=null,this.map_=null,this.listenerKeys=[],t.render&&(this.render=t.render),t.target&&this.setTarget(t.target)}disposeInternal(){this.element?.remove(),super.disposeInternal()}getMap(){return this.map_}setMap(t){this.map_&&this.element?.remove();for(let e=0,i=this.listenerKeys.length;e<i;++e)nt(this.listenerKeys[e]);if(this.listenerKeys.length=0,this.map_=t,t){const e=this.target_??t.getOverlayContainerStopEvent();this.element&&e.appendChild(this.element),this.render!==Zn&&this.listenerKeys.push(H(t,je.POSTRENDER,this.render,this)),t.render()}}render(t){}setTarget(t){this.target_=typeof t=="string"?document.getElementById(t):t}}class hp extends Ka{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target}),this.ulElement_=document.createElement("ul"),this.collapsed_=t.collapsed!==void 0?t.collapsed:!0,this.userCollapsed_=this.collapsed_,this.overrideCollapsible_=t.collapsible!==void 0,this.collapsible_=t.collapsible!==void 0?t.collapsible:!0,this.collapsible_||(this.collapsed_=!1),this.attributions_=t.attributions;const e=t.className!==void 0?t.className:"ol-attribution",i=t.tipLabel!==void 0?t.tipLabel:"Attributions",s=t.expandClassName!==void 0?t.expandClassName:e+"-expand",r=t.collapseLabel!==void 0?t.collapseLabel:"›",o=t.collapseClassName!==void 0?t.collapseClassName:e+"-collapse";typeof r=="string"?(this.collapseLabel_=document.createElement("span"),this.collapseLabel_.textContent=r,this.collapseLabel_.className=o):this.collapseLabel_=r;const a=t.label!==void 0?t.label:"i";typeof a=="string"?(this.label_=document.createElement("span"),this.label_.textContent=a,this.label_.className=s):this.label_=a;const l=this.collapsible_&&!this.collapsed_?this.collapseLabel_:this.label_;this.toggleButton_=document.createElement("button"),this.toggleButton_.setAttribute("type","button"),this.toggleButton_.setAttribute("aria-expanded",String(!this.collapsed_)),this.toggleButton_.title=i,this.toggleButton_.appendChild(l),this.toggleButton_.addEventListener(V.CLICK,this.handleClick_.bind(this),!1);const h=e+" "+Pr+" "+wa+(this.collapsed_&&this.collapsible_?" "+pc:"")+(this.collapsible_?"":" ol-uncollapsible"),c=this.element;c.className=h,c.appendChild(this.toggleButton_),c.appendChild(this.ulElement_),this.renderedAttributions_=[],this.renderedVisible_=!0}collectSourceAttributions_(t){const e=this.getMap().getAllLayers(),i=new Set(e.flatMap(s=>s.getAttributions(t)));if(this.attributions_!==void 0&&(Array.isArray(this.attributions_)?this.attributions_.forEach(s=>i.add(s)):i.add(this.attributions_)),!this.overrideCollapsible_){const s=!e.some(r=>r.getSource()?.getAttributionsCollapsible()===!1);this.setCollapsible(s)}return Array.from(i)}async updateElement_(t){if(!t){this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1);return}const e=await Promise.all(this.collectSourceAttributions_(t).map(s=>bf(()=>s))),i=e.length>0;if(this.renderedVisible_!=i&&(this.element.style.display=i?"":"none",this.renderedVisible_=i),!ai(e,this.renderedAttributions_)){uc(this.ulElement_);for(let s=0,r=e.length;s<r;++s){const o=document.createElement("li");o.innerHTML=e[s],this.ulElement_.appendChild(o)}this.renderedAttributions_=e}}handleClick_(t){t.preventDefault(),this.handleToggle_(),this.userCollapsed_=this.collapsed_}handleToggle_(){this.element.classList.toggle(pc),this.collapsed_?cc(this.collapseLabel_,this.label_):cc(this.label_,this.collapseLabel_),this.collapsed_=!this.collapsed_,this.toggleButton_.setAttribute("aria-expanded",String(!this.collapsed_))}getCollapsible(){return this.collapsible_}setCollapsible(t){this.collapsible_!==t&&(this.collapsible_=t,this.element.classList.toggle("ol-uncollapsible"),this.userCollapsed_&&this.handleToggle_())}setCollapsed(t){this.userCollapsed_=t,!(!this.collapsible_||this.collapsed_===t)&&this.handleToggle_()}getCollapsed(){return this.collapsed_}render(t){this.updateElement_(t.frameState)}}class cp extends Ka{constructor(t){t=t||{},super({element:document.createElement("div"),render:t.render,target:t.target});const e=t.className!==void 0?t.className:"ol-rotate",i=t.label!==void 0?t.label:"⇧",s=t.compassClassName!==void 0?t.compassClassName:"ol-compass";this.label_=null,typeof i=="string"?(this.label_=document.createElement("span"),this.label_.className=s,this.label_.textContent=i):(this.label_=i,this.label_.classList.add(s));const r=t.tipLabel?t.tipLabel:"Reset rotation",o=document.createElement("button");o.className=e+"-reset",o.setAttribute("type","button"),o.title=r,o.appendChild(this.label_),o.addEventListener(V.CLICK,this.handleClick_.bind(this),!1);const a=e+" "+Pr+" "+wa,l=this.element;l.className=a,l.appendChild(o),this.callResetNorth_=t.resetNorth?t.resetNorth:void 0,this.duration_=t.duration!==void 0?t.duration:250,this.autoHide_=t.autoHide!==void 0?t.autoHide:!0,this.rotation_=void 0,this.autoHide_&&this.element.classList.add(Ar)}handleClick_(t){t.preventDefault(),this.callResetNorth_!==void 0?this.callResetNorth_():this.resetNorth_()}resetNorth_(){const e=this.getMap().getView();if(!e)return;const i=e.getRotation();i!==void 0&&(this.duration_>0&&i%(2*Math.PI)!==0?e.animate({rotation:0,duration:this.duration_,easing:Sn}):e.setRotation(0))}render(t){const e=t.frameState;if(!e)return;const i=e.viewState.rotation;if(i!=this.rotation_){const s="rotate("+i+"rad)";if(this.autoHide_){const r=this.element.classList.contains(Ar);!r&&i===0?this.element.classList.add(Ar):r&&i!==0&&this.element.classList.remove(Ar)}this.label_.style.transform=s}this.rotation_=i}}class up extends Ka{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target});const e=t.className!==void 0?t.className:"ol-zoom",i=t.delta!==void 0?t.delta:1,s=t.zoomInClassName!==void 0?t.zoomInClassName:e+"-in",r=t.zoomOutClassName!==void 0?t.zoomOutClassName:e+"-out",o=t.zoomInLabel!==void 0?t.zoomInLabel:"+",a=t.zoomOutLabel!==void 0?t.zoomOutLabel:"–",l=t.zoomInTipLabel!==void 0?t.zoomInTipLabel:"Zoom in",h=t.zoomOutTipLabel!==void 0?t.zoomOutTipLabel:"Zoom out",c=document.createElement("button");c.className=s,c.setAttribute("type","button"),c.title=l,c.appendChild(typeof o=="string"?document.createTextNode(o):o),c.addEventListener(V.CLICK,this.handleClick_.bind(this,i),!1);const u=document.createElement("button");u.className=r,u.setAttribute("type","button"),u.title=h,u.appendChild(typeof a=="string"?document.createTextNode(a):a),u.addEventListener(V.CLICK,this.handleClick_.bind(this,-i),!1);const d=e+" "+Pr+" "+wa,f=this.element;f.className=d,f.appendChild(c),f.appendChild(u),this.duration_=t.duration!==void 0?t.duration:250}handleClick_(t,e){e.preventDefault(),this.zoomByDelta_(t)}zoomByDelta_(t){const i=this.getMap().getView();if(!i)return;const s=i.getZoom();if(s!==void 0){const r=i.getConstrainedZoom(s+t);this.duration_>0?(i.getAnimating()&&i.cancelAnimations(),i.animate({zoom:r,duration:this.duration_,easing:Sn})):i.setZoom(r)}}}function dp(n){n=n||{};const t=new re;return(n.zoom!==void 0?n.zoom:!0)&&t.push(new up(n.zoomOptions)),(n.rotate!==void 0?n.rotate:!0)&&t.push(new cp(n.rotateOptions)),(n.attribution!==void 0?n.attribution:!0)&&t.push(new hp(n.attributionOptions)),t}const wu={ACTIVE:"active"};class Is extends ye{constructor(t){super(),this.on,this.once,this.un,t&&t.handleEvent&&(this.handleEvent=t.handleEvent),this.map_=null,this.setActive(!0)}getActive(){return this.get(wu.ACTIVE)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(wu.ACTIVE,t)}setMap(t){this.map_=t}}function fp(n,t,e){const i=n.getCenterInternal();if(i){const s=[i[0]+t[0],i[1]+t[1]];n.animateInternal({duration:e!==void 0?e:250,easing:Km,center:n.getConstrainedCenter(s)})}}function ja(n,t,e,i){const s=n.getZoom();if(s===void 0)return;const r=n.getConstrainedZoom(s+t),o=n.getResolutionForZoom(r);n.getAnimating()&&n.cancelAnimations(),n.animate({resolution:o,anchor:e,duration:i!==void 0?i:250,easing:Sn})}class gp extends Is{constructor(t){super(),t=t||{},this.delta_=t.delta?t.delta:1,this.duration_=t.duration!==void 0?t.duration:250}handleEvent(t){let e=!1;if(t.type==lt.DBLCLICK){const i=t.originalEvent,s=t.map,r=t.coordinate,o=i.shiftKey?-this.delta_:this.delta_,a=s.getView();ja(a,o,r,this.duration_),i.preventDefault(),e=!0}return!e}}function Ua(n){const t=arguments;return function(e){let i=!0;for(let s=0,r=t.length;s<r&&(i=i&&t[s](e),!!i);++s);return i}}const _p=function(n){const t=n.originalEvent;return t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},mp=function(n){const t=n.map.getTargetElement(),e=t.getRootNode(),i=n.map.getOwnerDocument().activeElement;return e instanceof ShadowRoot?e.host.contains(i):t.contains(i)},vu=function(n){const t=n.map.getTargetElement(),e=t.getRootNode();return(e instanceof ShadowRoot?e.host:t).hasAttribute("tabindex")?mp(n):!0},pp=Un,Cu=function(n){const t=n.originalEvent;return"pointerId"in t&&t.button==0&&!(Kg&&ac&&t.ctrlKey)},Tu=function(n){const t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&!t.shiftKey},yp=function(n){const t=n.originalEvent;return ac?t.metaKey:t.ctrlKey},xp=function(n){const t=n.originalEvent;return!t.altKey&&!(t.metaKey||t.ctrlKey)&&t.shiftKey},Ru=function(n){const t=n.originalEvent,e=t.target.tagName;return e!=="INPUT"&&e!=="SELECT"&&e!=="TEXTAREA"&&!t.target.isContentEditable},Za=function(n){const t=n.originalEvent;return"pointerId"in t&&t.pointerType=="mouse"},Ep=function(n){const t=n.originalEvent;return"pointerId"in t&&t.isPrimary&&t.button===0};class bs extends Is{constructor(t){t=t||{},super(t),t.handleDownEvent&&(this.handleDownEvent=t.handleDownEvent),t.handleDragEvent&&(this.handleDragEvent=t.handleDragEvent),t.handleMoveEvent&&(this.handleMoveEvent=t.handleMoveEvent),t.handleUpEvent&&(this.handleUpEvent=t.handleUpEvent),t.stopDown&&(this.stopDown=t.stopDown),this.handlingDownUpSequence=!1,this.targetPointers=[]}getPointerCount(){return this.targetPointers.length}handleDownEvent(t){return!1}handleDragEvent(t){}handleEvent(t){if(!t.originalEvent)return!0;let e=!1;if(this.updateTrackedPointers_(t),this.handlingDownUpSequence){if(t.type==lt.POINTERDRAG)this.handleDragEvent(t),t.originalEvent.preventDefault();else if(t.type==lt.POINTERUP){const i=this.handleUpEvent(t);this.handlingDownUpSequence=i&&this.targetPointers.length>0}}else if(t.type==lt.POINTERDOWN){const i=this.handleDownEvent(t);this.handlingDownUpSequence=i,e=this.stopDown(i)}else t.type==lt.POINTERMOVE&&this.handleMoveEvent(t);return!e}handleMoveEvent(t){}handleUpEvent(t){return!1}stopDown(t){return t}updateTrackedPointers_(t){t.activePointers&&(this.targetPointers=t.activePointers)}}function Ha(n){const t=n.length;let e=0,i=0;for(let s=0;s<t;s++)e+=n[s].clientX,i+=n[s].clientY;return{clientX:e/t,clientY:i/t}}class wp extends bs{constructor(t){super({stopDown:nr}),t=t||{},this.kinetic_=t.kinetic,this.lastCentroid=null,this.lastPointersCount_,this.panning_=!1;const e=t.condition?t.condition:Ua(Tu,Ep);this.condition_=t.onFocusOnly?Ua(vu,e):e,this.noKinetic_=!1}handleDragEvent(t){const e=t.map;this.panning_||(this.panning_=!0,e.getView().beginInteraction());const i=this.targetPointers,s=e.getEventPixel(Ha(i));if(i.length==this.lastPointersCount_){if(this.kinetic_&&this.kinetic_.update(s[0],s[1]),this.lastCentroid){const r=[this.lastCentroid[0]-s[0],s[1]-this.lastCentroid[1]],a=t.map.getView();Wf(r,a.getResolution()),Mo(r,a.getRotation()),a.adjustCenterInternal(r)}}else this.kinetic_&&this.kinetic_.begin();this.lastCentroid=s,this.lastPointersCount_=i.length,t.originalEvent.preventDefault()}handleUpEvent(t){const e=t.map,i=e.getView();if(this.targetPointers.length===0){if(!this.noKinetic_&&this.kinetic_&&this.kinetic_.end()){const s=this.kinetic_.getDistance(),r=this.kinetic_.getAngle(),o=i.getCenterInternal(),a=e.getPixelFromCoordinateInternal(o),l=e.getCoordinateFromPixelInternal([a[0]-s*Math.cos(r),a[1]-s*Math.sin(r)]);i.animateInternal({center:i.getConstrainedCenter(l),duration:500,easing:Sn})}return this.panning_&&(this.panning_=!1,i.endInteraction()),!1}return this.kinetic_&&this.kinetic_.begin(),this.lastCentroid=null,!0}handleDownEvent(t){if(this.targetPointers.length>0&&this.condition_(t)){const i=t.map.getView();return this.lastCentroid=null,i.getAnimating()&&i.cancelAnimations(),this.kinetic_&&this.kinetic_.begin(),this.noKinetic_=this.targetPointers.length>1,!0}return!1}}class vp extends bs{constructor(t){t=t||{},super({stopDown:nr}),this.condition_=t.condition?t.condition:_p,this.lastAngle_=void 0,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){if(!Za(t))return;const e=t.map,i=e.getView();if(i.getConstraints().rotation===za)return;const s=e.getSize(),r=t.pixel,o=Math.atan2(s[1]/2-r[1],r[0]-s[0]/2);if(this.lastAngle_!==void 0){const a=o-this.lastAngle_;i.adjustRotationInternal(-a)}this.lastAngle_=o}handleUpEvent(t){return Za(t)?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){return Za(t)&&Cu(t)&&this.condition_(t)?(t.map.getView().beginInteraction(),this.lastAngle_=void 0,!0):!1}}class Cp extends ir{constructor(t){super(),this.geometry_=null,this.element_=document.createElement("div"),this.element_.style.position="absolute",this.element_.style.pointerEvents="auto",this.element_.className="ol-box "+t,this.map_=null,this.startPixel_=null,this.endPixel_=null}disposeInternal(){this.setMap(null)}render_(){const t=this.startPixel_,e=this.endPixel_,i="px",s=this.element_.style;s.left=Math.min(t[0],e[0])+i,s.top=Math.min(t[1],e[1])+i,s.width=Math.abs(e[0]-t[0])+i,s.height=Math.abs(e[1]-t[1])+i}setMap(t){if(this.map_){this.map_.getOverlayContainer().removeChild(this.element_);const e=this.element_.style;e.left="inherit",e.top="inherit",e.width="inherit",e.height="inherit"}this.map_=t,this.map_&&this.map_.getOverlayContainer().appendChild(this.element_)}setPixels(t,e){this.startPixel_=t,this.endPixel_=e,this.createOrUpdateGeometry(),this.render_()}createOrUpdateGeometry(){if(!this.map_)return;const t=this.startPixel_,e=this.endPixel_,s=[t,[t[0],e[1]],e,[e[0],t[1]]].map(this.map_.getCoordinateFromPixelInternal,this.map_);s[4]=s[0].slice(),this.geometry_?this.geometry_.setCoordinates([s]):this.geometry_=new gi([s])}getGeometry(){return this.geometry_}}const bn={BOXSTART:"boxstart",BOXDRAG:"boxdrag",BOXEND:"boxend",BOXCANCEL:"boxcancel"};class Ls extends ke{constructor(t,e,i){super(t),this.coordinate=e,this.mapBrowserEvent=i}}class Tp extends bs{constructor(t){super(),this.on,this.once,this.un,t=t??{},this.box_=new Cp(t.className||"ol-dragbox"),this.minArea_=t.minArea??64,t.onBoxEnd&&(this.onBoxEnd=t.onBoxEnd),this.startPixel_=null,this.condition_=t.condition??Cu,this.boxEndCondition_=t.boxEndCondition??this.defaultBoxEndCondition}defaultBoxEndCondition(t,e,i){const s=i[0]-e[0],r=i[1]-e[1];return s*s+r*r>=this.minArea_}getGeometry(){return this.box_.getGeometry()}handleDragEvent(t){this.startPixel_&&(this.box_.setPixels(this.startPixel_,t.pixel),this.dispatchEvent(new Ls(bn.BOXDRAG,t.coordinate,t)))}handleUpEvent(t){if(!this.startPixel_)return!1;const e=this.boxEndCondition_(t,this.startPixel_,t.pixel);return e&&this.onBoxEnd(t),this.dispatchEvent(new Ls(e?bn.BOXEND:bn.BOXCANCEL,t.coordinate,t)),this.box_.setMap(null),this.startPixel_=null,!1}handleDownEvent(t){return this.condition_(t)?(this.startPixel_=t.pixel,this.box_.setMap(t.map),this.box_.setPixels(this.startPixel_,this.startPixel_),this.dispatchEvent(new Ls(bn.BOXSTART,t.coordinate,t)),!0):!1}onBoxEnd(t){}setActive(t){t||(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new Ls(bn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setActive(t)}setMap(t){this.getMap()&&(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new Ls(bn.BOXCANCEL,this.startPixel_,null)),this.startPixel_=null)),super.setMap(t)}}class Rp extends Tp{constructor(t){t=t||{};const e=t.condition?t.condition:xp;super({condition:e,className:t.className||"ol-dragzoom",minArea:t.minArea}),this.duration_=t.duration!==void 0?t.duration:200,this.out_=t.out!==void 0?t.out:!1}onBoxEnd(t){const i=this.getMap().getView();let s=this.getGeometry();if(this.out_){const r=i.rotatedExtentForGeometry(s),o=i.getResolutionForExtentInternal(r),a=i.getResolution()/o;s=s.clone(),s.scale(a*a)}i.fitInternal(s,{duration:this.duration_,easing:Sn})}}const Hi={LEFT:"ArrowLeft",UP:"ArrowUp",RIGHT:"ArrowRight",DOWN:"ArrowDown"};class Sp extends Is{constructor(t){super(),t=t||{},this.defaultCondition_=function(e){return Tu(e)&&Ru(e)},this.condition_=t.condition!==void 0?t.condition:this.defaultCondition_,this.duration_=t.duration!==void 0?t.duration:100,this.pixelDelta_=t.pixelDelta!==void 0?t.pixelDelta:128}handleEvent(t){let e=!1;if(t.type==V.KEYDOWN){const i=t.originalEvent,s=i.key;if(this.condition_(t)&&(s==Hi.DOWN||s==Hi.LEFT||s==Hi.RIGHT||s==Hi.UP)){const o=t.map.getView(),a=o.getResolution()*this.pixelDelta_;let l=0,h=0;s==Hi.DOWN?h=-a:s==Hi.LEFT?l=-a:s==Hi.RIGHT?l=a:h=a;const c=[l,h];Mo(c,o.getRotation()),fp(o,c,this.duration_),i.preventDefault(),e=!0}}return!e}}class Ip extends Is{constructor(t){super(),t=t||{},this.condition_=t.condition?t.condition:function(e){return!yp(e)&&Ru(e)},this.delta_=t.delta?t.delta:1,this.duration_=t.duration!==void 0?t.duration:100}handleEvent(t){let e=!1;if(t.type==V.KEYDOWN||t.type==V.KEYPRESS){const i=t.originalEvent,s=i.key;if(this.condition_(t)&&(s==="+"||s==="-")){const r=t.map,o=s==="+"?this.delta_:-this.delta_,a=r.getView();ja(a,o,void 0,this.duration_),i.preventDefault(),e=!0}}return!e}}const bp=40,Lp=300;class Ap extends Is{constructor(t){t=t||{},super(t),this.totalDelta_=0,this.lastDelta_=0,this.maxDelta_=t.maxDelta!==void 0?t.maxDelta:1,this.duration_=t.duration!==void 0?t.duration:250,this.timeout_=t.timeout!==void 0?t.timeout:80,this.useAnchor_=t.useAnchor!==void 0?t.useAnchor:!0,this.constrainResolution_=t.constrainResolution!==void 0?t.constrainResolution:!1;const e=t.condition?t.condition:pp;this.condition_=t.onFocusOnly?Ua(vu,e):e,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_,this.mode_=void 0,this.trackpadEventGap_=400,this.trackpadTimeoutId_,this.deltaPerZoom_=300}endInteraction_(){this.trackpadTimeoutId_=void 0;const t=this.getMap();if(!t)return;t.getView().endInteraction(void 0,this.lastDelta_?this.lastDelta_>0?1:-1:0,this.lastAnchor_?t.getCoordinateFromPixel(this.lastAnchor_):null)}handleEvent(t){if(!this.condition_(t)||t.type!==V.WHEEL)return!0;const i=t.map,s=t.originalEvent;s.preventDefault(),this.useAnchor_&&(this.lastAnchor_=t.pixel);let r=s.deltaY;switch(s.deltaMode){case WheelEvent.DOM_DELTA_LINE:r*=bp;break;case WheelEvent.DOM_DELTA_PAGE:r*=Lp;break}if(r===0)return!1;this.lastDelta_=r;const o=Date.now();this.startTime_===void 0&&(this.startTime_=o),(!this.mode_||o-this.startTime_>this.trackpadEventGap_)&&(this.mode_=Math.abs(r)<4?"trackpad":"wheel");const a=i.getView();if(this.mode_==="trackpad"&&!(a.getConstrainResolution()||this.constrainResolution_))return this.trackpadTimeoutId_?clearTimeout(this.trackpadTimeoutId_):(a.getAnimating()&&a.cancelAnimations(),a.beginInteraction()),this.trackpadTimeoutId_=setTimeout(this.endInteraction_.bind(this),this.timeout_),a.adjustZoom(-r/this.deltaPerZoom_,this.lastAnchor_?i.getCoordinateFromPixel(this.lastAnchor_):null),this.startTime_=o,!1;this.totalDelta_+=r;const l=Math.max(this.timeout_-(o-this.startTime_),0);return clearTimeout(this.timeoutId_),this.timeoutId_=setTimeout(this.handleWheelZoom_.bind(this,i),l),!1}handleWheelZoom_(t){const e=t.getView();e.getAnimating()&&e.cancelAnimations();let i=-rt(this.totalDelta_,-this.maxDelta_*this.deltaPerZoom_,this.maxDelta_*this.deltaPerZoom_)/this.deltaPerZoom_;(e.getConstrainResolution()||this.constrainResolution_)&&(i=i?i>0?1:-1:0),ja(e,i,this.lastAnchor_?t.getCoordinateFromPixel(this.lastAnchor_):null,this.duration_),this.mode_=void 0,this.totalDelta_=0,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_=void 0}setMouseAnchor(t){this.useAnchor_=t,t||(this.lastAnchor_=null)}}class Pp extends bs{constructor(t){t=t||{};const e=t;e.stopDown||(e.stopDown=nr),super(e),this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.threshold_=t.threshold!==void 0?t.threshold:.3,this.duration_=t.duration!==void 0?t.duration:250}handleDragEvent(t){let e=0;const i=this.targetPointers[0],s=this.targetPointers[1],r=Math.atan2(s.clientY-i.clientY,s.clientX-i.clientX);if(this.lastAngle_!==void 0){const l=r-this.lastAngle_;this.rotationDelta_+=l,!this.rotating_&&Math.abs(this.rotationDelta_)>this.threshold_&&(this.rotating_=!0),e=l}this.lastAngle_=r;const o=t.map,a=o.getView();a.getConstraints().rotation!==za&&(this.anchor_=o.getCoordinateFromPixelInternal(o.getEventPixel(Ha(this.targetPointers))),this.rotating_&&(o.render(),a.adjustRotationInternal(e,this.anchor_)))}handleUpEvent(t){return this.targetPointers.length<2?(t.map.getView().endInteraction(this.duration_),!1):!0}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}}class Mp extends bs{constructor(t){t=t||{};const e=t;e.stopDown||(e.stopDown=nr),super(e),this.anchor_=null,this.duration_=t.duration!==void 0?t.duration:400,this.lastDistance_=void 0,this.lastScaleDelta_=1}handleDragEvent(t){let e=1;const i=this.targetPointers[0],s=this.targetPointers[1],r=i.clientX-s.clientX,o=i.clientY-s.clientY,a=Math.sqrt(r*r+o*o);this.lastDistance_!==void 0&&(e=this.lastDistance_/a),this.lastDistance_=a;const l=t.map,h=l.getView();e!=1&&(this.lastScaleDelta_=e),this.anchor_=l.getCoordinateFromPixelInternal(l.getEventPixel(Ha(this.targetPointers))),l.render(),h.adjustResolutionInternal(e,this.anchor_)}handleUpEvent(t){if(this.targetPointers.length<2){const i=t.map.getView(),s=this.lastScaleDelta_>1?1:-1;return i.endInteraction(this.duration_,s),!1}return!0}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastDistance_=void 0,this.lastScaleDelta_=1,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}}function Fp(n){n=n||{};const t=new re,e=new sp(-.005,.05,100);return(n.altShiftDragRotate!==void 0?n.altShiftDragRotate:!0)&&t.push(new vp),(n.doubleClickZoom!==void 0?n.doubleClickZoom:!0)&&t.push(new gp({delta:n.zoomDelta,duration:n.zoomDuration})),(n.dragPan!==void 0?n.dragPan:!0)&&t.push(new wp({onFocusOnly:n.onFocusOnly,kinetic:e})),(n.pinchRotate!==void 0?n.pinchRotate:!0)&&t.push(new Pp),(n.pinchZoom!==void 0?n.pinchZoom:!0)&&t.push(new Mp({duration:n.zoomDuration})),(n.keyboard!==void 0?n.keyboard:!0)&&(t.push(new Sp),t.push(new Ip({delta:n.zoomDelta,duration:n.zoomDuration}))),(n.mouseWheelZoom!==void 0?n.mouseWheelZoom:!0)&&t.push(new Ap({onFocusOnly:n.onFocusOnly,duration:n.zoomDuration})),(n.shiftDragZoom!==void 0?n.shiftDragZoom:!0)&&t.push(new Rp({duration:n.zoomDuration})),t}const vi={ADDLAYER:"addlayer",REMOVELAYER:"removelayer"};class Ci extends ke{constructor(t,e){super(t),this.layer=e}}const qa={LAYERS:"layers"};class Ln extends yu{constructor(t){t=t||{};const e=Object.assign({},t);delete e.layers;let i=t.layers;super(e),this.on,this.once,this.un,this.layersListenerKeys_=[],this.listenerKeys_={},this.addChangeListener(qa.LAYERS,this.handleLayersChanged_),i?Array.isArray(i)?i=new re(i.slice(),{unique:!0}):J(typeof i.getArray=="function","Expected `layers` to be an array or a `Collection`"):i=new re(void 0,{unique:!0}),this.setLayers(i)}handleLayerChange_(){this.changed()}handleLayersChanged_(){this.layersListenerKeys_.forEach(nt),this.layersListenerKeys_.length=0;const t=this.getLayers();this.layersListenerKeys_.push(H(t,Xt.ADD,this.handleLayersAdd_,this),H(t,Xt.REMOVE,this.handleLayersRemove_,this));for(const i in this.listenerKeys_)this.listenerKeys_[i].forEach(nt);Hn(this.listenerKeys_);const e=t.getArray();for(let i=0,s=e.length;i<s;i++){const r=e[i];this.registerLayerListeners_(r),this.dispatchEvent(new Ci(vi.ADDLAYER,r))}this.changed()}registerLayerListeners_(t){const e=[H(t,rn.PROPERTYCHANGE,this.handleLayerChange_,this),H(t,V.CHANGE,this.handleLayerChange_,this)];t instanceof Ln&&e.push(H(t,vi.ADDLAYER,this.handleLayerGroupAdd_,this),H(t,vi.REMOVELAYER,this.handleLayerGroupRemove_,this)),this.listenerKeys_[B(t)]=e}handleLayerGroupAdd_(t){this.dispatchEvent(new Ci(vi.ADDLAYER,t.layer))}handleLayerGroupRemove_(t){this.dispatchEvent(new Ci(vi.REMOVELAYER,t.layer))}handleLayersAdd_(t){const e=t.element;this.registerLayerListeners_(e),this.dispatchEvent(new Ci(vi.ADDLAYER,e)),this.changed()}handleLayersRemove_(t){const e=t.element,i=B(e);this.listenerKeys_[i].forEach(nt),delete this.listenerKeys_[i],this.dispatchEvent(new Ci(vi.REMOVELAYER,e)),this.changed()}getLayers(){return this.get(qa.LAYERS)}setLayers(t){const e=this.getLayers();if(e){const i=e.getArray();for(let s=0,r=i.length;s<r;++s)this.dispatchEvent(new Ci(vi.REMOVELAYER,i[s]))}this.set(qa.LAYERS,t)}getLayersArray(t){return t=t!==void 0?t:[],this.getLayers().forEach(function(e){e.getLayersArray(t)}),t}getLayerStatesArray(t){const e=t!==void 0?t:[],i=e.length;this.getLayers().forEach(function(o){o.getLayerStatesArray(e)});const s=this.getLayerState();let r=s.zIndex;!t&&s.zIndex===void 0&&(r=0);for(let o=i,a=e.length;o<a;o++){const l=e[o];l.opacity*=s.opacity,l.visible=l.visible&&s.visible,l.maxResolution=Math.min(l.maxResolution,s.maxResolution),l.minResolution=Math.max(l.minResolution,s.minResolution),l.minZoom=Math.max(l.minZoom,s.minZoom),l.maxZoom=Math.min(l.maxZoom,s.maxZoom),s.extent!==void 0&&(l.extent!==void 0?l.extent=Ge(l.extent,s.extent):l.extent=s.extent),l.zIndex===void 0&&(l.zIndex=r)}return e}getSourceState(){return"ready"}}class Op extends ir{constructor(t){super(),this.map_=t}dispatchRenderEvent(t,e){j()}calculateMatrices2D(t){const e=t.viewState,i=t.coordinateToPixelTransform,s=t.pixelToCoordinateTransform;Xe(i,t.size[0]/2,t.size[1]/2,1/e.resolution,-1/e.resolution,-e.rotation,-e.center[0],-e.center[1]),$h(s,i)}forEachFeatureAtCoordinate(t,e,i,s,r,o,a,l){let h;const c=e.viewState;function u(x,E,C,R){return r.call(o,E,x?C:null,R)}const d=c.projection,f=Fo(t.slice(),d),g=[[0,0]];if(d.canWrapX()&&s){const x=d.getExtent(),E=tt(x);g.push([-E,0],[E,0])}const m=e.layerStatesArray,_=m.length,p=[],y=[];for(let x=0;x<g.length;x++)for(let E=_-1;E>=0;--E){const C=m[E],R=C.layer;if(R.hasRenderer()&&Va(C,c)&&a.call(l,R)){const S=R.getRenderer(),b=R.getSource();if(S&&b){const v=b.getWrapX()?f:t,I=u.bind(null,C.managed);y[0]=v[0]+g[x][0],y[1]=v[1]+g[x][1],h=S.forEachFeatureAtCoordinate(y,e,i,I,p)}if(h)return h}}if(p.length===0)return;const w=1/p.length;return p.forEach((x,E)=>x.distanceSq+=E*w),p.sort((x,E)=>x.distanceSq-E.distanceSq),p.some(x=>h=x.callback(x.feature,x.layer,x.geometry)),h}hasFeatureAtCoordinate(t,e,i,s,r,o){return this.forEachFeatureAtCoordinate(t,e,i,s,Un,this,r,o)!==void 0}getMap(){return this.map_}renderFrame(t){j()}scheduleExpireIconCache(t){he.canExpireCache()&&t.postRenderFunctions.push(Dp)}}function Dp(n,t){he.expire()}class kp extends Op{constructor(t){super(t),this.fontChangeListenerKey_=H(yn,rn.PROPERTYCHANGE,t.redrawText,t),this.element_=Zt?dc():document.createElement("div");const e=this.element_.style;e.position="absolute",e.width="100%",e.height="100%",e.zIndex="0",this.element_.className=Pr+" ol-layers";const i=t.getViewport();i&&i.insertBefore(this.element_,i.firstChild||null),this.children_=[],this.renderedVisible_=!0}dispatchRenderEvent(t,e){const i=this.getMap();if(i.hasListener(t)){const s=new Hc(t,void 0,e);i.dispatchEvent(s)}}disposeInternal(){nt(this.fontChangeListenerKey_),this.element_.remove(),super.disposeInternal()}renderFrame(t){if(!t){this.renderedVisible_&&(this.element_.style.display="none",this.renderedVisible_=!1);return}this.calculateMatrices2D(t),this.dispatchRenderEvent(le.PRECOMPOSE,t);const e=t.layerStatesArray.sort((h,c)=>h.zIndex-c.zIndex);e.some(h=>h.layer instanceof Ba&&h.layer.getDeclutter())&&(t.declutter={});const s=t.viewState;this.children_.length=0;const r=[];let o=null;for(let h=0,c=e.length;h<c;++h){const u=e[h];t.layerIndex=h;const d=u.layer,f=d.getSourceState();if(!Va(u,s)||f!="ready"&&f!="undefined"){d.unrender();continue}const g=d.render(t,o);g&&(g!==o&&(this.children_.push(g),o=g),r.push(u))}this.declutter(t,r),Hg(this.element_,this.children_);const l=this.getMap().getTargetElement();if(_i(l)){const h=l.getContext("2d");for(const c of this.children_){const u=c.firstElementChild||c,d=c.style.backgroundColor;if(d&&(!_i(u)||u.width>0)&&(h.fillStyle=d,h.fillRect(0,0,l.width,l.height)),_i(u)&&u.width>0){const f=c.style.opacity||u.style.opacity;h.globalAlpha=f===""?1:Number(f);const g=u.style.transform;if(g)h.setTransform(...Ho(g));else{const m=parseFloat(u.style.width)/u.width,_=parseFloat(u.style.height)/u.height;h.setTransform(m,0,0,_,0,0)}h.drawImage(u,0,0)}}h.globalAlpha=1,h.setTransform(1,0,0,1,0,0)}this.dispatchRenderEvent(le.POSTCOMPOSE,t),this.renderedVisible_||(this.element_.style.display="",this.renderedVisible_=!0),this.scheduleExpireIconCache(t)}declutter(t,e){if(t.declutter){for(let i=e.length-1;i>=0;--i){const s=e[i],r=s.layer;r.getDeclutter()&&r.renderDeclutter(t,s)}e.forEach(i=>i.layer.renderDeferred(t))}}}function Su(n){if(n instanceof qr){n.setMapInternal(null);return}n instanceof Ln&&n.getLayers().forEach(Su)}function Iu(n,t){if(n instanceof qr){n.setMapInternal(t);return}if(n instanceof Ln){const e=n.getLayers().getArray();for(let i=0,s=e.length;i<s;++i)Iu(e[i],t)}}let Np=class extends ye{constructor(t){super(),t=t||{},this.on,this.once,this.un;const e=Gp(t);this.renderComplete_=!1,this.loaded_=!0,this.boundHandleBrowserEvent_=this.handleBrowserEvent.bind(this),this.maxTilesLoading_=t.maxTilesLoading!==void 0?t.maxTilesLoading:16,this.pixelRatio_=t.pixelRatio!==void 0?t.pixelRatio:jg,this.postRenderTimeoutHandle_,this.animationDelayKey_,this.animationDelay_=this.animationDelay_.bind(this),this.coordinateToPixelTransform_=ae(),this.pixelToCoordinateTransform_=ae(),this.frameIndex_=0,this.frameState_=null,this.previousExtent_=null,this.viewPropertyListenerKey_=null,this.viewChangeListenerKey_=null,this.layerGroupPropertyListenerKeys_=null,Zt||(this.viewport_=document.createElement("div"),this.viewport_.className="ol-viewport"+("ontouchstart"in window?" ol-touch":""),this.viewport_.style.position="relative",this.viewport_.style.overflow="hidden",this.viewport_.style.width="100%",this.viewport_.style.height="100%",this.overlayContainer_=document.createElement("div"),this.overlayContainer_.style.position="absolute",this.overlayContainer_.style.zIndex="0",this.overlayContainer_.style.width="100%",this.overlayContainer_.style.height="100%",this.overlayContainer_.style.pointerEvents="none",this.overlayContainer_.className="ol-overlaycontainer",this.viewport_.appendChild(this.overlayContainer_),this.overlayContainerStopEvent_=document.createElement("div"),this.overlayContainerStopEvent_.style.position="absolute",this.overlayContainerStopEvent_.style.zIndex="0",this.overlayContainerStopEvent_.style.width="100%",this.overlayContainerStopEvent_.style.height="100%",this.overlayContainerStopEvent_.style.pointerEvents="none",this.overlayContainerStopEvent_.className="ol-overlaycontainer-stopevent",this.viewport_.appendChild(this.overlayContainerStopEvent_)),this.mapBrowserEventHandler_=null,this.moveTolerance_=t.moveTolerance,this.keyboardEventTarget_=e.keyboardEventTarget,this.targetChangeHandlerKeys_=null,this.targetElement_=null,Zt||(this.resizeObserver_=new ResizeObserver(()=>this.updateSize())),this.controls=e.controls||(Zt?new re:dp()),this.interactions=e.interactions||(Zt?new re:Fp({onFocusOnly:!0})),this.overlays_=e.overlays,this.overlayIdIndex_={},this.renderer_=null,this.postRenderFunctions_=[],this.tileQueue_=new ap(this.getTilePriority.bind(this),this.handleTileChange_.bind(this)),this.addChangeListener(St.LAYERGROUP,this.handleLayerGroupChanged_),this.addChangeListener(St.VIEW,this.handleViewChanged_),this.addChangeListener(St.SIZE,this.handleSizeChanged_),this.addChangeListener(St.TARGET,this.handleTargetChanged_),this.setProperties(e.values);const i=this;t.view&&!(t.view instanceof Ie)&&t.view.then(function(s){i.setView(new Ie(s))}),this.controls.addEventListener(Xt.ADD,s=>{s.element.setMap(this)}),this.controls.addEventListener(Xt.REMOVE,s=>{s.element.setMap(null)}),this.interactions.addEventListener(Xt.ADD,s=>{s.element.setMap(this)}),this.interactions.addEventListener(Xt.REMOVE,s=>{s.element.setMap(null)}),this.overlays_.addEventListener(Xt.ADD,s=>{this.addOverlayInternal_(s.element)}),this.overlays_.addEventListener(Xt.REMOVE,s=>{const r=s.element.getId();r!==void 0&&delete this.overlayIdIndex_[r.toString()],s.element.setMap(null)}),this.controls.forEach(s=>{s.setMap(this)}),this.interactions.forEach(s=>{s.setMap(this)}),this.overlays_.forEach(this.addOverlayInternal_.bind(this))}addControl(t){this.getControls().push(t)}addInteraction(t){this.getInteractions().push(t)}addLayer(t){this.getLayerGroup().getLayers().push(t)}handleLayerAdd_(t){Iu(t.layer,this)}addOverlay(t){this.getOverlays().push(t)}addOverlayInternal_(t){const e=t.getId();e!==void 0&&(this.overlayIdIndex_[e.toString()]=t),t.setMap(this)}disposeInternal(){this.controls.clear(),this.interactions.clear(),this.overlays_.clear(),this.resizeObserver_?.disconnect(),this.setTarget(null),super.disposeInternal()}forEachFeatureAtPixel(t,e,i){if(!this.frameState_||!this.renderer_)return;const s=this.getCoordinateFromPixelInternal(t);i=i!==void 0?i:{};const r=i.hitTolerance!==void 0?i.hitTolerance:0,o=i.layerFilter!==void 0?i.layerFilter:Un,a=i.checkWrapped!==!1;return this.renderer_.forEachFeatureAtCoordinate(s,this.frameState_,r,a,e,null,o,null)}getFeaturesAtPixel(t,e){const i=[];return this.forEachFeatureAtPixel(t,function(s){i.push(s)},e),i}getAllLayers(){const t=[];function e(i){i.forEach(function(s){s instanceof Ln?e(s.getLayers()):t.push(s)})}return e(this.getLayers()),t}hasFeatureAtPixel(t,e){if(!this.frameState_||!this.renderer_)return!1;const i=this.getCoordinateFromPixelInternal(t);e=e!==void 0?e:{};const s=e.layerFilter!==void 0?e.layerFilter:Un,r=e.hitTolerance!==void 0?e.hitTolerance:0,o=e.checkWrapped!==!1;return this.renderer_.hasFeatureAtCoordinate(i,this.frameState_,r,o,s,null)}getEventCoordinate(t){return this.getCoordinateFromPixel(this.getEventPixel(t))}getEventCoordinateInternal(t){return this.getCoordinateFromPixelInternal(this.getEventPixel(t))}getEventPixel(t){const i=this.viewport_.getBoundingClientRect(),s=this.getSize(),r=i.width/s[0],o=i.height/s[1],a="changedTouches"in t?t.changedTouches[0]:t;return[(a.clientX-i.left)/r,(a.clientY-i.top)/o]}getTarget(){return this.get(St.TARGET)}getTargetElement(){return this.targetElement_}getCoordinateFromPixel(t){return $o(this.getCoordinateFromPixelInternal(t),this.getView().getProjection())}getCoordinateFromPixelInternal(t){const e=this.frameState_;return e?gt(e.pixelToCoordinateTransform,t.slice()):null}getControls(){return this.controls}getOverlays(){return this.overlays_}getOverlayById(t){const e=this.overlayIdIndex_[t.toString()];return e!==void 0?e:null}getInteractions(){return this.interactions}getLayerGroup(){return this.get(St.LAYERGROUP)}setLayers(t){const e=this.getLayerGroup();if(t instanceof re){e.setLayers(t);return}const i=e.getLayers();i.clear(),i.extend(t)}getLayers(){return this.getLayerGroup().getLayers()}getLoadingOrNotReady(){const t=this.getLayerGroup().getLayerStatesArray();for(let e=0,i=t.length;e<i;++e){const s=t[e];if(!s.visible)continue;const r=s.layer.getRenderer();if(r&&!r.ready)return!0;const o=s.layer.getSource();if(o&&o.loading)return!0}return!1}getPixelFromCoordinate(t){const e=ze(t,this.getView().getProjection());return this.getPixelFromCoordinateInternal(e)}getPixelFromCoordinateInternal(t){const e=this.frameState_;return e?gt(e.coordinateToPixelTransform,t.slice(0,2)):null}getRenderer(){return this.renderer_}getSize(){return this.get(St.SIZE)}getView(){return this.get(St.VIEW)}getViewport(){return this.viewport_}getOverlayContainer(){return this.overlayContainer_}getOverlayContainerStopEvent(){return this.overlayContainerStopEvent_}getOwnerDocument(){const t=this.getTargetElement();return t?t.ownerDocument:document}getTilePriority(t,e,i,s){return lp(this.frameState_,t,e,i,s)}handleBrowserEvent(t,e){e=e||t.type;const i=new wi(e,this,t);this.handleMapBrowserEvent(i)}handleMapBrowserEvent(t){if(!this.frameState_)return;const e=t.originalEvent,i=e.type;if(i===$a.POINTERDOWN||i===V.WHEEL||i===V.KEYDOWN){const s=this.getOwnerDocument(),r=this.viewport_.getRootNode?this.viewport_.getRootNode():s,o=e.target,a=r instanceof ShadowRoot?r.host===o?r.host.ownerDocument:r:r===s?s.documentElement:r;if(this.overlayContainerStopEvent_.contains(o)||!a.contains(o))return}if(t.frameState=this.frameState_,this.dispatchEvent(t)!==!1){const s=this.getInteractions().getArray().slice();for(let r=s.length-1;r>=0;r--){const o=s[r];if(o.getMap()!==this||!o.getActive()||!this.getTargetElement())continue;if(!o.handleEvent(t)||t.propagationStopped)break}}}handlePostRender(){const t=this.frameState_,e=this.tileQueue_;if(!e.isEmpty()){let s=this.maxTilesLoading_,r=s;if(t){const o=t.viewHints;if(o[at.ANIMATING]||o[at.INTERACTING]){const a=Date.now()-t.time>8;s=a?0:8,r=a?0:2}}e.getTilesLoading()<s&&(e.reprioritize(),e.loadMoreTiles(s,r))}t&&this.renderer_&&!t.animate&&(this.renderComplete_?(this.hasListener(le.RENDERCOMPLETE)&&this.renderer_.dispatchRenderEvent(le.RENDERCOMPLETE,t),this.loaded_===!1&&(this.loaded_=!0,this.dispatchEvent(new In(je.LOADEND,this,t)))):this.loaded_===!0&&(this.loaded_=!1,this.dispatchEvent(new In(je.LOADSTART,this,t))));const i=this.postRenderFunctions_;if(t)for(let s=0,r=i.length;s<r;++s)i[s](this,t);i.length=0}handleSizeChanged_(){this.getView()&&!this.getView().getAnimating()&&this.getView().resolveConstraints(0),this.render()}handleTargetChanged_(){if(this.mapBrowserEventHandler_){for(let i=0,s=this.targetChangeHandlerKeys_.length;i<s;++i)nt(this.targetChangeHandlerKeys_[i]);this.targetChangeHandlerKeys_=null,this.viewport_.removeEventListener(V.CONTEXTMENU,this.boundHandleBrowserEvent_),this.viewport_.removeEventListener(V.WHEEL,this.boundHandleBrowserEvent_),this.mapBrowserEventHandler_.dispose(),this.mapBrowserEventHandler_=null,this.viewport_.remove()}if(this.targetElement_&&!_i(this.targetElement_)){this.resizeObserver_?.unobserve(this.targetElement_);const i=this.targetElement_.getRootNode();i instanceof ShadowRoot&&this.resizeObserver_.unobserve(i.host),this.setSize(void 0)}const t=this.getTarget(),e=typeof t=="string"?document.getElementById(t):t;if(this.targetElement_=e,!e)this.renderer_&&(clearTimeout(this.postRenderTimeoutHandle_),this.postRenderTimeoutHandle_=void 0,this.postRenderFunctions_.length=0,this.renderer_.dispose(),this.renderer_=null),this.animationDelayKey_&&(cancelAnimationFrame(this.animationDelayKey_),this.animationDelayKey_=void 0);else{if(_i(e)||e.appendChild(this.viewport_),this.renderer_||(this.renderer_=new kp(this)),!_i(e)){this.mapBrowserEventHandler_=new rp(this,this.moveTolerance_);for(const s in lt)this.mapBrowserEventHandler_.addEventListener(lt[s],this.handleMapBrowserEvent.bind(this));this.viewport_.addEventListener(V.CONTEXTMENU,this.boundHandleBrowserEvent_,!1),this.viewport_.addEventListener(V.WHEEL,this.boundHandleBrowserEvent_,hc?{passive:!1}:!1);let i;if(this.keyboardEventTarget_)i=this.keyboardEventTarget_;else{const s=e.getRootNode();i=s instanceof ShadowRoot?s.host:e}if(this.targetChangeHandlerKeys_=[H(i,V.KEYDOWN,this.handleBrowserEvent,this),H(i,V.KEYPRESS,this.handleBrowserEvent,this)],e instanceof HTMLElement){const s=e.getRootNode();s instanceof ShadowRoot&&this.resizeObserver_.observe(s.host),this.resizeObserver_?.observe(e)}}this.updateSize()}}handleTileChange_(){this.render()}handleViewPropertyChanged_(){this.render()}handleViewChanged_(){this.viewPropertyListenerKey_&&(nt(this.viewPropertyListenerKey_),this.viewPropertyListenerKey_=null),this.viewChangeListenerKey_&&(nt(this.viewChangeListenerKey_),this.viewChangeListenerKey_=null);const t=this.getView();t&&(this.updateViewportSize_(this.getSize()),this.viewPropertyListenerKey_=H(t,rn.PROPERTYCHANGE,this.handleViewPropertyChanged_,this),this.viewChangeListenerKey_=H(t,V.CHANGE,this.handleViewPropertyChanged_,this),t.resolveConstraints(0)),this.render()}handleLayerGroupChanged_(){this.layerGroupPropertyListenerKeys_&&(this.layerGroupPropertyListenerKeys_.forEach(nt),this.layerGroupPropertyListenerKeys_=null);const t=this.getLayerGroup();t&&(this.handleLayerAdd_(new Ci("addlayer",t)),this.layerGroupPropertyListenerKeys_=[H(t,rn.PROPERTYCHANGE,this.render,this),H(t,V.CHANGE,this.render,this),H(t,"addlayer",this.handleLayerAdd_,this),H(t,"removelayer",this.handleLayerRemove_,this)]),this.render()}isRendered(){return!!this.frameState_}animationDelay_(){this.animationDelayKey_=void 0,this.renderFrame_(Date.now())}renderSync(){this.animationDelayKey_&&cancelAnimationFrame(this.animationDelayKey_),this.animationDelay_()}redrawText(){if(!this.frameState_)return;const t=this.frameState_.layerStatesArray;for(let e=0,i=t.length;e<i;++e){const s=t[e].layer;s.hasRenderer()&&s.getRenderer().handleFontsChanged()}}render(){this.renderer_&&this.animationDelayKey_===void 0&&(this.animationDelayKey_=requestAnimationFrame(this.animationDelay_))}removeControl(t){return this.getControls().remove(t)}removeInteraction(t){return this.getInteractions().remove(t)}removeLayer(t){return this.getLayerGroup().getLayers().remove(t)}handleLayerRemove_(t){Su(t.layer)}removeOverlay(t){return this.getOverlays().remove(t)}renderFrame_(t){const e=this.getSize(),i=this.getView(),s=this.frameState_;let r=null;if(e!==void 0&&Nc(e)&&i&&i.isDef()){const o=i.getHints(this.frameState_?this.frameState_.viewHints:void 0),a=i.getState();if(r={animate:!1,coordinateToPixelTransform:this.coordinateToPixelTransform_,declutter:null,extent:Ao(a.center,a.resolution,a.rotation,e),index:this.frameIndex_++,layerIndex:0,layerStatesArray:this.getLayerGroup().getLayerStatesArray(),pixelRatio:this.pixelRatio_,pixelToCoordinateTransform:this.pixelToCoordinateTransform_,postRenderFunctions:[],size:e,tileQueue:this.tileQueue_,time:t,usedTiles:{},viewState:a,viewHints:o,wantedTiles:{},mapId:B(this),renderTargets:{}},a.nextCenter&&a.nextResolution){const l=isNaN(a.nextRotation)?a.rotation:a.nextRotation;r.nextExtent=Ao(a.nextCenter,a.nextResolution,l,e)}}this.frameState_=r,this.renderer_.renderFrame(r),r&&(r.animate&&this.render(),Array.prototype.push.apply(this.postRenderFunctions_,r.postRenderFunctions),s&&(!this.previousExtent_||!ts(this.previousExtent_)&&!ln(r.extent,this.previousExtent_))&&(this.dispatchEvent(new In(je.MOVESTART,this,s)),this.previousExtent_=Jn(this.previousExtent_)),this.previousExtent_&&!r.viewHints[at.ANIMATING]&&!r.viewHints[at.INTERACTING]&&!ln(r.extent,this.previousExtent_)&&(this.dispatchEvent(new In(je.MOVEEND,this,r)),ph(r.extent,this.previousExtent_))),this.dispatchEvent(new In(je.POSTRENDER,this,r)),this.renderComplete_=(this.hasListener(je.LOADSTART)||this.hasListener(je.LOADEND)||this.hasListener(le.RENDERCOMPLETE))&&!this.tileQueue_.getTilesLoading()&&!this.tileQueue_.getCount()&&!this.getLoadingOrNotReady(),this.postRenderTimeoutHandle_||(this.postRenderTimeoutHandle_=setTimeout(()=>{this.postRenderTimeoutHandle_=void 0,this.handlePostRender()},0))}setLayerGroup(t){const e=this.getLayerGroup();e&&this.handleLayerRemove_(new Ci("removelayer",e)),this.set(St.LAYERGROUP,t)}setSize(t){this.set(St.SIZE,t)}setTarget(t){this.set(St.TARGET,t)}setView(t){if(!t||t instanceof Ie){this.set(St.VIEW,t);return}this.set(St.VIEW,new Ie);const e=this;t.then(function(i){e.setView(new Ie(i))})}updateSize(){const t=this.getTargetElement();let e;if(t){let s,r;if(_i(t))s=t.width,r=t.height;else{const o=getComputedStyle(t);s=t.offsetWidth-parseFloat(o.borderLeftWidth)-parseFloat(o.paddingLeft)-parseFloat(o.paddingRight)-parseFloat(o.borderRightWidth),r=t.offsetHeight-parseFloat(o.borderTopWidth)-parseFloat(o.paddingTop)-parseFloat(o.paddingBottom)-parseFloat(o.borderBottomWidth)}!isNaN(s)&&!isNaN(r)&&(e=[Math.max(0,s),Math.max(0,r)],!Nc(e)&&(t.offsetWidth||t.offsetHeight||t.getClientRects().length)&&Ih("No map visible because the map container's width or height are 0."))}const i=this.getSize();e&&(!i||!ai(e,i))&&(this.setSize(e),this.updateViewportSize_(e))}updateViewportSize_(t){const e=this.getView();e&&e.setViewportSize(t)}};function Gp(n){let t=null;n.keyboardEventTarget!==void 0&&(t=typeof n.keyboardEventTarget=="string"?document.getElementById(n.keyboardEventTarget):n.keyboardEventTarget);const e={},i=n.layers&&typeof n.layers.getLayers=="function"?n.layers:new Ln({layers:n.layers});e[St.LAYERGROUP]=i,e[St.TARGET]=n.target,e[St.VIEW]=n.view instanceof Ie?n.view:new Ie;let s;n.controls!==void 0&&(Array.isArray(n.controls)?s=new re(n.controls.slice()):(J(typeof n.controls.getArray=="function","Expected `controls` to be an array or an `ol/Collection.js`"),s=n.controls));let r;n.interactions!==void 0&&(Array.isArray(n.interactions)?r=new re(n.interactions.slice()):(J(typeof n.interactions.getArray=="function","Expected `interactions` to be an array or an `ol/Collection.js`"),r=n.interactions));let o;return n.overlays!==void 0?Array.isArray(n.overlays)?o=new re(n.overlays.slice()):(J(typeof n.overlays.getArray=="function","Expected `overlays` to be an array or an `ol/Collection.js`"),o=n.overlays):o=new re,{controls:s,interactions:r,keyboardEventTarget:t,overlays:o,values:e}}const It={ELEMENT:"element",MAP:"map",OFFSET:"offset",POSITION:"position",POSITIONING:"positioning"};class zp extends ye{constructor(t){super(),this.on,this.once,this.un,this.options=t,this.id=t.id,this.insertFirst=t.insertFirst!==void 0?t.insertFirst:!0,this.stopEvent=t.stopEvent!==void 0?t.stopEvent:!0,this.element=document.createElement("div"),this.element.className=t.className!==void 0?t.className:"ol-overlay-container "+u_,this.element.style.position="absolute",this.element.style.pointerEvents="auto",this.autoPan=t.autoPan===!0?{}:t.autoPan||void 0,this.rendered={transform_:"",visible:!0},this.mapPostrenderListenerKey=null,this.addChangeListener(It.ELEMENT,this.handleElementChanged),this.addChangeListener(It.MAP,this.handleMapChanged),this.addChangeListener(It.OFFSET,this.handleOffsetChanged),this.addChangeListener(It.POSITION,this.handlePositionChanged),this.addChangeListener(It.POSITIONING,this.handlePositioningChanged),t.element!==void 0&&this.setElement(t.element),this.setOffset(t.offset!==void 0?t.offset:[0,0]),this.setPositioning(t.positioning||"top-left"),t.position!==void 0&&this.setPosition(t.position)}getElement(){return this.get(It.ELEMENT)}getId(){return this.id}getMap(){return this.get(It.MAP)||null}getOffset(){return this.get(It.OFFSET)}getPosition(){return this.get(It.POSITION)}getPositioning(){return this.get(It.POSITIONING)}handleElementChanged(){uc(this.element);const t=this.getElement();t&&this.element.appendChild(t)}handleMapChanged(){this.mapPostrenderListenerKey&&(this.element?.remove(),nt(this.mapPostrenderListenerKey),this.mapPostrenderListenerKey=null);const t=this.getMap();if(t){this.mapPostrenderListenerKey=H(t,je.POSTRENDER,this.render,this),this.updatePixelPosition();const e=this.stopEvent?t.getOverlayContainerStopEvent():t.getOverlayContainer();this.insertFirst?e.insertBefore(this.element,e.childNodes[0]||null):e.appendChild(this.element),this.performAutoPan()}}render(){this.updatePixelPosition()}handleOffsetChanged(){this.updatePixelPosition()}handlePositionChanged(){this.updatePixelPosition(),this.performAutoPan()}handlePositioningChanged(){this.updatePixelPosition()}setElement(t){this.set(It.ELEMENT,t)}setMap(t){this.set(It.MAP,t)}setOffset(t){this.set(It.OFFSET,t)}setPosition(t){this.set(It.POSITION,t)}performAutoPan(){this.autoPan&&this.panIntoView(this.autoPan)}panIntoView(t){const e=this.getMap();if(!e||!e.getTargetElement()||!this.get(It.POSITION))return;const i=this.getRect(e.getTargetElement(),e.getSize()),s=this.getElement(),r=this.getRect(s,[Ug(s),Zg(s)]);t=t||{};const o=t.margin===void 0?20:t.margin;if(!Oi(i,r)){const a=r[0]-i[0],l=i[2]-r[2],h=r[1]-i[1],c=i[3]-r[3],u=[0,0];if(a<0?u[0]=a-o:l<0&&(u[0]=Math.abs(l)+o),h<0?u[1]=h-o:c<0&&(u[1]=Math.abs(c)+o),u[0]!==0||u[1]!==0){const d=e.getView().getCenterInternal(),f=e.getPixelFromCoordinateInternal(d);if(!f)return;const g=[f[0]+u[0],f[1]+u[1]],m=t.animation||{};e.getView().animateInternal({center:e.getCoordinateFromPixelInternal(g),duration:m.duration,easing:m.easing})}}}getRect(t,e){const i=t.getBoundingClientRect(),s=i.left+window.pageXOffset,r=i.top+window.pageYOffset;return[s,r,s+e[0],r+e[1]]}setPositioning(t){this.set(It.POSITIONING,t)}setVisible(t){this.rendered.visible!==t&&(this.element.style.display=t?"":"none",this.rendered.visible=t)}updatePixelPosition(){const t=this.getMap(),e=this.getPosition();if(!t||!t.isRendered()||!e){this.setVisible(!1);return}const i=t.getPixelFromCoordinate(e),s=t.getSize();this.updateRenderedPosition(i,s)}updateRenderedPosition(t,e){const i=this.element.style,s=this.getOffset(),r=this.getPositioning();this.setVisible(!0);const o=`${t[0]+s[0]}px`,a=`${t[1]+s[1]}px`;let l="0%",h="0%";r=="bottom-right"||r=="center-right"||r=="top-right"?l="-100%":(r=="bottom-center"||r=="center-center"||r=="top-center")&&(l="-50%"),r=="bottom-left"||r=="bottom-center"||r=="bottom-right"?h="-100%":(r=="center-left"||r=="center-center"||r=="center-right")&&(h="-50%");const c=`translate(${l}, ${h}) translate(${o}, ${a})`;this.rendered.transform_!=c&&(this.rendered.transform_=c,i.transform=c)}getOptions(){return this.options}}class Ja{constructor(t,e,i,s){this.minX=t,this.maxX=e,this.minY=i,this.maxY=s}contains(t){return this.containsXY(t[1],t[2])}containsTileRange(t){return this.minX<=t.minX&&t.maxX<=this.maxX&&this.minY<=t.minY&&t.maxY<=this.maxY}containsXY(t,e){return this.minX<=t&&t<=this.maxX&&this.minY<=e&&e<=this.maxY}equals(t){return this.minX==t.minX&&this.minY==t.minY&&this.maxX==t.maxX&&this.maxY==t.maxY}extend(t){t.minX<this.minX&&(this.minX=t.minX),t.maxX>this.maxX&&(this.maxX=t.maxX),t.minY<this.minY&&(this.minY=t.minY),t.maxY>this.maxY&&(this.maxY=t.maxY)}getHeight(){return this.maxY-this.minY+1}getSize(){return[this.getWidth(),this.getHeight()]}getWidth(){return this.maxX-this.minX+1}intersects(t){return this.minX<=t.maxX&&this.maxX>=t.minX&&this.minY<=t.maxY&&this.maxY>=t.minY}}function An(n,t,e,i,s){return s!==void 0?(s.minX=n,s.maxX=t,s.minY=e,s.maxY=i,s):new Ja(n,t,e,i)}const bu=[];class Xp extends Ss{constructor(t,e,i,s,r){super(t,e,{transition:0}),this.context_=null,this.executorGroups={},this.loadingSourceTiles=0,this.hitDetectionImageData={},this.replayState_={},this.sourceTiles=[],this.errorTileKeys={},this.wantedResolution,this.getSourceTiles=s.bind(void 0,this),this.removeSourceTiles_=r,this.wrappedTileCoord=i}getContext(){return this.context_||(this.context_=ut(1,1,bu)),this.context_}hasContext(){return!!this.context_}getImage(){return this.hasContext()?this.getContext().canvas:null}getReplayState(t){const e=B(t);return e in this.replayState_||(this.replayState_[e]={dirty:!1,renderedRenderOrder:null,renderedResolution:NaN,renderedRevision:-1,renderedTileResolution:NaN,renderedTileRevision:-1,renderedTileZ:-1}),this.replayState_[e]}load(){this.getSourceTiles()}release(){this.context_&&(os(this.context_),bu.push(this.context_.canvas),this.context_=null),this.removeSourceTiles_(this),this.sourceTiles.length=0,super.release()}}let Yp=class extends Ss{constructor(t,e,i,s,r,o){super(t,e,o),this.extent=null,this.format_=s,this.features_=null,this.loader_,this.projection=null,this.resolution,this.tileLoadFunction_=r,this.url_=i,this.key=i}getTileUrl(){return this.url_}getFormat(){return this.format_}getFeatures(){return this.features_}load(){this.state==O.IDLE&&(this.setState(O.LOADING),this.tileLoadFunction_(this,this.url_),this.loader_&&this.loader_(this.extent,this.resolution,this.projection))}onLoad(t,e){this.setFeatures(t)}onError(){this.setState(O.ERROR)}setFeatures(t){this.features_=t,this.setState(O.LOADED)}setLoader(t){this.loader_=t}},Qa;const Pn=[];function Lu(n,t,e,i,s){n.beginPath(),n.moveTo(0,0),n.lineTo(t,e),n.lineTo(i,s),n.closePath(),n.save(),n.clip(),n.fillRect(0,0,Math.max(t,i)+1,Math.max(e,s)),n.restore()}function tl(n,t){return Math.abs(n[t*4]-210)>2||Math.abs(n[t*4+3]-.75*255)>2}function Wp(){if(Qa===void 0){const n=ut(6,6,Pn);n.globalCompositeOperation="lighter",n.fillStyle="rgba(210, 0, 0, 0.75)",Lu(n,4,5,4,0),Lu(n,4,5,0,5);const t=n.getImageData(0,0,3,3).data;Qa=tl(t,0)||tl(t,4)||tl(t,8),os(n),Pn.push(n.canvas)}return Qa}function Au(n,t,e,i){const s=ns(e,t,n);let r=Yh(t,i,e);const o=t.getMetersPerUnit();o!==void 0&&(r*=o);const a=n.getMetersPerUnit();a!==void 0&&(r/=a);const l=n.getExtent();if(!l||an(l,s)){const h=Yh(n,r,s)/r;isFinite(h)&&h>0&&(r/=h)}return r}function Vp(n,t,e,i){const s=Di(e);let r=Au(n,t,s,i);return(!isFinite(r)||r<=0)&&wh(e,function(o){return r=Au(n,t,o,i),isFinite(r)&&r>0}),r}function Bp(n,t,e,i,s,r,o,a,l,h,c,u,d,f){const g=ut(Math.round(e*n),Math.round(e*t),Pn);if(u||(g.imageSmoothingEnabled=!1),l.length===0)return g.canvas;g.scale(e,e);function m(E){return Math.round(E*e)/e}g.globalCompositeOperation="lighter";const _=Kt();l.forEach(function(E,C,R){xh(_,E.extent)});let p;const y=e/i,w=(u?1:1+Math.pow(2,-24))/y;p=ut(Math.round(tt(_)*y),Math.round(Ot(_)*y),Pn),u||(p.imageSmoothingEnabled=!1),l.forEach(function(E,C,R){if(E.image.width>0&&E.image.height>0){if(E.clipExtent){p.save();const A=(E.clipExtent[0]-_[0])*y,F=-(E.clipExtent[3]-_[3])*y,M=tt(E.clipExtent)*y,N=Ot(E.clipExtent)*y;p.rect(u?A:Math.round(A),u?F:Math.round(F),u?M:Math.round(A+M)-Math.round(A),u?N:Math.round(F+N)-Math.round(F)),p.clip()}const S=(E.extent[0]-_[0])*y,b=-(E.extent[3]-_[3])*y,v=tt(E.extent)*y,I=Ot(E.extent)*y;p.drawImage(E.image,h,h,E.image.width-2*h,E.image.height-2*h,u?S:Math.round(S),u?b:Math.round(b),u?v:Math.round(S+v)-Math.round(S),u?I:Math.round(b+I)-Math.round(b)),E.clipExtent&&p.restore()}});const x=hi(o);return a.getTriangles().forEach(function(E,C,R){const S=E.source,b=E.target;let v=S[0][0],I=S[0][1],A=S[1][0],F=S[1][1],M=S[2][0],N=S[2][1];const L=m((b[0][0]-x[0])/r),k=m(-(b[0][1]-x[1])/r),D=m((b[1][0]-x[0])/r),X=m(-(b[1][1]-x[1])/r),Y=m((b[2][0]-x[0])/r),W=m(-(b[2][1]-x[1])/r),P=v,pt=I;v=0,I=0,A-=P,F-=pt,M-=P,N-=pt;const yt=[[A,F,0,0,D-L],[M,N,0,0,Y-L],[0,0,A,F,X-k],[0,0,M,N,W-k]],ot=zf(yt);if(!ot)return;if(g.save(),g.beginPath(),Wp()||!u){g.moveTo(D,X);const dt=4,Nt=L-D,bt=k-X;for(let Et=0;Et<dt;Et++)g.lineTo(D+m((Et+1)*Nt/dt),X+m(Et*bt/(dt-1))),Et!=dt-1&&g.lineTo(D+m((Et+1)*Nt/dt),X+m((Et+1)*bt/(dt-1)));g.lineTo(Y,W)}else g.moveTo(D,X),g.lineTo(L,k),g.lineTo(Y,W);g.clip(),g.transform(ot[0],ot[2],ot[1],ot[3],L,k),g.translate(_[0]-P,_[3]-pt);let kt;if(p)kt=p.canvas,g.scale(w,-w);else{const dt=l[0],Nt=dt.extent;kt=dt.image,g.scale(tt(Nt)/kt.width,-Ot(Nt)/kt.height)}g.drawImage(kt,0,0),g.restore()}),p&&(os(p),Pn.push(p.canvas)),c&&(g.save(),g.globalCompositeOperation="source-over",g.strokeStyle="black",g.lineWidth=1,a.getTriangles().forEach(function(E,C,R){const S=E.target,b=(S[0][0]-x[0])/r,v=-(S[0][1]-x[1])/r,I=(S[1][0]-x[0])/r,A=-(S[1][1]-x[1])/r,F=(S[2][0]-x[0])/r,M=-(S[2][1]-x[1])/r;g.beginPath(),g.moveTo(I,A),g.lineTo(b,v),g.lineTo(F,M),g.closePath(),g.stroke()}),g.restore()),g.canvas}const $p=10,Pu=.25;class Kp{constructor(t,e,i,s,r,o,a){this.sourceProj_=t,this.targetProj_=e;let l={};const h=a?mg(w=>gt(a,ns(w,this.targetProj_,this.sourceProj_))):zi(this.targetProj_,this.sourceProj_);this.transformInv_=function(w){const x=w[0]+"/"+w[1];return l[x]||(l[x]=h(w)),l[x]},this.maxSourceExtent_=s,this.errorThresholdSquared_=r*r,this.triangles_=[],this.wrapsXInSource_=!1,this.canWrapXInSource_=this.sourceProj_.canWrapX()&&!!s&&!!this.sourceProj_.getExtent()&&tt(s)>=tt(this.sourceProj_.getExtent()),this.sourceWorldWidth_=this.sourceProj_.getExtent()?tt(this.sourceProj_.getExtent()):null,this.targetWorldWidth_=this.targetProj_.getExtent()?tt(this.targetProj_.getExtent()):null;const c=hi(i),u=cr(i),d=hr(i),f=lr(i),g=this.transformInv_(c),m=this.transformInv_(u),_=this.transformInv_(d),p=this.transformInv_(f),y=$p+(o?Math.max(0,Math.ceil(Math.log2(Lo(i)/(o*o*256*256)))):0);if(this.addQuad_(c,u,d,f,g,m,_,p,y),this.wrapsXInSource_){let w=1/0;this.triangles_.forEach(function(x,E,C){w=Math.min(w,x.source[0][0],x.source[1][0],x.source[2][0])}),this.triangles_.forEach(x=>{if(Math.max(x.source[0][0],x.source[1][0],x.source[2][0])-w>this.sourceWorldWidth_/2){const E=[[x.source[0][0],x.source[0][1]],[x.source[1][0],x.source[1][1]],[x.source[2][0],x.source[2][1]]];E[0][0]-w>this.sourceWorldWidth_/2&&(E[0][0]-=this.sourceWorldWidth_),E[1][0]-w>this.sourceWorldWidth_/2&&(E[1][0]-=this.sourceWorldWidth_),E[2][0]-w>this.sourceWorldWidth_/2&&(E[2][0]-=this.sourceWorldWidth_);const C=Math.min(E[0][0],E[1][0],E[2][0]);Math.max(E[0][0],E[1][0],E[2][0])-C<this.sourceWorldWidth_/2&&(x.source=E)}})}l={}}addTriangle_(t,e,i,s,r,o){this.triangles_.push({source:[s,r,o],target:[t,e,i]})}addQuad_(t,e,i,s,r,o,a,l,h){const c=Ro([r,o,a,l]),u=this.sourceWorldWidth_?tt(c)/this.sourceWorldWidth_:null,d=this.sourceWorldWidth_,f=this.sourceProj_.canWrapX()&&u>.5&&u<1;let g=!1;if(h>0){if(this.targetProj_.isGlobal()&&this.targetWorldWidth_){const _=Ro([t,e,i,s]);g=tt(_)/this.targetWorldWidth_>Pu||g}!f&&this.sourceProj_.isGlobal()&&u&&(g=u>Pu||g)}if(!g&&this.maxSourceExtent_&&isFinite(c[0])&&isFinite(c[1])&&isFinite(c[2])&&isFinite(c[3])&&!ct(c,this.maxSourceExtent_))return;let m=0;if(!g&&(!isFinite(r[0])||!isFinite(r[1])||!isFinite(o[0])||!isFinite(o[1])||!isFinite(a[0])||!isFinite(a[1])||!isFinite(l[0])||!isFinite(l[1]))){if(h>0)g=!0;else if(m=(!isFinite(r[0])||!isFinite(r[1])?8:0)+(!isFinite(o[0])||!isFinite(o[1])?4:0)+(!isFinite(a[0])||!isFinite(a[1])?2:0)+(!isFinite(l[0])||!isFinite(l[1])?1:0),m!=1&&m!=2&&m!=4&&m!=8)return}if(h>0){if(!g){const _=[(t[0]+i[0])/2,(t[1]+i[1])/2],p=this.transformInv_(_);let y;f?y=(hn(r[0],d)+hn(a[0],d))/2-hn(p[0],d):y=(r[0]+a[0])/2-p[0];const w=(r[1]+a[1])/2-p[1];g=y*y+w*w>this.errorThresholdSquared_}if(g){if(Math.abs(t[0]-i[0])<=Math.abs(t[1]-i[1])){const _=[(e[0]+i[0])/2,(e[1]+i[1])/2],p=this.transformInv_(_),y=[(s[0]+t[0])/2,(s[1]+t[1])/2],w=this.transformInv_(y);this.addQuad_(t,e,_,y,r,o,p,w,h-1),this.addQuad_(y,_,i,s,w,p,a,l,h-1)}else{const _=[(t[0]+e[0])/2,(t[1]+e[1])/2],p=this.transformInv_(_),y=[(i[0]+s[0])/2,(i[1]+s[1])/2],w=this.transformInv_(y);this.addQuad_(t,_,y,s,r,p,w,l,h-1),this.addQuad_(_,e,i,y,p,o,a,w,h-1)}return}}if(f){if(!this.canWrapXInSource_)return;this.wrapsXInSource_=!0}(m&11)==0&&this.addTriangle_(t,i,s,r,a,l),(m&14)==0&&this.addTriangle_(t,i,e,r,a,o),m&&((m&13)==0&&this.addTriangle_(e,s,t,o,l,r),(m&7)==0&&this.addTriangle_(e,s,i,o,l,a))}calculateSourceExtent(){const t=Kt();return this.triangles_.forEach(function(e,i,s){const r=e.source;Qn(t,r[0]),Qn(t,r[1]),Qn(t,r[2])}),t}getTriangles(){return this.triangles_}}const jp=.5;class Mu extends Ss{constructor(t,e,i,s,r,o,a,l,h,c,u,d){super(r,O.IDLE,d),this.renderEdges_=u!==void 0?u:!1,this.pixelRatio_=a,this.gutter_=l,this.canvas_=null,this.sourceTileGrid_=e,this.targetTileGrid_=s,this.wrappedTileCoord_=o||r,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0,this.clipExtent_=t.canWrapX()?t.getExtent():void 0;const f=s.getTileCoordExtent(this.wrappedTileCoord_),g=this.targetTileGrid_.getExtent();let m=this.sourceTileGrid_.getExtent();const _=g?Ge(f,g):f;if(Lo(_)===0){this.state=O.EMPTY;return}const p=t.getExtent();p&&(m?m=Ge(m,p):m=p);const y=s.getResolution(this.wrappedTileCoord_[0]),w=Vp(t,i,_,y);if(!isFinite(w)||w<=0){this.state=O.EMPTY;return}const x=c!==void 0?c:jp;if(this.triangulation_=new Kp(t,i,_,m,w*x,y),this.triangulation_.getTriangles().length===0){this.state=O.EMPTY;return}this.sourceZ_=e.getZForResolution(w);let E=this.triangulation_.calculateSourceExtent();if(m&&(t.canWrapX()?(E[1]=rt(E[1],m[1],m[3]),E[3]=rt(E[3],m[1],m[3])):E=Ge(E,m)),!Lo(E))this.state=O.EMPTY;else{let C=0,R=0;t.canWrapX()&&(C=tt(p),R=Math.floor((E[0]-p[0])/C)),Th(E.slice(),t,!0).forEach(b=>{const v=e.getTileRangeForExtentAndZ(b,this.sourceZ_);for(let I=v.minX;I<=v.maxX;I++)for(let A=v.minY;A<=v.maxY;A++){const F=h(this.sourceZ_,I,A,a);if(F){const M=R*C;this.sourceTiles_.push({tile:F,offset:M})}}++R}),this.sourceTiles_.length===0&&(this.state=O.EMPTY)}}getImage(){return this.canvas_}reproject_(){const t=[];if(this.sourceTiles_.forEach(e=>{const i=e.tile;if(i&&i.getState()==O.LOADED){const s=this.sourceTileGrid_.getTileCoordExtent(i.tileCoord);s[0]+=e.offset,s[2]+=e.offset;const r=this.clipExtent_?.slice();r&&(r[0]+=e.offset,r[2]+=e.offset),t.push({extent:s,clipExtent:r,image:i.getImage()})}}),this.sourceTiles_.length=0,t.length===0)this.state=O.ERROR;else{const e=this.wrappedTileCoord_[0],i=this.targetTileGrid_.getTileSize(e),s=typeof i=="number"?i:i[0],r=typeof i=="number"?i:i[1],o=this.targetTileGrid_.getResolution(e),a=this.sourceTileGrid_.getResolution(this.sourceZ_),l=this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_);this.canvas_=Bp(s,r,this.pixelRatio_,a,this.sourceTileGrid_.getExtent(),o,l,this.triangulation_,t,this.gutter_,this.renderEdges_,this.interpolate),this.state=O.LOADED}this.changed()}load(){if(this.state==O.IDLE){this.state=O.LOADING,this.changed();let t=0;this.sourcesListenerKeys_=[],this.sourceTiles_.forEach(({tile:e})=>{const i=e.getState();if(i==O.IDLE||i==O.LOADING){t++;const s=H(e,V.CHANGE,r=>{const o=e.getState();(o==O.LOADED||o==O.ERROR||o==O.EMPTY)&&(nt(s),t--,t===0&&(this.unlistenSources_(),this.reproject_()))});this.sourcesListenerKeys_.push(s)}}),t===0?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach(function({tile:e},i,s){e.getState()==O.IDLE&&e.load()})}}unlistenSources_(){this.sourcesListenerKeys_.forEach(nt),this.sourcesListenerKeys_=null}release(){this.canvas_&&(os(this.canvas_.getContext("2d")),Pn.push(this.canvas_),this.canvas_=null),super.release()}}function Qr(n,t,e,i){return i!==void 0?(i[0]=n,i[1]=t,i[2]=e,i):[n,t,e]}function Up(n,t,e){return n+"/"+t+"/"+e}function to(n,t,e,i,s){return`${B(n)},${t},${Up(e,i,s)}`}function Zp(n){return Hp(n[0],n[1],n[2])}function Hp(n,t,e){return(t<<n)+e}function qp(n,t){const e=n[0],i=n[1],s=n[2];if(t.getMinZoom()>e||e>t.getMaxZoom())return!1;const r=t.getFullTileRange(e);return r?r.containsXY(i,s):!0}const Mn=[0,0,0],Ti=5;class el{constructor(t){this.minZoom=t.minZoom!==void 0?t.minZoom:0,this.resolutions_=t.resolutions,J(If(this.resolutions_,(s,r)=>r-s),"`resolutions` must be sorted in descending order");let e;if(!t.origins){for(let s=0,r=this.resolutions_.length-1;s<r;++s)if(!e)e=this.resolutions_[s]/this.resolutions_[s+1];else if(this.resolutions_[s]/this.resolutions_[s+1]!==e){e=void 0;break}}this.zoomFactor_=e,this.maxZoom=this.resolutions_.length-1,this.origin_=t.origin!==void 0?t.origin:null,this.origins_=null,t.origins!==void 0&&(this.origins_=t.origins,J(this.origins_.length==this.resolutions_.length,"Number of `origins` and `resolutions` must be equal"));const i=t.extent;i!==void 0&&!this.origin_&&!this.origins_&&(this.origin_=hi(i)),J(!this.origin_&&this.origins_||this.origin_&&!this.origins_,"Either `origin` or `origins` must be configured, never both"),this.tileSizes_=null,t.tileSizes!==void 0&&(this.tileSizes_=t.tileSizes,J(this.tileSizes_.length==this.resolutions_.length,"Number of `tileSizes` and `resolutions` must be equal")),this.tileSize_=t.tileSize!==void 0?t.tileSize:this.tileSizes_?null:Xa,J(!this.tileSize_&&this.tileSizes_||this.tileSize_&&!this.tileSizes_,"Either `tileSize` or `tileSizes` must be configured, never both"),this.extent_=i!==void 0?i:null,this.fullTileRanges_=null,this.tmpSize_=[0,0],this.tmpExtent_=[0,0,0,0],t.sizes!==void 0?this.fullTileRanges_=t.sizes.map((s,r)=>{const o=new Ja(Math.min(0,s[0]),Math.max(s[0]-1,-1),Math.min(0,s[1]),Math.max(s[1]-1,-1));if(i){const a=this.getTileRangeForExtentAndZ(i,r);o.minX=Math.max(a.minX,o.minX),o.maxX=Math.min(a.maxX,o.maxX),o.minY=Math.max(a.minY,o.minY),o.maxY=Math.min(a.maxY,o.maxY)}return o}):i&&this.calculateTileRanges_(i)}forEachTileCoord(t,e,i){const s=this.getTileRangeForExtentAndZ(t,e);for(let r=s.minX,o=s.maxX;r<=o;++r)for(let a=s.minY,l=s.maxY;a<=l;++a)i([e,r,a])}forEachTileCoordParentTileRange(t,e,i,s){let r,o,a,l=null,h=t[0]-1;for(this.zoomFactor_===2?(o=t[1],a=t[2]):l=this.getTileCoordExtent(t,s);h>=this.minZoom;){if(o!==void 0&&a!==void 0?(o=Math.floor(o/2),a=Math.floor(a/2),r=An(o,o,a,a,i)):r=this.getTileRangeForExtentAndZ(l,h,i),e(h,r))return!0;--h}return!1}getExtent(){return this.extent_}getMaxZoom(){return this.maxZoom}getMinZoom(){return this.minZoom}getOrigin(t){return this.origin_?this.origin_:this.origins_[t]}getResolution(t){return this.resolutions_[t]}getResolutions(){return this.resolutions_}getTileCoordChildTileRange(t,e,i){if(t[0]<this.maxZoom){if(this.zoomFactor_===2){const r=t[1]*2,o=t[2]*2;return An(r,r+1,o,o+1,e)}const s=this.getTileCoordExtent(t,i||this.tmpExtent_);return this.getTileRangeForExtentAndZ(s,t[0]+1,e)}return null}getTileRangeForTileCoordAndZ(t,e,i){if(e>this.maxZoom||e<this.minZoom)return null;const s=t[0],r=t[1],o=t[2];if(e===s)return An(r,o,r,o,i);if(this.zoomFactor_){const l=Math.pow(this.zoomFactor_,e-s),h=Math.floor(r*l),c=Math.floor(o*l);if(e<s)return An(h,h,c,c,i);const u=Math.floor(l*(r+1))-1,d=Math.floor(l*(o+1))-1;return An(h,u,c,d,i)}const a=this.getTileCoordExtent(t,this.tmpExtent_);return this.getTileRangeForExtentAndZ(a,e,i)}getTileRangeForExtentAndZ(t,e,i){this.getTileCoordForXYAndZ_(t[0],t[3],e,!1,Mn);const s=Mn[1],r=Mn[2];this.getTileCoordForXYAndZ_(t[2],t[1],e,!0,Mn);const o=Mn[1],a=Mn[2];return An(s,o,r,a,i)}getTileCoordCenter(t){const e=this.getOrigin(t[0]),i=this.getResolution(t[0]),s=Rt(this.getTileSize(t[0]),this.tmpSize_);return[e[0]+(t[1]+.5)*s[0]*i,e[1]-(t[2]+.5)*s[1]*i]}getTileCoordExtent(t,e){const i=this.getOrigin(t[0]),s=this.getResolution(t[0]),r=Rt(this.getTileSize(t[0]),this.tmpSize_),o=i[0]+t[1]*r[0]*s,a=i[1]-(t[2]+1)*r[1]*s,l=o+r[0]*s,h=a+r[1]*s;return Ne(o,a,l,h,e)}getTileCoordForCoordAndResolution(t,e,i){return this.getTileCoordForXYAndResolution_(t[0],t[1],e,!1,i)}getTileCoordForXYAndResolution_(t,e,i,s,r){const o=this.getZForResolution(i),a=i/this.getResolution(o),l=this.getOrigin(o),h=Rt(this.getTileSize(o),this.tmpSize_);let c=a*(t-l[0])/i/h[0],u=a*(l[1]-e)/i/h[1];return s?(c=fr(c,Ti)-1,u=fr(u,Ti)-1):(c=dr(c,Ti),u=dr(u,Ti)),Qr(o,c,u,r)}getTileCoordForXYAndZ_(t,e,i,s,r){const o=this.getOrigin(i),a=this.getResolution(i),l=Rt(this.getTileSize(i),this.tmpSize_);let h=(t-o[0])/a/l[0],c=(o[1]-e)/a/l[1];return s?(h=fr(h,Ti)-1,c=fr(c,Ti)-1):(h=dr(h,Ti),c=dr(c,Ti)),Qr(i,h,c,r)}getTileCoordForCoordAndZ(t,e,i){return this.getTileCoordForXYAndZ_(t[0],t[1],e,!1,i)}getTileCoordResolution(t){return this.resolutions_[t[0]]}getTileSize(t){return this.tileSize_?this.tileSize_:this.tileSizes_[t]}getFullTileRange(t){return this.fullTileRanges_?this.fullTileRanges_[t]:this.extent_?this.getTileRangeForExtentAndZ(this.extent_,t):null}getZForResolution(t,e){const i=To(this.resolutions_,t,e||0);return rt(i,this.minZoom,this.maxZoom)}tileCoordIntersectsViewport(t,e){return ec(e,0,e.length,2,this.getTileCoordExtent(t))}calculateTileRanges_(t){const e=this.resolutions_.length,i=new Array(e);for(let s=this.minZoom;s<e;++s)i[s]=this.getTileRangeForExtentAndZ(t,s);this.fullTileRanges_=i}}function il(n){let t=n.getDefaultTileGrid();return t||(t=t0(n),n.setDefaultTileGrid(t)),t}function Jp(n,t,e){const i=t[0],s=n.getTileCoordCenter(t),r=eo(e);if(!an(r,s)){const o=tt(r),a=Math.ceil((r[0]-s[0])/o);return s[0]+=o*a,n.getTileCoordForCoordAndZ(s,i)}return t}function Qp(n,t,e,i){i=i!==void 0?i:"top-left";const s=Ou(n,t,e);return new el({extent:n,origin:Of(n,i),resolutions:s,tileSize:e})}function Fu(n){const t=n||{},e=t.extent||ft("EPSG:3857").getExtent(),i={extent:e,minZoom:t.minZoom,tileSize:t.tileSize,resolutions:Ou(e,t.maxZoom,t.tileSize,t.maxResolution)};return new el(i)}function Ou(n,t,e,i){t=t!==void 0?t:pu,e=Rt(e!==void 0?e:Xa);const s=Ot(n),r=tt(n);i=i>0?i:Math.max(r/e[0],s/e[1]);const o=t+1,a=new Array(o);for(let l=0;l<o;++l)a[l]=i/Math.pow(2,l);return a}function t0(n,t,e,i){const s=eo(n);return Qp(s,t,e,i)}function eo(n){n=ft(n);let t=n.getExtent();if(!t){const e=180*Oo.degrees/n.getMetersPerUnit();t=Ne(-e,-e,e,e)}return t}const e0=/\{z\}/g,i0=/\{x\}/g,n0=/\{y\}/g,s0=/\{-y\}/g;function r0(n,t,e,i,s){return n.replace(e0,t.toString()).replace(i0,e.toString()).replace(n0,i.toString()).replace(s0,function(){if(s===void 0)throw new Error("If the URL template has a {-y} placeholder, the grid extent must be known");return(s-i).toString()})}function o0(n){const t=[];let e=/\{([a-z])-([a-z])\}/.exec(n);if(e){const i=e[1].charCodeAt(0),s=e[2].charCodeAt(0);let r;for(r=i;r<=s;++r)t.push(n.replace(e[0],String.fromCharCode(r)));return t}if(e=/\{(\d+)-(\d+)\}/.exec(n),e){const i=parseInt(e[2],10);for(let s=parseInt(e[1],10);s<=i;s++)t.push(n.replace(e[0],s.toString()));return t}return t.push(n),t}function a0(n,t){return(function(e,i,s){if(!e)return;let r;const o=e[0];if(t){const a=t.getFullTileRange(o);a&&(r=a.getHeight()-1)}return r0(n,o,e[1],e[2],r)})}function l0(n,t){const e=n.length,i=new Array(e);for(let s=0;s<e;++s)i[s]=a0(n[s],t);return h0(i)}function h0(n){return n.length===1?n[0]:(function(t,e,i){if(!t)return;const s=Zp(t),r=hn(s,n.length);return n[r](t,e,i)})}class c0 extends Dc{constructor(t){super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,projection:t.projection,state:t.state,wrapX:t.wrapX,interpolate:t.interpolate}),this.on,this.once,this.un,this.tilePixelRatio_=t.tilePixelRatio!==void 0?t.tilePixelRatio:1,this.tileGrid=t.tileGrid!==void 0?t.tileGrid:null;const e=[256,256];this.tileGrid&&Rt(this.tileGrid.getTileSize(this.tileGrid.getMinZoom()),e),this.tmpSize=[0,0],this.key_=t.key||B(this),this.tileOptions={transition:t.transition,interpolate:t.interpolate},this.zDirection=t.zDirection?t.zDirection:0}getGutterForProjection(t){return 0}getKey(){return this.key_}setKey(t){this.key_!==t&&(this.key_=t,this.changed())}getResolutions(t){const e=t?this.getTileGridForProjection(t):this.tileGrid;return e?e.getResolutions():null}getTile(t,e,i,s,r,o){return j()}getTileGrid(){return this.tileGrid}getTileGridForProjection(t){return this.tileGrid?this.tileGrid:il(t)}getTilePixelRatio(t){return this.tilePixelRatio_}getTilePixelSize(t,e,i){const s=this.getTileGridForProjection(i),r=this.getTilePixelRatio(e),o=Rt(s.getTileSize(t),this.tmpSize);return r==1?o:Y_(o,r,this.tmpSize)}getTileCoordForTileUrlFunction(t,e){const i=e!==void 0?e:this.getProjection(),s=e!==void 0?this.getTileGridForProjection(i):this.tileGrid||this.getTileGridForProjection(i);return this.getWrapX()&&i.isGlobal()&&(t=Jp(s,t,i)),qp(t,s)?t:null}clear(){}refresh(){this.clear(),super.refresh()}}class u0 extends ke{constructor(t,e){super(t),this.tile=e}}const nl={TILELOADSTART:"tileloadstart",TILELOADEND:"tileloadend",TILELOADERROR:"tileloaderror"};class io extends c0{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tilePixelRatio:t.tilePixelRatio,wrapX:t.wrapX,transition:t.transition,interpolate:t.interpolate,key:t.key,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.generateTileUrlFunction_=this.tileUrlFunction===io.prototype.tileUrlFunction,this.tileLoadFunction=t.tileLoadFunction,t.tileUrlFunction&&(this.tileUrlFunction=t.tileUrlFunction),this.urls=null,t.urls?this.setUrls(t.urls):t.url&&this.setUrl(t.url),this.tileLoadingKeys_={}}getTileLoadFunction(){return this.tileLoadFunction}getTileUrlFunction(){return Object.getPrototypeOf(this).tileUrlFunction===this.tileUrlFunction?this.tileUrlFunction.bind(this):this.tileUrlFunction}getUrls(){return this.urls}handleTileChange(t){const e=t.target,i=B(e),s=e.getState();let r;s==O.LOADING?(this.tileLoadingKeys_[i]=!0,r=nl.TILELOADSTART):i in this.tileLoadingKeys_&&(delete this.tileLoadingKeys_[i],r=s==O.ERROR?nl.TILELOADERROR:s==O.LOADED?nl.TILELOADEND:void 0),r!=null&&this.dispatchEvent(new u0(r,e))}setTileLoadFunction(t){this.tileLoadFunction=t,this.changed()}setTileUrlFunction(t,e){this.tileUrlFunction=t,typeof e<"u"?this.setKey(e):this.changed()}setUrl(t){const e=o0(t);this.urls=e,this.setUrls(e)}setUrls(t){this.urls=t;const e=t.join(`
|
|
8
|
+
`);this.generateTileUrlFunction_?this.setTileUrlFunction(l0(t,this.tileGrid),e):this.setKey(e)}tileUrlFunction(t,e,i){}}class d0 extends io{constructor(t){super({attributions:t.attributions,cacheSize:t.cacheSize,projection:t.projection,state:t.state,tileGrid:t.tileGrid,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:Du,tilePixelRatio:t.tilePixelRatio,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:t.wrapX,transition:t.transition,interpolate:t.interpolate!==void 0?t.interpolate:!0,key:t.key,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.crossOrigin=t.crossOrigin!==void 0?t.crossOrigin:null,this.tileClass=t.tileClass!==void 0?t.tileClass:Eu,this.tileGridForProjection={},this.reprojectionErrorThreshold_=t.reprojectionErrorThreshold,this.renderReprojectionEdges_=!1}getGutterForProjection(t){return this.getProjection()&&t&&!Ut(this.getProjection(),t)?0:this.getGutter()}getGutter(){return 0}getKey(){let t=super.getKey();return this.getInterpolate()||(t+=":disable-interpolation"),t}getTileGridForProjection(t){const e=this.getProjection();if(this.tileGrid&&(!e||Ut(e,t)))return this.tileGrid;const i=B(t);return i in this.tileGridForProjection||(this.tileGridForProjection[i]=il(t)),this.tileGridForProjection[i]}createTile_(t,e,i,s,r,o){const a=[t,e,i],l=this.getTileCoordForTileUrlFunction(a,r),h=l?this.tileUrlFunction(l,s,r):void 0,c=new this.tileClass(a,h!==void 0?O.IDLE:O.EMPTY,h!==void 0?h:"",this.crossOrigin,this.tileLoadFunction,this.tileOptions);return c.key=o,c.addEventListener(V.CHANGE,this.handleTileChange.bind(this)),c}getTile(t,e,i,s,r,o){const a=this.getProjection();if(!a||!r||Ut(a,r))return this.getTileInternal(t,e,i,s,a||r);const l=[t,e,i],h=this.getKey(),c=this.getTileGridForProjection(a),u=this.getTileGridForProjection(r),d=this.getTileCoordForTileUrlFunction(l,r),f=new Mu(a,c,r,u,l,d,this.getTilePixelRatio(s),this.getGutter(),(g,m,_,p)=>this.getTileInternal(g,m,_,p,a,o),this.reprojectionErrorThreshold_,this.renderReprojectionEdges_,this.tileOptions);return f.key=h,f}getTileInternal(t,e,i,s,r,o){const a=this.getKey(),l=to(this,a,t,e,i);if(o&&o.containsKey(l))return o.get(l);const h=this.createTile_(t,e,i,s,r,a);return o?.set(l,h),h}setRenderReprojectionEdges(t){this.renderReprojectionEdges_!=t&&(this.renderReprojectionEdges_=t,this.changed())}setTileGridForProjection(t,e){const i=ft(t);if(i){const s=B(i);s in this.tileGridForProjection||(this.tileGridForProjection[s]=e)}}}function Du(n,t){if(Zt){const e=n.getCrossOrigin();let i="same-origin",s="same-origin";e==="anonymous"||e===""?(i="cors",s="omit"):e==="use-credentials"&&(i="cors",s="include"),fetch(t,{mode:i,credentials:s}).then(r=>{if(!r.ok)throw new Error(`HTTP ${r.status}`);return r.blob()}).then(r=>createImageBitmap(r)).then(r=>{const o=n.getImage();o.width=r.width,o.height=r.height,o.getContext("2d").drawImage(r,0,0),r.close?.(),o.dispatchEvent(new Event("load"))}).catch(()=>{n.getImage().dispatchEvent(new Event("error"))});return}n.getImage().src=t}class ku extends d0{constructor(t){t=t||{};const e=t.projection!==void 0?t.projection:"EPSG:3857",i=t.tileGrid!==void 0?t.tileGrid:Fu({extent:eo(e),maxResolution:t.maxResolution,maxZoom:t.maxZoom,minZoom:t.minZoom,tileSize:t.tileSize});super({attributions:t.attributions,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,interpolate:t.interpolate,projection:e,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileGrid:i,tileLoadFunction:t.tileLoadFunction,tilePixelRatio:t.tilePixelRatio,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:t.wrapX!==void 0?t.wrapX:!0,transition:t.transition,attributionsCollapsible:t.attributionsCollapsible,zDirection:t.zDirection}),this.gutter_=t.gutter!==void 0?t.gutter:0}getGutter(){return this.gutter_}}const f0='© <a href="https://www.openstreetmap.org/copyright" target="_blank">OpenStreetMap</a> contributors.';class g0 extends ku{constructor(t){t=t||{};let e;t.attributions!==void 0?e=t.attributions:e=[f0];const i=t.crossOrigin!==void 0?t.crossOrigin:"anonymous",s=t.url!==void 0?t.url:"https://tile.openstreetmap.org/{z}/{x}/{y}.png";super({attributions:e,attributionsCollapsible:!1,cacheSize:t.cacheSize,crossOrigin:i,interpolate:t.interpolate,maxZoom:t.maxZoom!==void 0?t.maxZoom:19,reprojectionErrorThreshold:t.reprojectionErrorThreshold,tileLoadFunction:(r,o)=>{const a=r.getImage();!Zt&&a instanceof HTMLImageElement&&(a.referrerPolicy="origin-when-cross-origin"),(t.tileLoadFunction||Du)(r,o)},transition:t.transition,url:s,wrapX:t.wrapX,zDirection:t.zDirection})}}function sl(n){return n instanceof Image||n instanceof HTMLCanvasElement||n instanceof HTMLVideoElement||n instanceof ImageBitmap?n:null}const _0=new Error("disposed"),m0=[256,256];class Nu extends Ss{constructor(t){const e=O.IDLE;super(t.tileCoord,e,{transition:t.transition,interpolate:t.interpolate}),this.loader_=t.loader,this.data_=null,this.error_=null,this.size_=t.size||null,this.controller_=t.controller||null}getSize(){if(this.size_)return this.size_;const t=sl(this.data_);return t?[t.width,t.height]:m0}getData(){return this.data_}getError(){return this.error_}load(){if(this.state!==O.IDLE&&this.state!==O.ERROR)return;this.state=O.LOADING,this.changed();const t=this;this.loader_().then(function(e){t.data_=e,t.state=O.LOADED,t.changed()}).catch(function(e){t.error_=e,t.state=O.ERROR,t.changed()})}disposeInternal(){this.controller_&&(this.controller_.abort(_0),this.controller_=null),super.disposeInternal()}}class Gu{constructor(t){this.highWaterMark=t!==void 0?t:2048,this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}deleteOldest(){const t=this.pop();t instanceof ir&&t.dispose()}canExpireCache(){return this.highWaterMark>0&&this.getCount()>this.highWaterMark}expireCache(t){for(;this.canExpireCache();)this.deleteOldest()}clear(){for(;this.oldest_;)this.deleteOldest()}containsKey(t){return this.entries_.hasOwnProperty(t)}forEach(t){let e=this.oldest_;for(;e;)t(e.value_,e.key_,this),e=e.newer}get(t,e){const i=this.entries_[t];return J(i!==void 0,"Tried to get a value for a key that does not exist in the cache"),i===this.newest_||(i===this.oldest_?(this.oldest_=this.oldest_.newer,this.oldest_.older=null):(i.newer.older=i.older,i.older.newer=i.newer),i.newer=null,i.older=this.newest_,this.newest_.newer=i,this.newest_=i),i.value_}remove(t){const e=this.entries_[t];return J(e!==void 0,"Tried to get a value for a key that does not exist in the cache"),e===this.newest_?(this.newest_=e.older,this.newest_&&(this.newest_.newer=null)):e===this.oldest_?(this.oldest_=e.newer,this.oldest_&&(this.oldest_.older=null)):(e.newer.older=e.older,e.older.newer=e.newer),delete this.entries_[t],--this.count_,e.value_}getCount(){return this.count_}getKeys(){const t=new Array(this.count_);let e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.key_;return t}getValues(){const t=new Array(this.count_);let e=0,i;for(i=this.newest_;i;i=i.older)t[e++]=i.value_;return t}peekLast(){return this.oldest_.value_}peekLastKey(){return this.oldest_.key_}peekFirstKey(){return this.newest_.key_}peek(t){return this.entries_[t]?.value_}pop(){const t=this.oldest_;return delete this.entries_[t.key_],t.newer&&(t.newer.older=null),this.oldest_=t.newer,this.oldest_||(this.newest_=null),--this.count_,t.value_}replace(t,e){this.get(t),this.entries_[t].value_=e}set(t,e){J(!(t in this.entries_),"Tried to set a value for a key that is used already");const i={key_:t,newer:null,older:this.newest_,value_:e};this.newest_?this.newest_.newer=i:this.oldest_=i,this.newest_=i,this.entries_[t]=i,++this.count_}setSize(t){this.highWaterMark=t}}function rl(n,t,e){if(!(e in n))return n[e]=new Set([t]),!0;const i=n[e],s=i.has(t);return s||i.add(t),!s}function p0(n,t,e){const i=n[e];return i?i.delete(t):!1}function zu(n,t){const e=n.layerStatesArray[n.layerIndex];e.extent&&(t=Ge(t,ui(e.extent,n.viewState.projection)));const i=e.layer.getRenderSource();if(!i.getWrapX()){const s=i.getTileGridForProjection(n.viewState.projection).getExtent();s&&(t=Ge(t,s))}return t}class Xu extends Jc{constructor(t,e){super(t),e=e||{},this.extentChanged=!0,this.renderComplete=!1,this.renderedExtent_=null,this.renderedPixelRatio,this.renderedProjection=null,this.renderedTiles=[],this.renderedSourceKey_,this.renderedSourceRevision_,this.tempExtent=Kt(),this.tempTileRange_=new Ja(0,0,0,0),this.tempTileCoord_=Qr(0,0,0);const i=e.cacheSize!==void 0?e.cacheSize:512;this.tileCache_=new Gu(i),this.sourceTileCache_=null,this.maxStaleKeys=i*.5}getTileCache(){return this.tileCache_}getSourceTileCache(){return this.sourceTileCache_||(this.sourceTileCache_=new Gu(512)),this.sourceTileCache_}getOrCreateTile(t,e,i,s){const r=this.tileCache_,a=this.getLayer().getSource(),l=to(a,a.getKey(),t,e,i);let h;if(r.containsKey(l))h=r.get(l);else{const c=s.viewState.projection,u=a.getProjection();if(h=a.getTile(t,e,i,s.pixelRatio,c,!u||Ut(u,c)?void 0:this.getSourceTileCache()),!h)return null;r.set(l,h)}return h}getTile(t,e,i,s){const r=this.getOrCreateTile(t,e,i,s);return r||null}getData(t){const e=this.frameState;if(!e)return null;const i=this.getLayer(),s=gt(e.pixelToCoordinateTransform,t.slice()),r=i.getExtent();if(r&&!an(r,s))return null;const o=e.viewState,a=i.getRenderSource(),l=a.getTileGridForProjection(o.projection),h=a.getTilePixelRatio(e.pixelRatio);for(let c=l.getZForResolution(o.resolution);c>=l.getMinZoom();--c){const u=l.getTileCoordForCoordAndZ(s,c),d=this.getTile(c,u[1],u[2],e);if(!d||d.getState()!==O.LOADED)continue;const f=l.getOrigin(c),g=Rt(l.getTileSize(c)),m=l.getResolution(c);let _;if(d instanceof Eu||d instanceof Mu)_=d.getImage();else if(d instanceof Nu){if(_=sl(d.getData()),!_)continue}else continue;const p=Math.floor(h*((s[0]-f[0])/m-u[1]*g[0])),y=Math.floor(h*((f[1]-s[1])/m-u[2]*g[1])),w=Math.round(h*a.getGutterForProjection(o.projection));return this.getImageData(_,p+w,y+w)}return null}prepareFrame(t){this.renderedProjection?t.viewState.projection!==this.renderedProjection&&(this.tileCache_.clear(),this.renderedProjection=t.viewState.projection):this.renderedProjection=t.viewState.projection;const e=this.getLayer().getSource();if(!e)return!1;const i=e.getRevision();return this.renderedSourceRevision_?this.renderedSourceRevision_!==i&&(this.renderedSourceRevision_=i,this.renderedSourceKey_===e.getKey()&&(this.tileCache_.clear(),this.sourceTileCache_?.clear())):this.renderedSourceRevision_=i,!0}enqueueTilesForNextExtent(){return!0}enqueueTiles(t,e,i,s,r){const o=t.viewState,a=this.getLayer(),l=a.getRenderSource(),h=l.getTileGridForProjection(o.projection),c=B(l);c in t.wantedTiles||(t.wantedTiles[c]={});const u=t.wantedTiles[c],d=a.getMapInternal(),f=Math.max(i-r,h.getMinZoom(),h.getZForResolution(Math.min(a.getMaxResolution(),d?d.getView().getResolutionForZoom(Math.max(a.getMinZoom(),0)):h.getResolution(0)),l.zDirection)),g=o.rotation,m=g?vh(o.center,o.resolution,g,t.size):void 0;for(let _=i;_>=f;--_){const p=h.getTileRangeForExtentAndZ(e,_,this.tempTileRange_),y=h.getResolution(_);for(let w=p.minX;w<=p.maxX;++w)for(let x=p.minY;x<=p.maxY;++x){if(g&&!h.tileCoordIntersectsViewport([_,w,x],m))continue;const E=this.getTile(_,w,x,t);if(!E||!rl(s,E,_))continue;const R=E.getKey();if(u[R]=!0,E.getState()===O.IDLE&&!t.tileQueue.isKeyQueued(R)){const S=Qr(_,w,x,this.tempTileCoord_);t.tileQueue.enqueue([E,c,h.getTileCoordCenter(S),y])}}}}findStaleTile_(t,e){const i=this.tileCache_,s=t[0],r=t[1],o=t[2],a=this.getStaleKeys();for(let l=0;l<a.length;++l){const h=to(this.getLayer().getSource(),a[l],s,r,o);if(i.containsKey(h)){const c=i.peek(h);if(c.getState()===O.LOADED)return c.endTransition(B(this)),rl(e,c,s),!0}}return!1}findAltTiles_(t,e,i,s){const r=t.getTileRangeForTileCoordAndZ(e,i,this.tempTileRange_);if(!r)return!1;let o=!0;const a=this.tileCache_,l=this.getLayer().getRenderSource(),h=l.getKey();for(let c=r.minX;c<=r.maxX;++c)for(let u=r.minY;u<=r.maxY;++u){const d=to(l,h,i,c,u);let f=!1;if(a.containsKey(d)){const g=a.peek(d);g.getState()===O.LOADED&&(rl(s,g,i),f=!0)}f||(o=!1)}return o}renderFrame(t,e){this.renderComplete=!0;const i=t.layerStatesArray[t.layerIndex],s=t.viewState,r=s.projection,o=s.resolution,a=s.center,l=t.pixelRatio,h=this.getLayer(),c=h.getSource(),u=c.getTileGridForProjection(r),d=u.getZForResolution(o,c.zDirection),f=u.getResolution(d),g=c.getKey();this.renderedSourceKey_?this.renderedSourceKey_!==g&&(this.prependStaleKey(this.renderedSourceKey_),this.renderedSourceKey_=g):this.renderedSourceKey_=g;let m=t.extent;const _=c.getTilePixelRatio(l);this.prepareContainer(t,e);const p=this.context.canvas.width,y=this.context.canvas.height,w=i.extent&&ui(i.extent);w&&(m=Ge(m,ui(i.extent)));const x=f*p/2/_,E=f*y/2/_,C=[a[0]-x,a[1]-E,a[0]+x,a[1]+E],R={};this.renderedTiles.length=0;const S=h.getPreload();if(t.nextExtent&&this.enqueueTilesForNextExtent()){const D=u.getZForResolution(s.nextResolution,c.zDirection),X=zu(t,t.nextExtent);this.enqueueTiles(t,X,D,R,S)}const b=zu(t,m);if(this.enqueueTiles(t,b,d,R,0),S>0&&setTimeout(()=>{this.enqueueTiles(t,b,d-1,R,S-1)},0),!(d in R))return this.container;const v=B(this),I=t.time;for(const D of R[d]){const X=D.getState();if(X===O.EMPTY)continue;const Y=D.tileCoord;if(X===O.LOADED&&D.getAlpha(v,I)===1){D.endTransition(v);continue}if(X!==O.ERROR&&(this.renderComplete=!1),this.findStaleTile_(Y,R)){p0(R,D,d),t.animate=!0;continue}if(this.findAltTiles_(u,Y,d+1,R))continue;const pt=u.getMinZoom();for(let yt=d-1;yt>=pt&&!this.findAltTiles_(u,Y,yt,R);--yt);}const A=f/o*l/_,F=this.getRenderContext(t);Xe(this.tempTransform,p/2,y/2,A,A,0,-p/2,-y/2),i.extent&&this.clipUnrotated(F,t,w),c.getInterpolate()||(F.imageSmoothingEnabled=!1),this.preRender(F,t);const M=Object.keys(R).map(Number);M.sort(Te);let N;const L=[],k=[];for(let D=M.length-1;D>=0;--D){const X=M[D],Y=c.getTilePixelSize(X,l,r),P=u.getResolution(X)/f,pt=Y[0]*P*A,yt=Y[1]*P*A,ot=u.getTileCoordForCoordAndZ(hi(C),X),kt=u.getTileCoordExtent(ot),dt=gt(this.tempTransform,[_*(kt[0]-C[0])/f,_*(C[3]-kt[3])/f]),Nt=_*c.getGutterForProjection(r);for(const bt of R[X]){if(bt.getState()!==O.LOADED)continue;const Et=bt.tileCoord,Ue=ot[1]-Et[1],ll=Math.round(dt[0]-(Ue-1)*pt),Ps=ot[2]-Et[2],qi=Math.round(dt[1]-(Ps-1)*yt),ue=Math.round(dt[0]-Ue*pt),be=Math.round(dt[1]-Ps*yt),On=ll-ue,Dn=qi-be,Ms=M.length===1;let Ji=!1;N=[ue,be,ue+On,be,ue+On,be+Dn,ue,be+Dn];for(let kn=0,Nn=L.length;kn<Nn;++kn)if(!Ms&&X<k[kn]){const wt=L[kn];ct([ue,be,ue+On,be+Dn],[wt[0],wt[3],wt[4],wt[7]])&&(Ji||(F.save(),Ji=!0),F.beginPath(),F.moveTo(N[0],N[1]),F.lineTo(N[2],N[3]),F.lineTo(N[4],N[5]),F.lineTo(N[6],N[7]),F.moveTo(wt[6],wt[7]),F.lineTo(wt[4],wt[5]),F.lineTo(wt[2],wt[3]),F.lineTo(wt[0],wt[1]),F.clip())}L.push(N),k.push(X),this.drawTile(bt,t,ue,be,On,Dn,Nt,Ms),Ji&&F.restore(),this.renderedTiles.unshift(bt),this.updateUsedTiles(t.usedTiles,c,bt)}}if(this.renderedResolution=f,this.extentChanged=!this.renderedExtent_||!ln(this.renderedExtent_,C),this.renderedExtent_=C,this.renderedPixelRatio=l,this.postRender(this.context,t),i.extent&&F.restore(),F.imageSmoothingEnabled=!0,this.renderComplete){const D=(X,Y)=>{const W=B(c),P=Y.wantedTiles[W],pt=P?Object.keys(P).length:0;this.updateCacheSize(pt),this.tileCache_.expireCache(),this.sourceTileCache_?.expireCache()};t.postRenderFunctions.push(D)}return this.container}updateCacheSize(t){this.tileCache_.highWaterMark=Math.max(this.tileCache_.highWaterMark,t*2)}drawTile(t,e,i,s,r,o,a,l){let h;if(t instanceof Nu){if(h=sl(t.getData()),!h)throw new Error("Rendering array data is not yet supported")}else h=this.getTileImage(t);if(!h)return;const c=this.getRenderContext(e),u=B(this),d=e.layerStatesArray[e.layerIndex],f=d.opacity*(l?t.getAlpha(u,e.time):1),g=f!==c.globalAlpha;g&&(c.save(),c.globalAlpha=f),c.drawImage(h,a,a,h.width-2*a,h.height-2*a,i,s,r,o),g&&c.restore(),f!==d.opacity?e.animate=!0:l&&t.endTransition(u)}getImage(){const t=this.context;return t?t.canvas:null}getTileImage(t){return t.getImage()}updateUsedTiles(t,e,i){const s=B(e);s in t||(t[s]={}),t[s][i.getKey()]=!0}}const Ri={PRELOAD:"preload",USE_INTERIM_TILES_ON_ERROR:"useInterimTilesOnError"};class y0 extends qr{constructor(t){t=t||{};const e=Object.assign({},t),i=t.cacheSize;delete t.cacheSize,delete e.preload,delete e.useInterimTilesOnError,super(e),this.on,this.once,this.un,this.cacheSize_=i,this.setPreload(t.preload!==void 0?t.preload:0),this.setUseInterimTilesOnError(t.useInterimTilesOnError!==void 0?t.useInterimTilesOnError:!0)}getCacheSize(){return this.cacheSize_}getPreload(){return this.get(Ri.PRELOAD)}setPreload(t){this.set(Ri.PRELOAD,t)}getUseInterimTilesOnError(){return this.get(Ri.USE_INTERIM_TILES_ON_ERROR)}setUseInterimTilesOnError(t){this.set(Ri.USE_INTERIM_TILES_ON_ERROR,t)}getData(t){return super.getData(t)}}class Yu extends y0{constructor(t){super(t)}createRenderer(){return new Xu(this,{cacheSize:this.getCacheSize()})}}const x0={image:["Polygon","Circle","LineString","Image","Text"],hybrid:["Polygon","LineString"],vector:[]},Wu={hybrid:["Image","Text","Default"],vector:["Polygon","Circle","LineString","Image","Text","Default"]};class E0 extends Xu{constructor(t,e){super(t,e),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.renderedLayerRevision_,this.renderedPixelToCoordinateTransform_=null,this.renderedRotation_,this.renderedOpacity_=1,this.tmpTransform_=ae(),this.tileClipContexts_=null}enqueueTilesForNextExtent(){return this.getLayer().getRenderMode()!=="vector"}drawTile(t,e,i,s,r,o,a,l){this.updateExecutorGroup_(t,e.pixelRatio,e.viewState.projection),this.tileImageNeedsRender_(t)&&this.renderTileImage_(t,e),super.drawTile(t,e,i,s,r,o,a,l)}getTile(t,e,i,s){const r=this.getOrCreateTile(t,e,i,s);if(!r)return null;const o=s.viewState,a=o.resolution,l=s.viewHints,h=this.getLayer().getSource(),c=h.getTileGridForProjection(o.projection),u=!(l[at.ANIMATING]||l[at.INTERACTING]),d=c.getZForResolution(a,h.zDirection)===t;return u&&d?r.wantedResolution=a:r.wantedResolution||(r.wantedResolution=c.getResolution(t)),r}prepareFrame(t){const e=this.getLayer().getRevision();return this.renderedLayerRevision_!==e&&(this.renderedLayerRevision_=e,this.renderedTiles.length=0),super.prepareFrame(t)}updateExecutorGroup_(t,e,i){const s=this.getLayer(),r=s.getRevision(),o=s.getRenderOrder()||null,a=t.wantedResolution,l=t.getReplayState(s);if(!l.dirty&&l.renderedResolution===a&&l.renderedRevision==r&&l.renderedRenderOrder==o)return;const h=s.getSource(),c=!!s.getDeclutter(),u=h.getTileGrid(),f=h.getTileGridForProjection(i).getTileCoordExtent(t.wrappedTileCoord),g=h.getSourceTiles(e,i,t),m=B(s);delete t.hitDetectionImageData[m],t.executorGroups[m]=[],l.dirty=!1;for(let _=0,p=g.length;_<p;++_){const y=g[_];if(y.getState()!=O.LOADED)continue;const w=h.getProjection(),x=y.tileCoord;let E=u.getTileCoordExtent(x);i&&w&&!Ut(i,w)&&(E=vr(E,w,i,32));const C=Ge(f,E),R=li(C,s.getRenderBuffer()*a,this.tempExtent),S=ln(E,C)?null:R,b=new Vc(0,C,a,e),v=Ra(a,e),I=function(L,k){let D;const X=L.getStyleFunction()||s.getStyleFunction();if(X&&(D=X(L,a)),D){const Y=this.renderFeature(L,v,D,b,c,k);l.dirty=l.dirty||Y}},A=y.getFeatures();o&&o!==l.renderedRenderOrder&&A.sort(o);for(let L=0,k=A.length;L<k;++L){let D=A[L];i&&y.projection&&!Ut(i,y.projection)&&(D=D.clone(),D.getGeometry().applyTransform(zi(y.projection,i))),(!S||ct(S,D.getGeometry().getExtent()))&&I.call(this,D,L)}const F=b.finish(),M=s.getRenderMode()!=="vector"&&c&&g.length===1?null:C,N=new Kc(M,a,e,h.getOverlaps(),F,s.getRenderBuffer(),!0);t.executorGroups[m].push(N)}l.renderedRevision=r,l.renderedRenderOrder=o,l.renderedResolution=a}forEachFeatureAtCoordinate(t,e,i,s,r){const o=e.viewState.resolution,a=e.viewState.rotation;i=i??0;const l=this.getLayer(),c=l.getSource().getTileGridForProjection(e.viewState.projection),u=Ro([t]);li(u,o*i,u);const d={},f=function(w,x,E){let C=w.getId();C===void 0&&(C=B(w));const R=d[C];if(R){if(R!==!0&&E<R.distanceSq){if(E===0)return d[C]=!0,r.splice(r.lastIndexOf(R),1),s(w,l,x);R.geometry=x,R.distanceSq=E}}else{if(E===0)return d[C]=!0,s(w,l,x);r.push(d[C]={feature:w,layer:l,geometry:x,distanceSq:E,callback:s})}},g=this.renderedTiles,m=B(l),_=l.getDeclutter(),p=_?e.declutter?.[_]?.all().map(w=>w.value):null;let y;t:for(let w=0,x=g.length;w<x;++w){const E=g[w],C=c.getTileCoordExtent(E.wrappedTileCoord);if(!ct(C,u))continue;const R=E.executorGroups[m];for(let S=0,b=R.length;S<b;++S)if(y=R[S].forEachFeatureAtCoordinate(t,o,a,i,f,p),y)break t}return y}getFeatures(t){return this.renderedTiles.length===0?Promise.resolve([]):new Promise((e,i)=>{const s=this.getLayer(),r=s.getSource(),o=this.renderedProjection,a=o.getExtent(),l=this.renderedResolution,h=r.getTileGridForProjection(o),c=gt(this.renderedPixelToCoordinateTransform_,t.slice()),u=h.getTileCoordForCoordAndResolution(c,l).toString(),d=this.renderedTiles.find(w=>w.tileCoord.toString()===u&&w.getState()===O.LOADED);if(!d||d.loadingSourceTiles>0){e([]);return}r.getWrapX()&&o.canWrapX()&&!Oi(a,h.getTileCoordExtent(d.tileCoord))&&Fo(c,o);const f=B(s),g=h.getTileCoordExtent(d.wrappedTileCoord),m=hi(g),_=[(c[0]-m[0])/l,(m[1]-c[1])/l],p=d.getSourceTiles().reduce((w,x)=>w.concat(x.getFeatures()),[]);let y=d.hitDetectionImageData[f];if(!y){const w=Rt(h.getTileSize(h.getZForResolution(l,r.zDirection))),x=this.renderedRotation_,E=[this.getRenderTransform(h.getTileCoordCenter(d.wrappedTileCoord),l,0,Jt,w[0]*Jt,w[1]*Jt,0)];y=Uc(w,E,p,s.getStyleFunction(),h.getTileCoordExtent(d.wrappedTileCoord),d.getReplayState(s).renderedResolution,x),d.hitDetectionImageData[f]=y}e(Zc(_,p,y))})}getFeaturesInExtent(t){const e=[],i=this.getTileCache();if(i.getCount()===0)return e;const r=this.getLayer().getSource().getTileGridForProjection(this.frameState.viewState.projection),o=r.getZForResolution(this.renderedResolution),a={};return i.forEach(l=>{if(l.tileCoord[0]!==o||l.getState()!==O.LOADED)return;const h=l.getSourceTiles();for(let c=0,u=h.length;c<u;++c){const d=h[c],f=d.getKey();if(f in a)continue;a[f]=!0;const g=d.tileCoord;if(ct(t,r.getTileCoordExtent(g))){const m=d.getFeatures();if(m)for(let _=0,p=m.length;_<p;++_){const y=m[_],w=y.getGeometry();ct(t,w.getExtent())&&e.push(y)}}}}),e}handleFontsChanged(){const t=this.getLayer();t.getVisible()&&this.renderedLayerRevision_!==void 0&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}renderDeclutter(t,e){const i=this.context,s=i.globalAlpha;i.globalAlpha=e.opacity;const r=t.viewHints,o=!(r[at.ANIMATING]||r[at.INTERACTING]),a=[this.context.canvas.width,this.context.canvas.height],l=this.getLayer().getDeclutter(),h=l?t.declutter?.[l]:void 0,c=B(this.getLayer()),u=this.renderedTiles;for(let d=0,f=u.length;d<f;++d){const g=u[d],m=g.executorGroups[c];if(m)for(let _=m.length-1;_>=0;--_)m[_].execute(this.context,a,this.getTileRenderTransform(g,t),t.viewState.rotation,o,Br,h)}i.globalAlpha=s}renderDeferredInternal(t){const e=this.renderedTiles,i=B(this.getLayer()),s=e.reduce((l,h,c)=>(h.executorGroups[i].forEach(u=>l.push({executorGroup:u,index:c})),l),[]),r=s.map(({executorGroup:l})=>l.getDeferredZIndexContexts()),o={};for(let l=0,h=s.length;l<h;++l){const c=s[l].executorGroup.getDeferredZIndexContexts();for(const u in c)o[u]=!0}Object.keys(o).map(Number).sort(Te).forEach(l=>{r.forEach((h,c)=>{h[l]&&(h[l].forEach(u=>{const{executorGroup:d,index:f}=s[c],g=d.getRenderedContext(),m=g.globalAlpha;g.globalAlpha=this.renderedOpacity_;const _=this.tileClipContexts_[f];_&&_.draw(g),u.draw(g),_&&g.restore(),g.globalAlpha=m,u.clear()}),h[l].length=0)})})}getTileRenderTransform(t,e){const i=e.pixelRatio,s=e.viewState,r=s.center,o=s.resolution,a=s.rotation,l=e.size,h=Math.round(l[0]*i),c=Math.round(l[1]*i),d=this.getLayer().getSource().getTileGridForProjection(e.viewState.projection),f=t.tileCoord,g=d.getTileCoordExtent(t.wrappedTileCoord),m=d.getTileCoordExtent(f,this.tempExtent)[0]-g[0];return jo(Zo(this.inversePixelTransform.slice(),1/i,1/i),this.getRenderTransform(r,o,a,i,h,c,m))}postRender(t,e){const i=e.viewHints,s=!(i[at.ANIMATING]||i[at.INTERACTING]);this.renderedPixelToCoordinateTransform_=e.pixelToCoordinateTransform.slice(),this.renderedRotation_=e.viewState.rotation,this.renderedOpacity_=e.layerStatesArray[e.layerIndex].opacity;const r=this.getLayer(),o=r.getRenderMode(),a=t.globalAlpha;t.globalAlpha=this.renderedOpacity_;const l=r.getDeclutter(),h=l?Wu[o].filter(E=>!Br.includes(E)):Wu[o],c=e.viewState,u=c.rotation,d=r.getSource(),g=d.getTileGridForProjection(c.projection).getZForResolution(c.resolution,d.zDirection),m=this.renderedTiles,_=[],p=[],y=[],w=B(r);let x=!0;for(let E=m.length-1;E>=0;--E){const C=m[E];x=x&&!C.getReplayState(r).dirty;const R=C.executorGroups[w].filter(M=>M.hasExecutors(h));if(R.length===0)continue;const S=this.getTileRenderTransform(C,e),b=C.tileCoord[0];let v=!1;const I=R[0].getClipCoords(S);let A=t,F;if(I){F=new La,A=F.getContext();for(let M=0,N=_.length;M<N;++M)if(g!==b&&b<p[M]){const L=_[M];ct([I[0],I[3],I[4],I[7]],[L[0],L[3],L[4],L[7]])&&(v||(A.save(),v=!0),A.beginPath(),A.moveTo(I[0],I[1]),A.lineTo(I[2],I[3]),A.lineTo(I[4],I[5]),A.lineTo(I[6],I[7]),A.moveTo(L[6],L[7]),A.lineTo(L[4],L[5]),A.lineTo(L[2],L[3]),A.lineTo(L[0],L[1]),A.clip())}_.push(I),p.push(b)}for(let M=0,N=R.length;M<N;++M)R[M].execute(t,[t.canvas.width,t.canvas.height],S,u,s,h,e.declutter?.[l]);v&&(A===t?A.restore():y[E]=F)}t.globalAlpha=a,this.ready=x,this.tileClipContexts_=y,e.declutter||this.renderDeferredInternal(e),super.postRender(t,e)}renderFeature(t,e,i,s,r,o){if(!i)return!1;let a=!1;if(Array.isArray(i))for(let l=0,h=i.length;l<h;++l)a=Fr(s,t,i[l],e,this.boundHandleStyleImageChange_,void 0,r,o)||a;else a=Fr(s,t,i,e,this.boundHandleStyleImageChange_,void 0,r,o);return a}tileImageNeedsRender_(t){const e=this.getLayer();if(e.getRenderMode()==="vector")return!1;const i=t.getReplayState(e),s=e.getRevision(),r=t.wantedResolution;return i.renderedTileResolution!==r||i.renderedTileRevision!==s}renderTileImage_(t,e){const i=this.getLayer(),s=t.getReplayState(i),r=i.getRevision(),o=t.executorGroups[B(i)];s.renderedTileRevision=r;const a=t.wrappedTileCoord,l=a[0],h=i.getSource();let c=e.pixelRatio;const d=e.viewState.projection,f=h.getTileGridForProjection(d),g=f.getResolution(t.tileCoord[0]),m=e.pixelRatio/t.wantedResolution*g,_=f.getResolution(l),p=t.getContext();c=Math.round(Math.max(c,m/c));const y=h.getTilePixelSize(l,c,d);p.canvas.width=y[0],p.canvas.height=y[1];const w=c/m;if(w!==1){const R=Bh(this.tmpTransform_);Zo(R,w,w),p.setTransform.apply(p,R)}const x=f.getTileCoordExtent(a,this.tempExtent),E=m/_,C=Bh(this.tmpTransform_);Zo(C,E,-E),wg(C,-x[0],-x[3]);for(let R=0,S=o.length;R<S;++R)o[R].execute(p,[p.canvas.width*w,p.canvas.height*w],C,0,!0,x0[i.getRenderMode()],null);s.renderedTileResolution=t.wantedResolution}}class w0 extends Ba{constructor(t){t=t||{};const e=Object.assign({},t);delete e.preload;const i=t.cacheSize===void 0?0:t.cacheSize;delete t.cacheSize,delete e.useInterimTilesOnError,super(e),this.on,this.once,this.un,this.cacheSize_=i;const s=t.renderMode||"hybrid";J(s=="hybrid"||s=="vector","`renderMode` must be `'hybrid'` or `'vector'`"),this.renderMode_=s,this.setPreload(t.preload?t.preload:0),this.setUseInterimTilesOnError(t.useInterimTilesOnError!==void 0?t.useInterimTilesOnError:!0),this.getBackground,this.setBackground}createRenderer(){return new E0(this,{cacheSize:this.cacheSize_})}getFeatures(t){return super.getFeatures(t)}getFeaturesInExtent(t){return this.getRenderer().getFeaturesInExtent(t)}getRenderMode(){return this.renderMode_}getPreload(){return this.get(Ri.PRELOAD)}getUseInterimTilesOnError(){return this.get(Ri.USE_INTERIM_TILES_ON_ERROR)}setPreload(t){this.set(Ri.PRELOAD,t)}setUseInterimTilesOnError(t){this.set(Ri.USE_INTERIM_TILES_ON_ERROR,t)}}class v0 extends io{constructor(t){const e=t.projection||"EPSG:3857",i=t.extent||eo(e),s=t.tileGrid||Fu({extent:i,maxResolution:t.maxResolution,maxZoom:t.maxZoom!==void 0?t.maxZoom:22,minZoom:t.minZoom,tileSize:t.tileSize||512});super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,cacheSize:t.cacheSize,interpolate:!0,projection:e,state:t.state,tileGrid:s,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:C0,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:t.wrapX===void 0?!0:t.wrapX,transition:t.transition,zDirection:t.zDirection===void 0?1:t.zDirection}),this.format_=t.format?t.format:null,this.tileKeysBySourceTileUrl_={},this.sourceTiles_={},this.overlaps_=t.overlaps==null?!0:t.overlaps,this.tileClass=t.tileClass?t.tileClass:Yp,this.tileGrids_={}}getOverlaps(){return this.overlaps_}getSourceTiles(t,e,i){if(i.getState()===O.IDLE){i.setState(O.LOADING);const s=i.wrappedTileCoord,r=this.getTileGridForProjection(e);let o=r.getTileCoordExtent(s);const a=s[0],l=r.getResolution(a);li(o,-l,o);const h=this.projection;e&&this.projection&&!Ut(e,h)&&(o=vr(o,e,h));const c=this.tileGrid,u=c.getExtent();u&&Ge(o,u,o);let d=l;e&&h&&!Ut(e,h)&&(d=l/h.getMetersPerUnit()/e.getMetersPerUnit());const f=c.getZForResolution(d,this.zDirection);c.forEachTileCoord(o,f,g=>{const m=this.tileUrlFunction(g,t,e);this.sourceTiles_[m]||(this.sourceTiles_[m]=new this.tileClass(g,m?O.IDLE:O.EMPTY,m,this.format_,this.tileLoadFunction));const _=this.sourceTiles_[m];i.sourceTiles.push(_),this.tileKeysBySourceTileUrl_[m]||(this.tileKeysBySourceTileUrl_[m]=[]),this.tileKeysBySourceTileUrl_[m].push(i.getKey());const p=_.getState();if(p<O.LOADED){const y=w=>{this.handleTileChange(w);const x=_.getState();if(x===O.LOADED||x===O.ERROR){const E=_.getKey();E in i.errorTileKeys?_.getState()===O.LOADED&&delete i.errorTileKeys[E]:i.loadingSourceTiles--,x===O.ERROR?i.errorTileKeys[E]=!0:_.removeEventListener(V.CHANGE,y),i.loadingSourceTiles===0&&i.setState(Fi(i.errorTileKeys)?O.LOADED:O.ERROR)}};_.addEventListener(V.CHANGE,y),i.loadingSourceTiles++}p===O.IDLE&&(_.extent=c.getTileCoordExtent(g),_.projection=this.projection,_.resolution=c.getResolution(g[0]),_.load())}),i.loadingSourceTiles||i.setState(i.sourceTiles.some(g=>g.getState()===O.ERROR)?O.ERROR:O.LOADED)}return i.sourceTiles}removeSourceTiles(t){const e=t.getKey(),i=t.sourceTiles;for(let s=0,r=i.length;s<r;++s){const o=i[s].getTileUrl();if(!this.tileKeysBySourceTileUrl_[o])return;const a=this.tileKeysBySourceTileUrl_[o].indexOf(e);a!==-1&&(this.tileKeysBySourceTileUrl_[o].splice(a,1),this.tileKeysBySourceTileUrl_[o].length===0&&(delete this.tileKeysBySourceTileUrl_[o],delete this.sourceTiles_[o]))}}getTile(t,e,i,s,r){const o=[t,e,i];let a=this.getTileCoordForTileUrlFunction(o,r);const l=this.getTileGrid().getExtent(),h=this.projection,c=this.getTileGridForProjection(r);if(a&&l){const f=c.getTileCoordExtent(a);li(f,-c.getResolution(t),f),ct(l,!r||!h||Ut(r,h)?f:vr(f,r,h))||(a=null)}let u=!0;if(a!==null){const f=this.tileGrid,g=c.getResolution(t);let m=g;r&&h&&!Ut(r,h)&&(m=g/h.getMetersPerUnit()/r.getMetersPerUnit());const _=f.getZForResolution(m,1),p=c.getTileCoordExtent(a);li(p,-g,p),f.forEachTileCoord(!r||!h||Ut(r,h)?p:vr(p,r,h),_,y=>{u=u&&!this.tileUrlFunction(y,s,h)})}const d=new Xp(o,u?O.EMPTY:O.IDLE,a,this.getSourceTiles.bind(this,s,r),this.removeSourceTiles.bind(this));return d.key=this.getKey(),d}getTileGridForProjection(t){const e=t.getCode();let i=this.tileGrids_[e];if(!i){const s=this.projection;if(s!==null&&!Ut(s,t))return il(t);const r=this.tileGrid,o=r.getResolutions().slice(),a=o.map(function(c,u){return r.getOrigin(u)}),l=o.map(function(c,u){return r.getTileSize(u)}),h=pu+1;for(let c=o.length;c<h;++c)o.push(o[c-1]/2),a.push(a[c-1]),l.push(l[c-1]);i=new el({extent:r.getExtent(),origins:a,resolutions:o,tileSizes:l}),this.tileGrids_[e]=i}return i}getTilePixelRatio(t){return t}getTilePixelSize(t,e,i){const s=this.getTileGridForProjection(i),r=Rt(s.getTileSize(t),this.tmpSize);return[Math.round(r[0]*e),Math.round(r[1]*e)]}setOverlaps(t){this.overlaps_=t,this.changed()}}function C0(n,t){n.setLoader(function(e,i,s){Ic(t,n.getFormat(),e,i,s,n.onLoad.bind(n),n.onError.bind(n))})}const ol=65536*65536,Vu=1/ol,T0=12,Bu=typeof TextDecoder>"u"?null:new TextDecoder("utf-8"),al=0,no=1,As=2,so=5;class R0{constructor(t=new Uint8Array(16)){this.buf=ArrayBuffer.isView(t)?t:new Uint8Array(t),this.dataView=new DataView(this.buf.buffer),this.pos=0,this.type=0,this.length=this.buf.length}readFields(t,e,i=this.length){for(;this.pos<i;){const s=this.readVarint(),r=s>>3,o=this.pos;this.type=s&7,t(r,e,this),this.pos===o&&this.skip(s)}return e}readMessage(t,e){return this.readFields(t,e,this.readVarint()+this.pos)}readFixed32(){const t=this.dataView.getUint32(this.pos,!0);return this.pos+=4,t}readSFixed32(){const t=this.dataView.getInt32(this.pos,!0);return this.pos+=4,t}readFixed64(){const t=this.dataView.getUint32(this.pos,!0)+this.dataView.getUint32(this.pos+4,!0)*ol;return this.pos+=8,t}readSFixed64(){const t=this.dataView.getUint32(this.pos,!0)+this.dataView.getInt32(this.pos+4,!0)*ol;return this.pos+=8,t}readFloat(){const t=this.dataView.getFloat32(this.pos,!0);return this.pos+=4,t}readDouble(){const t=this.dataView.getFloat64(this.pos,!0);return this.pos+=8,t}readVarint(t){const e=this.buf;let i,s;return s=e[this.pos++],i=s&127,s<128||(s=e[this.pos++],i|=(s&127)<<7,s<128)||(s=e[this.pos++],i|=(s&127)<<14,s<128)||(s=e[this.pos++],i|=(s&127)<<21,s<128)?i:(s=e[this.pos],i|=(s&15)<<28,S0(i,t,this))}readVarint64(){return this.readVarint(!0)}readSVarint(){const t=this.readVarint();return t%2===1?(t+1)/-2:t/2}readBoolean(){return!!this.readVarint()}readString(){const t=this.readVarint()+this.pos,e=this.pos;return this.pos=t,t-e>=T0&&Bu?Bu.decode(this.buf.subarray(e,t)):z0(this.buf,e,t)}readBytes(){const t=this.readVarint()+this.pos,e=this.buf.subarray(this.pos,t);return this.pos=t,e}readPackedVarint(t=[],e){const i=this.readPackedEnd();for(;this.pos<i;)t.push(this.readVarint(e));return t}readPackedSVarint(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readSVarint());return t}readPackedBoolean(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readBoolean());return t}readPackedFloat(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readFloat());return t}readPackedDouble(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readDouble());return t}readPackedFixed32(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readFixed32());return t}readPackedSFixed32(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readSFixed32());return t}readPackedFixed64(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readFixed64());return t}readPackedSFixed64(t=[]){const e=this.readPackedEnd();for(;this.pos<e;)t.push(this.readSFixed64());return t}readPackedEnd(){return this.type===As?this.readVarint()+this.pos:this.pos+1}skip(t){const e=t&7;if(e===al)for(;this.buf[this.pos++]>127;);else if(e===As)this.pos=this.readVarint()+this.pos;else if(e===so)this.pos+=4;else if(e===no)this.pos+=8;else throw new Error(`Unimplemented type: ${e}`)}writeTag(t,e){this.writeVarint(t<<3|e)}realloc(t){let e=this.length||16;for(;e<this.pos+t;)e*=2;if(e!==this.length){const i=new Uint8Array(e);i.set(this.buf),this.buf=i,this.dataView=new DataView(i.buffer),this.length=e}}finish(){return this.length=this.pos,this.pos=0,this.buf.subarray(0,this.length)}writeFixed32(t){this.realloc(4),this.dataView.setInt32(this.pos,t,!0),this.pos+=4}writeSFixed32(t){this.realloc(4),this.dataView.setInt32(this.pos,t,!0),this.pos+=4}writeFixed64(t){this.realloc(8),this.dataView.setInt32(this.pos,t&-1,!0),this.dataView.setInt32(this.pos+4,Math.floor(t*Vu),!0),this.pos+=8}writeSFixed64(t){this.realloc(8),this.dataView.setInt32(this.pos,t&-1,!0),this.dataView.setInt32(this.pos+4,Math.floor(t*Vu),!0),this.pos+=8}writeVarint(t){if(t=+t||0,t>268435455||t<0){I0(t,this);return}this.realloc(4),this.buf[this.pos++]=t&127|(t>127?128:0),!(t<=127)&&(this.buf[this.pos++]=(t>>>=7)&127|(t>127?128:0),!(t<=127)&&(this.buf[this.pos++]=(t>>>=7)&127|(t>127?128:0),!(t<=127)&&(this.buf[this.pos++]=t>>>7&127)))}writeSVarint(t){this.writeVarint(t<0?-t*2-1:t*2)}writeBoolean(t){this.writeVarint(+t)}writeString(t){t=String(t),this.realloc(t.length*4),this.pos++;const e=this.pos;this.pos=X0(this.buf,t,this.pos);const i=this.pos-e;i>=128&&$u(e,i,this),this.pos=e-1,this.writeVarint(i),this.pos+=i}writeFloat(t){this.realloc(4),this.dataView.setFloat32(this.pos,t,!0),this.pos+=4}writeDouble(t){this.realloc(8),this.dataView.setFloat64(this.pos,t,!0),this.pos+=8}writeBytes(t){const e=t.length;this.writeVarint(e),this.realloc(e);for(let i=0;i<e;i++)this.buf[this.pos++]=t[i]}writeRawMessage(t,e){this.pos++;const i=this.pos;t(e,this);const s=this.pos-i;s>=128&&$u(i,s,this),this.pos=i-1,this.writeVarint(s),this.pos+=s}writeMessage(t,e,i){this.writeTag(t,As),this.writeRawMessage(e,i)}writePackedVarint(t,e){e.length&&this.writeMessage(t,A0,e)}writePackedSVarint(t,e){e.length&&this.writeMessage(t,P0,e)}writePackedBoolean(t,e){e.length&&this.writeMessage(t,O0,e)}writePackedFloat(t,e){e.length&&this.writeMessage(t,M0,e)}writePackedDouble(t,e){e.length&&this.writeMessage(t,F0,e)}writePackedFixed32(t,e){e.length&&this.writeMessage(t,D0,e)}writePackedSFixed32(t,e){e.length&&this.writeMessage(t,k0,e)}writePackedFixed64(t,e){e.length&&this.writeMessage(t,N0,e)}writePackedSFixed64(t,e){e.length&&this.writeMessage(t,G0,e)}writeBytesField(t,e){this.writeTag(t,As),this.writeBytes(e)}writeFixed32Field(t,e){this.writeTag(t,so),this.writeFixed32(e)}writeSFixed32Field(t,e){this.writeTag(t,so),this.writeSFixed32(e)}writeFixed64Field(t,e){this.writeTag(t,no),this.writeFixed64(e)}writeSFixed64Field(t,e){this.writeTag(t,no),this.writeSFixed64(e)}writeVarintField(t,e){this.writeTag(t,al),this.writeVarint(e)}writeSVarintField(t,e){this.writeTag(t,al),this.writeSVarint(e)}writeStringField(t,e){this.writeTag(t,As),this.writeString(e)}writeFloatField(t,e){this.writeTag(t,so),this.writeFloat(e)}writeDoubleField(t,e){this.writeTag(t,no),this.writeDouble(e)}writeBooleanField(t,e){this.writeVarintField(t,+e)}}function S0(n,t,e){const i=e.buf;let s,r;if(r=i[e.pos++],s=(r&112)>>4,r<128||(r=i[e.pos++],s|=(r&127)<<3,r<128)||(r=i[e.pos++],s|=(r&127)<<10,r<128)||(r=i[e.pos++],s|=(r&127)<<17,r<128)||(r=i[e.pos++],s|=(r&127)<<24,r<128)||(r=i[e.pos++],s|=(r&1)<<31,r<128))return Fn(n,s,t);throw new Error("Expected varint not more than 10 bytes")}function Fn(n,t,e){return e?t*4294967296+(n>>>0):(t>>>0)*4294967296+(n>>>0)}function I0(n,t){let e,i;if(n>=0?(e=n%4294967296|0,i=n/4294967296|0):(e=~(-n%4294967296),i=~(-n/4294967296),e^4294967295?e=e+1|0:(e=0,i=i+1|0)),n>=18446744073709552e3||n<-18446744073709552e3)throw new Error("Given varint doesn't fit into 10 bytes");t.realloc(10),b0(e,i,t),L0(i,t)}function b0(n,t,e){e.buf[e.pos++]=n&127|128,n>>>=7,e.buf[e.pos++]=n&127|128,n>>>=7,e.buf[e.pos++]=n&127|128,n>>>=7,e.buf[e.pos++]=n&127|128,n>>>=7,e.buf[e.pos]=n&127}function L0(n,t){const e=(n&7)<<4;t.buf[t.pos++]|=e|((n>>>=3)?128:0),n&&(t.buf[t.pos++]=n&127|((n>>>=7)?128:0),n&&(t.buf[t.pos++]=n&127|((n>>>=7)?128:0),n&&(t.buf[t.pos++]=n&127|((n>>>=7)?128:0),n&&(t.buf[t.pos++]=n&127|((n>>>=7)?128:0),n&&(t.buf[t.pos++]=n&127)))))}function $u(n,t,e){const i=t<=16383?1:t<=2097151?2:t<=268435455?3:Math.floor(Math.log(t)/(Math.LN2*7));e.realloc(i);for(let s=e.pos-1;s>=n;s--)e.buf[s+i]=e.buf[s]}function A0(n,t){for(let e=0;e<n.length;e++)t.writeVarint(n[e])}function P0(n,t){for(let e=0;e<n.length;e++)t.writeSVarint(n[e])}function M0(n,t){for(let e=0;e<n.length;e++)t.writeFloat(n[e])}function F0(n,t){for(let e=0;e<n.length;e++)t.writeDouble(n[e])}function O0(n,t){for(let e=0;e<n.length;e++)t.writeBoolean(n[e])}function D0(n,t){for(let e=0;e<n.length;e++)t.writeFixed32(n[e])}function k0(n,t){for(let e=0;e<n.length;e++)t.writeSFixed32(n[e])}function N0(n,t){for(let e=0;e<n.length;e++)t.writeFixed64(n[e])}function G0(n,t){for(let e=0;e<n.length;e++)t.writeSFixed64(n[e])}function z0(n,t,e){let i="",s=t;for(;s<e;){const r=n[s];let o=null,a=r>239?4:r>223?3:r>191?2:1;if(s+a>e)break;let l,h,c;a===1?r<128&&(o=r):a===2?(l=n[s+1],(l&192)===128&&(o=(r&31)<<6|l&63,o<=127&&(o=null))):a===3?(l=n[s+1],h=n[s+2],(l&192)===128&&(h&192)===128&&(o=(r&15)<<12|(l&63)<<6|h&63,(o<=2047||o>=55296&&o<=57343)&&(o=null))):a===4&&(l=n[s+1],h=n[s+2],c=n[s+3],(l&192)===128&&(h&192)===128&&(c&192)===128&&(o=(r&15)<<18|(l&63)<<12|(h&63)<<6|c&63,(o<=65535||o>=1114112)&&(o=null))),o===null?(o=65533,a=1):o>65535&&(o-=65536,i+=String.fromCharCode(o>>>10&1023|55296),o=56320|o&1023),i+=String.fromCharCode(o),s+=a}return i}function X0(n,t,e){for(let i=0,s,r;i<t.length;i++){if(s=t.charCodeAt(i),s>55295&&s<57344)if(r)if(s<56320){n[e++]=239,n[e++]=191,n[e++]=189,r=s;continue}else s=r-55296<<10|s-56320|65536,r=null;else{s>56319||i+1===t.length?(n[e++]=239,n[e++]=191,n[e++]=189):r=s;continue}else r&&(n[e++]=239,n[e++]=191,n[e++]=189,r=null);s<128?n[e++]=s:(s<2048?n[e++]=s>>6|192:(s<65536?n[e++]=s>>12|224:(n[e++]=s>>18|240,n[e++]=s>>12&63|128),n[e++]=s>>6&63|128),n[e++]=s&63|128)}return e}class Y0{constructor(){this.dataProjection=void 0,this.defaultFeatureProjection=void 0,this.featureClass=ar,this.supportedMediaTypes=null}getReadOptions(t,e){if(e){let i=e.dataProjection?ft(e.dataProjection):this.readProjection(t);e.extent&&i&&i.getUnits()==="tile-pixels"&&(i=ft(i),i.setWorldExtent(e.extent)),e={dataProjection:i,featureProjection:e.featureProjection}}return this.adaptOptions(e)}adaptOptions(t){return Object.assign({dataProjection:this.dataProjection,featureProjection:this.defaultFeatureProjection,featureClass:this.featureClass},t)}getType(){return j()}readFeature(t,e){return j()}readFeatures(t,e){return j()}readGeometry(t,e){return j()}readProjection(t){return j()}writeFeature(t,e){return j()}writeFeatures(t,e){return j()}writeGeometry(t,e){return j()}}function W0(n,t,e){const i=e?ft(e.featureProjection):null,s=e?ft(e.dataProjection):null;let r=n;if(i&&s&&!Ut(i,s)){const o=s,a=i;o.getUnits()==="tile-pixels"?r.transform(o,a):r.applyTransform(zi(o,a))}return r}class V0 extends Y0{constructor(t){super(),t=t||{},this.dataProjection=new _r({code:"",units:"tile-pixels"}),this.featureClass=t.featureClass?t.featureClass:Ht,this.geometryName_=t.geometryName,this.layerName_=t.layerName?t.layerName:"layer",this.layers_=t.layers?t.layers:null,this.idProperty_=t.idProperty,this.supportedMediaTypes=["application/vnd.mapbox-vector-tile","application/x-protobuf"]}readRawGeometry_(t,e,i,s){t.pos=e.geometry;const r=t.readVarint()+t.pos;let o=1,a=0,l=0,h=0,c=0,u=0;for(;t.pos<r;){if(!a){const d=t.readVarint();o=d&7,a=d>>3}if(a--,o===1||o===2)l+=t.readSVarint(),h+=t.readSVarint(),o===1&&c>u&&(s.push(c),u=c),i.push(l,h),c+=2;else if(o===7)c>u&&(i.push(i[u],i[u+1]),c+=2);else throw new Error("Invalid command found in the PBF")}c>u&&(s.push(c),u=c)}createFeature_(t,e,i){const s=e.type;if(s===0)return null;let r;const o=e.properties;let a;this.idProperty_?(a=o[this.idProperty_],delete o[this.idProperty_]):a=e.id,o[this.layerName_]=e.layer.name;const l=[],h=[];this.readRawGeometry_(t,e,l,h);const c=U0(s,h.length);if(this.featureClass===Ht)r=new this.featureClass(c,l,h,2,o,a),r.transform(i.dataProjection);else{let u;if(c=="Polygon"){const g=rc(l,h);u=g.length>1?new kr(l,"XY",g):new gi(l,"XY",h)}else u=c==="Point"?new Wi(l,"XY"):c==="LineString"?new gn(l,"XY"):c==="MultiPoint"?new Dr(l,"XY"):c==="MultiLineString"?new Or(l,"XY",h):null;const d=this.featureClass;r=new d,this.geometryName_&&r.setGeometryName(this.geometryName_);const f=W0(u,!1,i);r.setGeometry(f),a!==void 0&&r.setId(a),r.setProperties(o,!0)}return r}getType(){return"arraybuffer"}readFeatures(t,e){const i=this.layers_;e=this.adaptOptions(e);const s=ft(e.dataProjection);s.setWorldExtent(e.extent),e.dataProjection=s;const r=new R0(t),o=r.readFields(B0,{}),a=[];for(const l in o){if(i&&!i.includes(l))continue;const h=o[l],c=h?[0,0,h.extent,h.extent]:null;s.setExtent(c);for(let u=0,d=h.length;u<d;++u){const f=j0(r,h,u),g=this.createFeature_(r,f,e);g!==null&&a.push(g)}}return a}readProjection(t){return this.dataProjection}setLayers(t){this.layers_=t}}function B0(n,t,e){if(n===3){const i={keys:[],values:[],features:[]},s=e.readVarint()+e.pos;e.readFields($0,i,s),i.length=i.features.length,i.length&&(t[i.name]=i)}}function $0(n,t,e){if(n===15)t.version=e.readVarint();else if(n===1)t.name=e.readString();else if(n===5)t.extent=e.readVarint();else if(n===2)t.features.push(e.pos);else if(n===3)t.keys.push(e.readString());else if(n===4){let i=null;const s=e.readVarint()+e.pos;for(;e.pos<s;)n=e.readVarint()>>3,i=n===1?e.readString():n===2?e.readFloat():n===3?e.readDouble():n===4?e.readVarint64():n===5?e.readVarint():n===6?e.readSVarint():n===7?e.readBoolean():null;t.values.push(i)}}function K0(n,t,e){if(n==1)t.id=e.readVarint();else if(n==2){const i=e.readVarint()+e.pos;for(;e.pos<i;){const s=t.layer.keys[e.readVarint()],r=t.layer.values[e.readVarint()];t.properties[s]=r}}else n==3?t.type=e.readVarint():n==4&&(t.geometry=e.pos)}function j0(n,t,e){n.pos=t.features[e];const i=n.readVarint()+n.pos,s={layer:t,type:0,properties:{}};return n.readFields(K0,s,i),s}function U0(n,t){let e;return n===1?e=t===1?"Point":"MultiPoint":n===2?e=t===1?"LineString":"MultiLineString":n===3&&(e="Polygon"),e}const Ku=`
|
|
9
9
|
.ol-box {
|
|
10
10
|
box-sizing: border-box;
|
|
11
11
|
border-radius: 2px;
|
|
@@ -327,5 +327,5 @@
|
|
|
327
327
|
content: "✖";
|
|
328
328
|
}
|
|
329
329
|
|
|
330
|
-
`;function
|
|
330
|
+
`;function Z0(n,t=100,e={}){if(typeof n!="function")throw new TypeError(`Expected the first parameter to be a function, got \`${typeof n}\`.`);if(t<0)throw new RangeError("`wait` must not be negative.");if(typeof e=="boolean")throw new TypeError("The `options` parameter must be an object, not a boolean. Use `{immediate: true}` instead.");const{immediate:i}=e;let s,r,o,a,l;function h(){const d=s,f=r;return s=void 0,r=void 0,l=n.apply(d,f),l}function c(){const d=Date.now()-a;d<t&&d>=0?o=setTimeout(c,t-d):(o=void 0,i||(l=h()))}const u=function(...d){if(s&&this!==s&&Object.getPrototypeOf(this)===Object.getPrototypeOf(s))throw new Error("Debounced method called with different contexts of the same prototype.");s=this,r=d,a=Date.now();const f=i&&!o;if(o||(o=setTimeout(c,t)),f)return l=h(),l};return Object.defineProperty(u,"isPending",{get(){return o!==void 0}}),u.clear=()=>{o&&(clearTimeout(o),o=void 0,s=void 0,r=void 0)},u.flush=()=>{o&&u.trigger()},u.trigger=()=>{l=h(),u.clear()},u}var H0=df('<div id="map" style="width: 100%; height: 100%;"></div> <div id="popup" class="ol-popup"><button id="popup-closer" class="ol-popup-closer" aria-label="Close popup"></button> <div id="popup-content"></div></div>',1);const q0={hash:"svelte-1nwnfh0",code:":host {display:block;height:200px;width:200px;}"};function ju(n,t){Al(t,!0),yf(n,q0);function e(v,I){t.$$host.dispatchEvent(new CustomEvent(v,{detail:I}))}let i=ie(null),s=ie(null),r=ie(void 0),o=ie(null),a,l=Mi(t,"id",7,""),h=Mi(t,"center",23,()=>[37.5176038,15.0819224]),c=Mi(t,"zoom",7,6),u=Mi(t,"source",23,()=>({type:"osm"})),d=Mi(t,"options",23,()=>({})),f=Mi(t,"data",23,()=>[]),g=Mi(t,"screenshot",7,"");xo(()=>{let v=!1;typeof u()=="string"&&(u(JSON.parse(u())),v=!0),d()&&typeof d()=="string"&&(d(JSON.parse(d())),v=!0),typeof c()=="string"&&(c(Number(c())),v=!0),typeof h()=="string"&&(h(JSON.parse(h())),v=!0),typeof f()=="string"&&(f(JSON.parse(f())),v=!0),v&&w()}),xo(()=>{g()==="yes"&&Z(i)&&m()});function m(){!Z(i)||!Z(s)||(Z(i).once("rendercomplete",function(){const v=Z(i).getSize();if(!v)return;const I=document.createElement("canvas");I.width=v[0],I.height=v[1];const A=I.getContext("2d");if(!A)return;Z(s).querySelectorAll(".ol-layer canvas").forEach(function(N){if(N.width>0){const k=N.parentNode?.style?.opacity;A.globalAlpha=!k||k===""?1:Number(k);const X=N.style.transform.match(/^matrix\(([^)]*)\)$/);if(X){const Y=X[1].split(",").map(Number);A.setTransform(Y[0],Y[1],Y[2],Y[3],Y[4],Y[5])}A.drawImage(N,0,0)}}),A.globalAlpha=1,A.setTransform(1,0,0,1,0,0);const M=I.toDataURL("image/png");e("screenshotTaken",{base64:M})}),Z(i).renderSync())}function _(v){const I=ns(v.coordinate,"EPSG:3857","EPSG:4326"),A=Z(i)?.getView?.()?.getCenter?.(),F=ns(A||h(),"EPSG:3857","EPSG:4326"),M=Z(i)?.getView?.()?.getZoom?.()||c(),N=Z(i)?.forEachFeatureAtPixel(v.pixel,function(L,k){return L});N&&N.get("marker")?(e("markerClick",{coordinates:{latitude:I[1],longitude:I[0]},id:N.get("id")}),N.get("popupHtml")&&Z(o)?.innerHTML&&(Z(o).innerHTML=N.get("popupHtml"),a?.setPosition(v.coordinate))):(a?.setPosition(void 0),e("pointClickCoordinates",{coordinates:{latitude:I[1],longitude:I[0]},zoom:M,center:F}))}const p={positron:{water:"#aad3df",waterway:"#aad3df",park:"#d8e8c8",landcover:"#e8e4de",landuse:"#ededed",building:"#d9d0c9",buildingStroke:"#cfcdca",road:"#ffffff",roadCasing:"#cfcdca",motorway:"#f0c070",primary:"#fbe29a",rail:"#bfbfbf",boundary:"#b3b3b3"},dark_matter:{water:"#0e1626",waterway:"#0e1626",park:"#111c11",landcover:"#121212",landuse:"#181818",building:"#222222",buildingStroke:"#2a2a2a",road:"#3c3c3c",roadCasing:"#222222",motorway:"#4a4a4a",primary:"#444444",rail:"#333333",boundary:"#4a4a4a"},voyager:{water:"#aad3df",waterway:"#aad3df",park:"#c8facc",landcover:"#e8e4de",landuse:"#ededed",building:"#e0d8d0",buildingStroke:"#d5cec4",road:"#ffffff",roadCasing:"#e0dcd8",motorway:"#f0c56c",primary:"#fbe29a",rail:"#bfbfbf",boundary:"#9e9cab"}};function y(v){const I=p[v]||p.voyager;return function(A){switch(A.get("layer")){case"water":return new _t({fill:new qt({color:I.water})});case"waterway":return new _t({stroke:new xe({color:I.waterway,width:1})});case"park":case"landcover":return new _t({fill:new qt({color:I.landcover})});case"landuse":return new _t({fill:new qt({color:I.landuse})});case"building":return new _t({fill:new qt({color:I.building}),stroke:new xe({color:I.buildingStroke,width:.5})});case"transportation":{const M=A.get("class");let N=I.road,L=1;return M==="motorway"||M==="trunk"?(N=I.motorway,L=3):M==="primary"||M==="secondary"?(N=I.primary,L=2):M==="rail"&&(N=I.rail,L=1),new _t({stroke:new xe({color:N,width:L})})}case"boundary":return new _t({stroke:new xe({color:I.boundary,width:1,lineDash:[4,4]})});case"aeroway":return new _t({stroke:new xe({color:I.road,width:1}),fill:new qt({color:I.landuse})});case"place":case"poi":case"housenumber":case"transportation_name":case"water_name":case"aerodrome_label":case"mountain_peak":return null;default:{const M=v==="dark_matter"||v==="positron"?I.landuse:I.landcover;return new _t({fill:new qt({color:M}),stroke:new xe({color:M,width:1})})}}}}function w(){if(Z(s)){if(Z(i)){zt(i,null);const F=document.createElement("style");F.innerHTML=Ku,Z(s).innerHTML="",Z(s).appendChild(F)}const v=[];if(u().type.toLowerCase()==="osm")v.push(new Yu({source:new g0}));else if(u().type.toLowerCase()==="xyz"&&u().url)v.push(new Yu({source:new ku({url:u().url})}));else if(u().type.toLowerCase()==="carto_vector"){const F=u().style||"voyager",M=p[F]||p.voyager;v.push(new w0({source:new v0({format:new V0,url:u().url||"https://tiles-d.basemaps.cartocdn.com/vectortiles/carto.streets/v1/{z}/{x}/{y}.mvt"}),style:y(F),background:F==="dark_matter"?M.landuse:void 0}))}let I=[],A=Kt();if(f()?.filter?.(F=>F.marker)?.length){const F=[];for(const L of f().filter(k=>k.marker).map(k=>k.marker)){const k=new ar({geometry:L?.lngLat?new Wi(Vo(L.lngLat)):void 0,icon:L?.icon,marker:!0,id:L?.id||void 0,popupHtml:L?.popupHtml,label:L?.text,textPosition:L?.text_position||d().text_position||"right",textOffset:L?.text_offset??d().text_offset});F.push(k);const D=k.getGeometry()?.getCoordinates();L?.lngLat&&I.push(L.lngLat),d().centerFromGeometries&&D&&D[2]!==-1/0&&D[3]!==-1/0&&(console.log("coords",D),A=xh(A,D))}const M=new _t({image:new vn({scale:3,anchor:[.5,.8],src:"https://upload.wikimedia.org/wikipedia/commons/e/e7/Maki2-marker-18.svg"})}),N=new ip({source:new X_({features:F}),style(L){const k=L.get("icon"),D=L.get("label"),X=L.get("textPosition")||"right",Y=L.get("textOffset");let W={offsetX:0,offsetY:0,textAlign:"center",textBaseline:"middle"};if(k?.uri&&D){const yt=k.scale||.15,ot=k.anchor?.[0]??.5,kt=k.anchor?.[1]??.8,dt=yt>=1?18*yt:150*yt,Nt=-(kt-.5)*dt,bt=-(ot-.5)*dt,Et=Y??6,Ue=dt/2;switch(X){case"right":W.offsetX=bt+Ue+Et,W.offsetY=Nt+3,W.textAlign="left",W.textBaseline="middle";break;case"left":W.offsetX=bt-Ue-Et,W.offsetY=Nt+3,W.textAlign="right",W.textBaseline="middle";break;case"top":W.offsetX=bt,W.offsetY=Nt-Ue-Et,W.textAlign="center",W.textBaseline="bottom";break;case"bottom":W.offsetX=bt,W.offsetY=Nt+Ue+Et,W.textAlign="center",W.textBaseline="top";break}}const P=Math.round(13*(d().text_scale??1)),pt=D?new Xc({text:D,font:`${P}px sans-serif`,fill:new qt({color:"#333"}),stroke:new xe({color:"#fff",width:3}),...W}):void 0;return k?.uri?new _t({image:new vn({scale:k.scale||.15,anchor:k.anchor||[.5,.8],src:k.uri,opacity:k.opacity||1,color:k.color||void 0}),text:pt}):D?new _t({text:pt}):M}});v.push(N)}a=new zp({element:Z(r),autoPan:{animation:{duration:250}}}),zt(i,new Np({target:Z(s),layers:v,overlays:[a],view:new Ie({center:Vo(h()),zoom:c()})}),!0),d()?.centerFromGeometries&&I&&I.length>1&&A[2]!==-1/0&&A[3]!==-1/0?(console.log("extent",A),Z(i).getView().fit(A,{padding:[25,25,25,25]})):d()?.centerFromGeometries&&Z(i).getView().setCenter(Vo(I[0])),Z(i).on("singleclick",function(F){_(F)})}}function x(v){a?.setPosition(void 0),v?.target?.blur?.()}pf(()=>{zt(s,t.$$host?.shadowRoot?.querySelector("#map"),!0),zt(r,t.$$host?.shadowRoot?.querySelector("#popup"),!0),zt(o,t.$$host?.shadowRoot?.querySelector("#popup-content"),!0);const v=document.createElement("style");v.innerHTML=Ku,Z(s)?.appendChild(v),w()});var E={get id(){return l()},set id(v=""){l(v),ii()},get center(){return h()},set center(v=[37.5176038,15.0819224]){h(v),ii()},get zoom(){return c()},set zoom(v=6){c(v),ii()},get source(){return u()},set source(v={type:"osm"}){u(v),ii()},get options(){return d()},set options(v={}){d(v),ii()},get data(){return f()},set data(v=[]){f(v),ii()},get screenshot(){return g()},set screenshot(v=""){g(v),ii()}},C=H0(),R=Gd(()=>Z0(w,200));hf("resize",mo,function(...v){Z(R)?.apply(this,v)});var S=$d(Bd(C),2),b=Vd(S);return b.__click=v=>x(v),Il(2),bd(S),ch(n,C),Pl(E)}cf(["click"]),customElements.define("hb-map",Cf(ju,{id:{},center:{},zoom:{},source:{},options:{},data:{},screenshot:{}},[],[],!0)),gl.Component=ju,Object.defineProperty(gl,Symbol.toStringTag,{value:"Module"})})(this.map=this.map||{});
|
|
331
331
|
//# sourceMappingURL=main.iife.js.map
|